Kangaroo.CLI
0.1.0
See the version list below for details.
dotnet tool install --global Kangaroo.CLI --version 0.1.0
dotnet new tool-manifest # if you are setting up this repo dotnet tool install --local Kangaroo.CLI --version 0.1.0
#tool dotnet:?package=Kangaroo.CLI&version=0.1.0
nuke :add-package Kangaroo.CLI --version 0.1.0
kangaroo Network Scanner
"Kangaroos have large, powerful hind legs, large feet adapted for leaping"
The kangaroo network scanner supports (or will support) the following features.
Table of Contents
Building
Kangaroo leverages the builder pattern to ensure its configured correctly before usage.
begin with a ScannerBuilder.Configure() method
// IScanner implements IDisposable so optionally use a using statement
using var scanner = ScannerBuilder.Configure()
If no additional options are provided the kangaroo will grab your first up network interface and use that subnet for scans. (lies, not yet)
Begin chaining addition options together as depicted.
using var scanner = ScannerBuilder
.Configure()
.WithAddresses([ip1, ip2, ip3...])
.WithParallelism(numberOfBatches: 10)
.WithNodeTimeout(TimeSpan.FromMilliseconds(250))
.WithLogging(
LoggerFactory.Create(builder =>
{
builder.AddConsole();
}))
.Build();
var nodes = await scanner.QueryNetwork();
Console.WriteLine(nodes.Dump());
IP Configuration
Optionally kangaroo can use specific IPs, a range of IPs, or scan an entire subnet
ip address collection
using var scanner = ScannerBuilder
.Configure()
.WithAddresses([ip1, ip2, ip3...]) // provide an IEnerable of IP addresses
.Build();
single ip address
var scanner = ScannerBuilder.Configure()
.WithAddress( IPAddress.Parse("10.0.0.111"))
.WithHttpScan()
.WithMaxTimeout(TimeSpan.FromSeconds(2))
.Build();
subnetmask
using var scanner = ScannerBuilder
.Configure()
.WithSubnet("10.0.0.0", "255.255.255.0") // provide an ip subnet to scan
.Build();
network interface
using var scanner = ScannerBuilder
.Configure()
.withInterface(ethernet2) // provide an adapter to determine a subnet (optinal string name)
.Build();
range of ips
using var scanner = ScannerBuilder
.Configure()
.WithRange(startIpAddress, endIpAddress) // provide a start and end address to scan a range of IPs
.Build();
Web Server Query
An optional web server query can be enabled. Use the WithHttpScan
option after configuring the addresses.
In order to prevent port or dns exhaustion the scan depends on a Func<HttpClient>
. You can use this function to create an http client pool,
leverage the http client factory, or simply return a new client. Each query will request a client and dispose of the client afterwards.
A default factory is provided in the library if no function is provided.
var scanner = config
.WithInterface(adapter)
.WithHttpScan(() => new HttpClient())
.Build();
Ping Configuration
The ping can be configured as well. optional timeout and TTL can be provided to effectively speed up or slow down each query. A shorter timeout will allow kangaroo to fail faster on an unknown address. The TTL can be configured to ensure you are only scanning IP addresses within a physical boundary. A TTL of 1 would only ping devices on the physical switch.
using var scanner = ScannerBuilder.Configure()
.WithIpAddresses(ips)
.WithMaxTimeout(TimeSpan.FromSeconds(1))
.Build();
using var scanner = ScannerBuilder.Configure()
.WithIpAddresses(ips)
.WithMaxHops(2)
.Build();
Parallel Configuration
After the ips are determined you can optionally execute the scans using the TPL, add the WithParallelism method and provide a batch size. Each batch of IP addresses will be scanned in parellel. Each batch will contsin the number of IP addresses divided by the size of the provided addresses.
using var scanner = ScannerBuilder
.Configure()
.WithAddresses(ips)
.WithParallelism(numberOfBatches: 10) // of 254 addresses 25 batches of 10 addresses will be scanned.
.Build();
Logging Configuration
BYOL(Logger)
using var scanner = ScannerBuilder.Configure()
.WithIpAddresses(ips)
.WithLogging(_logger) //Provide a logger
.Build();
using var scanner = ScannerBuilder.Configure()
.WithIpAddresses(ips)
.WithLogging(() => ILogger) //Provide a logger func
.Build();
Scanning Networks
So now you have a new Kangaroo Scanner. lets scan, await a call to QueryAddresses(optionalCtx)
to return a ScanResult
containing a list of network nodes, and scan results.
var nodes = await scanner.QueryNetwork();
Console.WriteLine(nodes.Dump());
Network Protocols
ICMP
The first scan kangaroo will execute is a simple ping (or icmp) query. Depending on the ping configuration the kangaroo scanner will send icmp packets to the specified IP addresses and wait for a reply. The ping test is used to determin if the endpoint is currently up, and the latency of the node. When and only when a Ping is replied too, kangaroo will attempt to perform additional tests.
ARP
The next step in the network query involves an arp request. When an endpoint responds the MAC address of the network node will be gathered.
NETBIOS / Hostname
After collecting the icmp results and mac address, kangaroo will attempt to gather the netbios information by sending and output packet over UDP port 137. Should the endpoint respond with hostname information the data is parsed and collected. Results may very...
WEB Server
The last and final optional step includes an http query. The goal of this query is simply to determine if an http webserver
exist at that endpoint and report the servers headers. For this test an HTTP GET request on port 80 is made to the
servers IP address root GET http://172.22.5.5/
. If any response is return the headers will queried to dertmine the type of webserver.
IP Scanning
Await a call to the QueryNetwork to query all the IP addresses provided. Depending on the configuration each query could take anywhere from 5 seconds to several minutes. The reslts will include an IEnumerable of nodes each containing the following data. Note, the hostname results depend on the network environment and machine running the scanner.
public record NetworkNode(
IPAddress IpAddress, // IP address that was queried
MacAddress MacAddress, // MAC address return from arp request
string? HostName, // Hostname return from the query
string? WebServer, // HTTP server header information (future)
TimeSpan? Latency, // Ping response time
TimeSpan QueryTime, // Elapsed time for the duration of thr query
bool Alive); // True if the endpoint replied to ping
Nodes
Individual nodes can be queried as well.
var node = await scanner.CheckNetworkNode();
Console.WriteLine(node.Dump());
Scan Results
The results of each scan will include the elapsed time and other properties.
Port Scanner
(Future!)
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
This package has no dependencies.