Custom Integration Scripts
To set up the custom integration script, you will need to:
- Write the script.
- Optionally add credentials.
- Create an integration task.
Step 1: Write integration script
The script can be written in Starlark, a Python like language with some notable differences:
- There is no exception handling (
try/catch
) - There is no f-string
f'{var}'
formatting -"{}".format(var)
is the supported method of string interpolation.
Step 1a: Entrypoint
The script needs an entrypoint, a function that gets called by the runZero service and returns the Inventory Assets discovered by the script.
- The entrypoint must accept a variadic
*args
and**kwargs
for parameters to be passed in. - The entrypoint must return a
list
ofImportAsset
s to be imported. - The entrypoint (function name) of the script will default to
main
, but can be set depending on the integration type scan probe or a connector task.
def main(*args, **kwargs):
asset_one = ImportAsset(
id=1,
os='custom import os',
osVersion='0.0.0.0.0.0.1-pre-alphabetazed',
manufacturer='Name of manufacturer',
model='Model of asset',
)
asset_two = ImportAsset(
id=2,
os='custom import os 2',
osVersion='0.0.0.0.0.0.2-prezed',
manufacturer='Name of manufacturer',
model='model of asset',
)
return [asset_one, asset_two]
Step 2: Add the custom script Credential to runZero
The credential used for the script is a key-value pair passed into the script function as kwargs
and can be used as username and password or for anything requiring a secret.
def main(*args, **kwargs):
client_id = kwargs['access_key']
client_secret = kwargs['access_secret']
- Go to the Credentials page in the runZero console and click Add Credential.
- Choose Custom Script Secret from the list of credential types.
- Provide a name for the credential, like
Script Secret
for the service being integrated with. - Provide the following information:
- Access Key - The username or client id that will be passed into the script as a
kwargs
namedaccess_key
. - Access Secret - The secret that will be passed into the script as a
kwargs
namedaccess_secret
.
- Access Key - The username or client id that will be passed into the script as a
- If you want other organizations to be able to use this credential, select the
Make this a global credential
option. Otherwise, you can configure access on a per organization basis. - Save the credential.
Step 3: Create a new task
- Go to Tasks, click the Integrate button, and select Custom Scripts under Custom integrations from the dropdown.
- Provide a name for the task
- Select or create a custom integration
- Select or create credentials for the script
- Select an explorer
- Custom integration scripts must be run on a hosted explorer
- Select Site, Task description, and Schedule as appropriate.
- Click Activate Connection to start the task.
Using the CLI
The runzero
CLI includes a script
sub-command to help in writing and debugging Starlark scripts that use the [[#runZero Types]] and [[#Libraries]] outlined below.
Running scripts
Hello World
def main(*args, **kwargs):
print("Hello world!")
Save the file as print.star
so it can be run from the CLI
$ runzero script --filename print.star
Dec 12 12:59:07.099 [INFO] script: Hello world
None
Running the script with args
def main(*args, **kwargs):
print("Hello {}".format(args[0]))
$ runzero script --filename print.star --args Dave
Dec 12 13:01:20.707 [INFO] script: Hello Dave
None
Running the script with kwargs
def main(*args, **kwargs):
print("Hello {}".format(kwargs["name"]))
runzero script --filename print.star --kwargs name=Dave
Dec 12 13:28:56.933 [INFO] script: Hello Dave
None
args
and kwargs
can be called multiple times to pass in as many arguments as needed
def main(*args, **kwargs):
print("{} {}".format(args[0], args[1]))
print("{} {}".format(kwargs["access_key"], kwargs["access_secret"]))
runzero script --filename print.star --args Hello --args Dave --kwargs access_key=foo --kwargs access_secret=bar
Dec 12 13:45:50.284 [INFO] script: Hello Dave
Dec 12 13:45:50.284 [INFO] script: foo bar
None
REPL
The sub-command script repl
can be useful for larger scripts with multiple functions. The REPL will allow setting variables, calling functions, printing variables, and anything else that can be done in Starlark.
runzero script repl --filename print.star
>>> main(*("hello", "dave"), **{"access_key": "foo", "access_secret": "bar"})
Dec 12 14:53:42.384 [INFO] script: hello dave
Dec 12 14:53:42.384 [INFO] script: foo bar
>>> print("Hello {}".format("dave"))
Dec 12 14:57:28.961 [INFO] script: Hello dave
>>> args = ("hello", "dave")
>>> kwargs = {"access_key": "foo", "access_secret": "bar"}
>>> main(*args, **kwargs)
Dec 12 14:58:57.567 [INFO] script: hello dave
Dec 12 14:58:57.567 [INFO] script: foo bar
>>>
^D
To exit the REPL
runZero Types
Resource types are implemented in Starlark and are equivalent with the Python SDK types:
load('runzero.types', 'ImportAsset', 'NetworkInterface', 'Service', 'ServiceProtocolData', 'Software', 'Vulnerability')
Libraries
runZero provides some additional libraries for basic functionality to make web requests.
- http
load('http', http_post='post', http_get='get', 'url_encode')
url_encode
post
get
- net
load('net', 'ip_address')
ip_address
- json
load('json', json_encode='encode', json_decode='decode')
encode
decode
- time
load('time', 'parse_time')
parse_time
- uuid
load('uuid', 'new_uuid')
new_uuid
The types can be run from the CLI or loaded into the REPL.
runzero script repl --filename print.star
>>> load('json', json_encode='encode', json_decode='decode')
>>> greeter = json_decode('{"greeting":"hello", "name":"dave"}')
>>> print(greeter)
Dec 12 15:13:00.971 [INFO] script: {"greeting": "hello", "name": "dave"}
>>> ^D