API: list_arp search by MAC (#10803)
* API: Allow search ARP by MAC * reformat mac * Update docs
This commit is contained in:
parent
dc751123bc
commit
12773d125b
|
@ -5,15 +5,16 @@ path: blob/master/doc/
|
|||
|
||||
Retrieve a specific ARP entry or all ARP enties for a device
|
||||
|
||||
Route: `/api/v0/resources/ip/arp/:ip`
|
||||
Route: `/api/v0/resources/ip/arp/:query`
|
||||
|
||||
- ip is the specific IP you would like to query, if this is all then
|
||||
you need to pass ?device=_hostname_ (or device id)
|
||||
- This may also be a cidr network, for example 192.168.1.0/24
|
||||
Query can be:
|
||||
- An IP address
|
||||
- A CIDR network (192.168.1.0/24)
|
||||
- `all` and set ?device=_hostname_ (or device id)
|
||||
|
||||
Input:
|
||||
|
||||
- device if you specify all for the IP then you need to populate this
|
||||
- device if you specify all for the query then you need to populate this
|
||||
with the hostname or id of the device.
|
||||
|
||||
Example:
|
||||
|
|
|
@ -1996,22 +1996,22 @@ function list_ip_networks()
|
|||
|
||||
function list_arp(\Illuminate\Http\Request $request)
|
||||
{
|
||||
$ip = $request->route('ip');
|
||||
$query = $request->route('query');
|
||||
$cidr = $request->route('cidr');
|
||||
$hostname = $request->get('device');
|
||||
|
||||
if (empty($ip)) {
|
||||
return api_error(400, "No valid IP provided");
|
||||
} elseif ($ip === "all" && empty($hostname)) {
|
||||
if (empty($query)) {
|
||||
return api_error(400, "No valid IP/MAC provided");
|
||||
} elseif ($query === "all" && empty($hostname)) {
|
||||
return api_error(400, "Device argument is required when requesting all entries");
|
||||
}
|
||||
|
||||
if ($ip === "all") {
|
||||
if ($query === "all") {
|
||||
$device_id = ctype_digit($hostname) ? $hostname : getidbyname($hostname);
|
||||
$arp = dbFetchRows("SELECT `ipv4_mac`.* FROM `ipv4_mac` LEFT JOIN `ports` ON `ipv4_mac`.`port_id` = `ports`.`port_id` WHERE `ports`.`device_id` = ?", [$device_id]);
|
||||
} elseif ($cidr) {
|
||||
try {
|
||||
$ip = new IPv4("$ip/$cidr");
|
||||
$ip = new IPv4("$query/$cidr");
|
||||
$arp = dbFetchRows(
|
||||
'SELECT * FROM `ipv4_mac` WHERE (inet_aton(`ipv4_address`) & ?) = ?',
|
||||
[ip2long($ip->getNetmask()), ip2long($ip->getNetworkAddress())]
|
||||
|
@ -2019,8 +2019,11 @@ function list_arp(\Illuminate\Http\Request $request)
|
|||
} catch (InvalidIpException $e) {
|
||||
return api_error(400, "Invalid Network Address");
|
||||
}
|
||||
} elseif (filter_var($query, FILTER_VALIDATE_MAC)) {
|
||||
$mac = \LibreNMS\Util\Rewrite::macToHex($query);
|
||||
$arp = dbFetchRows("SELECT * FROM `ipv4_mac` WHERE `mac_address`=?", [$mac]);
|
||||
} else {
|
||||
$arp = dbFetchRows("SELECT * FROM `ipv4_mac` WHERE `ipv4_address`=?", [$ip]);
|
||||
$arp = dbFetchRows("SELECT * FROM `ipv4_mac` WHERE `ipv4_address`=?", [$query]);
|
||||
}
|
||||
return api_success($arp, 'arp');
|
||||
}
|
||||
|
|
|
@ -40,7 +40,7 @@ Route::group(['prefix' => 'v0', 'namespace' => '\App\Api\Controllers'], function
|
|||
Route::get('links/{id}', 'LegacyApiController@get_link')->name('get_link');
|
||||
Route::get('locations', 'LegacyApiController@list_locations')->name('list_locations');
|
||||
Route::get('ip/addresses', 'LegacyApiController@list_ip_addresses')->name('list_ip_addresses');
|
||||
Route::get('ip/arp/{ip}/{cidr?}', 'LegacyApiController@list_arp')->name('list_arp');
|
||||
Route::get('ip/arp/{query}/{cidr?}', 'LegacyApiController@list_arp')->name('list_arp');
|
||||
Route::get('ip/networks', 'LegacyApiController@list_ip_networks')->name('list_ip_networks');
|
||||
Route::get('ip/networks/{id}/ip', 'LegacyApiController@get_network_ip_addresses')->name('get_network_ip_addresses');
|
||||
});
|
||||
|
|
Loading…
Reference in New Issue