diff options
author | Christian Hesse <mail@eworm.de> | 2024-12-06 12:17:47 +0100 |
---|---|---|
committer | Christian Hesse <mail@eworm.de> | 2024-12-09 11:49:50 +0100 |
commit | 3866ea19235e467a3e16cc627ab2dccca3db3a2c (patch) | |
tree | 3c5fa83bc0a13f5be94e677568357840e98115e1 /lease-script.rsc | |
parent | 48bcf8ee6e92445b01f792f1c52af012ba05b7b4 (diff) | |
parent | ee030740cba5bd0c8b0c9c3e77551dd460abe48b (diff) |
Merge branch 'exit-error' into next
Diffstat (limited to 'lease-script.rsc')
-rw-r--r-- | lease-script.rsc | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/lease-script.rsc b/lease-script.rsc index f484414..995c7e4 100644 --- a/lease-script.rsc +++ b/lease-script.rsc @@ -11,6 +11,7 @@ :global GlobalFunctionsReady; :while ($GlobalFunctionsReady != true) do={ :delay 500ms; } +:local ExitOK false; :do { :local ScriptName [ :jobname ]; @@ -25,6 +26,7 @@ [ :typeof $leaseServerName ] = "nothing" || \ [ :typeof $leaseBound ] = "nothing") do={ $LogPrint error $ScriptName ("This script is supposed to run from ip dhcp-server."); + :set ExitOK true; :error false; } @@ -32,11 +34,13 @@ "de" "" ] . "assigned lease " . $leaseActIP . " to " . $leaseActMAC); :if ([ $ScriptLock $ScriptName 10 ] = false) do={ + :set ExitOK true; :error false; } :if ([ :len [ /system/script/job/find where script=$ScriptName ] ] > 1) do={ $LogPrint debug $ScriptName ("More invocations are waiting, exiting early."); + :set ExitOK true; :error true; } @@ -56,4 +60,6 @@ $LogPrint warning $ScriptName ("Running script '" . $Script . "' failed!"); } } -} on-error={ } +} on-error={ + :global ExitError; $ExitError $ExitOK [ :jobname ]; +} |