neops.core.provider.device_configure_from_jinja
DeviceJinjaConfigureProvider
Provider to configure a device based on a jinja template
Device Configure Parameters
Template
A Jinja Template which is processed before apply the result of this template.
The following parameters are passed to the template processing:
input
: all inputs from the task run argumentsdevice
: the current device object serialized as dictionaryneops
: the neops object brings methods to access to other elements over the neops.io searchneops.search_devices(query)
: returns a list of devices found by the search queryneops.search_interfaces(query)
: returns a list of interfaces found by the search queryneops.search_device_groups(query)
: returns a list of groups found by the search queryneops.search_client(query)
: returns a list of clients found by the search queryneops.get_common_facts(key)
: returns the common/global fact of the given key
For more information on how to build a Jinja2 template, have a look at Appendix under Jinja2
Example of device and neops usage (only to show usage, config change doesn't make sense):
hostname {{ device.hostname }}
{% for interface in device.interfaces %}
interface {{ interface.name }}
description NEW-DESCRIPTION
{% endfor %}
{% for interface in neops.interface_search("devices.id:" ~ device.id ~ " AND interfaces.description: *CLIENT*") %}
{### process every interface with CLIENT in description #}
interface {{ interface.name }}
description NEW-DESCRIPTION
{% endfor %}
Global Base Configure Parameters
Apply Method
The apply method descripbes how the configuration is written to the device.
cli
: the configuration is applied directly in the configration modescp
: the configuration is copied (with scp) as a file to the device and applied with an merge operationscp-startup
: the configuration is copied (with scp) as a file to the device and written to the start up configuration
Slow Devices
With the slow_device
parameter you can specify a delay factor to wait a longer time on responses from
slow devices
JSON Schema
Device Configuration
Properties
-
apply
(string): Method how to apply the configuration, over cli or copy with scp and merge. Must be one of:['scp', 'cli', 'scp-startup']
. -
slow_device
(integer): Add a factor for longer wait times for heavy loaded devices. Default:0
. -
template
(string)
Methods
run_on_device
is called by the run cycle.
\
It generates the configuration with the given input parameters