|
@ -3,6 +3,7 @@ using Microsoft.EntityFrameworkCore; |
|
|
using System; |
|
|
using System; |
|
|
using System.Collections.Generic; |
|
|
using System.Collections.Generic; |
|
|
using System.Linq; |
|
|
using System.Linq; |
|
|
|
|
|
using System.Net; |
|
|
using System.Net.NetworkInformation; |
|
|
using System.Net.NetworkInformation; |
|
|
using System.Text; |
|
|
using System.Text; |
|
|
using System.Threading; |
|
|
using System.Threading; |
|
@ -13,9 +14,11 @@ namespace ISPChk |
|
|
public class NetworkTest : INetworkTest |
|
|
public class NetworkTest : INetworkTest |
|
|
{ |
|
|
{ |
|
|
private ISPChkContext _context; |
|
|
private ISPChkContext _context; |
|
|
|
|
|
private List<Task> runningTasks; |
|
|
|
|
|
|
|
|
public NetworkTest() { |
|
|
public NetworkTest() { |
|
|
_context = CreateDbContext(); |
|
|
_context = CreateDbContext(); |
|
|
|
|
|
System.Diagnostics.Debug.WriteLine("NetworkTest instantiated."); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
public async void LoadHostsFromDatabase() |
|
|
public async void LoadHostsFromDatabase() |
|
@ -32,7 +35,7 @@ namespace ISPChk |
|
|
var optionsBuilder = new DbContextOptionsBuilder<ISPChkContext>(); |
|
|
var optionsBuilder = new DbContextOptionsBuilder<ISPChkContext>(); |
|
|
optionsBuilder.UseSqlite("Data Source=ispchk.db"); |
|
|
optionsBuilder.UseSqlite("Data Source=ispchk.db"); |
|
|
var ctx = new ISPChkContext(optionsBuilder.Options); |
|
|
var ctx = new ISPChkContext(optionsBuilder.Options); |
|
|
System.Diagnostics.Debug.WriteLine("NetworkTest instantiated."); |
|
|
System.Diagnostics.Debug.WriteLine("DbContext created."); |
|
|
ctx.Database.EnsureCreated(); |
|
|
ctx.Database.EnsureCreated(); |
|
|
return ctx; |
|
|
return ctx; |
|
|
} |
|
|
} |
|
@ -46,6 +49,30 @@ namespace ISPChk |
|
|
var h = await ctx.Hosts.FindAsync(host.HostId); |
|
|
var h = await ctx.Hosts.FindAsync(host.HostId); |
|
|
ctx.Entry(h).Collection(hst => hst.PingItems).Load(); |
|
|
ctx.Entry(h).Collection(hst => hst.PingItems).Load(); |
|
|
|
|
|
|
|
|
|
|
|
IPAddress pingAddress; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (!IPAddress.TryParse(h.HostName, out pingAddress)) |
|
|
|
|
|
{ |
|
|
|
|
|
System.Diagnostics.Debug.WriteLine("Resolving "+h.HostName); |
|
|
|
|
|
IPHostEntry hostInfo = Dns.GetHostEntry(h.HostName); |
|
|
|
|
|
foreach(var a in hostInfo.AddressList) |
|
|
|
|
|
{ |
|
|
|
|
|
if((a.AddressFamily == System.Net.Sockets.AddressFamily.InterNetworkV6 && h.IPv6 == true) || |
|
|
|
|
|
a.AddressFamily == System.Net.Sockets.AddressFamily.InterNetwork && h.IPv6 == false) |
|
|
|
|
|
{ |
|
|
|
|
|
pingAddress = a; |
|
|
|
|
|
break; |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if(pingAddress == null) |
|
|
|
|
|
{ |
|
|
|
|
|
System.Diagnostics.Debug.WriteLine("No address to ping found..."); |
|
|
|
|
|
return; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
Ping pingSender = new Ping(); |
|
|
Ping pingSender = new Ping(); |
|
|
|
|
|
|
|
|
// Create a buffer of 32 bytes of data to be transmitted.
|
|
|
// Create a buffer of 32 bytes of data to be transmitted.
|
|
@ -61,7 +88,7 @@ namespace ISPChk |
|
|
// cannot be fragmented.
|
|
|
// cannot be fragmented.
|
|
|
PingOptions options = new PingOptions(64, true); |
|
|
PingOptions options = new PingOptions(64, true); |
|
|
|
|
|
|
|
|
System.Diagnostics.Debug.WriteLine("Pinging " + host.Name); |
|
|
System.Diagnostics.Debug.WriteLine("Initiate ping to " + pingAddress); |
|
|
|
|
|
|
|
|
while (true) |
|
|
while (true) |
|
|
{ |
|
|
{ |
|
@ -73,30 +100,35 @@ namespace ISPChk |
|
|
int failures = 0; |
|
|
int failures = 0; |
|
|
for (var i = 0; i < numPings; ++i) |
|
|
for (var i = 0; i < numPings; ++i) |
|
|
{ |
|
|
{ |
|
|
// Send the request.
|
|
|
try { |
|
|
PingReply reply = pingSender.Send(host.HostName, timeout, buffer, options); |
|
|
// Send the request.
|
|
|
|
|
|
PingReply reply = pingSender.Send(pingAddress, timeout, buffer, options); |
|
|
|
|
|
|
|
|
if (reply.Status == IPStatus.Success) |
|
|
if (reply.Status == IPStatus.Success) |
|
|
{ |
|
|
|
|
|
successes++; |
|
|
|
|
|
//System.Diagnostics.Debug.WriteLine("Reply from " + reply.Address.ToString() +
|
|
|
|
|
|
// ": bytes=" + reply.Buffer.Length +
|
|
|
|
|
|
// " time=" + reply.RoundtripTime + "ms");
|
|
|
|
|
|
avg += reply.RoundtripTime; |
|
|
|
|
|
if (reply.RoundtripTime < min) |
|
|
|
|
|
{ |
|
|
{ |
|
|
min = reply.RoundtripTime; |
|
|
successes++; |
|
|
|
|
|
//System.Diagnostics.Debug.WriteLine("Reply from " + reply.Address.ToString() +
|
|
|
|
|
|
// ": bytes=" + reply.Buffer.Length +
|
|
|
|
|
|
// " time=" + reply.RoundtripTime + "ms");
|
|
|
|
|
|
avg += reply.RoundtripTime; |
|
|
|
|
|
if (reply.RoundtripTime < min) |
|
|
|
|
|
{ |
|
|
|
|
|
min = reply.RoundtripTime; |
|
|
|
|
|
} |
|
|
|
|
|
if (reply.RoundtripTime > max) |
|
|
|
|
|
{ |
|
|
|
|
|
max = reply.RoundtripTime; |
|
|
|
|
|
} |
|
|
|
|
|
//System.Diagnostics.Debug.WriteLine("Time to live: {0}", reply.Options.Ttl);
|
|
|
|
|
|
//System.Diagnostics.Debug.WriteLine("Don't fragment: {0}", reply.Options.DontFragment);
|
|
|
} |
|
|
} |
|
|
if (reply.RoundtripTime > max) |
|
|
else |
|
|
{ |
|
|
{ |
|
|
max = reply.RoundtripTime; |
|
|
System.Diagnostics.Debug.WriteLine(reply.Status); |
|
|
|
|
|
failures++; |
|
|
} |
|
|
} |
|
|
//System.Diagnostics.Debug.WriteLine("Time to live: {0}", reply.Options.Ttl);
|
|
|
} catch(Exception e) { |
|
|
//System.Diagnostics.Debug.WriteLine("Don't fragment: {0}", reply.Options.DontFragment);
|
|
|
System.Diagnostics.Debug.WriteLine("Found exception while pinging"+e); |
|
|
} |
|
|
|
|
|
else |
|
|
|
|
|
{ |
|
|
|
|
|
System.Diagnostics.Debug.WriteLine(reply.Status); |
|
|
|
|
|
failures++; |
|
|
failures++; |
|
|
} |
|
|
} |
|
|
Thread.Sleep(500); |
|
|
Thread.Sleep(500); |
|
|