cisco.dnac.network_device_v1 module -- Resource module for Network Device V1
Note
This module is part of the cisco.dnac collection (version 6.27.0).
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_device_v1
.
New in cisco.dnac 3.1.0
Synopsis
Manage operations create, update and delete of the resource Network Device V1.
Adds the device with given credential.
This API allows any network device that is not currently provisioned to be removed from the inventory. Important Devices currently provisioned cannot be deleted. To delete a provisioned device, the device must be first deprovisioned.
Update the credentials, management IP address of a given device or a set of devices in Catalyst Center and trigger an inventory sync.
Note
This module has a corresponding action plugin.
Requirements
The below requirements are needed on the host that executes this module.
dnacentersdk >= 2.4.9
python >= 3.5
Parameters
Parameter |
Comments |
---|---|
CleanConfig query parameter. Selecting the clean up configuration option will attempt to remove device settings that were configured during the addition of the device to the inventory and site assignment. Please note that this operation is different from deprovisioning. It does not remove configurations that were pushed during device provisioning. Choices: |
|
CLI transport. Supported values telnet, ssh. Required if type is NETWORK_DEVICE. |
|
Compute Device or not. Options are true / false. Choices: |
|
Flag for Cisco DNA Center SDK to enable debugging. Choices: |
|
The Cisco DNA Center hostname. |
|
The Cisco DNA Center password to authenticate. |
|
The Cisco DNA Center port. Default: :ansible-option-default:`443` |
|
The Cisco DNA Center username to authenticate. Default: :ansible-option-default:`"admin"` |
|
Flag to enable or disable SSL certificate verification. Choices: |
|
Informs the SDK which version of Cisco DNA Center to use. Default: :ansible-option-default:`"2.3.7.6"` |
|
CLI enable password of the device. Required if device is configured to use enable password. |
|
This field holds that info as whether to add device with canned data or not. Supported values DISCOVER_WITH_CANNED_DATA. |
|
HTTP password of the device / API key for Meraki Dashboard. Required if type is MERAKI_DASHBOARD or COMPUTE_DEVICE. |
|
HTTP port of the device. Required if type is COMPUTE_DEVICE. |
|
Flag to select HTTP / HTTPS protocol. Options are true / false. True for HTTPS and false for HTTP. Default is true. Choices: |
|
HTTP Username of the device. Required if type is COMPUTE_DEVICE. |
|
Id path parameter. Device ID. |
|
IP Address of the device. Required if type is NETWORK_DEVICE, COMPUTE_DEVICE or THIRD_PARTY_DEVICE. |
|
Selected Meraki organization for which the devices needs to be imported. Required if type is MERAKI_DASHBOARD. |
|
Netconf Port of the device. CliTransport must be 'ssh' if netconf is provided. Netconf port is required for eWLC. |
|
CLI Password of the device. Required if type is NETWORK_DEVICE. |
|
Serial Number of the Device. Required if extendedDiscoveryInfo is 'DISCOVER_WITH_CANNED_DATA'. |
|
SNMPv3 auth passphrase of the device. Required if snmpMode is authNoPriv or authPriv. |
|
SNMPv3 auth protocol. Supported values sha, md5. Required if snmpMode is authNoPriv or authPriv. |
|
SNMPv3 mode. Supported values noAuthnoPriv, authNoPriv, authPriv. Required if snmpVersion is v3. |
|
SNMPv3 priv passphrase. Required if snmpMode is authPriv. |
|
SNMPv3 priv protocol. Supported values AES128. Required if snmpMode is authPriv. |
|
SNMP retry count. Max value supported is 3. Default is Global SNMP retry (if exists) or 3. |
|
SNMP Read Community of the device. If snmpVersion is v2, at least one of snmpROCommunity and snmpRWCommunity is required. |
|
SNMP Write Community of the device. If snmpVersion is v2, at least one of snmpROCommunity and snmpRWCommunity is required. |
|
SNMP timeout in seconds. Max value supported is 300. Default is Global SNMP timeout (if exists) or 5. |
|
SNMPV3 user name of the device. Required if snmpVersion is v3. |
|
SNMP version. Values supported v2, v3. Required if type is NETWORK_DEVICE, COMPUTE_DEVICE or THIRD_PARTY_DEVICE. |
|
Type of device being added. Default is NETWORK_DEVICE. |
|
Network Device's updateMgmtIPaddressList. |
|
ExistMgmtIpAddress IP Address of the device. |
|
New IP Address to be Updated. |
|
CLI user name of the device. Required if type is NETWORK_DEVICE. |
|
Flag for Cisco DNA Center SDK to enable the validation of request bodies against a JSON schema. Choices: |
Notes
Note
SDK Method used are devices.Devices.add_device, devices.Devices.delete_device_by_id_v1, devices.Devices.sync_devices,
Paths used are post /dna/intent/api/v1/network-device, delete /dna/intent/api/v1/network-device/{id}, put /dna/intent/api/v1/network-device,
Does not support
check_mode
The plugin runs on the control node and does not use any ansible connection plugins, but instead the embedded connection manager from Cisco DNAC SDK
The parameters starting with dnac_ are used by the Cisco DNAC Python SDK to establish the connection
See Also
See also
- Cisco DNA Center documentation for Devices AddDeviceKnowYourNetworkV1
Complete reference of the AddDeviceKnowYourNetworkV1 API.
- Cisco DNA Center documentation for Devices DeleteDeviceByIdV1
Complete reference of the DeleteDeviceByIdV1 API.
- Cisco DNA Center documentation for Devices UpdateDeviceDetailsV1
Complete reference of the UpdateDeviceDetailsV1 API.
Examples
- name: Create
cisco.dnac.network_device_v1:
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}}"
state: present
cliTransport: string
computeDevice: true
enablePassword: string
extendedDiscoveryInfo: string
httpPassword: string
httpPort: string
httpSecure: true
httpUserName: string
ipAddress:
- string
merakiOrgId:
- string
netconfPort: string
password: string
serialNumber: string
snmpAuthPassphrase: string
snmpAuthProtocol: string
snmpMode: string
snmpPrivPassphrase: string
snmpPrivProtocol: string
snmpROCommunity: string
snmpRWCommunity: string
snmpRetry: 0
snmpTimeout: 0
snmpUserName: string
snmpVersion: string
type: string
userName: string
- name: Update all
cisco.dnac.network_device_v1:
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}}"
state: present
cliTransport: string
computeDevice: true
enablePassword: string
extendedDiscoveryInfo: string
httpPassword: string
httpPort: string
httpSecure: true
httpUserName: string
ipAddress:
- string
merakiOrgId:
- string
netconfPort: string
password: string
serialNumber: string
snmpAuthPassphrase: string
snmpAuthProtocol: string
snmpMode: string
snmpPrivPassphrase: string
snmpPrivProtocol: string
snmpROCommunity: string
snmpRWCommunity: string
snmpRetry: 0
snmpTimeout: 0
snmpUserName: string
snmpVersion: string
type: string
updateMgmtIPaddressList:
- existMgmtIpAddress: string
newMgmtIpAddress: string
userName: string
- name: Delete by id
cisco.dnac.network_device_v1:
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}}"
state: absent
cleanConfig: true
id: string
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 DNAC Python SDK Returned: always Sample: :ansible-rv-sample-value:`{"response": {"taskId": "string", "url": "string"}, "version": "string"}` |