mirror of
https://github.com/gbudny93/RouterOS_Useful_Scripts.git
synced 2025-06-26 03:38:38 +02:00
378 lines
No EOL
11 KiB
Markdown
378 lines
No EOL
11 KiB
Markdown
## RouterOS_Useful_Scripts
|
|
> MikroTik RouterOS Scripts for various use and shared among different projects. Repository contains ready to use scripts as well functions ready to use in larger projects.
|
|
**Check also another repository with scripts related strictly to MikroTik CAPsMAN automation :link: [CAPsMAN Automation Scripts](https://github.com/gbudny93/MikroTik_CAPsMAN_Automation).**
|
|
**Here you can find script template that I use :link: [RouterOS_Script_Template](https://gist.github.com/gbudny93/8ad0899576407e5efe9323febb368796).**
|
|
|
|

|
|

|
|

|
|
|
|
#### Change log
|
|
- 7/3/2020
|
|
- RouterOS_All_Software_Download.rsc - typos fix
|
|
- RouterOS_Array_Append.rsc
|
|
|
|
- 4/19/2020
|
|
- RouterOS_All_Software_Download.rsc
|
|
- RouterOS_Dual_WAN_Failover.rsc
|
|
|
|
- 23/3/2020
|
|
- RouterOS_Config_Fetch.rsc
|
|
- RouterOS_Measure_Execution_Time.rsc
|
|
- RouterOS_RB750GR3_DUDE_Setup.rsc
|
|
|
|
- 15/2/2020
|
|
- RouterOS_Cloud_Backup.rsc
|
|
- RouterOS_FTP_Backup.rsc
|
|
- RouterOS_Function_Template.rsc
|
|
- RouterOS_PPP_Disconnect_Active_Sessions.rsc
|
|
- RouterOS_Recreate_Bridge.rsc
|
|
|
|
- 12/4/2019
|
|
- RouterOS_RadiusMonitor.rsc
|
|
- RouterOS_User_Alerts.rsc
|
|
|
|
- 12/4/2019
|
|
- RouterOS_Auto_Firmware_Upgrade.rsc
|
|
- RouterOS_Port_Knock.rsc
|
|
|
|
- 11/24/2019
|
|
- RouterOS_R_ARP.rsc
|
|
- RouterOS_Format_Drive.rsc
|
|
- RouterOS_Substring_Variable.rsc
|
|
- RouterOS_System_Status.rsc
|
|
|
|
- 10/14/2019
|
|
- RouterOS_Mail_Backup.rsc
|
|
- RouterOS_Cloud_Backup.rsc
|
|
- RouterOS_File_Screening.rsc
|
|
- RouterOS_Renew_License.rsc
|
|
- RouterOS_Script_Fetch.rsc - Update
|
|
- RouterOS_Auto_Upgrade.rsc - Update/Clean ups
|
|
|
|
- 10/1/2019
|
|
- RouterOS_Auto_Upgrade.rsc
|
|
- Fixed missing auto check for updates to get variables values at first
|
|
|
|
- 8/21/2019
|
|
- RouterOS_Script_Fetch.rsc
|
|
- Fetches script from git to RouterOS directory
|
|
|
|
- 8/14/2019
|
|
- RouterOS_Auto_Upgrade.rsc
|
|
- Upgrades RouterOS if new package found when run
|
|
|
|
- 8/3/2019
|
|
- RouterOS_String_Generator.rsc
|
|
- Generates 6 char string based on dictionary
|
|
- RouterOS_Reset_Interface.rsc
|
|
- Resets interface if particular IP does not respond
|
|
|
|
- 7/29/2019
|
|
- RouterOS_Modulo.rsc
|
|
- Modulo operation
|
|
- RouterOS_Load_Script.rsc
|
|
- Loads RouterOS script to environment. If file is missing adds log entry
|
|
|
|
- 7/19/2019
|
|
- FTP_Backup_Template.rsc
|
|
- Schedules generation of *.backup* and *.rsc* file on RouterOS. Create FTP user dedicated for automatic backups. More on automatic RouterOS
|
|
backups can be found under dedicated project: :link: [Backup_mt by gbudny93](https://github.com/gbudny93/Backup_mt)
|
|
- RouterOS_Auto_Upgrade.rsc
|
|
- in progress
|
|
- RouterOS_Create_Directory.rsc
|
|
- Creates directory with specific name in RouterOS
|
|
- RouterOS_Log_Filtering.rsc
|
|
- Filters logs based on specified criteria: time or message and put in desired output
|
|
- RouterOS_Log_To_Alert.rsc
|
|
- Sends an email alert based on log message match
|
|
- RouterOS_Send_Email.rsc
|
|
- Sends email via SMTP server with common email parameters as function parameters
|
|
- RouterOS_File_Logging.rsc
|
|
- Adds log entry if file was added or removed
|
|
- RouterOS_LCD_Change.rsc (Applies only to physical devices with LCD)
|
|
- Changes LCD mode from dark to light and vice versa based on schedule set up
|
|
- RouterOS_Low_Disk_Space.rsc
|
|
- Sends email alert if disk space is under specified treshhold
|
|
- RouterOS_File_Screening.rsc
|
|
- in progress
|
|
- RouterOS_Eth_Errors_Handling.rsc
|
|
- in progress
|
|
- RouterOS_Config_Check.rsc
|
|
- in progress
|
|
|
|
- 6/14/2019 first release
|
|
- FTP_Backup_Template.rsc
|
|
- Schedules generation of *.backup* and *.rsc* file on RouterOS. Create FTP user dedicated for automatic backups. More on automatic RouterOS
|
|
backups can be found under dedicated project: :link: [Backup_mt by gbudny93](https://github.com/gbudny93/Backup_mt)
|
|
- RouterOS_Auto_Upgrade.rsc
|
|
- in progress
|
|
- RouterOS_Create_Directory.rsc
|
|
- Function that creates directory with specific name in RouterOS
|
|
- RouterOS_Log_Filtering.rsc
|
|
- in progress
|
|
- RouterOS_Log_To_Alert.rsc
|
|
- in progress
|
|
- RouterOS_Send_Email.rsc
|
|
- Fucntion sending email via SMTP server with common email parameters as function parameters
|
|
|
|
### Prerequisites
|
|
|
|
- :white_check_mark: RouterOS v6.40 or higher
|
|
- :white_check_mark: MikroTik CRS or CCR with LCD for RouterOS_LCD_Change.rsc
|
|
|
|
### How to use
|
|
> Use the following scripts to make your RouterOS management easier or use them in various larger scripts or projects
|
|
:+1:
|
|
|
|
#### FTP_Backup_Template.rsc
|
|
> This script creates two files via RouterOS scheduler as well creates FTP user and group:
|
|
- *.backup* file
|
|
- *.rsc* file
|
|
|
|
Script is a part of :link: [Backup_mt by gbudny93](https://github.com/gbudny93/Backup_mt) project.
|
|
|
|
#### RouterOS_All_Software_Download.rsc
|
|
> Automated download of all latest RouterOS standard packages. Tool recommended for CAPsMANs and DUDE servers
|
|
|
|
### RouterOS_Array_Append.rsc
|
|
> Wrapper to append array elements
|
|
|
|
#### RouterOS_Auto_Firmware_Upgrade.rsc
|
|
> Checks if latest firmware is available. Installs it and sends email notification
|
|
|
|
**Example**
|
|
```
|
|
$AutoFirmwareUpgrade smtpServer=smtpServer smtpPort=smtpPort domain=example.com \
|
|
recipient=recipient@example.com;
|
|
```
|
|
|
|
#### RouterOS_Auto_Software_Upgrade.rsc
|
|
> Checks if latest package is available. Downloads it, installs and sends email notification
|
|
|
|
**Example**
|
|
```
|
|
$PackageAutoDownload userName=userName password=password packagePath=path \
|
|
smtpServer=ipAddress smtpPort=poty domain=@example.com \
|
|
recipient=recipient@example.com;
|
|
```
|
|
|
|
#### RouterOS_Cloud_Backup.rsc
|
|
> Creates new backup file and uploads it to MikroTik Cloud
|
|
|
|
**Example**
|
|
```
|
|
$CloudBackup password=password;
|
|
```
|
|
|
|
#### RouterOS_Create_Directory.rsc
|
|
> RouterOS function that creates directory with defined name in the system. Can be used just to create directory or be a part of larger project.
|
|
|
|
**Example**
|
|
```
|
|
$CreateDirecotry userName=UserName password=Password directoryName=DirectoryName;
|
|
```
|
|
|
|
#### RouterOS_Dual_WAN_Failover.rsc
|
|
> Simple setup for DUAL WAN failover. Main WAN must be commented as WAN1. Secondary WAN must be commented as WAN2
|
|
|
|
#### RouterOS_Log_Filtering.rsc
|
|
> RouterOS function for log messages filtering based on message or time match stored in chosen output.
|
|
|
|
**Example**
|
|
```
|
|
$LogFilter;
|
|
```
|
|
|
|
#### RouterOS_Log_To_Alert.rsc
|
|
> RouterOS function sending mail alert if log entry matches message criteria.
|
|
|
|
**Example**
|
|
```
|
|
$LogToAlert message="message" fileName="fileName" smtpServer=smtpServer smtpPort=smtpPort domain="@example.com" \
|
|
recipient="recipient@example.com";
|
|
```
|
|
|
|
#### RouterOS_Send_Email.rsc
|
|
> RouterOS function to send email via SMTP server. Function contains all common email fields like *to*, *cc*, *subject*, *body* and more. Function can be called itself in RouterOS or by other script.
|
|
|
|
**Example**
|
|
```
|
|
$SendEmail smtpServer=SMTPServer smtpPort=SMTPPort from=From to=To subject=Subject body=Body;
|
|
```
|
|
|
|
#### RouterOS_File_Logging.rsc
|
|
> RouterOS function adding log entry if file was added or removed.
|
|
|
|
**Example**
|
|
```
|
|
$FileToLog;
|
|
```
|
|
|
|
#### RouterOS_LCD_Change.rsc
|
|
> RouterOS function changing LCD mode from dark to light and vice versa based on schedule setup.
|
|
|
|
**Example**
|
|
```
|
|
$ChangeLcd lightModeStartTime="08:00:00" darkModeStartTime="17:00:00";
|
|
```
|
|
|
|
#### RouterOS_Low_Disk_Space.rsc
|
|
> RouterOS function generating mail alert if disk space is below defined treshhold.
|
|
|
|
**Example**
|
|
```
|
|
$LowDiskSpace treshhold=free_disk_space_in_%;
|
|
```
|
|
|
|
#### RouterOS_Mail_Backup.rsc
|
|
> Creates RouterOS backup and config file and sends them via email
|
|
|
|
**Example**
|
|
```
|
|
$MailBackup configName=configName backupName=backupName smtpServer=smtpServer smtpPort=smtpPort domain=@example.com \
|
|
recipient=recipient@example.com;
|
|
```
|
|
|
|
#### RouterOS_File_Screening.rsc
|
|
> Removes files by specific name or file extansion
|
|
|
|
**Example**
|
|
```
|
|
$FileScreening keyWord=".txt";
|
|
```
|
|
|
|
#### RouterOS_Format_Drive.rsc
|
|
> Formats RouterOS additional drive
|
|
|
|
**Example**
|
|
```
|
|
$FormatDrive drive=0 fileSystem=ext3 label=data;
|
|
```
|
|
|
|
#### RouterOS_Modulo.rsc
|
|
>Modulo function.
|
|
|
|
**Example**
|
|
```
|
|
$Modulo number=number_to_be_devided modulo=modulo_value;
|
|
```
|
|
|
|
#### RouterOS_Port_Knock.rsc
|
|
> Port Knock from RouterOS
|
|
|
|
**Example**
|
|
```
|
|
:global knockBase {"sourceIP1"="port23"; \
|
|
"sourceIP2"="port22" \
|
|
};
|
|
|
|
$PortKnock base=$knockBase destinationAddress=destinationIP;
|
|
```
|
|
|
|
#### RouterOS_R_ARP.rsc
|
|
> ARP/RARP Function (shortange syntax)
|
|
|
|
**Example**
|
|
```
|
|
$R_ARP mode=mode;
|
|
```
|
|
|
|
#### RouterOS_Radius_Monitor.rsc
|
|
> Sends Radius statistics via email
|
|
|
|
**Example**
|
|
```
|
|
$RadiusMonitor smtpServer=smtpServer smtpPort=smtpPort domain="@example.com" recipient="recipient@example.com";
|
|
```
|
|
|
|
#### RouterOS_Renew_License.rsc
|
|
> Renews RouterOS License
|
|
|
|
**Example**
|
|
```
|
|
$RenewLicense account=account password=password level=level;
|
|
```
|
|
|
|
#### RouterOS_Load_Script.rsc
|
|
> Loads function to RouterOS environment
|
|
|
|
**Example**
|
|
```
|
|
$LoadScript scriptName=scriptName.rsc;
|
|
```
|
|
|
|
#### RouterOS_String_Generator.rsc
|
|
> Generates 6 char string based on dictionary
|
|
|
|
**Example**
|
|
```
|
|
$GenerateString;
|
|
```
|
|
|
|
#### RouterOS_Reset_Interface.rsc
|
|
> Resets interface if particular IP does not respond
|
|
|
|
**Example**
|
|
```
|
|
$ResetInterface ipAddress=ipAddress_To_Monitor interfaceName=interface_name;
|
|
```
|
|
|
|
#### RouterOS_Script_Fetch.rsc
|
|
> Fetches script from git to RouterOS directory
|
|
|
|
**Example**
|
|
```
|
|
$FetchScript url="https://example.repo.com" destinationPath="FolderName" destinationFileName="ScriptName"
|
|
|
|
$FetchScript url="https://example.repo.com" destinationPath="FolderName" destinationFileName="ScriptName" isRun=true
|
|
|
|
$FetchScript url="https://example.repo.com" destinationPath="FolderName" destinationFileName="ScriptName" isSchedule=true\
|
|
interval="24" taskName="TaskName" startTime="startup"
|
|
```
|
|
|
|
#### RouterOS_Substring_Variable.rsc
|
|
> Substrings variable
|
|
|
|
**Example**
|
|
```
|
|
$Substring findMode=true string="string" signA="A" signB "b";
|
|
```
|
|
|
|
#### RouterOS_User_alert.rsc
|
|
> After defined number of logon failure attempts in 1 hour sends email alert and blocks source IP on firewall
|
|
|
|
**Example**
|
|
```
|
|
$UserAlert message="message" treshhold=3 fileName="fileName" smtpServer=smtpServer smtpPort=smtpPort domain="@example.com" \
|
|
recipient="recipient@example.com";
|
|
```
|
|
|
|
#### RouterOS_FTP_Backup.rsc
|
|
> Creates backup files and sends them via FTP to FTP server
|
|
|
|
**Example**
|
|
```
|
|
$FTPBackup configName=configName backupName=backupName smtpServer=smtpServer smtpPort=smtpPort domain=@example.com \
|
|
recipient=recipient@example.com destPath=destPath ftpUser=user ftpPassword=password ftpServer=ftpserver;
|
|
```
|
|
|
|
#### RouterOS_Function_Template.rsc
|
|
> Function template that I use
|
|
|
|
#### RouterOS_PPP_Disconnect_Active_Sessions.rsc
|
|
> Disconnects all PPP active sessions at once
|
|
|
|
**Example**
|
|
```
|
|
$DisconnectPPPActveSessions;
|
|
```
|
|
|
|
#### RouterOS_Recreate_Bridge.rsc
|
|
> Recreates bridge if broken or misconfigured
|
|
|
|
#### More scripts comming soon :)
|
|
|
|
### Authors
|
|
|
|
- Grzegorz Budny |