| 
									
										
										
										
											2020-09-18 11:00:27 +02:00
										 |  |  | #!rsc by RouterOS | 
					
						
							| 
									
										
										
										
											2018-07-05 15:29:26 +02:00
										 |  |  | # RouterOS script: global-config | 
					
						
							| 
									
										
										
										
											2022-01-01 21:38:15 +01:00
										 |  |  | # Copyright (c) 2013-2022 Christian Hesse <mail@eworm.de> | 
					
						
							| 
									
										
										
										
											2020-06-19 22:17:42 +02:00
										 |  |  | # https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md | 
					
						
							| 
									
										
										
										
											2018-07-05 15:29:26 +02:00
										 |  |  | # | 
					
						
							|  |  |  | # global configuration | 
					
						
							| 
									
										
										
										
											2020-03-27 21:54:00 +01:00
										 |  |  | # https://git.eworm.de/cgit/routeros-scripts/about/ | 
					
						
							| 
									
										
										
										
											2018-07-05 15:29:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-03 15:36:26 +01:00
										 |  |  | # Make sure all configuration properties are up to date and this | 
					
						
							|  |  |  | # value is in sync with value in script 'global-functions'! | 
					
						
							| 
									
										
										
										
											2022-03-30 18:03:50 +02:00
										 |  |  | :global GlobalConfigVersion 79; | 
					
						
							| 
									
										
										
										
											2019-01-03 15:36:26 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-05 15:29:26 +02:00
										 |  |  | # This is used for DNS and backup file. | 
					
						
							| 
									
										
											  
											
												global: variable names are CamelCase
            ___  _         ___     __
           / _ )(_)__ _   / _/__ _/ /_
          / _  / / _ `/  / _/ _ `/ __/
         /____/_/\_, /  /_/ \_,_/\__/
 _       __     /___/       _             __
| |     / /___ __________  (_)___  ____ _/ /
| | /| / / __ `/ ___/ __ \/ / __ \/ __ `/ /
| |/ |/ / /_/ / /  / / / / / / / / /_/ /_/
|__/|__/\__,_/_/  /_/ /_/_/_/ /_/\__, (_)
                                /____/
RouterOS has some odd behavior when it comes to variable names. Let's
have a look at the interfaces:
[admin@MikroTik] > / interface print where name=en1
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
That looks ok. Now we use a script:
{ :local interface "en1";
  / interface print where name=$interface; }
And the result...
[admin@MikroTik] > { :local interface "en1";
{...   / interface print where name=$interface; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
... still looks ok.
We make a little modification to the script:
{ :local name "en1";
  / interface print where name=$name; }
And the result:
[admin@MikroTik] > { :local name "en1";
{...   / interface print where name=$name; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
 1   S en2                                 ether            1500  1598
 2   S en3                                 ether            1500  1598
 3   S en4                                 ether            1500  1598
 4   S en5                                 ether            1500  1598
 5  R  br-local                            bridge           1500  1598
Ups! The filter has no effect!
That happens whenever the variable name ($name) matches the property
name (name=).
And another modification:
{ :local type "en1";
  / interface print where name=$type; }
And the result:
[admin@MikroTik] > { :local type "en1";
{...   / interface print where name=$type; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
Ups! Nothing?
Even if the variable name ($type) matches whatever property name (type=)
things go wrong.
The answer from MikroTik support (in Ticket#2019010222000454):
> This is how scripting works in RouterOS and we will not fix it.
To get around this we use variable names in CamelCase. Let's hope
Mikrotik never ever introduces property names in CamelCase...
*fingers crossed*
											
										 
											2019-01-03 17:45:43 +01:00
										 |  |  | :global Domain "example.com"; | 
					
						
							|  |  |  | :global HostNameInZone true; | 
					
						
							| 
									
										
										
										
											2020-07-03 08:08:04 +02:00
										 |  |  | :global PrefixInZone true; | 
					
						
							| 
									
										
										
										
											2020-08-02 23:31:21 +02:00
										 |  |  | :global ServerNameInZone false; | 
					
						
							| 
									
										
										
										
											2018-07-05 15:29:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-08 17:30:39 +02:00
										 |  |  | # These addresses are used to send e-mails to. The to-address needs | 
					
						
							|  |  |  | # to be filled; cc-address can be empty, one address or a comma | 
					
						
							| 
									
										
										
										
											2018-07-05 15:29:26 +02:00
										 |  |  | # separated list of addresses. | 
					
						
							| 
									
										
										
										
											2020-10-15 22:45:27 +02:00
										 |  |  | :global EmailGeneralTo ""; | 
					
						
							|  |  |  | :global EmailGeneralCc ""; | 
					
						
							|  |  |  | #:global EmailGeneralTo "mail@example.com"; | 
					
						
							|  |  |  | #:global EmailGeneralCc "another@example.com,third@example.com"; | 
					
						
							| 
									
										
										
										
											2018-07-05 15:29:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-09 15:46:39 +02:00
										 |  |  | # You can send Telegram notifications. Register a bot | 
					
						
							| 
									
										
										
										
											2021-06-02 22:53:43 +02:00
										 |  |  | # and add the token and chat ids here, then install the module: | 
					
						
							| 
									
										
										
										
											2021-11-15 20:22:56 +01:00
										 |  |  | # $ScriptInstallUpdate mod/notification-telegram | 
					
						
							| 
									
										
											  
											
												global: variable names are CamelCase
            ___  _         ___     __
           / _ )(_)__ _   / _/__ _/ /_
          / _  / / _ `/  / _/ _ `/ __/
         /____/_/\_, /  /_/ \_,_/\__/
 _       __     /___/       _             __
| |     / /___ __________  (_)___  ____ _/ /
| | /| / / __ `/ ___/ __ \/ / __ \/ __ `/ /
| |/ |/ / /_/ / /  / / / / / / / / /_/ /_/
|__/|__/\__,_/_/  /_/ /_/_/_/ /_/\__, (_)
                                /____/
RouterOS has some odd behavior when it comes to variable names. Let's
have a look at the interfaces:
[admin@MikroTik] > / interface print where name=en1
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
That looks ok. Now we use a script:
{ :local interface "en1";
  / interface print where name=$interface; }
And the result...
[admin@MikroTik] > { :local interface "en1";
{...   / interface print where name=$interface; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
... still looks ok.
We make a little modification to the script:
{ :local name "en1";
  / interface print where name=$name; }
And the result:
[admin@MikroTik] > { :local name "en1";
{...   / interface print where name=$name; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
 1   S en2                                 ether            1500  1598
 2   S en3                                 ether            1500  1598
 3   S en4                                 ether            1500  1598
 4   S en5                                 ether            1500  1598
 5  R  br-local                            bridge           1500  1598
Ups! The filter has no effect!
That happens whenever the variable name ($name) matches the property
name (name=).
And another modification:
{ :local type "en1";
  / interface print where name=$type; }
And the result:
[admin@MikroTik] > { :local type "en1";
{...   / interface print where name=$type; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
Ups! Nothing?
Even if the variable name ($type) matches whatever property name (type=)
things go wrong.
The answer from MikroTik support (in Ticket#2019010222000454):
> This is how scripting works in RouterOS and we will not fix it.
To get around this we use variable names in CamelCase. Let's hope
Mikrotik never ever introduces property names in CamelCase...
*fingers crossed*
											
										 
											2019-01-03 17:45:43 +01:00
										 |  |  | :global TelegramTokenId ""; | 
					
						
							|  |  |  | :global TelegramChatId ""; | 
					
						
							|  |  |  | #:global TelegramTokenId "123456:ABCDEF-GHI"; | 
					
						
							|  |  |  | #:global TelegramChatId "12345678"; | 
					
						
							| 
									
										
										
										
											2020-10-12 23:58:20 +02:00
										 |  |  | # This is whether or not to send Telegram messages with fixed-width font. | 
					
						
							|  |  |  | :global TelegramFixedWidthFont true; | 
					
						
							| 
									
										
										
										
											2018-10-09 15:46:39 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-28 17:30:37 +02:00
										 |  |  | # You can send Matrix notifications. Configure these settings and | 
					
						
							|  |  |  | # install the module: | 
					
						
							| 
									
										
										
										
											2021-11-15 20:22:56 +01:00
										 |  |  | # $ScriptInstallUpdate mod/notification-matrix | 
					
						
							| 
									
										
										
										
											2021-05-28 17:30:37 +02:00
										 |  |  | :global MatrixHomeServer ""; | 
					
						
							|  |  |  | :global MatrixAccessToken ""; | 
					
						
							|  |  |  | :global MatrixRoom ""; | 
					
						
							|  |  |  | #:global MatrixHomeServer "matrix.org"; | 
					
						
							|  |  |  | #:global MatrixAccessToken "123456ABCDEFGHI..."; | 
					
						
							|  |  |  | #:global MatrixRoom "!example:matrix.org"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # It is possible to override e-mail, Telegram and Matrix setting for every | 
					
						
							|  |  |  | # script. This is done in arrays, where 'Override' is appended to the | 
					
						
							|  |  |  | # variable name, like this: | 
					
						
							| 
									
										
										
										
											2021-04-28 15:11:08 +02:00
										 |  |  | #:global EmailGeneralToOverride { | 
					
						
							|  |  |  | #  "check-certificates"="override@example.com"; | 
					
						
							| 
									
										
										
										
											2022-01-05 22:37:35 +01:00
										 |  |  | #  "backup-email"="backup@example.com"; | 
					
						
							| 
									
										
										
										
											2021-04-28 15:11:08 +02:00
										 |  |  | #} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-17 08:07:12 +02:00
										 |  |  | # Toggle this to disable symbols in notifications. | 
					
						
							|  |  |  | :global NotificationsWithSymbols true; | 
					
						
							| 
									
										
										
										
											2021-01-22 09:20:49 +01:00
										 |  |  | # Toggle this to disable color output in terminal/cli. | 
					
						
							|  |  |  | :global TerminalColorOutput true; | 
					
						
							| 
									
										
										
										
											2020-07-17 08:07:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-05 15:29:26 +02:00
										 |  |  | # This defines what backups to generate and what password to use. | 
					
						
							| 
									
										
											  
											
												global: variable names are CamelCase
            ___  _         ___     __
           / _ )(_)__ _   / _/__ _/ /_
          / _  / / _ `/  / _/ _ `/ __/
         /____/_/\_, /  /_/ \_,_/\__/
 _       __     /___/       _             __
| |     / /___ __________  (_)___  ____ _/ /
| | /| / / __ `/ ___/ __ \/ / __ \/ __ `/ /
| |/ |/ / /_/ / /  / / / / / / / / /_/ /_/
|__/|__/\__,_/_/  /_/ /_/_/_/ /_/\__, (_)
                                /____/
RouterOS has some odd behavior when it comes to variable names. Let's
have a look at the interfaces:
[admin@MikroTik] > / interface print where name=en1
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
That looks ok. Now we use a script:
{ :local interface "en1";
  / interface print where name=$interface; }
And the result...
[admin@MikroTik] > { :local interface "en1";
{...   / interface print where name=$interface; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
... still looks ok.
We make a little modification to the script:
{ :local name "en1";
  / interface print where name=$name; }
And the result:
[admin@MikroTik] > { :local name "en1";
{...   / interface print where name=$name; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
 1   S en2                                 ether            1500  1598
 2   S en3                                 ether            1500  1598
 3   S en4                                 ether            1500  1598
 4   S en5                                 ether            1500  1598
 5  R  br-local                            bridge           1500  1598
Ups! The filter has no effect!
That happens whenever the variable name ($name) matches the property
name (name=).
And another modification:
{ :local type "en1";
  / interface print where name=$type; }
And the result:
[admin@MikroTik] > { :local type "en1";
{...   / interface print where name=$type; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
Ups! Nothing?
Even if the variable name ($type) matches whatever property name (type=)
things go wrong.
The answer from MikroTik support (in Ticket#2019010222000454):
> This is how scripting works in RouterOS and we will not fix it.
To get around this we use variable names in CamelCase. Let's hope
Mikrotik never ever introduces property names in CamelCase...
*fingers crossed*
											
										 
											2019-01-03 17:45:43 +01:00
										 |  |  | :global BackupSendBinary false; | 
					
						
							|  |  |  | :global BackupSendExport true; | 
					
						
							|  |  |  | :global BackupPassword "v3ry-s3cr3t"; | 
					
						
							| 
									
										
										
										
											2021-02-23 09:55:14 +01:00
										 |  |  | :global BackupRandomDelay 0; | 
					
						
							| 
									
										
										
										
											2019-07-08 17:48:55 +02:00
										 |  |  | # These credentials are used to upload backup and config export files. | 
					
						
							|  |  |  | # SFTP authentication is tricky, you may have to limit authentication | 
					
						
							|  |  |  | # methods for your SSH server. | 
					
						
							|  |  |  | :global BackupUploadUrl "sftp://example.com/backup/"; | 
					
						
							|  |  |  | :global BackupUploadUser "mikrotik"; | 
					
						
							|  |  |  | :global BackupUploadPass "v3ry-s3cr3t"; | 
					
						
							| 
									
										
										
										
											2018-07-05 15:29:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-09 14:32:52 +02:00
										 |  |  | # This defines what log messages to filter or include by topic or message | 
					
						
							| 
									
										
										
										
											2021-06-09 14:25:58 +02:00
										 |  |  | # text. Regular expressions are supported. Do *NOT* set an empty string, | 
					
						
							| 
									
										
										
										
											2021-06-09 14:32:52 +02:00
										 |  |  | # that will filter or include everything! | 
					
						
							| 
									
										
										
										
											2021-06-09 14:25:58 +02:00
										 |  |  | # These are filters, so excluding messages from forwarding. | 
					
						
							| 
									
										
										
										
											2020-11-13 22:46:26 +01:00
										 |  |  | :global LogForwardFilter "(debug|info)"; | 
					
						
							| 
									
										
										
										
											2021-03-15 00:48:38 +01:00
										 |  |  | :global LogForwardFilterMessage []; | 
					
						
							|  |  |  | #:global LogForwardFilterMessage "message text"; | 
					
						
							|  |  |  | #:global LogForwardFilterMessage "(message text|another text|...)"; | 
					
						
							| 
									
										
										
										
											2021-06-09 14:32:52 +02:00
										 |  |  | # ... and another setting with reverse logic. This includes messages even | 
					
						
							|  |  |  | # if filtered above. | 
					
						
							|  |  |  | :global LogForwardInclude []; | 
					
						
							|  |  |  | :global LogForwardIncludeMessage []; | 
					
						
							|  |  |  | #:global LogForwardInclude "account"; | 
					
						
							|  |  |  | #:global LogForwardIncludeMessage "message text"; | 
					
						
							| 
									
										
										
										
											2020-07-15 12:22:55 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-30 11:26:47 +02:00
										 |  |  | # Specify an address to enable auto update to version assumed safe. | 
					
						
							|  |  |  | # The configured channel (bugfix, current, release-candidate) is appended. | 
					
						
							| 
									
										
											  
											
												global: variable names are CamelCase
            ___  _         ___     __
           / _ )(_)__ _   / _/__ _/ /_
          / _  / / _ `/  / _/ _ `/ __/
         /____/_/\_, /  /_/ \_,_/\__/
 _       __     /___/       _             __
| |     / /___ __________  (_)___  ____ _/ /
| | /| / / __ `/ ___/ __ \/ / __ \/ __ `/ /
| |/ |/ / /_/ / /  / / / / / / / / /_/ /_/
|__/|__/\__,_/_/  /_/ /_/_/_/ /_/\__, (_)
                                /____/
RouterOS has some odd behavior when it comes to variable names. Let's
have a look at the interfaces:
[admin@MikroTik] > / interface print where name=en1
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
That looks ok. Now we use a script:
{ :local interface "en1";
  / interface print where name=$interface; }
And the result...
[admin@MikroTik] > { :local interface "en1";
{...   / interface print where name=$interface; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
... still looks ok.
We make a little modification to the script:
{ :local name "en1";
  / interface print where name=$name; }
And the result:
[admin@MikroTik] > { :local name "en1";
{...   / interface print where name=$name; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
 1   S en2                                 ether            1500  1598
 2   S en3                                 ether            1500  1598
 3   S en4                                 ether            1500  1598
 4   S en5                                 ether            1500  1598
 5  R  br-local                            bridge           1500  1598
Ups! The filter has no effect!
That happens whenever the variable name ($name) matches the property
name (name=).
And another modification:
{ :local type "en1";
  / interface print where name=$type; }
And the result:
[admin@MikroTik] > { :local type "en1";
{...   / interface print where name=$type; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
Ups! Nothing?
Even if the variable name ($type) matches whatever property name (type=)
things go wrong.
The answer from MikroTik support (in Ticket#2019010222000454):
> This is how scripting works in RouterOS and we will not fix it.
To get around this we use variable names in CamelCase. Let's hope
Mikrotik never ever introduces property names in CamelCase...
*fingers crossed*
											
										 
											2019-01-03 17:45:43 +01:00
										 |  |  | :global SafeUpdateUrl ""; | 
					
						
							|  |  |  | #:global SafeUpdateUrl "https://example.com/ros/safe-update/"; | 
					
						
							| 
									
										
										
										
											2020-07-07 00:21:47 +02:00
										 |  |  | # Allow to install patch updates automatically. | 
					
						
							|  |  |  | :global SafeUpdatePatch false; | 
					
						
							| 
									
										
										
										
											2020-11-01 21:48:03 +01:00
										 |  |  | # Allow to install updates automatically if seen in neighbor list. | 
					
						
							|  |  |  | :global SafeUpdateNeighbor false; | 
					
						
							| 
									
										
										
										
											2021-06-28 18:00:25 +02:00
										 |  |  | # Allow to install updates even if device is managed by CAPsMAN. | 
					
						
							|  |  |  | :global SafeUpdateOnCap false; | 
					
						
							| 
									
										
										
										
											2018-08-30 11:26:47 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-14 19:06:21 +02:00
										 |  |  | # These thresholds control when to send health notification | 
					
						
							|  |  |  | # on temperature and voltage. | 
					
						
							| 
									
										
										
										
											2019-08-27 10:35:53 +02:00
										 |  |  | :global CheckHealthTemperature { | 
					
						
							|  |  |  |   temperature=50; | 
					
						
							|  |  |  |   cpu-temperature=70; | 
					
						
							|  |  |  |   board-temperature1=50; | 
					
						
							|  |  |  |   board-temperature2=50; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2020-10-16 22:51:51 +02:00
										 |  |  | # This is deviation on recovery threshold against notification flooding. | 
					
						
							|  |  |  | :global CheckHealthTemperatureDeviation 2; | 
					
						
							| 
									
										
										
										
											2021-11-13 21:29:33 +01:00
										 |  |  | :global CheckHealthVoltageLow 115; | 
					
						
							| 
									
										
										
										
											2019-10-22 15:03:52 +02:00
										 |  |  | :global CheckHealthVoltagePercent 10; | 
					
						
							| 
									
										
										
										
											2019-08-27 10:35:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-09 14:12:38 +02:00
										 |  |  | # Access-list entries matching this comment are updated | 
					
						
							|  |  |  | # with daily pseudo-random PSK. | 
					
						
							| 
									
										
											  
											
												global: variable names are CamelCase
            ___  _         ___     __
           / _ )(_)__ _   / _/__ _/ /_
          / _  / / _ `/  / _/ _ `/ __/
         /____/_/\_, /  /_/ \_,_/\__/
 _       __     /___/       _             __
| |     / /___ __________  (_)___  ____ _/ /
| | /| / / __ `/ ___/ __ \/ / __ \/ __ `/ /
| |/ |/ / /_/ / /  / / / / / / / / /_/ /_/
|__/|__/\__,_/_/  /_/ /_/_/_/ /_/\__, (_)
                                /____/
RouterOS has some odd behavior when it comes to variable names. Let's
have a look at the interfaces:
[admin@MikroTik] > / interface print where name=en1
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
That looks ok. Now we use a script:
{ :local interface "en1";
  / interface print where name=$interface; }
And the result...
[admin@MikroTik] > { :local interface "en1";
{...   / interface print where name=$interface; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
... still looks ok.
We make a little modification to the script:
{ :local name "en1";
  / interface print where name=$name; }
And the result:
[admin@MikroTik] > { :local name "en1";
{...   / interface print where name=$name; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
 1   S en2                                 ether            1500  1598
 2   S en3                                 ether            1500  1598
 3   S en4                                 ether            1500  1598
 4   S en5                                 ether            1500  1598
 5  R  br-local                            bridge           1500  1598
Ups! The filter has no effect!
That happens whenever the variable name ($name) matches the property
name (name=).
And another modification:
{ :local type "en1";
  / interface print where name=$type; }
And the result:
[admin@MikroTik] > { :local type "en1";
{...   / interface print where name=$type; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
Ups! Nothing?
Even if the variable name ($type) matches whatever property name (type=)
things go wrong.
The answer from MikroTik support (in Ticket#2019010222000454):
> This is how scripting works in RouterOS and we will not fix it.
To get around this we use variable names in CamelCase. Let's hope
Mikrotik never ever introduces property names in CamelCase...
*fingers crossed*
											
										 
											2019-01-03 17:45:43 +01:00
										 |  |  | :global DailyPskMatchComment "Daily PSK"; | 
					
						
							|  |  |  | :global DailyPskSecrets { | 
					
						
							| 
									
										
										
										
											2018-10-09 14:12:38 +02:00
										 |  |  |   { "Abusive"; "Aggressive"; "Bored"; "Chemical"; "Cold"; | 
					
						
							|  |  |  |     "Cruel"; "Curved"; "Delightful"; "Discreet"; "Elite"; | 
					
						
							|  |  |  |     "Evasive"; "Faded"; "Flat"; "Future"; "Grandiose"; | 
					
						
							|  |  |  |     "Hanging"; "Humorous"; "Interesting"; "Magenta"; | 
					
						
							|  |  |  |     "Magnificent"; "Numerous"; "Optimal"; "Pathetic"; | 
					
						
							|  |  |  |     "Possessive"; "Remarkable"; "Rightful"; "Ruthless"; | 
					
						
							|  |  |  |     "Stale"; "Unusual"; "Useless"; "Various" }; | 
					
						
							|  |  |  |   { "Adhesive"; "Amusing"; "Astonishing"; "Frantic"; | 
					
						
							|  |  |  |     "Kindhearted"; "Limping"; "Roasted"; "Robust"; | 
					
						
							| 
									
										
										
										
											2019-04-05 07:56:50 +02:00
										 |  |  |     "Staking"; "Thundering"; "Ultra"; "Unreal" }; | 
					
						
							| 
									
										
										
										
											2018-10-09 14:12:38 +02:00
										 |  |  |   { "Belief"; "Button"; "Curtain"; "Edge"; "Jewel"; | 
					
						
							|  |  |  |     "String"; "Whistle" } | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-07-05 15:29:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-10 22:15:54 +02:00
										 |  |  | # Run different commands with multiple mode-button presses. | 
					
						
							| 
									
										
											  
											
												global: variable names are CamelCase
            ___  _         ___     __
           / _ )(_)__ _   / _/__ _/ /_
          / _  / / _ `/  / _/ _ `/ __/
         /____/_/\_, /  /_/ \_,_/\__/
 _       __     /___/       _             __
| |     / /___ __________  (_)___  ____ _/ /
| | /| / / __ `/ ___/ __ \/ / __ \/ __ `/ /
| |/ |/ / /_/ / /  / / / / / / / / /_/ /_/
|__/|__/\__,_/_/  /_/ /_/_/_/ /_/\__, (_)
                                /____/
RouterOS has some odd behavior when it comes to variable names. Let's
have a look at the interfaces:
[admin@MikroTik] > / interface print where name=en1
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
That looks ok. Now we use a script:
{ :local interface "en1";
  / interface print where name=$interface; }
And the result...
[admin@MikroTik] > { :local interface "en1";
{...   / interface print where name=$interface; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
... still looks ok.
We make a little modification to the script:
{ :local name "en1";
  / interface print where name=$name; }
And the result:
[admin@MikroTik] > { :local name "en1";
{...   / interface print where name=$name; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
 1   S en2                                 ether            1500  1598
 2   S en3                                 ether            1500  1598
 3   S en4                                 ether            1500  1598
 4   S en5                                 ether            1500  1598
 5  R  br-local                            bridge           1500  1598
Ups! The filter has no effect!
That happens whenever the variable name ($name) matches the property
name (name=).
And another modification:
{ :local type "en1";
  / interface print where name=$type; }
And the result:
[admin@MikroTik] > { :local type "en1";
{...   / interface print where name=$type; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
Ups! Nothing?
Even if the variable name ($type) matches whatever property name (type=)
things go wrong.
The answer from MikroTik support (in Ticket#2019010222000454):
> This is how scripting works in RouterOS and we will not fix it.
To get around this we use variable names in CamelCase. Let's hope
Mikrotik never ever introduces property names in CamelCase...
*fingers crossed*
											
										 
											2019-01-03 17:45:43 +01:00
										 |  |  | :global ModeButton { | 
					
						
							| 
									
										
										
										
											2018-09-10 22:15:54 +02:00
										 |  |  |   1="/ system script run leds-toggle-mode;"; | 
					
						
							| 
									
										
											  
											
												global: variable names are CamelCase
            ___  _         ___     __
           / _ )(_)__ _   / _/__ _/ /_
          / _  / / _ `/  / _/ _ `/ __/
         /____/_/\_, /  /_/ \_,_/\__/
 _       __     /___/       _             __
| |     / /___ __________  (_)___  ____ _/ /
| | /| / / __ `/ ___/ __ \/ / __ \/ __ `/ /
| |/ |/ / /_/ / /  / / / / / / / / /_/ /_/
|__/|__/\__,_/_/  /_/ /_/_/_/ /_/\__, (_)
                                /____/
RouterOS has some odd behavior when it comes to variable names. Let's
have a look at the interfaces:
[admin@MikroTik] > / interface print where name=en1
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
That looks ok. Now we use a script:
{ :local interface "en1";
  / interface print where name=$interface; }
And the result...
[admin@MikroTik] > { :local interface "en1";
{...   / interface print where name=$interface; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
... still looks ok.
We make a little modification to the script:
{ :local name "en1";
  / interface print where name=$name; }
And the result:
[admin@MikroTik] > { :local name "en1";
{...   / interface print where name=$name; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
 1   S en2                                 ether            1500  1598
 2   S en3                                 ether            1500  1598
 3   S en4                                 ether            1500  1598
 4   S en5                                 ether            1500  1598
 5  R  br-local                            bridge           1500  1598
Ups! The filter has no effect!
That happens whenever the variable name ($name) matches the property
name (name=).
And another modification:
{ :local type "en1";
  / interface print where name=$type; }
And the result:
[admin@MikroTik] > { :local type "en1";
{...   / interface print where name=$type; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
Ups! Nothing?
Even if the variable name ($type) matches whatever property name (type=)
things go wrong.
The answer from MikroTik support (in Ticket#2019010222000454):
> This is how scripting works in RouterOS and we will not fix it.
To get around this we use variable names in CamelCase. Let's hope
Mikrotik never ever introduces property names in CamelCase...
*fingers crossed*
											
										 
											2019-01-03 17:45:43 +01:00
										 |  |  |   2=":global SendNotification; :global Identity; \$SendNotification (\"Hello...\") (\"Hello world, \" . \$Identity . \" calling!\");"; | 
					
						
							| 
									
										
										
										
											2018-11-13 10:17:56 +01:00
										 |  |  |   3="/ system shutdown;"; | 
					
						
							|  |  |  |   4="/ system reboot;"; | 
					
						
							| 
									
										
										
										
											2021-11-12 14:10:13 +01:00
										 |  |  |   5=":global BridgePortVlan; \$BridgePortVlan alt;"; | 
					
						
							| 
									
										
										
										
											2018-09-13 22:25:38 +02:00
										 |  |  | # add more here... | 
					
						
							| 
									
										
										
										
											2018-09-10 22:15:54 +02:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2020-10-23 21:33:38 +02:00
										 |  |  | # This led gives visual feedback if type is 'on' or 'off'. | 
					
						
							|  |  |  | :global ModeButtonLED "user-led"; | 
					
						
							| 
									
										
										
										
											2018-09-10 22:15:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-13 22:05:36 +02:00
										 |  |  | # Run commands on SMS action. | 
					
						
							| 
									
										
											  
											
												global: variable names are CamelCase
            ___  _         ___     __
           / _ )(_)__ _   / _/__ _/ /_
          / _  / / _ `/  / _/ _ `/ __/
         /____/_/\_, /  /_/ \_,_/\__/
 _       __     /___/       _             __
| |     / /___ __________  (_)___  ____ _/ /
| | /| / / __ `/ ___/ __ \/ / __ \/ __ `/ /
| |/ |/ / /_/ / /  / / / / / / / / /_/ /_/
|__/|__/\__,_/_/  /_/ /_/_/_/ /_/\__, (_)
                                /____/
RouterOS has some odd behavior when it comes to variable names. Let's
have a look at the interfaces:
[admin@MikroTik] > / interface print where name=en1
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
That looks ok. Now we use a script:
{ :local interface "en1";
  / interface print where name=$interface; }
And the result...
[admin@MikroTik] > { :local interface "en1";
{...   / interface print where name=$interface; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
... still looks ok.
We make a little modification to the script:
{ :local name "en1";
  / interface print where name=$name; }
And the result:
[admin@MikroTik] > { :local name "en1";
{...   / interface print where name=$name; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
 1   S en2                                 ether            1500  1598
 2   S en3                                 ether            1500  1598
 3   S en4                                 ether            1500  1598
 4   S en5                                 ether            1500  1598
 5  R  br-local                            bridge           1500  1598
Ups! The filter has no effect!
That happens whenever the variable name ($name) matches the property
name (name=).
And another modification:
{ :local type "en1";
  / interface print where name=$type; }
And the result:
[admin@MikroTik] > { :local type "en1";
{...   / interface print where name=$type; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
Ups! Nothing?
Even if the variable name ($type) matches whatever property name (type=)
things go wrong.
The answer from MikroTik support (in Ticket#2019010222000454):
> This is how scripting works in RouterOS and we will not fix it.
To get around this we use variable names in CamelCase. Let's hope
Mikrotik never ever introduces property names in CamelCase...
*fingers crossed*
											
										 
											2019-01-03 17:45:43 +01:00
										 |  |  | :global SmsAction { | 
					
						
							| 
									
										
										
										
											2021-11-12 14:10:13 +01:00
										 |  |  |   bridge-port-vlan-alt=":global BridgePortVlan; \$BridgePortVlan alt;"; | 
					
						
							| 
									
										
										
										
											2018-11-13 10:20:45 +01:00
										 |  |  |   reboot="/ system reboot;"; | 
					
						
							|  |  |  |   shutdown="/ system shutdown;"; | 
					
						
							| 
									
										
										
										
											2018-09-13 22:05:36 +02:00
										 |  |  | # add more here... | 
					
						
							| 
									
										
										
										
											2018-10-04 13:32:21 +02:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2018-09-13 22:05:36 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-05 15:29:26 +02:00
										 |  |  | # This address should resolve ntp servers and is used to update | 
					
						
							|  |  |  | # ntp settings. A pool can rotate servers. | 
					
						
							| 
									
										
											  
											
												global: variable names are CamelCase
            ___  _         ___     __
           / _ )(_)__ _   / _/__ _/ /_
          / _  / / _ `/  / _/ _ `/ __/
         /____/_/\_, /  /_/ \_,_/\__/
 _       __     /___/       _             __
| |     / /___ __________  (_)___  ____ _/ /
| | /| / / __ `/ ___/ __ \/ / __ \/ __ `/ /
| |/ |/ / /_/ / /  / / / / / / / / /_/ /_/
|__/|__/\__,_/_/  /_/ /_/_/_/ /_/\__, (_)
                                /____/
RouterOS has some odd behavior when it comes to variable names. Let's
have a look at the interfaces:
[admin@MikroTik] > / interface print where name=en1
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
That looks ok. Now we use a script:
{ :local interface "en1";
  / interface print where name=$interface; }
And the result...
[admin@MikroTik] > { :local interface "en1";
{...   / interface print where name=$interface; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
... still looks ok.
We make a little modification to the script:
{ :local name "en1";
  / interface print where name=$name; }
And the result:
[admin@MikroTik] > { :local name "en1";
{...   / interface print where name=$name; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
 1   S en2                                 ether            1500  1598
 2   S en3                                 ether            1500  1598
 3   S en4                                 ether            1500  1598
 4   S en5                                 ether            1500  1598
 5  R  br-local                            bridge           1500  1598
Ups! The filter has no effect!
That happens whenever the variable name ($name) matches the property
name (name=).
And another modification:
{ :local type "en1";
  / interface print where name=$type; }
And the result:
[admin@MikroTik] > { :local type "en1";
{...   / interface print where name=$type; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
Ups! Nothing?
Even if the variable name ($type) matches whatever property name (type=)
things go wrong.
The answer from MikroTik support (in Ticket#2019010222000454):
> This is how scripting works in RouterOS and we will not fix it.
To get around this we use variable names in CamelCase. Let's hope
Mikrotik never ever introduces property names in CamelCase...
*fingers crossed*
											
										 
											2019-01-03 17:45:43 +01:00
										 |  |  | :global NtpPool "pool.ntp.org"; | 
					
						
							| 
									
										
										
										
											2018-07-05 15:29:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-06 14:21:55 +02:00
										 |  |  | # This is the address used to send gps data to. | 
					
						
							| 
									
										
											  
											
												global: variable names are CamelCase
            ___  _         ___     __
           / _ )(_)__ _   / _/__ _/ /_
          / _  / / _ `/  / _/ _ `/ __/
         /____/_/\_, /  /_/ \_,_/\__/
 _       __     /___/       _             __
| |     / /___ __________  (_)___  ____ _/ /
| | /| / / __ `/ ___/ __ \/ / __ \/ __ `/ /
| |/ |/ / /_/ / /  / / / / / / / / /_/ /_/
|__/|__/\__,_/_/  /_/ /_/_/_/ /_/\__, (_)
                                /____/
RouterOS has some odd behavior when it comes to variable names. Let's
have a look at the interfaces:
[admin@MikroTik] > / interface print where name=en1
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
That looks ok. Now we use a script:
{ :local interface "en1";
  / interface print where name=$interface; }
And the result...
[admin@MikroTik] > { :local interface "en1";
{...   / interface print where name=$interface; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
... still looks ok.
We make a little modification to the script:
{ :local name "en1";
  / interface print where name=$name; }
And the result:
[admin@MikroTik] > { :local name "en1";
{...   / interface print where name=$name; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
 1   S en2                                 ether            1500  1598
 2   S en3                                 ether            1500  1598
 3   S en4                                 ether            1500  1598
 4   S en5                                 ether            1500  1598
 5  R  br-local                            bridge           1500  1598
Ups! The filter has no effect!
That happens whenever the variable name ($name) matches the property
name (name=).
And another modification:
{ :local type "en1";
  / interface print where name=$type; }
And the result:
[admin@MikroTik] > { :local type "en1";
{...   / interface print where name=$type; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
Ups! Nothing?
Even if the variable name ($type) matches whatever property name (type=)
things go wrong.
The answer from MikroTik support (in Ticket#2019010222000454):
> This is how scripting works in RouterOS and we will not fix it.
To get around this we use variable names in CamelCase. Let's hope
Mikrotik never ever introduces property names in CamelCase...
*fingers crossed*
											
										 
											2019-01-03 17:45:43 +01:00
										 |  |  | :global GpsTrackUrl "https://example.com/index.php"; | 
					
						
							| 
									
										
										
										
											2018-08-06 14:21:55 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-09 16:05:04 +02:00
										 |  |  | # Enable this to fetch scripts from given url. | 
					
						
							| 
									
										
											  
											
												global: variable names are CamelCase
            ___  _         ___     __
           / _ )(_)__ _   / _/__ _/ /_
          / _  / / _ `/  / _/ _ `/ __/
         /____/_/\_, /  /_/ \_,_/\__/
 _       __     /___/       _             __
| |     / /___ __________  (_)___  ____ _/ /
| | /| / / __ `/ ___/ __ \/ / __ \/ __ `/ /
| |/ |/ / /_/ / /  / / / / / / / / /_/ /_/
|__/|__/\__,_/_/  /_/ /_/_/_/ /_/\__, (_)
                                /____/
RouterOS has some odd behavior when it comes to variable names. Let's
have a look at the interfaces:
[admin@MikroTik] > / interface print where name=en1
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
That looks ok. Now we use a script:
{ :local interface "en1";
  / interface print where name=$interface; }
And the result...
[admin@MikroTik] > { :local interface "en1";
{...   / interface print where name=$interface; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
... still looks ok.
We make a little modification to the script:
{ :local name "en1";
  / interface print where name=$name; }
And the result:
[admin@MikroTik] > { :local name "en1";
{...   / interface print where name=$name; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
 1   S en2                                 ether            1500  1598
 2   S en3                                 ether            1500  1598
 3   S en4                                 ether            1500  1598
 4   S en5                                 ether            1500  1598
 5  R  br-local                            bridge           1500  1598
Ups! The filter has no effect!
That happens whenever the variable name ($name) matches the property
name (name=).
And another modification:
{ :local type "en1";
  / interface print where name=$type; }
And the result:
[admin@MikroTik] > { :local type "en1";
{...   / interface print where name=$type; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
Ups! Nothing?
Even if the variable name ($type) matches whatever property name (type=)
things go wrong.
The answer from MikroTik support (in Ticket#2019010222000454):
> This is how scripting works in RouterOS and we will not fix it.
To get around this we use variable names in CamelCase. Let's hope
Mikrotik never ever introduces property names in CamelCase...
*fingers crossed*
											
										 
											2019-01-03 17:45:43 +01:00
										 |  |  | :global ScriptUpdatesFetch true; | 
					
						
							| 
									
										
										
										
											2019-08-30 13:28:14 +02:00
										 |  |  | :global ScriptUpdatesBaseUrl "https://git.eworm.de/cgit/routeros-scripts/plain/"; | 
					
						
							| 
									
										
										
										
											2021-02-25 11:13:35 +01:00
										 |  |  | # alternative urls - main: stable code - next: currently in development | 
					
						
							| 
									
										
										
										
											2021-02-23 10:14:09 +01:00
										 |  |  | #:global ScriptUpdatesBaseUrl "https://raw.githubusercontent.com/eworm-de/routeros-scripts/main/"; | 
					
						
							| 
									
										
										
										
											2021-02-25 11:13:35 +01:00
										 |  |  | #:global ScriptUpdatesBaseUrl "https://raw.githubusercontent.com/eworm-de/routeros-scripts/next/"; | 
					
						
							| 
									
										
										
										
											2021-02-23 10:14:09 +01:00
										 |  |  | #:global ScriptUpdatesBaseUrl "https://gitlab.com/eworm-de/routeros-scripts/raw/main/"; | 
					
						
							| 
									
										
										
										
											2021-02-25 11:13:35 +01:00
										 |  |  | #:global ScriptUpdatesBaseUrl "https://gitlab.com/eworm-de/routeros-scripts/raw/next/"; | 
					
						
							| 
									
										
											  
											
												global: variable names are CamelCase
            ___  _         ___     __
           / _ )(_)__ _   / _/__ _/ /_
          / _  / / _ `/  / _/ _ `/ __/
         /____/_/\_, /  /_/ \_,_/\__/
 _       __     /___/       _             __
| |     / /___ __________  (_)___  ____ _/ /
| | /| / / __ `/ ___/ __ \/ / __ \/ __ `/ /
| |/ |/ / /_/ / /  / / / / / / / / /_/ /_/
|__/|__/\__,_/_/  /_/ /_/_/_/ /_/\__, (_)
                                /____/
RouterOS has some odd behavior when it comes to variable names. Let's
have a look at the interfaces:
[admin@MikroTik] > / interface print where name=en1
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
That looks ok. Now we use a script:
{ :local interface "en1";
  / interface print where name=$interface; }
And the result...
[admin@MikroTik] > { :local interface "en1";
{...   / interface print where name=$interface; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
... still looks ok.
We make a little modification to the script:
{ :local name "en1";
  / interface print where name=$name; }
And the result:
[admin@MikroTik] > { :local name "en1";
{...   / interface print where name=$name; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
 1   S en2                                 ether            1500  1598
 2   S en3                                 ether            1500  1598
 3   S en4                                 ether            1500  1598
 4   S en5                                 ether            1500  1598
 5  R  br-local                            bridge           1500  1598
Ups! The filter has no effect!
That happens whenever the variable name ($name) matches the property
name (name=).
And another modification:
{ :local type "en1";
  / interface print where name=$type; }
And the result:
[admin@MikroTik] > { :local type "en1";
{...   / interface print where name=$type; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
Ups! Nothing?
Even if the variable name ($type) matches whatever property name (type=)
things go wrong.
The answer from MikroTik support (in Ticket#2019010222000454):
> This is how scripting works in RouterOS and we will not fix it.
To get around this we use variable names in CamelCase. Let's hope
Mikrotik never ever introduces property names in CamelCase...
*fingers crossed*
											
										 
											2019-01-03 17:45:43 +01:00
										 |  |  | :global ScriptUpdatesUrlSuffix ""; | 
					
						
							| 
									
										
										
										
											2021-12-14 16:44:01 +01:00
										 |  |  | # use next branch with default url (git.eworm.de) | 
					
						
							| 
									
										
										
										
											2021-02-25 11:13:35 +01:00
										 |  |  | #:global ScriptUpdatesUrlSuffix "\?h=next"; | 
					
						
							| 
									
										
										
										
											2020-07-14 16:32:17 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-09 22:05:45 +02:00
										 |  |  | # Use this for defaults with $ScriptRunOnce | 
					
						
							| 
									
										
										
										
											2021-09-17 16:32:59 +02:00
										 |  |  | # Install module with: | 
					
						
							| 
									
										
										
										
											2021-11-15 20:22:56 +01:00
										 |  |  | # $ScriptInstallUpdate mod/scriptrunonce | 
					
						
							| 
									
										
										
										
											2021-07-09 22:05:45 +02:00
										 |  |  | :global ScriptRunOnceBaseUrl ""; | 
					
						
							|  |  |  | :global ScriptRunOnceUrlSuffix ""; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-30 13:41:20 +02:00
										 |  |  | # This project is developed in private spare time and usage is free of charge | 
					
						
							|  |  |  | # for you. If you like the scripts and think this is of value for you or your | 
					
						
							|  |  |  | # business please consider a donation: | 
					
						
							|  |  |  | # https://git.eworm.de/cgit/routeros-scripts/about/#donate | 
					
						
							|  |  |  | # Enable this to silence donation hint. | 
					
						
							|  |  |  | :global IDonate false; | 
					
						
							| 
									
										
										
										
											2018-07-09 16:05:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-20 15:55:40 +01:00
										 |  |  | # Use this for certificate auto-renew | 
					
						
							| 
									
										
											  
											
												global: variable names are CamelCase
            ___  _         ___     __
           / _ )(_)__ _   / _/__ _/ /_
          / _  / / _ `/  / _/ _ `/ __/
         /____/_/\_, /  /_/ \_,_/\__/
 _       __     /___/       _             __
| |     / /___ __________  (_)___  ____ _/ /
| | /| / / __ `/ ___/ __ \/ / __ \/ __ `/ /
| |/ |/ / /_/ / /  / / / / / / / / /_/ /_/
|__/|__/\__,_/_/  /_/ /_/_/_/ /_/\__, (_)
                                /____/
RouterOS has some odd behavior when it comes to variable names. Let's
have a look at the interfaces:
[admin@MikroTik] > / interface print where name=en1
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
That looks ok. Now we use a script:
{ :local interface "en1";
  / interface print where name=$interface; }
And the result...
[admin@MikroTik] > { :local interface "en1";
{...   / interface print where name=$interface; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
... still looks ok.
We make a little modification to the script:
{ :local name "en1";
  / interface print where name=$name; }
And the result:
[admin@MikroTik] > { :local name "en1";
{...   / interface print where name=$name; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
 0  RS en1                                 ether            1500  1598
 1   S en2                                 ether            1500  1598
 2   S en3                                 ether            1500  1598
 3   S en4                                 ether            1500  1598
 4   S en5                                 ether            1500  1598
 5  R  br-local                            bridge           1500  1598
Ups! The filter has no effect!
That happens whenever the variable name ($name) matches the property
name (name=).
And another modification:
{ :local type "en1";
  / interface print where name=$type; }
And the result:
[admin@MikroTik] > { :local type "en1";
{...   / interface print where name=$type; }
Flags: D - dynamic, X - disabled, R - running, S - slave
 #     NAME                                TYPE       ACTUAL-MTU L2MTU
Ups! Nothing?
Even if the variable name ($type) matches whatever property name (type=)
things go wrong.
The answer from MikroTik support (in Ticket#2019010222000454):
> This is how scripting works in RouterOS and we will not fix it.
To get around this we use variable names in CamelCase. Let's hope
Mikrotik never ever introduces property names in CamelCase...
*fingers crossed*
											
										 
											2019-01-03 17:45:43 +01:00
										 |  |  | :global CertRenewUrl ""; | 
					
						
							|  |  |  | #:global CertRenewUrl "https://example.com/certificates/"; | 
					
						
							| 
									
										
										
										
											2020-12-18 16:02:31 +01:00
										 |  |  | :global CertRenewTime 3w; | 
					
						
							| 
									
										
										
										
											2019-04-01 22:45:38 +02:00
										 |  |  | :global CertRenewPass { | 
					
						
							|  |  |  |   "v3ry-s3cr3t"; | 
					
						
							|  |  |  |   "4n0th3r-s3cr3t"; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2020-03-20 08:49:09 +01:00
										 |  |  | :global CertIssuedExportPass { | 
					
						
							|  |  |  |   "cert1-cn"="v3ry-s3cr3t"; | 
					
						
							|  |  |  |   "cert2-cn"="4n0th3r-s3cr3t"; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2021-12-07 15:40:14 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | # load custom settings from overlay | 
					
						
							|  |  |  | # Warning: Do *NOT* copy this code to overlay! | 
					
						
							|  |  |  | :do { | 
					
						
							|  |  |  |   / system script run global-config-overlay; | 
					
						
							|  |  |  | } on-error={ | 
					
						
							|  |  |  |   :log error ("Loading configuration from overlay failed!"); | 
					
						
							|  |  |  | } |