Server IP : 85.214.239.14 / Your IP : 52.15.172.207 Web Server : Apache/2.4.62 (Debian) System : Linux h2886529.stratoserver.net 4.9.0 #1 SMP Tue Jan 9 19:45:01 MSK 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.18 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, MySQL : OFF | cURL : OFF | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : OFF Directory : /lib/python3/dist-packages/ansible_collections/cisco/nso/plugins/modules/ |
Upload File : |
#!/usr/bin/python # -*- coding: utf-8 -*- # Copyright (c) 2017 Cisco and/or its affiliates. # # This file is part of Ansible # # Ansible is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # Ansible is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with Ansible. If not, see <http://www.gnu.org/licenses/>. # from __future__ import (absolute_import, division, print_function) __metaclass__ = type DOCUMENTATION = ''' --- module: nso_action extends_documentation_fragment: - cisco.nso.nso short_description: Executes Cisco NSO actions and verifies output. description: - This module provides support for executing Cisco NSO actions and then verifying that the output is as expected. requirements: - Cisco NSO version 3.4 or higher. author: "Claes Nästén (@cnasten)" options: path: description: Path to NSO action. required: true type: str input: description: > NSO action parameters. type: dict output_required: description: > Required output parameters. type: dict output_invalid: description: > List of result parameter names that will cause the task to fail if they are present. type: dict validate_strict: description: > If set to true, the task will fail if any output parameters not in output_required is present in the output. type: bool default: False ''' EXAMPLES = ''' - name: Sync NSO device cisco.nso.nso_action: url: https://10.10.20.49/jsonrpc username: developer password: C1sco12345 path: /ncs:devices/device{dist-rtr01}/sync-from input: {} - name: Check device sync cisco.nso.nso_action: url: https://10.10.20.49/jsonrpc username: developer password: C1sco12345 path: /ncs:devices/check-sync input: {} - name: Load Native Config cisco.nso.nso_action: url: "https://10.10.20.49/jsonrpc" username: developer password: C1sco12345 path: /ncs:devices/ncs:device{dist-rtr01}/load-native-config input: { file: "/home/developer/test.cfg" , verbose: true, mode: "merge"} register: result ''' RETURN = ''' output: description: Action output returned: success type: dict sample: result: true ''' from ansible_collections.cisco.nso.plugins.module_utils.nso import connect, verify_version, nso_argument_spec from ansible_collections.cisco.nso.plugins.module_utils.nso import normalize_value from ansible_collections.cisco.nso.plugins.module_utils.nso import ModuleFailException, NsoException from ansible.module_utils.basic import AnsibleModule class NsoAction(object): REQUIRED_VERSIONS = [ (3, 4) ] def __init__(self, check_mode, client, path, input, output_required, output_invalid, validate_strict): self._check_mode = check_mode self._client = client self._path = path self._input = input self._output_required = output_required self._output_invalid = output_invalid self._validate_strict = validate_strict def main(self): schema = self._client.get_schema(path=self._path) if schema['data']['kind'] != 'action': raise ModuleFailException('{0} is not an action'.format(self._path)) input_schema = [] for c in schema['data']['children']: if c.get('is_action_input', False): if c['kind'] == 'choice': for case in c['cases']: input_schema.append(case) else: input_schema.append(c) for key, value in self._input.items(): child = next((c for c in input_schema if c['name'] == key), None) if child is None: raise ModuleFailException("unsupported input parameter '{0}'".format(key)) # implement type validation in the future if self._check_mode: return {} else: return self._run_and_verify() def _run_and_verify(self): output = self._client.run_action(None, self._path, self._input) for key, value in self._output_required.items(): if key not in output: raise ModuleFailException('{0} not in result'.format(key)) n_value = normalize_value(value, output[key], key) if value != n_value: msg = '{0} value mismatch. expected {1} got {2}'.format( key, value, n_value) raise ModuleFailException(msg) for key in self._output_invalid.keys(): if key in output: raise ModuleFailException('{0} not allowed in result'.format(key)) if self._validate_strict: for name in output.keys(): if name not in self._output_required: raise ModuleFailException('{0} not allowed in result'.format(name)) return output def main(): argument_spec = dict( path=dict(required=True), input=dict(required=False, type='dict', default={}), output_required=dict(required=False, type='dict', default={}), output_invalid=dict(required=False, type='dict', default={}), validate_strict=dict(required=False, type='bool', default=False) ) argument_spec.update(nso_argument_spec) module = AnsibleModule( argument_spec=argument_spec, supports_check_mode=True ) p = module.params client = connect(p) nso_action = NsoAction( module.check_mode, client, p['path'], p['input'], p['output_required'], p['output_invalid'], p['validate_strict']) try: verify_version(client, NsoAction.REQUIRED_VERSIONS) output = nso_action.main() client.logout() module.exit_json(changed=True, output=output) except NsoException as ex: client.logout() module.fail_json(msg=ex.message) except ModuleFailException as ex: client.logout() module.fail_json(msg=ex.message) if __name__ == '__main__': main()