cisco.dnac.network_settings_workflow_manager module – Resource module for IP Address pools and network functions
Note
This module is part of the cisco.dnac collection (version 6.40.0).
You might already have this collection installed if you are using the ansible package.
It is not included in ansible-core.
To check whether it is installed, run ansible-galaxy collection list.
To install it, use: ansible-galaxy collection install cisco.dnac.
You need further requirements to be able to use this module,
see Requirements for details.
To use it in a playbook, specify: cisco.dnac.network_settings_workflow_manager.
New in cisco.dnac 6.6.0
Synopsis
- Manage operations on Global Pool, Reserve Pool, Network resources. 
- API to create/update/delete global pool. 
- API to reserve/update/delete an ip subpool from the global pool. 
- API to update network settings for DHCP, Syslog, SNMP, NTP, Network AAA, Client and Endpoint AAA, and/or DNS center server settings. 
Requirements
The below requirements are needed on the host that executes this module.
- dnacentersdk >= 2.7.2 
- python >= 3.9 
Parameters
| Parameter | Comments | 
|---|---|
| List of details of global pool, reserved pool, network being managed. | |
| Defines the default device controllability settings at the site level. Controls whether Catalyst Center can apply telemetry and configuration policies to devices. | |
| Boolean flag to automatically correct telemetry configuration on devices if it deviates from the expected state. Optional setting; defaults to false. Choices: 
 | |
| Boolean flag to enable or disable device controllability at the site level. This is a required setting. When enabled, Catalyst Center manages telemetry and configuration policies on devices. Choices: 
 | |
| Manages IPv4 and IPv6 IP pools in the global level. | |
| Global Pool’s settings. | |
| Contains a list of global IP pool configurations. | |
| Defines the IP pool’s Classless Inter-Domain Routing block, enabling systematic IP address distribution within a network. | |
| The DHCP server IPs responsible for automatically assigning IP addresses and network configuration parameters to devices on a local network. | |
| Responsible for translating domain names into corresponding IP addresses. | |
| Forcefully delete all IP pools from the global level of the global pool. The default value is false. Choices: 
 | |
| Serves as an entry or exit point for data traffic between networks. | |
| IP address space either IPv4 or IPv6. | |
| Specifies the name assigned to the Global IP Pool. Required for the operations in the Global IP Pool. Length should be less than or equal to 100. Only letters, numbers and -_./ characters are allowed. | |
| Includes both the Generic Ip Pool and Tunnel Ip Pool. Generic - Used for general purpose within the network such as device management or communication between the network devices. Tunnel - Designated for the tunnel interfaces to encapsulate packets within the network protocol. It is used in VPN connections, GRE tunnels, or other types of overlay networks. Choices: 
 | |
| The former identifier for the global pool. It should be used exclusively when you need to update the global pool’s name. | |
| Set default network settings for the site | |
| Network management details settings. | |
| Manages AAA (Authentication Authorization Accounting) for clients and endpoints. | |
| PAN IP address for the ISE server. For example, 1.1.1.1. | |
| Primary IP address for the ISE/AAA server. For example, 1.1.1.2. | |
| Protocol for AAA or ISE server. Choices: 
 | |
| Secondary IP address for the AAA server. For example, 1.1.1.3. | |
| Server type for managing AAA for client and endpoints. Choices: 
 | |
| Shared secret for ISE Server. Length of the shared secret should be atleast 4 characters. | |
| DHCP Server IP address (eg 1.1.1.4). | |
| DNS server details of the network under a specific site. | |
| Domain Name of DHCP (eg; cisco.com, cisco.net). | |
| Primary IP Address for DHCP (eg 2.2.2.2). | |
| Secondary IP Address for DHCP (eg 3.3.3.3). | |
| Banner details under a specific site. | |
| Message for the banner (eg; Good day). | |
| Retain existing banner message. Choices: 
 | |
| NetFlow collector configuration for a specific site. | |
| Type of NetFlow collector. Supported values include ‘Builtin’ and ‘Telemetry_broker_or_UDP_director’. Applicable from Cisco Catalyst Center version 2.3.7.6 onwards. Choices: 
 | |
| Enable or disable wired access device. Applicable from Cisco Catalyst Center version 2.3.7.6 onwards.. Choices: 
 | |
| IP Address for NetFlow collector. For example, 3.3.3.1. | |
| Port number used by the NetFlow collector. For example, 443. | |
| Manages AAA (Authentication Authorization Accounting) for network devices. | |
| PAN IP address for the ISE server. For example, 1.1.1.1. | |
| Primary IP address for the ISE/AAA server. For example, 1.1.1.2. | |
| Protocol for AAA or ISE server. Choices: 
 | |
| Secondary IP address for the AAA server. For example, 1.1.1.3. | |
| Server type for managing AAA for network devices. Choices: 
 | |
| Shared secret for ISE Server. Length of the shared secret should be atleast 4 characters. | |
| IP address for NTP server under a specific site (eg 1.1.1.2). | |
| Snmp Server details under a specific site. | |
| Configuration Cisco Catalyst Center IP for SNMP Server (eg true). Choices: 
 | |
| IP Address for SNMP Server (eg 4.4.4.1). | |
| syslog Server details under a specific site. | |
| Configuration Cisco Catalyst Center IP for syslog server (eg true). Choices: 
 | |
| IP Address for syslog server (eg 4.4.4.4). | |
| Time zone of a specific site. (eg Africa/Abidjan/GMT). | |
| Enables or disables the collection of data from wired network devices for telemetry and monitoring purposes. Applicable from Cisco Catalyst Center version 2.3.7.6 onwards. | |
| Enable or disable wired data collection. Choices: 
 | |
| Enables or disables the collection of telemetry data from wireless network devices for performance monitoring and analysis. Applicable from Cisco Catalyst Center version 2.3.7.6 onwards. | |
| Enable or disable wireless telemetry. Choices: 
 | |
| The name of the site provided as a path parameter, used to specify where the IP sub-pool will be reserved. (eg Global/Chennai/Trill) | |
| Reserved IP subpool details from the global pool. | |
| Forcefully delete all IP pools from the reserve level of the IP sub-pool. The default value is false. Choices: 
 | |
| - Specifies the number of IPv4 addresses that have already been allocated. - Reflects the count of addresses currently in use. | |
| - Specifies the number of IPv4 addresses assigned by default during pool creation. - Represents the initial allocation count when the pool is created. | |
| Specifies the IPv4 addresses for DHCP servers, for example, “1.1.1.1”. | |
| Specifies the IPv4 addresses for DNS servers, for example, “4.4.4.4”. | |
| Provides the gateway’s IPv4 address, for example, “175.175.0.1”. | |
| Specifies the IPv4 global pool address in CIDR notation, for example, “175.175.0.0/16”. When both ‘ipv4_global_pool’ and ‘ipv4_global_pool_name’ are provided, the value of ‘ipv4_global_pool’ takes precedence in version 2.3.5.3. However, in version 2.3.7.9, ipv4_global_pool_name takes precedence over ipv4_global_pool. | |
| Specifies the name to be associated with the IPv4 Global IP Pool. If both ‘ipv4_global_pool’ and ‘ipv4_global_pool_name’ are provided, the ‘ipv4_global_pool’ will be given priority. | |
| Indicates whether the IPv4 prefix length input is enabled. If true, the IPv4 prefix length must be specified. Alternatively, the IPv4 total host input can be enabled instead. Choices: 
 | |
| Specifies the IPv4 prefix length. For IPv4, it must be between 8 and 30, inclusive. Required when ‘ipv4_prefix’ is true. For example, a prefix length of 24 corresponds to a subnet mask of 255.255.255.0. Mandatory starting from Cisco Catalyst Center version 2.3.7.9 if ‘ipv4_total_host’ is not provided. | |
| Indicates the IPv4 subnet address, for example, “175.175.0.0”. This parameter is required starting from Cisco Catalyst Center version 2.3.7.9 and later. | |
| Specifies the total number of IPv4 hosts. Must be a positive integer within the subnet capacity. For IPv4, the value must fit within a 32-bit address space. Required when ‘ipv4_prefix’ is false. Mandatory starting from Cisco Catalyst Center version 2.3.7.9 if ‘ipv4_prefix_length’ is not provided. | |
| - Specifies the number of IPv4 addresses that cannot be assigned due to constraints or reservations. - These addresses are excluded from allocation pools. | |
| Determines whether both IPv6 and IPv4 inputs are required. If set to false, only IPv4 inputs are required. If set to true, both IPv6 and IPv4 inputs are required. Choices: 
 | |
| - Specifies the number of IPv6 addresses that have already been allocated. - Reflects the count of addresses currently in use. | |
| - Specifies the number of IPv6 addresses assigned by default during pool creation. - Represents the initial allocation count when the pool is created. | |
| Specifies the IPv6 addresses for DHCP servers in the format. For example, “2001:0db8:0123:4567:89ab:cdef:0001:0001”. | |
| Specifies the IPv6 addresses for DNS servers. For example, “2001:0db8:0123:4567:89ab:cdef:0002:0002”. | |
| Provides the gateway’s IPv6 address. For example, “2001:0db8:0123:4567:89ab:cdef:0003:0003”. | |
| The ipv6_global_pool is a required when the ipv6_address_space is set to true. It specifies the global IPv6 address pool using CIDR notation, such as “2001:db8:85a3::/64”. In cases where both ipv6_global_pool and ipv6_global_pool_name are specified, ipv6_global_pool will take precedence. | |
| Specifies the name assigned to the Ip v6 Global IP Pool. If both ‘ipv6_global_pool’ and ‘ipv6_global_pool_name’ are provided, the ‘ipv6_global_pool’ will be given priority. | |
| Determines whether to enable the ‘ipv6_prefix_length’ or ‘ipv6_total_host’ input field. If the IPv6 prefix value is true, the IPv6 prefix length input field is required. If it is false, the ipv6_total_host input is required. Choices: 
 | |
| Specifies the IPv6 prefix length. The valid range is from 0 to 128. Required when ‘ipv6_prefix’ is true. Mandatory starting from Cisco Catalyst Center version 2.3.7.9 if ‘ipv6_total_host’ is not provided. | |
| IPv6 Subnet address, example 2001:db8:85a3:0:100. This parameter is required starting from Cisco Catalyst Center version 2.3.7.9 and later. | |
| Specifies the total number of IPv6 hosts. Must be an integer less than 256. Required when ‘ipv6_prefix’ is false. Mandatory starting from Cisco Catalyst Center version 2.3.7.9 if ‘ipv6_prefix_length’ is not provided. | |
| - Specifies the number of IPv6 addresses that cannot be assigned due to constraints or reservations. - These addresses are excluded from allocation pools. | |
| Name of the reserve IP subpool. Required for the operations in the Reserve IP Pool. Length should be less than or equal to 100. Only letters, numbers and -_./ characters are allowed. | |
| Type of the reserve ip sub pool. Generic - Used for general purpose within the network such as device management or communication between the network devices. LAN - Used for the devices and the resources within the Local Area Network such as device connectivity, internal communication, or services. Management - Used for the management purposes such as device management interfaces, management access, or other administrative functions. Service - Used for the network services and application such as DNS (Domain Name System), DHCP (Dynamic Host Configuration Protocol), NTP (Network Time Protocol). WAN - Used for the devices and resources with the Wide Area Network such as remote sites interconnection with other network or services hosted within WAN. Choices: 
 | |
| The former name associated with the reserved IP sub-pool. | |
| The name of the site provided as a path parameter, used to specify where the IP sub-pool will be reserved. | |
| Allows devices on IPv6 networks to self-configure their IP addresses autonomously, eliminating the need for manual setup. Choices: 
 | |
| Set to True to verify the Cisco Catalyst Center after applying the playbook config. Choices: 
 | |
| Defines the timeout in seconds for API calls to retrieve task details. If the task details are not received within this period, the process will end, and a timeout notification will be logged. Default:  | |
| Indicates whether debugging is enabled in the Cisco Catalyst Center SDK. Choices: 
 | |
| The hostname of the Cisco Catalyst Center. | |
| Flag to enable/disable playbook execution logging. When true and dnac_log_file_path is provided, - Create the log file at the execution location with the specified name. When true and dnac_log_file_path is not provided, - Create the log file at the execution location with the name ‘dnac.log’. When false, - Logging is disabled. If the log file doesn’t exist, - It is created in append or write mode based on the “dnac_log_append” flag. If the log file exists, - It is overwritten or appended based on the “dnac_log_append” flag. Choices: 
 | |
| Determines the mode of the file. Set to True for ‘append’ mode. Set to False for ‘write’ mode. Choices: 
 | |
| Governs logging. Logs are recorded if dnac_log is True. If path is not specified, - When ‘dnac_log_append’ is True, ‘dnac.log’ is generated in the current Ansible directory; logs are appended. - When ‘dnac_log_append’ is False, ‘dnac.log’ is generated; logs are overwritten. If path is specified, - When ‘dnac_log_append’ is True, the file opens in append mode. - When ‘dnac_log_append’ is False, the file opens in write (w) mode. - In shared file scenarios, without append mode, content is overwritten after each module execution. - For a shared log file, set append to False for the 1st module (to overwrite); for subsequent modules, set append to True. Default:  | |
| Sets the threshold for log level. Messages with a level equal to or higher than this will be logged. Levels are listed in order of severity [CRITICAL, ERROR, WARNING, INFO, DEBUG]. CRITICAL indicates serious errors halting the program. Displays only CRITICAL messages. ERROR indicates problems preventing a function. Displays ERROR and CRITICAL messages. WARNING indicates potential future issues. Displays WARNING, ERROR, CRITICAL messages. INFO tracks normal operation. Displays INFO, WARNING, ERROR, CRITICAL messages. DEBUG provides detailed diagnostic info. Displays all log messages. Default:  | |
| The password for authentication at the Cisco Catalyst Center. | |
| Specifies the port number associated with the Cisco Catalyst Center. Default:  | |
| Specifies the interval in seconds between successive calls to the API to retrieve task details. Default:  | |
| The username for authentication at the Cisco Catalyst Center. Default:  | |
| Flag to enable or disable SSL certificate verification. Choices: 
 | |
| Specifies the version of the Cisco Catalyst Center that the SDK should use. Default:  | |
| The state of Cisco Catalyst Center after module completion. Choices: 
 | |
| Flag for Cisco Catalyst Center SDK to enable the validation of request bodies against a JSON schema. Choices: 
 | 
Notes
Note
- SDK Method used are network_settings.NetworkSettings.create_global_pool, network_settings.NetworkSettings.delete_global_ip_pool, network_settings.NetworkSettings.update_global_pool, network_settings.NetworkSettings.release_reserve_ip_subpool, network_settings.NetworkSettings.reserve_ip_subpool, network_settings.NetworkSettings.update_reserve_ip_subpool, network_settings.NetworkSettings.update_network_v2, network_settings.NetworkSettings.retrieves_global_ip_address_pools, network_settings.NetworkSettings.retrieves_ip_address_subpools, network_settings.NetworkSettings.create_a_global_ip_address_pool, network_settings.NetworkSettings.reserve_create_ip_address_subpools, network_settings.NetworkSettings.delete_a_global_ip_address_pool, network_settings.NetworkSettings.release_an_ip_address_subpool, network_settings.NetworkSettings.updates_a_global_ip_address_pool, network_settings.NetworkSettings.updates_an_ip_address_subpool, network_settings.NetworkSettings.get_device_controllability_settings, network_settings.NetworkSettings.update_device_controllability_settings 
- Paths used are post /dna/intent/api/v1/global-pool, delete /dna/intent/api/v1/global-pool/{id}, put /dna/intent/api/v1/global-pool, post /dna/intent/api/v1/reserve-ip-subpool/{siteId}, delete /dna/intent/api/v1/reserve-ip-subpool/{id}, put /dna/intent/api/v1/reserve-ip-subpool/{siteId}, put /dna/intent/api/v2/network/{siteId}, GET /intent/api/v1/ipam/globalIpAddressPools GET /intent/api/v1/ipam/siteIpAddressPools POST /intent/api/v1/ipam/globalIpAddressPools POST /intent/api/v1/ipam/siteIpAddressPools PUT /intent/api/v1/ipam/globalIpAddressPools/{id} PUT /intent/api/v1/ipam/siteIpAddressPools/{id} DELETE /intent/api/v1/ipam/globalIpAddressPools/{id} DELETE /intent/api/v1/ipam/siteIpAddressPools/{id} GET /networkDevices/deviceControllability/settings PUT /dna/intent/api/v1/networkDevices/deviceControllability/settings 
- Does not support - check_mode
- The plugin runs on the control node and does not use any ansible connection plugins instead embedded connection manager from Cisco Catalyst Center SDK 
- The parameters starting with dnac_ are used by the Cisco Catalyst Center Python SDK to establish the connection 
Examples
---
- name: Create global pool
  cisco.dnac.network_settings_workflow_manager:
    dnac_host: "{{dnac_host}}"
    dnac_username: "{{dnac_username}}"
    dnac_password: "{{dnac_password}}"
    dnac_verify: "{{dnac_verify}}"
    dnac_port: "{{dnac_port}}"
    dnac_version: "{{dnac_version}}"
    dnac_debug: "{{dnac_debug}}"
    dnac_log: true
    dnac_log_level: "{{ dnac_log_level }}"
    state: merged
    config_verify: true
    config:
      - global_pool_details:
          settings:
            ip_pool:
              - name: string
                pool_type: Generic
                ip_address_space: string
                cidr: string
                gateway: string
                dhcp_server_ips: list
                dns_server_ips: list
- name: Create reserve an ip pool
  cisco.dnac.network_settings_workflow_manager:
    dnac_host: "{{dnac_host}}"
    dnac_username: "{{dnac_username}}"
    dnac_password: "{{dnac_password}}"
    dnac_verify: "{{dnac_verify}}"
    dnac_port: "{{dnac_port}}"
    dnac_version: "{{dnac_version}}"
    dnac_debug: "{{dnac_debug}}"
    dnac_log: true
    dnac_log_level: "{{ dnac_log_level }}"
    state: merged
    config_verify: true
    config:
      - reserve_pool_details:
          - site_name: string
            name: string
            pool_type: LAN
            ipv6_address_space: true
            ipv4_global_pool: string
            ipv4_prefix: true
            ipv4_prefix_length: 9
            ipv4_subnet: string
            ipv6_prefix: true
            ipv6_prefix_length: 64
            ipv6_global_pool: string
            ipv6_subnet: string
            slaac_support: true
- name: Create reserve an ip pool using global pool
    name
  cisco.dnac.network_settings_workflow_manager:
    dnac_host: "{{dnac_host}}"
    dnac_username: "{{dnac_username}}"
    dnac_password: "{{dnac_password}}"
    dnac_verify: "{{dnac_verify}}"
    dnac_port: "{{dnac_port}}"
    dnac_version: "{{dnac_version}}"
    dnac_debug: "{{dnac_debug}}"
    dnac_log: true
    dnac_log_level: "{{ dnac_log_level }}"
    state: merged
    config_verify: true
    config:
      - reserve_pool_details:
          - name: string
            site_name: string
            pool_type: LAN
            ipv6_address_space: true
            ipv4_global_pool_name: string
            ipv4_prefix: true
            ipv4_prefix_length: 9
            ipv4_subnet: string
            ipv6_prefix: true
            ipv6_prefix_length: 64
            ipv6_global_pool_name: string
            ipv6_subnet: string
            slaac_support: true
- name: Delete reserved pool
  cisco.dnac.network_settings_workflow_manager:
    dnac_host: "{{dnac_host}}"
    dnac_username: "{{dnac_username}}"
    dnac_password: "{{dnac_password}}"
    dnac_verify: "{{dnac_verify}}"
    dnac_port: "{{dnac_port}}"
    dnac_version: "{{dnac_version}}"
    dnac_debug: "{{dnac_debug}}"
    dnac_log: true
    dnac_log_level: "{{ dnac_log_level }}"
    state: deleted
    config_verify: true
    config:
      - reserve_pool_details:
          - site_name: string
            name: string
- name: Delete Global Pool
  cisco.dnac.network_settings_workflow_manager:
    dnac_host: "{{ dnac_host }}"
    dnac_port: "{{ dnac_port }}"
    dnac_username: "{{ dnac_username }}"
    dnac_password: "{{ dnac_password }}"
    dnac_verify: "{{ dnac_verify }}"
    dnac_debug: "{{ dnac_debug }}"
    dnac_version: "{{ dnac_version }}"
    dnac_log_level: "{{ dnac_log_level }}"
    dnac_log: true
    state: deleted
    config_verify: true
    config:
      - global_pool_details:
          settings:
            ip_pool:
              - name: string
- name: Manage the network functions
  cisco.dnac.network_settings_workflow_manager:
    dnac_host: "{{dnac_host}}"
    dnac_username: "{{dnac_username}}"
    dnac_password: "{{dnac_password}}"
    dnac_verify: "{{dnac_verify}}"
    dnac_port: "{{dnac_port}}"
    dnac_version: "{{dnac_version}}"
    dnac_debug: "{{dnac_debug}}"
    dnac_log: true
    dnac_log_level: "{{ dnac_log_level }}"
    state: merged
    config_verify: true
    config:
      - network_management_details:
          - site_name: string
            settings:
              dhcp_server: list
              dns_server:
                domain_name: string
                primary_ip_address: string
                secondary_ip_address: string
              ntp_server: list
              timezone: string
              message_of_the_day:
                banner_message: string
                retain_existing_banner: bool
              netflow_collector:
                ip_address: string
                port: 443
              snmp_server:
                configure_dnac_ip: true
                ip_addresses: list
              syslog_server:
                configure_dnac_ip: true
                ip_addresses: list
- name: Adding the network_aaa and client_and_endpoint_aaa
    AAA server
  cisco.dnac.network_settings_workflow_manager:
    dnac_host: "{{dnac_host}}"
    dnac_username: "{{dnac_username}}"
    dnac_password: "{{dnac_password}}"
    dnac_verify: "{{dnac_verify}}"
    dnac_port: "{{dnac_port}}"
    dnac_version: "{{dnac_version}}"
    dnac_debug: "{{dnac_debug}}"
    dnac_log: true
    dnac_log_level: "{{ dnac_log_level }}"
    state: merged
    config_verify: true
    config:
      - network_management_details:
          - site_name: string
            settings:
              network_aaa:
                server_type: AAA
                primary_server_address: string
                secondary_server_address: string
                protocol: string
              client_and_endpoint_aaa:
                server_type: AAA
                primary_server_address: string
                secondary_server_address: string
                protocol: string
- name: Adding the network_aaa and client_and_endpoint_aaa
    ISE server
  cisco.dnac.network_settings_workflow_manager:
    dnac_host: "{{ dnac_host }}"
    dnac_username: "{{ dnac_username }}"
    dnac_password: "{{ dnac_password }}"
    dnac_verify: "{{ dnac_verify }}"
    dnac_port: "{{ dnac_port }}"
    dnac_version: "{{ dnac_version }}"
    dnac_debug: "{{ dnac_debug }}"
    dnac_log: true
    dnac_log_level: "{{ dnac_log_level }}"
    state: merged
    config_verify: true
    config:
      - network_management_details:
          - site_name: string
            settings:
              network_aaa:
                server_type: ISE
                pan_address: string
                primary_server_address: string
                protocol: string
              client_and_endpoint_aaa:
                server_type: ISE
                pan_address: string
                primary_server_address: string
                protocol: string
- name: Adding device_controllability details
  cisco.dnac.network_settings_workflow_manager:
    dnac_host: "{{ dnac_host }}"
    dnac_username: "{{ dnac_username }}"
    dnac_password: "{{ dnac_password }}"
    dnac_verify: "{{ dnac_verify }}"
    dnac_port: "{{ dnac_port }}"
    dnac_version: "{{ dnac_version }}"
    dnac_debug: "{{ dnac_debug }}"
    dnac_log: true
    dnac_log_level: "{{ dnac_log_level }}"
    state: merged
    config_verify: true
    config:
      - device_controllability_details:
          device_controllability: true
          autocorrect_telemetry_config: true
Return Values
Common return values are documented here, the following are the fields unique to this module:
| Key | Description | 
|---|---|
| A dictionary or list with the response returned by the Cisco Catalyst Center Python SDK Returned: always Sample:  | |
| A dictionary or list with the response returned by the Cisco Catalyst Center Python SDK Returned: always Sample:  | |
| A dictionary or list with the response returned by the Cisco Catalyst Center Python SDK Returned: always Sample:  | 
