menu:operate:scenarios:commands
Differences
This shows you the differences between two versions of the page.
menu:operate:scenarios:commands [2022/04/07 11:44] – [file_put] yspeerte | menu:operate:scenarios:commands [2024/07/03 12:31] (current) – external edit 127.0.0.1 | ||
---|---|---|---|
Line 1: | Line 1: | ||
+ | {{indexmenu_n> | ||
+ | |||
+ | ====== Scenario Commands ====== | ||
+ | |||
+ | Scenario Commands can be called upon in scenarios. They can return nothing, a list variable or a hash variable. When they fail, the < | ||
+ | |||
+ | Several of the commands will benefit from the support of 'here documents' | ||
+ | |||
+ | |||
+ | ===== Commands ===== | ||
+ | |||
+ | ==== cmd_exec ==== | ||
+ | <WRAP indent> | ||
+ | Execute command line-by line on cli of a NetYCE managed node. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node | ||
+ | -f cmd_file | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-o < | ||
+ | [-c < | ||
+ | [-a < | ||
+ | [-d < | ||
+ | [-v < | ||
+ | [-q] sets quick-mode: skip config save/ | ||
+ | [-e] | ||
+ | [-u < | ||
+ | </ | ||
+ | |||
+ | The '' | ||
+ | to login to the device. When available, the '' | ||
+ | |||
+ | The '' | ||
+ | The logs will not indicate an error was encountered. | ||
+ | </ | ||
+ | |||
+ | ==== cmd_exec_basic ==== | ||
+ | |||
+ | <WRAP indent> | ||
+ | Execute command line by line on cli of a node in the CMDB table | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node | ||
+ | -f cmd_file | ||
+ | -a < | ||
+ | -d < | ||
+ | -v < | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-c < | ||
+ | [-u < | ||
+ | </ | ||
+ | |||
+ | The '' | ||
+ | to login to the device. When available, the '' | ||
+ | |||
+ | </ | ||
+ | ==== resched_job ==== | ||
+ | |||
+ | <WRAP indent> | ||
+ | |||
+ | > <color orange> Note </ | ||
+ | |||
+ | Schedule the running job to execute again. The '' | ||
+ | |||
+ | To stop the job from rescheduling itself it needs to be manually ' | ||
+ | |||
+ | |||
+ | == Mandatory options == | ||
+ | |||
+ | It is mandatory to specify the '' | ||
+ | |||
+ | < | ||
+ | -i interval | ||
+ | " | ||
+ | no ' | ||
+ | -t daytime | ||
+ | " | ||
+ | no ' | ||
+ | </ | ||
+ | |||
+ | A maximum of eight (8) days can be scheduled ahead of the current time using either the ' | ||
+ | |||
+ | Using a ' | ||
+ | If the ' | ||
+ | |||
+ | == Optional == | ||
+ | < | ||
+ | [-s] set server selection to ' | ||
+ | </ | ||
+ | |||
+ | Job parameters are reused from the scheduler and job files: | ||
+ | - reuse scenario file | ||
+ | - reuse command file | ||
+ | - reuse parameters file | ||
+ | - operator will stay the same | ||
+ | - reuse the change-id | ||
+ | - reuse the queue | ||
+ | - reuse the description | ||
+ | - jobtype stays the same - reuse job-rule validations / approvals | ||
+ | |||
+ | The NetYCE server where the job will be rescheduled is the same as the current server by default. Only when the ' | ||
+ | |||
+ | |||
+ | </ | ||
+ | |||
+ | ===== Configs ===== | ||
+ | |||
+ | ==== config_create ==== | ||
+ | <WRAP indent> | ||
+ | Generate commands from template. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node hostname of the node | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-t < | ||
+ | [-f < | ||
+ | [-p parameter=< | ||
+ | It should be quoted if the value has whitespaces. | ||
+ | [-i < | ||
+ | [-x] | ||
+ | </ | ||
+ | Parameters already known within the context are not required to be provided manually. | ||
+ | |||
+ | Multiple ' | ||
+ | |||
+ | Configuration can also be created ' | ||
+ | |||
+ | < | ||
+ | config_create -n < | ||
+ | ntp server < | ||
+ | |< | ||
+ | EOT | ||
+ | cmd_exec -n < | ||
+ | </ | ||
+ | |||
+ | The [[menu: | ||
+ | </ | ||
+ | |||
+ | |||
+ | ==== config_startup ==== | ||
+ | <WRAP indent> | ||
+ | Upload full config file and make startup. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node | ||
+ | -f cfg_file | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-c < | ||
+ | [-a < | ||
+ | [-d < | ||
+ | [-v < | ||
+ | [-u < | ||
+ | </ | ||
+ | |||
+ | The '' | ||
+ | to login to the device. When available, the '' | ||
+ | |||
+ | </ | ||
+ | ==== config_save ==== | ||
+ | <WRAP indent> | ||
+ | Save config on device and download to nccm. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-c < | ||
+ | [-a < | ||
+ | [-d < | ||
+ | [-v < | ||
+ | [-m < | ||
+ | [-u < | ||
+ | </ | ||
+ | |||
+ | The '' | ||
+ | to login to the device. When available, the '' | ||
+ | |||
+ | </ | ||
+ | |||
+ | ==== config_diff ==== | ||
+ | <WRAP indent> | ||
+ | Fetch running config and save it into the nccm | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-c < | ||
+ | [-a < | ||
+ | [-d < | ||
+ | [-v < | ||
+ | </ | ||
+ | |||
+ | This command will return an error if its backup cannot be retrieved or saved. | ||
+ | </ | ||
+ | |||
+ | ==== config_restore ==== | ||
+ | <WRAP indent> | ||
+ | Upload config from NCCM to the node as startup-configuration. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-c < | ||
+ | [-a < | ||
+ | [-d < | ||
+ | [-v < | ||
+ | [-u < | ||
+ | [-s < | ||
+ | may be one of: | ||
+ | ' | ||
+ | it selects the latest poll or pre-config backup available. | ||
+ | this is the default action if no -s option is provided | ||
+ | ' | ||
+ | ' | ||
+ | ' | ||
+ | using the NCCM ' | ||
+ | the mark will NOT be cleared after execution. | ||
+ | < | ||
+ | jobs can create a pre-config backup if a config change was detected | ||
+ | before a config change is made, but will also create a post-config backup. | ||
+ | the config selected will be the final (post-config) backup the job executed. | ||
+ | < | ||
+ | the date (yyy-mm-dd) must included in full, the time may be partial (hh:mm:ss). | ||
+ | a valid option value is therefore " | ||
+ | < | ||
+ | this option is only useful when direct database access is available. | ||
+ | </ | ||
+ | |||
+ | The '' | ||
+ | to login to the device. When available, the '' | ||
+ | |||
+ | </ | ||
+ | ===== Parsing ===== | ||
+ | |||
+ | /* Hiding config parsing from the wiki for now until we can find the time to properly support it again | ||
+ | ==== parse_run ==== | ||
+ | <WRAP indent> | ||
+ | Parse variables from config in a live machine, and return them as a list variable. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node hostname of the node | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-t < | ||
+ | [-c < | ||
+ | [-v < | ||
+ | [-l] if set, turns on logging for this command | ||
+ | </ | ||
+ | |||
+ | More information on [[guides: | ||
+ | |||
+ | Multiple parse_run commands can be used in a scenario. Even though, the configuration is only retrieved once to not burden the device. | ||
+ | </ | ||
+ | |||
+ | */ | ||
+ | /* Hiding config parsing from the wiki for now until we can find the time to properly support it again | ||
+ | ==== parse_nccm ==== | ||
+ | <WRAP indent> | ||
+ | Parse variables from config in an nccm record, and return them as a list variable. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node hostname of the node | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-t < | ||
+ | [-c < | ||
+ | [-v < | ||
+ | [-l] if set, turns on logging for this command | ||
+ | </ | ||
+ | |||
+ | If no nccm entry is found for this node, the < | ||
+ | |||
+ | More information on [[guides: | ||
+ | </ | ||
+ | */ | ||
+ | ==== parse_cmd ==== | ||
+ | <WRAP indent> | ||
+ | Run a show command on a node, and parse its output. Returns a hash variable with its result, trying to put the results in a regular list variable will fail. (< | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node hostname of the node | ||
+ | -t < | ||
+ | -r < | ||
+ | -c < | ||
+ | </ | ||
+ | |||
+ | |||
+ | Some vendors allow the option to specify pipes ' | ||
+ | |||
+ | An example is shown for Junos, which allows multiple pipes with multiple commands. In this case it is required to have them escaped (escaped with ' | ||
+ | |||
+ | > Before 7.1.0 the syntax was < | ||
+ | |||
+ | < | ||
+ | < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ===== Device ===== | ||
+ | |||
+ | ==== reboot_node ==== | ||
+ | <WRAP indent> | ||
+ | Restart the device. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-c < | ||
+ | [-a < | ||
+ | [-d < | ||
+ | [-v < | ||
+ | [-u < | ||
+ | </ | ||
+ | |||
+ | The '' | ||
+ | to login to the device. When available, the '' | ||
+ | |||
+ | </ | ||
+ | ==== clear_console ==== | ||
+ | <WRAP indent> | ||
+ | Reset the console line on the terminal server | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node hostname of the node | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-c < | ||
+ | [-a < | ||
+ | [-d < | ||
+ | [-v < | ||
+ | [-t < | ||
+ | [-l < | ||
+ | [-u < | ||
+ | </ | ||
+ | |||
+ | The '' | ||
+ | to login to the device. When available, the '' | ||
+ | |||
+ | </ | ||
+ | ===== File transfer ===== | ||
+ | |||
+ | ==== file_get ==== | ||
+ | <WRAP indent> | ||
+ | Transfer a file TO the named node. The transfer uses SFTP or TFTP depending on the available support | ||
+ | from the vendor and the connectivity available. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node | ||
+ | -s source | ||
+ | -t target | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-c < | ||
+ | [-a < | ||
+ | [-d < | ||
+ | [-v < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== file_put ==== | ||
+ | <WRAP indent> | ||
+ | Transfer a file TO the NetYCE system. The transfer uses SFTP or TFTP depending on the available support | ||
+ | from the vendor and the connectivity available. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node | ||
+ | -s source | ||
+ | -t target | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-c < | ||
+ | [-a < | ||
+ | [-d < | ||
+ | [-v < | ||
+ | [-u < | ||
+ | </ | ||
+ | |||
+ | The '' | ||
+ | to login to the device. When available, the '' | ||
+ | |||
+ | </ | ||
+ | ===== OS Upgrades ===== | ||
+ | |||
+ | |||
+ | Also see page on [[guides: | ||
+ | ==== os_files ==== | ||
+ | <WRAP indent> | ||
+ | retrieves a list of os files from the OS repository. Returns an error if no os files are found for these criteria. | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-n < | ||
+ | [-v < | ||
+ | [-s < | ||
+ | [-t < | ||
+ | [-f < | ||
+ | [-d < | ||
+ | [-y < | ||
+ | [-o < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | |||
+ | ==== os_image_select ==== | ||
+ | <WRAP indent> | ||
+ | retrieve os repo image data. The returned hash variable has the following attributes: Id, Error, Status, Vendor_type, | ||
+ | |||
+ | If the options result multiple os images, the image with status production will be returned. If there are more than that, the one with the latest timestamp will be returned. If you want to guarantee that no more than one os image will be selected, then provide a filter for vendor type and device type, since only one os image in production status can exist for each vendor type/device type combination, | ||
+ | |||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-n < | ||
+ | [-v < | ||
+ | [-s < | ||
+ | [-t < | ||
+ | [-f < | ||
+ | [-d < | ||
+ | [-y < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== os_file_select ==== | ||
+ | <WRAP indent> | ||
+ | retrieve the files of an os repo image as a list of hash variables. Each hash variable has the following attributes: Os_file_name, | ||
+ | |||
+ | If the options result multiple os files, the one with the newest timestamp will be returned. | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-i < | ||
+ | [-v < | ||
+ | [-n < | ||
+ | [-t < | ||
+ | </ | ||
+ | |||
+ | |||
+ | /* | ||
+ | ==== os_inventory ==== | ||
+ | <WRAP indent> | ||
+ | Perform an OS inventory and update the OS record. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node hostname of the node | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-c < | ||
+ | [-a < | ||
+ | [-d < | ||
+ | [-v < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== os_update ==== | ||
+ | <WRAP indent> | ||
+ | Upload the target OS files to node and install - but do not activate. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node hostname of the node | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-c < | ||
+ | [-a < | ||
+ | [-d < | ||
+ | [-v < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== os_activate ==== | ||
+ | <WRAP indent> | ||
+ | Activate the uploaded OS files and reboot node. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node hostname of the node | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-c < | ||
+ | [-a < | ||
+ | [-d < | ||
+ | [-v < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== os_strict ==== | ||
+ | <WRAP indent> | ||
+ | Upload the target OS files and activate, then reboot node. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node hostname of the node | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-c < | ||
+ | [-a < | ||
+ | [-d < | ||
+ | [-v < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== os_finish ==== | ||
+ | <WRAP indent> | ||
+ | Remove the old OS files from the node now upgrade complete. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node hostname of the node | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-c < | ||
+ | [-a < | ||
+ | [-d < | ||
+ | [-v < | ||
+ | </ | ||
+ | </ | ||
+ | */ | ||
+ | ===== DNS ===== | ||
+ | |||
+ | ==== dns_add_host ==== | ||
+ | <WRAP indent> | ||
+ | This command is available only with the Infoblox integration operational. | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-n < | ||
+ | | ||
+ | Do not use the fqdn here. | ||
+ | [-f < | ||
+ | | ||
+ | | ||
+ | [-a < | ||
+ | The ipv4-address must include a /prefix in the format ' | ||
+ | Use a /32 prefix to bypass the subnet-size check. | ||
+ | [-6 < | ||
+ | The ipv6-address must include a /prefix. Use prefix /128 to bypass subnet-size test. | ||
+ | [-t < | ||
+ | | ||
+ | [-v < | ||
+ | which is normally ' | ||
+ | [-d < | ||
+ | which is normally ' | ||
+ | [-r] flag to renew the existing ip-address of the DNS record. | ||
+ | | ||
+ | [-i < | ||
+ | </ | ||
+ | |||
+ | |||
+ | The **'' | ||
+ | |||
+ | < | ||
+ | dns_add_host -n < | ||
+ | </ | ||
+ | |||
+ | If the node is present in the CMDB table, the fqdn is retrieved from this table, but the ip-address must be included explicitly using the **'' | ||
+ | |||
+ | < | ||
+ | # requires subnet ' | ||
+ | | ||
+ | </ | ||
+ | |||
+ | It is mandatory to specify the ip-address with its subnet' | ||
+ | |||
+ | The only exception to this policy is where a /32 (single address) subnet is targeted. In that case, the address is tested to exist and is available (unused), but the subnets prefix needs not to be explicitly known. | ||
+ | |||
+ | < | ||
+ | # only requires the address to exist in IPAM, but subnet-size is ignored | ||
+ | | ||
+ | </ | ||
+ | |||
+ | The ' | ||
+ | |||
+ | < | ||
+ | # create the DNS host using the fqdn | ||
+ | | ||
+ | </ | ||
+ | |||
+ | If the fqdn is available in the YCE database, the management address of the node is located and used, but otherwise the address option is needed too. The '' | ||
+ | |||
+ | Policies demand that a domain name must pre-exist as a ' | ||
+ | |||
+ | By default a ' | ||
+ | |||
+ | The Infoblox environment requires the use of IPAM-views and DNS-views. The DNS-views are associated with the IPAM-views. Both views have defaults assigned in the ' | ||
+ | |||
+ | > When creating a host, the fqdn must be unique and not exist, the domain-name must exist in the DNS-view, and the subnet must exist in the IPAM-view. A ' | ||
+ | |||
+ | < | ||
+ | # remove a host from the IPAM-view ' | ||
+ | dns_clear_host -n < | ||
+ | |||
+ | # add a host to the IPAM-view ' | ||
+ | dns_add_host -n < | ||
+ | </ | ||
+ | |||
+ | > Note: currently the ipv6 support is limited to ' | ||
+ | |||
+ | For additional details, see the article on " | ||
+ | [[guides: | ||
+ | It is this API call that will be executed when using the dns_add_host command. | ||
+ | |||
+ | |||
+ | > These are the four new DNS commands and rely on the NetYCE - Infoblox integration. Please note that in these early-release DNS commands there is no support for the Infoblox Extended Attributes. | ||
+ | </ | ||
+ | |||
+ | ==== dns_clear_host ==== | ||
+ | <WRAP indent> | ||
+ | Remove DNS host. This command is available only with the Infoblox integration operational. | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-n < | ||
+ | | ||
+ | Do not use the fqdn here. | ||
+ | [-f < | ||
+ | | ||
+ | | ||
+ | [-t < | ||
+ | [-v < | ||
+ | which is normally ' | ||
+ | [-d < | ||
+ | which is normally ' | ||
+ | [-c] also remove cnames | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== dns_add_alias ==== | ||
+ | <WRAP indent> | ||
+ | Add DNS alias. \\ | ||
+ | This command is available only with the Infoblox integration operational. Edit the configuration file ''/ | ||
+ | |||
+ | Use the type (' | ||
+ | |||
+ | The use of the ' | ||
+ | |||
+ | Aliases should be included as a fqdn. However, should it look like a hostname, and a host domain is available, the alias will be extended with use the host domain to find it. Multiple aliases may be specified in one call. | ||
+ | |||
+ | == Options:== | ||
+ | < | ||
+ | -n < | ||
+ | -f < | ||
+ | -a < | ||
+ | [-t < | ||
+ | [-d < | ||
+ | [-i < | ||
+ | [-e < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== dns_clear_alias ==== | ||
+ | <WRAP indent> | ||
+ | Remove DNS alias. \\ | ||
+ | This command is available only with the Infoblox integration operational. Edit the configuration file ''/ | ||
+ | |||
+ | The behaviour when removing an alias from a ' | ||
+ | |||
+ | When type (' | ||
+ | |||
+ | If the type is ' | ||
+ | |||
+ | The use of the ' | ||
+ | |||
+ | Aliases should be included as a fqdn. However, should it look like a hostname, and a host domain is available, the alias will be extended with use the host domain to find it. Multiple aliases may be specified in one call. | ||
+ | |||
+ | == Options:== | ||
+ | < | ||
+ | -n < | ||
+ | -f < | ||
+ | -a < | ||
+ | [-t < | ||
+ | [-d < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== dns_clear_ip ==== | ||
+ | <WRAP indent> | ||
+ | This command is available only with the Infoblox integration operational. | ||
+ | |||
+ | The '' | ||
+ | |||
+ | Since an Infoblox Host construct can be associated with multiple ip-records, only the targeted ip-address is removed. Should such a Host constrict at that point have no ip-addresses left, then the entire Host is deleted. CNAMES pointing to Hosts constructs are preserved if ipv4-addresses remain. | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-a < | ||
+ | | ||
+ | [-n < | ||
+ | Do not use the fqdn here, the nodename is assumed to be a known NetYCE object. | ||
+ | [-f < | ||
+ | Only the first ip-address that the DNS returns is searched for. | ||
+ | </ | ||
+ | |||
+ | By default, the DNS view searched is ' | ||
+ | |||
+ | Examples: | ||
+ | < | ||
+ | dns_clear_ip -a 10.106.16.10 | ||
+ | dns_clear_ip -n ams-cr01 | ||
+ | dns_clear_ip -f server-1234.acme.com | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ===== External calls ===== | ||
+ | |||
+ | The external calls is a group of traps, signals and other exec calls. | ||
+ | |||
+ | ==== trap_nms ==== | ||
+ | <WRAP indent> | ||
+ | The '' | ||
+ | using the '' | ||
+ | |||
+ | The trap can include message details that require the '' | ||
+ | with the variable OID (object-id). Then by including a '' | ||
+ | |||
+ | By including more '' | ||
+ | the OID. The order of the -m's determine which OID is used. The default -v is ' | ||
+ | |||
+ | Example: | ||
+ | < | ||
+ | [scenario] | ||
+ | Description < | ||
+ | |||
+ | trap_nms -a 172.17.10.21 -a 172.17.10.28 -e 1006 -v 3.2.1 -m " | ||
+ | |||
+ | end | ||
+ | </ | ||
+ | |||
+ | The traps sent will in this case include a ' | ||
+ | < | ||
+ | { | ||
+ | ' | ||
+ | ' | ||
+ | ' | ||
+ | }, | ||
+ | </ | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -a < | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-e < | ||
+ | [-v < | ||
+ | [-m < | ||
+ | [-s < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== trap_node ==== | ||
+ | <WRAP indent> | ||
+ | The '' | ||
+ | |||
+ | The trap can include message details that require the '' | ||
+ | with the variable OID (object-id). Then by including a '' | ||
+ | |||
+ | By including more '' | ||
+ | the OID. The order of the -m's determine which OID is used. The default -v is ' | ||
+ | |||
+ | Example: | ||
+ | < | ||
+ | [scenario] | ||
+ | Description < | ||
+ | |||
+ | trap_node -n < | ||
+ | |||
+ | end | ||
+ | </ | ||
+ | |||
+ | The traps sent will in this case include a ' | ||
+ | < | ||
+ | { | ||
+ | ' | ||
+ | ' | ||
+ | ' | ||
+ | }, | ||
+ | </ | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n < | ||
+ | -a < | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-e < | ||
+ | [-v < | ||
+ | [-m < | ||
+ | [-s < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== signal_json ==== | ||
+ | <WRAP indent> | ||
+ | A RESTFUL JSON call can be added to the scenario using signal_json. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -t < | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | -p " | ||
+ | -n < | ||
+ | -m < | ||
+ | -a < | ||
+ | -s < | ||
+ | </ | ||
+ | |||
+ | This call is dependent on the configuration file ''/ | ||
+ | |||
+ | This configuration file must be setup to define the various '' | ||
+ | example the ticketing system, the monitoring tool or the cmdb. Each of these targets have attributes like: host, URL path and authentication details. | ||
+ | |||
+ | since these details may vary per NetYCE server, these targets have their attributes defined per NetYCE hostname, or when they are identical to all servers, use the ' | ||
+ | |||
+ | Example **signal_json.conf** file: | ||
+ | <code perl> | ||
+ | our $json_config | ||
+ | ' | ||
+ | ' | ||
+ | host => ' | ||
+ | url => '/ | ||
+ | # provide for websevice basic authentication | ||
+ | username => undef, | ||
+ | password => undef, | ||
+ | # provide for webservice bearer authentication | ||
+ | webtoken => ' | ||
+ | }, | ||
+ | ' | ||
+ | host => ' | ||
+ | url => '/ | ||
+ | # provide for websevice basic authentication | ||
+ | username => ' | ||
+ | password => ' | ||
+ | # provide for webservice bearer authentication | ||
+ | webtoken => undef, | ||
+ | }, | ||
+ | }, | ||
+ | ' | ||
+ | ' | ||
+ | host => ' | ||
+ | url => '/ | ||
+ | # provide for websevice basic authentication | ||
+ | username => undef, | ||
+ | password => undef, | ||
+ | # provide for webservice bearer authentication | ||
+ | webtoken => ' | ||
+ | }, | ||
+ | }, | ||
+ | }; | ||
+ | </ | ||
+ | |||
+ | The JSON dataset has a few pre-defined attributes (node, message, status, action) but can easily be extended using the '' | ||
+ | |||
+ | To allow nesting of attributes (called hashes), the parameter name in the -p option may be using dots ('' | ||
+ | |||
+ | A simple example may clarify their use: | ||
+ | < | ||
+ | signal_json -t ticketing | ||
+ | |||
+ | Results in: | ||
+ | using Json config for target ' | ||
+ | #--- JSON ----------------------------------------- | ||
+ | { | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | } | ||
+ | } | ||
+ | } | ||
+ | | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== st_exec ==== | ||
+ | <WRAP indent> | ||
+ | **ST_EXEC** allows the job to execute a **Service-type** from the scenario. Traditionally, | ||
+ | |||
+ | Any Service-type can be used with ' | ||
+ | |||
+ | If the Service-type uses API ' | ||
+ | |||
+ | < | ||
+ | [-b < | ||
+ | [-c < | ||
+ | [-s < | ||
+ | -t < | ||
+ | |||
+ | [-n < | ||
+ | Also sets ' | ||
+ | [-a < | ||
+ | Sets ' | ||
+ | [-6 < | ||
+ | Sets ' | ||
+ | |||
+ | [-p < | ||
+ | in Service-type. Use multiple ' | ||
+ | </ | ||
+ | |||
+ | The simplest call uses only the '-n node' and '-t service_task' | ||
+ | If any of -b, -c or -s is specified, it will overrule the values found for the node. | ||
+ | |||
+ | < | ||
+ | [scenario] | ||
+ | Description < | ||
+ | |||
+ | st_exec -n < | ||
+ | if < | ||
+ | log -m " | ||
+ | stop | ||
+ | endif | ||
+ | </ | ||
+ | |||
+ | == Service-types using ' | ||
+ | |||
+ | When including the '-n node', some of the service-type commands that match on ' | ||
+ | |||
+ | Note however, that ' | ||
+ | |||
+ | |||
+ | == API Service-types == | ||
+ | |||
+ | A Service-type may also be fully specified by including the -b, -c -s, and -t options. This form is commonly used to execute API based Service-types. Since they usually require custom variables, these variables must be included using -p options. Before execution of the Service-type, | ||
+ | |||
+ | The example below shows the -p options one separate lines following the st_exec call. This is a supported format and is used to improve readability. Options are automatically joined if the first part of the line is a recognizable option ('-a ', '-6 '). Comments cannot be included. | ||
+ | |||
+ | < | ||
+ | [scenario] | ||
+ | Description Add_dmz_frw to LB | ||
+ | |||
+ | st_exec -b ' | ||
+ | -p " | ||
+ | -p " | ||
+ | -p " | ||
+ | -p " | ||
+ | -p " | ||
+ | -p " | ||
+ | |||
+ | if < | ||
+ | log -m " | ||
+ | stop | ||
+ | endif | ||
+ | </ | ||
+ | |||
+ | It is allowed and sometimes useful to include a '-n node' option even when all four Service-task specifying options are explicitly set. In this case the node will provide the ' | ||
+ | </ | ||
+ | |||
+ | ==== ansible_exec ==== | ||
+ | <WRAP indent> | ||
+ | This calls upon the local ansible installation. It allows the launching of either an existing Playbook, or the launching of a NetYCE Scenariobook by Ansible. Where the Playbook option refers to a pre-existing playbook-file that can be used as-is, the Scenariobook refers to the NetYCE template-based generated Playbook that can be parameterised using the NetYCE modelling and database. | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-n < | ||
+ | [-p < | ||
+ | [-s < | ||
+ | [-o " | ||
+ | </ | ||
+ | |||
+ | Example, static yaml file: | ||
+ | < | ||
+ | ansible_exec -n < | ||
+ | </ | ||
+ | |||
+ | Example, dynamic yaml file, which is generated by NetYCE: | ||
+ | < | ||
+ | config_create -n < | ||
+ | ansible_exec -n < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | |||
+ | ==== script_exec ==== | ||
+ | <WRAP indent> | ||
+ | This calls upon a local script. Additional arguments can be provided to the script and if needed the interpreter can be overridden. | ||
+ | |||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | -s script | ||
+ | [-i < | ||
+ | [-o < | ||
+ | [-t < | ||
+ | </ | ||
+ | |||
+ | Example, of the python script execution: | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | </ | ||
+ | |||
+ | </ | ||
+ | |||
+ | ===== List Operations ===== | ||
+ | |||
+ | ==== calc ==== | ||
+ | <WRAP indent> | ||
+ | Executes the given calculation | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -c < | ||
+ | </ | ||
+ | |||
+ | |||
+ | ==Example: | ||
+ | |||
+ | < | ||
+ | < | ||
+ | < | ||
+ | |||
+ | # Output in the job log: | ||
+ | Assignment: (valA -- result: (5)) | ||
+ | Assignment: (newVal -- result: (10)) | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== relation ==== | ||
+ | <WRAP indent> | ||
+ | Extract a variable (list) from a named relation, and returns this to a list variable. More information on [[menu: | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n < | ||
+ | -r < | ||
+ | -v < | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-p < | ||
+ | [-f < | ||
+ | the relation row must match all filters to be included in the result | ||
+ | [-l < | ||
+ | </ | ||
+ | |||
+ | ==Example: | ||
+ | Using variable: < | ||
+ | < | ||
+ | < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== replace ==== | ||
+ | <WRAP indent> | ||
+ | Replace searches for a specific string-value and replaces it with another string-value. The replace value can be empty. The match string is non case-sensitive. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -l < | ||
+ | -c < | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-r < | ||
+ | [-a] Provide this to replace every match | ||
+ | </ | ||
+ | |||
+ | |||
+ | ==Example: | ||
+ | |||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | |||
+ | # Output in the job log: | ||
+ | Assignment: (valA -- result: (abc)) | ||
+ | Assignment: (valB -- result: (def)) | ||
+ | Assignment: (newVal -- result: (adef)) | ||
+ | </ | ||
+ | </ | ||
+ | ==== sort ==== | ||
+ | <WRAP indent> | ||
+ | Takes one or more lists and sorts its elements ascending. Returns a list variable. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -l < | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-r] reverse sort | ||
+ | [-n] sort the list numerically | ||
+ | [-u] return unique elements | ||
+ | </ | ||
+ | |||
+ | ==Example: | ||
+ | |||
+ | < | ||
+ | |||
+ | < | ||
+ | < | ||
+ | < | ||
+ | |||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | | ||
+ | # sort both lists numerically in reverse keeping only unique items | ||
+ | < | ||
+ | | ||
+ | <msg> = concat -s ", " -l < | ||
+ | log -m " | ||
+ | | ||
+ | # prints the log message: | ||
+ | # 2019-03-14 11:43:35 items: 5, 4, 3, 2, 1 | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== concat ==== | ||
+ | <WRAP indent> | ||
+ | Takes one or more lists and concatenates its values in a single string. Each value is separated by the separator string specified with the ' | ||
+ | Returns a list variable with a single string value. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -s < | ||
+ | -l < | ||
+ | </ | ||
+ | |||
+ | ==Example: | ||
+ | |||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | |||
+ | < | ||
+ | < | ||
+ | < | ||
+ | | ||
+ | <msg> = concat -s ", " -l < | ||
+ | log -m " | ||
+ | | ||
+ | # prints the log message: | ||
+ | # 2019-03-14 12:17:52 items: 1, 2, 3, one, two, three | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== like ==== | ||
+ | <WRAP indent> | ||
+ | > The ' | ||
+ | </ | ||
+ | |||
+ | ==== grep ==== | ||
+ | <WRAP indent> | ||
+ | Takes one or more lists and a condition, and runs that condition against a wildcard or a regex over the list. Returns all matching elements as a list variable. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -l < | ||
+ | -c < | ||
+ | </ | ||
+ | |||
+ | ==Other Options:== | ||
+ | < | ||
+ | [-u] | ||
+ | </ | ||
+ | |||
+ | |||
+ | **NOTE:** the difference for the regex. It requires the two '/' | ||
+ | |||
+ | **NOTE:** Variables that were defined as [parameters] will be substituted with the ' | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | </ | ||
+ | |||
+ | |||
+ | ==Example: | ||
+ | |||
+ | < | ||
+ | [parameters] | ||
+ | |||
+ | [scenario] | ||
+ | |||
+ | Description < | ||
+ | |||
+ | # fill a list with relation entries | ||
+ | # (must use += because each relation entry will copy this line in the final task before the scenario starts) | ||
+ | < | ||
+ | |||
+ | # copy this list to another list | ||
+ | < | ||
+ | |||
+ | # append some entries to this list | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | |||
+ | # filter the entries ending in " | ||
+ | < | ||
+ | # or using wildcard: | ||
+ | # < | ||
+ | |||
+ | # and log them one by one | ||
+ | foreach < | ||
+ | log -m nie_name: < | ||
+ | endeach | ||
+ | |||
+ | end | ||
+ | |||
+ | </ | ||
+ | The last lines of the log shows only ‘eenie’, | ||
+ | </ | ||
+ | |||
+ | ==== match ==== | ||
+ | <WRAP indent> | ||
+ | Takes one or more lists and a condition, and runs that condition against a wildcard or a regex over the list. Returns a list with the matching substring(s) of each element. | ||
+ | |||
+ | The behavior of ' | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -l < | ||
+ | -c < | ||
+ | </ | ||
+ | |||
+ | ==Other Options:== | ||
+ | < | ||
+ | [-u] | ||
+ | </ | ||
+ | |||
+ | As with ' | ||
+ | The wildcard condition support the ' | ||
+ | The regex condition uses a format like '' | ||
+ | |||
+ | ==Example: | ||
+ | This example illustrates the difference between the ' | ||
+ | |||
+ | < | ||
+ | [scenario] | ||
+ | Description test match function | ||
+ | |||
+ | < | ||
+ | < | ||
+ | |||
+ | < | ||
+ | < | ||
+ | |||
+ | < | ||
+ | |||
+ | foreach < | ||
+ | log -m "grep entry: < | ||
+ | endeach | ||
+ | |||
+ | < | ||
+ | |||
+ | foreach < | ||
+ | log -m "match entry: < | ||
+ | endeach | ||
+ | |||
+ | end | ||
+ | </ | ||
+ | |||
+ | Results: | ||
+ | < | ||
+ | The grep entries: | ||
+ | "the first element" | ||
+ | |||
+ | The matched entries | ||
+ | "The first" | ||
+ | </ | ||
+ | |||
+ | |||
+ | When using the regex condition a distinct feature can be used: multiple substring matches. Regular expressions have the capability to ' | ||
+ | |||
+ | When using these ' | ||
+ | |||
+ | ==Example: | ||
+ | < | ||
+ | The same dataset as above using the regex condition below: | ||
+ | < | ||
+ | |||
+ | Results in the matched entries: | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | |||
+ | And, when adding the optional ' | ||
+ | < | ||
+ | |||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | </ | ||
+ | |||
+ | |||
+ | **NOTE:** Variables that were defined as [parameters] will be substituted with the ' | ||
+ | < | ||
+ | # this will only work when <var> is defined in the [parameter] section or | ||
+ | # is a parameter that is defined in de < | ||
+ | < | ||
+ | |||
+ | # this will work with run-time variable <var> that was defined in the scenario section | ||
+ | <var> = " | ||
+ | < | ||
+ | </ | ||
+ | |||
+ | **NOTE:** Regular expressions support the use of ' | ||
+ | < | ||
+ | Using spaces: | ||
+ | < | ||
+ | Using \s: | ||
+ | < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | |||
+ | ==== split ==== | ||
+ | <WRAP indent> | ||
+ | Takes list(s) and a regex or wildcard separator to split the element strings into more elements; returns a list with the separated substring of each element. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -l < | ||
+ | -c < | ||
+ | </ | ||
+ | |||
+ | ==Other Options:== | ||
+ | < | ||
+ | [-n < | ||
+ | [-u] return unique elements as a sorted list | ||
+ | </ | ||
+ | |||
+ | ==Example: | ||
+ | |||
+ | < | ||
+ | < | ||
+ | < | ||
+ | |||
+ | # one way using regex | ||
+ | < | ||
+ | |||
+ | # another using wildcards | ||
+ | < | ||
+ | |||
+ | # same, but with a result limit of 1. | ||
+ | < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ===== Misc ===== | ||
+ | |||
+ | ==== pingable ==== | ||
+ | <WRAP indent> | ||
+ | Test if node is pingable | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n < | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-a < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== reachable ==== | ||
+ | <WRAP indent> | ||
+ | test if node is reachable using ssh or telnet | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n < | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-a < | ||
+ | [-p < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== hangup ==== | ||
+ | <WRAP indent> | ||
+ | Disconnect node connection(s). | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n < | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-c < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== wait ==== | ||
+ | <WRAP indent> | ||
+ | Delay all actions for < | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -t < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== update_rev ==== | ||
+ | <WRAP indent> | ||
+ | Update database with active template revision. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ===== Database ===== | ||
+ | |||
+ | ==== shortest_path ==== | ||
+ | <WRAP indent> | ||
+ | Locate the devices that make up the shortest path between end points. Returns a variable list of all nodes making up the path including the start and end points. | ||
+ | |||
+ | The shortest-path uses the topology (links between ports) of the nodes in the YCE database. Tracing a path is therefore limited to YCE nodes and the accuracy of the topology. | ||
+ | |||
+ | For finding the shortest path the Dijkstra greedy algorithm is used. The model uses any kind of topology between ports of different nodes as a valid path and takes into account the modelling of the hierarchy in that uplink directions have a cost of ' | ||
+ | |||
+ | The algorithm will find exactly one path that has the lowest cost even is there are multiple paths due to redundancy. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -s < | ||
+ | -e < | ||
+ | </ | ||
+ | |||
+ | ==Optional: | ||
+ | < | ||
+ | -a < | ||
+ | -a [< | ||
+ | </ | ||
+ | |||
+ | The ' | ||
+ | |||
+ | < | ||
+ | < | ||
+ | |||
+ | < | ||
+ | </ | ||
+ | |||
+ | The example shows the use of the special notation "-a **<color red> | ||
+ | |||
+ | When using the ' | ||
+ | |||
+ | Note that the increase in cost is unidirectional: | ||
+ | |||
+ | In the example below the primary and secondary paths must avoid the link between " | ||
+ | < | ||
+ | < | ||
+ | |||
+ | < | ||
+ | </ | ||
+ | |||
+ | |||
+ | </ | ||
+ | |||
+ | |||
+ | ==== db_query ==== | ||
+ | <WRAP indent> | ||
+ | Retrieve a variable(-list) from the database. Returns a variable list. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -t < | ||
+ | -f < | ||
+ | -w '< | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== db_update ==== | ||
+ | <WRAP indent> | ||
+ | Set a value in the database using a sql statement. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -t < | ||
+ | -p '< | ||
+ | -w '< | ||
+ | </ | ||
+ | |||
+ | > Make sure you put the entire part after -p and -w in quotes. | ||
+ | |||
+ | In case you wish to update Custom Attributes, the where would contain pipes (' | ||
+ | |||
+ | < | ||
+ | db_update -t Par_vals -p " | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ===== Logging ===== | ||
+ | For the logging, as well as the scenario in general and templates, it is possible to show/use the job_id using ''< | ||
+ | |||
+ | ==== log ==== | ||
+ | <WRAP indent> | ||
+ | Insert timestamped message in the log of the job. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -m "< | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== log_action ==== | ||
+ | <WRAP indent> | ||
+ | Add entry to action log. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n < | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-a < | ||
+ | [-m "< | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== send_email ==== | ||
+ | <WRAP indent> | ||
+ | Send email notification to the operator/ | ||
+ | |||
+ | This behaviour can be adjusted using the [[guides: | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-s < | ||
+ | [-m < | ||
+ | [-t <mail to> | ||
+ | [-f <mail from> | ||
+ | [-a < | ||
+ | [-r < | ||
+ | </ | ||
+ | |||
+ | Multiple '-t < | ||
+ | |||
+ | ==Example== | ||
+ | See the entry below on '' | ||
+ | </ | ||
+ | |||
+ | ==== csv_file ==== | ||
+ | <WRAP indent> | ||
+ | Create csv file of list variable(s) | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -r < | ||
+ | -v < | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-s < | ||
+ | [-d] | ||
+ | </ | ||
+ | |||
+ | The generated csv report will be created in the job-directory named after the job-id (/ | ||
+ | and will receive the '' | ||
+ | |||
+ | Tip: The report file can be emailed directly from the job scenario to the operator by using the '' | ||
+ | |||
+ | ==Example== | ||
+ | The example below uses data from the relation " | ||
+ | |||
+ | The report name can include variables as well as is demonstrated. The -d option appends todays date to the report name. | ||
+ | |||
+ | The same report is then created as a local csv-file using '' | ||
+ | |||
+ | Finally the report is sent to the local ' | ||
+ | |||
+ | < | ||
+ | [scenario] | ||
+ | Description < | ||
+ | |||
+ | < | ||
+ | < | ||
+ | < | ||
+ | |||
+ | csv_report -r "< | ||
+ | |||
+ | csv_file -r "< | ||
+ | |||
+ | send_email -a "< | ||
+ | |||
+ | end | ||
+ | </ | ||
+ | |||
+ | When executing the following logs were produced: | ||
+ | < | ||
+ | 28-Function (csv_report -r " | ||
+ | saved report as ' | ||
+ | 29-Function (csv_file -r " | ||
+ | | ||
+ | 30-Function (send_email -a " | ||
+ | | ||
+ | | ||
+ | | ||
+ | | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== csv_report ==== | ||
+ | <WRAP indent> | ||
+ | Create custom csv report of list variable(s) | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -r < | ||
+ | -v < | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-s < | ||
+ | [-d] add the creation date to the report name (' | ||
+ | </ | ||
+ | |||
+ | The generated csv report will be added to the '' | ||
+ | |||
+ | ==Example== | ||
+ | See the section above on '' | ||
+ | </ | ||
+ | |||
+ | ===== Error handling ===== | ||
+ | <WRAP indent> | ||
+ | All scenario commands can set the '< | ||
+ | |||
+ | When the scenario reaches the '' | ||
+ | |||
+ | < | ||
+ | reachable -n < | ||
+ | if < | ||
+ | log -m "node < | ||
+ | stop | ||
+ | endif | ||
+ | |||
+ | cmd_exec -n < | ||
+ | if < | ||
+ | log -m " | ||
+ | stop | ||
+ | endif | ||
+ | |||
+ | end | ||
+ | </ | ||
+ | |||
+ | Since having to include explicit error checking for every command in a lengthy scenario can be quite tedious, the default error behaviour can be modified to automatically ABORT the scenario at the failing command. This is accomplished with the '' | ||
+ | |||
+ | < | ||
+ | stop on-error | ||
+ | |||
+ | reachable -n < | ||
+ | |||
+ | cmd_exec -n < | ||
+ | |||
+ | end | ||
+ | </ | ||
+ | |||
+ | Note that the automatic abort will ignore any error handling that is present in the scenario since the scenario will stop before it reaches the next line with the 'if error' test. | ||
+ | |||
+ | At the point where the normal error handling by the scenario must be resumed the '' | ||
+ | |||
+ | < | ||
+ | stop on-error | ||
+ | |||
+ | reachable -n < | ||
+ | |||
+ | stop default | ||
+ | |||
+ | cmd_exec -n < | ||
+ | if < | ||
+ | log -m " | ||
+ | stop | ||
+ | endif | ||
+ | |||
+ | end | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ===== Here documents ===== | ||
+ | <WRAP indent> | ||
+ | At times it is cumbersome having to create and define lots of trivial or very small templates. In those cases the scenario command can support HERE DOCUMENTS. This name is a reference to unix systems where multi-line input can be given for a command. In our case that input represents the content of a template. | ||
+ | |||
+ | A here document uses the **< <** and a terminator string that is defined at the end of the command line. The next line all the way up to the terminator string on a line by itself then forms the here document that will be used as the template text. | ||
+ | |||
+ | An example using the scenario command **'' | ||
+ | The string '' | ||
+ | |||
+ | < | ||
+ | description < | ||
+ | |||
+ | cmd_exec -n < | ||
+ | ! | ||
+ | a sample command for hostname < | ||
+ | another command for the node in < | ||
+ | the full template syntax can be used in a here-document | ||
+ | | condition | {template} | ||
+ | ! | ||
+ | EOT | ||
+ | </ | ||
+ | |||
+ | This example will create the command file ' | ||
+ | < | ||
+ | ! | ||
+ | a sample command for hostname AMS-DC99001 of customer ACME | ||
+ | another command for the node in AMS-DC99 | ||
+ | the full template syntax can be used in a here-document | ||
+ | ! | ||
+ | </ | ||
+ | |||
+ | Please note that in the example above the '' | ||
+ | |||
+ | |||
+ | The second example shows how a more complex command file can be created using a few '' | ||
+ | |||
+ | Since the default behaviour of the '' | ||
+ | |||
+ | < | ||
+ | description < | ||
+ | |||
+ | config_create -n < | ||
+ | # | ||
+ | SOME COMMANDS FOR < | ||
+ | # | ||
+ | EOT | ||
+ | |||
+ | config_create -n < | ||
+ | |||
+ | config_create -n < | ||
+ | # | ||
+ | SOME MORE COMMANDS FOR < | ||
+ | {create_atm} | ||
+ | # | ||
+ | EOT | ||
+ | |||
+ | cmd_exec -n < | ||
+ | |||
+ | </ | ||
+ | |||
+ | In this case the finally resulting config file ' | ||
+ | </ | ||
+ | |||
+ | <WRAP widths 60% box warning> | ||
+ | ===== Deprecated ===== | ||
+ | </ | ||
+ | |||
+ | These commands are still supported for backwards compatibility, | ||
+ | When upgrading to version 7.0.2, a conversion was executed whereby the old commands and options were replaced with the new. Creating scenarios using the old commands is still supported for the time being. | ||
+ | |||
+ | ==== import_cfg ==== | ||
+ | <WRAP indent> | ||
+ | Execute command line-by line on cli of a NetYCE managed node. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node hostname of the node | ||
+ | -f cmd_file | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-a < | ||
+ | [-d < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== basic_import ==== | ||
+ | <WRAP indent> | ||
+ | Execute command line by line on cli of a node in the cmdb table - does not support templates. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node hostname of the node | ||
+ | -f cmd_file | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-a < | ||
+ | [-d < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== gen_startup ==== | ||
+ | <WRAP indent> | ||
+ | Generate commands from template. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node hostname of the node | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-t < | ||
+ | [-p < | ||
+ | [-i < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== write_startup ==== | ||
+ | <WRAP indent> | ||
+ | Upload full config file and make startup. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node hostname of the node | ||
+ | -f cfg_file | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-a < | ||
+ | [-d < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== save_config ==== | ||
+ | <WRAP indent> | ||
+ | Save config on device and download to nccm. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node hostname of the node | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-a < | ||
+ | [-d < | ||
+ | [-m < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== diff_config ==== | ||
+ | <WRAP indent> | ||
+ | Fetch running config and compare to latest nccm config. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node hostname of the node | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-a < | ||
+ | [-d < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== reload ==== | ||
+ | <WRAP indent> | ||
+ | Restart the device. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node hostname of the node | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-a < | ||
+ | [-d < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== restore ==== | ||
+ | <WRAP indent> | ||
+ | Upload config from nccm and reload. | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n node hostname of the node | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-a < | ||
+ | [-d < | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== LogAction ==== | ||
+ | <WRAP indent> | ||
+ | Add entry to action log. | ||
+ | |||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -n < | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-a < | ||
+ | [-m <message text> | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== trap ==== | ||
+ | <WRAP indent> | ||
+ | Send snmp trap from yce server to nms (" | ||
+ | |||
+ | ==Mandatory options:== | ||
+ | < | ||
+ | -e < | ||
+ | -v < | ||
+ | -s < | ||
+ | </ | ||
+ | |||
+ | ==Optional options:== | ||
+ | < | ||
+ | [-m <message text>] the trap message | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | |||