The resource module builder is an Ansible Collection that helps developers scaffold and maintain an Ansible network resource modules.
Capabilities
- Use a pre-defined docstring (in YAML) to scaffold a resource module directory layout and initial class files in an Ansible Collection.
- Subsequent uses of the Resource Module Builder (RMB) will only update the module argspec and doc string.
- Maintain the module
DOCUMENTATION
as the source of truth for the module argspec and use RMB to update the source files as needed. - Generates working sample modules for both
<network_os>_<resource>
and<network_os>_facts
pip install -r requirements.txt
ansible-galaxy collection install git+https://github.com/ansible-network/cli_rm_builder.git
run.yml
---
- hosts: localhost
gather_facts: yes
roles:
- ansible_network.cli_rm_builder.run
ansible-playbook -e rm_dest=<destination for modules and module utils> \
-e collection_org=<collection_org> \
-e collection_name=<collection_name> \
-e docstring=</path/to/docstring> \
-e resource=<resource>
run.yml
ansible-playbook -e rm_dest=<destination for modules and module utils> \
-e collection_org=<collection_org> \
-e collection_name=<collection_name> \
-e resource=<resource> \
run.yml
rm_dest
: The directory in which the files and directories for the resource module and facts modules should be placedcollection_org
: The organization of the collectioncollection_name
: The name of the collectionresource
: The network resource targeted by the moduledocstring
: The path to the file that contains docstring (in YAML)network_os
: The value of network_os (defaults tocollection_name
)
See the docstrings
directory for an example.
Collection directory layout
network_os
: myosresource
: interfaces
├── LICENSE
├── README.md
├── docs
├── meta
├── plugins
│ ├── action
│ │ └── __init__.py
│ ├── filter
│ │ └── __init__.py
│ ├── inventory
│ │ └── __init__.py
│ ├── module_utils
│ │ ├── __init__.py
│ │ └── network
│ │ ├── __init__.py
│ │ └── myos
│ │ ├── __init__.py
│ │ ├── argspec
│ │ │ ├── __init__.py
│ │ │ ├── facts
│ │ │ │ ├── __init__.py
│ │ │ │ └── facts.py
│ │ │ └── interfaces
│ │ │ ├── __init__.py
│ │ │ └── interfaces.py
│ │ ├── config
│ │ │ ├── __init__.py
│ │ │ └── interfaces
│ │ │ ├── __init__.py
│ │ │ └── interfaces.py
│ │ ├── facts
│ │ │ ├── __init__.py
│ │ │ ├── facts.py
│ │ │ └── interfaces
│ │ │ ├── __init__.py
│ │ │ └── interfaces.py
│ │ ├── rm_templates
│ │ │ ├── __init__.py
│ │ │ └── interfaces.py
│ │ └── utils
│ │ ├── __init__.py
│ │ └── utils.py
│ └── modules
│ ├── __init__.py
│ ├── myos_facts.py
│ └── myos_interfaces.py
└── tests
Please refer to using collections in a playbook guide for detailed information.
Module
plugins/modules/<ansible_network_os>_<resource>.py
- Import
module_utils
resource package and callsexecute_module
API
def main():
result = <resource_package>(module).execute_module()
Module Argspec
module_utils/network/<ansible_network_os>/argspec/<resource>/
- Argspec for the resource.
- The recommended way of updating the argspec is by updating the module docstring first and then running the Resource Module Builder to update the argspec. This ensures that both the artifacts are always in sync.
Facts
module_utils/network/<ansible_network_os>/facts/<resource>/
- Populate facts for the resource.
- Entry in
module_utils/network/<ansible_network_os>/facts/facts.py
forget_facts
API to keep<ansible_network_os>_facts
module and facts gathered for the resource module in sync for every subset.
Parser Templates
module_utils/network/<ansible_network_os>/rm_templates/<resource>
-
Define a list of parser templates that the
NetworkTemplate
parent class inansible.netcommon
uses to converts native configuration to Ansible structured data and vice versa. -
Example parser template:
{
"name": "auto_cost",
"getval": re.compile(
r"""
\s+auto-cost\sreference-bandwidth\s
(?P<acrb>\d+)\s(?P<unit>\S+)$""",
re.VERBOSE,
),
"setval": (
"auto-cost reference-bandwidth"
" {{ auto_cost.reference_bandwidth }}"
" {{ auto_cost.unit }}"
),
"result": {
"vrfs": {
'{{ "vrf_" + vrf|d() }}': {
"auto_cost": {
"reference_bandwidth": "{{ acrb }}",
"unit": "{{ unit }}",
}
}
}
},
}
Resource Config Package in module_utils
module_utils/network/<ansible_network_os>/<config>/<resource>/
-
Implement
execute_module
API that uses the existing device configuration (have
), the task input (want
), and thecompare
functionality provided by the parent classResourceModule
inansible.netcommon
to render and push configuration commands to the target device. -
The task run result contains the following keys:
before
: state of the<resource>
in target device before module execution (as structured data)after
: state of the<resource>
in target device after module execution (as structured data)commands
: list of commands sent to the target devicechanged
:True
orFalse
depending on whether the task run was idempotentgathered
: state of the<resource>
in target device (as structured data) [only whenstate
:gathered
]parsed
: configuration passed through therunning_config
option as structured data [only whenstate
:parsed
]rendered
: provided configuration in the task as device native config lines [only whenstate
:rendered
]
Note: Please refer to Network resource module states for more information.
Utils
module_utils/<ansible_network_os>/utils
.
- Utilities for the
<ansible_network_os>
platform.
The tests rely on a role generated by the resource module builder. After changes to the resource module builder, the role should be regenerated and the tests modified and run as needed. To generate the role after changes:
rm -rf rmb_tests/roles/my_role
ansible-playbook -e docstring=docs/examples/docstrings/myos_interfaces.yaml \
-e rm_dest=tests/rmb_tests/collections/ansible_collections/myorg/myos \
-e resource=interfaces \
-e collection_org=myorg \
-e collection_name=myos \
run.yml