gps-track: move code into function

This commit is contained in:
Christian Hesse 2024-03-04 13:48:01 +01:00
parent 480ad0c196
commit a0fc6c30ef

View file

@ -8,10 +8,12 @@
# track gps data by sending json data to http server # track gps data by sending json data to http server
# https://git.eworm.de/cgit/routeros-scripts/about/doc/gps-track.md # https://git.eworm.de/cgit/routeros-scripts/about/doc/gps-track.md
:local 0 [ :jobname ];
:global GlobalFunctionsReady; :global GlobalFunctionsReady;
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; } :while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
:local Main do={
:local ScriptName [ :tostr $1 ];
:global GpsTrackUrl; :global GpsTrackUrl;
:global Identity; :global Identity;
@ -19,7 +21,7 @@
:global ScriptLock; :global ScriptLock;
:global WaitFullyConnected; :global WaitFullyConnected;
$ScriptLock $0; $ScriptLock $ScriptName;
$WaitFullyConnected; $WaitFullyConnected;
:local CoordinateFormat [ /system/gps/get coordinate-format ]; :local CoordinateFormat [ /system/gps/get coordinate-format ];
@ -34,12 +36,15 @@ $WaitFullyConnected;
"\"lon\":\"" . ($Gps->"longitude") . "\"," . \ "\"lon\":\"" . ($Gps->"longitude") . "\"," . \
"\"identity\":\"" . $Identity . "\"" . \ "\"identity\":\"" . $Identity . "\"" . \
"}") as-value; "}") as-value;
$LogPrintExit2 debug $0 ("Sending GPS data in " . $CoordinateFormat . " format: " . \ $LogPrintExit2 debug $ScriptName ("Sending GPS data in " . $CoordinateFormat . " format: " . \
"lat: " . ($Gps->"latitude") . " " . \ "lat: " . ($Gps->"latitude") . " " . \
"lon: " . ($Gps->"longitude")) false; "lon: " . ($Gps->"longitude")) false;
} on-error={ } on-error={
$LogPrintExit2 warning $0 ("Failed sending GPS data!") false; $LogPrintExit2 warning $ScriptName ("Failed sending GPS data!") false;
} }
} else={ } else={
$LogPrintExit2 debug $0 ("GPS data not valid.") false; $LogPrintExit2 debug $ScriptName ("GPS data not valid.") false;
} }
}
$Main [ :jobname ];