From fda5712a0d45ae0d0f499beca7f613b6b64e417b Mon Sep 17 00:00:00 2001 From: akinross Date: Mon, 11 Nov 2024 09:59:44 +0100 Subject: [PATCH 1/5] [docs] Remove reference in documentation to encap_mode in the encap variable description of aci_epg_to_domain module --- plugins/modules/aci_epg_to_domain.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/modules/aci_epg_to_domain.py b/plugins/modules/aci_epg_to_domain.py index 1b82f9361..f10b1e7bf 100644 --- a/plugins/modules/aci_epg_to_domain.py +++ b/plugins/modules/aci_epg_to_domain.py @@ -48,7 +48,7 @@ aliases: [ type ] encap: description: - - The VLAN encapsulation for the EPG when binding a VMM Domain with static C(encap_mode). + - The VLAN encapsulation for the EPG when binding a VMM Domain in static VLAN mode. - This acts as the secondary encap when using useg. - Accepted values range between C(1) and C(4096). type: int From a5380c55b8b77cc1b69205eb00ddb02def76f587 Mon Sep 17 00:00:00 2001 From: akinross Date: Mon, 11 Nov 2024 10:04:50 +0100 Subject: [PATCH 2/5] [docs] Add comment to describe UI behaviour of VLAN mode when encap is set in aci_epg_to_domain module --- plugins/modules/aci_epg_to_domain.py | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/modules/aci_epg_to_domain.py b/plugins/modules/aci_epg_to_domain.py index f10b1e7bf..611b1d66d 100644 --- a/plugins/modules/aci_epg_to_domain.py +++ b/plugins/modules/aci_epg_to_domain.py @@ -49,6 +49,7 @@ encap: description: - The VLAN encapsulation for the EPG when binding a VMM Domain in static VLAN mode. + - The VLAN mode in UI is set to static when O(encap) is not set. - This acts as the secondary encap when using useg. - Accepted values range between C(1) and C(4096). type: int From df2c3465ea8350d325745b131b65cb777073273b Mon Sep 17 00:00:00 2001 From: samitab Date: Tue, 19 Nov 2024 12:13:32 +1000 Subject: [PATCH 3/5] [minor_change] Added support for Ansible 2.18 and dropped support for 2.15. - Also changed supported Python version from 3.10 to 3.11 --- .github/workflows/ansible-test.yml | 12 ++++++------ README.md | 4 ++-- meta/runtime.yml | 2 +- 3 files changed, 9 insertions(+), 9 deletions(-) diff --git a/.github/workflows/ansible-test.yml b/.github/workflows/ansible-test.yml index a58fdd1d9..2eb0b5498 100644 --- a/.github/workflows/ansible-test.yml +++ b/.github/workflows/ansible-test.yml @@ -7,7 +7,7 @@ on: # * is a special character in YAML so you have to quote this string - cron: '0 8 * * *' env: - python_version: '3.10' + python_version: '3.11' jobs: build: name: Build collection @@ -15,7 +15,7 @@ jobs: strategy: fail-fast: false matrix: - ansible: [v2.15.11, v2.16.6, stable-2.16, stable-2.17] + ansible: [v2.16.6, stable-2.16, stable-2.17, stable-2.18] steps: - name: Check out code uses: actions/checkout@v4 @@ -62,7 +62,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - ansible: [stable-2.17] + ansible: [stable-2.18] steps: - name: Set up Python ${{ env.python_version }} uses: actions/setup-python@v5 @@ -116,7 +116,7 @@ jobs: strategy: fail-fast: false matrix: - ansible: [v2.15.11, v2.16.6, stable-2.16, stable-2.17] + ansible: [v2.16.6, stable-2.16, stable-2.17, stable-2.18] steps: - name: Set up Python ${{ env.python_version }} uses: actions/setup-python@v5 @@ -158,7 +158,7 @@ jobs: strategy: fail-fast: false matrix: - ansible: [v2.15.11, v2.16.6, stable-2.16, stable-2.17] + ansible: [v2.16.6, stable-2.16, stable-2.17, stable-2.18] steps: - name: Set up Python ${{ env.python_version }} uses: actions/setup-python@v5 @@ -200,7 +200,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - ansible: [stable-2.17] + ansible: [stable-2.18] env: MUTEX_URL: https://8v7s765ibh.execute-api.us-west-1.amazonaws.com steps: diff --git a/README.md b/README.md index ec82fb23f..add546ea7 100644 --- a/README.md +++ b/README.md @@ -8,8 +8,8 @@ See the [cisco.aci collection index](https://galaxy.ansible.com/ui/repo/publishe ## Requirements -- Ansible v2.15 or newer -- Python v3.10 or newer +- Ansible v2.16 or newer +- Python v3.11 or newer Follow the [Installing Ansible](https://docs.ansible.com/ansible/latest/installation_guide/intro_installation.html) guide for detailed instructions. diff --git a/meta/runtime.yml b/meta/runtime.yml index 9ecf221ac..8c6aac980 100644 --- a/meta/runtime.yml +++ b/meta/runtime.yml @@ -1,5 +1,5 @@ --- -requires_ansible: '>=2.15.0' +requires_ansible: '>=2.16.0' action_groups: all: - aci_aaa_certificate_authority From de33e9b4e0fac7d716aaa1d2fa1fc4581d2d0ded Mon Sep 17 00:00:00 2001 From: samitab Date: Tue, 19 Nov 2024 12:30:21 +1000 Subject: [PATCH 4/5] [ignore] Fix 2.18 sanity issues --- plugins/modules/aci_cloud_subnet.py | 5 +++-- plugins/modules/aci_interface_description.py | 1 + 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/plugins/modules/aci_cloud_subnet.py b/plugins/modules/aci_cloud_subnet.py index bfdad0a33..4eb03d0d1 100644 --- a/plugins/modules/aci_cloud_subnet.py +++ b/plugins/modules/aci_cloud_subnet.py @@ -28,6 +28,7 @@ description: - The name of the Cloud Subnet. type: str + aliases: [subnet] description: description: - Description of the Cloud Subnet. @@ -36,7 +37,7 @@ description: - Ip address of the Cloud Subnet. type: str - aliases: [subnet] + aliases: [ip] name_alias: description: - An alias for the name of the current object. This relates to the nameAlias field in ACI and is used to rename object without changing the DN. @@ -255,7 +256,7 @@ def main(): argument_spec.update( name=dict(type="str", aliases=["subnet"]), description=dict(type="str"), - address=dict(type="str"), + address=dict(type="str", aliases=["ip"]), name_alias=dict(type="str"), vnet_gateway=dict(type="bool", default=False), tenant=dict(type="str", required=True), diff --git a/plugins/modules/aci_interface_description.py b/plugins/modules/aci_interface_description.py index 387acd54a..97471ed98 100644 --- a/plugins/modules/aci_interface_description.py +++ b/plugins/modules/aci_interface_description.py @@ -289,6 +289,7 @@ def main(): class_name = "infraSHPathS" children = ["infraRsSHPathAtt"] rn = None + child_configs = None if node_id and interface: if fex_id: From 7272ad675594368ebde34e23e5b4d5020c3cb583 Mon Sep 17 00:00:00 2001 From: samitab Date: Tue, 19 Nov 2024 13:53:06 +1000 Subject: [PATCH 5/5] [bug_fix] Fixed seealso module references to include FQCN. --- plugins/modules/aci_interface_policy_hsrp.py | 2 +- plugins/modules/aci_l2out_logical_interface_path.py | 8 ++++---- .../modules/aci_l2out_logical_interface_profile.py | 8 ++++---- plugins/modules/aci_l2out_logical_node_profile.py | 8 ++++---- plugins/modules/aci_l3out_bgp_peer.py | 4 ++-- plugins/modules/aci_l3out_hsrp_group.py | 10 +++++----- plugins/modules/aci_l3out_hsrp_interface_profile.py | 10 +++++----- plugins/modules/aci_l3out_hsrp_secondary_vip.py | 12 ++++++------ plugins/modules/aci_l3out_interface.py | 8 ++++---- plugins/modules/aci_l3out_interface_secondary_ip.py | 10 ++++------ plugins/modules/aci_l3out_logical_node.py | 4 ++-- plugins/modules/aci_l3out_logical_node_profile.py | 2 +- plugins/modules/aci_l3out_static_routes_nexthop.py | 8 ++++---- 13 files changed, 46 insertions(+), 48 deletions(-) diff --git a/plugins/modules/aci_interface_policy_hsrp.py b/plugins/modules/aci_interface_policy_hsrp.py index c94b5af42..806b53d5a 100644 --- a/plugins/modules/aci_interface_policy_hsrp.py +++ b/plugins/modules/aci_interface_policy_hsrp.py @@ -64,7 +64,7 @@ - The C(tenant) must exist before using this module in your playbook. The M(cisco.aci.aci_tenant) can be used for this. seealso: -- module: aci_tenant +- module: cisco.aci.aci_tenant - name: APIC Management Information Model reference description: More information about the internal APIC class B(hsrp:IfPol). link: https://developer.cisco.com/docs/apic-mim-ref/ diff --git a/plugins/modules/aci_l2out_logical_interface_path.py b/plugins/modules/aci_l2out_logical_interface_path.py index 0d8130139..bc93b6205 100644 --- a/plugins/modules/aci_l2out_logical_interface_path.py +++ b/plugins/modules/aci_l2out_logical_interface_path.py @@ -74,10 +74,10 @@ - cisco.aci.annotation seealso: -- module: aci_l2out -- module: aci_l2out_logical_node_profile -- module: aci_l2out_logical_interface_profile -- module: aci_l2out_extepg +- module: cisco.aci.aci_l2out +- module: cisco.aci.aci_l2out_logical_node_profile +- module: cisco.aci.aci_l2out_logical_interface_profile +- module: cisco.aci.aci_l2out_extepg - name: APIC Management Information Model reference description: More information about the internal APIC class B(l2ext:RsPathL2OutAtt). link: https://developer.cisco.com/docs/apic-mim-ref/ diff --git a/plugins/modules/aci_l2out_logical_interface_profile.py b/plugins/modules/aci_l2out_logical_interface_profile.py index c1d0b3d61..2da34b69e 100644 --- a/plugins/modules/aci_l2out_logical_interface_profile.py +++ b/plugins/modules/aci_l2out_logical_interface_profile.py @@ -50,10 +50,10 @@ - cisco.aci.owner seealso: -- module: aci_l2out -- module: aci_l2out_logical_node_profile -- module: aci_l2out_logical_interface_path -- module: aci_l2out_extepg +- module: cisco.aci.aci_l2out +- module: cisco.aci.aci_l2out_logical_node_profile +- module: cisco.aci.aci_l2out_logical_interface_path +- module: cisco.aci.aci_l2out_extepg - name: APIC Management Information Model reference description: More information about the internal APIC class B(l2ext:LIfP). link: https://developer.cisco.com/docs/apic-mim-ref/ diff --git a/plugins/modules/aci_l2out_logical_node_profile.py b/plugins/modules/aci_l2out_logical_node_profile.py index 6fa04db01..687c8b5ae 100644 --- a/plugins/modules/aci_l2out_logical_node_profile.py +++ b/plugins/modules/aci_l2out_logical_node_profile.py @@ -44,10 +44,10 @@ - cisco.aci.owner seealso: -- module: aci_l2out -- module: aci_l2out_logical_interface_profile -- module: aci_l2out_logical_interface_path -- module: aci_l2out_extepg +- module: cisco.aci.aci_l2out +- module: cisco.aci.aci_l2out_logical_interface_profile +- module: cisco.aci.aci_l2out_logical_interface_path +- module: cisco.aci.aci_l2out_extepg - name: APIC Management Information Model reference description: More information about the internal APIC class B(l2ext:LNodeP). link: https://developer.cisco.com/docs/apic-mim-ref/ diff --git a/plugins/modules/aci_l3out_bgp_peer.py b/plugins/modules/aci_l3out_bgp_peer.py index c803daba2..9bca6ae92 100644 --- a/plugins/modules/aci_l3out_bgp_peer.py +++ b/plugins/modules/aci_l3out_bgp_peer.py @@ -186,8 +186,8 @@ - cisco.aci.annotation seealso: -- module: aci_l3out -- module: aci_l3out_logical_node_profile +- module: cisco.aci.aci_l3out +- module: cisco.aci.aci_l3out_logical_node_profile - name: APIC Management Information Model reference description: More information about the internal APIC classes B(bgp:peerP) and B(bgp:InfraPeerP) link: https://developer.cisco.com/docs/apic-mim-ref/ diff --git a/plugins/modules/aci_l3out_hsrp_group.py b/plugins/modules/aci_l3out_hsrp_group.py index c6f7316b2..0194923d8 100644 --- a/plugins/modules/aci_l3out_hsrp_group.py +++ b/plugins/modules/aci_l3out_hsrp_group.py @@ -94,11 +94,11 @@ your playbook. The M(cisco.aci.aci_tenant), M(cisco.aci.aci_l3out), M(cisco.aci.aci_l3out_logical_node_profile), M(cisco.aci.aci_l3out_logical_interface_profile) and M(cisco.aci.aci_l3out_hsrp_interface_profile) can be used for this. seealso: -- module: aci_tenant -- module: aci_l3out -- module: aci_l3out_logical_node_profile -- module: aci_l3out_logical_interface_profile -- module: aci_l3out_hsrp_interface_profile +- module: cisco.aci.aci_tenant +- module: cisco.aci.aci_l3out +- module: cisco.aci.aci_l3out_logical_node_profile +- module: cisco.aci.aci_l3out_logical_interface_profile +- module: cisco.aci.aci_l3out_hsrp_interface_profile - name: APIC Management Information Model reference description: More information about the internal APIC class B(hsrp:IfP). link: https://developer.cisco.com/docs/apic-mim-ref/ diff --git a/plugins/modules/aci_l3out_hsrp_interface_profile.py b/plugins/modules/aci_l3out_hsrp_interface_profile.py index 634a7f2f5..8ed1684dd 100644 --- a/plugins/modules/aci_l3out_hsrp_interface_profile.py +++ b/plugins/modules/aci_l3out_hsrp_interface_profile.py @@ -66,11 +66,11 @@ - If C(hsrp_policy) is used, it must exist before using this module in your playbook. The M(cisco.aci.aci_interface_policy_hsrp) can be used for this. seealso: -- module: aci_tenant -- module: aci_l3out -- module: aci_l3out_logical_node_profile -- module: aci_l3out_logical_interface_profile -- module: aci_interface_policy_hsrp +- module: cisco.aci.aci_tenant +- module: cisco.aci.aci_l3out +- module: cisco.aci.aci_l3out_logical_node_profile +- module: cisco.aci.aci_l3out_logical_interface_profile +- module: cisco.aci.aci_interface_policy_hsrp - name: APIC Management Information Model reference description: More information about the internal APIC class B(hsrp:IfP). link: https://developer.cisco.com/docs/apic-mim-ref/ diff --git a/plugins/modules/aci_l3out_hsrp_secondary_vip.py b/plugins/modules/aci_l3out_hsrp_secondary_vip.py index f4fd4b1d3..55d1455bf 100644 --- a/plugins/modules/aci_l3out_hsrp_secondary_vip.py +++ b/plugins/modules/aci_l3out_hsrp_secondary_vip.py @@ -65,12 +65,12 @@ M(cisco.aci.aci_l3out_logical_interface_profile), M(cisco.aci.aci_l3out_hsrp_interface_profile) and M(cisco.aci.aci_l3out_hsrp_group) can be used for this. seealso: -- module: aci_tenant -- module: aci_l3out -- module: aci_l3out_logical_node_profile -- module: aci_l3out_logical_interface_profile -- module: aci_l3out_hsrp_interface_profile -- module: aci_l3out_hsrp_group +- module: cisco.aci.aci_tenant +- module: cisco.aci.aci_l3out +- module: cisco.aci.aci_l3out_logical_node_profile +- module: cisco.aci.aci_l3out_logical_interface_profile +- module: cisco.aci.aci_l3out_hsrp_interface_profile +- module: cisco.aci.aci_l3out_hsrp_group - name: APIC Management Information Model reference description: More information about the internal APIC class B(hsrp:SecVip). link: https://developer.cisco.com/docs/apic-mim-ref/ diff --git a/plugins/modules/aci_l3out_interface.py b/plugins/modules/aci_l3out_interface.py index 6a8de791f..4d09b7eec 100644 --- a/plugins/modules/aci_l3out_interface.py +++ b/plugins/modules/aci_l3out_interface.py @@ -137,10 +137,10 @@ The M(cisco.aci.aci_tenant), M(cisco.aci.aci_l3out), M(cisco.aci.aci_l3out_logical_node_profile) and M(cisco.aci.aci_l3out_logical_interface_profile) can be used for this. seealso: -- module: aci_tenant -- module: aci_l3out -- module: aci_l3out_logical_node_profile -- module: aci_l3out_logical_interface_profile +- module: cisco.aci.aci_tenant +- module: cisco.aci.aci_l3out +- module: cisco.aci.aci_l3out_logical_node_profile +- module: cisco.aci.aci_l3out_logical_interface_profile - name: APIC Management Information Model reference description: More information about the internal APIC class B(l3ext:RsPathL3OutAtt) link: https://developer.cisco.com/docs/apic-mim-ref/ diff --git a/plugins/modules/aci_l3out_interface_secondary_ip.py b/plugins/modules/aci_l3out_interface_secondary_ip.py index e127e1ff6..39a2cf681 100644 --- a/plugins/modules/aci_l3out_interface_secondary_ip.py +++ b/plugins/modules/aci_l3out_interface_secondary_ip.py @@ -81,13 +81,11 @@ - cisco.aci.aci - cisco.aci.annotation -notes: -- This is a test seealso: -- module: aci_l3out -- module: aci_l3out_logical_node_profile -- module: aci_l3out_logical_interface_profile -- module: aci_l3out_logical_interface +- module: cisco.aci.aci_l3out +- module: cisco.aci.aci_l3out_logical_node_profile +- module: cisco.aci.aci_l3out_logical_interface_profile +- module: cisco.aci.aci_l3out_logical_interface - name: APIC Management Information Model reference description: More information about the internal APIC class B(l3ext:Ip) link: https://developer.cisco.com/docs/apic-mim-ref/ diff --git a/plugins/modules/aci_l3out_logical_node.py b/plugins/modules/aci_l3out_logical_node.py index a3619238a..eb4705c09 100644 --- a/plugins/modules/aci_l3out_logical_node.py +++ b/plugins/modules/aci_l3out_logical_node.py @@ -80,8 +80,8 @@ - cisco.aci.annotation seealso: -- module: aci_l3out -- module: aci_l3out_logical_node_profile +- module: cisco.aci.aci_l3out +- module: cisco.aci.aci_l3out_logical_node_profile - name: APIC Management Information Model reference description: More information about the internal APIC classes B(l3ext:RsNodeL3OutAtt) link: https://developer.cisco.com/docs/apic-mim-ref/ diff --git a/plugins/modules/aci_l3out_logical_node_profile.py b/plugins/modules/aci_l3out_logical_node_profile.py index ac6b87ebe..873f85d9b 100644 --- a/plugins/modules/aci_l3out_logical_node_profile.py +++ b/plugins/modules/aci_l3out_logical_node_profile.py @@ -67,7 +67,7 @@ - cisco.aci.owner seealso: -- module: aci_l3out +- module: cisco.aci.aci_l3out - name: APIC Management Information Model reference description: More information about the internal APIC classes B(l3ext:LNodeP). link: https://developer.cisco.com/docs/apic-mim-ref/ diff --git a/plugins/modules/aci_l3out_static_routes_nexthop.py b/plugins/modules/aci_l3out_static_routes_nexthop.py index b475bba5c..d8017004f 100644 --- a/plugins/modules/aci_l3out_static_routes_nexthop.py +++ b/plugins/modules/aci_l3out_static_routes_nexthop.py @@ -60,10 +60,10 @@ - cisco.aci.annotation seealso: -- module: aci_l3out -- module: aci_l3out_logical_node_profile -- module: aci_l3out_logical_node_profile_to_node -- module: aci_l3out_static_routes +- module: cisco.aci.aci_l3out +- module: cisco.aci.aci_l3out_logical_node_profile +- module: cisco.aci.aci_l3out_logical_node_profile_to_node +- module: cisco.aci.aci_l3out_static_routes - name: APIC Management Information Model reference description: More information about the internal APIC classes B(ip:NexthopP) link: https://developer.cisco.com/docs/apic-mim-ref/