Server IP : 85.214.239.14 / Your IP : 3.146.176.19 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/nxos/plugins/modules/ |
Upload File : |
#!/usr/bin/python # # 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: nxos_igmp extends_documentation_fragment: - cisco.nxos.nxos short_description: Manages IGMP global configuration. description: - Manages IGMP global configuration configuration settings. version_added: 1.0.0 author: - Jason Edelman (@jedelman8) - Gabriele Gerbino (@GGabriele) notes: - Tested against NXOSv 7.3.(0)D1(1) on VIRL - Unsupported for Cisco MDS - When C(state=default), all supported params will be reset to a default state. - If restart is set to true with other params set, the restart will happen last, i.e. after the configuration takes place. options: flush_routes: description: - Removes routes when the IGMP process is restarted. By default, routes are not flushed. type: bool enforce_rtr_alert: description: - Enables or disables the enforce router alert option check for IGMPv2 and IGMPv3 packets. type: bool restart: description: - Restarts the igmp process (using an exec config command). type: bool default: False state: description: - Manages desired state of the resource. default: present choices: - present - default type: str """ EXAMPLES = """ - name: Default igmp global params (all params except restart) cisco.nxos.nxos_igmp: state: default - name: Ensure the following igmp global config exists on the device cisco.nxos.nxos_igmp: flush_routes: true enforce_rtr_alert: true - name: Restart the igmp process cisco.nxos.nxos_igmp: restart: true """ RETURN = """ updates: description: commands sent to the device returned: always type: list sample: ["ip igmp flush-routes"] """ from ansible.module_utils.basic import AnsibleModule from ansible_collections.cisco.nxos.plugins.module_utils.network.nxos.nxos import ( load_config, run_commands, ) def get_current(module): output = run_commands(module, {"command": "show running-config", "output": "text"}) return { "flush_routes": "ip igmp flush-routes" in output[0], "enforce_rtr_alert": "ip igmp enforce-router-alert" in output[0], } def get_desired(module): return { "flush_routes": module.params["flush_routes"], "enforce_rtr_alert": module.params["enforce_rtr_alert"], } def main(): argument_spec = dict( flush_routes=dict(type="bool"), enforce_rtr_alert=dict(type="bool"), restart=dict(type="bool", default=False), state=dict(choices=["present", "default"], default="present"), ) module = AnsibleModule(argument_spec=argument_spec, supports_check_mode=True) warnings = list() current = get_current(module) desired = get_desired(module) state = module.params["state"] commands = list() if state == "default": if current["flush_routes"]: commands.append("no ip igmp flush-routes") if current["enforce_rtr_alert"]: commands.append("no ip igmp enforce-router-alert") elif state == "present": ldict = { "flush_routes": "flush-routes", "enforce_rtr_alert": "enforce-router-alert", } for arg in ["flush_routes", "enforce_rtr_alert"]: if desired[arg] and not current[arg]: commands.append("ip igmp {0}".format(ldict.get(arg))) elif current[arg] and not desired[arg]: commands.append("no ip igmp {0}".format(ldict.get(arg))) result = {"changed": False, "updates": commands, "warnings": warnings} if commands: if not module.check_mode: load_config(module, commands) result["changed"] = True if module.params["restart"]: cmd = {"command": "restart igmp", "output": "text"} run_commands(module, cmd) module.exit_json(**result) if __name__ == "__main__": main()