Server IP : 85.214.239.14 / Your IP : 52.15.224.97 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/ios/plugins/modules/ |
Upload File : |
#!/usr/bin/python # -*- coding: utf-8 -*- # Copyright 2021 Red Hat # GNU General Public License v3.0+ # (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt) """ The module file for ios_ntp_global """ from __future__ import absolute_import, division, print_function __metaclass__ = type DOCUMENTATION = """ module: ios_ntp_global short_description: Resource module to configure NTP. description: - This module provides declarative management of ntp on Cisco IOS devices. version_added: 2.5.0 author: - Sagar Paul (@KB-perByte) notes: - Tested against Cisco IOSXE Version 17.3 on CML. - This module works with connection C(network_cli). options: config: description: A dictionary of ntp options type: dict suboptions: access_group: description: Control NTP access type: dict suboptions: peer: description: Provide full access type: list elements: dict suboptions: access_list: &access_group_acl description: name or number of access list type: str kod: &kod description: Send a Kiss-o-Death packet for failing peers type: bool ipv4: &ipv4 description: ipv4 access lists (Default not idempotent) type: bool ipv6: &ipv6 description: ipv6 access lists (Default not idempotent) type: bool query_only: description: Allow only control queries type: list elements: dict suboptions: access_list: *access_group_acl kod: *kod ipv4: *ipv4 ipv6: *ipv6 serve: description: Provide server and query access type: list elements: dict suboptions: access_list: *access_group_acl kod: *kod ipv4: *ipv4 ipv6: *ipv6 serve_only: description: Provide only server access type: list elements: dict suboptions: access_list: *access_group_acl kod: *kod ipv4: *ipv4 ipv6: *ipv6 allow: description: Allow processing of packets type: dict suboptions: control: description: Allow processing control mode packets type: dict suboptions: rate_limit: description: Rate-limit delay. type: int private: description: Allow processing private mode packets type: bool authenticate: description: Authenticate time sources type: bool authentication_keys: description: Authentication key for trusted time sources type: list elements: dict suboptions: id: description: Key number type: int algorithm: description: Authentication type type: str key: description: Password type: str encryption: description: Authentication key encryption type type: int broadcast_delay: description: Estimated round-trip delay type: int clock_period: description: Length of hardware clock tick, clock period in 2^-32 seconds type: int logging: description: Enable NTP message logging type: bool master: description: Act as NTP master clock type: dict suboptions: enabled: description: Enable master clock type: bool stratum: description: Stratum number type: int max_associations: description: Set maximum number of associations type: int max_distance: description: Maximum Distance for synchronization type: int min_distance: description: Minimum distance to consider for clockhop type: int orphan: description: Threshold Stratum for orphan mode type: int panic_update: description: Reject time updates > panic threshold (default 1000Sec) type: bool passive: description: NTP passive mode type: bool peers: description: Configure NTP peer type: list elements: dict suboptions: peer: description: ipv4/ipv6 address or hostname of the peer type: str use_ipv4: &use_ipv4 description: Use IP for DNS resolution type: bool use_ipv6: &use_ipv6 description: Use IPv6 for DNS resolution type: bool vrf: &vrf description: VPN Routing/Forwarding Information type: str burst: &burst description: Send a burst when peer is reachable (Default) type: bool iburst: &iburst description: Send a burst when peer is unreachable (Default) type: bool key_id: &key description: Configure peer authentication key type: int aliases: - key maxpoll: &maxpoll description: Maximum poll interval Poll value in Log2 type: int minpoll: &minpoll description: Minimum poll interval Poll value in Log2 type: int normal_sync: &normal_sync description: Disable rapid sync at startup type: bool prefer: &prefer description: Prefer this peer when possible type: bool source: &source description: Interface for source address type: str version: &version description: Configure NTP version type: int servers: description: Configure NTP server type: list elements: dict suboptions: server: description: ipv4/ipv6 address or hostname of the server type: str use_ipv4: *use_ipv4 use_ipv6: *use_ipv6 vrf: *vrf burst: *burst iburst: *iburst key_id: *key maxpoll: *maxpoll minpoll: *minpoll normal_sync: *normal_sync prefer: *prefer source: *source version: *version source: description: Configure interface for source address type: str trusted_keys: description: Key numbers for trusted time sources type: list elements: dict suboptions: range_start: description: Start / key number type: int range_end: description: End key number type: int update_calendar: description: Periodically update calendar with NTP time type: bool running_config: description: - This option is used only with state I(parsed). - The value of this option should be the output received from the IOS device by executing the command B(show running-config | section ^ntp). - The state I(parsed) reads the configuration from C(running_config) option and transforms it into Ansible structured data as per the resource module's argspec and the value is then returned in the I(parsed) key within the result. type: str state: choices: - merged - replaced - overridden - deleted - rendered - gathered - parsed default: merged description: - The state the configuration should be left in - The states I(rendered), I(gathered) and I(parsed) does not perform any change on the device. - The state I(rendered) will transform the configuration in C(config) option to platform specific CLI commands which will be returned in the I(rendered) key within the result. For state I(rendered) active connection to remote host is not required. - The states I(replaced) and I(overridden) have identical behaviour for this module. - The state I(gathered) will fetch the running configuration from device and transform it into structured data in the format as per the resource module argspec and the value is returned in the I(gathered) key within the result. - The state I(parsed) reads the configuration from C(running_config) option and transforms it into JSON format as per the resource module parameters and the value is returned in the I(parsed) key within the result. The value of C(running_config) option should be the same format as the output of command I(show running-config | section ^ntp) executed on device. For state I(parsed) active connection to remote host is not required. type: str """ EXAMPLES = """ # Using state: merged # Before state: # ------------- # router-ios#show running-config | section ^ntp # --------------------- EMPTY ----------------- # Merged play: # ------------ - name: Apply the provided configuration cisco.ios.ios_ntp_global: config: access_group: peer: - access_list: DHCP-Server ipv4: true kod: true - access_list: preauth_ipv6_acl ipv6: true kod: true - access_list: "2" kod: true query_only: - access_list: "10" allow: control: rate_limit: 4 private: true authenticate: true authentication_keys: - algorithm: md5 encryption: 22 id: 2 key: SomeSecurePassword broadcast_delay: 22 clock_period: 5 logging: true master: stratum: 4 max_associations: 34 max_distance: 3 min_distance: 10 orphan: 4 panic_update: true peers: - peer: 172.16.1.10 version: 2 - key: 2 minpoll: 5 peer: 172.16.1.11 prefer: true version: 2 - peer: checkPeerDomainIpv4.com prefer: true use_ipv4: true - peer: checkPeerDomainIpv6.com use_ipv6: true - peer: testPeerDomainIpv6.com prefer: true use_ipv6: true servers: - server: 172.16.1.12 version: 2 - server: checkServerDomainIpv6.com use_ipv6: true - server: 172.16.1.13 source: GigabitEthernet0/1 source: GigabitEthernet0/1 trusted_keys: - range_end: 3 range_start: 3 - range_start: 21 state: merged # Commands Fired: # --------------- # "commands": [ # "ntp allow mode control 4", # "ntp allow mode private", # "ntp authenticate", # "ntp broadcastdelay 22", # "ntp clock-period 5", # "ntp logging", # "ntp master 4", # "ntp max-associations 34", # "ntp maxdistance 3", # "ntp mindistance 10", # "ntp orphan 4", # "ntp panic update", # "ntp source GigabitEthernet0/1", # "ntp access-group ipv4 peer DHCP-Server kod", # "ntp access-group ipv6 peer preauth_ipv6_acl kod", # "ntp access-group peer 2 kod", # "ntp access-group query-only 10", # "ntp authentication-key 2 md5 SomeSecurePassword 22", # "ntp peer 172.16.1.10 version 2", # "ntp peer 172.16.1.11 key 2 minpoll 5 prefer version 2", # "ntp peer ip checkPeerDomainIpv4.com prefer", # "ntp peer ipv6 checkPeerDomainIpv6.com", # "ntp peer ipv6 testPeerDomainIpv6.com prefer", # "ntp server 172.16.1.12 version 2", # "ntp server ipv6 checkServerDomainIpv6.com", # "ntp server 172.16.1.13 source GigabitEthernet0/1", # "ntp trusted-key 3 - 3", # "ntp trusted-key 21" # ], # After state: # ------------ # router-ios#show running-config | section ^ntp # ntp max-associations 34 # ntp logging # ntp allow mode control 4 # ntp panic update # ntp authentication-key 2 md5 0635002C497D0C1A1005173B0D17393C2B3A37 7 # ntp authenticate # ntp trusted-key 3 - 3 # ntp trusted-key 21 # ntp orphan 4 # ntp mindistance 10 # ntp maxdistance 3 # ntp broadcastdelay 22 # ntp source GigabitEthernet0/1 # ntp access-group peer 2 kod # ntp access-group ipv6 peer preauth_ipv6_acl kod # ntp master 4 # ntp peer 172.16.1.10 version 2 # ntp peer 172.16.1.11 key 2 minpoll 5 prefer version 2 # ntp server 172.16.1.12 version 2 # ntp server 172.16.1.13 source GigabitEthernet0/1 # ntp peer ip checkPeerDomainIpv4.com prefer # ntp peer ipv6 checkPeerDomainIpv6.com # ntp peer ipv6 testPeerDomainIpv6.com prefer # ntp server ipv6 checkServerDomainIpv6.com # Using state: deleted # Before state: # ------------- # router-ios#show running-config | section ^ntp # ntp max-associations 34 # ntp logging # ntp allow mode control 4 # ntp panic update # ntp authentication-key 2 md5 0635002C497D0C1A1005173B0D17393C2B3A37 7 # ntp authenticate # ntp trusted-key 3 - 3 # ntp trusted-key 21 # ntp orphan 4 # ntp mindistance 10 # ntp maxdistance 3 # ntp broadcastdelay 22 # ntp source GigabitEthernet0/1 # ntp access-group peer 2 kod # ntp access-group ipv6 peer preauth_ipv6_acl kod # ntp master 4 # ntp peer 172.16.1.10 version 2 # ntp peer 172.16.1.11 key 2 minpoll 5 prefer version 2 # ntp server 172.16.1.12 version 2 # ntp server 172.16.1.13 source GigabitEthernet0/1 # ntp peer ip checkPeerDomainIpv4.com prefer # ntp peer ipv6 checkPeerDomainIpv6.com # ntp peer ipv6 testPeerDomainIpv6.com prefer # ntp server ipv6 checkServerDomainIpv6.com # Deleted play: # ------------- - name: Remove all existing configuration cisco.ios.ios_ntp_global: state: deleted # Commands Fired: # --------------- # "commands": [ # "no ntp allow mode control 4", # "no ntp authenticate", # "no ntp broadcastdelay 22", # "no ntp logging", # "no ntp master 4", # "no ntp max-associations 34", # "no ntp maxdistance 3", # "no ntp mindistance 10", # "no ntp orphan 4", # "no ntp panic update", # "no ntp source GigabitEthernet0/1", # "no ntp access-group peer 2 kod", # "no ntp access-group ipv6 peer preauth_ipv6_acl kod", # "no ntp authentication-key 2 md5 0635002C497D0C1A1005173B0D17393C2B3A37 7", # "no ntp peer 172.16.1.10 version 2", # "no ntp peer 172.16.1.11 key 2 minpoll 5 prefer version 2", # "no ntp peer ip checkPeerDomainIpv4.com prefer", # "no ntp peer ipv6 checkPeerDomainIpv6.com", # "no ntp peer ipv6 testPeerDomainIpv6.com prefer", # "no ntp server 172.16.1.12 version 2", # "no ntp server 172.16.1.13 source GigabitEthernet0/1", # "no ntp server ipv6 checkServerDomainIpv6.com", # "no ntp trusted-key 21", # "no ntp trusted-key 3 - 3" # ], # After state: # ------------ # router-ios#show running-config | section ^ntp # --------------------- EMPTY ----------------- # Using state: overridden # Before state: # ------------- # router-ios#show running-config | section ^ntp # ntp panic update # ntp authentication-key 2 md5 00371C0B01680E051A33497E080A16001D1908 7 # ntp authenticate # ntp trusted-key 3 - 4 # ntp trusted-key 21 # ntp source GigabitEthernet0/1 # ntp peer 172.16.1.10 version 2 # ntp server 172.16.1.12 version 2 # ntp peer ip checkPeerDomainIpv4.com prefer # ntp server ipv6 checkServerDomainIpv6.com # Overridden play: # ---------------- - name: Override commands with provided configuration cisco.ios.ios_ntp_global: config: peers: - peer: ipv6DomainNew.com use_ipv6: true - peer: 172.16.1.100 prefer: true use_ipv4: true access_group: peer: - access_list: DHCP-Server ipv6: true state: overridden # Commands Fired: # --------------- # "commands": [ # "no ntp authenticate", # "no ntp panic update", # "no ntp source GigabitEthernet0/1", # "ntp access-group ipv6 peer DHCP-Server", # "no ntp authentication-key 2 md5 00371C0B01680E051A33497E080A16001D1908 7", # "ntp peer ipv6 ipv6DomainNew.com", # "ntp peer 172.16.1.100 prefer", # "no ntp peer 172.16.1.10 version 2", # "no ntp peer ip checkPeerDomainIpv4.com prefer", # "no ntp server 172.16.1.12 version 2", # "no ntp server ipv6 checkServerDomainIpv6.com", # "no ntp trusted-key 21", # "no ntp trusted-key 3 - 4" # ], # After state: # ------------ # router-ios#show running-config | section ^ntp # ntp access-group ipv6 peer DHCP-Server # ntp peer ipv6 ipv6DomainNew.com # ntp peer 172.16.1.100 prefer # Using state: replaced # Before state: # ------------- # router-ios#show running-config | section ^ntp # ntp access-group ipv6 peer DHCP-Server # ntp peer ipv6 ipv6DomainNew.com # ntp peer 172.16.1.100 prefer # Replaced play: # -------------- - name: Replace commands with provided configuration cisco.ios.ios_ntp_global: config: broadcast_delay: 22 clock_period: 5 logging: true master: stratum: 4 max_associations: 34 max_distance: 3 min_distance: 10 orphan: 4 state: replaced # Commands Fired: # --------------- # "commands": [ # "ntp broadcastdelay 22", # "ntp clock-period 5", # "ntp logging", # "ntp master 4", # "ntp max-associations 34", # "ntp maxdistance 3", # "ntp mindistance 10", # "ntp orphan 4", # "no ntp access-group ipv6 peer DHCP-Server", # "no ntp peer 172.16.1.100 prefer", # "no ntp peer ipv6 ipv6DomainNew.com" # ], # After state: # ------------ # router-ios#show running-config | section ^ntp # ntp max-associations 34 # ntp logging # ntp orphan 4 # ntp mindistance 10 # ntp maxdistance 3 # ntp broadcastdelay 22 # ntp master 4 # Using state: gathered # Before state: # ------------- #router-ios#show running-config | section ^ntp # ntp max-associations 34 # ntp logging # ntp allow mode control 4 # ntp panic update # ntp authentication-key 2 md5 0635002C497D0C1A1005173B0D17393C2B3A37 7 # ntp authenticate # ntp trusted-key 3 - 3 # ntp trusted-key 21 # ntp orphan 4 # ntp mindistance 10 # ntp maxdistance 3 # ntp broadcastdelay 22 # ntp source GigabitEthernet0/1 # ntp access-group peer 2 kod # ntp access-group ipv6 peer preauth_ipv6_acl kod # ntp master 4 # ntp update-calendar # ntp peer 172.16.1.10 version 2 # ntp peer 172.16.1.11 key 2 minpoll 5 prefer version 2 # ntp server 172.16.1.12 version 2 # ntp server 172.16.1.13 source GigabitEthernet0/1 # ntp peer ip checkPeerDomainIpv4.com prefer # ntp peer ipv6 checkPeerDomainIpv6.com # ntp peer ipv6 testPeerDomainIpv6.com prefer # ntp server ipv6 checkServerDomainIpv6.com # Gathered play: # -------------- - name: Gather listed ntp config cisco.ios.ios_ntp_global: state: gathered # Module Execution Result: # ------------------------ # "gathered": { # "access_group": { # "peer": [ # { # "access_list": "2", # "kod": true # }, # { # "access_list": "preauth_ipv6_acl", # "ipv6": true, # "kod": true # } # ] # }, # "allow": { # "control": { # "rate_limit": 4 # } # }, # "authenticate": true, # "authentication_keys": [ # { # "algorithm": "md5", # "encryption": 7, # "id": 2, # "key": "0635002C497D0C1A1005173B0D17393C2B3A37" # } # ], # "broadcast_delay": 22, # "logging": true, # "master": { # "stratum": 4 # }, # "max_associations": 34, # "max_distance": 3, # "min_distance": 10, # "orphan": 4, # "panic_update": true, # "peers": [ # { # "peer": "172.16.1.10", # "version": 2 # }, # { # "key": 2, # "minpoll": 5, # "peer": "172.16.1.11", # "prefer": true, # "version": 2 # }, # { # "peer": "checkPeerDomainIpv4.com", # "prefer": true, # "use_ipv4": true # }, # { # "peer": "checkPeerDomainIpv6.com", # "use_ipv6": true # }, # { # "peer": "testPeerDomainIpv6.com", # "prefer": true, # "use_ipv6": true # } # ], # "servers": [ # { # "server": "172.16.1.12", # "version": 2 # }, # { # "server": "172.16.1.13", # "source": "GigabitEthernet0/1" # }, # { # "server": "checkServerDomainIpv6.com", # "use_ipv6": true # } # ], # "source": "GigabitEthernet0/1", # "trusted_keys": [ # { # "range_start": 21 # }, # { # "range_end": 3, # "range_start": 3 # } # ], # "update_calendar": true # }, # After state: # ------------- # router-ios#show running-config | section ^ntp # ntp max-associations 34 # ntp logging # ntp allow mode control 4 # ntp panic update # ntp authentication-key 2 md5 0635002C497D0C1A1005173B0D17393C2B3A37 7 # ntp authenticate # ntp trusted-key 3 - 3 # ntp trusted-key 21 # ntp orphan 4 # ntp mindistance 10 # ntp maxdistance 3 # ntp broadcastdelay 22 # ntp source GigabitEthernet0/1 # ntp access-group peer 2 kod # ntp access-group ipv6 peer preauth_ipv6_acl kod # ntp master 4 # ntp update-calendar # ntp peer 172.16.1.10 version 2 # ntp peer 172.16.1.11 key 2 minpoll 5 prefer version 2 # ntp server 172.16.1.12 version 2 # ntp server 172.16.1.13 source GigabitEthernet0/1 # ntp peer ip checkPeerDomainIpv4.com prefer # ntp peer ipv6 checkPeerDomainIpv6.com # ntp peer ipv6 testPeerDomainIpv6.com prefer # ntp server ipv6 checkServerDomainIpv6.com # Using state: rendered # Rendered play: # -------------- - name: Render the commands for provided configuration cisco.ios.ios_ntp_global: config: access_group: peer: - access_list: DHCP-Server ipv4: true kod: true - access_list: preauth_ipv6_acl ipv6: true kod: true - access_list: "2" kod: true query_only: - access_list: "10" allow: control: rate_limit: 4 private: true authenticate: true authentication_keys: - algorithm: md5 encryption: 22 id: 2 key: SomeSecurePassword broadcast_delay: 22 clock_period: 5 logging: true master: stratum: 4 max_associations: 34 max_distance: 3 min_distance: 10 orphan: 4 panic_update: true peers: - peer: 172.16.1.10 version: 2 - key: 2 minpoll: 5 peer: 172.16.1.11 prefer: true version: 2 - peer: checkPeerDomainIpv4.com prefer: true use_ipv4: true - peer: checkPeerDomainIpv6.com use_ipv6: true - peer: testPeerDomainIpv6.com prefer: true use_ipv6: true servers: - server: 172.16.1.12 version: 2 - server: checkServerDomainIpv6.com use_ipv6: true - server: 172.16.1.13 source: GigabitEthernet0/1 source: GigabitEthernet0/1 trusted_keys: - range_end: 3 range_start: 10 - range_start: 21 update_calendar: true state: rendered # Module Execution Result: # ------------------------ # "rendered": [ # "ntp allow mode control 4", # "ntp allow mode private", # "ntp authenticate", # "ntp broadcastdelay 22", # "ntp clock-period 5", # "ntp logging", # "ntp master 4", # "ntp max-associations 34", # "ntp maxdistance 3", # "ntp mindistance 10", # "ntp orphan 4", # "ntp panic update", # "ntp source GigabitEthernet0/1", # "ntp update-calendar", # "ntp access-group ipv4 peer DHCP-Server kod", # "ntp access-group ipv6 peer preauth_ipv6_acl kod", # "ntp access-group peer 2 kod", # "ntp access-group query-only 10", # "ntp authentication-key 2 md5 SomeSecurePassword 22", # "ntp peer 172.16.1.10 version 2", # "ntp peer 172.16.1.11 key 2 minpoll 5 prefer version 2", # "ntp peer ip checkPeerDomainIpv4.com prefer", # "ntp peer ipv6 checkPeerDomainIpv6.com", # "ntp peer ipv6 testPeerDomainIpv6.com prefer", # "ntp server 172.16.1.12 version 2", # "ntp server ipv6 checkServerDomainIpv6.com", # "ntp server 172.16.1.13 source GigabitEthernet0/1", # "ntp trusted-key 3 - 3", # "ntp trusted-key 21" # ] # Using state: parsed # File: parsed.cfg # ---------------- # ntp allow mode control 4 # ntp allow mode private # ntp authenticate # ntp broadcastdelay 22 # ntp clock-period 5 # ntp logging # ntp master 4 # ntp max-associations 34 # ntp maxdistance 3 # ntp mindistance 10 # ntp orphan 4 # ntp panic update # ntp source GigabitEthernet0/1 # ntp update-calendar # ntp access-group ipv4 peer DHCP-Server kod # ntp access-group ipv6 peer preauth_ipv6_acl kod # ntp access-group peer 2 kod # ntp access-group query-only 10 # ntp authentication-key 2 md5 SomeSecurePassword 22 # ntp peer 172.16.1.10 version 2 # ntp peer 172.16.1.11 key 2 minpoll 5 prefer version 2 # ntp peer ip checkPeerDomainIpv4.com prefer # ntp peer ipv6 checkPeerDomainIpv6.com # ntp peer ipv6 testPeerDomainIpv6.com prefer # ntp server 172.16.1.12 version 2 # ntp server ipv6 checkServerDomainIpv6.com # ntp server 172.16.1.13 source GigabitEthernet0/1 # ntp trusted-key 3 - 13 # ntp trusted-key 21 # Parsed play: # ------------ - name: Parse the provided configuration with the existing running configuration cisco.ios.ios_ntp_global: running_config: "{{ lookup('file', 'parsed.cfg') }}" state: parsed # Module Execution Result: # ------------------------ # "parsed": { # "access_group": { # "peer": [ # { # "access_list": "2", # "kod": true # }, # { # "access_list": "DHCP-Server", # "ipv4": true, # "kod": true # }, # { # "access_list": "preauth_ipv6_acl", # "ipv6": true, # "kod": true # } # ], # "query_only": [ # { # "access_list": "10" # } # ] # }, # "allow": { # "control": { # "rate_limit": 4 # }, # "private": true # }, # "authenticate": true, # "authentication_keys": [ # { # "algorithm": "md5", # "encryption": 22, # "id": 2, # "key": "SomeSecurePassword" # } # ], # "broadcast_delay": 22, # "clock_period": 5, # "logging": true, # "master": { # "stratum": 4 # }, # "max_associations": 34, # "max_distance": 3, # "min_distance": 10, # "orphan": 4, # "panic_update": true, # "peers": [ # { # "peer": "172.16.1.10", # "version": 2 # }, # { # "peer": "checkPeerDomainIpv6.com", # "use_ipv6": true # } # ], # "servers": [ # { # "server": "172.16.1.12", # "version": 2 # }, # { # "server": "172.16.1.13", # "source": "GigabitEthernet0/1" # }, # { # "server": "checkServerDomainIpv6.com", # "use_ipv6": true # } # ], # "source": "GigabitEthernet0/1", # "trusted_keys": [ # { # "range_start": 21 # }, # { # "range_end": 13, # "range_start": 3 # } # ], # "update_calendar": true # } """ RETURN = """ before: description: The configuration prior to the module execution. returned: when I(state) is C(merged), C(replaced), C(overridden), C(deleted) or C(purged) type: dict sample: > This output will always be in the same format as the module argspec. after: description: The resulting configuration after module execution. returned: when changed type: dict sample: > This output will always be in the same format as the module argspec. commands: description: The set of commands pushed to the remote device. returned: when I(state) is C(merged), C(replaced), C(overridden), C(deleted) or C(purged) type: list sample: - ntp peer 20.18.11.3 key 6 minpoll 15 prefer version 2 - ntp access-group ipv4 peer DHCP-Server kod - ntp trusted-key 9 - 96 - ntp master stratum 2 - ntp orphan 4 - ntp panic update rendered: description: The provided configuration in the task rendered in device-native format (offline). returned: when state is I(rendered) type: list sample: - ntp master stratum 2 - ntp server ip testserver.com prefer - ntp authentication-key 2 md5 testpass 22 - ntp allow mode control 4 - ntp max-associations 34 - ntp broadcastdelay 22 gathered: description: Facts about the network resource gathered from the remote device as structured data. returned: when I(state) is C(gathered) type: list sample: > This output will always be in the same format as the module argspec. parsed: description: The device native config provided in I(running_config) option parsed into structured data as per module argspec. returned: when I(state) is C(parsed) type: list sample: > This output will always be in the same format as the module argspec. """ from ansible.module_utils.basic import AnsibleModule from ansible_collections.cisco.ios.plugins.module_utils.network.ios.argspec.ntp_global.ntp_global import ( Ntp_globalArgs, ) from ansible_collections.cisco.ios.plugins.module_utils.network.ios.config.ntp_global.ntp_global import ( Ntp_global, ) def main(): """ Main entry point for module execution :returns: the result form module invocation """ module = AnsibleModule( argument_spec=Ntp_globalArgs.argument_spec, mutually_exclusive=[["config", "running_config"]], required_if=[ ["state", "merged", ["config"]], ["state", "replaced", ["config"]], ["state", "overridden", ["config"]], ["state", "rendered", ["config"]], ["state", "parsed", ["running_config"]], ], supports_check_mode=True, ) result = Ntp_global(module).execute_module() module.exit_json(**result) if __name__ == "__main__": main()