Introduction
The Automation & Scripts feature allows you to create scripts that can be used on IP-connected devices to retrieve additional data and execute actions on them.
Supported network protocols:
- HTTP
- SSH
- WinRM
- Telnet
- SNMP
- TCP
How to use a Script and apply it to a specific device
Step 1 – Go to Integrations > Automation & Scripts
data:image/s3,"s3://crabby-images/57d28/57d283f817f5fb4963cc1e7f652df9d023ec214d" alt=""
Step 2 – Search for in our Library:
This will filter for example scripts that we have already developed which they work as it is and that can be customized to fit your needs:
data:image/s3,"s3://crabby-images/cdfda/cdfdae2aaa64499bc1c7eaf1a6ce77c2aaa18c09" alt=""
Step 3 – Select one Script example and “use” it:
data:image/s3,"s3://crabby-images/0edcd/0edcd74c203fa027b4f191e05dccff5a2e72e37f" alt=""
Step 4 – Select the devices you would like to apply it to and add the script to them:
data:image/s3,"s3://crabby-images/26783/26783d6de8485224d1a7c8d51e734357b8a610de" alt=""
Step 5 – Customize the scripts for your needs:
data:image/s3,"s3://crabby-images/08229/08229e54d1df6be279aa7a453642ff45943d76a3" alt=""
How to create a Script from scratch?
Search in the Click on Create a New Script:
data:image/s3,"s3://crabby-images/f41bf/f41bf580c20f7a3d096177414b3da53b4cbbe293" alt=""
Step 3 Enter script properties and code
data:image/s3,"s3://crabby-images/a7acd/a7acda1201f81678b13835616f91fb989ee94a2a" alt=""
Step 4 Add Parameters
If needed (most scripts won’t require parameters), by using the “Add Parameters” + button, it is possible to add parameters:
data:image/s3,"s3://crabby-images/b5116/b511682b9bd85379dd34ff0cb3caeb9b45d59406" alt=""
data:image/s3,"s3://crabby-images/98430/98430d1668167337256026037732cc15aa0d6645" alt=""
We support three parameter types: List, Text, and Number.
Once defined you will be able to see it here:
data:image/s3,"s3://crabby-images/bbcb6/bbcb6a98e77b7148ae0d648db7301266ce962b1f" alt=""
And you will be able to access it in the code by using the D.getParameter() function:
data:image/s3,"s3://crabby-images/682b8/682b866899027d41d35c06a1a6805de97901a1f2" alt=""
Change Parameters on an already applied script
Please note that once the script has been applied, you will be able to change its parameters directly in the Scripts tab:
data:image/s3,"s3://crabby-images/9a50c/9a50cb66a90517d95235042cd36c36b09de7bba0" alt=""
data:image/s3,"s3://crabby-images/9b46a/9b46a2e4d67a1979c43725a9f28cc086a1fa5a60" alt=""
Step 5 Add additional Custom Actions
By using the “Add Actions” button, it is possible to create user defined “actions/functions”:
data:image/s3,"s3://crabby-images/5874d/5874dc51eee625a9cd74a738d7995fd1ea1adbcd" alt=""
And these can be tested by assigning the script to the device and selecting the proper Custom function:
data:image/s3,"s3://crabby-images/96c1a/96c1a78d726ce65ff49f4a5b88f6d553cd1cb9e4" alt=""
In the above example, the custom_1 action is a button with the label “Reboot Now” that if pressed will run the command contained in the rebootCommand variable.
If you select the device you would like to test the script on and you select the custom_1 function and then press the “Run code” button, you will be able to test that specific action on the device.
After assigning the custom_1 action to the device (please see here how to assign it: https://help.domotz.com/monitoring-management/custom-driver/#htoc-how-to-apply-drivers-to-device) , you can see it in the “Scripts” tab of your device and execute the function by clicking on the “Execute Action” botton:
data:image/s3,"s3://crabby-images/691e5/691e571b85a837937ccf578f17ae6f744c75bc7a" alt=""
Expandable descriptions are also available for your Custom action under “Scripts” tab of your device.
data:image/s3,"s3://crabby-images/cf247/cf24737715d158c9987e8c99c936ea40e7b5f9b5" alt=""
How to test a Script?
You can validate the code of a script by executing it against a device of your choice.
Step 1 Open the Script Details section
data:image/s3,"s3://crabby-images/45511/45511d6404be044c60cb9abc1e295363b748c8a7" alt=""
Step 2 Select a Device for the Script
data:image/s3,"s3://crabby-images/09c54/09c544a40ee5043d016eb965bce44c5b13ac47fd" alt="Custom Driver screenshot 5"
Step 3 Select a function to execute.
- Validate is designed to verify if the device that you apply a script to can support the script’s functionality. To clarify, the function will be executed and depending on the result it will allow or prevent the script to device association:
- The D.success() callback indicates the device is a valid candidate for the script .
- The D.failure(D.errorType.DEVICE_NOT_SUPPORTED) callback indicates that this script’s functionality is not supported on the selected device.
2. Get_status and Run Code:
data:image/s3,"s3://crabby-images/fb935/fb935bdb377ed26174a9db07fe6bff1e9b8ef4eb" alt=""
data:image/s3,"s3://crabby-images/18b26/18b26687f4c7177fa4c88cc861039c76dea2255f" alt="Custom Driver screenshot 6"
Then select the device you want to run the script on:
data:image/s3,"s3://crabby-images/9bdad/9bdadf3fa6ba7bcf279a102ee6acc50536646a87" alt=""
Step 4 Run function code:
Step 4.1 If Credentials Required
data:image/s3,"s3://crabby-images/d958b/d958bbf714243c0861bbe5d36fad9a64bbc7f3f4" alt=""
Step 5 Checking the result
A pop-up will appear with the code run execution result for the specified function. You have two choices:
- get_status is the function name that was executed
- Variables is the section that contains a list of variable name-value pairs
– “this is an example label” is the name we’ve given the variable
– “this is an example value” is its value
data:image/s3,"s3://crabby-images/11f96/11f96296905967950f97eaa8c6200f6af0c17bf2" alt=""
You can also add logging to your script:
data:image/s3,"s3://crabby-images/b214b/b214b00b196009df190b0dff5df497ac7927b80d" alt=""
And after running the code you will be able to access it under the Log tab:
data:image/s3,"s3://crabby-images/6eb91/6eb9184f7974d805ae8e23ff5898d0f43c069081" alt=""
Script table variables
Now, you can also create table variables where each record is a demonstration of various key/value pairs. You can basically insert records and insert the unique identifier of the row, which in this case is the Docker container ID, then you just insert for each column your defined value.
data:image/s3,"s3://crabby-images/30e53/30e53c5d0ff2faf316645de387ff104a2463e016" alt=""
data:image/s3,"s3://crabby-images/6516b/6516b3208afe642c5f2595430adac1ca729b33ae" alt=""
How to define Script Table, you can follow the link: https://portal.domotz.com/custom-driver/driverTable.html
To see an example of script table variables: https://github.com/domotz/custom-driver/blob/master/examples/ssh/docker_stats.js
How to apply a Script from the Device Page
Step 1 – If no scripts where assigned to the device
Go on the page of the device you would like to apply the script to and click on “Apply Scripts to Device”:
data:image/s3,"s3://crabby-images/72743/72743dcebcb23c6d2e41d6abfbb770ab9e45cc35" alt=""
Step 1 – If you have already assigned a script to a specific device
Go on the page of the device you would like to apply the script to and click on select “Manage Automation & Scripts” or click on the “Scripts” tab button:
data:image/s3,"s3://crabby-images/b88e8/b88e8327d9a4cf4863b2206f46e16da62a70f449" alt=""
Step 2 – Search and Apply the custom script
Select the script that you want to apply to this device. To filter your Script list, check the boxes ” Already associated to a device” or ” Valid Code”, or both.
data:image/s3,"s3://crabby-images/d605a/d605a18d2442be211efb55bcf34770c407a959a1" alt=""
data:image/s3,"s3://crabby-images/5d8e5/5d8e553aaa498f2cfebf0ac71128d9c0a17adcc4" alt=""
The ‘Script’ tab will appeare after assigning a script to a single device:
data:image/s3,"s3://crabby-images/fe638/fe63850f692b2576f32c9d206416b7d69487dfa3" alt=""
When multiple scripts are associated to a single device, the Scripts tab will display them one after the other (you just need to scroll down in the Scripts section):
data:image/s3,"s3://crabby-images/cc66d/cc66d568d167eb0ef75a88843b22fa652ef2dba6" alt=""
Agent Variable Consumption
The Agent’s Automation & Scripts variable consumption box shown on the ‘Devices lis’t screen indicates the number of script variables consumed by the particular Agent:
data:image/s3,"s3://crabby-images/d2294/d2294002d2b692a926bbe3cc587b704e7f514d0c" alt=""
By clicking on the highlighted above section, you will be able to access the Manage Automation & Scripts section where you can see which devices are consuming variables:
data:image/s3,"s3://crabby-images/bc2d9/bc2d926f39a67ae27930ea5744cbb97517727f23" alt=""
Step 3 Script configuration
Go to the Scripts tab and find your script configuration (sample period) and results:
data:image/s3,"s3://crabby-images/9089a/9089ab911dbfddcbfb51eab3895a72fc87bcc47f" alt=""
A historical view of the variable value changes is available by clicking under its value cell:
How to Download a CSV file of your Script variables tables
After selecting your device, please enter the Scripts tab of your device with custom integrations and click the “Download CSV” link to download a CSV of your chosen variables tables.
data:image/s3,"s3://crabby-images/c4dfb/c4dfb806245c62825247737168cb8a73aa078d6e" alt=""
Failed Scripts
If one or more scripts are in the “Failed” status, you will see an informative banner in the “Automation and Scripts variables” section stating “One or more Scripts have stopped working”.
data:image/s3,"s3://crabby-images/8ea1f/8ea1fc483dd3bb2e69f2ddb17f12121156963048" alt=""
By clicking on the banner, you will be able to access the Manage Automation & Scripts section, where you can see a list of devices for which the script has been stopped.
data:image/s3,"s3://crabby-images/52226/5222619026498c8b12f1bb6bb80d8320092e5ddd" alt=""