ansible.utils.validate filter – Validate data with provided criteria
Note
This filter plugin is part of the ansible.utils collection (version 5.1.2).
You might already have this collection installed if you are using the ansible
package.
It is not included in ansible-core
.
To check whether it is installed, run ansible-galaxy collection list
.
To install it, use: ansible-galaxy collection install ansible.utils
.
To use it in a playbook, specify: ansible.utils.validate
.
New in ansible.utils 1.0.0
Synopsis
Validate data with provided criteria based on the validation engine.
Keyword parameters
This describes keyword parameters of the filter. These are the values key1=value1
, key2=value2
and so on in the following
example: input | ansible.utils.validate(key1=value1, key2=value2, ...)
Parameter |
Comments |
---|---|
The criteria used for validation of value that represents data options. This option represents the first argument passed in the filter plugin. For example For the type of criteria that represents this value refer to the documentation of individual validator plugins. |
|
Data that will be validated against criteria. This option represents the value that is passed to the filter plugin in pipe format. For example For the type of data that represents this value refer to the documentation of individual validator plugins. |
|
The name of the validator plugin to use. This option can be passed in lookup plugin as a key, value pair. For example The value should be in fully qualified collection name format that is Default: |
Notes
Note
For the type of options data and criteria refer to the individual validate plugin documentation that is represented in the value of engine option.
For additional plugin configuration options refer to the individual validate plugin documentation that is represented by the value of engine option.
The plugin configuration option can be either passed as
key=value
pairs within filter plugin or environment variables.The precedence of the validate plugin configurable option is the variable passed within filter plugin as
key=value
pairs followed by the environment variables.
Examples
- name: set facts for data and criteria
ansible.builtin.set_fact:
data: "{{ lookup('ansible.builtin.file', './validate/data/show_interfaces_iosxr.json')}}"
criteria: "{{ lookup('ansible.builtin.file', './validate/criteria/jsonschema/show_interfaces_iosxr.json')}}"
- name: validate data in json format using jsonschema by passing plugin configuration variable as key/value pairs
ansible.builtin.set_fact:
data_validity: "{{ data|ansible.utils.validate(criteria, engine='ansible.utils.jsonschema', draft='draft7') }}"
Return Value
Key |
Description |
---|---|
If data is valid returns empty list If data is invalid returns list of errors in data Returned: success |