receptor-catalog
Receptor Catalog Worker Plugin
This plugin allows the receptor node to send HTTP GET and POST requests to Ansible Tower.
The config file on the receptor for this plugin should have the following values defined in the /etc/receptor/rh_ansible_tower/receptor.conf
[plugin_receptor_catalog]
token=your_ansible_application_token
url=https://your_ansible_tower/
verify_ssl=False
The payload supported by the plugin contains
- method: GET|POST
- href_slug: the href to the resource or collection e.g api/v2/job_templates/
- accept_encoding {Optional}: gzip
- fetch_all_pages {Optional}: True|False
- params: Extra query or post parameters as a hash/dictionary
- apply_filter {Optional}: A JMESPath search string to limit the amount of data that is returned. The filter can be specified as a hash/dictionary or as a string. The hash is used when filtering responses from a list call when the response contains an array of objects. The string filter is used when dealing with a single object.
The response payload coming back will have the following keys
- status: The HTTP Status code
- body: The response body received from the Ansible Tower if Accept-Encoding was gzip, the body will be compressed and the caller would have to uncompress the data. The first 2 bytes of the payload can be checked to see if the data has been gzip compressed. A valid gzip'ed buffer would start with 0x1f 0x8B
To install the plugin in your local dev environment
python setup.py install
To run the tests
python setup.py test
Filtering Examples
Filters are based on JMESPath which allows us to search and filter out sections of JSON. https://jmespath.org
When fetching an array of objects you have to specific the filter as a dictionary with the key name containing the name of the attribute. e.g apply_filter ={results='results[].{catalog_id:id, url:url,created:created,name:name, modified:modified, playbook:playbook}'}
Here we are filtering the results key so we have to specify the filter as a dictionary. The plugin will swap out the contents of the key with the filtered results. The filtered response will contain
{
"count": 28,
"next": "/api/v2/job_templates/?page=2",
"previous": null,
"results": [
{
"catalog_id": 5,
"url": "/api/v2/job_templates/5/",
"created": "2019-05-29T15:17:05.466994Z",
"name": "Demo Job Template",
"modified": "2019-05-29T15:17:05.467018Z",
"playbook": "hello_world.yml"
},
{
"catalog_id": 58,
"url": "/api/v2/job_templates/58/",
"created": "2020-03-06T21:56:55.134663Z",
"name": "Ephemeral Template",
"modified": "2020-03-06T22:15:15.655800Z",
"playbook": "hello_world.yml"
},
When a single object needs to be filtered we specify the filter as a string
apply_filter = '{id:id, url:url, name:name, description:descripti on, playbook:playbook}'
The response contains
{
"id": 6565,
"url": "/api/v2/jobs/6565/",
"name": "Hello World",
"description": "Test Description",
"playbook": "hello_world.yml"
}