mirror of
https://github.com/eworm-de/routeros-scripts
synced 2024-05-14 08:04:19 +00:00
collect-wireless-mac: properly handle vanished device
This commit is contained in:
parent
5f357fd242
commit
877e95d4be
3 changed files with 45 additions and 18 deletions
|
@ -31,9 +31,21 @@ $ScriptLock $0 false 10;
|
|||
:local PlaceBefore ([ / caps-man access-list find where comment="--- collected above ---" disabled ]->0);
|
||||
|
||||
:foreach RegTbl in=[ / caps-man registration-table find ] do={
|
||||
:local Mac [ / caps-man registration-table get $RegTbl mac-address ];
|
||||
:local AccessList ([ / caps-man access-list find where mac-address=$Mac ]->0);
|
||||
:if ([ :len $AccessList ] = 0) do={
|
||||
:local Mac;
|
||||
:local AccessList;
|
||||
:do {
|
||||
:set Mac [ / caps-man registration-table get $RegTbl mac-address ];
|
||||
:set AccessList ([ / caps-man access-list find where mac-address=$Mac ]->0);
|
||||
} on-error={
|
||||
$LogPrintExit2 debug $0 ("Device already gone... Ignoring.") false;
|
||||
}
|
||||
|
||||
:if ([ :len $AccessList ] > 0) do={
|
||||
$LogPrintExit2 debug $0 ("MAC address " . $Mac . " already known: " . \
|
||||
[ / caps-man access-list get $AccessList comment ]) false;
|
||||
}
|
||||
|
||||
:if ([ :typeof $Mac ] = "str" && [ :len $AccessList ] = 0) do={
|
||||
:local Address "no dhcp lease";
|
||||
:local DnsName "no dhcp lease";
|
||||
:local HostName "no dhcp lease";
|
||||
|
@ -70,8 +82,5 @@ $ScriptLock $0 false 10;
|
|||
"Address: " . $Address . "\n" . \
|
||||
"DNS name: " . $DnsName . "\n" . \
|
||||
"Date: " . $DateTime) });
|
||||
} else={
|
||||
$LogPrintExit2 debug $0 ("MAC address " . $Mac . " already known: " . \
|
||||
[ / caps-man access-list get $AccessList comment ]) false;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -31,9 +31,21 @@ $ScriptLock $0 false 10;
|
|||
:local PlaceBefore ([ / interface wireless access-list find where comment="--- collected above ---" disabled ]->0);
|
||||
|
||||
:foreach RegTbl in=[ / interface wireless registration-table find ] do={
|
||||
:local Mac [ / interface wireless registration-table get $RegTbl mac-address ];
|
||||
:local AccessList ([ / interface wireless access-list find where mac-address=$Mac ]->0);
|
||||
:if ([ :len $AccessList ] = 0) do={
|
||||
:local Mac;
|
||||
:local AccessList;
|
||||
:do {
|
||||
:set Mac [ / interface wireless registration-table get $RegTbl mac-address ];
|
||||
:set AccessList ([ / interface wireless access-list find where mac-address=$Mac ]->0);
|
||||
} on-error={
|
||||
$LogPrintExit2 debug $0 ("Device already gone... Ignoring.") false;
|
||||
}
|
||||
|
||||
:if ([ :len $AccessList ] > 0) do={
|
||||
$LogPrintExit2 debug $0 ("MAC address " . $Mac . " already known: " . \
|
||||
[ / interface wireless access-list get $AccessList comment ]) false;
|
||||
}
|
||||
|
||||
:if ([ :typeof $Mac ] = "str" && [ :len $AccessList ] = 0) do={
|
||||
:local Address "no dhcp lease";
|
||||
:local DnsName "no dhcp lease";
|
||||
:local HostName "no dhcp lease";
|
||||
|
@ -70,8 +82,5 @@ $ScriptLock $0 false 10;
|
|||
"Address: " . $Address . "\n" . \
|
||||
"DNS name: " . $DnsName . "\n" . \
|
||||
"Date: " . $DateTime) });
|
||||
} else={
|
||||
$LogPrintExit2 debug $0 ("MAC address " . $Mac . " already known: " . \
|
||||
[ / interface wireless access-list get $AccessList comment ]) false;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -32,9 +32,21 @@ $ScriptLock $0 false 10;
|
|||
:local PlaceBefore ([ / %PATH% access-list find where comment="--- collected above ---" disabled ]->0);
|
||||
|
||||
:foreach RegTbl in=[ / %PATH% registration-table find ] do={
|
||||
:local Mac [ / %PATH% registration-table get $RegTbl mac-address ];
|
||||
:local AccessList ([ / %PATH% access-list find where mac-address=$Mac ]->0);
|
||||
:if ([ :len $AccessList ] = 0) do={
|
||||
:local Mac;
|
||||
:local AccessList;
|
||||
:do {
|
||||
:set Mac [ / %PATH% registration-table get $RegTbl mac-address ];
|
||||
:set AccessList ([ / %PATH% access-list find where mac-address=$Mac ]->0);
|
||||
} on-error={
|
||||
$LogPrintExit2 debug $0 ("Device already gone... Ignoring.") false;
|
||||
}
|
||||
|
||||
:if ([ :len $AccessList ] > 0) do={
|
||||
$LogPrintExit2 debug $0 ("MAC address " . $Mac . " already known: " . \
|
||||
[ / %PATH% access-list get $AccessList comment ]) false;
|
||||
}
|
||||
|
||||
:if ([ :typeof $Mac ] = "str" && [ :len $AccessList ] = 0) do={
|
||||
:local Address "no dhcp lease";
|
||||
:local DnsName "no dhcp lease";
|
||||
:local HostName "no dhcp lease";
|
||||
|
@ -72,8 +84,5 @@ $ScriptLock $0 false 10;
|
|||
"Address: " . $Address . "\n" . \
|
||||
"DNS name: " . $DnsName . "\n" . \
|
||||
"Date: " . $DateTime) });
|
||||
} else={
|
||||
$LogPrintExit2 debug $0 ("MAC address " . $Mac . " already known: " . \
|
||||
[ / %PATH% access-list get $AccessList comment ]) false;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue