summaryrefslogtreecommitdiffstats
path: root/ansible_collections/infoblox
diff options
context:
space:
mode:
Diffstat (limited to 'ansible_collections/infoblox')
-rw-r--r--ansible_collections/infoblox/nios_modules/.github/workflows/ansible-test.yml200
-rw-r--r--ansible_collections/infoblox/nios_modules/.gitignore101
-rw-r--r--ansible_collections/infoblox/nios_modules/CHANGELOG.rst251
-rw-r--r--ansible_collections/infoblox/nios_modules/CONTRIBUTING.md31
-rw-r--r--ansible_collections/infoblox/nios_modules/COPYING674
-rw-r--r--ansible_collections/infoblox/nios_modules/FILES.json1601
-rw-r--r--ansible_collections/infoblox/nios_modules/MANIFEST.json38
-rw-r--r--ansible_collections/infoblox/nios_modules/README.md209
-rw-r--r--ansible_collections/infoblox/nios_modules/changelogs/.plugin-cache.yaml131
-rw-r--r--ansible_collections/infoblox/nios_modules/changelogs/changelog.yaml200
-rw-r--r--ansible_collections/infoblox/nios_modules/changelogs/config.yaml32
-rw-r--r--ansible_collections/infoblox/nios_modules/meta/runtime.yml2
-rw-r--r--ansible_collections/infoblox/nios_modules/playbooks/create_a_record.yaml19
-rw-r--r--ansible_collections/infoblox/nios_modules/playbooks/create_cname_record.yaml19
-rw-r--r--ansible_collections/infoblox/nios_modules/playbooks/create_dns_view.yml20
-rw-r--r--ansible_collections/infoblox/nios_modules/playbooks/create_dtc_lbdn.yml29
-rw-r--r--ansible_collections/infoblox/nios_modules/playbooks/create_dtc_pool.yml25
-rw-r--r--ansible_collections/infoblox/nios_modules/playbooks/create_dtc_server.yml19
-rw-r--r--ansible_collections/infoblox/nios_modules/playbooks/create_mx_record.yaml20
-rw-r--r--ansible_collections/infoblox/nios_modules/playbooks/create_network.yml23
-rw-r--r--ansible_collections/infoblox/nios_modules/playbooks/create_network_view.yml19
-rw-r--r--ansible_collections/infoblox/nios_modules/playbooks/create_txt_record.yaml19
-rw-r--r--ansible_collections/infoblox/nios_modules/playbooks/create_zone.yml21
-rw-r--r--ansible_collections/infoblox/nios_modules/playbooks/delete_cname_record.yaml18
-rw-r--r--ansible_collections/infoblox/nios_modules/playbooks/delete_dnsview.yml17
-rw-r--r--ansible_collections/infoblox/nios_modules/playbooks/delete_mx_record.yaml19
-rw-r--r--ansible_collections/infoblox/nios_modules/playbooks/delete_network.yml17
-rw-r--r--ansible_collections/infoblox/nios_modules/playbooks/delete_network_view.yml16
-rw-r--r--ansible_collections/infoblox/nios_modules/playbooks/delete_txt_record.yaml19
-rw-r--r--ansible_collections/infoblox/nios_modules/playbooks/delete_zone.yml17
-rw-r--r--ansible_collections/infoblox/nios_modules/playbooks/restart_services.yml15
-rw-r--r--ansible_collections/infoblox/nios_modules/playbooks/update_a_record.yml19
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/README.md31
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/doc_fragments/nios.py113
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/inventory/nios_inventory.py107
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/lookup/nios_lookup.py112
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/lookup/nios_next_ip.py115
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/lookup/nios_next_network.py118
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/module_utils/api.py701
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/module_utils/network.py19
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/modules/nios_a_record.py178
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/modules/nios_aaaa_record.py166
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/modules/nios_cname_record.py154
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/modules/nios_dns_view.py148
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/modules/nios_dtc_lbdn.py242
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/modules/nios_dtc_pool.py235
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/modules/nios_dtc_server.py144
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/modules/nios_fixed_address.py324
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/modules/nios_host_record.py373
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/modules/nios_member.py575
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/modules/nios_mx_record.py163
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/modules/nios_naptr_record.py195
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/modules/nios_network.py318
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/modules/nios_network_view.py138
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/modules/nios_nsgroup.py439
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/modules/nios_ptr_record.py164
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/modules/nios_restartservices.py144
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/modules/nios_srv_record.py175
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/modules/nios_txt_record.py139
-rw-r--r--ansible_collections/infoblox/nios_modules/plugins/modules/nios_zone.py244
-rw-r--r--ansible_collections/infoblox/nios_modules/requirements.txt1
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_a_record/aliases3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_a_record/defaults/main.yaml3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_a_record/meta/main.yaml2
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_a_record/tasks/main.yml1
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_a_record/tasks/nios_a_record_idempotence.yml77
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_aaaa_record/aliases3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_aaaa_record/defaults/main.yaml3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_aaaa_record/meta/main.yaml2
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_aaaa_record/tasks/main.yml1
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_aaaa_record/tasks/nios_aaaa_record_idempotence.yml77
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_cname_record/aliases3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_cname_record/defaults/main.yaml3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_cname_record/meta/main.yaml2
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_cname_record/tasks/main.yml1
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_cname_record/tasks/nios_cname_record_idempotence.yml77
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_dns_view/aliases3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_dns_view/defaults/main.yaml3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_dns_view/meta/main.yaml2
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_dns_view/tasks/main.yml1
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_dns_view/tasks/nios_dns_view_idempotence.yml58
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_host_record/aliases3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_host_record/defaults/main.yaml3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_host_record/meta/main.yaml2
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_host_record/tasks/main.yml1
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_host_record/tasks/nios_host_record_idempotence.yml126
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_mx_record/aliases3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_mx_record/defaults/main.yaml3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_mx_record/meta/main.yaml2
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_mx_record/tasks/main.yml1
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_mx_record/tasks/nios_mx_record_idempotence.yml84
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_naptr_record/aliases3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_naptr_record/defaults/main.yaml3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_naptr_record/meta/main.yaml2
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_naptr_record/tasks/main.yml1
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_naptr_record/tasks/nios_naptr_record_idempotence.yml91
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network/aliases3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network/defaults/main.yaml0
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network/meta/main.yaml2
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network/tasks/main.yml1
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network/tasks/nios_network_idempotence.yml80
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network_view/aliases3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network_view/defaults/main.yaml3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network_view/meta/main.yaml2
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network_view/tasks/main.yml1
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network_view/tasks/nios_network_view_idempotence.yml58
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_ptr_record/aliases3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_ptr_record/defaults/main.yaml3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_ptr_record/meta/main.yaml2
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_ptr_record/tasks/main.yml1
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_ptr_record/tasks/nios_ptr_record_idempotence.yml83
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_srv_record/aliases3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_srv_record/defaults/main.yaml3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_srv_record/meta/main.yaml2
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_srv_record/tasks/main.yml1
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_srv_record/tasks/nios_srv_record_idempotence.yml98
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_txt_record/aliases3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_txt_record/defaults/main.yaml3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_txt_record/meta/main.yaml2
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_txt_record/tasks/main.yml1
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_txt_record/tasks/nios_txt_record_idempotence.yml82
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_zone/aliases3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_zone/defaults/main.yaml3
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_zone/meta/main.yaml2
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_zone/tasks/main.yml1
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_zone/tasks/nios_zone_idempotence.yml68
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/prepare_nios_tests/tasks/main.yml1
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/integration/targets/prepare_nios_tests/tasks/prepare_nios_tests_idempotence.yml2
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/requirements.txt9
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/__init__.py0
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/compat/__init__.py0
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/compat/mock.py120
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/__init__.py0
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/module_utils/__init__.py0
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/module_utils/test_api.py255
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/__init__.py0
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/fixtures/nios_result.txt0
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_a_record.py163
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_aaaa_record.py163
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_cname_record.py137
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_dns_view.py131
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_fixed_address.py201
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_host_record.py156
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_member.py162
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_module.py88
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_mx_record.py141
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_naptr_record.py151
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_network.py248
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_network_view.py160
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_nsgroup.py130
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_ptr_record.py184
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_srv_record.py157
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_zone.py287
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/utils.py52
-rw-r--r--ansible_collections/infoblox/nios_modules/tests/unit/requirements.txt8
155 files changed, 14114 insertions, 0 deletions
diff --git a/ansible_collections/infoblox/nios_modules/.github/workflows/ansible-test.yml b/ansible_collections/infoblox/nios_modules/.github/workflows/ansible-test.yml
new file mode 100644
index 00000000..e6235107
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/.github/workflows/ansible-test.yml
@@ -0,0 +1,200 @@
+name: CI
+on:
+# Run CI against all pushes (direct commits) and Pull Requests
+ push:
+ pull_request:
+ schedule:
+ - cron: '0 2 * * 1'
+
+jobs:
+ build:
+ name: Build collection
+ runs-on: ubuntu-latest
+ strategy:
+ fail-fast: false
+ matrix:
+ ansible-version: [stable-2.10]
+ steps:
+ - name: Check out code
+ uses: actions/checkout@v2
+
+ - name: Set up Python 3.9
+ uses: actions/setup-python@v1
+ with:
+ python-version: 3.9
+
+ - name: Install ansible (${{ matrix.ansible-version }})
+ run: pip install pip install https://github.com/ansible/ansible/archive/${{ matrix.ansible-version }}.tar.gz --disable-pip-version-check
+
+ - name: Build a collection tarball
+ run: ansible-galaxy collection build --output-path "${GITHUB_WORKSPACE}/.cache/collection-tarballs"
+
+ - name: Store migrated collection artifacts
+ uses: actions/upload-artifact@v1
+ with:
+ name: collection
+ path: .cache/collection-tarballs
+
+
+###
+# Unit tests
+#
+# https://docs.ansible.com/ansible/latest/dev_guide/testing_units.html
+
+ unit:
+ name: Unit Tests
+ needs: [build]
+ runs-on: ubuntu-latest
+ strategy:
+ fail-fast: false
+ matrix:
+ python-version: [2.7, 3.8, 3.9]
+ ansible-version: [stable-2.9, stable-2.10, stable-2.11, stable-2.12, stable-2.13, devel]
+ exclude:
+ - ansible-version: devel
+ python-version: 2.7
+ - ansible-version: devel
+ python-version: 3.8
+ - ansible-version: stable-2.12
+ python-version: 2.7
+ - ansible-version: stable-2.13
+ python-version: 2.7
+ - ansible-version: stable-2.9
+ python-version: 3.9
+
+ steps:
+ - name: Set up Python ${{ matrix.python-version }}
+ uses: actions/setup-python@v1
+ with:
+ python-version: ${{ matrix.python-version }}
+
+ - name: Install ansible (${{ matrix.ansible-version }}) version
+ run: pip install https://github.com/ansible/ansible/archive/${{ matrix.ansible-version }}.tar.gz --disable-pip-version-check
+
+ - name: Download migrated collection artifacts
+ uses: actions/download-artifact@v1
+ with:
+ name: collection
+ path: .cache/collection-tarballs
+
+ - name: Setup Unit test Pre-requisites
+ run: |
+ ansible-galaxy collection install .cache/collection-tarballs/*.tar.gz
+ git clone https://github.com/ansible/ansible.git
+ cp -rf ansible/test/units/compat /home/runner/.ansible/collections/ansible_collections/infoblox/nios_modules/tests/unit/
+ cp -rf ansible/test/units/modules/utils.py /home/runner/.ansible/collections/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/
+ sed -i 's/units/ansible_collections.infoblox.nios_modules.tests.unit/' /home/runner/.ansible/collections/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/utils.py
+ if [ -f /home/runner/.ansible/collections/ansible_collections/infoblox/nios_modules/tests/unit/requirements.txt ]; then pip install -r /home/runner/.ansible/collections/ansible_collections/infoblox/nios_modules/tests/unit/requirements.txt; fi
+ - name: Run Unit tests using ansible-test
+ run: ansible-test units -v --color --python ${{ matrix.python-version }} --coverage
+ working-directory: /home/runner/.ansible/collections/ansible_collections/infoblox/nios_modules/
+
+ - name: Generate coverage report
+ run: |
+ if [ "${{ matrix.ansible-version }}" == "devel" ]; then pip install coverage==6.5.0; fi
+ ansible-test coverage xml -v --group-by command --group-by version
+ working-directory: /home/runner/.ansible/collections/ansible_collections/infoblox/nios_modules/
+
+
+###
+# Integration tests
+#
+# https://docs.ansible.com/ansible/latest/dev_guide/testing_integration.html
+
+ integration:
+ name: Integration tests
+ needs: [build]
+ runs-on: ubuntu-latest
+ strategy:
+ fail-fast: false
+ matrix:
+ python-version: [2.7, 3.8, 3.9]
+ ansible-version: [stable-2.9, stable-2.10, stable-2.11, stable-2.12, stable-2.13, devel]
+ exclude:
+ - ansible-version: stable-2.9
+ python-version: 3.9
+ steps:
+ - name: Set up Python 3.9
+ uses: actions/setup-python@v1
+ with:
+ python-version: 3.9
+
+ - name: Check out code
+ uses: actions/checkout@v2
+
+ - name: Install ansible-base (${{ matrix.ansible }})
+ run: pip install https://github.com/ansible/ansible/archive/${{ matrix.ansible-version }}.tar.gz --disable-pip-version-check
+
+ - name: Download migrated collection artifacts
+ uses: actions/download-artifact@v1
+ with:
+ name: collection
+ path: .cache/collection-tarball
+
+ - name: Install the collection tarball
+ run: ansible-galaxy collection install .cache/collection-tarball/*.tar.gz
+
+ - name: Setup Integration test Pre-requisites
+ run: |
+ sudo apt install libgirepository1.0-dev gcc libcairo2-dev pkg-config python3-dev gir1.2-gtk-3.0
+ pip install -r /home/runner/.ansible/collections/ansible_collections/infoblox/nios_modules/tests/requirements.txt
+
+ # Run the integration tests
+ - name: Run integration test
+ run: |
+ echo $ANSIBLE_NIOSSIM_CONTAINER
+ ansible-test integration -v --color --retry-on-error --continue-on-error --diff --python ${{ matrix.python-version }} --docker --coverage
+ env:
+ ANSIBLE_NIOSSIM_CONTAINER: quay.io/ansible/nios-test-container:1.4.0
+ working-directory: /home/runner/.ansible/collections/ansible_collections/infoblox/nios_modules/
+
+ # ansible-test support producing code coverage date
+ - name: Generate coverage report
+ run: ansible-test coverage xml -v --requirements --group-by command --group-by version
+ working-directory: /home/runner/.ansible/collections/ansible_collections/infoblox/nios_modules/
+
+ - uses: codecov/codecov-action@v1
+ with:
+ fail_ci_if_error: false
+
+
+###
+# Sanity tests (REQUIRED)
+#
+# https://docs.ansible.com/ansible/latest/dev_guide/testing_sanity.html
+
+ sanity:
+ name: Sanity Tests
+ runs-on: ubuntu-latest
+ needs: [build]
+ strategy:
+ fail-fast: false
+ matrix:
+ ansible-version: [stable-2.9, stable-2.10, stable-2.11, stable-2.12, stable-2.13, devel]
+
+ steps:
+ - name: Set up Python 3.9
+ uses: actions/setup-python@v1
+ with:
+ # it is just required to run that once as "ansible-test sanity" in the docker image
+ # will run on all python versions it supports.
+ python-version: 3.9
+
+ - name: Install ansible (${{ matrix.ansible-version }}) version
+ run: pip install https://github.com/ansible/ansible/archive/${{ matrix.ansible-version }}.tar.gz --disable-pip-version-check
+
+ - name: Download migrated collection artifacts
+ uses: actions/download-artifact@v1
+ with:
+ name: collection
+ path: .cache/collection-tarballs
+
+ - name: Setup Sanity test Pre-requisites
+ run: ansible-galaxy collection install .cache/collection-tarballs/*.tar.gz
+
+ # run ansible-test sanity inside of Docker.
+ # The docker container has all the pinned dependencies that are required
+ # and all python versions ansible supports.
+ - name: Run sanity tests
+ run: ansible-test sanity --docker -v --color
+ working-directory: /home/runner/.ansible/collections/ansible_collections/infoblox/nios_modules
diff --git a/ansible_collections/infoblox/nios_modules/.gitignore b/ansible_collections/infoblox/nios_modules/.gitignore
new file mode 100644
index 00000000..7bbc71c0
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/.gitignore
@@ -0,0 +1,101 @@
+# Byte-compiled / optimized / DLL files
+__pycache__/
+*.py[cod]
+*$py.class
+
+# C extensions
+*.so
+
+# Distribution / packaging
+.Python
+env/
+build/
+develop-eggs/
+dist/
+downloads/
+eggs/
+.eggs/
+lib/
+lib64/
+parts/
+sdist/
+var/
+wheels/
+*.egg-info/
+.installed.cfg
+*.egg
+
+# PyInstaller
+# Usually these files are written by a python script from a template
+# before PyInstaller builds the exe, so as to inject date/other infos into it.
+*.manifest
+*.spec
+
+# Installer logs
+pip-log.txt
+pip-delete-this-directory.txt
+
+# Unit test / coverage reports
+htmlcov/
+.tox/
+.coverage
+.coverage.*
+.cache
+nosetests.xml
+coverage.xml
+*.cover
+.hypothesis/
+
+# Translations
+*.mo
+*.pot
+
+# Django stuff:
+*.log
+local_settings.py
+
+# Flask stuff:
+instance/
+.webassets-cache
+
+# Scrapy stuff:
+.scrapy
+
+# Sphinx documentation
+docs/_build/
+
+# PyBuilder
+target/
+
+# Jupyter Notebook
+.ipynb_checkpoints
+
+# pyenv
+.python-version
+
+# celery beat schedule file
+celerybeat-schedule
+
+# SageMath parsed files
+*.sage.py
+
+# dotenv
+.env
+
+# virtualenv
+.venv
+venv/
+ENV/
+
+# Spyder project settings
+.spyderproject
+.spyproject
+
+# Rope project settings
+.ropeproject
+
+# mkdocs documentation
+/site
+
+# mypy
+.mypy_cache/
diff --git a/ansible_collections/infoblox/nios_modules/CHANGELOG.rst b/ansible_collections/infoblox/nios_modules/CHANGELOG.rst
new file mode 100644
index 00000000..1ad355cb
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/CHANGELOG.rst
@@ -0,0 +1,251 @@
+===================================
+Infoblox.Nios_Modules Release Notes
+===================================
+
+.. contents:: Topics
+
+v1.4.1
+======
+
+Release Summary
+---------------
+- Ansible Lookup modules can specify network_view to which a network/ip belongs
+- Fixes camelCase issue while updating 'nios_network_view' with 'new_name'
+- Fixes issue to allocate ip to a_record dynamically
+- Updates 'nios_a_record' name with multiple ips having same name
+
+Minor Changes
+-------------
+- Fix to specify network_view in lookup modules to return absolute network/ip `#157 <https://github.com/infobloxopen/infoblox-ansible/pull/157>`_
+- Fix to camelcase issue for updating 'nios_network_view' name `#163 <https://github.com/infobloxopen/infoblox-ansible/pull/163>`_
+- Fix to allocate ip to a_record dynamically `#163 <https://github.com/infobloxopen/infoblox-ansible/pull/163>`_
+- Fix to update 'nios_a_record' name with multiple ips having same name `#164 <https://github.com/infobloxopen/infoblox-ansible/pull/164>`_
+- Fix to changelog yaml file with linting issues `#161 <https://github.com/infobloxopen/infoblox-ansible/pull/161>`_
+
+
+v1.4.0
+======
+
+Release Summary
+---------------
+- For ansible module, added certificate authentication feature
+- Few bug fixes in ansible module nios network
+
+Major Changes
+-------------
+- Feature for extra layer security, with `cert` and `key` parameters in playbooks for authenticating using certificate and key .pem file absolute path `#154 <https://github.com/infobloxopen/infoblox-ansible/pull/154>`
+- Fix to remove issue causing due to template attr in deleting network using Ansible module nios network `#147 <https://github.com/infobloxopen/infoblox-ansible/pull/147>`_
+
+
+v1.3.0
+======
+
+Release Summary
+---------------
+- Issue fixes to create TXT record with equals sign
+- For nonexistent record, update operation creates the new record
+- For nonexistent IPv4Address, update operation creates a new A record with new_ipv4addr
+
+Major Changes
+-------------
+- Update operation using `old_name` and `new_name` for the object with dummy name in `old_name` (which does not exist in system) will not create a new object in the system. An error will be thrown stating the object does not exist in the system `#129 <https://github.com/infobloxopen/infoblox-ansible/pull/129>`_
+- Update `text` field of TXT Record `#128 <https://github.com/infobloxopen/infoblox-ansible/pull/128>`_
+
+Bugfixes
+---------
+- Fix to create TXT record with equals sign `#128 <https://github.com/infobloxopen/infoblox-ansible/pull/128>`_
+
+
+v1.2.2
+======
+
+Release Summary
+---------------
+- Issue fixes to create PTR record in different network views
+- Support extended to determine whether the DTC server is disabled or not
+
+Minor Changes
+-------------
+- Fix to create PTR record in different network views `#103 <https://github.com/infobloxopen/infoblox-ansible/pull/103>`_
+- Remove use_option for DHCP option 60 `#104 <https://github.com/infobloxopen/infoblox-ansible/pull/104>`_
+- Allow specifying a template when creating a network `#105 <https://github.com/infobloxopen/infoblox-ansible/pull/105>`_
+- Fix unit and sanity test issues `#117 <https://github.com/infobloxopen/infoblox-ansible/pull/117>`_
+- Expanding for disable value `#119 <https://github.com/infobloxopen/infoblox-ansible/pull/119>`_
+
+
+v1.2.1
+======
+
+Release Summary
+---------------
+Added tags to support release on Ansible Automation Hub
+
+Minor Changes
+-------------
+Added tags 'cloud' and 'networking' in 'galaxy.yaml'
+
+
+v1.2.0
+======
+Release Summary
+---------------
+- Issue fixes to update A Record using 'next_available_ip' function
+- Added a new feature - Update canonical name of the CNAME Record
+- Updated the 'required' fields in modules
+
+Minor Changes
+-------------
+- Updated 'required' field in modules `#99 <https://github.com/infobloxopen/infoblox-ansible/pull/99>`_
+- Following options are made required in the modules
+
+.. list-table::
+ :widths: 25 25
+ :header-rows: 1
+
+ * - Record
+ - Option made required
+ * - A
+ - ipv4addr
+ * - AAAA
+ - ipv6addr
+ * - CNAME
+ - canonical
+ * - MX
+ - mail_exchanger, preference
+ * - PTR
+ - ptrdname
+
+Bugfixes
+-------------
+- nios_a_record module - KeyError: 'old_ipv4addr' `#79 <https://github.com/infobloxopen/infoblox-ansible/issues/79>`_
+- Ansible playbook fails to update canonical name of CName Record `#97 <https://github.com/infobloxopen/infoblox-ansible/pull/97>`_
+
+
+v1.1.2
+======
+Release Summary
+---------------
+- Issue fixes and standardization of inventory plugin and lookup modules as per Ansible guidelines
+- Directory restructure and added integration & unit tests
+
+Minor Changes
+-------------
+- Changes in inventory and lookup plugins documentation `#85 <https://github.com/infobloxopen/infoblox-ansible/pull/85>`_
+- Directory restructure and added integration & unit tests `#87 <https://github.com/infobloxopen/infoblox-ansible/pull/87>`_
+
+Bugfixes
+-------------
+- Handle NoneType parsing in nios_inventory.py `#81 <https://github.com/infobloxopen/infoblox-ansible/pull/81>`_
+- Check all dhcp options, not just first one `#83 <https://github.com/infobloxopen/infoblox-ansible/pull/83>`_
+
+
+v1.1.1
+======
+Release Summary
+---------------
+- Support for creating IPv6 Fixed Address with DUID
+- Support added to return the next available IP address for an IPv6 network
+- Modules made compatible to work with ansible-core 2.11
+- Issue fixes and standardization of modules as per Ansible guidelines
+
+Minor Changes
+-------------
+- The modules are standardized as per Ansible guidelines
+
+Bugfixes
+-------------
+- Implemented the bugfixes provided by Ansible `community.general`
+- Update the name of existing A and AAAA records `#70 <https://github.com/infobloxopen/infoblox-ansible/pull/70>`_
+- Update of comment field of SRV, PTR and NAPTR records failing with the following error:
+ ```[Err: fatal: [localhost]: FAILED! => {"changed": false, "code": "Client.Ibap.Proto", "msg": "Field is not allowed for update: view", "operation": "update_object", "type": "AdmConProtoError"}]```
+ `#70 <https://github.com/infobloxopen/infoblox-ansible/pull/70>`_
+- PTR Record failed to update and raises KeyError for view field `#70 <https://github.com/infobloxopen/infoblox-ansible/pull/70>`_
+- Update comment field and delete an existing Fixed Address `#73 <https://github.com/infobloxopen/infoblox-ansible/pull/73>`_
+- GitHub issue fix - Lookup module for next available IPV6 `#31 <https://github.com/infobloxopen/infoblox-ansible/issues/31>`_
+- GitHub issue fix - [nios_zone] changing a nios_zone does not work `#60 <https://github.com/infobloxopen/infoblox-ansible/issues/60>`_
+- GitHub issue fix - Getting an error, running every module `#67 <https://github.com/infobloxopen/infoblox-ansible/issues/67>`_
+- GitHub issue fix - Error - Dictionary Issues `#68 <https://github.com/infobloxopen/infoblox-ansible/issues/68>`_
+- GitHub issue fix - Examples for lookups don't work as written `#72 <https://github.com/infobloxopen/infoblox-ansible/issues/72>`_
+- Sanity fixes as per Ansible guidelines to all modules
+
+
+v1.1.0
+======
+
+Release Summary
+---------------
+
+This release provides plugins for NIOS DTC
+
+New Modules
+-----------
+
+- infoblox.nios_modules.nios_dtc_lbdn - Configure Infoblox NIOS DTC LBDN
+- infoblox.nios_modules.nios_dtc_pool - Configure Infoblox NIOS DTC Pool
+- infoblox.nios_modules.nios_dtc_server - Configure Infoblox NIOS DTC Server
+- infoblox.nios_modules.nios_restartservices - Restart grid services.
+
+v1.0.2
+======
+
+Release Summary
+---------------
+
+This release provides compatibilty for Ansible v3.0.0
+
+Minor Changes
+-------------
+
+- Fixed the ignored sanity errors required for Ansible 3.0.0 collection
+- Made it compatible for Ansible v3.0.0
+
+v1.0.1
+======
+
+Release Summary
+---------------
+
+This release provides compatibilty for Ansible v3.0.0
+
+Minor Changes
+-------------
+
+- Made it compatible for Ansible v3.0.0
+
+v1.0.0
+======
+
+Release Summary
+---------------
+
+First release of the `nios_modules` collection! This release includes multiple plugins:- an `api` plugin, a `network` plugin, a `nios` plugin, a `nios_inventory` plugin, a `lookup plugin`, a `nios_next_ip` plugin, a `nios_next_network` plugin
+
+New Plugins
+-----------
+
+Lookup
+~~~~~~
+
+- infoblox.nios_modules.nios - Query Infoblox NIOS objects
+- infoblox.nios_modules.nios_next_ip - Return the next available IP address for a network
+- infoblox.nios_modules.nios_next_network - Return the next available network range for a network-container
+
+New Modules
+-----------
+
+- infoblox.nios_modules.nios_a_record - Configure Infoblox NIOS A records
+- infoblox.nios_modules.nios_aaaa_record - Configure Infoblox NIOS AAAA records
+- infoblox.nios_modules.nios_cname_record - Configure Infoblox NIOS CNAME records
+- infoblox.nios_modules.nios_dns_view - Configure Infoblox NIOS DNS views
+- infoblox.nios_modules.nios_fixed_address - Configure Infoblox NIOS DHCP Fixed Address
+- infoblox.nios_modules.nios_host_record - Configure Infoblox NIOS host records
+- infoblox.nios_modules.nios_member - Configure Infoblox NIOS members
+- infoblox.nios_modules.nios_mx_record - Configure Infoblox NIOS MX records
+- infoblox.nios_modules.nios_naptr_record - Configure Infoblox NIOS NAPTR records
+- infoblox.nios_modules.nios_network - Configure Infoblox NIOS network object
+- infoblox.nios_modules.nios_network_view - Configure Infoblox NIOS network views
+- infoblox.nios_modules.nios_nsgroup - Configure Infoblox NIOS Nameserver Groups
+- infoblox.nios_modules.nios_ptr_record - Configure Infoblox NIOS PTR records
+- infoblox.nios_modules.nios_srv_record - Configure Infoblox NIOS SRV records
+- infoblox.nios_modules.nios_txt_record - Configure Infoblox NIOS txt records
+- infoblox.nios_modules.nios_zone - Configure Infoblox NIOS DNS zones
diff --git a/ansible_collections/infoblox/nios_modules/CONTRIBUTING.md b/ansible_collections/infoblox/nios_modules/CONTRIBUTING.md
new file mode 100644
index 00000000..436410b8
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/CONTRIBUTING.md
@@ -0,0 +1,31 @@
+# Contributing
+
+Hello and welcome! Thank you for being interested in contributing to this project.
+
+First of all get confident with the [Ansible Collections Overview](https://github.com/ansible-collections/overview).
+
+We accept pull requests for bugfixes, new features, and other improvements, assuming they pass our review. If you are planning a larger feature or refactoring, please create an issue first to discuss it with us.
+
+## :bug: Reporting an issue
+
+Please [search in the issue list](https://github.com/infobloxopen/infoblox-ansible/issues) and if has not been already reported, [open a new issue](https://github.com/infobloxopen/infoblox-ansible/issues/new)
+
+## 🏗 To contribute
+
+A more extensive walk-through can be found in [Ansible's Contributing to collections](https://docs.ansible.com/ansible/latest/dev_guide/developing_collections.html#hacking-collections).
+
+1. Fork this repo (when checking it out, see [here](https://docs.ansible.com/ansible/latest/dev_guide/developing_collections.html#contributing-to-collections) for how to place the checkout correctly)
+1. Create a feature branch
+1. Commit and push your code. To make the process faster, please ensure:
+
+ - the tests are green. Tests runs using [GitHub Actions](https://help.github.com/en/actions)
+ - you added a [changelog fragment](https://docs.ansible.com/ansible/latest/community/development_process.html#changelogs-how-to)
+
+Please note that all PRs that are not strictly documentation, testing, or add a new plugin or module, require a changelog fragment. See [Creating a changelog fragment](https://docs.ansible.com/ansible/latest/community/development_process.html#changelogs-how-to) for information on that.
+
+Further resources:
+
+- [Ansible Developer guide: developing collections](https://docs.ansible.com/ansible/latest/dev_guide/developing_collections.html)
+- [Ansible Developer guide](https://docs.ansible.com/ansible/latest/dev_guide/index.html)
+
+This repository adheres to the [Ansible Community code of conduct](https://docs.ansible.com/ansible/latest/community/code_of_conduct.html)
diff --git a/ansible_collections/infoblox/nios_modules/COPYING b/ansible_collections/infoblox/nios_modules/COPYING
new file mode 100644
index 00000000..f288702d
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/COPYING
@@ -0,0 +1,674 @@
+ GNU GENERAL PUBLIC LICENSE
+ Version 3, 29 June 2007
+
+ Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/>
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+ Preamble
+
+ The GNU General Public License is a free, copyleft license for
+software and other kinds of works.
+
+ The licenses for most software and other practical works are designed
+to take away your freedom to share and change the works. By contrast,
+the GNU General Public License is intended to guarantee your freedom to
+share and change all versions of a program--to make sure it remains free
+software for all its users. We, the Free Software Foundation, use the
+GNU General Public License for most of our software; it applies also to
+any other work released this way by its authors. You can apply it to
+your programs, too.
+
+ When we speak of free software, we are referring to freedom, not
+price. Our General Public Licenses are designed to make sure that you
+have the freedom to distribute copies of free software (and charge for
+them if you wish), that you receive source code or can get it if you
+want it, that you can change the software or use pieces of it in new
+free programs, and that you know you can do these things.
+
+ To protect your rights, we need to prevent others from denying you
+these rights or asking you to surrender the rights. Therefore, you have
+certain responsibilities if you distribute copies of the software, or if
+you modify it: responsibilities to respect the freedom of others.
+
+ For example, if you distribute copies of such a program, whether
+gratis or for a fee, you must pass on to the recipients the same
+freedoms that you received. You must make sure that they, too, receive
+or can get the source code. And you must show them these terms so they
+know their rights.
+
+ Developers that use the GNU GPL protect your rights with two steps:
+(1) assert copyright on the software, and (2) offer you this License
+giving you legal permission to copy, distribute and/or modify it.
+
+ For the developers' and authors' protection, the GPL clearly explains
+that there is no warranty for this free software. For both users' and
+authors' sake, the GPL requires that modified versions be marked as
+changed, so that their problems will not be attributed erroneously to
+authors of previous versions.
+
+ Some devices are designed to deny users access to install or run
+modified versions of the software inside them, although the manufacturer
+can do so. This is fundamentally incompatible with the aim of
+protecting users' freedom to change the software. The systematic
+pattern of such abuse occurs in the area of products for individuals to
+use, which is precisely where it is most unacceptable. Therefore, we
+have designed this version of the GPL to prohibit the practice for those
+products. If such problems arise substantially in other domains, we
+stand ready to extend this provision to those domains in future versions
+of the GPL, as needed to protect the freedom of users.
+
+ Finally, every program is threatened constantly by software patents.
+States should not allow patents to restrict development and use of
+software on general-purpose computers, but in those that do, we wish to
+avoid the special danger that patents applied to a free program could
+make it effectively proprietary. To prevent this, the GPL assures that
+patents cannot be used to render the program non-free.
+
+ The precise terms and conditions for copying, distribution and
+modification follow.
+
+ TERMS AND CONDITIONS
+
+ 0. Definitions.
+
+ "This License" refers to version 3 of the GNU General Public License.
+
+ "Copyright" also means copyright-like laws that apply to other kinds of
+works, such as semiconductor masks.
+
+ "The Program" refers to any copyrightable work licensed under this
+License. Each licensee is addressed as "you". "Licensees" and
+"recipients" may be individuals or organizations.
+
+ To "modify" a work means to copy from or adapt all or part of the work
+in a fashion requiring copyright permission, other than the making of an
+exact copy. The resulting work is called a "modified version" of the
+earlier work or a work "based on" the earlier work.
+
+ A "covered work" means either the unmodified Program or a work based
+on the Program.
+
+ To "propagate" a work means to do anything with it that, without
+permission, would make you directly or secondarily liable for
+infringement under applicable copyright law, except executing it on a
+computer or modifying a private copy. Propagation includes copying,
+distribution (with or without modification), making available to the
+public, and in some countries other activities as well.
+
+ To "convey" a work means any kind of propagation that enables other
+parties to make or receive copies. Mere interaction with a user through
+a computer network, with no transfer of a copy, is not conveying.
+
+ An interactive user interface displays "Appropriate Legal Notices"
+to the extent that it includes a convenient and prominently visible
+feature that (1) displays an appropriate copyright notice, and (2)
+tells the user that there is no warranty for the work (except to the
+extent that warranties are provided), that licensees may convey the
+work under this License, and how to view a copy of this License. If
+the interface presents a list of user commands or options, such as a
+menu, a prominent item in the list meets this criterion.
+
+ 1. Source Code.
+
+ The "source code" for a work means the preferred form of the work
+for making modifications to it. "Object code" means any non-source
+form of a work.
+
+ A "Standard Interface" means an interface that either is an official
+standard defined by a recognized standards body, or, in the case of
+interfaces specified for a particular programming language, one that
+is widely used among developers working in that language.
+
+ The "System Libraries" of an executable work include anything, other
+than the work as a whole, that (a) is included in the normal form of
+packaging a Major Component, but which is not part of that Major
+Component, and (b) serves only to enable use of the work with that
+Major Component, or to implement a Standard Interface for which an
+implementation is available to the public in source code form. A
+"Major Component", in this context, means a major essential component
+(kernel, window system, and so on) of the specific operating system
+(if any) on which the executable work runs, or a compiler used to
+produce the work, or an object code interpreter used to run it.
+
+ The "Corresponding Source" for a work in object code form means all
+the source code needed to generate, install, and (for an executable
+work) run the object code and to modify the work, including scripts to
+control those activities. However, it does not include the work's
+System Libraries, or general-purpose tools or generally available free
+programs which are used unmodified in performing those activities but
+which are not part of the work. For example, Corresponding Source
+includes interface definition files associated with source files for
+the work, and the source code for shared libraries and dynamically
+linked subprograms that the work is specifically designed to require,
+such as by intimate data communication or control flow between those
+subprograms and other parts of the work.
+
+ The Corresponding Source need not include anything that users
+can regenerate automatically from other parts of the Corresponding
+Source.
+
+ The Corresponding Source for a work in source code form is that
+same work.
+
+ 2. Basic Permissions.
+
+ All rights granted under this License are granted for the term of
+copyright on the Program, and are irrevocable provided the stated
+conditions are met. This License explicitly affirms your unlimited
+permission to run the unmodified Program. The output from running a
+covered work is covered by this License only if the output, given its
+content, constitutes a covered work. This License acknowledges your
+rights of fair use or other equivalent, as provided by copyright law.
+
+ You may make, run and propagate covered works that you do not
+convey, without conditions so long as your license otherwise remains
+in force. You may convey covered works to others for the sole purpose
+of having them make modifications exclusively for you, or provide you
+with facilities for running those works, provided that you comply with
+the terms of this License in conveying all material for which you do
+not control copyright. Those thus making or running the covered works
+for you must do so exclusively on your behalf, under your direction
+and control, on terms that prohibit them from making any copies of
+your copyrighted material outside their relationship with you.
+
+ Conveying under any other circumstances is permitted solely under
+the conditions stated below. Sublicensing is not allowed; section 10
+makes it unnecessary.
+
+ 3. Protecting Users' Legal Rights From Anti-Circumvention Law.
+
+ No covered work shall be deemed part of an effective technological
+measure under any applicable law fulfilling obligations under article
+11 of the WIPO copyright treaty adopted on 20 December 1996, or
+similar laws prohibiting or restricting circumvention of such
+measures.
+
+ When you convey a covered work, you waive any legal power to forbid
+circumvention of technological measures to the extent such circumvention
+is effected by exercising rights under this License with respect to
+the covered work, and you disclaim any intention to limit operation or
+modification of the work as a means of enforcing, against the work's
+users, your or third parties' legal rights to forbid circumvention of
+technological measures.
+
+ 4. Conveying Verbatim Copies.
+
+ You may convey verbatim copies of the Program's source code as you
+receive it, in any medium, provided that you conspicuously and
+appropriately publish on each copy an appropriate copyright notice;
+keep intact all notices stating that this License and any
+non-permissive terms added in accord with section 7 apply to the code;
+keep intact all notices of the absence of any warranty; and give all
+recipients a copy of this License along with the Program.
+
+ You may charge any price or no price for each copy that you convey,
+and you may offer support or warranty protection for a fee.
+
+ 5. Conveying Modified Source Versions.
+
+ You may convey a work based on the Program, or the modifications to
+produce it from the Program, in the form of source code under the
+terms of section 4, provided that you also meet all of these conditions:
+
+ a) The work must carry prominent notices stating that you modified
+ it, and giving a relevant date.
+
+ b) The work must carry prominent notices stating that it is
+ released under this License and any conditions added under section
+ 7. This requirement modifies the requirement in section 4 to
+ "keep intact all notices".
+
+ c) You must license the entire work, as a whole, under this
+ License to anyone who comes into possession of a copy. This
+ License will therefore apply, along with any applicable section 7
+ additional terms, to the whole of the work, and all its parts,
+ regardless of how they are packaged. This License gives no
+ permission to license the work in any other way, but it does not
+ invalidate such permission if you have separately received it.
+
+ d) If the work has interactive user interfaces, each must display
+ Appropriate Legal Notices; however, if the Program has interactive
+ interfaces that do not display Appropriate Legal Notices, your
+ work need not make them do so.
+
+ A compilation of a covered work with other separate and independent
+works, which are not by their nature extensions of the covered work,
+and which are not combined with it such as to form a larger program,
+in or on a volume of a storage or distribution medium, is called an
+"aggregate" if the compilation and its resulting copyright are not
+used to limit the access or legal rights of the compilation's users
+beyond what the individual works permit. Inclusion of a covered work
+in an aggregate does not cause this License to apply to the other
+parts of the aggregate.
+
+ 6. Conveying Non-Source Forms.
+
+ You may convey a covered work in object code form under the terms
+of sections 4 and 5, provided that you also convey the
+machine-readable Corresponding Source under the terms of this License,
+in one of these ways:
+
+ a) Convey the object code in, or embodied in, a physical product
+ (including a physical distribution medium), accompanied by the
+ Corresponding Source fixed on a durable physical medium
+ customarily used for software interchange.
+
+ b) Convey the object code in, or embodied in, a physical product
+ (including a physical distribution medium), accompanied by a
+ written offer, valid for at least three years and valid for as
+ long as you offer spare parts or customer support for that product
+ model, to give anyone who possesses the object code either (1) a
+ copy of the Corresponding Source for all the software in the
+ product that is covered by this License, on a durable physical
+ medium customarily used for software interchange, for a price no
+ more than your reasonable cost of physically performing this
+ conveying of source, or (2) access to copy the
+ Corresponding Source from a network server at no charge.
+
+ c) Convey individual copies of the object code with a copy of the
+ written offer to provide the Corresponding Source. This
+ alternative is allowed only occasionally and noncommercially, and
+ only if you received the object code with such an offer, in accord
+ with subsection 6b.
+
+ d) Convey the object code by offering access from a designated
+ place (gratis or for a charge), and offer equivalent access to the
+ Corresponding Source in the same way through the same place at no
+ further charge. You need not require recipients to copy the
+ Corresponding Source along with the object code. If the place to
+ copy the object code is a network server, the Corresponding Source
+ may be on a different server (operated by you or a third party)
+ that supports equivalent copying facilities, provided you maintain
+ clear directions next to the object code saying where to find the
+ Corresponding Source. Regardless of what server hosts the
+ Corresponding Source, you remain obligated to ensure that it is
+ available for as long as needed to satisfy these requirements.
+
+ e) Convey the object code using peer-to-peer transmission, provided
+ you inform other peers where the object code and Corresponding
+ Source of the work are being offered to the general public at no
+ charge under subsection 6d.
+
+ A separable portion of the object code, whose source code is excluded
+from the Corresponding Source as a System Library, need not be
+included in conveying the object code work.
+
+ A "User Product" is either (1) a "consumer product", which means any
+tangible personal property which is normally used for personal, family,
+or household purposes, or (2) anything designed or sold for incorporation
+into a dwelling. In determining whether a product is a consumer product,
+doubtful cases shall be resolved in favor of coverage. For a particular
+product received by a particular user, "normally used" refers to a
+typical or common use of that class of product, regardless of the status
+of the particular user or of the way in which the particular user
+actually uses, or expects or is expected to use, the product. A product
+is a consumer product regardless of whether the product has substantial
+commercial, industrial or non-consumer uses, unless such uses represent
+the only significant mode of use of the product.
+
+ "Installation Information" for a User Product means any methods,
+procedures, authorization keys, or other information required to install
+and execute modified versions of a covered work in that User Product from
+a modified version of its Corresponding Source. The information must
+suffice to ensure that the continued functioning of the modified object
+code is in no case prevented or interfered with solely because
+modification has been made.
+
+ If you convey an object code work under this section in, or with, or
+specifically for use in, a User Product, and the conveying occurs as
+part of a transaction in which the right of possession and use of the
+User Product is transferred to the recipient in perpetuity or for a
+fixed term (regardless of how the transaction is characterized), the
+Corresponding Source conveyed under this section must be accompanied
+by the Installation Information. But this requirement does not apply
+if neither you nor any third party retains the ability to install
+modified object code on the User Product (for example, the work has
+been installed in ROM).
+
+ The requirement to provide Installation Information does not include a
+requirement to continue to provide support service, warranty, or updates
+for a work that has been modified or installed by the recipient, or for
+the User Product in which it has been modified or installed. Access to a
+network may be denied when the modification itself materially and
+adversely affects the operation of the network or violates the rules and
+protocols for communication across the network.
+
+ Corresponding Source conveyed, and Installation Information provided,
+in accord with this section must be in a format that is publicly
+documented (and with an implementation available to the public in
+source code form), and must require no special password or key for
+unpacking, reading or copying.
+
+ 7. Additional Terms.
+
+ "Additional permissions" are terms that supplement the terms of this
+License by making exceptions from one or more of its conditions.
+Additional permissions that are applicable to the entire Program shall
+be treated as though they were included in this License, to the extent
+that they are valid under applicable law. If additional permissions
+apply only to part of the Program, that part may be used separately
+under those permissions, but the entire Program remains governed by
+this License without regard to the additional permissions.
+
+ When you convey a copy of a covered work, you may at your option
+remove any additional permissions from that copy, or from any part of
+it. (Additional permissions may be written to require their own
+removal in certain cases when you modify the work.) You may place
+additional permissions on material, added by you to a covered work,
+for which you have or can give appropriate copyright permission.
+
+ Notwithstanding any other provision of this License, for material you
+add to a covered work, you may (if authorized by the copyright holders of
+that material) supplement the terms of this License with terms:
+
+ a) Disclaiming warranty or limiting liability differently from the
+ terms of sections 15 and 16 of this License; or
+
+ b) Requiring preservation of specified reasonable legal notices or
+ author attributions in that material or in the Appropriate Legal
+ Notices displayed by works containing it; or
+
+ c) Prohibiting misrepresentation of the origin of that material, or
+ requiring that modified versions of such material be marked in
+ reasonable ways as different from the original version; or
+
+ d) Limiting the use for publicity purposes of names of licensors or
+ authors of the material; or
+
+ e) Declining to grant rights under trademark law for use of some
+ trade names, trademarks, or service marks; or
+
+ f) Requiring indemnification of licensors and authors of that
+ material by anyone who conveys the material (or modified versions of
+ it) with contractual assumptions of liability to the recipient, for
+ any liability that these contractual assumptions directly impose on
+ those licensors and authors.
+
+ All other non-permissive additional terms are considered "further
+restrictions" within the meaning of section 10. If the Program as you
+received it, or any part of it, contains a notice stating that it is
+governed by this License along with a term that is a further
+restriction, you may remove that term. If a license document contains
+a further restriction but permits relicensing or conveying under this
+License, you may add to a covered work material governed by the terms
+of that license document, provided that the further restriction does
+not survive such relicensing or conveying.
+
+ If you add terms to a covered work in accord with this section, you
+must place, in the relevant source files, a statement of the
+additional terms that apply to those files, or a notice indicating
+where to find the applicable terms.
+
+ Additional terms, permissive or non-permissive, may be stated in the
+form of a separately written license, or stated as exceptions;
+the above requirements apply either way.
+
+ 8. Termination.
+
+ You may not propagate or modify a covered work except as expressly
+provided under this License. Any attempt otherwise to propagate or
+modify it is void, and will automatically terminate your rights under
+this License (including any patent licenses granted under the third
+paragraph of section 11).
+
+ However, if you cease all violation of this License, then your
+license from a particular copyright holder is reinstated (a)
+provisionally, unless and until the copyright holder explicitly and
+finally terminates your license, and (b) permanently, if the copyright
+holder fails to notify you of the violation by some reasonable means
+prior to 60 days after the cessation.
+
+ Moreover, your license from a particular copyright holder is
+reinstated permanently if the copyright holder notifies you of the
+violation by some reasonable means, this is the first time you have
+received notice of violation of this License (for any work) from that
+copyright holder, and you cure the violation prior to 30 days after
+your receipt of the notice.
+
+ Termination of your rights under this section does not terminate the
+licenses of parties who have received copies or rights from you under
+this License. If your rights have been terminated and not permanently
+reinstated, you do not qualify to receive new licenses for the same
+material under section 10.
+
+ 9. Acceptance Not Required for Having Copies.
+
+ You are not required to accept this License in order to receive or
+run a copy of the Program. Ancillary propagation of a covered work
+occurring solely as a consequence of using peer-to-peer transmission
+to receive a copy likewise does not require acceptance. However,
+nothing other than this License grants you permission to propagate or
+modify any covered work. These actions infringe copyright if you do
+not accept this License. Therefore, by modifying or propagating a
+covered work, you indicate your acceptance of this License to do so.
+
+ 10. Automatic Licensing of Downstream Recipients.
+
+ Each time you convey a covered work, the recipient automatically
+receives a license from the original licensors, to run, modify and
+propagate that work, subject to this License. You are not responsible
+for enforcing compliance by third parties with this License.
+
+ An "entity transaction" is a transaction transferring control of an
+organization, or substantially all assets of one, or subdividing an
+organization, or merging organizations. If propagation of a covered
+work results from an entity transaction, each party to that
+transaction who receives a copy of the work also receives whatever
+licenses to the work the party's predecessor in interest had or could
+give under the previous paragraph, plus a right to possession of the
+Corresponding Source of the work from the predecessor in interest, if
+the predecessor has it or can get it with reasonable efforts.
+
+ You may not impose any further restrictions on the exercise of the
+rights granted or affirmed under this License. For example, you may
+not impose a license fee, royalty, or other charge for exercise of
+rights granted under this License, and you may not initiate litigation
+(including a cross-claim or counterclaim in a lawsuit) alleging that
+any patent claim is infringed by making, using, selling, offering for
+sale, or importing the Program or any portion of it.
+
+ 11. Patents.
+
+ A "contributor" is a copyright holder who authorizes use under this
+License of the Program or a work on which the Program is based. The
+work thus licensed is called the contributor's "contributor version".
+
+ A contributor's "essential patent claims" are all patent claims
+owned or controlled by the contributor, whether already acquired or
+hereafter acquired, that would be infringed by some manner, permitted
+by this License, of making, using, or selling its contributor version,
+but do not include claims that would be infringed only as a
+consequence of further modification of the contributor version. For
+purposes of this definition, "control" includes the right to grant
+patent sublicenses in a manner consistent with the requirements of
+this License.
+
+ Each contributor grants you a non-exclusive, worldwide, royalty-free
+patent license under the contributor's essential patent claims, to
+make, use, sell, offer for sale, import and otherwise run, modify and
+propagate the contents of its contributor version.
+
+ In the following three paragraphs, a "patent license" is any express
+agreement or commitment, however denominated, not to enforce a patent
+(such as an express permission to practice a patent or covenant not to
+sue for patent infringement). To "grant" such a patent license to a
+party means to make such an agreement or commitment not to enforce a
+patent against the party.
+
+ If you convey a covered work, knowingly relying on a patent license,
+and the Corresponding Source of the work is not available for anyone
+to copy, free of charge and under the terms of this License, through a
+publicly available network server or other readily accessible means,
+then you must either (1) cause the Corresponding Source to be so
+available, or (2) arrange to deprive yourself of the benefit of the
+patent license for this particular work, or (3) arrange, in a manner
+consistent with the requirements of this License, to extend the patent
+license to downstream recipients. "Knowingly relying" means you have
+actual knowledge that, but for the patent license, your conveying the
+covered work in a country, or your recipient's use of the covered work
+in a country, would infringe one or more identifiable patents in that
+country that you have reason to believe are valid.
+
+ If, pursuant to or in connection with a single transaction or
+arrangement, you convey, or propagate by procuring conveyance of, a
+covered work, and grant a patent license to some of the parties
+receiving the covered work authorizing them to use, propagate, modify
+or convey a specific copy of the covered work, then the patent license
+you grant is automatically extended to all recipients of the covered
+work and works based on it.
+
+ A patent license is "discriminatory" if it does not include within
+the scope of its coverage, prohibits the exercise of, or is
+conditioned on the non-exercise of one or more of the rights that are
+specifically granted under this License. You may not convey a covered
+work if you are a party to an arrangement with a third party that is
+in the business of distributing software, under which you make payment
+to the third party based on the extent of your activity of conveying
+the work, and under which the third party grants, to any of the
+parties who would receive the covered work from you, a discriminatory
+patent license (a) in connection with copies of the covered work
+conveyed by you (or copies made from those copies), or (b) primarily
+for and in connection with specific products or compilations that
+contain the covered work, unless you entered into that arrangement,
+or that patent license was granted, prior to 28 March 2007.
+
+ Nothing in this License shall be construed as excluding or limiting
+any implied license or other defenses to infringement that may
+otherwise be available to you under applicable patent law.
+
+ 12. No Surrender of Others' Freedom.
+
+ If conditions are imposed on you (whether by court order, agreement or
+otherwise) that contradict the conditions of this License, they do not
+excuse you from the conditions of this License. If you cannot convey a
+covered work so as to satisfy simultaneously your obligations under this
+License and any other pertinent obligations, then as a consequence you may
+not convey it at all. For example, if you agree to terms that obligate you
+to collect a royalty for further conveying from those to whom you convey
+the Program, the only way you could satisfy both those terms and this
+License would be to refrain entirely from conveying the Program.
+
+ 13. Use with the GNU Affero General Public License.
+
+ Notwithstanding any other provision of this License, you have
+permission to link or combine any covered work with a work licensed
+under version 3 of the GNU Affero General Public License into a single
+combined work, and to convey the resulting work. The terms of this
+License will continue to apply to the part which is the covered work,
+but the special requirements of the GNU Affero General Public License,
+section 13, concerning interaction through a network will apply to the
+combination as such.
+
+ 14. Revised Versions of this License.
+
+ The Free Software Foundation may publish revised and/or new versions of
+the GNU General Public License from time to time. Such new versions will
+be similar in spirit to the present version, but may differ in detail to
+address new problems or concerns.
+
+ Each version is given a distinguishing version number. If the
+Program specifies that a certain numbered version of the GNU General
+Public License "or any later version" applies to it, you have the
+option of following the terms and conditions either of that numbered
+version or of any later version published by the Free Software
+Foundation. If the Program does not specify a version number of the
+GNU General Public License, you may choose any version ever published
+by the Free Software Foundation.
+
+ If the Program specifies that a proxy can decide which future
+versions of the GNU General Public License can be used, that proxy's
+public statement of acceptance of a version permanently authorizes you
+to choose that version for the Program.
+
+ Later license versions may give you additional or different
+permissions. However, no additional obligations are imposed on any
+author or copyright holder as a result of your choosing to follow a
+later version.
+
+ 15. Disclaimer of Warranty.
+
+ THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
+APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
+HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
+OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
+THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
+IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
+ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
+
+ 16. Limitation of Liability.
+
+ IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
+WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
+THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
+GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
+USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
+DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
+PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
+EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
+SUCH DAMAGES.
+
+ 17. Interpretation of Sections 15 and 16.
+
+ If the disclaimer of warranty and limitation of liability provided
+above cannot be given local legal effect according to their terms,
+reviewing courts shall apply local law that most closely approximates
+an absolute waiver of all civil liability in connection with the
+Program, unless a warranty or assumption of liability accompanies a
+copy of the Program in return for a fee.
+
+ END OF TERMS AND CONDITIONS
+
+ How to Apply These Terms to Your New Programs
+
+ If you develop a new program, and you want it to be of the greatest
+possible use to the public, the best way to achieve this is to make it
+free software which everyone can redistribute and change under these terms.
+
+ To do so, attach the following notices to the program. It is safest
+to attach them to the start of each source file to most effectively
+state the exclusion of warranty; and each file should have at least
+the "copyright" line and a pointer to where the full notice is found.
+
+ <one line to give the program's name and a brief idea of what it does.>
+ Copyright (C) <year> <name of author>
+
+ This program 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.
+
+ This program 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 this program. If not, see <https://www.gnu.org/licenses/>.
+
+Also add information on how to contact you by electronic and paper mail.
+
+ If the program does terminal interaction, make it output a short
+notice like this when it starts in an interactive mode:
+
+ <program> Copyright (C) <year> <name of author>
+ This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
+ This is free software, and you are welcome to redistribute it
+ under certain conditions; type `show c' for details.
+
+The hypothetical commands `show w' and `show c' should show the appropriate
+parts of the General Public License. Of course, your program's commands
+might be different; for a GUI interface, you would use an "about box".
+
+ You should also get your employer (if you work as a programmer) or school,
+if any, to sign a "copyright disclaimer" for the program, if necessary.
+For more information on this, and how to apply and follow the GNU GPL, see
+<https://www.gnu.org/licenses/>.
+
+ The GNU General Public License does not permit incorporating your program
+into proprietary programs. If your program is a subroutine library, you
+may consider it more useful to permit linking proprietary applications with
+the library. If this is what you want to do, use the GNU Lesser General
+Public License instead of this License. But first, please read
+<https://www.gnu.org/licenses/why-not-lgpl.html>.
diff --git a/ansible_collections/infoblox/nios_modules/FILES.json b/ansible_collections/infoblox/nios_modules/FILES.json
new file mode 100644
index 00000000..5446f5dd
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/FILES.json
@@ -0,0 +1,1601 @@
+{
+ "files": [
+ {
+ "name": ".",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": ".gitignore",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "9cde0277827d89b86382822f9ac4b8519f3db2cf535aab10e5fc931b3a4879f9",
+ "format": 1
+ },
+ {
+ "name": "plugins",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "plugins/doc_fragments",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "plugins/doc_fragments/nios.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "94f28d629cd27662f493fb392d2ebb05c83e3f308a5e0069ae26a4e452da5c02",
+ "format": 1
+ },
+ {
+ "name": "plugins/lookup",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "plugins/lookup/nios_lookup.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "b8982cb06294b51bbfc8aa6754077c3f12e1613a8986f0519eb75d895645174b",
+ "format": 1
+ },
+ {
+ "name": "plugins/lookup/nios_next_ip.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "a0a81954f6f2d819f76de82c6a5ba98c544f901153b20c804078dc4b97bb2481",
+ "format": 1
+ },
+ {
+ "name": "plugins/lookup/nios_next_network.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "e9a8c057f7e902a411772d411ad98436d265c86f73073af61443b6e2c1b7e7e9",
+ "format": 1
+ },
+ {
+ "name": "plugins/module_utils",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "plugins/module_utils/api.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "5caef2eadefdce453068614852108a4177cd74be0da6fce0758889ccdc9c8c2c",
+ "format": 1
+ },
+ {
+ "name": "plugins/module_utils/network.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "dced8c65f333a3a101224574c358fa55aa40f2e0e21cfc5f49b64f4bd1ab12d8",
+ "format": 1
+ },
+ {
+ "name": "plugins/inventory",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "plugins/inventory/nios_inventory.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "8c05e0161380bd212badf22d3004260424d538b7f7674f9eb52d0b2b0d80bcae",
+ "format": 1
+ },
+ {
+ "name": "plugins/README.md",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "c82ee692702ec1dd604cdbc38ff252114e5204e1b0627045a66c9451e7a918ac",
+ "format": 1
+ },
+ {
+ "name": "plugins/modules",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "plugins/modules/nios_network_view.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "60249f22776ba43cbc456c7a305fea55f5c5825a80aa384472d71cd8b58b4924",
+ "format": 1
+ },
+ {
+ "name": "plugins/modules/nios_srv_record.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "8d220967209c16b4edc94f9ab8d1e2e7c9f1984a9239df3f8b3c7734edccdd17",
+ "format": 1
+ },
+ {
+ "name": "plugins/modules/nios_naptr_record.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "05fcfda337dd1408c3bd622c0032efb2b4fe3c0c8b4f9e0da79b2a17e7718250",
+ "format": 1
+ },
+ {
+ "name": "plugins/modules/nios_dns_view.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "e762c774e13ddcd2e12d7df728bcf8c6c572eaff7cf4819f2aa822b078db7b7d",
+ "format": 1
+ },
+ {
+ "name": "plugins/modules/nios_network.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "f30befbfba62d0ea58a59121bf5d856c08576c1f7dc1771d25cec81a4c1b9258",
+ "format": 1
+ },
+ {
+ "name": "plugins/modules/nios_a_record.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "098d4de36c1ca5b71af73d57a198ef707498017c5607941cd938ca48921cb269",
+ "format": 1
+ },
+ {
+ "name": "plugins/modules/nios_zone.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "4f3a1763e347e5fdaf55d7ae7ed1c1d2bf937b645b25023f5317869fac56107c",
+ "format": 1
+ },
+ {
+ "name": "plugins/modules/nios_cname_record.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "85c3a554eddd72cd08cee90b783ec56ffd70466c68c9cc60e0c2591f6722d6f1",
+ "format": 1
+ },
+ {
+ "name": "plugins/modules/nios_restartservices.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "c5f2b010272ca85393050f85cc6c36b2c8b973965e70fa114388838164ae92a4",
+ "format": 1
+ },
+ {
+ "name": "plugins/modules/nios_fixed_address.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "6d16da939f573934520c585c6fcf38c7bb8de40b5f43ffca6dd0563c2fa75935",
+ "format": 1
+ },
+ {
+ "name": "plugins/modules/nios_dtc_server.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "4977aa719a713e9b6d68732a28ad84cc54aa5fd9d3d53a45f07d74ac1cf92a86",
+ "format": 1
+ },
+ {
+ "name": "plugins/modules/nios_member.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "e3643fdf1c188ef8d5584f787e4ce7cf8bea277a0a93d9a715cb3e3b6aad65da",
+ "format": 1
+ },
+ {
+ "name": "plugins/modules/nios_ptr_record.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "a5cdd84504c3183b7b83c592e662cb0950fae8b0efa29836366dcd1445f9caf6",
+ "format": 1
+ },
+ {
+ "name": "plugins/modules/nios_dtc_lbdn.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "de73793e44a144dd9cfedae4e4de9e64931e55e5e8bc05784c1ffb341c239293",
+ "format": 1
+ },
+ {
+ "name": "plugins/modules/nios_nsgroup.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "f75be0f86aa6fe535cbcee064ba4f77db1a74c912fae0cb79d3c9238e14d7014",
+ "format": 1
+ },
+ {
+ "name": "plugins/modules/nios_aaaa_record.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "1cba14889411e1ad1c634ea391c99b8a3fd0c40219e9d440bb63cc7cdc42f496",
+ "format": 1
+ },
+ {
+ "name": "plugins/modules/nios_mx_record.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "4b0573f4f57a5ed22ebef5c4f5e0dd22eb228d833fbd1351ef4a48e9c7326284",
+ "format": 1
+ },
+ {
+ "name": "plugins/modules/nios_dtc_pool.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "284caec37488fde49bad0451d9bf0b5c3a5c1bef3ab0652e96c1dcb981e59887",
+ "format": 1
+ },
+ {
+ "name": "plugins/modules/nios_host_record.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "e6784e231f0b78340516b8ec5d45f6e100cc82e80b5ead94cdae6c36bfda063c",
+ "format": 1
+ },
+ {
+ "name": "plugins/modules/nios_txt_record.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "044cef98685547f09d8c3aad87784c5b47e743507243e1e03160d85f7dedd833",
+ "format": 1
+ },
+ {
+ "name": "requirements.txt",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "55fb25c4faa774de799493c0f9ca57dae363e19d91e1358131ec9a0cc326f1e9",
+ "format": 1
+ },
+ {
+ "name": ".github",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": ".github/workflows",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": ".github/workflows/ansible-test.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "7cb4cc28ab268c0318231914511e5b976b2998466358fcc66887b0b8fc13168a",
+ "format": 1
+ },
+ {
+ "name": "playbooks",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "playbooks/create_txt_record.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "111d1ce384d339af78c3e8daae32e7deda1b9cb62f08023733ea8e693586dc0d",
+ "format": 1
+ },
+ {
+ "name": "playbooks/delete_zone.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "61e5e563e04d918cc76bac07f0ce374bf3796ecb63ea75257d976376c4157c20",
+ "format": 1
+ },
+ {
+ "name": "playbooks/delete_txt_record.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "f72cdc6c618cd7e75a1a1063d5cba782af5fcb07c226e91c2535ac8ff113150f",
+ "format": 1
+ },
+ {
+ "name": "playbooks/create_cname_record.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "10e363c89e5d82b68d4f63ed529282de833b7951b12b9a97f5469d580b24b576",
+ "format": 1
+ },
+ {
+ "name": "playbooks/create_network_view.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "7fc8ebffa421f96e493531d3436d6fa73fe741a55746e669e8c89a1ff9ff030d",
+ "format": 1
+ },
+ {
+ "name": "playbooks/delete_dnsview.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "37deda100ff17068ff552ba5e1e74b9fad1394ebe2db62e7f2adad294c1affc6",
+ "format": 1
+ },
+ {
+ "name": "playbooks/restart_services.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "5dcc9476be118206220829486758c5465cd784a95b66550a414f9004907bc3c1",
+ "format": 1
+ },
+ {
+ "name": "playbooks/delete_mx_record.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "da47165c799c1e87329ccf9461c4681b4245f097b55d3d62dba411edd3e25da5",
+ "format": 1
+ },
+ {
+ "name": "playbooks/create_mx_record.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "b9ae5787aaf298aeaa8b5d7f768402f0f50065699938a3eb5eaacbd7bce1ce8d",
+ "format": 1
+ },
+ {
+ "name": "playbooks/create_dtc_server.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "e4a00c5e95b6476e354b5564c874eff4e38b9fd92d71dc921677b689213b9199",
+ "format": 1
+ },
+ {
+ "name": "playbooks/create_dns_view.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "cd1b9dc35122024065dacfff26cc6a690c677d44f4a047d2a661618d71b409a6",
+ "format": 1
+ },
+ {
+ "name": "playbooks/create_network.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "4786f86ec3ed73faf52441b153f81eaf5020907be7cce195cec049e6abbef51e",
+ "format": 1
+ },
+ {
+ "name": "playbooks/update_a_record.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "2d74da9f596d41369eb8859bb6a628662b573f695d3326a587c5683d4a2e90b3",
+ "format": 1
+ },
+ {
+ "name": "playbooks/create_a_record.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "ace1f52c338c1f9032444ed75f51ef2e8ded43e30fd6af74461b27266900e6bf",
+ "format": 1
+ },
+ {
+ "name": "playbooks/delete_network_view.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "c9fbcaff43e867ffc8a9d8cb8e6a3dc92d1af8c92fb96cbd887655e8cadb0971",
+ "format": 1
+ },
+ {
+ "name": "playbooks/create_dtc_lbdn.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "17840632d509d7e87e5af56b654c7df3cc6ebd92f25d4f86a4c46cbce6ff7edd",
+ "format": 1
+ },
+ {
+ "name": "playbooks/create_zone.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "1d94121423e1184461a55897c7427e7cfd1a242fbfd4709e99c61d16025556d7",
+ "format": 1
+ },
+ {
+ "name": "playbooks/delete_cname_record.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "c04b11f344bfd49f03995665d553e5a008975067010554fd9f1f1a161b7796ae",
+ "format": 1
+ },
+ {
+ "name": "playbooks/create_dtc_pool.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "5d39c51ed9d38d8a1fa9f6c9968203ef1633dce612ff0fcd46706fa6c3969796",
+ "format": 1
+ },
+ {
+ "name": "playbooks/delete_network.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "4577274aa1bba6a8450e1c534ee8c97cbab9b47b2339f6f2f7cce4f79124ad36",
+ "format": 1
+ },
+ {
+ "name": "changelogs",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "changelogs/config.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "44e348d60d00b2812b8cb8aba66308db03d0c83b228611759a2630240b29dfdf",
+ "format": 1
+ },
+ {
+ "name": "changelogs/changelog.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "0ec8d5b4ad41682e233ca578bbaafa5556a049c3900e1c18fb76612048e55e43",
+ "format": 1
+ },
+ {
+ "name": "changelogs/.plugin-cache.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "fb49b92734edb8224cc865269784f571d5edf629123137471917df284ee32b53",
+ "format": 1
+ },
+ {
+ "name": "tests",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/requirements.txt",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "f1d4cbfb694f6fe029ac69b53766a557c3c91f82efe8cc4540c483bda5d4d329",
+ "format": 1
+ },
+ {
+ "name": "tests/integration",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_cname_record",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_cname_record/aliases",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "b2aba930fc2918934f7b9bdff17f9f99ab65167a6e9e41a0c9f45fffb31eaef0",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_cname_record/defaults",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_cname_record/defaults/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "665288590cd4226da42511817f09ccdfc92df36c9621583cd2c82919af295c5a",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_cname_record/meta",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_cname_record/meta/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "f6641fa60f8ba09c7ce762c2ef3514012995ac5302b4864a10e6aa0f1c83d512",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_cname_record/tasks",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_cname_record/tasks/nios_cname_record_idempotence.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "6e5e3f2f0b5ed874e855b9122802b8706faa49150d1d8d4fe2e9d46a535f754e",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_cname_record/tasks/main.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "787a53293d68001b9cccea1154d4c6b4c6277aa52df187ef6b7ecb4e519e5a65",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_aaaa_record",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_aaaa_record/aliases",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "b2aba930fc2918934f7b9bdff17f9f99ab65167a6e9e41a0c9f45fffb31eaef0",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_aaaa_record/defaults",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_aaaa_record/defaults/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "665288590cd4226da42511817f09ccdfc92df36c9621583cd2c82919af295c5a",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_aaaa_record/meta",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_aaaa_record/meta/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "f6641fa60f8ba09c7ce762c2ef3514012995ac5302b4864a10e6aa0f1c83d512",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_aaaa_record/tasks",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_aaaa_record/tasks/nios_aaaa_record_idempotence.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "9b7293e35f42a9951679d1eb30c0a73c5b20e8563373e81e77ef4ef149145abe",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_aaaa_record/tasks/main.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "51f2c8c8d2bf554c82d3ef5a8158377adadd87b71b6de8bc09a360e9ff1f5524",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/prepare_nios_tests",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/prepare_nios_tests/tasks",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/prepare_nios_tests/tasks/main.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "7f6b41fc52044ee283bfaa36506ad6e8e63e40abb080d4d955b57682c0c5a895",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/prepare_nios_tests/tasks/prepare_nios_tests_idempotence.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "9f7ef612d02c82d058380d8a5db2a7f593236034fc83da2b78165186ebb7a095",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_network",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_network/aliases",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "b2aba930fc2918934f7b9bdff17f9f99ab65167a6e9e41a0c9f45fffb31eaef0",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_network/defaults",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_network/defaults/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_network/meta",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_network/meta/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "9b2c007ef16bd19c23982f22d955c1cebe881731f8e06615c9a8fb2985604cc4",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_network/tasks",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_network/tasks/nios_network_idempotence.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "0e8b1f0c838de0cea2151ce497b6d631b0aefda15731e2eb6bc0daefdab3774f",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_network/tasks/main.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "11b1faac4c49c5acbace378328c5fea92014f667d732dbe2ef2a2583f826dc82",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_a_record",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_a_record/aliases",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "b2aba930fc2918934f7b9bdff17f9f99ab65167a6e9e41a0c9f45fffb31eaef0",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_a_record/defaults",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_a_record/defaults/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "665288590cd4226da42511817f09ccdfc92df36c9621583cd2c82919af295c5a",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_a_record/meta",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_a_record/meta/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "f6641fa60f8ba09c7ce762c2ef3514012995ac5302b4864a10e6aa0f1c83d512",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_a_record/tasks",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_a_record/tasks/main.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "5d15dab6a8d8e6b40ac5147025cb8a316ebff5b5822d2305a7fa768ba209f894",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_a_record/tasks/nios_a_record_idempotence.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "ce6edea9daaa81eaeabe5c9565437f59744da7eefe0834b66a35fdba9408a3c5",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_dns_view",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_dns_view/aliases",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "b2aba930fc2918934f7b9bdff17f9f99ab65167a6e9e41a0c9f45fffb31eaef0",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_dns_view/defaults",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_dns_view/defaults/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "3cb79c3d80cffc120afea8cc796848a327b790dbe8b6702bd51c1e2a5d82d906",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_dns_view/meta",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_dns_view/meta/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "9b2c007ef16bd19c23982f22d955c1cebe881731f8e06615c9a8fb2985604cc4",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_dns_view/tasks",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_dns_view/tasks/nios_dns_view_idempotence.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "35a60985b368995a2347da83a8cbb30217cf2d5a3b71204e40f626ef13d228bb",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_dns_view/tasks/main.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "ba5bfe201c74edd65e1df617cad400bd2634d1bf5c9b6b66a22108e73566ebd2",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_ptr_record",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_ptr_record/aliases",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "b2aba930fc2918934f7b9bdff17f9f99ab65167a6e9e41a0c9f45fffb31eaef0",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_ptr_record/defaults",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_ptr_record/defaults/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "665288590cd4226da42511817f09ccdfc92df36c9621583cd2c82919af295c5a",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_ptr_record/meta",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_ptr_record/meta/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "f6641fa60f8ba09c7ce762c2ef3514012995ac5302b4864a10e6aa0f1c83d512",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_ptr_record/tasks",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_ptr_record/tasks/nios_ptr_record_idempotence.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "d963d7efe7113cc92ab45fc5bca5faafd1aa713346558b43004aedd684725019",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_ptr_record/tasks/main.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "964ab01e8de80401c3d083286c2fa5e85c13d8a80a9209433c44c6b8adb5f05e",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_srv_record",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_srv_record/aliases",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "b2aba930fc2918934f7b9bdff17f9f99ab65167a6e9e41a0c9f45fffb31eaef0",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_srv_record/defaults",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_srv_record/defaults/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "665288590cd4226da42511817f09ccdfc92df36c9621583cd2c82919af295c5a",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_srv_record/meta",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_srv_record/meta/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "f6641fa60f8ba09c7ce762c2ef3514012995ac5302b4864a10e6aa0f1c83d512",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_srv_record/tasks",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_srv_record/tasks/main.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "d9588a0ae488ec618c82e823db100269d87978fc7336ed1d41ac282f40603483",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_srv_record/tasks/nios_srv_record_idempotence.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "983b84f88a05dc722a0ef22e4a2deea656cf9425f86a40d10abe1c3d91cfe51d",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_txt_record",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_txt_record/aliases",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "b2aba930fc2918934f7b9bdff17f9f99ab65167a6e9e41a0c9f45fffb31eaef0",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_txt_record/defaults",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_txt_record/defaults/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "3cb79c3d80cffc120afea8cc796848a327b790dbe8b6702bd51c1e2a5d82d906",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_txt_record/meta",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_txt_record/meta/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "9b2c007ef16bd19c23982f22d955c1cebe881731f8e06615c9a8fb2985604cc4",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_txt_record/tasks",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_txt_record/tasks/nios_txt_record_idempotence.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "c357b3236a490bbb05bf10f0bd9965882d4ffff7d48f0d8df059335c4c55227c",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_txt_record/tasks/main.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "6143fed0b778a7af1a4f8f7d7c6da63e07dcb162dd794b861b2582c1c48a8854",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_network_view",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_network_view/aliases",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "b2aba930fc2918934f7b9bdff17f9f99ab65167a6e9e41a0c9f45fffb31eaef0",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_network_view/defaults",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_network_view/defaults/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "3cb79c3d80cffc120afea8cc796848a327b790dbe8b6702bd51c1e2a5d82d906",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_network_view/meta",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_network_view/meta/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "9b2c007ef16bd19c23982f22d955c1cebe881731f8e06615c9a8fb2985604cc4",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_network_view/tasks",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_network_view/tasks/nios_network_view_idempotence.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "0988d75d8debe3ad04f656d77c22cff648214fff669323be2ae1d1707dfd06f1",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_network_view/tasks/main.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "2e3e46fde3dbeb3ae613631df0384134902707bd5511c6dbb4f04ceca4abc714",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_zone",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_zone/aliases",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "b2aba930fc2918934f7b9bdff17f9f99ab65167a6e9e41a0c9f45fffb31eaef0",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_zone/defaults",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_zone/defaults/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "3cb79c3d80cffc120afea8cc796848a327b790dbe8b6702bd51c1e2a5d82d906",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_zone/meta",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_zone/meta/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "9b2c007ef16bd19c23982f22d955c1cebe881731f8e06615c9a8fb2985604cc4",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_zone/tasks",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_zone/tasks/main.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "321785ddd2789cc1265b9502c5463bd9c4979267ae0be21558ea5eec4eceed72",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_zone/tasks/nios_zone_idempotence.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "22e69c13af0623593d880c24015f6b8990c8d3d8f03bc887d10dca8972b76d0c",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_naptr_record",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_naptr_record/aliases",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "b2aba930fc2918934f7b9bdff17f9f99ab65167a6e9e41a0c9f45fffb31eaef0",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_naptr_record/defaults",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_naptr_record/defaults/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "665288590cd4226da42511817f09ccdfc92df36c9621583cd2c82919af295c5a",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_naptr_record/meta",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_naptr_record/meta/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "f6641fa60f8ba09c7ce762c2ef3514012995ac5302b4864a10e6aa0f1c83d512",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_naptr_record/tasks",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_naptr_record/tasks/nios_naptr_record_idempotence.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "943fccfaaab7641fff4e8d2f809830fd3d266504e5a093ba19423fb79c3ac363",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_naptr_record/tasks/main.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "f8c01642191a24501d81753c5cb8af0ab2b6962482903560d2547119686232a1",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_mx_record",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_mx_record/aliases",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "b2aba930fc2918934f7b9bdff17f9f99ab65167a6e9e41a0c9f45fffb31eaef0",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_mx_record/defaults",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_mx_record/defaults/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "665288590cd4226da42511817f09ccdfc92df36c9621583cd2c82919af295c5a",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_mx_record/meta",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_mx_record/meta/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "f6641fa60f8ba09c7ce762c2ef3514012995ac5302b4864a10e6aa0f1c83d512",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_mx_record/tasks",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_mx_record/tasks/nios_mx_record_idempotence.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "8082362994c85378fd9c5b26cad32f583dc83d84d5f83527fb905c401946e65a",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_mx_record/tasks/main.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "3a2d3fb34b2974e819a3401ab9bc26576b2be2f1b2e3f3c428cb78039bc21f98",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_host_record",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_host_record/aliases",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "b2aba930fc2918934f7b9bdff17f9f99ab65167a6e9e41a0c9f45fffb31eaef0",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_host_record/defaults",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_host_record/defaults/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "3cb79c3d80cffc120afea8cc796848a327b790dbe8b6702bd51c1e2a5d82d906",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_host_record/meta",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_host_record/meta/main.yaml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "9b2c007ef16bd19c23982f22d955c1cebe881731f8e06615c9a8fb2985604cc4",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_host_record/tasks",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_host_record/tasks/nios_host_record_idempotence.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "2c6efd391e887105cc040b3dfc42ed5e8ce4ce3bafaba8ccd2377292a27de8c5",
+ "format": 1
+ },
+ {
+ "name": "tests/integration/targets/nios_host_record/tasks/main.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "d6fddc4c90cd988fc0533529f29845b018b09d228e0079c37d7a938399d10480",
+ "format": 1
+ },
+ {
+ "name": "tests/unit",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/module_utils",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/module_utils/test_api.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "78cfcf64d2ba488d15e770dae5ea42f30643a77ed0780d14df66eefd3c8a2af0",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/module_utils/__init__.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/__init__.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/modules",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/modules/test_nios_naptr_record.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "95b80c1e4a02a4035952c7fd0f1ef5de4cd4665773cd1b56d88595eafcc5f2c0",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/modules/test_nios_srv_record.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "bb147e9fcf3f5918b1c068af3a40d21dfeacdffc190c25d0951a190d3961bb93",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/modules/test_nios_aaaa_record.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "add3503be1f73a5eaf32e3e62fb70265e98bfee63cd6fefa0a8eec8dee4b3e3b",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/modules/test_nios_cname_record.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "7c5e930a07686e4b0aee8f1469eec587dc2e06466f5724e626156b396e150708",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/modules/test_nios_zone.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "cbb7b98c199a0f7bb1c50e2e21e2a3353aa37c7ff9a676cf9194e4e659510710",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/modules/test_nios_nsgroup.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "b8aeca79a11e3be969f82e845a712f1eb86ea8e562f91a10a008952226271186",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/modules/test_nios_host_record.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "07e4fc0b0abfb0bb6fa8c3a68eafe79635ea0e687b96fbaa1f2a776ceee84588",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/modules/test_nios_network.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "94bdde6ba5224d532a22d37b26f1b2398c42d4fd315a040a32fc61f9b91ff1ec",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/modules/test_nios_member.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "bd0b8081e628d0112da7ba69398de00d7cdd9afa6ba1bd34ccbd9ae513b11285",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/modules/test_nios_a_record.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "7da0ed2bbfdc92f9db397be48e201fb4d8bd67ac7069d5e457d0ad1e46bdcc97",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/modules/test_nios_fixed_address.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "e6dc2a63173e9af0fa27a50f1ac4b524718eef99d0ae062fb7b8de1fe0a970da",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/modules/test_nios_mx_record.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "a6a64554903eff210c9392ff0f66b3ca41a7accc9cc5d427f5723e899b283ef4",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/modules/test_nios_dns_view.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "832fd1e4f3bce40833e99466c2dab63930a321dd32250bd326c33d0d8cd919fc",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/modules/test_nios_network_view.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "f9a94a50ee09d4f42755f1ce5d6ed87158825eec35b958e390ace6fcaa830378",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/modules/fixtures",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/modules/fixtures/nios_result.txt",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/modules/test_nios_ptr_record.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "e5388b813fc6c70b53545d05ec18792ed258e966f3e712ee78de0fd29f90dde1",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/modules/utils.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "3ebeccd641cf5de2b25ae1bf4e153492bb499c641c5b5465ca25168f08b1a1ac",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/modules/__init__.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/plugins/modules/test_nios_module.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "c733e6ebea7febb7eab14e589c489aed9f5e6d6e188d85556d6d4d1b754f5b67",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/requirements.txt",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "c1b6aded0bacf264f0dcee417363adcb09fac038946bf434ae1c8a5f56a964a8",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/compat",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "tests/unit/compat/mock.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "e18448d2582e03b3c782d3f5039907f364b852021f8033951f5abbdcd5e07d7a",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/compat/__init__.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855",
+ "format": 1
+ },
+ {
+ "name": "tests/unit/__init__.py",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855",
+ "format": 1
+ },
+ {
+ "name": "meta",
+ "ftype": "dir",
+ "chksum_type": null,
+ "chksum_sha256": null,
+ "format": 1
+ },
+ {
+ "name": "meta/runtime.yml",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "df18179bb2f5447a56ac92261a911649b96821c0b2c08eea62d5cc6b0195203f",
+ "format": 1
+ },
+ {
+ "name": "CONTRIBUTING.md",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "fd88c8b2920fd2d659c1ee76d5709c61a3d68e4af1c21a156670a5f543dc26ef",
+ "format": 1
+ },
+ {
+ "name": "README.md",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "02b63d779ec8985281e1e2858d00bbdb919e5517aad637e8634d1971f8530cfd",
+ "format": 1
+ },
+ {
+ "name": "COPYING",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "3972dc9744f6499f0f9b2dbf76696f2ae7ad8af9b23dde66d6af86c9dfb36986",
+ "format": 1
+ },
+ {
+ "name": "CHANGELOG.rst",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "479e7ae0fd077a8adcb801df27be0773976b4058c658fb3a1a79b1a9e4d06221",
+ "format": 1
+ }
+ ],
+ "format": 1
+} \ No newline at end of file
diff --git a/ansible_collections/infoblox/nios_modules/MANIFEST.json b/ansible_collections/infoblox/nios_modules/MANIFEST.json
new file mode 100644
index 00000000..166a335c
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/MANIFEST.json
@@ -0,0 +1,38 @@
+{
+ "collection_info": {
+ "namespace": "infoblox",
+ "name": "nios_modules",
+ "version": "1.4.1",
+ "authors": [
+ "Sailesh Giri (sgiri@infoblox.com)",
+ "Vaishnavi TR (vtr@infoblox.com)",
+ "Anagha KH (akh@infoblox.com)",
+ "Shankar Ganesh (sganesh@infoblox.com)"
+ ],
+ "readme": "README.md",
+ "tags": [
+ "infoblox",
+ "nios",
+ "cloud",
+ "networking"
+ ],
+ "description": "Infoblox Ansible Collection for vNIOS allows managing your NIOS objects through APIs.",
+ "license": [
+ "GPL-3.0-only"
+ ],
+ "license_file": null,
+ "dependencies": {},
+ "repository": "https://github.com/infobloxopen/infoblox-ansible/tree/master",
+ "documentation": "https://github.com/infobloxopen/infoblox-ansible/blob/master/README.md",
+ "homepage": "https://github.com/infobloxopen/infoblox-ansible",
+ "issues": "https://github.com/infobloxopen/infoblox-ansible/issues"
+ },
+ "file_manifest_file": {
+ "name": "FILES.json",
+ "ftype": "file",
+ "chksum_type": "sha256",
+ "chksum_sha256": "322c0c8f3d92585641eade44b5d87df7c96cc3ee1b0a913a54732b73f325ba6f",
+ "format": 1
+ },
+ "format": 1
+} \ No newline at end of file
diff --git a/ansible_collections/infoblox/nios_modules/README.md b/ansible_collections/infoblox/nios_modules/README.md
new file mode 100644
index 00000000..131aaa2b
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/README.md
@@ -0,0 +1,209 @@
+# Infoblox NIOS Modules for Ansible Collections
+
+About
+======
+
+Infoblox NIOS Modules for Ansible Collections allows managing your NIOS objects
+through APIs.
+It, thus, enables the DNS and IPAM automation of VM workloads that are
+deployed across multiple platforms. The `nios_modules` collection
+provides modules and plugins for managing the networks, IP addresses,
+and DNS records in NIOS. This collection is hosted on Ansible Galaxy
+under `infoblox.nios_modules`.
+
+Modules Overview
+=================
+
+The `infoblox.nios_modules` collection has the following content:
+
+Modules
+--------
+
+- `nios_a_record` – Configure Infoblox NIOS A records
+
+- `nios_aaaa_record` – Configure Infoblox NIOS AAAA records
+
+- `nios_cname_record` – Configure Infoblox NIOS CNAME records
+
+- `nios_dns_view` – Configure Infoblox NIOS DNS views
+
+- `nios_dtc_lbdn` – Configure Infoblox NIOS DTC LBDN records
+
+- `nios_dtc_pool` – Configure Infoblox NIOS DTC pools
+
+- `nios_dtc_server` – Configure Infoblox NIOS DTC server records
+
+- `nios_fixed_address` – Configure Infoblox NIOS DHCP Fixed Address
+
+- `nios_host_record` – Configure Infoblox NIOS host records
+
+- `nios_member` – Configure Infoblox NIOS members
+
+- `nios_mx_record` – Configure Infoblox NIOS MX records
+
+- `nios_naptr_record` – Configure Infoblox NIOS NAPTR records
+
+- `nios_network` – Configure Infoblox NIOS network object
+
+- `nios_network_view` – Configure Infoblox NIOS network views
+
+- `nios_nsgroup` – Configure Infoblox DNS Nameserver Groups
+
+- `nios_ptr_record` – Configure Infoblox NIOS PTR records
+
+- `nios_restartservices` - Controlled restart of Infoblox NIOS services
+
+- `nios_srv_record` – Configure Infoblox NIOS SRV records
+
+- `nios_txt_record` – Configure Infoblox NIOS txt records
+
+- `nios_zone` – Configure Infoblox NIOS DNS zones
+
+Plugins
+--------
+
+- `nios_inventory`: List all the hosts with records created in NIOS
+
+- `nios_lookup`: Look up queries for NIOS database objects
+
+- `nios_next_ip`: Returns the next available IP address for a network
+
+- `nios_next_network`: Returns the next available network addresses
+ for a given network CIDR
+
+Installation
+=============
+
+Dependencies
+------------
+
+- Python version 2.7 or later
+
+- Ansible version 2.9.0 or later
+
+- NIOS 8.2.4 or later
+
+Prerequisites
+-------------
+
+Install the infoblox-client WAPI package. To install, run the following command:
+
+```shell
+$ pip install infoblox-client
+```
+
+Installation of nios_modules Collection
+----------------------------------------
+
+The `nios_modules` collection can be installed either from Ansible Galaxy
+or directly from git. It is recommended to install collections from
+Ansible Galaxy as those are more stable than the ones in the git
+branch.
+
+### Installation from Ansible Galaxy
+- To directly install the `nios_modules` collection from [Ansible Galaxy](https://galaxy.ansible.com/infoblox/nios_modules), run the following command:
+ - ```
+ $ ansible-galaxy collection install infoblox.nios_modules
+ ```
+ - The collection folder would be installed at
+ ```
+ ~/.ansible/collections/ansible_collections/infoblox/nios_modules
+ ```
+
+- For offline installation on the Ansible control machine, download the required tar archive version of the collection from [Infoblox Nios Modules collections](https://galaxy.ansible.com/infoblox/nios_modules) and run the command given below in `~/.ansible` directory:
+ - ```
+ $ ansible-galaxy collection install infoblox-nios_modules-<version>.tar.gz -p ./collections
+ ```
+
+### Installation from GitHub
+- Install the collection directly from the [GitHub](https://github.com/infobloxopen/infoblox-ansible) repository using the latest commit on the master branch:
+ - ```
+ $ ansible-galaxy collection install git+https://github.com/infobloxopen/infoblox-ansible.git,master
+ ```
+
+- For offline installation on the Ansible control machine, to git clone and install from this repo, follow these steps:
+
+ - **Clone the repo:**
+
+ ```
+ $ git clone https://github.com/infobloxopen/infoblox-ansible.git
+ ```
+
+ - **Build the collection:**
+
+ To build a collection, run the following command from inside the
+ root directory of the collection:
+ ```
+ $ ansible-galaxy collection build
+ ```
+ This creates a tarball of the built collection in the current directory.
+
+ - **Install the collection:**
+
+ ```
+ $ ansible-galaxy collection install infoblox-nios_modules-<version>.tar.gz -p ./collections
+ ```
+
+Please refer to our Ansible [deployment
+guide](https://www.infoblox.com/wp-content/uploads/infoblox-deployment-guide-automate-infoblox-infrastructure-using-ansible.pdf)
+for more details.
+
+Playbooks
+=========
+Latest sample playbooks and examples are available at [playbooks](https://github.com/infobloxopen/infoblox-ansible/tree/master/playbooks).
+
+
+Releasing
+=========
+
+Next release
+---------------
+
+Dates TBD
+
+Current release
+---------------
+
+1.4.1 on 24 November 2022
+
+Versioning
+=========
+
+- galaxy.yml in the master branch will always contain the version of the current major or minor release. It will be updated right after a release.
+- version_added needs to be used for every new feature and module/plugin, and needs to coincide with the next minor/major release version. (This will eventually be enforced by CI.)
+
+Deprecation
+===========
+- Deprecations are done by version number (not by date).
+- New deprecations can be added during every minor release, under the condition that they do not break backward compatibility.
+
+Contributing
+============
+We welcome your contributions to Infoblox Nios Modules. See
+[CONTRIBUTING.md](https://github.com/infobloxopen/infoblox-ansible/blob/master/CONTRIBUTING.md) for
+more details.
+
+Resources
+=========
+
+- Infoblox [NIOS
+ modules](https://docs.ansible.com/ansible/latest/scenario_guides/guide_infoblox.html)
+ on Ansible documentation
+
+- Infoblox [workspace](https://galaxy.ansible.com/infoblox) in Ansible
+ Galaxy
+
+- Infoblox Ansible [deployment
+ guide](https://www.infoblox.com/wp-content/uploads/infoblox-deployment-guide-automate-infoblox-infrastructure-using-ansible.pdf)
+
+License
+=======
+
+This code is published under `GPL v3.0`
+
+[COPYING](https://github.com/infobloxopen/infoblox-ansible/blob/master/COPYING)
+
+Issues or RFEs
+===============
+You can open an issue or request for enhancement
+[here](https://github.com/infobloxopen/infoblox-ansible/issues)
diff --git a/ansible_collections/infoblox/nios_modules/changelogs/.plugin-cache.yaml b/ansible_collections/infoblox/nios_modules/changelogs/.plugin-cache.yaml
new file mode 100644
index 00000000..4eba71a2
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/changelogs/.plugin-cache.yaml
@@ -0,0 +1,131 @@
+plugins:
+ become: {}
+ cache: {}
+ callback: {}
+ cliconf: {}
+ connection: {}
+ httpapi: {}
+ inventory:
+ nios_inventory:
+ description: Infoblox inventory plugin
+ name: nios_inventory
+ version_added: 1.0.0
+ lookup:
+ nios_lookup:
+ description: Query Infoblox NIOS objects
+ name: nios_lookup
+ version_added: 1.0.0
+ nios_next_ip:
+ description: Return the next available IP address for a network
+ name: nios_next_ip
+ version_added: 1.0.0
+ nios_next_network:
+ description: Return the next available network range for a network-container
+ name: nios_next_network
+ version_added: 1.0.0
+ module:
+ nios_a_record:
+ description: Configure Infoblox NIOS A records
+ name: nios_a_record
+ namespace: ''
+ version_added: 1.0.0
+ nios_aaaa_record:
+ description: Configure Infoblox NIOS AAAA records
+ name: nios_aaaa_record
+ namespace: ''
+ version_added: 1.0.0
+ nios_cname_record:
+ description: Configure Infoblox NIOS CNAME records
+ name: nios_cname_record
+ namespace: ''
+ version_added: 1.0.0
+ nios_dns_view:
+ description: Configure Infoblox NIOS DNS views
+ name: nios_dns_view
+ namespace: ''
+ version_added: 1.0.0
+ nios_dtc_lbdn:
+ description: Configure Infoblox NIOS DTC LBDN
+ name: nios_dtc_lbdn
+ namespace: ''
+ version_added: 1.1.0
+ nios_dtc_pool:
+ description: Configure Infoblox NIOS DTC Pool
+ name: nios_dtc_pool
+ namespace: ''
+ version_added: 1.1.0
+ nios_dtc_server:
+ description: Configure Infoblox NIOS DTC Server
+ name: nios_dtc_server
+ namespace: ''
+ version_added: 1.1.0
+ nios_fixed_address:
+ description: Configure Infoblox NIOS DHCP Fixed Address
+ name: nios_fixed_address
+ namespace: ''
+ version_added: 1.0.0
+ nios_host_record:
+ description: Configure Infoblox NIOS host records
+ name: nios_host_record
+ namespace: ''
+ version_added: 1.0.0
+ nios_member:
+ description: Configure Infoblox NIOS members
+ name: nios_member
+ namespace: ''
+ version_added: 1.0.0
+ nios_mx_record:
+ description: Configure Infoblox NIOS MX records
+ name: nios_mx_record
+ namespace: ''
+ version_added: 1.0.0
+ nios_naptr_record:
+ description: Configure Infoblox NIOS NAPTR records
+ name: nios_naptr_record
+ namespace: ''
+ version_added: 1.0.0
+ nios_network:
+ description: Configure Infoblox NIOS network object
+ name: nios_network
+ namespace: ''
+ version_added: 1.0.0
+ nios_network_view:
+ description: Configure Infoblox NIOS network views
+ name: nios_network_view
+ namespace: ''
+ version_added: 1.0.0
+ nios_nsgroup:
+ description: Configure InfoBlox DNS Nameserver Groups
+ name: nios_nsgroup
+ namespace: ''
+ version_added: 1.0.0
+ nios_ptr_record:
+ description: Configure Infoblox NIOS PTR records
+ name: nios_ptr_record
+ namespace: ''
+ version_added: 1.0.0
+ nios_restartservices:
+ description: Restart grid services.
+ name: nios_restartservices
+ namespace: ''
+ version_added: 1.1.0
+ nios_srv_record:
+ description: Configure Infoblox NIOS SRV records
+ name: nios_srv_record
+ namespace: ''
+ version_added: 1.0.0
+ nios_txt_record:
+ description: Configure Infoblox NIOS txt records
+ name: nios_txt_record
+ namespace: ''
+ version_added: 1.0.0
+ nios_zone:
+ description: Configure Infoblox NIOS DNS zones
+ name: nios_zone
+ namespace: ''
+ version_added: 1.0.0
+ netconf: {}
+ shell: {}
+ strategy: {}
+ vars: {}
+version: 1.4.1
diff --git a/ansible_collections/infoblox/nios_modules/changelogs/changelog.yaml b/ansible_collections/infoblox/nios_modules/changelogs/changelog.yaml
new file mode 100644
index 00000000..7c752c2c
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/changelogs/changelog.yaml
@@ -0,0 +1,200 @@
+ancestor: null
+releases:
+ 1.0.0:
+ changes:
+ release_summary: 'First release of the `nios_modules` collection! This release
+ includes multiple plugins:- an `api` plugin, a `network` plugin, a `nios`
+ plugin, a `nios_inventory` plugin, a `lookup plugin`, a `nios_next_ip` plugin,
+ a `nios_next_network` plugin '
+ modules:
+ - description: Configure Infoblox NIOS A records
+ name: nios_a_record
+ namespace: ''
+ - description: Configure Infoblox NIOS AAAA records
+ name: nios_aaaa_record
+ namespace: ''
+ - description: Configure Infoblox NIOS CNAME records
+ name: nios_cname_record
+ namespace: ''
+ - description: Configure Infoblox NIOS DNS views
+ name: nios_dns_view
+ namespace: ''
+ - description: Configure Infoblox NIOS DHCP Fixed Address
+ name: nios_fixed_address
+ namespace: ''
+ - description: Configure Infoblox NIOS host records
+ name: nios_host_record
+ namespace: ''
+ - description: Configure Infoblox NIOS members
+ name: nios_member
+ namespace: ''
+ - description: Configure Infoblox NIOS MX records
+ name: nios_mx_record
+ namespace: ''
+ - description: Configure Infoblox NIOS NAPTR records
+ name: nios_naptr_record
+ namespace: ''
+ - description: Configure Infoblox NIOS network object
+ name: nios_network
+ namespace: ''
+ - description: Configure Infoblox NIOS network views
+ name: nios_network_view
+ namespace: ''
+ - description: Configure Infoblox NIOS Nameserver Groups
+ name: nios_nsgroup
+ namespace: ''
+ - description: Configure Infoblox NIOS PTR records
+ name: nios_ptr_record
+ namespace: ''
+ - description: Configure Infoblox NIOS SRV records
+ name: nios_srv_record
+ namespace: ''
+ - description: Configure Infoblox NIOS txt records
+ name: nios_txt_record
+ namespace: ''
+ - description: Configure Infoblox NIOS DNS zones
+ name: nios_zone
+ namespace: ''
+ plugins:
+ lookup:
+ - description: Query Infoblox NIOS objects
+ name: nios
+ namespace: null
+ - description: Return the next available IP address for a network
+ name: nios_next_ip
+ namespace: null
+ - description: Return the next available network range for a network-container
+ name: nios_next_network
+ namespace: null
+ release_date: '2020-10-23'
+ 1.0.1:
+ changes:
+ minor_changes:
+ - Made it compatible for Ansible v3.0.0
+ release_summary: This release provides compatibilty for Ansible v3.0.0
+ release_date: '2021-01-25'
+ 1.0.2:
+ changes:
+ minor_changes:
+ - Fixed the ignored sanity errors required for Ansible 3.0.0 collection
+ - Made it compatible for Ansible v3.0.0
+ release_summary: This release provides compatibilty for Ansible v3.0.0
+ release_date: '2021-01-27'
+ 1.1.0:
+ changes:
+ release_summary: This release provides plugins for NIOS DTC
+ modules:
+ - description: Configure Infoblox NIOS DTC LBDN
+ name: nios_dtc_lbdn
+ namespace: ''
+ - description: Configure Infoblox NIOS DTC Pool
+ name: nios_dtc_pool
+ namespace: ''
+ - description: Configure Infoblox NIOS DTC Server
+ name: nios_dtc_server
+ namespace: ''
+ - description: Restart grid services.
+ name: nios_restartservices
+ namespace: ''
+ release_date: '2021-04-12'
+ 1.1.1:
+ changes:
+ bugfixes:
+ - Implemented the bugfixes provided by Ansible `community.general`
+ - Update the name of existing A and AAAA records `#70 <https://github.com/infobloxopen/infoblox-ansible/pull/70>`_
+ - Update of comment field of SRV, PTR and NAPTR records failing with the following error `#70 <https://github.com/infobloxopen/infoblox-ansible/pull/70>`_
+ - PTR Record failed to update and raises KeyError for view field `#70 <https://github.com/infobloxopen/infoblox-ansible/pull/70>`_
+ - Update comment field and delete an existing Fixed Address `#73 <https://github.com/infobloxopen/infoblox-ansible/pull/73>`_
+ - GitHub issue fix - Lookup module for next available IPV6 `#31 <https://github.com/infobloxopen/infoblox-ansible/issues/31>`_
+ - GitHub issue fix - [nios_zone] changing a nios_zone does not work `#60 <https://github.com/infobloxopen/infoblox-ansible/issues/60>`_
+ - GitHub issue fix - Getting an error, running every module `#67 <https://github.com/infobloxopen/infoblox-ansible/issues/67>`_
+ - GitHub issue fix - Error - Dictionary Issues `#68 <https://github.com/infobloxopen/infoblox-ansible/issues/68>`_
+ - GitHub issue fix - Examples for lookups don't work as written `#72 <https://github.com/infobloxopen/infoblox-ansible/issues/72>`_
+ - Sanity fixes as per Ansible guidelines to all modules
+ minor_changes:
+ - The modules are standardized as per Ansible guidelines
+ release_summary: 'Support for creating IPv6 Fixed Address with DUID,
+ Support added to return the next available IP address for an IPv6 network,
+ Modules made compatible to work with ansible-core 2.11,
+ Issue fixes and standardization of modules as per Ansible guidelines'
+ release_date: '2021-09-07'
+ 1.1.2:
+ changes:
+ bugfixes:
+ - Handle NoneType parsing in nios_inventory.py `#81 <https://github.com/infobloxopen/infoblox-ansible/pull/81>`_
+ - Check all dhcp options, not just first one `#83 <https://github.com/infobloxopen/infoblox-ansible/pull/83>`_
+ minor_changes:
+ - Changes in inventory and lookup plugins documentation `#85 <https://github.com/infobloxopen/infoblox-ansible/pull/85>`_
+ - Directory restructure and added integration & unit tests `#87 <https://github.com/infobloxopen/infoblox-ansible/pull/87>`_
+ release_summary: 'Issue fixes and standardization of inventory plugin and lookup modules as per Ansible guidelines,
+ Directory restructure and added integration & unit tests'
+ release_date: '2021-10-12'
+ 1.2.0:
+ changes:
+ bugfixes:
+ - nios_a_record module - KeyError 'old_ipv4addr' `#79 <https://github.com/infobloxopen/infoblox-ansible/issues/79>`_
+ - Ansible playbook fails to update canonical name of CName Record `#97 <https://github.com/infobloxopen/infoblox-ansible/pull/97>`_
+ minor_changes:
+ - Updated 'required' field in modules `#99 <https://github.com/infobloxopen/infoblox-ansible/pull/99>`_
+ - Following options are made required in the modules
+ | Record | Option made required |
+ | ------ | -------------------- |
+ | A | ipv4addr |
+ | AAAA | ipv6addr |
+ | CNAME | canonical |
+ | MX | mail_exchanger, preference |
+ | PTR | ptrdname |
+ release_summary: 'Issue fixes to update A Record using `next_available_ip` function,
+ Added a new feature - Update canonical name of the CNAME Record,
+ Updated the `required` fields in modules'
+ release_date: '2021-12-13'
+ 1.2.1:
+ changes:
+ minor_changes:
+ - Added tags 'cloud' and 'networking' in 'galaxy.yaml'
+ release_summary: 'Added tags to support release on Ansible Automation Hub'
+ release_date: '2021-12-20'
+
+ 1.2.2:
+ changes:
+ minor_changes:
+ - Fix to create PTR record in different network views `#103 <https://github.com/infobloxopen/infoblox-ansible/pull/103>`_
+ - Remove use_option for DHCP option 60 `#104 <https://github.com/infobloxopen/infoblox-ansible/pull/104>`_
+ - Allow specifying a template when creating a network `#105 <https://github.com/infobloxopen/infoblox-ansible/pull/105>`_
+ - Fix unit and sanity test issues `#117 <https://github.com/infobloxopen/infoblox-ansible/pull/117>`_
+ - Expanding for disable value `#119 <https://github.com/infobloxopen/infoblox-ansible/pull/119>`_
+ release_summary: 'Issue fixes to create PTR record in different network views,
+ Support extended to determine whether the DTC server is disabled or not'
+ release_date: '2022-05-23'
+ 1.3.0:
+ changes:
+ major_changes:
+ - Update operation using `old_name` and `new_name` for the object with dummy name in `old_name` (which does not exist in system) will not create a new object in the system. An error will be thrown stating the object does not exist in the system `#129 <https://github.com/infobloxopen/infoblox-ansible/pull/129>`_
+ - Update `text` field of TXT Record `#128 <https://github.com/infobloxopen/infoblox-ansible/pull/128>`_
+ bugfixes:
+ - Fix to create TXT record with equals sign `#128 <https://github.com/infobloxopen/infoblox-ansible/pull/128>`_
+ release_summary: 'Issue fixes to create TXT record with equals sign,
+ For nonexistent record, update operation creates the new record,
+ For nonexistent IPv4Address, update operation creates a new A record with new_ipv4addr'
+ release_date: '2022-07-01'
+ 1.4.0:
+ changes:
+ major_changes:
+ - Feature for extra layer security , with `cert` and `key` parameters in playbooks for authenticating using certificate and key ``*.pem`` file absolute path `#154 <https://github.com/infobloxopen/infoblox-ansible/pull/154>`_
+ - Fix to remove issue causing due to template attr in deleting network using Ansible module nios network `#147 <https://github.com/infobloxopen/infoblox-ansible/pull/147>`_
+ release_summary: 'For ansible module, added certificate authentication feature,
+ Few bugs fix in ansible module nios network'
+ release_date: '2022-10-12'
+ 1.4.1:
+ changes:
+ minor_changes:
+ - Fix to specify network_view in lookup modules to return absolute network and ip `#157 <https://github.com/infobloxopen/infoblox-ansible/pull/157>`_
+ - Fix to camelcase issue for updating 'nios_network_view' name `#163 <https://github.com/infobloxopen/infoblox-ansible/pull/163>`_
+ - Fix to allocate ip to a_record dynamically `#163 <https://github.com/infobloxopen/infoblox-ansible/pull/163>`_
+ - Fix to update 'nios_a_record' name with multiple ips having same name `#164 <https://github.com/infobloxopen/infoblox-ansible/pull/164>`_
+ - Fix to changelog yaml file with linting issues `#161 <https://github.com/infobloxopen/infoblox-ansible/pull/161>`_
+ release_summary: 'Ansible Lookup modules can specify network_view to which a network/ip belongs,
+ Fixes camelCase issue while updating `nios_network_view` with `new_name`,
+ Fixes issue to allocate ip to a_record dynamically,
+ Updates `nios_a_record` name with multiple ips having same name'
+ release_date: '2022-11-24'
diff --git a/ansible_collections/infoblox/nios_modules/changelogs/config.yaml b/ansible_collections/infoblox/nios_modules/changelogs/config.yaml
new file mode 100644
index 00000000..09a1f378
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/changelogs/config.yaml
@@ -0,0 +1,32 @@
+changelog_filename_template: ../CHANGELOG.rst
+changelog_filename_version_depth: 0
+changes_file: changelog.yaml
+changes_format: combined
+ignore_other_fragment_extensions: true
+keep_fragments: false
+mention_ancestor: true
+new_plugins_after_name: removed_features
+notesdir: fragments
+prelude_section_name: release_summary
+prelude_section_title: Release Summary
+sanitize_changelog: true
+sections:
+- - major_changes
+ - Major Changes
+- - minor_changes
+ - Minor Changes
+- - breaking_changes
+ - Breaking Changes / Porting Guide
+- - deprecated_features
+ - Deprecated Features
+- - removed_features
+ - Removed Features (previously deprecated)
+- - security_fixes
+ - Security Fixes
+- - bugfixes
+ - Bugfixes
+- - known_issues
+ - Known Issues
+title: Infoblox.Nios_Modules
+trivial_section_name: trivial
+use_fqcn: true
diff --git a/ansible_collections/infoblox/nios_modules/meta/runtime.yml b/ansible_collections/infoblox/nios_modules/meta/runtime.yml
new file mode 100644
index 00000000..2ee3c9fa
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/meta/runtime.yml
@@ -0,0 +1,2 @@
+---
+requires_ansible: '>=2.9.10'
diff --git a/ansible_collections/infoblox/nios_modules/playbooks/create_a_record.yaml b/ansible_collections/infoblox/nios_modules/playbooks/create_a_record.yaml
new file mode 100644
index 00000000..29245981
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/playbooks/create_a_record.yaml
@@ -0,0 +1,19 @@
+---
+
+- hosts: localhost
+ vars:
+ nios_provider:
+ host: 10.36.118.2
+ username: cloudadmin
+ password: admin
+
+ connection: local
+ tasks:
+ - name: Create Nios A record Test
+ infoblox.nios_modules.nios_a_record:
+ name: v55.ansibletestzone.com
+ view: ansibleDnsView
+ ipv4: 192.168.11.251
+ comment: Created with Ansible
+ state: present
+ provider: "{{ nios_provider }}"
diff --git a/ansible_collections/infoblox/nios_modules/playbooks/create_cname_record.yaml b/ansible_collections/infoblox/nios_modules/playbooks/create_cname_record.yaml
new file mode 100644
index 00000000..1c59c7a6
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/playbooks/create_cname_record.yaml
@@ -0,0 +1,19 @@
+---
+
+- hosts: localhost
+ vars:
+ nios_provider:
+ host: 10.36.118.2
+ username: cloudadmin
+ password: admin
+
+ connection: local
+ tasks:
+ - name: Create Nios CNAME record
+ infoblox.nios_modules.nios_cname_record:
+ name: cname.ansibletestzone.com
+ canonical: realhost.ansible.com
+ view: ansibleDnsView
+ comment: Created with Ansible
+ state: present
+ provider: "{{ nios_provider }}"
diff --git a/ansible_collections/infoblox/nios_modules/playbooks/create_dns_view.yml b/ansible_collections/infoblox/nios_modules/playbooks/create_dns_view.yml
new file mode 100644
index 00000000..834a7c9a
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/playbooks/create_dns_view.yml
@@ -0,0 +1,20 @@
+---
+
+- hosts: localhost
+ vars:
+ nios_provider:
+ host: 10.36.118.2
+ username: cloudadmin
+ password: admin
+
+ connection: local
+ tasks:
+ - name: create DNS view
+ infoblox.nios_modules.nios_dns_view:
+ name: ansibleDnsView
+ network_view: ansibleCollectionsView
+ extattrs:
+ Site: Test Site
+ comment: Created with Ansible
+ state: present
+ provider: "{{ nios_provider }}"
diff --git a/ansible_collections/infoblox/nios_modules/playbooks/create_dtc_lbdn.yml b/ansible_collections/infoblox/nios_modules/playbooks/create_dtc_lbdn.yml
new file mode 100644
index 00000000..9cbf3ad2
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/playbooks/create_dtc_lbdn.yml
@@ -0,0 +1,29 @@
+---
+- hosts: localhost
+ vars:
+ nios_provider:
+ host: 10.196.205.10
+ username: cloudadmin
+ password: infoblox
+ wapi_version: "2.12"
+
+ connection: local
+ tasks:
+ - name: 'create DTC LBDN'
+ infoblox.nios_modules.nios_dtc_lbdn:
+ name: LBDN1
+ lb_method: GLOBAL_AVAILABILITY
+ pools:
+ - pool: Pool1
+ ratio: 2
+ ttl: 100
+ auth_zones:
+ - 'demo.com'
+ patterns:
+ - '*.demo.com'
+ types:
+ - A
+ comment: Created with Ansible
+ state: present
+ provider: "{{ nios_provider }}"
+...
diff --git a/ansible_collections/infoblox/nios_modules/playbooks/create_dtc_pool.yml b/ansible_collections/infoblox/nios_modules/playbooks/create_dtc_pool.yml
new file mode 100644
index 00000000..96a59f29
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/playbooks/create_dtc_pool.yml
@@ -0,0 +1,25 @@
+---
+- hosts: localhost
+ vars:
+ nios_provider:
+ host: 10.196.205.10
+ username: cloudadmin
+ password: infoblox
+ wapi_version: "2.12"
+
+ connection: local
+ tasks:
+ - name: 'create DTC Pool'
+ infoblox.nios_modules.nios_dtc_pool:
+ name: Pool1
+ lb_preferred_method: ROUND_ROBIN
+ servers:
+ - server: Server1
+ ratio: 1
+ monitors:
+ - name: monitor1
+ type: icmp
+ comment: Created with Ansible
+ state: present
+ provider: "{{ nios_provider }}"
+...
diff --git a/ansible_collections/infoblox/nios_modules/playbooks/create_dtc_server.yml b/ansible_collections/infoblox/nios_modules/playbooks/create_dtc_server.yml
new file mode 100644
index 00000000..dd0c0388
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/playbooks/create_dtc_server.yml
@@ -0,0 +1,19 @@
+---
+- hosts: localhost
+ vars:
+ nios_provider:
+ host: 10.196.205.10
+ username: cloudadmin
+ password: infoblox
+ wapi_version: "2.12"
+
+ connection: local
+ tasks:
+ - name: 'create DTC server'
+ infoblox.nios_modules.nios_dtc_server:
+ name: Server1
+ host: 10.196.200.74
+ comment: Created with Ansible
+ state: present
+ provider: "{{ nios_provider }}"
+...
diff --git a/ansible_collections/infoblox/nios_modules/playbooks/create_mx_record.yaml b/ansible_collections/infoblox/nios_modules/playbooks/create_mx_record.yaml
new file mode 100644
index 00000000..ac8c8f34
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/playbooks/create_mx_record.yaml
@@ -0,0 +1,20 @@
+---
+
+- hosts: localhost
+ vars:
+ nios_provider:
+ host: 10.36.118.2
+ username: cloudadmin
+ password: admin
+
+ connection: local
+ tasks:
+ - name: Create Nios MX record
+ infoblox.nios_modules.nios_mx_record:
+ name: mx.ansibletestzone.com
+ mx: mailhost.ansible.com
+ view: ansibleDnsView
+ preference: 0
+ comment: Created with Ansible
+ state: present
+ provider: "{{ nios_provider }}"
diff --git a/ansible_collections/infoblox/nios_modules/playbooks/create_network.yml b/ansible_collections/infoblox/nios_modules/playbooks/create_network.yml
new file mode 100644
index 00000000..c309105f
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/playbooks/create_network.yml
@@ -0,0 +1,23 @@
+---
+
+- hosts: localhost
+ vars:
+ nios_provider:
+ host: 10.36.118.2
+ username: cloudadmin
+ password: admin
+
+ connection: local
+ tasks:
+ - name: create network
+ infoblox.nios_modules.nios_network:
+ network: 10.0.0.0/24
+ network_view: ansibleCollectionsView
+ options:
+ - name: domain-name
+ value: infoblox-ansible.com
+ extattrs:
+ Site: Test Site
+ comment: Created with Ansible
+ state: present
+ provider: "{{ nios_provider }}"
diff --git a/ansible_collections/infoblox/nios_modules/playbooks/create_network_view.yml b/ansible_collections/infoblox/nios_modules/playbooks/create_network_view.yml
new file mode 100644
index 00000000..ca372187
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/playbooks/create_network_view.yml
@@ -0,0 +1,19 @@
+---
+
+- hosts: localhost
+ vars:
+ nios_provider:
+ host: 10.36.118.2
+ username: cloudadmin
+ password: admin
+
+ connection: local
+ tasks:
+ - name: create network view
+ infoblox.nios_modules.nios_network_view:
+ name: ansibleCollectionsView
+ extattrs:
+ Site: Test Site
+ comment: Created with Ansible
+ state: present
+ provider: "{{ nios_provider }}"
diff --git a/ansible_collections/infoblox/nios_modules/playbooks/create_txt_record.yaml b/ansible_collections/infoblox/nios_modules/playbooks/create_txt_record.yaml
new file mode 100644
index 00000000..d0a28058
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/playbooks/create_txt_record.yaml
@@ -0,0 +1,19 @@
+---
+
+- hosts: localhost
+ vars:
+ nios_provider:
+ host: 10.36.118.2
+ username: cloudadmin
+ password: admin
+
+ connection: local
+ tasks:
+ - name: Create Nios TXT record
+ infoblox.nios_modules.nios_txt_record:
+ name: one.txt.ansibletestzone.com
+ text: example_text45
+ view: ansibleDnsView
+ comment: Created with Ansible
+ state: present
+ provider: "{{ nios_provider }}"
diff --git a/ansible_collections/infoblox/nios_modules/playbooks/create_zone.yml b/ansible_collections/infoblox/nios_modules/playbooks/create_zone.yml
new file mode 100644
index 00000000..63b874e2
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/playbooks/create_zone.yml
@@ -0,0 +1,21 @@
+---
+
+- hosts: localhost
+ vars:
+ nios_provider:
+ host: 10.36.118.2
+ username: cloudadmin
+ password: admin
+ wapi_version: 2.1
+
+ connection: local
+ tasks:
+ - name: create zone
+ infoblox.nios_modules.nios_zone:
+ name: ansibletestzone.com
+ view: ansibleDnsView
+ extattrs:
+ Site: Test Site
+ comment: Created with Ansible
+ state: present
+ provider: "{{ nios_provider }}"
diff --git a/ansible_collections/infoblox/nios_modules/playbooks/delete_cname_record.yaml b/ansible_collections/infoblox/nios_modules/playbooks/delete_cname_record.yaml
new file mode 100644
index 00000000..50c55105
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/playbooks/delete_cname_record.yaml
@@ -0,0 +1,18 @@
+---
+
+- hosts: localhost
+ vars:
+ nios_provider:
+ host: 10.36.118.2
+ username: cloudadmin
+ password: admin
+
+ connection: local
+ tasks:
+ - name: Create Nios CNAME record
+ infoblox.nios_modules.nios_cname_record:
+ name: cname.ansible.com
+ canonical: realhost.ansible.com
+ comment: Created with Ansible
+ state: absent
+ provider: "{{ nios_provider }}"
diff --git a/ansible_collections/infoblox/nios_modules/playbooks/delete_dnsview.yml b/ansible_collections/infoblox/nios_modules/playbooks/delete_dnsview.yml
new file mode 100644
index 00000000..bb5e22a2
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/playbooks/delete_dnsview.yml
@@ -0,0 +1,17 @@
+---
+
+- hosts: localhost
+ vars:
+ nios_provider:
+ host: 10.36.118.2
+ username: cloudadmin
+ password: admin
+
+ connection: local
+ tasks:
+ - name: delete DNS view
+ infoblox.nios_modules.nios_dns_view:
+ name: ansibleDnsView
+ network_view: ansibleNetView
+ state: absent
+ provider: "{{ nios_provider }}"
diff --git a/ansible_collections/infoblox/nios_modules/playbooks/delete_mx_record.yaml b/ansible_collections/infoblox/nios_modules/playbooks/delete_mx_record.yaml
new file mode 100644
index 00000000..3b269a25
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/playbooks/delete_mx_record.yaml
@@ -0,0 +1,19 @@
+---
+
+- hosts: localhost
+ vars:
+ nios_provider:
+ host: 10.36.118.2
+ username: cloudadmin
+ password: admin
+
+ connection: local
+ tasks:
+ - name: Create Nios MX record
+ infoblox.nios_modules.nios_mx_record:
+ name: ansible.com
+ mx: mailhost.ansible.com
+ preference: 0
+ comment: Created with Ansible
+ state: absent
+ provider: "{{ nios_provider }}"
diff --git a/ansible_collections/infoblox/nios_modules/playbooks/delete_network.yml b/ansible_collections/infoblox/nios_modules/playbooks/delete_network.yml
new file mode 100644
index 00000000..304dccc0
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/playbooks/delete_network.yml
@@ -0,0 +1,17 @@
+---
+
+- hosts: localhost
+ vars:
+ nios_provider:
+ host: 10.60.27.4
+ username: admin
+ password: admin
+
+ connection: local
+ tasks:
+ - name: delete network
+ infoblox.nios_modules.nios_network:
+ network: 10.0.0.0/24
+ network_view: ansibleNetView
+ state: absent
+ provider: "{{ nios_provider }}"
diff --git a/ansible_collections/infoblox/nios_modules/playbooks/delete_network_view.yml b/ansible_collections/infoblox/nios_modules/playbooks/delete_network_view.yml
new file mode 100644
index 00000000..e0a7b119
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/playbooks/delete_network_view.yml
@@ -0,0 +1,16 @@
+---
+
+- hosts: localhost
+ vars:
+ nios_provider:
+ host: 10.60.27.4
+ username: cloudadmin
+ password: admin
+
+ connection: local
+ tasks:
+ - name: delete network view
+ infoblox.nios_modules.nios_network_view:
+ name: ansibleNetView
+ state: absent
+ provider: "{{ nios_provider }}"
diff --git a/ansible_collections/infoblox/nios_modules/playbooks/delete_txt_record.yaml b/ansible_collections/infoblox/nios_modules/playbooks/delete_txt_record.yaml
new file mode 100644
index 00000000..376e2973
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/playbooks/delete_txt_record.yaml
@@ -0,0 +1,19 @@
+---
+
+- hosts: localhost
+ vars:
+ nios_provider:
+ host: 10.36.118.2
+ username: cloudadmin
+ password: admin
+
+ connection: local
+ tasks:
+ - name: Create Nios TXT record
+ infoblox.nios_modules.nios_txt_record:
+ name: fqdn.txt.ansible.com
+ text: example_text
+ view: default
+ comment: Created with Ansible
+ state: absent
+ provider: "{{ nios_provider }}"
diff --git a/ansible_collections/infoblox/nios_modules/playbooks/delete_zone.yml b/ansible_collections/infoblox/nios_modules/playbooks/delete_zone.yml
new file mode 100644
index 00000000..ca50801a
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/playbooks/delete_zone.yml
@@ -0,0 +1,17 @@
+---
+
+- hosts: localhost
+ vars:
+ nios_provider:
+ host: 10.36.118.2
+ username: cloudadmin
+ password: admin
+
+ connection: local
+ tasks:
+ - name: delete zone
+ infoblox.nios_modules.nios_zone:
+ name: ansiblezone.com
+ view: ansibleDnsView
+ state: absent
+ provider: "{{ nios_provider }}"
diff --git a/ansible_collections/infoblox/nios_modules/playbooks/restart_services.yml b/ansible_collections/infoblox/nios_modules/playbooks/restart_services.yml
new file mode 100644
index 00000000..23bbe590
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/playbooks/restart_services.yml
@@ -0,0 +1,15 @@
+---
+- hosts: localhost
+ vars:
+ nios_provider:
+ host: 10.196.205.10
+ username: cloudadmin
+ password: infoblox
+ wapi_version: "2.12"
+
+ connection: local
+ tasks:
+ - name: Restart Services
+ nios_restartservices:
+ provider: "{{ nios_provider }}"
+...
diff --git a/ansible_collections/infoblox/nios_modules/playbooks/update_a_record.yml b/ansible_collections/infoblox/nios_modules/playbooks/update_a_record.yml
new file mode 100644
index 00000000..2630c3bb
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/playbooks/update_a_record.yml
@@ -0,0 +1,19 @@
+---
+
+- hosts: localhost
+ vars:
+ nios_provider:
+ host: 10.34.34.175
+ username: cloudadmin
+ password: admin
+
+ connection: local
+ tasks:
+ - name: Update Nios A record
+ infoblox.nios_modules.nios_a_record:
+ name: {new_name: v7.testzone.com, old_name: v7.testzone.com}
+ view: testDnsView
+ ipv4: 1.1.11.2
+ comment: Created with Ansible
+ state: present
+ provider: "{{ nios_provider }}"
diff --git a/ansible_collections/infoblox/nios_modules/plugins/README.md b/ansible_collections/infoblox/nios_modules/plugins/README.md
new file mode 100644
index 00000000..6541cf7c
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/README.md
@@ -0,0 +1,31 @@
+# Collections Plugins Directory
+
+This directory can be used to ship various plugins inside an Ansible collection. Each plugin is placed in a folder that
+is named after the type of plugin it is in. It can also include the `module_utils` and `modules` directory that
+would contain module utils and modules respectively.
+
+Here is an example directory of the majority of plugins currently supported by Ansible:
+
+```
+└── plugins
+ ├── action
+ ├── become
+ ├── cache
+ ├── callback
+ ├── cliconf
+ ├── connection
+ ├── filter
+ ├── httpapi
+ ├── inventory
+ ├── lookup
+ ├── module_utils
+ ├── modules
+ ├── netconf
+ ├── shell
+ ├── strategy
+ ├── terminal
+ ├── test
+ └── vars
+```
+
+A full list of plugin types can be found at [Working With Plugins](https://docs.ansible.com/ansible/2.9/plugins/plugins.html). \ No newline at end of file
diff --git a/ansible_collections/infoblox/nios_modules/plugins/doc_fragments/nios.py b/ansible_collections/infoblox/nios_modules/plugins/doc_fragments/nios.py
new file mode 100644
index 00000000..b0cf764a
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/doc_fragments/nios.py
@@ -0,0 +1,113 @@
+# -*- coding: utf-8 -*-
+
+# Copyright: (c) 2015, Peter Sprygada <psprygada@ansible.com>
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+
+class ModuleDocFragment(object):
+
+ # Standard files documentation fragment
+ DOCUMENTATION = r'''
+options:
+ provider:
+ description:
+ - A dict object containing connection details.
+ type: dict
+ suboptions:
+ host:
+ description:
+ - Specifies the DNS host name or address for connecting to the remote
+ instance of NIOS WAPI over REST
+ - Value can also be specified using C(INFOBLOX_HOST) environment
+ variable.
+ type: str
+ username:
+ description:
+ - Configures the username to use to authenticate the connection to
+ the remote instance of NIOS.
+ - Value can also be specified using C(INFOBLOX_USERNAME) environment
+ variable.
+ type: str
+ password:
+ description:
+ - Specifies the password to use to authenticate the connection to
+ the remote instance of NIOS.
+ - Value can also be specified using C(INFOBLOX_PASSWORD) environment
+ variable.
+ type: str
+ cert:
+ description:
+ - Specifies the client certificate file with digest of x509 config
+ for extra layer secure connection the remote instance of NIOS.
+ - Value can also be specified using C(INFOBLOX_CERT) environment
+ variable.
+ type: str
+ key:
+ description:
+ - Specifies private key file for encryption with the certificate
+ in order to connect with remote instance of NIOS.
+ - Value can also be specified using C(INFOBLOX_KEY) environment
+ variable.
+ type: str
+ validate_certs:
+ description:
+ - Boolean value to enable or disable verifying SSL certificates
+ - Value can also be specified using C(INFOBLOX_SSL_VERIFY) environment
+ variable.
+ type: bool
+ default: no
+ aliases: [ ssl_verify ]
+ http_request_timeout:
+ description:
+ - The amount of time before to wait before receiving a response
+ - Value can also be specified using C(INFOBLOX_HTTP_REQUEST_TIMEOUT) environment
+ variable.
+ type: int
+ default: 10
+ max_retries:
+ description:
+ - Configures the number of attempted retries before the connection
+ is declared usable
+ - Value can also be specified using C(INFOBLOX_MAX_RETRIES) environment
+ variable.
+ type: int
+ default: 3
+ wapi_version:
+ description:
+ - Specifies the version of WAPI to use
+ - Value can also be specified using C(INFOBLOX_WAP_VERSION) environment
+ variable.
+ - Until ansible 2.8 the default WAPI was 1.4
+ type: str
+ default: '2.1'
+ max_results:
+ description:
+ - Specifies the maximum number of objects to be returned,
+ if set to a negative number the appliance will return an error when the
+ number of returned objects would exceed the setting.
+ - Value can also be specified using C(INFOBLOX_MAX_RESULTS) environment
+ variable.
+ type: int
+ default: 1000
+ http_pool_maxsize:
+ description:
+ - Insert description here
+ type: int
+ default: 10
+ http_pool_connections:
+ description:
+ - Insert decription here
+ type: int
+ default: 10
+ silent_ssl_warnings:
+ description:
+ - Insert description here
+ type: bool
+ default: True
+notes:
+ - "This module must be run locally, which can be achieved by specifying C(connection: local)."
+ - Please read the :ref:`nios_guide` for more detailed information on how to use Infoblox with Ansible.
+
+'''
diff --git a/ansible_collections/infoblox/nios_modules/plugins/inventory/nios_inventory.py b/ansible_collections/infoblox/nios_modules/plugins/inventory/nios_inventory.py
new file mode 100644
index 00000000..f23c0273
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/inventory/nios_inventory.py
@@ -0,0 +1,107 @@
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+DOCUMENTATION = r'''
+ name: nios_inventory
+ author:
+ - Will Tome (@willtome)
+ short_description: Infoblox inventory plugin
+ version_added: "1.0.0"
+ description:
+ - This plugin allows you to query the Infoblox Grid for host records and
+ use the response data to populate the inventory file.
+ options:
+ host:
+ description:
+ - Specifies the DNS host name or address for connecting to the remote
+ instance of NIOS WAPI over REST.
+ - Value can also be specified using C(INFOBLOX_HOST) environment
+ variable.
+ type: string
+ required: True
+ env:
+ - name: INFOBLOX_HOST
+ username:
+ description:
+ - Configures the username to use to authenticate the connection to
+ the remote instance of NIOS.
+ - Value can also be specified using C(INFOBLOX_USERNAME) environment
+ variable.
+ type: string
+ required: True
+ env:
+ - name: INFOBLOX_USERNAME
+ password:
+ description:
+ - Specifies the password to use to authenticate the connection to
+ the remote instance of NIOS.
+ - Value can also be specified using C(INFOBLOX_PASSWORD) environment
+ variable.
+ type: string
+ env:
+ - name: INFOBLOX_PASSWORD
+ extattrs:
+ description:
+ - Allows you to filter the returned host record based on the
+ extensible attributes assigned to them.
+ default: {}
+ type: dict
+ hostfilter:
+ description:
+ - Accepts a key/value pair and uses it to filter the
+ host records to be returned.
+ default: {}
+ type: dict
+ requirements:
+ - python >= 3.4
+ - infoblox-client
+'''
+
+EXAMPLES = r'''
+plugin: infoblox.nios_modules.nios_inventory
+host: blox.example.com
+username: admin
+'''
+
+
+from ansible.plugins.inventory import BaseInventoryPlugin
+from ..module_utils.api import WapiInventory
+from ..module_utils.api import normalize_extattrs, flatten_extattrs
+from ansible.module_utils.six import iteritems
+from ansible.errors import AnsibleError
+
+
+class InventoryModule(BaseInventoryPlugin):
+ NAME = 'nios_inventory'
+
+ def parse(self, inventory, loader, path, cache=True): # Plugin interface (2)
+ super(InventoryModule, self).parse(inventory, loader, path)
+ self._read_config_data(path)
+
+ provider = {'host': self.get_option('host'),
+ 'username': self.get_option('username'),
+ 'password': self.get_option('password')}
+
+ wapi = WapiInventory(provider)
+
+ host_filter = self.get_option('hostfilter')
+ extattrs = normalize_extattrs(self.get_option('extattrs'))
+ return_fields = ['name', 'view', 'extattrs', 'ipv4addrs']
+
+ hosts = wapi.get_object('record:host', host_filter, extattrs=extattrs, return_fields=return_fields) or []
+
+ if not hosts:
+ raise AnsibleError("host record is not present")
+
+ for host in hosts:
+ group_name = self.inventory.add_group(host['view'])
+ host_name = self.inventory.add_host(host['name'])
+ self.inventory.add_child(group_name, host_name)
+
+ self.inventory.set_variable(host_name, 'view', host['view'])
+
+ for key, value in iteritems(flatten_extattrs(host['extattrs'])):
+ self.inventory.set_variable(host_name, key, value)
diff --git a/ansible_collections/infoblox/nios_modules/plugins/lookup/nios_lookup.py b/ansible_collections/infoblox/nios_modules/plugins/lookup/nios_lookup.py
new file mode 100644
index 00000000..c33b212f
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/lookup/nios_lookup.py
@@ -0,0 +1,112 @@
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+
+from __future__ import (absolute_import, division, print_function)
+
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+name: nios_lookup
+short_description: Query Infoblox NIOS objects
+version_added: "1.0.0"
+description:
+ - Uses the Infoblox WAPI API to fetch NIOS specified objects. This lookup
+ supports adding additional keywords to filter the return data and specify
+ the desired set of returned fields.
+requirements:
+ - infoblox-client
+
+options:
+ _terms:
+ description:
+ - The name of the network object to be returned from the Infoblox appliance.
+ required: True
+ type: str
+ return_fields:
+ description: The list of field names to return for the specified object.
+ type: list
+ elements: str
+ filter:
+ description: A dict object that is used to filter the returned objects.
+ type: dict
+ extattrs:
+ description: A dict object that is used to filter based on extensible attributes.
+ type: dict
+'''
+
+EXAMPLES = """
+- name: fetch all networkview objects
+ ansible.builtin.set_fact:
+ networkviews: "{{ lookup('infoblox.nios_modules.nios_lookup', 'networkview', provider={'host': 'nios01', 'username': 'admin', 'password': 'password'}) }}"
+
+- name: fetch the default dns view
+ ansible.builtin.set_fact:
+ dns_views: "{{ lookup('infoblox.nios_modules.nios_lookup', 'view', filter={'name': 'default'},
+ provider={'host': 'nios01', 'username': 'admin', 'password': 'password'}) }}"
+
+# all of the examples below use credentials that are set using env variables
+# export INFOBLOX_HOST=nios01
+# export INFOBLOX_USERNAME=admin
+# export INFOBLOX_PASSWORD=admin
+
+- name: fetch all host records and include extended attributes
+ ansible.builtin.set_fact:
+ host_records: "{{ lookup('infoblox.nios_modules.nios_lookup', 'record:host', return_fields=['extattrs', 'name', 'view', 'comment']}) }}"
+
+
+- name: use env variables to pass credentials
+ ansible.builtin.set_fact:
+ networkviews: "{{ lookup('infoblox.nios_modules.nios_lookup', 'networkview') }}"
+
+- name: get a host record
+ ansible.builtin.set_fact:
+ host: "{{ lookup('infoblox.nios_modules.nios_lookup', 'record:host', filter={'name': 'hostname.ansible.com'}) }}"
+
+- name: get the authoritative zone from a non default dns view
+ ansible.builtin.set_fact:
+ host: "{{ lookup('infoblox.nios_modules.nios_lookup', 'zone_auth', filter={'fqdn': 'ansible.com', 'view': 'ansible-dns'}) }}"
+"""
+
+RETURN = """
+obj_type:
+ description:
+ - The object type specified in the terms argument
+ returned: always
+ type: list
+ contains:
+ obj_field:
+ description:
+ - One or more obj_type fields as specified by return_fields argument or
+ the default set of fields as per the object type
+"""
+
+from ansible.plugins.lookup import LookupBase
+from ansible.errors import AnsibleError
+from ..module_utils.api import WapiLookup
+from ..module_utils.api import normalize_extattrs, flatten_extattrs
+
+
+class LookupModule(LookupBase):
+
+ def run(self, terms, variables=None, **kwargs):
+ try:
+ obj_type = terms[0]
+ except IndexError:
+ raise AnsibleError('the object_type must be specified')
+
+ return_fields = kwargs.pop('return_fields', None)
+ filter_data = kwargs.pop('filter', {})
+ extattrs = normalize_extattrs(kwargs.pop('extattrs', {}))
+ provider = kwargs.pop('provider', {})
+ wapi = WapiLookup(provider)
+ res = wapi.get_object(obj_type, filter_data, return_fields=return_fields, extattrs=extattrs)
+ if res is not None:
+ for obj in res:
+ if 'extattrs' in obj:
+ obj['extattrs'] = flatten_extattrs(obj['extattrs'])
+ else:
+ res = []
+ return res
diff --git a/ansible_collections/infoblox/nios_modules/plugins/lookup/nios_next_ip.py b/ansible_collections/infoblox/nios_modules/plugins/lookup/nios_next_ip.py
new file mode 100644
index 00000000..e2fa076d
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/lookup/nios_next_ip.py
@@ -0,0 +1,115 @@
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+
+from __future__ import (absolute_import, division, print_function)
+
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+name: nios_next_ip
+short_description: Return the next available IP address for a network
+version_added: "1.0.0"
+description:
+ - Uses the Infoblox WAPI API to return the next available IP addresses
+ for a given network CIDR
+requirements:
+ - infoblox-client
+
+options:
+ _terms:
+ description: The CIDR network to retrieve the next address(es) from.
+ required: True
+ type: str
+ num:
+ description: The number of IP address(es) to return.
+ required: false
+ default: 1
+ type: int
+ exclude:
+ description: List of IP's that need to be excluded from returned IP addresses.
+ required: false
+ type: list
+ elements: str
+ network_view:
+ description: The network view to retrieve the CIDR network from.
+ required: false
+ default: default
+ type: str
+'''
+
+EXAMPLES = """
+- name: return next available IP address for network 192.168.10.0/24
+ ansible.builtin.set_fact:
+ ipaddr: "{{ lookup('infoblox.nios_modules.nios_next_ip', '192.168.10.0/24', provider={'host': 'nios01', 'username': 'admin', 'password': 'password'}) }}"
+
+- name: return next available IP address for network 192.168.10.0/24 in a non-default network view
+ ansible.builtin.set_fact:
+ ipaddr: "{{ lookup('infoblox.nios_modules.nios_next_ip', '192.168.10.0/24', network_view='ansible', \
+ provider={'host': 'nios01', 'username': 'admin', 'password': 'password'}) }}"
+
+- name: return the next 3 available IP addresses for network 192.168.10.0/24
+ ansible.builtin.set_fact:
+ ipaddr: "{{ lookup('infoblox.nios_modules.nios_next_ip', '192.168.10.0/24', num=3,
+ provider={'host': 'nios01', 'username': 'admin', 'password': 'password'}) }}"
+
+- name: return the next 3 available IP addresses for network 192.168.10.0/24 excluding ip addresses - ['192.168.10.1', '192.168.10.2']
+ ansible.builtin.set_fact:
+ ipaddr: "{{ lookup('infoblox.nios_modules.nios_next_ip', '192.168.10.0/24', num=3, exclude=['192.168.10.1', '192.168.10.2'],
+ provider={'host': 'nios01', 'username': 'admin', 'password': 'password'}) }}"
+
+- name: return next available IP address for network fd30:f52:2:12::/64
+ ansible.builtin.set_fact:
+ ipaddr: "{{ lookup('infoblox.nios_modules.nios_next_ip', 'fd30:f52:2:12::/64', provider={'host': 'nios01', 'username': 'admin', 'password': 'password'}) }}"
+"""
+
+RETURN = """
+_list:
+ description:
+ - The list of next IP addresses available
+ returned: always
+ type: list
+"""
+
+from ansible.plugins.lookup import LookupBase
+from ansible.module_utils._text import to_text
+from ansible.errors import AnsibleError
+from ..module_utils.api import WapiLookup
+import ipaddress
+
+
+class LookupModule(LookupBase):
+
+ def run(self, terms, variables=None, **kwargs):
+ try:
+ network = terms[0]
+ except IndexError:
+ raise AnsibleError('missing argument in the form of A.B.C.D/E')
+
+ provider = kwargs.pop('provider', {})
+ wapi = WapiLookup(provider)
+
+ if isinstance(ipaddress.ip_network(network), ipaddress.IPv6Network):
+ network_obj = wapi.get_object('ipv6network', {'network': network})
+ else:
+ network_obj = wapi.get_object('network', {'network': network})
+
+ if network_obj is None:
+ raise AnsibleError('unable to find network object %s' % network)
+
+ num = kwargs.get('num', 1)
+ exclude_ip = kwargs.get('exclude', [])
+ network_view = kwargs.get('network_view', 'default')
+
+ try:
+ ref_list = [network['_ref'] for network in network_obj if network['network_view'] == network_view]
+ if not ref_list:
+ raise AnsibleError('no records found')
+ else:
+ ref = ref_list[0]
+ avail_ips = wapi.call_func('next_available_ip', ref, {'num': num, 'exclude': exclude_ip})
+ return [avail_ips['ips']]
+ except Exception as exc:
+ raise AnsibleError(to_text(exc))
diff --git a/ansible_collections/infoblox/nios_modules/plugins/lookup/nios_next_network.py b/ansible_collections/infoblox/nios_modules/plugins/lookup/nios_next_network.py
new file mode 100644
index 00000000..af3dbf65
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/lookup/nios_next_network.py
@@ -0,0 +1,118 @@
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+
+from __future__ import (absolute_import, division, print_function)
+
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+name: nios_next_network
+short_description: Return the next available network range for a network-container
+version_added: "1.0.0"
+description:
+ - Uses the Infoblox WAPI API to return the next available network addresses for
+ a given network CIDR
+requirements:
+ - infoblox_client
+
+options:
+ _terms:
+ description: The CIDR network to retrieve the next network from next available network within the specified
+ container.
+ required: True
+ type: str
+ cidr:
+ description:
+ - The CIDR of the network to retrieve the next network from next available network within the
+ specified container. Also, Requested CIDR must be specified and greater than the parent CIDR.
+ required: True
+ type: str
+ num:
+ description: The number of network addresses to return from network-container.
+ required: false
+ default: 1
+ type: int
+ exclude:
+ description: Network addresses returned from network-container excluding list of user's input network range.
+ required: false
+ default: ''
+ type: list
+ elements: str
+ network_view:
+ description: The network view to retrieve the CIDR network from.
+ required: false
+ default: default
+ type: str
+'''
+
+EXAMPLES = """
+- name: return next available network for network-container 192.168.10.0/24
+ ansible.builtin.set_fact:
+ networkaddr: "{{ lookup('infoblox.nios_modules.nios_next_network', '192.168.10.0/24', cidr=25,
+ provider={'host': 'nios01', 'username': 'admin', 'password': 'password'}) }}"
+
+- name: return next available network for network-container 192.168.10.0/24 in a non-default network view
+ ansible.builtin.set_fact:
+ networkaddr: "{{ lookup('infoblox.nios_modules.nios_next_network', '192.168.10.0/24', cidr=25, network_view='ansible'
+ provider={'host': 'nios01', 'username': 'admin', 'password': 'password'}) }}"
+
+- name: return the next 2 available network addresses for network-container 192.168.10.0/24
+ ansible.builtin.set_fact:
+ networkaddr: "{{ lookup('infoblox.nios_modules.nios_next_network', '192.168.10.0/24', cidr=25, num=2,
+ provider={'host': 'nios01', 'username': 'admin', 'password': 'password'}) }}"
+
+- name: return the available network addresses for network-container 192.168.10.0/24 excluding network range '192.168.10.0/25'
+ ansible.builtin.set_fact:
+ networkaddr: "{{ lookup('infoblox.nios_modules.nios_next_network', '192.168.10.0/24', cidr=25, exclude=['192.168.10.0/25'],
+ provider={'host': 'nios01', 'username': 'admin', 'password': 'password'}) }}"
+"""
+
+RETURN = """
+_list:
+ description:
+ - The list of next network addresses available
+ returned: always
+ type: list
+"""
+
+from ansible.plugins.lookup import LookupBase
+from ansible.module_utils._text import to_text
+from ansible.errors import AnsibleError
+from ..module_utils.api import WapiLookup
+
+
+class LookupModule(LookupBase):
+
+ def run(self, terms, variables=None, **kwargs):
+ try:
+ network = terms[0]
+ except IndexError:
+ raise AnsibleError('missing network argument in the form of A.B.C.D/E')
+ try:
+ cidr = kwargs.get('cidr', 24)
+ except IndexError:
+ raise AnsibleError('missing CIDR argument in the form of xx')
+
+ provider = kwargs.pop('provider', {})
+ wapi = WapiLookup(provider)
+ network_obj = wapi.get_object('networkcontainer', {'network': network})
+
+ if network_obj is None:
+ raise AnsibleError('unable to find network-container object %s' % network)
+ num = kwargs.get('num', 1)
+ exclude_ip = kwargs.get('exclude', [])
+ network_view = kwargs.get('network_view', 'default')
+
+ try:
+ ref_list = [network['_ref'] for network in network_obj if network['network_view'] == network_view]
+ if not ref_list:
+ raise AnsibleError('no records found')
+ else:
+ ref = ref_list[0]
+ avail_nets = wapi.call_func('next_available_network', ref, {'cidr': cidr, 'num': num, 'exclude': exclude_ip})
+ return [avail_nets['networks']]
+ except Exception as exc:
+ raise AnsibleError(to_text(exc))
diff --git a/ansible_collections/infoblox/nios_modules/plugins/module_utils/api.py b/ansible_collections/infoblox/nios_modules/plugins/module_utils/api.py
new file mode 100644
index 00000000..018e9f15
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/module_utils/api.py
@@ -0,0 +1,701 @@
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+# This code is part of Ansible, but is an independent component.
+# This particular file snippet, and this file snippet only, is BSD licensed.
+# Modules you write using this snippet, which is embedded dynamically by Ansible
+# still belong to the author of the module, and may assign their own license
+# to the complete work.
+#
+# Copyright © 2020 Infoblox Inc
+#
+# Redistribution and use in source and binary forms, with or without modification,
+# are permitted provided that the following conditions are met:
+#
+# * Redistributions of source code must retain the above copyright
+# notice, this list of conditions and the following disclaimer.
+# * Redistributions in binary form must reproduce the above copyright notice,
+# this list of conditions and the following disclaimer in the documentation
+# and/or other materials provided with the distribution.
+#
+# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
+# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+# IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
+# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
+# USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+#
+
+
+import json
+import os
+from functools import partial
+from ansible.module_utils._text import to_native
+from ansible.module_utils.six import iteritems
+from ansible.module_utils._text import to_text
+from ansible.module_utils.basic import env_fallback
+from ansible.module_utils.common.validation import check_type_dict, safe_eval
+from ansible.module_utils.six import string_types
+
+try:
+ from infoblox_client.connector import Connector
+ from infoblox_client.exceptions import InfobloxException
+ HAS_INFOBLOX_CLIENT = True
+except ImportError:
+ HAS_INFOBLOX_CLIENT = False
+
+# defining nios constants
+NIOS_DNS_VIEW = 'view'
+NIOS_NETWORK_VIEW = 'networkview'
+NIOS_HOST_RECORD = 'record:host'
+NIOS_IPV4_NETWORK = 'network'
+NIOS_IPV6_NETWORK = 'ipv6network'
+NIOS_ZONE = 'zone_auth'
+NIOS_PTR_RECORD = 'record:ptr'
+NIOS_A_RECORD = 'record:a'
+NIOS_AAAA_RECORD = 'record:aaaa'
+NIOS_CNAME_RECORD = 'record:cname'
+NIOS_MX_RECORD = 'record:mx'
+NIOS_SRV_RECORD = 'record:srv'
+NIOS_NAPTR_RECORD = 'record:naptr'
+NIOS_TXT_RECORD = 'record:txt'
+NIOS_NSGROUP = 'nsgroup'
+NIOS_IPV4_FIXED_ADDRESS = 'fixedaddress'
+NIOS_IPV6_FIXED_ADDRESS = 'ipv6fixedaddress'
+NIOS_NEXT_AVAILABLE_IP = 'func:nextavailableip'
+NIOS_IPV4_NETWORK_CONTAINER = 'networkcontainer'
+NIOS_IPV6_NETWORK_CONTAINER = 'ipv6networkcontainer'
+NIOS_MEMBER = 'member'
+NIOS_DTC_SERVER = 'dtc:server'
+NIOS_DTC_POOL = 'dtc:pool'
+NIOS_DTC_LBDN = 'dtc:lbdn'
+
+NIOS_PROVIDER_SPEC = {
+ 'host': dict(fallback=(env_fallback, ['INFOBLOX_HOST'])),
+ 'username': dict(fallback=(env_fallback, ['INFOBLOX_USERNAME'])),
+ 'password': dict(fallback=(env_fallback, ['INFOBLOX_PASSWORD']), no_log=True),
+ 'cert': dict(fallback=(env_fallback, ['INFOBLOX_CERT'])),
+ 'key': dict(fallback=(env_fallback, ['INFOBLOX_KEY']), no_log=True),
+ 'validate_certs': dict(type='bool', default=False, fallback=(env_fallback, ['INFOBLOX_SSL_VERIFY']), aliases=['ssl_verify']),
+ 'silent_ssl_warnings': dict(type='bool', default=True),
+ 'http_request_timeout': dict(type='int', default=10, fallback=(env_fallback, ['INFOBLOX_HTTP_REQUEST_TIMEOUT'])),
+ 'http_pool_connections': dict(type='int', default=10),
+ 'http_pool_maxsize': dict(type='int', default=10),
+ 'max_retries': dict(type='int', default=3, fallback=(env_fallback, ['INFOBLOX_MAX_RETRIES'])),
+ 'wapi_version': dict(default='2.1', fallback=(env_fallback, ['INFOBLOX_WAP_VERSION'])),
+ 'max_results': dict(type='int', default=1000, fallback=(env_fallback, ['INFOBLOX_MAX_RETRIES']))
+}
+
+
+def get_connector(*args, **kwargs):
+ ''' Returns an instance of infoblox_client.connector.Connector
+ :params args: positional arguments are silently ignored
+ :params kwargs: dict that is passed to Connector init
+ :returns: Connector
+ '''
+ if not HAS_INFOBLOX_CLIENT:
+ raise Exception('infoblox-client is required but does not appear '
+ 'to be installed. It can be installed using the '
+ 'command `pip install infoblox-client`')
+
+ if not set(kwargs.keys()).issubset(list(NIOS_PROVIDER_SPEC.keys()) + ['ssl_verify']):
+ raise Exception('invalid or unsupported keyword argument for connector')
+ for key, value in iteritems(NIOS_PROVIDER_SPEC):
+ if key not in kwargs:
+ # apply default values from NIOS_PROVIDER_SPEC since we cannot just
+ # assume the provider values are coming from AnsibleModule
+ if 'default' in value:
+ kwargs[key] = value['default']
+
+ # override any values with env variables unless they were
+ # explicitly set
+ env = ('INFOBLOX_%s' % key).upper()
+ if env in os.environ:
+ kwargs[key] = os.environ.get(env)
+
+ if 'validate_certs' in kwargs.keys():
+ kwargs['ssl_verify'] = kwargs['validate_certs']
+ kwargs.pop('validate_certs', None)
+
+ return Connector(kwargs)
+
+
+def normalize_extattrs(value):
+ ''' Normalize extattrs field to expected format
+ The module accepts extattrs as key/value pairs. This method will
+ transform the key/value pairs into a structure suitable for
+ sending across WAPI in the format of:
+ extattrs: {
+ key: {
+ value: <value>
+ }
+ }
+ '''
+ return dict([(k, {'value': v}) for k, v in iteritems(value)])
+
+
+def flatten_extattrs(value):
+ ''' Flatten the key/value struct for extattrs
+ WAPI returns extattrs field as a dict in form of:
+ extattrs: {
+ key: {
+ value: <value>
+ }
+ }
+ This method will flatten the structure to:
+ extattrs: {
+ key: value
+ }
+ '''
+ return dict([(k, v['value']) for k, v in iteritems(value)])
+
+
+def member_normalize(member_spec):
+ ''' Transforms the member module arguments into a valid WAPI struct
+ This function will transform the arguments into a structure that
+ is a valid WAPI structure in the format of:
+ {
+ key: <value>,
+ }
+ It will remove any arguments that are set to None since WAPI will error on
+ that condition.
+ The remainder of the value validation is performed by WAPI
+ Some parameters in ib_spec are passed as a list in order to pass the validation for elements.
+ In this function, they are converted to dictionary.
+ '''
+ member_elements = ['vip_setting', 'ipv6_setting', 'lan2_port_setting', 'mgmt_port_setting',
+ 'pre_provisioning', 'network_setting', 'v6_network_setting',
+ 'ha_port_setting', 'lan_port_setting', 'lan2_physical_setting',
+ 'lan_ha_port_setting', 'mgmt_network_setting', 'v6_mgmt_network_setting']
+ for key in list(member_spec.keys()):
+ if key in member_elements and member_spec[key] is not None:
+ member_spec[key] = member_spec[key][0]
+ if isinstance(member_spec[key], dict):
+ member_spec[key] = member_normalize(member_spec[key])
+ elif isinstance(member_spec[key], list):
+ for x in member_spec[key]:
+ if isinstance(x, dict):
+ x = member_normalize(x)
+ elif member_spec[key] is None:
+ del member_spec[key]
+ return member_spec
+
+
+def normalize_ib_spec(ib_spec):
+ result = {}
+ for arg in ib_spec:
+ result[arg] = dict([(k, v)
+ for k, v in iteritems(ib_spec[arg])
+ if k not in ('ib_req', 'transform', 'update')])
+ return result
+
+
+class WapiBase(object):
+ ''' Base class for implementing Infoblox WAPI API '''
+ provider_spec = {'provider': dict(type='dict', options=NIOS_PROVIDER_SPEC)}
+
+ def __init__(self, provider):
+ self.connector = get_connector(**provider)
+
+ def __getattr__(self, name):
+ try:
+ return self.__dict__[name]
+ except KeyError:
+ if name.startswith('_'):
+ raise AttributeError("'%s' object has no attribute '%s'" % (self.__class__.__name__, name))
+ return partial(self._invoke_method, name)
+
+ def _invoke_method(self, name, *args, **kwargs):
+ try:
+ method = getattr(self.connector, name)
+ return method(*args, **kwargs)
+ except InfobloxException as exc:
+ if hasattr(self, 'handle_exception'):
+ self.handle_exception(name, exc)
+ else:
+ raise
+
+
+class WapiLookup(WapiBase):
+ ''' Implements WapiBase for lookup plugins '''
+ def handle_exception(self, method_name, exc):
+ if ('text' in exc.response):
+ raise Exception(exc.response['text'])
+ else:
+ raise Exception(exc)
+
+
+class WapiInventory(WapiBase):
+ ''' Implements WapiBase for dynamic inventory script '''
+ pass
+
+
+class WapiModule(WapiBase):
+ ''' Implements WapiBase for executing a NIOS module '''
+ def __init__(self, module):
+ self.module = module
+ provider = module.params['provider']
+ try:
+ super(WapiModule, self).__init__(provider)
+ except Exception as exc:
+ self.module.fail_json(msg=to_text(exc))
+
+ def handle_exception(self, method_name, exc):
+ ''' Handles any exceptions raised
+ This method will be called if an InfobloxException is raised for
+ any call to the instance of Connector and also, in case of generic
+ exception. This method will then gracefully fail the module.
+ :args exc: instance of InfobloxException
+ '''
+ if ('text' in exc.response):
+ self.module.fail_json(
+ msg=exc.response['text'],
+ type=exc.response['Error'].split(':')[0],
+ code=exc.response.get('code'),
+ operation=method_name
+ )
+ else:
+ self.module.fail_json(msg=to_native(exc))
+
+ def run(self, ib_obj_type, ib_spec):
+ ''' Runs the module and performans configuration tasks
+ :args ib_obj_type: the WAPI object type to operate against
+ :args ib_spec: the specification for the WAPI object as a dict
+ :returns: a results dict
+ '''
+
+ update = new_name = None
+ state = self.module.params['state']
+ if state not in ('present', 'absent'):
+ self.module.fail_json(msg='state must be one of `present`, `absent`, got `%s`' % state)
+
+ result = {'changed': False}
+
+ obj_filter = dict([(k, self.module.params[k]) for k, v in iteritems(ib_spec) if v.get('ib_req')])
+
+ # get object reference
+ ib_obj_ref, update, new_name = self.get_object_ref(self.module, ib_obj_type, obj_filter, ib_spec)
+ proposed_object = {}
+ for key, value in iteritems(ib_spec):
+ if self.module.params[key] is not None:
+ if 'transform' in value:
+ proposed_object[key] = value['transform'](self.module)
+ else:
+ proposed_object[key] = self.module.params[key]
+
+ # If configure_by_dns is set to False and view is 'default', then delete the default dns
+ if not proposed_object.get('configure_for_dns') and proposed_object.get('view') == 'default'\
+ and ib_obj_type == NIOS_HOST_RECORD:
+ del proposed_object['view']
+
+ if ib_obj_ref:
+ if len(ib_obj_ref) > 1:
+ for each in ib_obj_ref:
+ # To check for existing A_record with same name with input A_record by IP
+ if each.get('ipv4addr') and each.get('ipv4addr') == proposed_object.get('ipv4addr'):
+ current_object = each
+ # To check for existing Host_record with same name with input Host_record by IP
+ elif each.get('ipv4addrs') and each.get('ipv4addrs')[0].get('ipv4addr')\
+ == proposed_object.get('ipv4addrs')[0].get('ipv4addr'):
+ current_object = each
+ # Else set the current_object with input value
+ else:
+ current_object = obj_filter
+ ref = None
+ else:
+ current_object = ib_obj_ref[0]
+ if 'extattrs' in current_object:
+ current_object['extattrs'] = flatten_extattrs(current_object['extattrs'])
+ if current_object.get('_ref'):
+ ref = current_object.pop('_ref')
+ else:
+ current_object = obj_filter
+ ref = None
+ # checks if the object type is member to normalize the attributes being passed
+ if (ib_obj_type == NIOS_MEMBER):
+ proposed_object = member_normalize(proposed_object)
+
+ # checks if the 'text' field has to be updated for the TXT Record
+ if (ib_obj_type == NIOS_TXT_RECORD):
+ text_obj = proposed_object["text"]
+ if text_obj.startswith("{"):
+ try:
+ text_obj = json.loads(text_obj)
+ txt = text_obj['new_text']
+ except Exception:
+ (result, exc) = safe_eval(text_obj, dict(), include_exceptions=True)
+ if exc is not None:
+ raise TypeError('unable to evaluate string as dictionary')
+ txt = result['new_text']
+ proposed_object['text'] = txt
+
+ # checks if the name's field has been updated
+ if update and new_name:
+ proposed_object['name'] = new_name
+
+ check_remove = []
+ if (ib_obj_type == NIOS_HOST_RECORD):
+ # this check is for idempotency, as if the same ip address shall be passed
+ # add param will be removed, and same exists true for remove case as well.
+ if 'ipv4addrs' in [current_object and proposed_object]:
+ for each in current_object['ipv4addrs']:
+ if each['ipv4addr'] == proposed_object['ipv4addrs'][0]['ipv4addr']:
+ if 'add' in proposed_object['ipv4addrs'][0]:
+ del proposed_object['ipv4addrs'][0]['add']
+ break
+ check_remove += each.values()
+ if proposed_object['ipv4addrs'][0]['ipv4addr'] not in check_remove:
+ if 'remove' in proposed_object['ipv4addrs'][0]:
+ del proposed_object['ipv4addrs'][0]['remove']
+
+ res = None
+ modified = not self.compare_objects(current_object, proposed_object)
+ if 'extattrs' in proposed_object:
+ proposed_object['extattrs'] = normalize_extattrs(proposed_object['extattrs'])
+
+ # Checks if nios_next_ip param is passed in ipv4addrs/ipv4addr args
+ proposed_object = self.check_if_nios_next_ip_exists(proposed_object)
+
+ if state == 'present':
+ if ref is None:
+ if not self.module.check_mode:
+ self.create_object(ib_obj_type, proposed_object)
+ result['changed'] = True
+ # Check if NIOS_MEMBER and the flag to call function create_token is set
+ elif (ib_obj_type == NIOS_MEMBER) and (proposed_object['create_token']):
+ proposed_object = None
+ # the function creates a token that can be used by a pre-provisioned member to join the grid
+ result['api_results'] = self.call_func('create_token', ref, proposed_object)
+ result['changed'] = True
+ elif modified:
+ if 'ipv4addrs' in proposed_object:
+ if ('add' not in proposed_object['ipv4addrs'][0]) and ('remove' not in proposed_object['ipv4addrs'][0]):
+ self.check_if_recordname_exists(obj_filter, ib_obj_ref, ib_obj_type, current_object, proposed_object)
+
+ if (ib_obj_type in (NIOS_HOST_RECORD, NIOS_NETWORK_VIEW, NIOS_DNS_VIEW)):
+ run_update = True
+ proposed_object = self.on_update(proposed_object, ib_spec)
+ if 'ipv4addrs' in proposed_object:
+ if ('add' or 'remove') in proposed_object['ipv4addrs'][0]:
+ run_update, proposed_object = self.check_if_add_remove_ip_arg_exists(proposed_object)
+ if run_update:
+ res = self.update_object(ref, proposed_object)
+ result['changed'] = True
+ else:
+ res = ref
+
+ if (ib_obj_type in (NIOS_A_RECORD, NIOS_AAAA_RECORD, NIOS_PTR_RECORD, NIOS_SRV_RECORD, NIOS_NAPTR_RECORD)):
+ # popping 'view' key as update of 'view' is not supported with respect to a:record/aaaa:record/srv:record/ptr:record/naptr:record
+ proposed_object = self.on_update(proposed_object, ib_spec)
+ del proposed_object['view']
+ if not self.module.check_mode:
+ res = self.update_object(ref, proposed_object)
+ result['changed'] = True
+ if (ib_obj_type in (NIOS_ZONE)):
+ # popping 'zone_format' key as update of 'zone_format' is not supported with respect to zone_auth
+ proposed_object = self.on_update(proposed_object, ib_spec)
+ del proposed_object['zone_format']
+ self.update_object(ref, proposed_object)
+ result['changed'] = True
+ elif 'network_view' in proposed_object and (ib_obj_type not in (NIOS_IPV4_FIXED_ADDRESS, NIOS_IPV6_FIXED_ADDRESS)):
+ proposed_object.pop('network_view')
+ result['changed'] = True
+ if not self.module.check_mode and res is None:
+ proposed_object = self.on_update(proposed_object, ib_spec)
+ self.update_object(ref, proposed_object)
+ result['changed'] = True
+
+ elif state == 'absent':
+ if ref is not None:
+ if 'ipv4addrs' in proposed_object:
+ if 'remove' in proposed_object['ipv4addrs'][0]:
+ self.check_if_add_remove_ip_arg_exists(proposed_object)
+ self.update_object(ref, proposed_object)
+ result['changed'] = True
+ elif not self.module.check_mode:
+ self.delete_object(ref)
+ result['changed'] = True
+
+ return result
+
+ def check_if_recordname_exists(self, obj_filter, ib_obj_ref, ib_obj_type, current_object, proposed_object):
+ ''' Send POST request if host record input name and retrieved ref name is same,
+ but input IP and retrieved IP is different'''
+
+ if 'name' in (obj_filter and ib_obj_ref[0]) and ib_obj_type == NIOS_HOST_RECORD:
+ obj_host_name = obj_filter['name']
+ ref_host_name = ib_obj_ref[0]['name']
+ if 'ipv4addrs' in (current_object and proposed_object):
+ current_ip_addr = current_object['ipv4addrs'][0]['ipv4addr']
+ proposed_ip_addr = proposed_object['ipv4addrs'][0]['ipv4addr']
+ elif 'ipv6addrs' in (current_object and proposed_object):
+ current_ip_addr = current_object['ipv6addrs'][0]['ipv6addr']
+ proposed_ip_addr = proposed_object['ipv6addrs'][0]['ipv6addr']
+
+ if obj_host_name == ref_host_name and current_ip_addr != proposed_ip_addr:
+ self.create_object(ib_obj_type, proposed_object)
+
+ def check_if_nios_next_ip_exists(self, proposed_object):
+ ''' Check if nios_next_ip argument is passed in ipaddr while creating
+ host record, if yes then format proposed object ipv4addrs and pass
+ func:nextavailableip and ipaddr range to create hostrecord with next
+ available ip in one call to avoid any race condition '''
+
+ if 'ipv4addrs' in proposed_object:
+ if 'nios_next_ip' in proposed_object['ipv4addrs'][0]['ipv4addr']:
+ ip_range = check_type_dict(proposed_object['ipv4addrs'][0]['ipv4addr'])['nios_next_ip']
+ proposed_object['ipv4addrs'][0]['ipv4addr'] = NIOS_NEXT_AVAILABLE_IP + ':' + ip_range
+ elif 'ipv4addr' in proposed_object:
+ if 'nios_next_ip' in proposed_object['ipv4addr']:
+ ip_range = check_type_dict(proposed_object['ipv4addr'])['nios_next_ip']
+ proposed_object['ipv4addr'] = NIOS_NEXT_AVAILABLE_IP + ':' + ip_range
+
+ return proposed_object
+
+ def check_if_add_remove_ip_arg_exists(self, proposed_object):
+ '''
+ This function shall check if add/remove param is set to true and
+ is passed in the args, then we will update the proposed dictionary
+ to add/remove IP to existing host_record, if the user passes false
+ param with the argument nothing shall be done.
+ :returns: True if param is changed based on add/remove, and also the
+ changed proposed_object.
+ '''
+ update = False
+ if 'add' in proposed_object['ipv4addrs'][0]:
+ if proposed_object['ipv4addrs'][0]['add']:
+ proposed_object['ipv4addrs+'] = proposed_object['ipv4addrs']
+ del proposed_object['ipv4addrs']
+ del proposed_object['ipv4addrs+'][0]['add']
+ update = True
+ else:
+ del proposed_object['ipv4addrs'][0]['add']
+ elif 'remove' in proposed_object['ipv4addrs'][0]:
+ if proposed_object['ipv4addrs'][0]['remove']:
+ proposed_object['ipv4addrs-'] = proposed_object['ipv4addrs']
+ del proposed_object['ipv4addrs']
+ del proposed_object['ipv4addrs-'][0]['remove']
+ update = True
+ else:
+ del proposed_object['ipv4addrs'][0]['remove']
+ return update, proposed_object
+
+ def issubset(self, item, objects):
+ ''' Checks if item is a subset of objects
+ :args item: the subset item to validate
+ :args objects: superset list of objects to validate against
+ :returns: True if item is a subset of one entry in objects otherwise
+ this method will return None
+ '''
+ for obj in objects:
+ if isinstance(item, dict):
+ if all(entry in obj.items() for entry in item.items()):
+ return True
+ else:
+ if item in obj:
+ return True
+
+ def compare_objects(self, current_object, proposed_object):
+ for key, proposed_item in iteritems(proposed_object):
+ current_item = current_object.get(key)
+
+ # if proposed has a key that current doesn't then the objects are
+ # not equal and False will be immediately returned
+ if current_item is None:
+ return False
+
+ elif isinstance(proposed_item, list):
+ if key == 'aliases':
+ if set(current_item) != set(proposed_item):
+ return False
+ for subitem in proposed_item:
+ if not self.issubset(subitem, current_item):
+ return False
+
+ elif isinstance(proposed_item, dict):
+ return self.compare_objects(current_item, proposed_item)
+
+ else:
+ if current_item != proposed_item:
+ return False
+
+ return True
+
+ def get_object_ref(self, module, ib_obj_type, obj_filter, ib_spec):
+ ''' this function gets the reference object of pre-existing nios objects '''
+
+ update = False
+ old_name = new_name = None
+ old_ipv4addr_exists = old_text_exists = False
+ if ('name' in obj_filter):
+ # gets and returns the current object based on name/old_name passed
+ try:
+ name_obj = check_type_dict(obj_filter['name'])
+ # check if network_view allows searching and updating with camelCase
+ if (ib_obj_type == NIOS_NETWORK_VIEW):
+ old_name = name_obj['old_name']
+ new_name = name_obj['new_name']
+ else:
+ old_name = name_obj['old_name'].lower()
+ new_name = name_obj['new_name'].lower()
+ except TypeError:
+ name = obj_filter['name']
+
+ if old_name and new_name:
+ if (ib_obj_type == NIOS_HOST_RECORD):
+ test_obj_filter = dict([('name', old_name), ('view', obj_filter['view'])])
+ else:
+ test_obj_filter = dict([('name', old_name)])
+ # get the object reference
+ ib_obj = self.get_object(ib_obj_type, test_obj_filter, return_fields=list(ib_spec.keys()))
+ if ib_obj:
+ obj_filter['name'] = new_name
+ else:
+ raise Exception("object with name: '%s' is not found" % (old_name))
+ update = True
+ return ib_obj, update, new_name
+ if (ib_obj_type == NIOS_HOST_RECORD):
+ # to fix the sanity issue
+ name = obj_filter['name']
+ # to check only by name if dns bypassing is set
+ if not obj_filter['configure_for_dns']:
+ test_obj_filter = dict([('name', name)])
+ else:
+ test_obj_filter = dict([('name', name), ('view', obj_filter['view'])])
+ elif (ib_obj_type == NIOS_IPV4_FIXED_ADDRESS and 'mac' in obj_filter):
+ test_obj_filter = dict([['mac', obj_filter['mac']]])
+ elif (ib_obj_type == NIOS_IPV6_FIXED_ADDRESS and 'duid' in obj_filter):
+ test_obj_filter = dict([['duid', obj_filter['duid']]])
+ elif (ib_obj_type == NIOS_CNAME_RECORD):
+ test_obj_filter = dict([('name', obj_filter['name']), ('view', obj_filter['view'])])
+ elif (ib_obj_type == NIOS_A_RECORD):
+ # resolves issue where a_record with uppercase name was returning null and was failing
+ test_obj_filter = obj_filter
+ test_obj_filter['name'] = test_obj_filter['name'].lower()
+ # resolves issue where multiple a_records with same name and different IP address
+ try:
+ ipaddr_obj = check_type_dict(obj_filter['ipv4addr'])
+ ipaddr = ipaddr_obj.get('old_ipv4addr')
+ old_ipv4addr_exists = True if ipaddr else False
+ except TypeError:
+ ipaddr = obj_filter['ipv4addr']
+ test_obj_filter['ipv4addr'] = ipaddr
+ elif (ib_obj_type == NIOS_TXT_RECORD):
+ # resolves issue where multiple txt_records with same name and different text
+ test_obj_filter = obj_filter
+ try:
+ text_obj = obj_filter['text']
+ if text_obj.startswith("{"):
+ try:
+ text_obj = json.loads(text_obj)
+ txt = text_obj['old_text']
+ old_text_exists = True
+ except Exception:
+ (result, exc) = safe_eval(text_obj, dict(), include_exceptions=True)
+ if exc is not None:
+ raise TypeError('unable to evaluate string as dictionary')
+ txt = result['old_text']
+ old_text_exists = True
+ else:
+ txt = text_obj
+ except TypeError:
+ txt = obj_filter['text']
+ test_obj_filter['text'] = txt
+ # check if test_obj_filter is empty copy passed obj_filter
+ else:
+ test_obj_filter = obj_filter
+ ib_obj = self.get_object(ib_obj_type, test_obj_filter.copy(), return_fields=list(ib_spec.keys()))
+
+ # prevents creation of a new A record with 'new_ipv4addr' when A record with a particular 'old_ipv4addr' is not found
+ if old_ipv4addr_exists and ib_obj is None:
+ raise Exception("A Record with ipv4addr: '%s' is not found" % (ipaddr))
+ # prevents creation of a new TXT record with 'new_text' when TXT record with a particular 'old_text' is not found
+ if old_text_exists and ib_obj is None:
+ raise Exception("TXT Record with text: '%s' is not found" % (txt))
+ elif (ib_obj_type == NIOS_A_RECORD):
+ # resolves issue where multiple a_records with same name and different IP address
+ test_obj_filter = obj_filter
+ try:
+ ipaddr_obj = check_type_dict(obj_filter['ipv4addr'])
+ ipaddr = ipaddr_obj.get('old_ipv4addr')
+ old_ipv4addr_exists = True if ipaddr else False
+ except TypeError:
+ ipaddr = obj_filter['ipv4addr']
+ test_obj_filter['ipv4addr'] = ipaddr
+ # prevents creation of a new A record with 'new_ipv4addr' when A record with a particular 'old_ipv4addr' is not found
+ if old_ipv4addr_exists and ib_obj is None:
+ raise Exception("A Record with ipv4addr: '%s' is not found" % (ipaddr))
+ ib_obj = self.get_object(ib_obj_type, test_obj_filter.copy(), return_fields=list(ib_spec.keys()))
+ # prevents creation of a new A record with 'new_ipv4addr' when A record with a particular 'old_ipv4addr' is not found
+ if old_ipv4addr_exists and ib_obj is None:
+ raise Exception("A Record with ipv4addr: '%s' is not found" % (ipaddr))
+ elif (ib_obj_type == NIOS_TXT_RECORD):
+ # resolves issue where multiple txt_records with same name and different text
+ test_obj_filter = obj_filter
+ try:
+ text_obj = obj_filter(['text'])
+ if text_obj.startswith("{"):
+ try:
+ text_obj = json.loads(text_obj)
+ txt = text_obj['old_text']
+ old_text_exists = True
+ except Exception:
+ (result, exc) = safe_eval(text_obj, dict(), include_exceptions=True)
+ if exc is not None:
+ raise TypeError('unable to evaluate string as dictionary')
+ txt = result['old_text']
+ old_text_exists = True
+ else:
+ txt = text_obj
+ except TypeError:
+ txt = obj_filter['text']
+ test_obj_filter['text'] = txt
+ ib_obj = self.get_object(ib_obj_type, test_obj_filter.copy(), return_fields=list(ib_spec.keys()))
+ # prevents creation of a new TXT record with 'new_text' when TXT record with a particular 'old_text' is not found
+ if old_text_exists and ib_obj is None:
+ raise Exception("TXT Record with text: '%s' is not found" % (txt))
+ elif (ib_obj_type == NIOS_ZONE):
+ # del key 'restart_if_needed' as nios_zone get_object fails with the key present
+ temp = ib_spec['restart_if_needed']
+ del ib_spec['restart_if_needed']
+ ib_obj = self.get_object(ib_obj_type, obj_filter.copy(), return_fields=list(ib_spec.keys()))
+ # reinstate restart_if_needed if ib_obj is none, meaning there's no existing nios_zone ref
+ if not ib_obj:
+ ib_spec['restart_if_needed'] = temp
+ elif (ib_obj_type == NIOS_MEMBER):
+ # del key 'create_token' as nios_member get_object fails with the key present
+ temp = ib_spec['create_token']
+ del ib_spec['create_token']
+ ib_obj = self.get_object(ib_obj_type, obj_filter.copy(), return_fields=list(ib_spec.keys()))
+ if temp:
+ # reinstate 'create_token' key
+ ib_spec['create_token'] = temp
+ elif (ib_obj_type in (NIOS_IPV4_NETWORK, NIOS_IPV6_NETWORK, NIOS_IPV4_NETWORK_CONTAINER, NIOS_IPV6_NETWORK_CONTAINER)):
+ # del key 'template' as nios_network get_object fails with the key present
+ temp = ib_spec['template']
+ del ib_spec['template']
+ ib_obj = self.get_object(ib_obj_type, obj_filter.copy(), return_fields=list(ib_spec.keys()))
+ if temp:
+ # reinstate 'template' key
+ ib_spec['template'] = temp
+ else:
+ ib_obj = self.get_object(ib_obj_type, obj_filter.copy(), return_fields=list(ib_spec.keys()))
+ return ib_obj, update, new_name
+
+ def on_update(self, proposed_object, ib_spec):
+ ''' Event called before the update is sent to the API endpoing
+ This method will allow the final proposed object to be changed
+ and/or keys filtered before it is sent to the API endpoint to
+ be processed.
+ :args proposed_object: A dict item that will be encoded and sent
+ the API endpoint with the updated data structure
+ :returns: updated object to be sent to API endpoint
+ '''
+ keys = set()
+ for key, value in iteritems(proposed_object):
+ update = ib_spec[key].get('update', True)
+ if not update:
+ keys.add(key)
+ return dict([(k, v) for k, v in iteritems(proposed_object) if k not in keys])
diff --git a/ansible_collections/infoblox/nios_modules/plugins/module_utils/network.py b/ansible_collections/infoblox/nios_modules/plugins/module_utils/network.py
new file mode 100644
index 00000000..4357a9b5
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/module_utils/network.py
@@ -0,0 +1,19 @@
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+import socket
+
+
+def validate_ip_address(address):
+ try:
+ socket.inet_aton(address)
+ except socket.error:
+ return False
+ return address.count('.') == 3
+
+
+def validate_ip_v6_address(address):
+ try:
+ socket.inet_pton(socket.AF_INET6, address)
+ except socket.error:
+ return False
+ return True
diff --git a/ansible_collections/infoblox/nios_modules/plugins/modules/nios_a_record.py b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_a_record.py
new file mode 100644
index 00000000..0164e94e
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_a_record.py
@@ -0,0 +1,178 @@
+#!/usr/bin/python
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+module: nios_a_record
+author: "Blair Rampling (@brampling)"
+short_description: Configure Infoblox NIOS A records
+version_added: "1.0.0"
+description:
+ - Adds and/or removes instances of A record objects from
+ Infoblox NIOS servers. This module manages NIOS C(record:a) objects
+ using the Infoblox WAPI interface over REST.
+requirements:
+ - infoblox-client
+extends_documentation_fragment: infoblox.nios_modules.nios
+notes:
+ - This module supports C(check_mode).
+options:
+ name:
+ description:
+ - Specifies the fully qualified hostname to add or remove from
+ the system.
+ required: true
+ type: str
+ view:
+ description:
+ - Sets the DNS view to associate this A record with. The DNS
+ view must already be configured on the system.
+ default: default
+ aliases:
+ - dns_view
+ type: str
+ ipv4addr:
+ description:
+ - Configures the IPv4 address for this A record. Users can dynamically
+ allocate ipv4 address to A record by passing dictionary containing,
+ I(nios_next_ip) and I(CIDR network range). See example.
+ aliases:
+ - ipv4
+ required: true
+ type: str
+ ttl:
+ description:
+ - Configures the TTL to be associated with this A record.
+ type: int
+ extattrs:
+ description:
+ - Allows for the configuration of Extensible Attributes on the
+ instance of the object. This argument accepts a set of key / value
+ pairs for configuration.
+ type: dict
+ comment:
+ description:
+ - Configures a text string comment to be associated with the instance
+ of this object. The provided text string will be configured on the
+ object instance.
+ type: str
+ state:
+ description:
+ - Configures the intended state of the instance of the object on
+ the NIOS server. When this value is set to C(present), the object
+ is configured on the device and when this value is set to C(absent)
+ the value is removed (if necessary) from the device.
+ default: present
+ choices:
+ - present
+ - absent
+ type: str
+'''
+
+EXAMPLES = '''
+- name: Configure an A record
+ infoblox.nios_modules.nios_a_record:
+ name: a.ansible.com
+ ipv4: 192.168.10.1
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Add a comment to an existing A record
+ infoblox.nios_modules.nios_a_record:
+ name: a.ansible.com
+ ipv4: 192.168.10.1
+ comment: this is a test comment
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Remove an A record from the system
+ infoblox.nios_modules.nios_a_record:
+ name: a.ansible.com
+ ipv4: 192.168.10.1
+ state: absent
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Update an A record name
+ infoblox.nios_modules.nios_a_record:
+ name: {new_name: a_new.ansible.com, old_name: a.ansible.com}
+ ipv4: 192.168.10.1
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Dynamically add a record to next available ip
+ infoblox.nios_modules.nios_a_record:
+ name: a.ansible.com
+ ipv4: {nios_next_ip: 192.168.10.0/24}
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+'''
+
+RETURN = ''' # '''
+
+from ansible.module_utils.basic import AnsibleModule
+from ansible.module_utils.six import iteritems
+from ..module_utils.api import WapiModule
+from ..module_utils.api import NIOS_A_RECORD
+from ..module_utils.api import normalize_ib_spec
+
+
+def main():
+ ''' Main entry point for module execution
+ '''
+
+ ib_spec = dict(
+ name=dict(required=True, ib_req=True),
+ view=dict(default='default', aliases=['dns_view'], ib_req=True),
+
+ ipv4addr=dict(required=True, aliases=['ipv4'], ib_req=True),
+
+ ttl=dict(type='int'),
+
+ extattrs=dict(type='dict'),
+ comment=dict(),
+ )
+
+ argument_spec = dict(
+ provider=dict(required=True),
+ state=dict(default='present', choices=['present', 'absent'])
+ )
+
+ argument_spec.update(normalize_ib_spec(ib_spec))
+ argument_spec.update(WapiModule.provider_spec)
+
+ module = AnsibleModule(argument_spec=argument_spec,
+ supports_check_mode=True)
+
+ wapi = WapiModule(module)
+ result = wapi.run(NIOS_A_RECORD, ib_spec)
+
+ module.exit_json(**result)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/ansible_collections/infoblox/nios_modules/plugins/modules/nios_aaaa_record.py b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_aaaa_record.py
new file mode 100644
index 00000000..bbafe8db
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_aaaa_record.py
@@ -0,0 +1,166 @@
+#!/usr/bin/python
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+module: nios_aaaa_record
+author: "Blair Rampling (@brampling)"
+short_description: Configure Infoblox NIOS AAAA records
+version_added: "1.0.0"
+description:
+ - Adds and/or removes instances of AAAA record objects from
+ Infoblox NIOS servers. This module manages NIOS C(record:aaaa) objects
+ using the Infoblox WAPI interface over REST.
+requirements:
+ - infoblox-client
+options:
+ name:
+ description:
+ - Specifies the fully qualified hostname to add or remove from
+ the system.
+ required: true
+ type: str
+ view:
+ description:
+ - Sets the DNS view to associate this AAAA record with. The DNS
+ view must already be configured on the system.
+ default: default
+ aliases:
+ - dns_view
+ type: str
+ ipv6addr:
+ description:
+ - Configures the IPv6 address for this AAAA record.
+ aliases:
+ - ipv6
+ required: true
+ type: str
+ ttl:
+ description:
+ - Configures the TTL to be associated with this AAAA record.
+ type: int
+ extattrs:
+ description:
+ - Allows for the configuration of Extensible Attributes on the
+ instance of the object. This argument accepts a set of key / value
+ pairs for configuration.
+ type: dict
+ comment:
+ description:
+ - Configures a text string comment to be associated with the instance
+ of this object. The provided text string will be configured on the
+ object instance.
+ type: str
+ state:
+ description:
+ - Configures the intended state of the instance of the object on
+ the NIOS server. When this value is set to C(present), the object
+ is configured on the device and when this value is set to C(absent)
+ the value is removed (if necessary) from the device.
+ default: present
+ choices:
+ - present
+ - absent
+ type: str
+extends_documentation_fragment:
+ - infoblox.nios_modules.nios
+notes:
+ - This module supports C(check_mode).
+'''
+
+EXAMPLES = '''
+- name: Configure an AAAA record
+ infoblox.nios_modules.nios_aaaa_record:
+ name: aaaa.ansible.com
+ ipv6: 2001:0db8:85a3:0000:0000:8a2e:0370:7334
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Add a comment to an existing AAAA record
+ infoblox.nios_modules.nios_aaaa_record:
+ name: aaaa.ansible.com
+ ipv6: 2001:0db8:85a3:0000:0000:8a2e:0370:7334
+ comment: this is a test comment
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Remove an AAAA record from the system
+ infoblox.nios_modules.nios_aaaa_record:
+ name: aaaa.ansible.com
+ ipv6: 2001:0db8:85a3:0000:0000:8a2e:0370:7334
+ state: absent
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Update an AAAA record name
+ infoblox.nios_modules.nios_aaaa_record:
+ name: {new_name: aaaa_new.ansible.com, old_name: aaaa.ansible.com}
+ ipv6: 2001:0db8:85a3:0000:0000:8a2e:0370:7334
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+'''
+
+RETURN = ''' # '''
+
+from ansible.module_utils.basic import AnsibleModule
+from ansible.module_utils.six import iteritems
+from ..module_utils.api import WapiModule
+from ..module_utils.api import NIOS_AAAA_RECORD
+from ..module_utils.api import normalize_ib_spec
+
+
+def main():
+ ''' Main entry point for module execution
+ '''
+
+ ib_spec = dict(
+ name=dict(required=True, ib_req=True),
+ view=dict(default='default', aliases=['dns_view'], ib_req=True),
+
+ ipv6addr=dict(required=True, aliases=['ipv6'], ib_req=True),
+
+ ttl=dict(type='int'),
+
+ extattrs=dict(type='dict'),
+ comment=dict(),
+ )
+
+ argument_spec = dict(
+ provider=dict(required=True),
+ state=dict(default='present', choices=['present', 'absent'])
+ )
+
+ argument_spec.update(normalize_ib_spec(ib_spec))
+ argument_spec.update(WapiModule.provider_spec)
+
+ module = AnsibleModule(argument_spec=argument_spec,
+ supports_check_mode=True)
+
+ wapi = WapiModule(module)
+ result = wapi.run(NIOS_AAAA_RECORD, ib_spec)
+
+ module.exit_json(**result)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/ansible_collections/infoblox/nios_modules/plugins/modules/nios_cname_record.py b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_cname_record.py
new file mode 100644
index 00000000..5bc117d1
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_cname_record.py
@@ -0,0 +1,154 @@
+#!/usr/bin/python
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+module: nios_cname_record
+author: "Blair Rampling (@brampling)"
+short_description: Configure Infoblox NIOS CNAME records
+version_added: "1.0.0"
+description:
+ - Adds and/or removes instances of CNAME record objects from
+ Infoblox NIOS servers. This module manages NIOS C(record:cname) objects
+ using the Infoblox WAPI interface over REST.
+requirements:
+ - infoblox-client
+extends_documentation_fragment: infoblox.nios_modules.nios
+notes:
+ - This module supports C(check_mode).
+options:
+ name:
+ description:
+ - Specifies the fully qualified hostname to add or remove from
+ the system.
+ required: true
+ type: str
+ view:
+ description:
+ - Sets the DNS view to associate this CNAME record with. The DNS
+ view must already be configured on the system.
+ default: default
+ aliases:
+ - dns_view
+ type: str
+ canonical:
+ description:
+ - Configures the canonical name for this CNAME record.
+ aliases:
+ - cname
+ required: true
+ type: str
+ ttl:
+ description:
+ - Configures the TTL to be associated with this CNAME record.
+ type: int
+ extattrs:
+ description:
+ - Allows for the configuration of Extensible Attributes on the
+ instance of the object. This argument accepts a set of key / value
+ pairs for configuration.
+ type: dict
+ comment:
+ description:
+ - Configures a text string comment to be associated with the instance
+ of this object. The provided text string will be configured on the
+ object instance.
+ type: str
+ state:
+ description:
+ - Configures the intended state of the instance of the object on
+ the NIOS server. When this value is set to C(present), the object
+ is configured on the device and when this value is set to C(absent)
+ the value is removed (if necessary) from the device.
+ default: present
+ choices:
+ - present
+ - absent
+ type: str
+'''
+
+EXAMPLES = '''
+- name: Configure a CNAME record
+ infoblox.nios_modules.nios_cname_record:
+ name: cname.ansible.com
+ canonical: realhost.ansible.com
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Add a comment to an existing CNAME record
+ infoblox.nios_modules.nios_cname_record:
+ name: cname.ansible.com
+ canonical: realhost.ansible.com
+ comment: this is a test comment
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Remove a CNAME record from the system
+ infoblox.nios_modules.nios_cname_record:
+ name: cname.ansible.com
+ canonical: realhost.ansible.com
+ state: absent
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+'''
+
+RETURN = ''' # '''
+
+from ansible.module_utils.basic import AnsibleModule
+from ansible.module_utils.six import iteritems
+from ..module_utils.api import WapiModule
+from ..module_utils.api import NIOS_CNAME_RECORD
+from ..module_utils.api import normalize_ib_spec
+
+
+def main():
+ ''' Main entry point for module execution
+ '''
+
+ ib_spec = dict(
+ name=dict(required=True, ib_req=True),
+ view=dict(default='default', aliases=['dns_view'], ib_req=True),
+
+ canonical=dict(required=True, aliases=['cname'], ib_req=True),
+
+ ttl=dict(type='int'),
+
+ extattrs=dict(type='dict'),
+ comment=dict(),
+ )
+
+ argument_spec = dict(
+ provider=dict(required=True),
+ state=dict(default='present', choices=['present', 'absent'])
+ )
+
+ argument_spec.update(normalize_ib_spec(ib_spec))
+ argument_spec.update(WapiModule.provider_spec)
+
+ module = AnsibleModule(argument_spec=argument_spec,
+ supports_check_mode=True)
+
+ wapi = WapiModule(module)
+ result = wapi.run(NIOS_CNAME_RECORD, ib_spec)
+
+ module.exit_json(**result)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/ansible_collections/infoblox/nios_modules/plugins/modules/nios_dns_view.py b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_dns_view.py
new file mode 100644
index 00000000..83790aca
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_dns_view.py
@@ -0,0 +1,148 @@
+#!/usr/bin/python
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+module: nios_dns_view
+author: "Peter Sprygada (@privateip)"
+short_description: Configure Infoblox NIOS DNS views
+version_added: "1.0.0"
+description:
+ - Adds and/or removes instances of DNS view objects from
+ Infoblox NIOS servers. This module manages NIOS C(view) objects
+ using the Infoblox WAPI interface over REST.
+ - Updates instances of DNS view object from Infoblox NIOS servers.
+requirements:
+ - infoblox-client
+extends_documentation_fragment: infoblox.nios_modules.nios
+notes:
+ - This module supports C(check_mode).
+options:
+ name:
+ description:
+ - Specifies the fully qualified hostname to add or remove from
+ the system. User can also update the hostname as it is possible
+ to pass a dict containing I(new_name), I(old_name). See examples.
+ required: true
+ aliases:
+ - view
+ type: str
+ network_view:
+ description:
+ - Specifies the name of the network view to assign the configured
+ DNS view to. The network view must already be configured on the
+ target system.
+ default: default
+ type: str
+ extattrs:
+ description:
+ - Allows for the configuration of Extensible Attributes on the
+ instance of the object. This argument accepts a set of key / value
+ pairs for configuration.
+ type: dict
+ comment:
+ description:
+ - Configures a text string comment to be associated with the instance
+ of this object. The provided text string will be configured on the
+ object instance.
+ type: str
+ state:
+ description:
+ - Configures the intended state of the instance of the object on
+ the NIOS server. When this value is set to C(present), the object
+ is configured on the device and when this value is set to C(absent)
+ the value is removed (if necessary) from the device.
+ default: present
+ choices:
+ - present
+ - absent
+ type: str
+
+'''
+
+EXAMPLES = '''
+- name: Configure a new dns view instance
+ infoblox.nios_modules.nios_dns_view:
+ name: ansible-dns
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Update the comment for dns view
+ infoblox.nios_modules.nios_dns_view:
+ name: ansible-dns
+ comment: this is an example comment
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Remove the dns view instance
+ infoblox.nios_modules.nios_dns_view:
+ name: ansible-dns
+ state: absent
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Update the dns view instance
+ infoblox.nios_modules.nios_dns_view:
+ name: {new_name: ansible-dns-new, old_name: ansible-dns}
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+'''
+
+RETURN = ''' # '''
+
+from ansible.module_utils.basic import AnsibleModule
+from ..module_utils.api import WapiModule
+from ..module_utils.api import NIOS_DNS_VIEW
+from ..module_utils.api import normalize_ib_spec
+
+
+def main():
+ ''' Main entry point for module execution
+ '''
+ ib_spec = dict(
+ name=dict(required=True, aliases=['view'], ib_req=True),
+ network_view=dict(default='default', ib_req=True),
+
+ extattrs=dict(type='dict'),
+ comment=dict()
+ )
+
+ argument_spec = dict(
+ provider=dict(required=True),
+ state=dict(default='present', choices=['present', 'absent'])
+ )
+
+ argument_spec.update(normalize_ib_spec(ib_spec))
+ argument_spec.update(WapiModule.provider_spec)
+
+ module = AnsibleModule(argument_spec=argument_spec,
+ supports_check_mode=True)
+
+ wapi = WapiModule(module)
+ result = wapi.run(NIOS_DNS_VIEW, ib_spec)
+
+ module.exit_json(**result)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/ansible_collections/infoblox/nios_modules/plugins/modules/nios_dtc_lbdn.py b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_dtc_lbdn.py
new file mode 100644
index 00000000..392a7cb5
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_dtc_lbdn.py
@@ -0,0 +1,242 @@
+#!/usr/bin/python
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+module: nios_dtc_lbdn
+author: "Mauricio Teixeira (@badnetmask)"
+version_added: "1.1.0"
+short_description: Configure Infoblox NIOS DTC LBDN
+description:
+ - Adds and/or removes instances of DTC Load Balanced Domain Name (LBDN)
+ objects from Infoblox NIOS servers. This module manages NIOS
+ C(dtc:lbdn) objects using the Infoblox WAPI interface over REST.
+requirements:
+ - infoblox-client
+extends_documentation_fragment: infoblox.nios_modules.nios
+notes:
+ - This module supports C(check_mode).
+options:
+ name:
+ description:
+ - Specifies the display name of the DTC LBDN, not DNS related.
+ required: true
+ type: str
+ lb_method:
+ description:
+ - Configures the load balancing method. Used to select pool.
+ required: true
+ type: str
+ choices:
+ - GLOBAL_AVAILABILITY
+ - RATIO
+ - ROUND_ROBIN
+ - TOPOLOGY
+ auth_zones:
+ description:
+ - List of linked authoritative zones.
+ - When using I(auth_zones), you must specify at least one
+ I(patterns)
+ required: false
+ type: list
+ elements: str
+ patterns:
+ description:
+ - Specify LBDN wildcards for pattern match.
+ required: false
+ type: list
+ elements: str
+ types:
+ description:
+ - Specifies the list of resource record types supported by LBDN.
+ - This option will work properly only if you set the C(wapi_version)
+ variable on your C(provider) variable to a
+ number higher than "2.6".
+ required: false
+ type: list
+ elements: str
+ choices:
+ - A
+ - AAAA
+ - CNAME
+ - NAPTR
+ - SRV
+ pools:
+ description:
+ - The pools used for load balancing.
+ required: false
+ type: list
+ elements: dict
+ suboptions:
+ pool:
+ description:
+ - Provide the name of the pool to link with
+ required: true
+ type: str
+ ratio:
+ description:
+ - Provide the weight of the pool
+ default: 1
+ required: false
+ type: int
+ ttl:
+ description:
+ - The Time To Live (TTL) value for the DTC LBDN. A 32-bit unsigned
+ integer that represents the duration, in seconds, for which the
+ record is valid (cached). Zero indicates that the record should
+ not be cached.
+ type: int
+ extattrs:
+ description:
+ - Allows for the configuration of Extensible Attributes on the
+ instance of the object. This argument accepts a set of key / value
+ pairs for configuration.
+ type: dict
+ comment:
+ description:
+ - Configures a text string comment to be associated with the instance
+ of this object. The provided text string will be configured on the
+ object instance.
+ type: str
+ state:
+ description:
+ - Configures the intended state of the instance of the object on
+ the NIOS server. When this value is set to C(present), the object
+ is configured on the device and when this value is set to C(absent)
+ the value is removed (if necessary) from the device.
+ default: present
+ choices:
+ - present
+ - absent
+ type: str
+'''
+
+EXAMPLES = '''
+- name: Configure a DTC LBDN
+ infoblox.nios_modules.nios_dtc_lbdn:
+ name: web.ansible.com
+ lb_method: ROUND_ROBIN
+ pools:
+ - pool: web_pool
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Add a comment to a DTC LBDN
+ infoblox.nios_modules.nios_dtc_lbdn:
+ name: web.ansible.com
+ lb_method: ROUND_ROBIN
+ comment: this is a test comment
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Remove a DTC LBDN from the system
+ infoblox.nios_modules.nios_dtc_lbdn:
+ name: web.ansible.com
+ lb_method: ROUND_ROBIN
+ state: absent
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+'''
+
+RETURN = ''' # '''
+
+from ..module_utils.api import NIOS_DTC_LBDN
+from ..module_utils.api import WapiModule
+from ..module_utils.api import normalize_ib_spec
+from ansible.module_utils.six import iteritems
+from ansible.module_utils.basic import AnsibleModule
+
+
+def main():
+ ''' Main entry point for module execution
+ '''
+
+ def auth_zones_transform(module):
+ zone_list = list()
+ if module.params['auth_zones']:
+ for zone in module.params['auth_zones']:
+ zone_obj = wapi.get_object('zone_auth',
+ {'fqdn': zone})
+ if zone_obj is not None:
+ zone_list.append(zone_obj[0]['_ref'])
+ else:
+ module.fail_json(
+ msg='auth_zone %s cannot be found.' % zone)
+ # epdb.serve()
+ return zone_list
+
+ def pools_transform(module):
+ pool_list = list()
+ if module.params['pools']:
+ for pool in module.params['pools']:
+ pool_obj = wapi.get_object('dtc:pool',
+ {'name': pool['pool']})
+ if 'ratio' not in pool:
+ pool['ratio'] = 1
+ if pool_obj is not None:
+ pool_list.append({'pool': pool_obj[0]['_ref'],
+ 'ratio': pool['ratio']})
+ else:
+ module.fail_json(msg='pool %s cannot be found.' % pool)
+ return pool_list
+
+ auth_zones_spec = dict()
+
+ pools_spec = dict(
+ pool=dict(required=True),
+ ratio=dict(type='int', default=1)
+ )
+
+ ib_spec = dict(
+ name=dict(required=True, ib_req=True),
+ lb_method=dict(required=True, choices=['GLOBAL_AVAILABILITY',
+ 'RATIO', 'ROUND_ROBIN', 'TOPOLOGY']),
+
+ auth_zones=dict(type='list', elements='str', options=auth_zones_spec,
+ transform=auth_zones_transform),
+ patterns=dict(type='list', elements='str'),
+ types=dict(type='list', elements='str', choices=['A', 'AAAA', 'CNAME', 'NAPTR',
+ 'SRV']),
+ pools=dict(type='list', elements='dict', options=pools_spec,
+ transform=pools_transform),
+ ttl=dict(type='int'),
+
+ extattrs=dict(type='dict'),
+ comment=dict(),
+ )
+
+ argument_spec = dict(
+ provider=dict(required=True),
+ state=dict(default='present', choices=['present', 'absent'])
+ )
+
+ argument_spec.update(normalize_ib_spec(ib_spec))
+ argument_spec.update(WapiModule.provider_spec)
+
+ module = AnsibleModule(argument_spec=argument_spec,
+ supports_check_mode=True)
+
+ wapi = WapiModule(module)
+ result = wapi.run(NIOS_DTC_LBDN, ib_spec)
+
+ module.exit_json(**result)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/ansible_collections/infoblox/nios_modules/plugins/modules/nios_dtc_pool.py b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_dtc_pool.py
new file mode 100644
index 00000000..2611fe1b
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_dtc_pool.py
@@ -0,0 +1,235 @@
+#!/usr/bin/python
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+module: nios_dtc_pool
+author: "Mauricio Teixeira (@badnetmask)"
+version_added: "1.1.0"
+short_description: Configure Infoblox NIOS DTC Pool
+description:
+ - Adds and/or removes instances of DTC Pool objects from
+ Infoblox NIOS servers. This module manages NIOS C(dtc:pool) objects
+ using the Infoblox WAPI interface over REST. A DTC pool is a collection
+ of IDNS resources (virtual servers).
+requirements:
+ - infoblox-client
+extends_documentation_fragment: infoblox.nios_modules.nios
+notes:
+ - This module supports C(check_mode).
+options:
+ name:
+ description:
+ - Specifies the DTC Pool display name
+ required: true
+ type: str
+ lb_preferred_method:
+ description:
+ - Configures the preferred load balancing method.
+ - Use this to select a method type from the pool.
+ choices:
+ - ALL_AVAILABLE
+ - DYNAMIC_RATIO
+ - GLOBAL_AVAILABILITY
+ - RATIO
+ - ROUND_ROBIN
+ - TOPOLOGY
+ required: true
+ type: str
+ servers:
+ description:
+ - Configure the DTC Servers related to the pool
+ required: false
+ type: list
+ elements: dict
+ suboptions:
+ server:
+ description:
+ - Provide the name of the DTC Server
+ required: true
+ type: str
+ ratio:
+ description:
+ - Provide the weight of the server
+ default: 1
+ required: false
+ type: int
+ monitors:
+ description:
+ - Specifies the health monitors related to pool.
+ - The format of this parameter is required due to an API
+ limitation.
+ - This option only works if you set the C(wapi_version)
+ variable on your C(provider) variable to a number higher
+ than "2.6".
+ required: false
+ type: list
+ elements: dict
+ suboptions:
+ name:
+ description:
+ - Provide the name of the health monitor.
+ required: true
+ type: str
+ type:
+ description:
+ - Provide the type of health monitor.
+ choices:
+ - http
+ - icmp
+ - tcp
+ - pdp
+ - sip
+ - snmp
+ required: true
+ type: str
+ extattrs:
+ description:
+ - Allows for the configuration of Extensible Attributes on the
+ instance of the object. This argument accepts a set of key / value
+ pairs for configuration.
+ type: dict
+ comment:
+ description:
+ - Configures a text string comment to be associated with the instance
+ of this object. The provided text string will be configured on the
+ object instance.
+ type: str
+ state:
+ description:
+ - Configures the intended state of the instance of the object on
+ the NIOS server. When this value is set to C(present), the object
+ is configured on the device and when this value is set to C(absent)
+ the value is removed (if necessary) from the device.
+ default: present
+ choices:
+ - present
+ - absent
+ type: str
+'''
+
+EXAMPLES = '''
+- name: Configure a DTC Pool
+ infoblox.nios_modules.nios_dtc_pool:
+ name: web_pool
+ lb_preferred_method: ROUND_ROBIN
+ servers:
+ - server: a.ansible.com
+ - server: b.ansible.com
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Add a comment to a DTC Pool
+ infoblox.nios_modules.nios_dtc_pool:
+ name: web_pool
+ lb_preferred_method: ROUND_ROBIN
+ comment: this is a test comment
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Remove a DTC Pool from the system
+ infoblox.nios_modules.nios_dtc_pool:
+ name: web_pool
+ lb_preferred_method: ROUND_ROBIN
+ state: absent
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+'''
+
+RETURN = ''' # '''
+
+from ..module_utils.api import NIOS_DTC_POOL
+from ..module_utils.api import WapiModule
+from ..module_utils.api import normalize_ib_spec
+from ansible.module_utils.six import iteritems
+from ansible.module_utils.basic import AnsibleModule
+
+
+def main():
+ ''' Main entry point for module execution
+ '''
+
+ def servers_transform(module):
+ server_list = list()
+ if module.params['servers']:
+ for server in module.params['servers']:
+ server_obj = wapi.get_object('dtc:server',
+ {'name': server['server']})
+ if server_obj is not None:
+ server_list.append({'server': server_obj[0]['_ref'],
+ 'ratio': server['ratio']})
+ return server_list
+
+ def monitors_transform(module):
+ monitor_list = list()
+ if module.params['monitors']:
+ for monitor in module.params['monitors']:
+ monitor_obj = wapi.get_object('dtc:monitor:' + monitor['type'],
+ {'name': monitor['name']})
+ if monitor_obj is not None:
+ monitor_list.append(monitor_obj[0]['_ref'])
+ return monitor_list
+
+ servers_spec = dict(
+ server=dict(required=True),
+ ratio=dict(type='int', default=1)
+ )
+
+ monitors_spec = dict(
+ name=dict(required=True),
+ type=dict(required=True, choices=['http', 'icmp', 'tcp', 'pdp', 'sip', 'snmp'])
+ )
+
+ ib_spec = dict(
+ name=dict(required=True, ib_req=True),
+ lb_preferred_method=dict(required=True, choices=['ALL_AVAILABLE',
+ 'DYNAMIC_RATIO',
+ 'GLOBAL_AVAILABILITY',
+ 'RATIO',
+ 'ROUND_ROBIN',
+ 'TOPOLOGY']),
+
+ servers=dict(type='list', elements='dict', options=servers_spec,
+ transform=servers_transform),
+ monitors=dict(type='list', elements='dict', options=monitors_spec,
+ transform=monitors_transform),
+
+ extattrs=dict(type='dict'),
+ comment=dict(),
+ )
+
+ argument_spec = dict(
+ provider=dict(required=True),
+ state=dict(default='present', choices=['present', 'absent'])
+ )
+
+ argument_spec.update(normalize_ib_spec(ib_spec))
+ argument_spec.update(WapiModule.provider_spec)
+
+ module = AnsibleModule(argument_spec=argument_spec,
+ supports_check_mode=True)
+
+ wapi = WapiModule(module)
+ result = wapi.run(NIOS_DTC_POOL, ib_spec)
+
+ module.exit_json(**result)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/ansible_collections/infoblox/nios_modules/plugins/modules/nios_dtc_server.py b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_dtc_server.py
new file mode 100644
index 00000000..d2810a80
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_dtc_server.py
@@ -0,0 +1,144 @@
+#!/usr/bin/python
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+module: nios_dtc_server
+author: "Mauricio Teixeira (@badnetmask)"
+short_description: Configure Infoblox NIOS DTC Server
+version_added: "1.1.0"
+description:
+ - Adds and/or removes instances of DTC Server objects from
+ Infoblox NIOS servers. This module manages NIOS C(dtc:server) objects
+ using the Infoblox WAPI interface over REST.
+requirements:
+ - infoblox-client
+extends_documentation_fragment: infoblox.nios_modules.nios
+notes:
+ - This module supports C(check_mode).
+options:
+ name:
+ description:
+ - Specifies the DTC Server display name
+ required: true
+ type: str
+ host:
+ description:
+ - Configures the IP address (A response) or FQDN (CNAME response)
+ of the server
+ required: true
+ type: str
+ disable:
+ description:
+ - Determines whether the DTC Server is disabled or not.
+ When this is set to False, the fixed address is enabled.
+ required: false
+ type: bool
+ default: False
+ extattrs:
+ description:
+ - Allows for the configuration of Extensible Attributes on the
+ instance of the object. This argument accepts a set of key / value
+ pairs for configuration.
+ type: dict
+ comment:
+ description:
+ - Configures a text string comment to be associated with the instance
+ of this object. The provided text string will be configured on the
+ object instance.
+ type: str
+ state:
+ description:
+ - Configures the intended state of the instance of the object on
+ the NIOS server. When this value is set to C(present), the object
+ is configured on the device and when this value is set to C(absent)
+ the value is removed (if necessary) from the device.
+ default: present
+ choices:
+ - present
+ - absent
+ type: str
+'''
+
+EXAMPLES = '''
+- name: Configure a DTC Server
+ infoblox.nios_modules.nios_dtc_server:
+ name: a.example.com
+ host: 192.168.10.1
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Add a comment to a DTC server
+ infoblox.nios_modules.nios_dtc_server:
+ name: a.example.com
+ host: 192.168.10.1
+ comment: this is a test comment
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Remove a DTC Server from the system
+ infoblox.nios_modules.nios_dtc_server:
+ name: a.example.com
+ host: 192.168.10.1
+ state: absent
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+'''
+
+RETURN = ''' # '''
+
+from ansible.module_utils.basic import AnsibleModule
+from ansible.module_utils.six import iteritems
+from ..module_utils.api import WapiModule
+from ..module_utils.api import NIOS_DTC_SERVER
+from ..module_utils.api import normalize_ib_spec
+
+
+def main():
+ ''' Main entry point for module execution
+ '''
+
+ ib_spec = dict(
+ name=dict(required=True, ib_req=True),
+ host=dict(required=True, ib_req=True),
+
+ disable=dict(type='bool', default=False),
+ extattrs=dict(type='dict'),
+ comment=dict(),
+ )
+
+ argument_spec = dict(
+ provider=dict(required=True),
+ state=dict(default='present', choices=['present', 'absent'])
+ )
+
+ argument_spec.update(normalize_ib_spec(ib_spec))
+ argument_spec.update(WapiModule.provider_spec)
+
+ module = AnsibleModule(argument_spec=argument_spec,
+ supports_check_mode=True)
+
+ wapi = WapiModule(module)
+ result = wapi.run(NIOS_DTC_SERVER, ib_spec)
+
+ module.exit_json(**result)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/ansible_collections/infoblox/nios_modules/plugins/modules/nios_fixed_address.py b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_fixed_address.py
new file mode 100644
index 00000000..c01d762e
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_fixed_address.py
@@ -0,0 +1,324 @@
+#!/usr/bin/python
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+module: nios_fixed_address
+author: "Sumit Jaiswal (@sjaiswal)"
+short_description: Configure Infoblox NIOS DHCP Fixed Address
+version_added: "1.0.0"
+description:
+ - A fixed address is a specific IP address that a DHCP server
+ always assigns when a lease request comes from a particular
+ MAC address of the client.
+ - A fix address reservation is a specific IP address that a DHCP
+ server reserves and never assigns to a client.
+ - Supports both IPV4 and IPV6 internet protocols.
+requirements:
+ - infoblox-client
+extends_documentation_fragment: infoblox.nios_modules.nios
+notes:
+ - The "mac" field is mandatory for all CRUD operations relating to
+ IPv4 Fixed address.
+ - The "duid" field is mandatory for all CRUD operations relating to
+ IPv6 Fixed address.
+ - This module supports C(check_mode).
+options:
+ name:
+ description:
+ - Specifies the hostname with which fixed DHCP ip-address is stored
+ for respective mac.
+ type: str
+ required: true
+ ipaddr:
+ description:
+ - IPV4/V6 address of the fixed address.
+ type: str
+ required: true
+ mac:
+ description:
+ - The MAC address of the IPv4 interface. For a fix address reservation
+ specify mac address as 00:00:00:00:00:00
+ type: str
+ duid:
+ description:
+ - The DUID address of the IPv6 interface.
+ type: str
+ network:
+ description:
+ - Specifies the network range in which ipaddr exists.
+ type: str
+ aliases:
+ - network
+ network_view:
+ description:
+ - Configures the name of the network view to associate with this
+ configured instance.
+ type: str
+ default: default
+ options:
+ description:
+ - Configures the set of DHCP options to be included as part of
+ the configured network instance. This argument accepts a list
+ of values (see suboptions). When configuring suboptions at
+ least one of C(name) or C(num) must be specified.
+ type: list
+ elements: dict
+ suboptions:
+ name:
+ description:
+ - The name of the DHCP option to configure
+ type: str
+ num:
+ description:
+ - The number of the DHCP option to configure
+ type: int
+ value:
+ description:
+ - The value of the DHCP option specified by C(name)
+ type: str
+ required: true
+ use_option:
+ description:
+ - Only applies to a subset of options (see NIOS API documentation)
+ type: bool
+ default: 'yes'
+ vendor_class:
+ description:
+ - The name of the space this DHCP option is associated to
+ type: str
+ default: DHCP
+ extattrs:
+ description:
+ - Allows for the configuration of Extensible Attributes on the
+ instance of the object. This argument accepts a set of key / value
+ pairs for configuration.
+ type: dict
+ comment:
+ description:
+ - Configures a text string comment to be associated with the instance
+ of this object. The provided text string will be configured on the
+ object instance.
+ type: str
+ state:
+ description:
+ - Configures the intended state of the instance of the object on
+ the NIOS server. When this value is set to C(present), the object
+ is configured on the device and when this value is set to C(absent)
+ the value is removed (if necessary) from the device.
+ type: str
+ default: present
+ choices:
+ - present
+ - absent
+'''
+
+EXAMPLES = '''
+- name: Configure an ipv4 dhcp fixed address
+ infoblox.nios_modules.nios_fixed_address:
+ name: ipv4_fixed
+ ipaddr: 192.168.10.1
+ mac: 08:6d:41:e8:fd:e8
+ network: 192.168.10.0/24
+ network_view: default
+ comment: this is a test comment
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Configure an ipv4 dhcp fixed address reservation
+ infoblox.nios_modules.nios_fixed_address:
+ name: ipv4_fixed
+ ipaddr: 192.168.10.1
+ mac: 00:00:00:00:00:00
+ network: 192.168.10.0/24
+ network_view: default
+ comment: this is a test comment
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Configure an ipv6 dhcp fixed address
+ infoblox.nios_modules.nios_fixed_address:
+ name: ipv6_fixed
+ ipaddr: fe80::1/10
+ mac: 08:6d:41:e8:fd:e8
+ network: fe80::/64
+ network_view: default
+ comment: this is a test comment
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Set dhcp options for an ipv4 fixed address
+ infoblox.nios_modules.nios_fixed_address:
+ name: ipv4_fixed
+ ipaddr: 192.168.10.1
+ mac: 08:6d:41:e8:fd:e8
+ network: 192.168.10.0/24
+ network_view: default
+ comment: this is a test comment
+ options:
+ - name: domain-name
+ value: ansible.com
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Remove an ipv4 dhcp fixed address
+ infoblox.nios_modules.nios_fixed_address:
+ name: ipv4_fixed
+ ipaddr: 192.168.10.1
+ mac: 08:6d:41:e8:fd:e8
+ network: 192.168.10.0/24
+ network_view: default
+ state: absent
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+'''
+
+RETURN = ''' # '''
+
+from ansible.module_utils.basic import AnsibleModule
+from ansible.module_utils.six import iteritems
+from ..module_utils.api import NIOS_IPV4_FIXED_ADDRESS, NIOS_IPV6_FIXED_ADDRESS
+from ..module_utils.api import WapiModule
+from ..module_utils.api import normalize_ib_spec
+from ..module_utils.network import validate_ip_address, validate_ip_v6_address
+
+
+def options(module):
+ ''' Transforms the module argument into a valid WAPI struct
+ This function will transform the options argument into a structure that
+ is a valid WAPI structure in the format of:
+ {
+ name: <value>,
+ num: <value>,
+ value: <value>,
+ use_option: <value>,
+ vendor_class: <value>
+ }
+ It will remove any options that are set to None since WAPI will error on
+ that condition. The use_option field only applies
+ to special options that are displayed separately from other options and
+ have a use flag. This function removes the use_option flag from all
+ other options. It will also verify that either `name` or `num` is
+ set in the structure but does not validate the values are equal.
+ The remainder of the value validation is performed by WAPI
+ '''
+ special_options = ['routers', 'router-templates', 'domain-name-servers',
+ 'domain-name', 'broadcast-address', 'broadcast-address-offset',
+ 'dhcp-lease-time', 'dhcp6.name-servers']
+ # options-router-templates, broadcast-address-offset, dhcp6.name-servers don't have any associated number
+ special_num = [3, 6, 15, 28, 51]
+ options = list()
+ for item in module.params['options']:
+ opt = dict([(k, v) for k, v in iteritems(item) if v is not None])
+ if 'name' not in opt and 'num' not in opt:
+ module.fail_json(msg='one of `name` or `num` is required for option value')
+ if 'name' in opt and opt['name'] not in special_options:
+ del opt['use_option']
+ if 'num' in opt and opt['num'] not in special_num:
+ del opt['use_option']
+ options.append(opt)
+ return options
+
+
+def validate_ip_addr_type(ip, arg_spec, module):
+ '''This function will check if the argument ip is type v4/v6 and return appropriate infoblox network type
+ '''
+ check_ip = ip.split('/')
+
+ if validate_ip_address(check_ip[0]) and 'ipaddr' in arg_spec:
+ arg_spec['ipv4addr'] = arg_spec.pop('ipaddr')
+ module.params['ipv4addr'] = module.params.pop('ipaddr')
+ del arg_spec['duid']
+ del module.params['duid']
+ if module.params["mac"] is None:
+ raise ValueError("the 'mac' address of the object must be specified")
+ module.params['mac'] = module.params['mac'].lower()
+ return NIOS_IPV4_FIXED_ADDRESS, arg_spec, module
+ elif validate_ip_v6_address(check_ip[0]) and 'ipaddr' in arg_spec:
+ arg_spec['ipv6addr'] = arg_spec.pop('ipaddr')
+ module.params['ipv6addr'] = module.params.pop('ipaddr')
+ del arg_spec['mac']
+ del module.params['mac']
+ if module.params["duid"] is None:
+ raise ValueError("the 'duid' of the object must be specified")
+ module.params['duid'] = module.params['duid'].lower()
+ return NIOS_IPV6_FIXED_ADDRESS, arg_spec, module
+
+
+def main():
+ ''' Main entry point for module execution
+ '''
+ option_spec = dict(
+ # one of name or num is required; enforced by the function options()
+ name=dict(),
+ num=dict(type='int'),
+
+ value=dict(required=True),
+
+ use_option=dict(type='bool', default=True),
+ vendor_class=dict(default='DHCP')
+ )
+
+ ib_spec = dict(
+ name=dict(required=True),
+ ipaddr=dict(required=True, ib_req=True, type='str'),
+ mac=dict(ib_req=True, type='str'),
+ duid=dict(ib_req=True, type='str'),
+ network=dict(),
+ network_view=dict(default='default'),
+
+ options=dict(type='list', elements='dict', options=option_spec, transform=options),
+
+ extattrs=dict(type='dict'),
+ comment=dict(type='str')
+ )
+
+ argument_spec = dict(
+ provider=dict(required=True),
+ state=dict(default='present', choices=['present', 'absent'])
+ )
+
+ argument_spec.update(normalize_ib_spec(ib_spec))
+ argument_spec.update(WapiModule.provider_spec)
+
+ module = AnsibleModule(argument_spec=argument_spec,
+ supports_check_mode=True)
+
+ # to get the argument ipaddr
+ obj_filter = dict([(k, module.params[k]) for k, v in iteritems(ib_spec) if v.get('ib_req')])
+ # to modify argument based on ipaddr type i.e. IPV4/IPV6
+ fixed_address_ip_type, ib_spec, module = validate_ip_addr_type(obj_filter['ipaddr'], ib_spec, module)
+
+ wapi = WapiModule(module)
+
+ result = wapi.run(fixed_address_ip_type, ib_spec)
+
+ module.exit_json(**result)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/ansible_collections/infoblox/nios_modules/plugins/modules/nios_host_record.py b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_host_record.py
new file mode 100644
index 00000000..31f7f513
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_host_record.py
@@ -0,0 +1,373 @@
+#!/usr/bin/python
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+module: nios_host_record
+author: "Peter Sprygada (@privateip)"
+short_description: Configure Infoblox NIOS host records
+version_added: "1.0.0"
+description:
+ - Adds and/or removes instances of host record objects from
+ Infoblox NIOS servers. This module manages NIOS C(record:host) objects
+ using the Infoblox WAPI interface over REST.
+ - Updates instances of host record object from Infoblox NIOS servers.
+requirements:
+ - infoblox-client
+extends_documentation_fragment: infoblox.nios_modules.nios
+notes:
+ - This module supports C(check_mode).
+options:
+ name:
+ description:
+ - Specifies the fully qualified hostname to add or remove from
+ the system. User can also update the hostname as it is possible
+ to pass a dict containing I(new_name), I(old_name). See examples.
+ type: str
+ required: true
+ view:
+ description:
+ - Sets the DNS view to associate this host record with. The DNS
+ view must already be configured on the system.
+ type: str
+ default: default
+ aliases:
+ - dns_view
+ configure_for_dns:
+ description:
+ - Sets the DNS to particular parent. If user needs to bypass DNS
+ user can make the value to false.
+ type: bool
+ default: true
+ aliases:
+ - dns
+ ipv4addrs:
+ description:
+ - Configures the IPv4 addresses for this host record. This argument
+ accepts a list of values (see suboptions).
+ type: list
+ elements: dict
+ aliases:
+ - ipv4
+ suboptions:
+ ipv4addr:
+ description:
+ - Configures the IPv4 address for the host record. Users can dynamically
+ allocate ipv4 address to host record by passing dictionary containing,
+ I(nios_next_ip) and I(CIDR network range). If user wants to add or
+ remove the ipv4 address from existing record, I(add/remove)
+ params need to be used. See examples.
+ type: str
+ required: true
+ aliases:
+ - address
+ configure_for_dhcp:
+ description:
+ - Configure the host_record over DHCP instead of DNS, if user
+ changes it to true, user need to mention MAC address to configure.
+ type: bool
+ required: false
+ aliases:
+ - dhcp
+ mac:
+ description:
+ - Configures the hardware MAC address for the host record. If user makes
+ DHCP to true, user need to mention MAC address.
+ type: str
+ required: false
+ aliases:
+ - mac
+ add:
+ version_added: "1.0.0"
+ description:
+ - If user wants to add the ipv4 address to an existing host record.
+ Note that with I(add) user will have to keep the I(state) as I(present),
+ as new IP address is allocated to existing host record. See examples.
+ type: bool
+ required: false
+ aliases:
+ - add
+ remove:
+ version_added: "1.0.0"
+ description:
+ - If user wants to remove the ipv4 address from an existing host record.
+ Note that with I(remove) user will have to change the I(state) to I(absent),
+ as IP address is de-allocated from an existing host record. See examples.
+ type: bool
+ required: false
+ aliases:
+ - remove
+ ipv6addrs:
+ description:
+ - Configures the IPv6 addresses for the host record. This argument
+ accepts a list of values (see options).
+ type: list
+ elements: dict
+ aliases:
+ - ipv6
+ suboptions:
+ ipv6addr:
+ description:
+ - Configures the IPv6 address for the host record.
+ type: str
+ required: true
+ aliases:
+ - address
+ configure_for_dhcp:
+ description:
+ - Configure the host_record over DHCP instead of DNS, if user
+ changes it to true, user need to mention MAC address to configure.
+ type: bool
+ required: false
+ mac:
+ description:
+ - Configures the hardware MAC address for the host record. If user makes
+ DHCP to true, user need to mention MAC address.
+ type: str
+ required: false
+ aliases:
+ - mac
+ aliases:
+ description:
+ - Configures an optional list of additional aliases to add to the host
+ record. These are equivalent to CNAMEs but held within a host
+ record. Must be in list format.
+ type: list
+ elements: str
+ ttl:
+ description:
+ - Configures the TTL to be associated with this host record.
+ type: int
+ extattrs:
+ description:
+ - Allows for the configuration of Extensible Attributes on the
+ instance of the object. This argument accepts a set of key / value
+ pairs for configuration.
+ type: dict
+ comment:
+ description:
+ - Configures a text string comment to be associated with the instance
+ of this object. The provided text string will be configured on the
+ object instance.
+ type: str
+ state:
+ description:
+ - Configures the intended state of the instance of the object on
+ the NIOS server. When this value is set to C(present), the object
+ is configured on the device and when this value is set to C(absent)
+ the value is removed (if necessary) from the device.
+ type: str
+ default: present
+ choices:
+ - present
+ - absent
+'''
+
+EXAMPLES = '''
+- name: Configure an ipv4 host record
+ infoblox.nios_modules.nios_host_record:
+ name: host.ansible.com
+ ipv4:
+ - address: 192.168.10.1
+ aliases:
+ - cname.ansible.com
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Add a comment to an existing host record
+ infoblox.nios_modules.nios_host_record:
+ name: host.ansible.com
+ ipv4:
+ - address: 192.168.10.1
+ comment: this is a test comment
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Remove a host record from the system
+ infoblox.nios_modules.nios_host_record:
+ name: host.ansible.com
+ state: absent
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Update an ipv4 host record
+ infoblox.nios_modules.nios_host_record:
+ name: {new_name: host-new.ansible.com, old_name: host.ansible.com}
+ ipv4:
+ - address: 192.168.10.1
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Create an ipv4 host record bypassing DNS
+ infoblox.nios_modules.nios_host_record:
+ name: new_host
+ ipv4:
+ - address: 192.168.10.1
+ dns: false
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Create an ipv4 host record over DHCP
+ infoblox.nios_modules.nios_host_record:
+ name: host.ansible.com
+ ipv4:
+ - address: 192.168.10.1
+ dhcp: true
+ mac: 00-80-C8-E3-4C-BD
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Dynamically add host record to next available ip
+ infoblox.nios_modules.nios_host_record:
+ name: host.ansible.com
+ ipv4:
+ - address: {nios_next_ip: 192.168.10.0/24}
+ comment: this is a test comment
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Add ip to host record
+ infoblox.nios_modules.nios_host_record:
+ name: host.ansible.com
+ ipv4:
+ - address: 192.168.10.2
+ add: true
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Remove ip from host record
+ infoblox.nios_modules.nios_host_record:
+ name: host.ansible.com
+ ipv4:
+ - address: 192.168.10.1
+ remove: true
+ state: absent
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+'''
+
+RETURN = ''' # '''
+
+from ansible.module_utils.basic import AnsibleModule
+from ansible.module_utils.six import iteritems
+from ..module_utils.api import WapiModule
+from ..module_utils.api import NIOS_HOST_RECORD
+from ..module_utils.api import normalize_ib_spec
+
+
+def ipaddr(module, key, filtered_keys=None):
+ ''' Transforms the input value into a struct supported by WAPI
+ This function will transform the input from the playbook into a struct
+ that is valid for WAPI in the form of:
+ {
+ ipv4addr: <value>,
+ mac: <value>
+ }
+ This function does not validate the values are properly formatted or in
+ the acceptable range, that is left to WAPI.
+ '''
+ filtered_keys = filtered_keys or list()
+ objects = list()
+ for item in module.params[key]:
+ objects.append(dict([(k, v) for k, v in iteritems(item) if v is not None and k not in filtered_keys]))
+ return objects
+
+
+def ipv4addrs(module):
+ return ipaddr(module, 'ipv4addrs', filtered_keys=['address', 'dhcp'])
+
+
+def ipv6addrs(module):
+ return ipaddr(module, 'ipv6addrs', filtered_keys=['address', 'dhcp'])
+
+
+def main():
+ ''' Main entry point for module execution
+ '''
+ ipv4addr_spec = dict(
+ ipv4addr=dict(required=True, aliases=['address']),
+ configure_for_dhcp=dict(type='bool', required=False, aliases=['dhcp']),
+ mac=dict(required=False),
+ add=dict(type='bool', required=False),
+ remove=dict(type='bool', required=False)
+ )
+
+ ipv6addr_spec = dict(
+ ipv6addr=dict(required=True, aliases=['address']),
+ configure_for_dhcp=dict(type='bool', required=False),
+ mac=dict(required=False)
+ )
+
+ ib_spec = dict(
+ name=dict(required=True, ib_req=True),
+ view=dict(default='default', aliases=['dns_view'], ib_req=True),
+
+ ipv4addrs=dict(type='list', aliases=['ipv4'], elements='dict', options=ipv4addr_spec, transform=ipv4addrs),
+ ipv6addrs=dict(type='list', aliases=['ipv6'], elements='dict', options=ipv6addr_spec, transform=ipv6addrs),
+ configure_for_dns=dict(type='bool', default=True, required=False, aliases=['dns'], ib_req=True),
+ aliases=dict(type='list', elements='str'),
+
+ ttl=dict(type='int'),
+
+ extattrs=dict(type='dict'),
+ comment=dict(),
+ )
+
+ argument_spec = dict(
+ provider=dict(required=True),
+ state=dict(default='present', choices=['present', 'absent'])
+ )
+
+ argument_spec.update(normalize_ib_spec(ib_spec))
+ argument_spec.update(WapiModule.provider_spec)
+
+ module = AnsibleModule(argument_spec=argument_spec,
+ supports_check_mode=True)
+
+ wapi = WapiModule(module)
+ result = wapi.run(NIOS_HOST_RECORD, ib_spec)
+
+ module.exit_json(**result)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/ansible_collections/infoblox/nios_modules/plugins/modules/nios_member.py b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_member.py
new file mode 100644
index 00000000..38a6899b
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_member.py
@@ -0,0 +1,575 @@
+#!/usr/bin/python
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+module: nios_member
+author: "Krishna Vasudevan (@krisvasudevan)"
+short_description: Configure Infoblox NIOS members
+version_added: "1.0.0"
+description:
+ - Adds and/or removes Infoblox NIOS servers. This module manages NIOS C(member) objects using the Infoblox WAPI interface over REST.
+requirements:
+ - infoblox-client
+extends_documentation_fragment: infoblox.nios_modules.nios
+notes:
+ - This module supports C(check_mode).
+options:
+ host_name:
+ description:
+ - Specifies the host name of the member to either add or remove from
+ the NIOS instance.
+ required: true
+ aliases:
+ - name
+ type: str
+ vip_setting:
+ description:
+ - Configures the network settings for the grid member.
+ suboptions:
+ address:
+ description:
+ - The IPv4 Address of the Grid Member
+ type: str
+ subnet_mask:
+ description:
+ - The subnet mask for the Grid Member
+ type: str
+ gateway:
+ description:
+ - The default gateway for the Grid Member
+ type: str
+ type: list
+ elements: dict
+ ipv6_setting:
+ description:
+ - Configures the IPv6 settings for the grid member.
+ suboptions:
+ virtual_ip:
+ description:
+ - The IPv6 Address of the Grid Member
+ type: str
+ cidr_prefix:
+ description:
+ - The IPv6 CIDR prefix for the Grid Member
+ type: int
+ gateway:
+ description:
+ - The gateway address for the Grid Member
+ type: str
+ type: list
+ elements: dict
+ config_addr_type:
+ description:
+ - Address configuration type (IPV4/IPV6/BOTH).
+ default: IPV4
+ type: str
+ comment:
+ description:
+ - A descriptive comment of the Grid member.
+ type: str
+ extattrs:
+ description:
+ - Extensible attributes associated with the object.
+ type: dict
+ enable_ha:
+ description:
+ - If set to True, the member has two physical nodes (HA pair).
+ default: False
+ type: bool
+ router_id:
+ description:
+ - Virtual router identifier. Provide this ID if "ha_enabled" is set to "true". This is a unique VRID number (from 1 to 255) for the local subnet.
+ type: int
+ lan2_enabled:
+ description:
+ - When set to "true", the LAN2 port is enabled as an independent port or as a port for failover purposes.
+ default: False
+ type: bool
+ lan2_port_setting:
+ description:
+ - Settings for the Grid member LAN2 port if 'lan2_enabled' is set to "true".
+ type: list
+ elements: dict
+ suboptions:
+ enabled:
+ description:
+ - If set to True, then it has its own IP settings.
+ type: bool
+ network_setting:
+ description:
+ - If the 'enable' field is set to True, this defines IPv4 network settings for LAN2.
+ suboptions:
+ address:
+ description:
+ - The IPv4 Address of LAN2
+ type: str
+ subnet_mask:
+ description:
+ - The subnet mask of LAN2
+ type: str
+ gateway:
+ description:
+ - The default gateway of LAN2
+ type: str
+ type: list
+ elements: dict
+ v6_network_setting:
+ description:
+ - If the 'enable' field is set to True, this defines IPv6 network settings for LAN2.
+ type: list
+ elements: dict
+ suboptions:
+ virtual_ip:
+ description:
+ - The IPv6 Address of LAN2
+ type: str
+ cidr_prefix:
+ description:
+ - The IPv6 CIDR prefix of LAN2
+ type: int
+ gateway:
+ description:
+ - The gateway address of LAN2
+ type: str
+ platform:
+ description:
+ - Configures the Hardware Platform.
+ default: INFOBLOX
+ type: str
+ node_info:
+ description:
+ - Configures the node information list with detailed status report on the operations of the Grid Member.
+ type: list
+ elements: dict
+ suboptions:
+ lan2_physical_setting:
+ description:
+ - Physical port settings for the LAN2 interface.
+ suboptions:
+ auto_port_setting_enabled:
+ description:
+ - Enable or disalbe the auto port setting.
+ type: bool
+ duplex:
+ description:
+ - The port duplex; if speed is 1000, duplex must be FULL.
+ type: str
+ speed:
+ description:
+ - The port speed; if speed is 1000, duplex is FULL.
+ type: str
+ type: list
+ elements: dict
+ lan_ha_port_setting:
+ description:
+ - LAN/HA port settings for the node.
+ type: list
+ elements: dict
+ suboptions:
+ ha_ip_address:
+ description:
+ - HA IP address.
+ type: str
+ ha_port_setting:
+ description:
+ - Physical port settings for the HA interface.
+ type: list
+ elements: dict
+ suboptions:
+ auto_port_setting_enabled:
+ description:
+ - Enable or disalbe the auto port setting.
+ type: bool
+ duplex:
+ description:
+ - The port duplex; if speed is 1000, duplex must be FULL.
+ type: str
+ speed:
+ description:
+ - The port speed; if speed is 1000, duplex is FULL.
+ type: str
+ lan_port_setting:
+ description:
+ - Physical port settings for the LAN interface.
+ type: list
+ elements: dict
+ suboptions:
+ auto_port_setting_enabled:
+ description:
+ - Enable or disalbe the auto port setting.
+ type: bool
+ duplex:
+ description:
+ - The port duplex; if speed is 1000, duplex must be FULL.
+ type: str
+ speed:
+ description:
+ - The port speed; if speed is 1000, duplex is FULL.
+ type: str
+ mgmt_ipv6addr:
+ description:
+ - Public IPv6 address for the LAN1 interface.
+ type: str
+ mgmt_lan:
+ description:
+ - Public IPv4 address for the LAN1 interface.
+ type: str
+ mgmt_network_setting:
+ description:
+ - Network settings for the MGMT port of the node.
+ type: list
+ elements: dict
+ suboptions:
+ address:
+ description:
+ - The IPv4 Address of MGMT
+ type: str
+ subnet_mask:
+ description:
+ - The subnet mask of MGMT
+ type: str
+ gateway:
+ description:
+ - The default gateway of MGMT
+ type: str
+ v6_mgmt_network_setting:
+ description:
+ - The network settings for the IPv6 MGMT port of the node.
+ type: list
+ elements: dict
+ suboptions:
+ virtual_ip:
+ description:
+ - The IPv6 Address of MGMT
+ type: str
+ cidr_prefix:
+ description:
+ - The IPv6 CIDR prefix of MGMT
+ type: int
+ gateway:
+ description:
+ - The gateway address of MGMT
+ type: str
+ mgmt_port_setting:
+ description:
+ - Settings for the member MGMT port.
+ type: list
+ elements: dict
+ suboptions:
+ enabled:
+ description:
+ - Determines if MGMT port settings should be enabled.
+ type: bool
+ security_access_enabled:
+ description:
+ - Determines if security access on the MGMT port is enabled or not.
+ type: bool
+ vpn_enabled:
+ description:
+ - Determines if VPN on the MGMT port is enabled or not.
+ type: bool
+ upgrade_group:
+ description:
+ - The name of the upgrade group to which this Grid member belongs.
+ default: Default
+ type: str
+ use_syslog_proxy_setting:
+ description:
+ - Use flag for external_syslog_server_enable , syslog_servers, syslog_proxy_setting, syslog_size.
+ type: bool
+ external_syslog_server_enable:
+ description:
+ - Determines if external syslog servers should be enabled.
+ type: bool
+ syslog_servers:
+ description:
+ - The list of external syslog servers.
+ type: list
+ elements: dict
+ suboptions:
+ address:
+ description:
+ - The server address.
+ type: str
+ category_list:
+ description:
+ - The list of all syslog logging categories.
+ type: list
+ elements: str
+ connection_type:
+ description:
+ - The connection type for communicating with this server.(STCP/TCP?UDP)
+ default: UDP
+ type: str
+ local_interface:
+ description:
+ - The local interface through which the appliance sends syslog messages to the syslog server.(ANY/LAN/MGMT)
+ default: ANY
+ type: str
+ message_node_id:
+ description:
+ - Identify the node in the syslog message. (HOSTNAME/IP_HOSTNAME/LAN/MGMT)
+ default: LAN
+ type: str
+ message_source:
+ description:
+ - The source of syslog messages to be sent to the external syslog server.
+ default: ANY
+ type: str
+ only_category_list:
+ description:
+ - The list of selected syslog logging categories. The appliance forwards syslog messages that belong to the selected categories.
+ type: bool
+ port:
+ description:
+ - The port this server listens on.
+ default: 514
+ type: int
+ severity:
+ description:
+ - The severity filter. The appliance sends log messages of the specified severity and above to the external syslog server.
+ default: DEBUG
+ type: str
+ pre_provisioning:
+ description:
+ - Pre-provisioning information.
+ type: list
+ elements: dict
+ suboptions:
+ hardware_info:
+ description:
+ - An array of structures that describe the hardware being pre-provisioned.
+ type: list
+ elements: dict
+ suboptions:
+ hwmodel:
+ description:
+ - Hardware model
+ type: str
+ hwtype:
+ description:
+ - Hardware type.
+ type: str
+ licenses:
+ description:
+ - An array of license types.
+ type: list
+ elements: str
+ create_token:
+ description:
+ - Flag for initiating a create token request for pre-provisioned members.
+ type: bool
+ default: False
+ state:
+ description:
+ - Configures the intended state of the instance of the object on
+ the NIOS server. When this value is set to C(present), the object
+ is configured on the device and when this value is set to C(absent)
+ the value is removed (if necessary) from the device.
+ default: present
+ choices:
+ - present
+ - absent
+ type: str
+'''
+
+EXAMPLES = '''
+- name: Add a member to the grid with IPv4 address
+ infoblox.nios_modules.nios_member:
+ host_name: member01.localdomain
+ vip_setting:
+ - address: 192.168.1.100
+ subnet_mask: 255.255.255.0
+ gateway: 192.168.1.1
+ config_addr_type: IPV4
+ platform: VNIOS
+ comment: "Created by Ansible"
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Add a HA member to the grid
+ infoblox.nios_modules.nios_member:
+ host_name: memberha.localdomain
+ vip_setting:
+ - address: 192.168.1.100
+ subnet_mask: 255.255.255.0
+ gateway: 192.168.1.1
+ config_addr_type: IPV4
+ platform: VNIOS
+ enable_ha: true
+ router_id: 150
+ node_info:
+ - lan_ha_port_setting:
+ - ha_ip_address: 192.168.1.70
+ mgmt_lan: 192.168.1.80
+ - lan_ha_port_setting:
+ - ha_ip_address: 192.168.1.71
+ mgmt_lan: 192.168.1.81
+ comment: "Created by Ansible"
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Update the member with pre-provisioning details specified
+ infoblox.nios_modules.nios_member:
+ name: member01.localdomain
+ pre_provisioning:
+ - hardware_info:
+ - hwmodel: IB-VM-820
+ hwtype: IB-VNIOS
+ licenses:
+ - dns
+ - dhcp
+ - enterprise
+ - vnios
+ comment: "Updated by Ansible"
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Remove the member
+ infoblox.nios_modules.nios_member:
+ name: member01.localdomain
+ state: absent
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+'''
+
+RETURN = ''' # '''
+
+from ansible.module_utils.basic import AnsibleModule
+from ansible.module_utils.six import iteritems
+from ..module_utils.api import WapiModule
+from ..module_utils.api import NIOS_MEMBER
+from ..module_utils.api import normalize_ib_spec
+
+
+def main():
+ ''' Main entry point for module execution
+ '''
+ ipv4_spec = dict(
+ address=dict(),
+ subnet_mask=dict(),
+ gateway=dict(),
+ )
+
+ ipv6_spec = dict(
+ virtual_ip=dict(),
+ cidr_prefix=dict(type='int'),
+ gateway=dict(),
+ )
+
+ port_spec = dict(
+ auto_port_setting_enabled=dict(type='bool'),
+ duplex=dict(),
+ speed=dict(),
+ )
+
+ lan2_port_spec = dict(
+ enabled=dict(type='bool'),
+ network_setting=dict(type='list', elements='dict', options=ipv4_spec),
+ v6_network_setting=dict(type='list', elements='dict', options=ipv6_spec),
+ )
+
+ ha_port_spec = dict(
+ ha_ip_address=dict(),
+ ha_port_setting=dict(type='list', elements='dict', options=port_spec),
+ lan_port_setting=dict(type='list', elements='dict', options=port_spec),
+ mgmt_lan=dict(),
+ mgmt_ipv6addr=dict(),
+ )
+
+ node_spec = dict(
+ lan2_physical_setting=dict(type='list', elements='dict', options=port_spec),
+ lan_ha_port_setting=dict(type='list', elements='dict', options=ha_port_spec),
+ mgmt_network_setting=dict(type='list', elements='dict', options=ipv4_spec),
+ v6_mgmt_network_setting=dict(type='list', elements='dict', options=ipv6_spec),
+ )
+
+ mgmt_port_spec = dict(
+ enabled=dict(type='bool'),
+ security_access_enabled=dict(type='bool'),
+ vpn_enabled=dict(type='bool'),
+ )
+
+ syslog_spec = dict(
+ address=dict(),
+ category_list=dict(type='list', elements='str'),
+ connection_type=dict(default='UDP'),
+ local_interface=dict(default='ANY'),
+ message_node_id=dict(default='LAN'),
+ message_source=dict(default='ANY'),
+ only_category_list=dict(type='bool'),
+ port=dict(type='int', default=514),
+ severity=dict(default='DEBUG'),
+ )
+
+ hw_spec = dict(
+ hwmodel=dict(),
+ hwtype=dict(),
+ )
+
+ pre_prov_spec = dict(
+ hardware_info=dict(type='list', elements='dict', options=hw_spec),
+ licenses=dict(type='list', elements='str'),
+ )
+
+ ib_spec = dict(
+ host_name=dict(required=True, aliases=['name'], ib_req=True),
+ vip_setting=dict(type='list', elements='dict', options=ipv4_spec),
+ ipv6_setting=dict(type='list', elements='dict', options=ipv6_spec),
+ config_addr_type=dict(default='IPV4'),
+ comment=dict(),
+ enable_ha=dict(type='bool', default=False),
+ router_id=dict(type='int'),
+ lan2_enabled=dict(type='bool', default=False),
+ lan2_port_setting=dict(type='list', elements='dict', options=lan2_port_spec),
+ platform=dict(default='INFOBLOX'),
+ node_info=dict(type='list', elements='dict', options=node_spec),
+ mgmt_port_setting=dict(type='list', elements='dict', options=mgmt_port_spec),
+ upgrade_group=dict(default='Default'),
+ use_syslog_proxy_setting=dict(type='bool'),
+ external_syslog_server_enable=dict(type='bool'),
+ syslog_servers=dict(type='list', elements='dict', options=syslog_spec),
+ pre_provisioning=dict(type='list', elements='dict', options=pre_prov_spec),
+ extattrs=dict(type='dict'),
+ create_token=dict(type='bool', default=False),
+ )
+
+ argument_spec = dict(
+ provider=dict(required=True),
+ state=dict(default='present', choices=['present', 'absent'])
+ )
+
+ argument_spec.update(normalize_ib_spec(ib_spec))
+ argument_spec.update(WapiModule.provider_spec)
+
+ module = AnsibleModule(argument_spec=argument_spec,
+ supports_check_mode=True)
+
+ wapi = WapiModule(module)
+ result = wapi.run(NIOS_MEMBER, ib_spec)
+ module.exit_json(**result)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/ansible_collections/infoblox/nios_modules/plugins/modules/nios_mx_record.py b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_mx_record.py
new file mode 100644
index 00000000..1ff3bc8a
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_mx_record.py
@@ -0,0 +1,163 @@
+#!/usr/bin/python
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+module: nios_mx_record
+author: "Blair Rampling (@brampling)"
+short_description: Configure Infoblox NIOS MX records
+version_added: "1.0.0"
+description:
+ - Adds and/or removes instances of MX record objects from
+ Infoblox NIOS servers. This module manages NIOS C(record:mx) objects
+ using the Infoblox WAPI interface over REST.
+requirements:
+ - infoblox-client
+extends_documentation_fragment: infoblox.nios_modules.nios
+notes:
+ - This module supports C(check_mode).
+options:
+ name:
+ description:
+ - Specifies the fully qualified hostname to add or remove from
+ the system.
+ type: str
+ required: true
+ view:
+ description:
+ - Sets the DNS view to associate this a record with. The DNS
+ view must already be configured on the system.
+ type: str
+ default: default
+ aliases:
+ - dns_view
+ mail_exchanger:
+ description:
+ - Configures the mail exchanger FQDN for this MX record.
+ type: str
+ required: true
+ aliases:
+ - mx
+ preference:
+ description:
+ - Configures the preference (0-65535) for this MX record.
+ type: int
+ required: true
+ ttl:
+ description:
+ - Configures the TTL to be associated with this host record.
+ type: int
+ extattrs:
+ description:
+ - Allows for the configuration of Extensible Attributes on the
+ instance of the object. This argument accepts a set of key / value
+ pairs for configuration.
+ type: dict
+ comment:
+ description:
+ - Configures a text string comment to be associated with the instance
+ of this object. The provided text string will be configured on the
+ object instance.
+ type: str
+ state:
+ description:
+ - Configures the intended state of the instance of the object on
+ the NIOS server. When this value is set to C(present), the object
+ is configured on the device and when this value is set to C(absent)
+ the value is removed (if necessary) from the device.
+ type: str
+ default: present
+ choices:
+ - present
+ - absent
+'''
+
+EXAMPLES = '''
+- name: Configure an MX record
+ infoblox.nios_modules.nios_mx_record:
+ name: ansible.com
+ mx: mailhost.ansible.com
+ preference: 0
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Add a comment to an existing MX record
+ infoblox.nios_modules.nios_mx_record:
+ name: ansible.com
+ mx: mailhost.ansible.com
+ preference: 0
+ comment: this is a test comment
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Remove an MX record from the system
+ infoblox.nios_modules.nios_mx_record:
+ name: ansible.com
+ mx: mailhost.ansible.com
+ preference: 0
+ state: absent
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+'''
+
+RETURN = ''' # '''
+
+from ansible.module_utils.basic import AnsibleModule
+from ansible.module_utils.six import iteritems
+from ..module_utils.api import WapiModule
+from ..module_utils.api import NIOS_MX_RECORD
+from ..module_utils.api import normalize_ib_spec
+
+
+def main():
+ ''' Main entry point for module execution
+ '''
+
+ ib_spec = dict(
+ name=dict(required=True, ib_req=True),
+ view=dict(default='default', aliases=['dns_view'], ib_req=True),
+
+ mail_exchanger=dict(required=True, aliases=['mx'], ib_req=True),
+ preference=dict(required=True, type='int', ib_req=True),
+
+ ttl=dict(type='int'),
+
+ extattrs=dict(type='dict'),
+ comment=dict(),
+ )
+
+ argument_spec = dict(
+ provider=dict(required=True),
+ state=dict(default='present', choices=['present', 'absent'])
+ )
+
+ argument_spec.update(normalize_ib_spec(ib_spec))
+ argument_spec.update(WapiModule.provider_spec)
+
+ module = AnsibleModule(argument_spec=argument_spec,
+ supports_check_mode=True)
+
+ wapi = WapiModule(module)
+ result = wapi.run(NIOS_MX_RECORD, ib_spec)
+
+ module.exit_json(**result)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/ansible_collections/infoblox/nios_modules/plugins/modules/nios_naptr_record.py b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_naptr_record.py
new file mode 100644
index 00000000..aa59921b
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_naptr_record.py
@@ -0,0 +1,195 @@
+#!/usr/bin/python
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+module: nios_naptr_record
+author: "Blair Rampling (@brampling)"
+short_description: Configure Infoblox NIOS NAPTR records
+version_added: "1.0.0"
+description:
+ - Adds and/or removes instances of NAPTR record objects from
+ Infoblox NIOS servers. This module manages NIOS C(record:naptr) objects
+ using the Infoblox WAPI interface over REST.
+requirements:
+ - infoblox_client
+extends_documentation_fragment: infoblox.nios_modules.nios
+notes:
+ - This module supports C(check_mode).
+options:
+ name:
+ description:
+ - Specifies the fully qualified hostname to add or remove from
+ the system.
+ type: str
+ required: true
+ view:
+ description:
+ - Sets the DNS view to associate this a record with. The DNS
+ view must already be configured on the system.
+ type: str
+ default: default
+ aliases:
+ - dns_view
+ order:
+ description:
+ - Configures the order (0-65535) for this NAPTR record. This parameter
+ specifies the order in which the NAPTR rules are applied when
+ multiple rules are present.
+ type: int
+ preference:
+ description:
+ - Configures the preference (0-65535) for this NAPTR record. The
+ preference field determines the order NAPTR records are processed
+ when multiple records with the same order parameter are present.
+ type: int
+ replacement:
+ description:
+ - Configures the replacement field for this NAPTR record.
+ For nonterminal NAPTR records, this field specifies the
+ next domain name to look up.
+ type: str
+ services:
+ description:
+ - Configures the services field (128 characters maximum) for this
+ NAPTR record. The services field contains protocol and service
+ identifiers, such as "http+E2U" or "SIPS+D2T".
+ type: str
+ flags:
+ description:
+ - Configures the flags field for this NAPTR record. These control the
+ interpretation of the fields for an NAPTR record object. Supported
+ values for the flags field are "U", "S", "P" and "A".
+ type: str
+ regexp:
+ description:
+ - Configures the regexp field for this NAPTR record. This is the
+ regular expression-based rewriting rule of the NAPTR record. This
+ should be a POSIX compliant regular expression, including the
+ substitution rule and flags. Refer to RFC 2915 for the field syntax
+ details.
+ type: str
+ ttl:
+ description:
+ - Configures the TTL to be associated with this NAPTR record.
+ type: int
+ extattrs:
+ description:
+ - Allows for the configuration of Extensible Attributes on the
+ instance of the object. This argument accepts a set of key / value
+ pairs for configuration.
+ type: dict
+ comment:
+ description:
+ - Configures a text string comment to be associated with the instance
+ of this object. The provided text string will be configured on the
+ object instance.
+ type: str
+ state:
+ description:
+ - Configures the intended state of the instance of the object on
+ the NIOS server. When this value is set to C(present), the object
+ is configured on the device and when this value is set to C(absent)
+ the value is removed (if necessary) from the device.
+ type: str
+ default: present
+ choices:
+ - present
+ - absent
+'''
+
+EXAMPLES = '''
+- name: Configure an NAPTR record
+ infoblox.nios_modules.nios_naptr_record:
+ name: '*.subscriber-100.ansiblezone.com'
+ order: 1000
+ preference: 10
+ replacement: replacement1.network.ansiblezone.com
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Add a comment to an existing NAPTR record
+ infoblox.nios_modules.nios_naptr_record:
+ name: '*.subscriber-100.ansiblezone.com'
+ order: 1000
+ preference: 10
+ replacement: replacement1.network.ansiblezone.com
+ comment: this is a test comment
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Remove an NAPTR record from the system
+ infoblox.nios_modules.nios_naptr_record:
+ name: '*.subscriber-100.ansiblezone.com'
+ order: 1000
+ preference: 10
+ replacement: replacement1.network.ansiblezone.com
+ state: absent
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+'''
+
+RETURN = ''' # '''
+
+from ansible.module_utils.basic import AnsibleModule
+from ansible.module_utils.six import iteritems
+from ..module_utils.api import WapiModule
+from ..module_utils.api import normalize_ib_spec
+
+
+def main():
+ ''' Main entry point for module execution
+ '''
+
+ ib_spec = dict(
+ name=dict(required=True, ib_req=True),
+ view=dict(default='default', aliases=['dns_view'], ib_req=True),
+
+ order=dict(type='int', ib_req=True),
+ preference=dict(type='int', ib_req=True),
+ replacement=dict(ib_req=True),
+ services=dict(),
+ flags=dict(),
+ regexp=dict(),
+
+ ttl=dict(type='int'),
+
+ extattrs=dict(type='dict'),
+ comment=dict(),
+ )
+
+ argument_spec = dict(
+ provider=dict(required=True),
+ state=dict(default='present', choices=['present', 'absent'])
+ )
+
+ argument_spec.update(normalize_ib_spec(ib_spec))
+ argument_spec.update(WapiModule.provider_spec)
+
+ module = AnsibleModule(argument_spec=argument_spec,
+ supports_check_mode=True)
+
+ wapi = WapiModule(module)
+ result = wapi.run('record:naptr', ib_spec)
+
+ module.exit_json(**result)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/ansible_collections/infoblox/nios_modules/plugins/modules/nios_network.py b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_network.py
new file mode 100644
index 00000000..e53782dd
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_network.py
@@ -0,0 +1,318 @@
+#!/usr/bin/python
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+module: nios_network
+author: "Peter Sprygada (@privateip)"
+short_description: Configure Infoblox NIOS network object
+version_added: "1.0.0"
+description:
+ - Adds and/or removes instances of network objects from
+ Infoblox NIOS servers. This module manages NIOS C(network) objects
+ using the Infoblox WAPI interface over REST.
+ - Supports both IPV4 and IPV6 internet protocols.
+requirements:
+ - infoblox-client
+extends_documentation_fragment: infoblox.nios_modules.nios
+notes:
+ - This module supports C(check_mode).
+options:
+ network:
+ description:
+ - Specifies the network to add or remove from the system. The value
+ should use CIDR notation.
+ type: str
+ required: true
+ aliases:
+ - name
+ - cidr
+ network_view:
+ description:
+ - Configures the name of the network view to associate with this
+ configured instance.
+ type: str
+ default: default
+ options:
+ description:
+ - Configures the set of DHCP options to be included as part of
+ the configured network instance. This argument accepts a list
+ of values (see suboptions). When configuring suboptions at
+ least one of C(name) or C(num) must be specified.
+ type: list
+ elements: dict
+ suboptions:
+ name:
+ description:
+ - The name of the DHCP option to configure. The standard options are
+ C(router), C(router-templates), C(domain-name-servers), C(domain-name),
+ C(broadcast-address), C(broadcast-address-offset), C(dhcp-lease-time),
+ and C(dhcp6.name-servers).
+ type: str
+ num:
+ description:
+ - The number of the DHCP option to configure
+ type: int
+ value:
+ description:
+ - The value of the DHCP option specified by C(name)
+ type: str
+ required: true
+ use_option:
+ description:
+ - Only applies to a subset of options (see NIOS API documentation)
+ type: bool
+ default: 'yes'
+ vendor_class:
+ description:
+ - The name of the space this DHCP option is associated to
+ type: str
+ default: DHCP
+ template:
+ description:
+ - If set on creation, the network is created according to the values
+ specified in the selected template.
+ type: str
+ extattrs:
+ description:
+ - Allows for the configuration of Extensible Attributes on the
+ instance of the object. This argument accepts a set of key / value
+ pairs for configuration.
+ type: dict
+ comment:
+ description:
+ - Configures a text string comment to be associated with the instance
+ of this object. The provided text string will be configured on the
+ object instance.
+ type: str
+ container:
+ description:
+ - If set to true it'll create the network container to be added or removed
+ from the system.
+ type: bool
+ state:
+ description:
+ - Configures the intended state of the instance of the object on
+ the NIOS server. When this value is set to C(present), the object
+ is configured on the device and when this value is set to C(absent)
+ the value is removed (if necessary) from the device.
+ type: str
+ default: present
+ choices:
+ - present
+ - absent
+'''
+
+EXAMPLES = '''
+- name: Configure a network ipv4
+ infoblox.nios_modules.nios_network:
+ network: 192.168.10.0/24
+ comment: this is a test comment
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Configure a network ipv6
+ infoblox.nios_modules.nios_network:
+ network: fe80::/64
+ comment: this is a test comment
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Set dhcp options for a network ipv4
+ infoblox.nios_modules.nios_network:
+ network: 192.168.10.0/24
+ comment: this is a test comment
+ options:
+ - name: domain-name
+ value: ansible.com
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Remove a network ipv4
+ infoblox.nios_modules.nios_network:
+ network: 192.168.10.0/24
+ state: absent
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Configure an ipv4 network container
+ infoblox.nios_modules.nios_network:
+ network: 192.168.10.0/24
+ container: true
+ comment: test network container
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Configure an ipv6 network container
+ infoblox.nios_modules.nios_network:
+ network: fe80::/64
+ container: true
+ comment: test network container
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Remove an ipv4 network container
+ infoblox.nios_modules.nios_network:
+ networkr: 192.168.10.0/24
+ container: true
+ comment: test network container
+ state: absent
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+'''
+
+RETURN = ''' # '''
+
+from ansible.module_utils.basic import AnsibleModule
+from ansible.module_utils.six import iteritems
+from ..module_utils.api import WapiModule
+from ..module_utils.api import NIOS_IPV4_NETWORK, NIOS_IPV6_NETWORK
+from ..module_utils.api import NIOS_IPV4_NETWORK_CONTAINER, NIOS_IPV6_NETWORK_CONTAINER
+from ..module_utils.api import normalize_ib_spec
+from ..module_utils.network import validate_ip_address, validate_ip_v6_address
+
+
+def options(module):
+ ''' Transforms the module argument into a valid WAPI struct
+ This function will transform the options argument into a structure that
+ is a valid WAPI structure in the format of:
+ {
+ name: <value>,
+ num: <value>,
+ value: <value>,
+ use_option: <value>,
+ vendor_class: <value>
+ }
+ It will remove any options that are set to None since WAPI will error on
+ that condition. It will also verify that either `name` or `num` is
+ set in the structure but does not validate the values are equal.
+ The remainder of the value validation is performed by WAPI
+ '''
+ options = list()
+ for item in module.params['options']:
+ opt = dict([(k, v) for k, v in iteritems(item) if v is not None])
+ if 'name' not in opt and 'num' not in opt:
+ module.fail_json(msg='one of `name` or `num` is required for option value')
+ options.append(opt)
+ return options
+
+
+def check_ip_addr_type(obj_filter, ib_spec):
+ '''This function will check if the argument ip is type v4/v6 and return appropriate infoblox
+ network/networkcontainer type
+ '''
+
+ ip = obj_filter['network']
+ if 'container' in obj_filter and obj_filter['container']:
+ check_ip = ip.split('/')
+ del ib_spec['container'] # removing the container key from post arguments
+ del ib_spec['options'] # removing option argument as for network container it's not supported
+ if validate_ip_address(check_ip[0]):
+ return NIOS_IPV4_NETWORK_CONTAINER, ib_spec
+ elif validate_ip_v6_address(check_ip[0]):
+ return NIOS_IPV6_NETWORK_CONTAINER, ib_spec
+ else:
+ check_ip = ip.split('/')
+ del ib_spec['container'] # removing the container key from post arguments
+ if validate_ip_address(check_ip[0]):
+ return NIOS_IPV4_NETWORK, ib_spec
+ elif validate_ip_v6_address(check_ip[0]):
+ return NIOS_IPV6_NETWORK, ib_spec
+
+
+def check_vendor_specific_dhcp_option(module, ib_spec):
+ '''This function will check if the argument dhcp option belongs to vendor-specific and if yes then will remove
+ use_options flag which is not supported with vendor-specific dhcp options.
+ '''
+ for key, value in iteritems(ib_spec):
+ if isinstance(module.params[key], list):
+ for temp_dict in module.params[key]:
+ if 'num' in temp_dict:
+ if temp_dict['num'] in (43, 124, 125, 67, 60):
+ del temp_dict['use_option']
+ return ib_spec
+
+
+def main():
+ ''' Main entry point for module execution
+ '''
+ option_spec = dict(
+ # one of name or num is required; enforced by the function options()
+ name=dict(),
+ num=dict(type='int'),
+
+ value=dict(required=True),
+
+ use_option=dict(type='bool', default=True),
+ vendor_class=dict(default='DHCP')
+ )
+
+ ib_spec = dict(
+ network=dict(required=True, aliases=['name', 'cidr'], ib_req=True),
+ network_view=dict(default='default', ib_req=True),
+
+ options=dict(type='list', elements='dict', options=option_spec, transform=options),
+
+ template=dict(type='str'),
+ extattrs=dict(type='dict'),
+ comment=dict(),
+ container=dict(type='bool', ib_req=True)
+ )
+
+ argument_spec = dict(
+ provider=dict(required=True),
+ state=dict(default='present', choices=['present', 'absent'])
+ )
+
+ argument_spec.update(normalize_ib_spec(ib_spec))
+ argument_spec.update(WapiModule.provider_spec)
+
+ module = AnsibleModule(argument_spec=argument_spec,
+ supports_check_mode=True)
+
+ # to get the argument ipaddr
+ obj_filter = dict([(k, module.params[k]) for k, v in iteritems(ib_spec) if v.get('ib_req')])
+ network_type, ib_spec = check_ip_addr_type(obj_filter, ib_spec)
+
+ wapi = WapiModule(module)
+ # to check for vendor specific dhcp option
+ ib_spec = check_vendor_specific_dhcp_option(module, ib_spec)
+
+ result = wapi.run(network_type, ib_spec)
+
+ module.exit_json(**result)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/ansible_collections/infoblox/nios_modules/plugins/modules/nios_network_view.py b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_network_view.py
new file mode 100644
index 00000000..3ebcb1f6
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_network_view.py
@@ -0,0 +1,138 @@
+#!/usr/bin/python
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+module: nios_network_view
+author: "Peter Sprygada (@privateip)"
+short_description: Configure Infoblox NIOS network views
+version_added: "1.0.0"
+description:
+ - Adds and/or removes instances of network view objects from
+ Infoblox NIOS servers. This module manages NIOS C(networkview) objects
+ using the Infoblox WAPI interface over REST.
+ - Updates instances of network view object from Infoblox NIOS servers.
+requirements:
+ - infoblox-client
+extends_documentation_fragment: infoblox.nios_modules.nios
+notes:
+ - This module supports C(check_mode).
+options:
+ name:
+ description:
+ - Specifies the fully qualified hostname to add or remove from
+ the system. User can also update the hostname as it is possible
+ to pass a dict containing I(new_name), I(old_name). See examples.
+ type: str
+ required: true
+ aliases:
+ - network_view
+ extattrs:
+ description:
+ - Allows for the configuration of Extensible Attributes on the
+ instance of the object. This argument accepts a set of key / value
+ pairs for configuration.
+ type: dict
+ comment:
+ description:
+ - Configures a text string comment to be associated with the instance
+ of this object. The provided text string will be configured on the
+ object instance.
+ type: str
+ state:
+ description:
+ - Configures the intended state of the instance of the object on
+ the NIOS server. When this value is set to C(present), the object
+ is configured on the device and when this value is set to C(absent)
+ the value is removed (if necessary) from the device.
+ type: str
+ default: present
+ choices:
+ - present
+ - absent
+'''
+
+EXAMPLES = '''
+- name: Configure a new network view
+ infoblox.nios_modules.nios_network_view:
+ name: ansible
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Update the comment for network view
+ infoblox.nios_modules.nios_network_view:
+ name: ansible
+ comment: this is an example comment
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Remove the network view
+ infoblox.nios_modules.nios_network_view:
+ name: ansible
+ state: absent
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Update an existing network view
+ infoblox.nios_modules.nios_network_view:
+ name: {new_name: ansible-new, old_name: ansible}
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+'''
+
+RETURN = ''' # '''
+
+from ansible.module_utils.basic import AnsibleModule
+from ..module_utils.api import WapiModule
+from ..module_utils.api import NIOS_NETWORK_VIEW
+from ..module_utils.api import normalize_ib_spec
+
+
+def main():
+ ''' Main entry point for module execution
+ '''
+ ib_spec = dict(
+ name=dict(required=True, aliases=['network_view'], ib_req=True),
+ extattrs=dict(type='dict'),
+ comment=dict(),
+ )
+
+ argument_spec = dict(
+ provider=dict(required=True),
+ state=dict(default='present', choices=['present', 'absent'])
+ )
+
+ argument_spec.update(normalize_ib_spec(ib_spec))
+ argument_spec.update(WapiModule.provider_spec)
+
+ module = AnsibleModule(argument_spec=argument_spec,
+ supports_check_mode=True)
+
+ wapi = WapiModule(module)
+ result = wapi.run(NIOS_NETWORK_VIEW, ib_spec)
+
+ module.exit_json(**result)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/ansible_collections/infoblox/nios_modules/plugins/modules/nios_nsgroup.py b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_nsgroup.py
new file mode 100644
index 00000000..948fe238
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_nsgroup.py
@@ -0,0 +1,439 @@
+#!/usr/bin/python
+# Copyright © 2020 Infoblox Inc
+# -*- coding: utf-8 -*-
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+module: nios_nsgroup
+short_description: Configure InfoBlox DNS Nameserver Groups
+version_added: "1.0.0"
+extends_documentation_fragment: infoblox.nios_modules.nios
+author:
+ - Erich Birngruber (@ebirn)
+ - Sumit Jaiswal (@sjaiswal)
+description:
+ - Adds and/or removes nameserver groups form Infoblox NIOS servers.
+ This module manages NIOS C(nsgroup) objects using the Infoblox. WAPI interface over REST.
+requirements:
+ - infoblox_client
+notes:
+ - This module supports C(check_mode).
+options:
+ name:
+ description:
+ - Specifies the name of the NIOS nameserver group to be managed.
+ required: true
+ type: str
+ grid_primary:
+ description:
+ - This host is to be used as primary server in this nameserver group. It must be a grid member.
+ This option is required when setting I(use_external_primaries) to C(false).
+ type: list
+ elements: dict
+ suboptions:
+ name:
+ description:
+ - Provide the name of the grid member to identify the host.
+ required: true
+ type: str
+ enable_preferred_primaries:
+ description:
+ - This flag represents whether the preferred_primaries field values of this member are used (see Infoblox WAPI docs).
+ default: false
+ type: bool
+ grid_replicate:
+ description:
+ - Use DNS zone transfers if set to C(True) or ID Grid Replication if set to C(False).
+ type: bool
+ default: false
+ lead:
+ description:
+ - This flag controls if the grid lead secondary nameserver performs zone transfers to non lead secondaries.
+ type: bool
+ default: false
+ stealth:
+ description:
+ - Configure the external nameserver as stealth server (without NS record) in the zones.
+ type: bool
+ default: false
+ preferred_primaries:
+ description:
+ - Provide a list of elements like in I(external_primaries) to set the precedence of preferred primary nameservers.
+ type: list
+ elements: dict
+ suboptions:
+ address:
+ description:
+ - Configures the IP address of the external nameserver
+ required: true
+ type: str
+ name:
+ description:
+ - Set a label for the external nameserver
+ required: true
+ type: str
+ stealth:
+ description:
+ - Configure the external nameserver as stealth server (without NS record) in the zones.
+ type: bool
+ default: false
+ tsig_key_name:
+ description:
+ - Sets a label for the I(tsig_key) value
+ required: true
+ type: str
+ tsig_key_alg:
+ description:
+ - Provides the algorithm used for the I(tsig_key) in use.
+ choices: ['HMAC-MD5', 'HMAC-SHA256']
+ default: 'HMAC-MD5'
+ type: str
+ tsig_key:
+ description:
+ - Set a DNS TSIG key for the nameserver to secure zone transfers (AFXRs).
+ type: str
+ grid_secondaries:
+ description:
+ - Configures the list of grid member hosts that act as secondary nameservers.
+ This option is required when setting I(use_external_primaries) to C(true).
+ type: list
+ elements: dict
+ suboptions:
+ name:
+ description:
+ - Provide the name of the grid member to identify the host.
+ required: true
+ type: str
+ enable_preferred_primaries:
+ description:
+ - This flag represents whether the preferred_primaries field values of this member are used (see Infoblox WAPI docs).
+ default: false
+ type: bool
+ grid_replicate:
+ description:
+ - Use DNS zone transfers if set to C(True) or ID Grid Replication if set to C(False)
+ type: bool
+ default: false
+ lead:
+ description:
+ - This flag controls if the grid lead secondary nameserver performs zone transfers to non lead secondaries.
+ type: bool
+ default: false
+ stealth:
+ description:
+ - Configure the external nameserver as stealth server (without NS record) in the zones.
+ type: bool
+ default: false
+ preferred_primaries:
+ description:
+ - Provide a list of elements like in I(external_primaries) to set the precedence of preferred primary nameservers.
+ type: list
+ elements: dict
+ suboptions:
+ address:
+ description:
+ - Configures the IP address of the external nameserver
+ required: true
+ type: str
+ name:
+ description:
+ - Set a label for the external nameserver
+ required: true
+ type: str
+ stealth:
+ description:
+ - Configure the external nameserver as stealth server (without NS record) in the zones.
+ type: bool
+ default: false
+ tsig_key_name:
+ description:
+ - Sets a label for the I(tsig_key) value
+ required: true
+ type: str
+ tsig_key_alg:
+ description:
+ - Provides the algorithm used for the I(tsig_key) in use.
+ choices: ['HMAC-MD5', 'HMAC-SHA256']
+ default: 'HMAC-MD5'
+ type: str
+ tsig_key:
+ description:
+ - Set a DNS TSIG key for the nameserver to secure zone transfers (AFXRs).
+ type: str
+ is_grid_default:
+ description:
+ - If set to C(True) this nsgroup will become the default nameserver group for new zones.
+ type: bool
+ default: false
+ use_external_primary:
+ description:
+ - This flag controls whether the group is using an external primary nameserver.
+ Note that modification of this field requires passing values for I(grid_secondaries) and I(external_primaries).
+ type: bool
+ default: false
+ external_primaries:
+ description:
+ - Configures a list of external nameservers (non-members of the grid).
+ This option is required when setting I(use_external_primaries) to C(true).
+ type: list
+ elements: dict
+ suboptions:
+ address:
+ description:
+ - Configures the IP address of the external nameserver
+ required: true
+ type: str
+ name:
+ description:
+ - Set a label for the external nameserver
+ required: true
+ type: str
+ stealth:
+ description:
+ - Configure the external nameserver as stealth server (without NS record) in the zones.
+ type: bool
+ default: false
+ tsig_key_name:
+ description:
+ - Sets a label for the I(tsig_key) value
+ required: true
+ type: str
+ tsig_key_alg:
+ description:
+ - Provides the algorithm used for the I(tsig_key) in use.
+ choices: ['HMAC-MD5', 'HMAC-SHA256']
+ default: 'HMAC-MD5'
+ type: str
+ tsig_key:
+ description:
+ - Set a DNS TSIG key for the nameserver to secure zone transfers (AFXRs).
+ type: str
+ external_secondaries:
+ description:
+ - Allows to provide a list of external secondary nameservers, that are not members of the grid.
+ type: list
+ elements: dict
+ suboptions:
+ address:
+ description:
+ - Configures the IP address of the external nameserver
+ required: true
+ type: str
+ name:
+ description:
+ - Set a label for the external nameserver
+ required: true
+ type: str
+ stealth:
+ description:
+ - Configure the external nameserver as stealth server (without NS record) in the zones.
+ type: bool
+ default: false
+ tsig_key_name:
+ description:
+ - Sets a label for the I(tsig_key) value
+ required: true
+ type: str
+ tsig_key_alg:
+ description:
+ - Provides the algorithm used for the I(tsig_key) in use.
+ choices: ['HMAC-MD5', 'HMAC-SHA256']
+ default: 'HMAC-MD5'
+ type: str
+ tsig_key:
+ description:
+ - Set a DNS TSIG key for the nameserver to secure zone transfers (AFXRs).
+ type: str
+ extattrs:
+ description:
+ - Allows for the configuration of Extensible Attributes on the
+ instance of the object. This argument accepts a set of key / value
+ pairs for configuration.
+ type: str
+ comment:
+ description:
+ - Configures a text string comment to be associated with the instance
+ of this object. The provided text string will be configured on the
+ object instance.
+ type: str
+ state:
+ description:
+ - Configures the intended state of the instance of the object on
+ the NIOS server. When this value is set to C(present), the object
+ is configured on the device and when this value is set to C(absent)
+ the value is removed (if necessary) from the device.
+ choices: [present, absent]
+ default: present
+ type: str
+'''
+
+EXAMPLES = '''
+- name: Create simple infoblox nameserver group
+ infoblox.nios_modules.nios_nsgroup:
+ name: my-simple-group
+ comment: "this is a simple nameserver group"
+ grid_primary:
+ - name: infoblox-test.example.com
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Create infoblox nameserver group with external primaries
+ infoblox.nios_modules.nios_nsgroup:
+ name: my-example-group
+ use_external_primary: true
+ comment: "this is my example nameserver group"
+ external_primaries: "{{ ext_nameservers }}"
+ grid_secondaries:
+ - name: infoblox-test.example.com
+ lead: True
+ preferred_primaries: "{{ ext_nameservers }}"
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Delete infoblox nameserver group
+ infoblox.nios_modules.nios_nsgroup:
+ name: my-simple-group
+ comment: "this is a simple nameserver group"
+ grid_primary:
+ - name: infoblox-test.example.com
+ state: absent
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+'''
+
+RETURN = ''' # '''
+
+from ansible.module_utils.basic import AnsibleModule
+from ..module_utils.api import WapiModule
+from ..module_utils.api import NIOS_NSGROUP
+from ..module_utils.api import normalize_ib_spec
+
+
+# from infoblox documentation
+# Fields List
+# Field Type Req R/O Base Search
+# comment String N N Y : = ~
+# extattrs Extattr N N N ext
+# external_primaries [struct] N N N N/A
+# external_secondaries [struct] N N N N/A
+# grid_primary [struct] N N N N/A
+# grid_secondaries [struct] N N N N/A
+# is_grid_default Bool N N N N/A
+# is_multimaster Bool N Y N N/A
+# name String Y N Y : = ~
+# use_external_primary Bool N N N N/A
+
+
+def main():
+ '''entrypoint for module execution.'''
+ argument_spec = dict(
+ provider=dict(required=True),
+ state=dict(default='present', choices=['present', 'absent']),
+ )
+
+ # cleanup tsig fields
+ def clean_tsig(ext):
+ if 'tsig_key' in ext and not ext['tsig_key']:
+ del ext['tsig_key']
+ if 'tsig_key' not in ext and 'tsig_key_name' in ext and not ext['tsig_key_name']:
+ del ext['tsig_key_name']
+ if 'tsig_key' not in ext and 'tsig_key_alg' in ext:
+ del ext['tsig_key_alg']
+
+ def clean_grid_member(member):
+ if member['preferred_primaries']:
+ for ext in member['preferred_primaries']:
+ clean_tsig(ext)
+ if member['enable_preferred_primaries'] is False:
+ del member['enable_preferred_primaries']
+ del member['preferred_primaries']
+ if member['lead'] is False:
+ del member['lead']
+ if member['grid_replicate'] is False:
+ del member['grid_replicate']
+
+ def ext_primaries_transform(module):
+ if module.params['external_primaries']:
+ for ext in module.params['external_primaries']:
+ clean_tsig(ext)
+ return module.params['external_primaries']
+
+ def ext_secondaries_transform(module):
+ if module.params['external_secondaries']:
+ for ext in module.params['external_secondaries']:
+ clean_tsig(ext)
+ return module.params['external_secondaries']
+
+ def grid_primary_preferred_transform(module):
+ for member in module.params['grid_primary']:
+ clean_grid_member(member)
+ return module.params['grid_primary']
+
+ def grid_secondaries_preferred_primaries_transform(module):
+ for member in module.params['grid_secondaries']:
+ clean_grid_member(member)
+ return module.params['grid_secondaries']
+
+ extserver_spec = dict(
+ address=dict(required=True),
+ name=dict(required=True),
+ stealth=dict(type='bool', default=False),
+ tsig_key=dict(no_log=True),
+ tsig_key_alg=dict(choices=['HMAC-MD5', 'HMAC-SHA256'], default='HMAC-MD5'),
+ tsig_key_name=dict(required=True)
+ )
+
+ memberserver_spec = dict(
+ name=dict(required=True),
+ enable_preferred_primaries=dict(type='bool', default=False),
+ grid_replicate=dict(type='bool', default=False),
+ lead=dict(type='bool', default=False),
+ preferred_primaries=dict(type='list', elements='dict', options=extserver_spec, default=None),
+ stealth=dict(type='bool', default=False),
+ )
+
+ ib_spec = dict(
+ name=dict(required=True, ib_req=True),
+ grid_primary=dict(type='list', elements='dict', options=memberserver_spec,
+ transform=grid_primary_preferred_transform),
+ grid_secondaries=dict(type='list', elements='dict', options=memberserver_spec,
+ transform=grid_secondaries_preferred_primaries_transform),
+ external_primaries=dict(type='list', elements='dict', options=extserver_spec, transform=ext_primaries_transform),
+ external_secondaries=dict(type='list', elements='dict', options=extserver_spec,
+ transform=ext_secondaries_transform),
+ is_grid_default=dict(type='bool', default=False),
+ use_external_primary=dict(type='bool', default=False),
+ extattrs=dict(),
+ comment=dict(),
+ )
+
+ argument_spec.update(normalize_ib_spec(ib_spec))
+ argument_spec.update(WapiModule.provider_spec)
+
+ module = AnsibleModule(argument_spec=argument_spec, supports_check_mode=True)
+
+ wapi = WapiModule(module)
+ result = wapi.run(NIOS_NSGROUP, ib_spec)
+
+ module.exit_json(**result)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/ansible_collections/infoblox/nios_modules/plugins/modules/nios_ptr_record.py b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_ptr_record.py
new file mode 100644
index 00000000..d649badc
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_ptr_record.py
@@ -0,0 +1,164 @@
+#!/usr/bin/python
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+module: nios_ptr_record
+author: "Trebuchet Clement (@clementtrebuchet)"
+short_description: Configure Infoblox NIOS PTR records
+version_added: "1.0.0"
+description:
+ - Adds and/or removes instances of PTR record objects from
+ Infoblox NIOS servers. This module manages NIOS C(record:ptr) objects
+ using the Infoblox WAPI interface over REST.
+requirements:
+ - infoblox_client
+extends_documentation_fragment: infoblox.nios_modules.nios
+notes:
+ - This module supports C(check_mode).
+options:
+ name:
+ description:
+ - The name of the DNS PTR record in FQDN format to add or remove from
+ the system.
+ The field is required only for an PTR object in Forward Mapping Zone.
+ type: str
+ view:
+ description:
+ - Sets the DNS view to associate this a record with. The DNS
+ view must already be configured on the system.
+ type: str
+ default: default
+ aliases:
+ - dns_view
+ ipv4addr:
+ description:
+ - The IPv4 Address of the record. Mutually exclusive with the ipv6addr.
+ type: str
+ aliases:
+ - ipv4
+ ipv6addr:
+ description:
+ - The IPv6 Address of the record. Mutually exclusive with the ipv4addr.
+ aliases:
+ - ipv6
+ type: str
+ ptrdname:
+ description:
+ - The domain name of the DNS PTR record in FQDN format.
+ required: true
+ type: str
+ ttl:
+ description:
+ - Time To Live (TTL) value for the record.
+ A 32-bit unsigned integer that represents the duration, in seconds, that the record is valid (cached).
+ Zero indicates that the record should not be cached.
+ type: int
+ extattrs:
+ description:
+ - Allows for the configuration of Extensible Attributes on the
+ instance of the object. This argument accepts a set of key / value
+ pairs for configuration.
+ type: dict
+ comment:
+ description:
+ - Configures a text string comment to be associated with the instance
+ of this object. The provided text string will be configured on the
+ object instance. Maximum 256 characters.
+ type: str
+ state:
+ description:
+ - Configures the intended state of the instance of the object on
+ the NIOS server. When this value is set to C(present), the object
+ is configured on the device and when this value is set to C(absent)
+ the value is removed (if necessary) from the device.
+ default: present
+ choices:
+ - present
+ - absent
+ type: str
+'''
+
+EXAMPLES = '''
+- name: Create a PTR Record
+ infoblox.nios_modules.nios_ptr_record:
+ ipv4: 192.168.10.1
+ ptrdname: host.ansible.com
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Delete a PTR Record
+ infoblox.nios_modules.nios_ptr_record:
+ ipv4: 192.168.10.1
+ ptrdname: host.ansible.com
+ state: absent
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+'''
+
+RETURN = ''' # '''
+
+from ansible.module_utils.basic import AnsibleModule
+from ..module_utils.api import WapiModule
+from ..module_utils.api import NIOS_PTR_RECORD
+from ..module_utils.api import normalize_ib_spec
+
+
+def main():
+ # Module entry point
+ ib_spec = dict(
+ name=dict(required=False),
+ view=dict(default='default', aliases=['dns_view'], ib_req=True),
+ ipv4addr=dict(aliases=['ipv4'], ib_req=True),
+ ipv6addr=dict(aliases=['ipv6'], ib_req=True),
+ ptrdname=dict(required=True, ib_req=True),
+
+ ttl=dict(type='int'),
+
+ extattrs=dict(type='dict'),
+ comment=dict(),
+ )
+
+ argument_spec = dict(
+ provider=dict(required=True),
+ state=dict(default='present', choices=['present', 'absent'])
+ )
+
+ argument_spec.update(normalize_ib_spec(ib_spec))
+ argument_spec.update(WapiModule.provider_spec)
+
+ mutually_exclusive = [('ipv4addr', 'ipv6addr')]
+ required_one_of = [
+ ['ipv4addr', 'ipv6addr']
+ ]
+
+ module = AnsibleModule(argument_spec=argument_spec,
+ mutually_exclusive=mutually_exclusive,
+ supports_check_mode=True,
+ required_one_of=required_one_of)
+
+ if module.params['ipv4addr']:
+ del ib_spec['ipv6addr']
+ elif module.params['ipv6addr']:
+ del ib_spec['ipv4addr']
+
+ wapi = WapiModule(module)
+ result = wapi.run(NIOS_PTR_RECORD, ib_spec)
+
+ module.exit_json(**result)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/ansible_collections/infoblox/nios_modules/plugins/modules/nios_restartservices.py b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_restartservices.py
new file mode 100644
index 00000000..b8f0bc49
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_restartservices.py
@@ -0,0 +1,144 @@
+#!/usr/bin/python
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+module: nios_restartservices
+author: "Mauricio Teixeira (@badnetmask)"
+short_description: Restart grid services.
+version_added: "1.1.0"
+description:
+ - Restart grid services.
+ - When invoked without any options, will restart ALL services on the
+ default restart group IF NEEDED.
+requirements:
+ - infoblox-client
+extends_documentation_fragment: infoblox.nios_modules.nios
+notes:
+ - This module supports C(check_mode).
+options:
+ groups:
+ description:
+ - The list of the Service Restart Groups to restart.
+ required: false
+ type: list
+ elements: str
+ members:
+ description:
+ - The list of the Grid Members to restart.
+ required: false
+ type: list
+ elements: str
+ mode:
+ description:
+ - The restart method in case of grid restart.
+ required: false
+ type: str
+ choices:
+ - GROUPED
+ - SEQUENTIAL
+ - SIMULTANEOUS
+ restart_option:
+ description:
+ - Controls whether services are restarted unconditionally or when needed
+ required: false
+ type: str
+ default: RESTART_IF_NEEDED
+ choices:
+ - RESTART_IF_NEEDED
+ - FORCE_RESTART
+ services:
+ description:
+ - The list of services the restart applicable to.
+ required: false
+ type: list
+ elements: str
+ default: ALL
+ choices:
+ - ALL
+ - DNS
+ - DHCP
+ - DHCPV4
+ - DHCPV6
+'''
+
+EXAMPLES = '''
+- name: Restart all grid services if needed.
+ infoblox.nios_modules.nios_restartservices:
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Restart DNS service if needed.
+ infoblox.nios_modules.nios_restartservices:
+ services:
+ - DNS
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+'''
+
+RETURN = ''' # '''
+
+from ansible.module_utils.basic import AnsibleModule
+from ansible.module_utils.six import iteritems
+from ..module_utils.api import WapiModule
+from ..module_utils.api import normalize_ib_spec
+
+
+def main():
+ ''' Main entry point for module execution
+ '''
+
+ ib_spec = dict(
+ groups=dict(type='list', elements='str'),
+ members=dict(type='list', elements='str'),
+ mode=dict(type='str', choices=['GROUPED', 'SEQUENTIAL',
+ 'SIMULTANEOUS']),
+ restart_option=dict(type='str', default='RESTART_IF_NEEDED',
+ choices=['RESTART_IF_NEEDED', 'FORCE_RESTART']),
+ services=dict(type='list', elements='str', default=['ALL'],
+ choices=['ALL', 'DNS', 'DHCP', 'DHCPV4', 'DHCPV6'])
+ )
+
+ argument_spec = dict(
+ provider=dict(required=True)
+ )
+
+ argument_spec.update(normalize_ib_spec(ib_spec))
+ argument_spec.update(WapiModule.provider_spec)
+
+ module = AnsibleModule(argument_spec=argument_spec,
+ supports_check_mode=True)
+
+ wapi = WapiModule(module)
+
+ # restart is a grid function, so we need to properly format
+ # the arguments before sending the command
+ restart_params = module.params
+ del restart_params['provider']
+ if restart_params['groups'] is None:
+ del restart_params['groups']
+ if restart_params['members'] is None:
+ del restart_params['members']
+ if restart_params['mode'] is None:
+ del restart_params['mode']
+ grid_obj = wapi.get_object('grid')
+ if grid_obj is None:
+ module.fail_json(msg='Failed to get NIOS grid information.')
+ result = wapi.call_func('restartservices', grid_obj[0]['_ref'], restart_params)
+
+ module.exit_json(**result)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/ansible_collections/infoblox/nios_modules/plugins/modules/nios_srv_record.py b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_srv_record.py
new file mode 100644
index 00000000..9ac94577
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_srv_record.py
@@ -0,0 +1,175 @@
+#!/usr/bin/python
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+module: nios_srv_record
+author: "Blair Rampling (@brampling)"
+short_description: Configure Infoblox NIOS SRV records
+version_added: "1.0.0"
+description:
+ - Adds and/or removes instances of SRV record objects from
+ Infoblox NIOS servers. This module manages NIOS C(record:srv) objects
+ using the Infoblox WAPI interface over REST.
+requirements:
+ - infoblox-client
+extends_documentation_fragment: infoblox.nios_modules.nios
+notes:
+ - This module supports C(check_mode).
+options:
+ name:
+ description:
+ - Specifies the fully qualified hostname to add or remove from
+ the system.
+ required: true
+ type: str
+ view:
+ description:
+ - Sets the DNS view to associate this a record with. The DNS
+ view must already be configured on the system.
+ default: default
+ aliases:
+ - dns_view
+ type: str
+ port:
+ description:
+ - Configures the port (0-65535) of this SRV record.
+ type: int
+ priority:
+ description:
+ - Configures the priority (0-65535) for this SRV record.
+ type: int
+ target:
+ description:
+ - Configures the target FQDN for this SRV record.
+ type: str
+ weight:
+ description:
+ - Configures the weight (0-65535) for this SRV record.
+ type: int
+ ttl:
+ description:
+ - Configures the TTL to be associated with this host record.
+ type: int
+ extattrs:
+ description:
+ - Allows for the configuration of Extensible Attributes on the
+ instance of the object. This argument accepts a set of key / value
+ pairs for configuration.
+ type: dict
+ comment:
+ description:
+ - Configures a text string comment to be associated with the instance
+ of this object. The provided text string will be configured on the
+ object instance.
+ type: str
+ state:
+ description:
+ - Configures the intended state of the instance of the object on
+ the NIOS server. When this value is set to C(present), the object
+ is configured on the device and when this value is set to C(absent)
+ the value is removed (if necessary) from the device.
+ default: present
+ choices:
+ - present
+ - absent
+ type: str
+'''
+
+EXAMPLES = '''
+- name: Configure an SRV record
+ infoblox.nios_modules.nios_srv_record:
+ name: _sip._tcp.service.ansible.com
+ port: 5080
+ priority: 10
+ target: service1.ansible.com
+ weight: 10
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Add a comment to an existing SRV record
+ infoblox.nios_modules.nios_srv_record:
+ name: _sip._tcp.service.ansible.com
+ port: 5080
+ priority: 10
+ target: service1.ansible.com
+ weight: 10
+ comment: this is a test comment
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Remove an SRV record from the system
+ infoblox.nios_modules.nios_srv_record:
+ name: _sip._tcp.service.ansible.com
+ port: 5080
+ priority: 10
+ target: service1.ansible.com
+ weight: 10
+ state: absent
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+'''
+
+RETURN = ''' # '''
+
+from ansible.module_utils.basic import AnsibleModule
+from ansible.module_utils.six import iteritems
+from ..module_utils.api import WapiModule
+from ..module_utils.api import NIOS_SRV_RECORD
+from ..module_utils.api import normalize_ib_spec
+
+
+def main():
+ ''' Main entry point for module execution
+ '''
+
+ ib_spec = dict(
+ name=dict(required=True, ib_req=True),
+ view=dict(default='default', aliases=['dns_view'], ib_req=True),
+
+ port=dict(type='int', ib_req=True),
+ priority=dict(type='int', ib_req=True),
+ target=dict(ib_req=True),
+ weight=dict(type='int', ib_req=True),
+
+ ttl=dict(type='int'),
+
+ extattrs=dict(type='dict'),
+ comment=dict(),
+ )
+
+ argument_spec = dict(
+ provider=dict(required=True),
+ state=dict(default='present', choices=['present', 'absent'])
+ )
+
+ argument_spec.update(normalize_ib_spec(ib_spec))
+ argument_spec.update(WapiModule.provider_spec)
+
+ module = AnsibleModule(argument_spec=argument_spec,
+ supports_check_mode=True)
+
+ wapi = WapiModule(module)
+ result = wapi.run(NIOS_SRV_RECORD, ib_spec)
+
+ module.exit_json(**result)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/ansible_collections/infoblox/nios_modules/plugins/modules/nios_txt_record.py b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_txt_record.py
new file mode 100644
index 00000000..51e4504c
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_txt_record.py
@@ -0,0 +1,139 @@
+#!/usr/bin/python
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+module: nios_txt_record
+author: "Corey Wanless (@coreywan)"
+short_description: Configure Infoblox NIOS txt records
+version_added: "1.0.0"
+description:
+ - Adds and/or removes instances of txt record objects from
+ Infoblox NIOS servers. This module manages NIOS C(record:txt) objects
+ using the Infoblox WAPI interface over REST.
+requirements:
+ - infoblox_client
+extends_documentation_fragment: infoblox.nios_modules.nios
+notes:
+ - This module supports C(check_mode).
+options:
+ name:
+ description:
+ - Specifies the fully qualified hostname to add or remove from
+ the system.
+ required: true
+ type: str
+ view:
+ description:
+ - Sets the DNS view to associate this tst record with. The DNS
+ view must already be configured on the system.
+ default: default
+ aliases:
+ - dns_view
+ type: str
+ text:
+ description:
+ - Text associated with the record. It can contain up to 255 bytes
+ per substring, up to a total of 512 bytes. To enter leading,
+ trailing, or embedded spaces in the text, add quotes around the
+ text to preserve the spaces.
+ required: true
+ type: str
+ ttl:
+ description:
+ - Configures the TTL to be associated with this txt record.
+ type: int
+ extattrs:
+ description:
+ - Allows for the configuration of Extensible Attributes on the
+ instance of the object. This argument accepts a set of key / value
+ pairs for configuration.
+ type: dict
+ comment:
+ description:
+ - Configures a text string comment to be associated with the instance
+ of this object. The provided text string will be configured on the
+ object instance.
+ type: str
+ state:
+ description:
+ - Configures the intended state of the instance of the object on
+ the NIOS server. When this value is set to C(present), the object
+ is configured on the device and when this value is set to C(absent)
+ the value is removed (if necessary) from the device.
+ default: present
+ choices:
+ - present
+ - absent
+ type: str
+'''
+
+EXAMPLES = '''
+ - name: Ensure a text Record Exists
+ infoblox.nios_modules.nios_txt_record:
+ name: fqdn.txt.record.com
+ text: mytext
+ state: present
+ view: External
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+
+ - name: Ensure a text Record does not exist
+ infoblox.nios_modules.nios_txt_record:
+ name: fqdn.txt.record.com
+ text: mytext
+ state: absent
+ view: External
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+'''
+
+RETURN = ''' # '''
+
+from ansible.module_utils.basic import AnsibleModule
+from ansible.module_utils.six import iteritems
+from ..module_utils.api import WapiModule
+from ..module_utils.api import normalize_ib_spec
+
+
+def main():
+ ''' Main entry point for module execution
+ '''
+
+ ib_spec = dict(
+ name=dict(required=True, ib_req=True),
+ view=dict(default='default', aliases=['dns_view'], ib_req=True),
+ text=dict(required=True, type='str', ib_req=True),
+ ttl=dict(type='int'),
+ extattrs=dict(type='dict'),
+ comment=dict(),
+ )
+
+ argument_spec = dict(
+ provider=dict(required=True),
+ state=dict(default='present', choices=['present', 'absent'])
+ )
+
+ argument_spec.update(normalize_ib_spec(ib_spec))
+ argument_spec.update(WapiModule.provider_spec)
+
+ module = AnsibleModule(argument_spec=argument_spec,
+ supports_check_mode=True)
+
+ wapi = WapiModule(module)
+ result = wapi.run('record:txt', ib_spec)
+
+ module.exit_json(**result)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/ansible_collections/infoblox/nios_modules/plugins/modules/nios_zone.py b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_zone.py
new file mode 100644
index 00000000..982c5e21
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/plugins/modules/nios_zone.py
@@ -0,0 +1,244 @@
+#!/usr/bin/python
+# Copyright (c) 2018-2019 Red Hat, Inc.
+# Copyright (c) 2020 Infoblox, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+DOCUMENTATION = '''
+---
+module: nios_zone
+author: "Peter Sprygada (@privateip)"
+short_description: Configure Infoblox NIOS DNS zones
+version_added: "1.0.0"
+description:
+ - Adds and/or removes instances of DNS zone objects from
+ Infoblox NIOS servers. This module manages NIOS C(zone_auth) objects
+ using the Infoblox WAPI interface over REST.
+requirements:
+ - infoblox-client
+extends_documentation_fragment: infoblox.nios_modules.nios
+notes:
+ - This module supports C(check_mode).
+options:
+ fqdn:
+ description:
+ - Specifies the qualified domain name to either add or remove from
+ the NIOS instance based on the configured C(state) value.
+ required: true
+ aliases:
+ - name
+ type: str
+ view:
+ description:
+ - Configures the DNS view name for the configured resource. The
+ specified DNS zone must already exist on the running NIOS instance
+ prior to configuring zones.
+ default: default
+ aliases:
+ - dns_view
+ type: str
+ grid_primary:
+ description:
+ - Configures the grid primary servers for this zone.
+ suboptions:
+ name:
+ description:
+ - The name of the grid primary server
+ required: true
+ type: str
+ type: list
+ elements: dict
+ grid_secondaries:
+ description:
+ - Configures the grid secondary servers for this zone.
+ suboptions:
+ name:
+ description:
+ - The name of the grid secondary server
+ required: true
+ type: str
+ type: list
+ elements: dict
+ ns_group:
+ description:
+ - Configures the name server group for this zone. Name server group is
+ mutually exclusive with grid primary and grid secondaries.
+ type: str
+ restart_if_needed:
+ description:
+ - If set to true, causes the NIOS DNS service to restart and load the
+ new zone configuration.
+ type: bool
+ zone_format:
+ description:
+ - Create an authorative Reverse-Mapping Zone which is an area of network
+ space for which one or more name servers-primary and secondary-have the
+ responsibility to respond to address-to-name queries. It supports
+ reverse-mapping zones for both IPv4 and IPv6 addresses.
+ default: FORWARD
+ type: str
+ extattrs:
+ description:
+ - Allows for the configuration of Extensible Attributes on the
+ instance of the object. This argument accepts a set of key / value
+ pairs for configuration.
+ type: dict
+ comment:
+ description:
+ - Configures a text string comment to be associated with the instance
+ of this object. The provided text string will be configured on the
+ object instance.
+ type: str
+ state:
+ description:
+ - Configures the intended state of the instance of the object on
+ the NIOS server. When this value is set to C(present), the object
+ is configured on the device and when this value is set to C(absent)
+ the value is removed (if necessary) from the device.
+ default: present
+ choices:
+ - present
+ - absent
+ type: str
+'''
+
+EXAMPLES = '''
+- name: Configure a zone on the system using grid primary and secondaries
+ infoblox.nios_modules.nios_zone:
+ name: ansible.com
+ grid_primary:
+ - name: gridprimary.grid.com
+ grid_secondaries:
+ - name: gridsecondary1.grid.com
+ - name: gridsecondary2.grid.com
+ restart_if_needed: true
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Configure a zone on the system using a name server group
+ infoblox.nios_modules.nios_zone:
+ name: ansible.com
+ ns_group: examplensg
+ restart_if_needed: true
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Configure a reverse mapping zone on the system using IPV4 zone format
+ infoblox.nios_modules.nios_zone:
+ name: 10.10.10.0/24
+ zone_format: IPV4
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Configure a reverse mapping zone on the system using IPV6 zone format
+ infoblox.nios_modules.nios_zone:
+ name: 100::1/128
+ zone_format: IPV6
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Update the comment and ext attributes for an existing zone
+ infoblox.nios_modules.nios_zone:
+ name: ansible.com
+ comment: this is an example comment
+ extattrs:
+ Site: west-dc
+ state: present
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Remove the dns zone
+ infoblox.nios_modules.nios_zone:
+ name: ansible.com
+ state: absent
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+
+- name: Remove the reverse mapping dns zone from the system with IPV4 zone format
+ infoblox.nios_modules.nios_zone:
+ name: 10.10.10.0/24
+ zone_format: IPV4
+ state: absent
+ provider:
+ host: "{{ inventory_hostname_short }}"
+ username: admin
+ password: admin
+ connection: local
+'''
+
+RETURN = ''' # '''
+
+from ansible.module_utils.basic import AnsibleModule
+from ..module_utils.api import WapiModule
+from ..module_utils.api import NIOS_ZONE
+from ..module_utils.api import normalize_ib_spec
+
+
+def main():
+ ''' Main entry point for module execution
+ '''
+ grid_spec = dict(
+ name=dict(required=True),
+ )
+
+ ib_spec = dict(
+ fqdn=dict(required=True, aliases=['name'], ib_req=True, update=False),
+ zone_format=dict(default='FORWARD', ib_req=False),
+ view=dict(default='default', aliases=['dns_view'], ib_req=True),
+
+ grid_primary=dict(type='list', elements='dict', options=grid_spec),
+ grid_secondaries=dict(type='list', elements='dict', options=grid_spec),
+ ns_group=dict(),
+ restart_if_needed=dict(type='bool'),
+
+ extattrs=dict(type='dict'),
+ comment=dict()
+ )
+
+ argument_spec = dict(
+ provider=dict(required=True),
+ state=dict(default='present', choices=['present', 'absent'])
+ )
+
+ argument_spec.update(normalize_ib_spec(ib_spec))
+ argument_spec.update(WapiModule.provider_spec)
+
+ module = AnsibleModule(argument_spec=argument_spec,
+ supports_check_mode=True,
+ mutually_exclusive=[
+ ['ns_group', 'grid_primary'],
+ ['ns_group', 'grid_secondaries']
+ ])
+
+ wapi = WapiModule(module)
+ result = wapi.run(NIOS_ZONE, ib_spec)
+
+ module.exit_json(**result)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/ansible_collections/infoblox/nios_modules/requirements.txt b/ansible_collections/infoblox/nios_modules/requirements.txt
new file mode 100644
index 00000000..be611454
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/requirements.txt
@@ -0,0 +1 @@
+infoblox-client
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_a_record/aliases b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_a_record/aliases
new file mode 100644
index 00000000..b3138dc7
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_a_record/aliases
@@ -0,0 +1,3 @@
+shippable/cloud/group1
+cloud/nios
+destructive
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_a_record/defaults/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_a_record/defaults/main.yaml
new file mode 100644
index 00000000..9ef5ba51
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_a_record/defaults/main.yaml
@@ -0,0 +1,3 @@
+---
+testcase: "*"
+test_items: []
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_a_record/meta/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_a_record/meta/main.yaml
new file mode 100644
index 00000000..1b01a972
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_a_record/meta/main.yaml
@@ -0,0 +1,2 @@
+dependencies:
+ - prepare_nios_tests
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_a_record/tasks/main.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_a_record/tasks/main.yml
new file mode 100644
index 00000000..b3fa8014
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_a_record/tasks/main.yml
@@ -0,0 +1 @@
+- include: nios_a_record_idempotence.yml
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_a_record/tasks/nios_a_record_idempotence.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_a_record/tasks/nios_a_record_idempotence.yml
new file mode 100644
index 00000000..0bbf106c
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_a_record/tasks/nios_a_record_idempotence.yml
@@ -0,0 +1,77 @@
+- name: cleanup the parent object
+ nios_zone:
+ name: ansible.com
+ state: absent
+ provider: "{{ nios_provider }}"
+
+- name: create the parent object
+ nios_zone:
+ name: ansible.com
+ state: present
+ provider: "{{ nios_provider }}"
+
+- name: cleanup a_record
+ nios_a_record:
+ name: a.ansible.com
+ ipv4: 192.168.10.1
+ state: absent
+ provider: "{{ nios_provider }}"
+
+- name: create an a_record
+ nios_a_record:
+ name: a.ansible.com
+ ipv4: 192.168.10.1
+ state: present
+ provider: "{{ nios_provider }}"
+ register: a_record_create1
+
+- name: recreate an a_record
+ nios_a_record:
+ name: a.ansible.com
+ ipv4: 192.168.10.1
+ state: present
+ provider: "{{ nios_provider }}"
+ register: a_record_create2
+
+- name: add a comment to an existing a_record
+ nios_a_record:
+ name: a.ansible.com
+ ipv4: 192.168.10.1
+ comment: this is a test comment
+ state: present
+ provider: "{{ nios_provider }}"
+ register: a_record_update1
+
+- name: add a comment to an existing a_record
+ nios_a_record:
+ name: a.ansible.com
+ ipv4: 192.168.10.1
+ comment: this is a test comment
+ state: present
+ provider: "{{ nios_provider }}"
+ register: a_record_update2
+
+- name: remove a a_record from the system
+ nios_a_record:
+ name: a.ansible.com
+ ipv4: 192.168.10.1
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: a_record_delete1
+
+- name: remove a a_record from the system
+ nios_a_record:
+ name: a.ansible.com
+ ipv4: 192.168.10.1
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: a_record_delete2
+
+- assert:
+ that:
+ - "a_record_create1.changed"
+ - "not a_record_create2.changed"
+ - "a_record_update1.changed"
+ - "not a_record_update2.changed"
+ - "a_record_delete1.changed"
+ - "not a_record_delete2.changed"
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_aaaa_record/aliases b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_aaaa_record/aliases
new file mode 100644
index 00000000..b3138dc7
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_aaaa_record/aliases
@@ -0,0 +1,3 @@
+shippable/cloud/group1
+cloud/nios
+destructive
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_aaaa_record/defaults/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_aaaa_record/defaults/main.yaml
new file mode 100644
index 00000000..9ef5ba51
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_aaaa_record/defaults/main.yaml
@@ -0,0 +1,3 @@
+---
+testcase: "*"
+test_items: []
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_aaaa_record/meta/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_aaaa_record/meta/main.yaml
new file mode 100644
index 00000000..1b01a972
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_aaaa_record/meta/main.yaml
@@ -0,0 +1,2 @@
+dependencies:
+ - prepare_nios_tests
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_aaaa_record/tasks/main.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_aaaa_record/tasks/main.yml
new file mode 100644
index 00000000..2fec2adb
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_aaaa_record/tasks/main.yml
@@ -0,0 +1 @@
+- include: nios_aaaa_record_idempotence.yml
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_aaaa_record/tasks/nios_aaaa_record_idempotence.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_aaaa_record/tasks/nios_aaaa_record_idempotence.yml
new file mode 100644
index 00000000..2df01d34
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_aaaa_record/tasks/nios_aaaa_record_idempotence.yml
@@ -0,0 +1,77 @@
+- name: cleanup the parent object
+ nios_zone:
+ name: ansible.com
+ state: absent
+ provider: "{{ nios_provider }}"
+
+- name: create the parent object
+ nios_zone:
+ name: ansible.com
+ state: present
+ provider: "{{ nios_provider }}"
+
+- name: cleanup aaaa record
+ nios_aaaa_record:
+ name: aaaa.ansible.com
+ ipv6: 2001:0db8:85a3:0000:0000:8a2e:0370:7334
+ state: absent
+ provider: "{{ nios_provider }}"
+
+- name: create an aaaa record
+ nios_aaaa_record:
+ name: aaaa.ansible.com
+ ipv6: 2001:0db8:85a3:0000:0000:8a2e:0370:7334
+ state: present
+ provider: "{{ nios_provider }}"
+ register: aaaa_record_create1
+
+- name: recreate an aaaa record
+ nios_aaaa_record:
+ name: aaaa.ansible.com
+ ipv6: 2001:0db8:85a3:0000:0000:8a2e:0370:7334
+ state: present
+ provider: "{{ nios_provider }}"
+ register: aaaa_record_create2
+
+- name: add a comment to an existing aaaa record
+ nios_aaaa_record:
+ name: aaaa.ansible.com
+ ipv6: 2001:0db8:85a3:0000:0000:8a2e:0370:7334
+ comment: this is a test comment
+ state: present
+ provider: "{{ nios_provider }}"
+ register: aaaa_record_update1
+
+- name: add a comment to an existing aaaa record
+ nios_aaaa_record:
+ name: aaaa.ansible.com
+ ipv6: 2001:0db8:85a3:0000:0000:8a2e:0370:7334
+ comment: this is a test comment
+ state: present
+ provider: "{{ nios_provider }}"
+ register: aaaa_record_update2
+
+- name: remove a aaaa record from the system
+ nios_aaaa_record:
+ name: aaaa.ansible.com
+ ipv6: 2001:0db8:85a3:0000:0000:8a2e:0370:7334
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: aaaa_record_delete1
+
+- name: remove a aaaa record from the system
+ nios_aaaa_record:
+ name: aaaa.ansible.com
+ ipv6: 2001:0db8:85a3:0000:0000:8a2e:0370:7334
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: aaaa_record_delete2
+
+- assert:
+ that:
+ - "aaaa_record_create1.changed"
+ - "not aaaa_record_create2.changed"
+ - "aaaa_record_update1.changed"
+ - "not aaaa_record_update2.changed"
+ - "aaaa_record_delete1.changed"
+ - "not aaaa_record_delete2.changed"
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_cname_record/aliases b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_cname_record/aliases
new file mode 100644
index 00000000..b3138dc7
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_cname_record/aliases
@@ -0,0 +1,3 @@
+shippable/cloud/group1
+cloud/nios
+destructive
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_cname_record/defaults/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_cname_record/defaults/main.yaml
new file mode 100644
index 00000000..9ef5ba51
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_cname_record/defaults/main.yaml
@@ -0,0 +1,3 @@
+---
+testcase: "*"
+test_items: []
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_cname_record/meta/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_cname_record/meta/main.yaml
new file mode 100644
index 00000000..1b01a972
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_cname_record/meta/main.yaml
@@ -0,0 +1,2 @@
+dependencies:
+ - prepare_nios_tests
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_cname_record/tasks/main.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_cname_record/tasks/main.yml
new file mode 100644
index 00000000..b30f250a
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_cname_record/tasks/main.yml
@@ -0,0 +1 @@
+- include: nios_cname_record_idempotence.yml
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_cname_record/tasks/nios_cname_record_idempotence.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_cname_record/tasks/nios_cname_record_idempotence.yml
new file mode 100644
index 00000000..f450c716
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_cname_record/tasks/nios_cname_record_idempotence.yml
@@ -0,0 +1,77 @@
+- name: cleanup the parent object
+ nios_zone:
+ name: ansible.com
+ state: absent
+ provider: "{{ nios_provider }}"
+
+- name: create the parent object
+ nios_zone:
+ name: ansible.com
+ state: present
+ provider: "{{ nios_provider }}"
+
+- name: cleanup cname record
+ nios_cname_record:
+ name: cname.ansible.com
+ canonical: realhost.ansible.com
+ state: absent
+ provider: "{{ nios_provider }}"
+
+- name: create an cname record
+ nios_cname_record:
+ name: cname.ansible.com
+ canonical: realhost.ansible.com
+ state: present
+ provider: "{{ nios_provider }}"
+ register: cname_record_create1
+
+- name: recreate an cname record
+ nios_cname_record:
+ name: cname.ansible.com
+ canonical: realhost.ansible.com
+ state: present
+ provider: "{{ nios_provider }}"
+ register: cname_record_create2
+
+- name: add a comment to an existing cname record
+ nios_cname_record:
+ name: cname.ansible.com
+ canonical: realhost.ansible.com
+ comment: this is a test comment
+ state: present
+ provider: "{{ nios_provider }}"
+ register: cname_record_update1
+
+- name: add a comment to an existing cname record
+ nios_cname_record:
+ name: cname.ansible.com
+ canonical: realhost.ansible.com
+ comment: this is a test comment
+ state: present
+ provider: "{{ nios_provider }}"
+ register: cname_record_update2
+
+- name: remove a cname record from the system
+ nios_cname_record:
+ name: cname.ansible.com
+ canonical: realhost.ansible.com
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: cname_record_delete1
+
+- name: remove a cname record from the system
+ nios_cname_record:
+ name: cname.ansible.com
+ canonical: realhost.ansible.com
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: cname_record_delete2
+
+- assert:
+ that:
+ - "cname_record_create1.changed"
+ - "not cname_record_create2.changed"
+ - "cname_record_update1.changed"
+ - "not cname_record_update2.changed"
+ - "cname_record_delete1.changed"
+ - "not cname_record_delete2.changed"
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_dns_view/aliases b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_dns_view/aliases
new file mode 100644
index 00000000..b3138dc7
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_dns_view/aliases
@@ -0,0 +1,3 @@
+shippable/cloud/group1
+cloud/nios
+destructive
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_dns_view/defaults/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_dns_view/defaults/main.yaml
new file mode 100644
index 00000000..ebf6ffc9
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_dns_view/defaults/main.yaml
@@ -0,0 +1,3 @@
+---
+testcase: "*"
+test_items: [] \ No newline at end of file
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_dns_view/meta/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_dns_view/meta/main.yaml
new file mode 100644
index 00000000..9472935b
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_dns_view/meta/main.yaml
@@ -0,0 +1,2 @@
+dependencies:
+ - prepare_nios_tests \ No newline at end of file
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_dns_view/tasks/main.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_dns_view/tasks/main.yml
new file mode 100644
index 00000000..1eb9c07a
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_dns_view/tasks/main.yml
@@ -0,0 +1 @@
+- include: nios_dns_view_idempotence.yml
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_dns_view/tasks/nios_dns_view_idempotence.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_dns_view/tasks/nios_dns_view_idempotence.yml
new file mode 100644
index 00000000..b9dc9fec
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_dns_view/tasks/nios_dns_view_idempotence.yml
@@ -0,0 +1,58 @@
+- name: delete dns view instance
+ nios_dns_view:
+ name: ansible-dns
+ state: absent
+ provider: "{{ nios_provider }}"
+
+- name: configure a new dns view instance
+ nios_dns_view:
+ name: ansible-dns
+ state: present
+ provider: "{{ nios_provider }}"
+ register: nios_dns_create1
+
+- name: configure a new dns view instance
+ nios_dns_view:
+ name: ansible-dns
+ state: present
+ provider: "{{ nios_provider }}"
+ register: nios_dns_create2
+
+- name: update the comment for dns view
+ nios_dns_view:
+ name: ansible-dns
+ comment: this is an example comment
+ state: present
+ provider: "{{ nios_provider }}"
+ register: nios_dns_update1
+
+- name: update the comment for dns view
+ nios_dns_view:
+ name: ansible-dns
+ comment: this is an example comment
+ state: present
+ provider: "{{ nios_provider }}"
+ register: nios_dns_update2
+
+- name: delete dns view instance
+ nios_dns_view:
+ name: ansible-dns
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: nios_dns_delete1
+
+- name: delete dns view instance
+ nios_dns_view:
+ name: ansible-dns
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: nios_dns_delete2
+
+- assert:
+ that:
+ - "nios_dns_create1.changed"
+ - "not nios_dns_create2.changed"
+ - "nios_dns_update1.changed"
+ - "not nios_dns_update2.changed"
+ - "nios_dns_delete1.changed"
+ - "not nios_dns_delete2.changed"
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_host_record/aliases b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_host_record/aliases
new file mode 100644
index 00000000..b3138dc7
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_host_record/aliases
@@ -0,0 +1,3 @@
+shippable/cloud/group1
+cloud/nios
+destructive
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_host_record/defaults/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_host_record/defaults/main.yaml
new file mode 100644
index 00000000..ebf6ffc9
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_host_record/defaults/main.yaml
@@ -0,0 +1,3 @@
+---
+testcase: "*"
+test_items: [] \ No newline at end of file
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_host_record/meta/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_host_record/meta/main.yaml
new file mode 100644
index 00000000..9472935b
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_host_record/meta/main.yaml
@@ -0,0 +1,2 @@
+dependencies:
+ - prepare_nios_tests \ No newline at end of file
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_host_record/tasks/main.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_host_record/tasks/main.yml
new file mode 100644
index 00000000..2f1dcc55
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_host_record/tasks/main.yml
@@ -0,0 +1 @@
+- include: nios_host_record_idempotence.yml
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_host_record/tasks/nios_host_record_idempotence.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_host_record/tasks/nios_host_record_idempotence.yml
new file mode 100644
index 00000000..636431ee
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_host_record/tasks/nios_host_record_idempotence.yml
@@ -0,0 +1,126 @@
+- name: cleanup the parent object
+ nios_zone:
+ name: ansible.com
+ state: absent
+ provider: "{{ nios_provider }}"
+
+- name: create the parent object
+ nios_zone:
+ name: ansible.com
+ state: present
+ provider: "{{ nios_provider }}"
+
+- name: cleanup ipv4 host record
+ nios_host_record:
+ name: host.ansible.com
+ ipv4:
+ - address: 192.168.10.1
+ state: absent
+ provider: "{{ nios_provider }}"
+
+- name: create an ipv4 host record
+ nios_host_record:
+ name: host.ansible.com
+ ipv4:
+ - address: 192.168.10.1
+ state: present
+ provider: "{{ nios_provider }}"
+ register: ipv4_create1
+
+- name: recreate an ipv4 host record
+ nios_host_record:
+ name: host.ansible.com
+ ipv4:
+ - address: 192.168.10.1
+ state: present
+ provider: "{{ nios_provider }}"
+ register: ipv4_create2
+
+- name: add a comment to an existing host record
+ nios_host_record:
+ name: host.ansible.com
+ ipv4:
+ - address: 192.168.10.1
+ comment: this is a test comment
+ state: present
+ provider: "{{ nios_provider }}"
+ register: ipv4_update1
+
+- name: add a comment to an existing host record
+ nios_host_record:
+ name: host.ansible.com
+ ipv4:
+ - address: 192.168.10.1
+ comment: this is a test comment
+ state: present
+ provider: "{{ nios_provider }}"
+ register: ipv4_update2
+
+- name: remove a host record from the system
+ nios_host_record:
+ name: host.ansible.com
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: ipv4_delete1
+
+- name: remove a host record from the system
+ nios_host_record:
+ name: host.ansible.com
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: ipv4_delete2
+
+- name: create an ipv4 host record bypassing DNS
+ nios_host_record:
+ name: host
+ ipv4:
+ - address: 192.168.10.1
+ dns: false
+ state: present
+ provider: "{{ nios_provider }}"
+ register: ipv4_create3
+
+- name: recreate an ipv4 host record bypassing DNS
+ nios_host_record:
+ name: host
+ ipv4:
+ - address: 192.168.10.1
+ dns: false
+ state: present
+ provider: "{{ nios_provider }}"
+ register: ipv4_create4
+
+- name: create an ipv4 host record via DHCP and MAC
+ nios_host_record:
+ name: host
+ ipv4:
+ - address: 192.168.10.1
+ dhcp: true
+ mac: 00-80-C8-E3-4C-BD
+ state: present
+ provider: "{{ nios_provider }}"
+ register: ipv4_create5
+
+- name: recreate an ipv4 host record via DHCP and MAC
+ nios_host_record:
+ name: host
+ ipv4:
+ - address: 192.168.10.1
+ dhcp: true
+ mac: 00-80-C8-E3-4C-BD
+ state: present
+ provider: "{{ nios_provider }}"
+ register: ipv4_create6
+
+- assert:
+ that:
+ - "ipv4_create1.changed"
+ - "not ipv4_create2.changed"
+ - "ipv4_update1.changed"
+ - "not ipv4_update2.changed"
+ - "ipv4_delete1.changed"
+ - "not ipv4_delete2.changed"
+ - "ipv4_create3.changed"
+ - "not ipv4_create4.changed"
+ - "ipv4_create5.changed"
+ - "not ipv4_create6.changed"
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_mx_record/aliases b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_mx_record/aliases
new file mode 100644
index 00000000..b3138dc7
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_mx_record/aliases
@@ -0,0 +1,3 @@
+shippable/cloud/group1
+cloud/nios
+destructive
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_mx_record/defaults/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_mx_record/defaults/main.yaml
new file mode 100644
index 00000000..9ef5ba51
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_mx_record/defaults/main.yaml
@@ -0,0 +1,3 @@
+---
+testcase: "*"
+test_items: []
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_mx_record/meta/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_mx_record/meta/main.yaml
new file mode 100644
index 00000000..1b01a972
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_mx_record/meta/main.yaml
@@ -0,0 +1,2 @@
+dependencies:
+ - prepare_nios_tests
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_mx_record/tasks/main.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_mx_record/tasks/main.yml
new file mode 100644
index 00000000..fe687173
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_mx_record/tasks/main.yml
@@ -0,0 +1 @@
+- include: nios_mx_record_idempotence.yml
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_mx_record/tasks/nios_mx_record_idempotence.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_mx_record/tasks/nios_mx_record_idempotence.yml
new file mode 100644
index 00000000..65b1e8f4
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_mx_record/tasks/nios_mx_record_idempotence.yml
@@ -0,0 +1,84 @@
+- name: cleanup the parent object
+ nios_zone:
+ name: ansible.com
+ state: absent
+ provider: "{{ nios_provider }}"
+
+- name: create the parent object
+ nios_zone:
+ name: ansible.com
+ state: present
+ provider: "{{ nios_provider }}"
+
+- name: cleanup mx record
+ nios_mx_record:
+ name: ansible.com
+ mx: mailhost.ansible.com
+ preference: 0
+ state: absent
+ provider: "{{ nios_provider }}"
+
+- name: create an mx record
+ nios_mx_record:
+ name: ansible.com
+ mx: mailhost.ansible.com
+ preference: 0
+ state: present
+ provider: "{{ nios_provider }}"
+ register: mx_record_create1
+
+- name: recreate an mx record
+ nios_mx_record:
+ name: ansible.com
+ mx: mailhost.ansible.com
+ preference: 0
+ state: present
+ provider: "{{ nios_provider }}"
+ register: mx_record_create2
+
+- name: add a comment to an existing mx record
+ nios_mx_record:
+ name: ansible.com
+ mx: mailhost.ansible.com
+ preference: 0
+ comment: this is a test comment
+ state: present
+ provider: "{{ nios_provider }}"
+ register: mx_record_update1
+
+- name: add a comment to an existing mx record
+ nios_mx_record:
+ name: ansible.com
+ mx: mailhost.ansible.com
+ preference: 0
+ comment: this is a test comment
+ state: present
+ provider: "{{ nios_provider }}"
+ register: mx_record_update2
+
+- name: remove a mx record from the system
+ nios_mx_record:
+ name: ansible.com
+ mx: mailhost.ansible.com
+ preference: 0
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: mx_record_delete1
+
+- name: remove a mx record from the system
+ nios_mx_record:
+ name: ansible.com
+ mx: mailhost.ansible.com
+ preference: 0
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: mx_record_delete2
+
+- assert:
+ that:
+ - "mx_record_create1.changed"
+ - "not mx_record_create2.changed"
+ - "mx_record_update1.changed"
+ - "not mx_record_update2.changed"
+ - "mx_record_delete1.changed"
+ - "not mx_record_delete2.changed"
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_naptr_record/aliases b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_naptr_record/aliases
new file mode 100644
index 00000000..b3138dc7
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_naptr_record/aliases
@@ -0,0 +1,3 @@
+shippable/cloud/group1
+cloud/nios
+destructive
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_naptr_record/defaults/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_naptr_record/defaults/main.yaml
new file mode 100644
index 00000000..9ef5ba51
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_naptr_record/defaults/main.yaml
@@ -0,0 +1,3 @@
+---
+testcase: "*"
+test_items: []
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_naptr_record/meta/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_naptr_record/meta/main.yaml
new file mode 100644
index 00000000..1b01a972
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_naptr_record/meta/main.yaml
@@ -0,0 +1,2 @@
+dependencies:
+ - prepare_nios_tests
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_naptr_record/tasks/main.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_naptr_record/tasks/main.yml
new file mode 100644
index 00000000..a22a8018
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_naptr_record/tasks/main.yml
@@ -0,0 +1 @@
+- include: nios_naptr_record_idempotence.yml
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_naptr_record/tasks/nios_naptr_record_idempotence.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_naptr_record/tasks/nios_naptr_record_idempotence.yml
new file mode 100644
index 00000000..2303eff5
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_naptr_record/tasks/nios_naptr_record_idempotence.yml
@@ -0,0 +1,91 @@
+- name: cleanup the parent object
+ nios_zone:
+ name: ansible.com
+ state: absent
+ provider: "{{ nios_provider }}"
+
+- name: create the parent object
+ nios_zone:
+ name: ansible.com
+ state: present
+ provider: "{{ nios_provider }}"
+
+- name: cleanup naptr record
+ nios_naptr_record:
+ name: '*.subscriber-100.ansiblezone.com'
+ order: 1000
+ preference: 10
+ replacement: replacement1.network.ansiblezone.com
+ state: absent
+ provider: "{{ nios_provider }}"
+
+- name: create an naptr record
+ nios_naptr_record:
+ name: '*.subscriber-100.ansiblezone.com'
+ order: 1000
+ preference: 10
+ replacement: replacement1.network.ansiblezone.com
+ state: present
+ provider: "{{ nios_provider }}"
+ register: naptr_record_create1
+
+- name: recreate an naptr record
+ nios_naptr_record:
+ name: '*.subscriber-100.ansiblezone.com'
+ order: 1000
+ preference: 10
+ replacement: replacement1.network.ansiblezone.com
+ state: present
+ provider: "{{ nios_provider }}"
+ register: naptr_record_create2
+
+- name: add a comment to an existing naptr record
+ nios_naptr_record:
+ name: '*.subscriber-100.ansiblezone.com'
+ order: 1000
+ preference: 10
+ replacement: replacement1.network.ansiblezone.com
+ comment: this is a test comment
+ state: present
+ provider: "{{ nios_provider }}"
+ register: naptr_record_update1
+
+- name: add a comment to an existing naptr record
+ nios_naptr_record:
+ name: '*.subscriber-100.ansiblezone.com'
+ order: 1000
+ preference: 10
+ replacement: replacement1.network.ansiblezone.com
+ comment: this is a test comment
+ state: present
+ provider: "{{ nios_provider }}"
+ register: naptr_record_update2
+
+- name: remove a naptr record from the system
+ nios_naptr_record:
+ name: '*.subscriber-100.ansiblezone.com'
+ order: 1000
+ preference: 10
+ replacement: replacement1.network.ansiblezone.com
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: naptr_record_delete1
+
+- name: remove a naptr record from the system
+ nios_naptr_record:
+ name: '*.subscriber-100.ansiblezone.com'
+ order: 1000
+ preference: 10
+ replacement: replacement1.network.ansiblezone.com
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: naptr_record_delete2
+
+- assert:
+ that:
+ - "naptr_record_create1.changed"
+ - "not naptr_record_create2.changed"
+ - "naptr_record_update1.changed"
+ - "not naptr_record_update2.changed"
+ - "naptr_record_delete1.changed"
+ - "not naptr_record_delete2.changed"
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network/aliases b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network/aliases
new file mode 100644
index 00000000..b3138dc7
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network/aliases
@@ -0,0 +1,3 @@
+shippable/cloud/group1
+cloud/nios
+destructive
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network/defaults/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network/defaults/main.yaml
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network/defaults/main.yaml
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network/meta/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network/meta/main.yaml
new file mode 100644
index 00000000..9472935b
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network/meta/main.yaml
@@ -0,0 +1,2 @@
+dependencies:
+ - prepare_nios_tests \ No newline at end of file
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network/tasks/main.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network/tasks/main.yml
new file mode 100644
index 00000000..c147af8f
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network/tasks/main.yml
@@ -0,0 +1 @@
+- include: nios_network_idempotence.yml
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network/tasks/nios_network_idempotence.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network/tasks/nios_network_idempotence.yml
new file mode 100644
index 00000000..3b5dbc4b
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network/tasks/nios_network_idempotence.yml
@@ -0,0 +1,80 @@
+- name: cleanup a network ipv4
+ nios_network:
+ network: 192.168.10.0/24
+ comment: this is a test comment
+ state: absent
+ provider: "{{ nios_provider }}"
+
+- name: configure a network ipv4
+ nios_network:
+ network: 192.168.10.0/24
+ comment: this is a test comment
+ state: present
+ provider: "{{ nios_provider }}"
+ register: nios_ipv4_create1
+
+- name: configure a network ipv4
+ nios_network:
+ network: 192.168.10.0/24
+ comment: this is a test comment
+ state: present
+ provider: "{{ nios_provider }}"
+ register: nios_ipv4_create2
+
+#- assert:
+# that:
+# - "nios_ipv4_create1.changed"
+# - "not nios_ipv4_create2.changed"
+
+- name: set dhcp options for a network ipv4
+ nios_network:
+ network: 192.168.10.0/24
+ comment: this is a test comment
+ options:
+ - name: domain-name
+ value: ansible.com
+ state: present
+ provider: "{{ nios_provider }}"
+ register: nios_ipv4_update1
+
+- name: set dhcp options for a network ipv4
+ nios_network:
+ network: 192.168.10.0/24
+ comment: this is a test comment
+ options:
+ - name: domain-name
+ value: ansible.com
+ state: present
+ provider: "{{ nios_provider }}"
+ register: nios_ipv4_update2
+
+- name: remove a network ipv4
+ nios_network:
+ network: 192.168.10.0/24
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: nios_ipv4_remove1
+
+- name: remove a network ipv4
+ nios_network:
+ network: 192.168.10.0/24
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: nios_ipv4_remove2
+
+- name: configure a network ipv6
+ nios_network:
+ network: fe80::/64
+ comment: this is a test comment
+ state: present
+ provider: "{{ nios_provider }}"
+ register: nios_ipv6_create1
+
+- assert:
+ that:
+ - "nios_ipv4_create1.changed"
+ - "not nios_ipv4_create2.changed"
+ - "nios_ipv4_update1.changed"
+ - "not nios_ipv4_update2.changed"
+ - "nios_ipv4_remove1.changed"
+ - "not nios_ipv4_remove2.changed"
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network_view/aliases b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network_view/aliases
new file mode 100644
index 00000000..b3138dc7
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network_view/aliases
@@ -0,0 +1,3 @@
+shippable/cloud/group1
+cloud/nios
+destructive
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network_view/defaults/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network_view/defaults/main.yaml
new file mode 100644
index 00000000..ebf6ffc9
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network_view/defaults/main.yaml
@@ -0,0 +1,3 @@
+---
+testcase: "*"
+test_items: [] \ No newline at end of file
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network_view/meta/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network_view/meta/main.yaml
new file mode 100644
index 00000000..9472935b
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network_view/meta/main.yaml
@@ -0,0 +1,2 @@
+dependencies:
+ - prepare_nios_tests \ No newline at end of file
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network_view/tasks/main.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network_view/tasks/main.yml
new file mode 100644
index 00000000..97e87148
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network_view/tasks/main.yml
@@ -0,0 +1 @@
+- include: nios_network_view_idempotence.yml
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network_view/tasks/nios_network_view_idempotence.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network_view/tasks/nios_network_view_idempotence.yml
new file mode 100644
index 00000000..ad13e3a3
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_network_view/tasks/nios_network_view_idempotence.yml
@@ -0,0 +1,58 @@
+- name: cleanup a new network view
+ nios_network_view:
+ name: ansible
+ state: absent
+ provider: "{{ nios_provider }}"
+
+- name: configure a new network view
+ nios_network_view:
+ name: ansible
+ state: present
+ provider: "{{ nios_provider }}"
+ register: nios_network_view_create1
+
+- name: configure a new network view
+ nios_network_view:
+ name: ansible
+ state: present
+ provider: "{{ nios_provider }}"
+ register: nios_network_view_create2
+
+- name: update the comment for network view
+ nios_network_view:
+ name: ansible
+ comment: this is an example comment
+ state: present
+ provider: "{{ nios_provider }}"
+ register: nios_network_view_update1
+
+- name: update the comment for network view
+ nios_network_view:
+ name: ansible
+ comment: this is an example comment
+ state: present
+ provider: "{{ nios_provider }}"
+ register: nios_network_view_update2
+
+- name: remove the network view
+ nios_network_view:
+ name: ansible
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: nios_network_view_delete1
+
+- name: remove the network view
+ nios_network_view:
+ name: ansible
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: nios_network_view_delete2
+
+- assert:
+ that:
+ - "nios_network_view_create1.changed"
+ - "not nios_network_view_create2.changed"
+ - "nios_network_view_update1.changed"
+ - "not nios_network_view_update2.changed"
+ - "nios_network_view_delete1.changed"
+ - "not nios_network_view_delete2.changed"
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_ptr_record/aliases b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_ptr_record/aliases
new file mode 100644
index 00000000..b3138dc7
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_ptr_record/aliases
@@ -0,0 +1,3 @@
+shippable/cloud/group1
+cloud/nios
+destructive
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_ptr_record/defaults/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_ptr_record/defaults/main.yaml
new file mode 100644
index 00000000..9ef5ba51
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_ptr_record/defaults/main.yaml
@@ -0,0 +1,3 @@
+---
+testcase: "*"
+test_items: []
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_ptr_record/meta/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_ptr_record/meta/main.yaml
new file mode 100644
index 00000000..1b01a972
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_ptr_record/meta/main.yaml
@@ -0,0 +1,2 @@
+dependencies:
+ - prepare_nios_tests
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_ptr_record/tasks/main.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_ptr_record/tasks/main.yml
new file mode 100644
index 00000000..ec33e8f5
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_ptr_record/tasks/main.yml
@@ -0,0 +1 @@
+- include: nios_ptr_record_idempotence.yml
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_ptr_record/tasks/nios_ptr_record_idempotence.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_ptr_record/tasks/nios_ptr_record_idempotence.yml
new file mode 100644
index 00000000..a233d80f
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_ptr_record/tasks/nios_ptr_record_idempotence.yml
@@ -0,0 +1,83 @@
+---
+
+- name: create an ipv4 ptr record
+ nios_ptr_record:
+ name: ptr.ansible.com
+ ptrdname: ptr.ansible.com
+ ipv4: 192.168.10.1
+ state: present
+ provider: "{{ nios_provider }}"
+ view: default
+ register: ipv4_ptr_create1
+
+- name: create the same ipv4 ptr record
+ nios_ptr_record:
+ name: ptr.ansible.com
+ ptrdname: ptr.ansible.com
+ ipv4: 192.168.10.1
+ state: present
+ view: default
+ provider: "{{ nios_provider }}"
+ register: ipv4_ptr_create2
+
+- name: add a comment to an existing ipv4 ptr record
+ nios_ptr_record:
+ name: ptr.ansible.com
+ ptrdname: ptr.ansible.com
+ ipv4: 192.168.10.1
+ comment: this is a test comment
+ view: default
+ state: present
+ provider: "{{ nios_provider }}"
+ register: ipv4_ptr_update1
+
+- name: add the same comment to the same ipv4 ptr host record
+ nios_ptr_record:
+ name: ptr.ansible.com
+ ptrdname: ptr.ansible.com
+ ipv4: 192.168.10.1
+ comment: this is a test comment
+ view: default
+ state: present
+ provider: "{{ nios_provider }}"
+ register: ipv4_ptr_update2
+
+- name: remove a ptr record from the system
+ nios_ptr_record:
+ name: ptr.ansible.com
+ ptrdname: ptr.ansible.com
+ ipv4: 192.168.10.1
+ view: default
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: ipv4_ptr_delete1
+
+- name: remove the same ptr record from the system
+ nios_ptr_record:
+ ptrdname: ptr.ansible.com
+ name: ptr.ansible.com
+ ipv4: 192.168.10.1
+ view: default
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: ipv4_ptr_delete2
+
+- name: create an ipv6 ptr record
+ nios_ptr_record:
+ ptrdname: ptr6.ansible.com
+ name: ptr6.ansible.com
+ ipv6: "2002:8ac3:802d:1242:20d:60ff:fe38:6d16"
+ view: default
+ state: present
+ provider: "{{ nios_provider }}"
+ register: ipv6_ptr_create1
+
+- assert:
+ that:
+ - "ipv4_ptr_create1.changed"
+ - "not ipv4_ptr_create2.changed"
+ - "ipv4_ptr_update1.changed"
+ - "not ipv4_ptr_update2.changed"
+ - "ipv4_ptr_delete1.changed"
+ - "not ipv4_ptr_delete2.changed"
+ - "ipv6_ptr_create1.changed"
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_srv_record/aliases b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_srv_record/aliases
new file mode 100644
index 00000000..b3138dc7
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_srv_record/aliases
@@ -0,0 +1,3 @@
+shippable/cloud/group1
+cloud/nios
+destructive
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_srv_record/defaults/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_srv_record/defaults/main.yaml
new file mode 100644
index 00000000..9ef5ba51
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_srv_record/defaults/main.yaml
@@ -0,0 +1,3 @@
+---
+testcase: "*"
+test_items: []
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_srv_record/meta/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_srv_record/meta/main.yaml
new file mode 100644
index 00000000..1b01a972
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_srv_record/meta/main.yaml
@@ -0,0 +1,2 @@
+dependencies:
+ - prepare_nios_tests
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_srv_record/tasks/main.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_srv_record/tasks/main.yml
new file mode 100644
index 00000000..1c847673
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_srv_record/tasks/main.yml
@@ -0,0 +1 @@
+- include: nios_srv_record_idempotence.yml
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_srv_record/tasks/nios_srv_record_idempotence.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_srv_record/tasks/nios_srv_record_idempotence.yml
new file mode 100644
index 00000000..8f3dbfc7
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_srv_record/tasks/nios_srv_record_idempotence.yml
@@ -0,0 +1,98 @@
+- name: cleanup the parent object
+ nios_zone:
+ name: ansible.com
+ state: absent
+ provider: "{{ nios_provider }}"
+
+- name: create the parent object
+ nios_zone:
+ name: ansible.com
+ state: present
+ provider: "{{ nios_provider }}"
+
+- name: cleanup srv record
+ nios_srv_record:
+ name: ansible.com
+ port: 5080
+ priority: 10
+ target: service1.ansible.com
+ weight: 10
+ state: absent
+ provider: "{{ nios_provider }}"
+
+- name: create an srv record
+ nios_srv_record:
+ name: ansible.com
+ port: 5080
+ priority: 10
+ target: service1.ansible.com
+ weight: 10
+ state: present
+ provider: "{{ nios_provider }}"
+ register: srv_record_create1
+
+- name: recreate an srv record
+ nios_srv_record:
+ name: ansible.com
+ port: 5080
+ priority: 10
+ target: service1.ansible.com
+ weight: 10
+ state: present
+ provider: "{{ nios_provider }}"
+ register: srv_record_create2
+
+- name: add a comment to an existing srv record
+ nios_srv_record:
+ name: ansible.com
+ port: 5080
+ priority: 10
+ target: service1.ansible.com
+ weight: 10
+ comment: this is a test comment
+ state: present
+ provider: "{{ nios_provider }}"
+ register: srv_record_update1
+
+- name: add a comment to an existing srv record
+ nios_srv_record:
+ name: ansible.com
+ port: 5080
+ priority: 10
+ target: service1.ansible.com
+ weight: 10
+ comment: this is a test comment
+ state: present
+ provider: "{{ nios_provider }}"
+ register: srv_record_update2
+
+- name: remove a srv record from the system
+ nios_srv_record:
+ name: ansible.com
+ port: 5080
+ priority: 10
+ target: service1.ansible.com
+ weight: 10
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: srv_record_delete1
+
+- name: remove a srv record from the system
+ nios_srv_record:
+ name: ansible.com
+ port: 5080
+ priority: 10
+ target: service1.ansible.com
+ weight: 10
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: srv_record_delete2
+
+- assert:
+ that:
+ - "srv_record_create1.changed"
+ - "not srv_record_create2.changed"
+ - "srv_record_update1.changed"
+ - "not srv_record_update2.changed"
+ - "srv_record_delete1.changed"
+ - "not srv_record_delete2.changed"
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_txt_record/aliases b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_txt_record/aliases
new file mode 100644
index 00000000..b3138dc7
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_txt_record/aliases
@@ -0,0 +1,3 @@
+shippable/cloud/group1
+cloud/nios
+destructive
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_txt_record/defaults/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_txt_record/defaults/main.yaml
new file mode 100644
index 00000000..ebf6ffc9
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_txt_record/defaults/main.yaml
@@ -0,0 +1,3 @@
+---
+testcase: "*"
+test_items: [] \ No newline at end of file
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_txt_record/meta/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_txt_record/meta/main.yaml
new file mode 100644
index 00000000..9472935b
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_txt_record/meta/main.yaml
@@ -0,0 +1,2 @@
+dependencies:
+ - prepare_nios_tests \ No newline at end of file
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_txt_record/tasks/main.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_txt_record/tasks/main.yml
new file mode 100644
index 00000000..e15b4c55
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_txt_record/tasks/main.yml
@@ -0,0 +1 @@
+- include: nios_txt_record_idempotence.yml
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_txt_record/tasks/nios_txt_record_idempotence.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_txt_record/tasks/nios_txt_record_idempotence.yml
new file mode 100644
index 00000000..37638d85
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_txt_record/tasks/nios_txt_record_idempotence.yml
@@ -0,0 +1,82 @@
+- name: cleanup the parent object
+ nios_zone:
+ name: ansible.com
+ state: absent
+ provider: "{{ nios_provider }}"
+
+- name: create the parent object
+ nios_zone:
+ name: ansible.com
+ state: present
+ provider: "{{ nios_provider }}"
+
+- name: cleanup txt record
+ nios_txt_record:
+ name: txt.ansible.com
+ text: mytext
+ state: absent
+ provider: "{{ nios_provider }}"
+
+- name: create txt record
+ nios_txt_record:
+ name: txt.ansible.com
+ text: mytext
+ state: present
+ provider: "{{ nios_provider }}"
+ register: txt_create1
+
+- name: create txt record
+ nios_txt_record:
+ name: txt.ansible.com
+ text: mytext
+ state: present
+ provider: "{{ nios_provider }}"
+ register: txt_create2
+
+- assert:
+ that:
+ - "txt_create1.changed"
+ - "not txt_create2.changed"
+
+- name: add a comment to an existing txt record
+ nios_txt_record:
+ name: txt.ansible.com
+ text: mytext
+ state: present
+ comment: mycomment
+ provider: "{{ nios_provider }}"
+ register: txt_update1
+
+- name: add a comment to an existing txt record
+ nios_txt_record:
+ name: txt.ansible.com
+ text: mytext
+ state: present
+ comment: mycomment
+ provider: "{{ nios_provider }}"
+ register: txt_update2
+
+- name: remove a txt record from the system
+ nios_txt_record:
+ name: txt.ansible.com
+ text: mytext
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: txt_delete1
+
+- name: remove a txt record from the system
+ nios_txt_record:
+ name: txt.ansible.com
+ text: mytext
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: txt_delete2
+
+- assert:
+ that:
+ - "txt_create1.changed"
+ - "not txt_create2.changed"
+ - "txt_update1.changed"
+ - "not txt_update2.changed"
+ - "txt_delete1.changed"
+ - "not txt_delete2.changed"
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_zone/aliases b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_zone/aliases
new file mode 100644
index 00000000..b3138dc7
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_zone/aliases
@@ -0,0 +1,3 @@
+shippable/cloud/group1
+cloud/nios
+destructive
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_zone/defaults/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_zone/defaults/main.yaml
new file mode 100644
index 00000000..ebf6ffc9
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_zone/defaults/main.yaml
@@ -0,0 +1,3 @@
+---
+testcase: "*"
+test_items: [] \ No newline at end of file
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_zone/meta/main.yaml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_zone/meta/main.yaml
new file mode 100644
index 00000000..9472935b
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_zone/meta/main.yaml
@@ -0,0 +1,2 @@
+dependencies:
+ - prepare_nios_tests \ No newline at end of file
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_zone/tasks/main.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_zone/tasks/main.yml
new file mode 100644
index 00000000..f066edcd
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_zone/tasks/main.yml
@@ -0,0 +1 @@
+- include: nios_zone_idempotence.yml
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_zone/tasks/nios_zone_idempotence.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_zone/tasks/nios_zone_idempotence.yml
new file mode 100644
index 00000000..03d40aaf
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/nios_zone/tasks/nios_zone_idempotence.yml
@@ -0,0 +1,68 @@
+- name: cleanup dns view instance
+ nios_dns_view:
+ name: ansible-dns
+ state: absent
+ provider: "{{ nios_provider }}"
+
+- name: cleanup test zone
+ nios_zone:
+ name: ansible-dns
+ state: absent
+ provider: "{{ nios_provider }}"
+
+- name: configure a zone on the system
+ nios_zone:
+ name: ansible-dns
+ state: present
+ provider: "{{ nios_provider }}"
+ register: zone_create1
+
+- name: configure a zone on the system
+ nios_zone:
+ name: ansible-dns
+ state: present
+ provider: "{{ nios_provider }}"
+ register: zone_create2
+
+- name: update the comment and ext attributes for an existing zone
+ nios_zone:
+ name: ansible-dns
+ comment: this is an example comment
+ extattrs:
+ Site: west-dc
+ state: present
+ provider: "{{ nios_provider }}"
+ register: zone_update1
+
+- name: update the comment and ext attributes for an existing zone
+ nios_zone:
+ name: ansible-dns
+ comment: this is an example comment
+ extattrs:
+ Site: west-dc
+ state: present
+ provider: "{{ nios_provider }}"
+ register: zone_update2
+
+- name: remove the dns zone
+ nios_zone:
+ name: ansible-dns
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: zone_delete1
+
+- name: remove the dns zone
+ nios_zone:
+ name: ansible-dns
+ state: absent
+ provider: "{{ nios_provider }}"
+ register: zone_delete2
+
+- assert:
+ that:
+ - "zone_create1.changed"
+ - "not zone_create2.changed"
+ - "zone_update1.changed"
+ - "not zone_update2.changed"
+ - "zone_delete1.changed"
+ - "not zone_delete2.changed"
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/prepare_nios_tests/tasks/main.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/prepare_nios_tests/tasks/main.yml
new file mode 100644
index 00000000..2a3092f3
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/prepare_nios_tests/tasks/main.yml
@@ -0,0 +1 @@
+- include: prepare_nios_tests_idempotence.yml
diff --git a/ansible_collections/infoblox/nios_modules/tests/integration/targets/prepare_nios_tests/tasks/prepare_nios_tests_idempotence.yml b/ansible_collections/infoblox/nios_modules/tests/integration/targets/prepare_nios_tests/tasks/prepare_nios_tests_idempotence.yml
new file mode 100644
index 00000000..749faa20
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/integration/targets/prepare_nios_tests/tasks/prepare_nios_tests_idempotence.yml
@@ -0,0 +1,2 @@
+- pip:
+ name: infoblox-client
diff --git a/ansible_collections/infoblox/nios_modules/tests/requirements.txt b/ansible_collections/infoblox/nios_modules/tests/requirements.txt
new file mode 100644
index 00000000..7f835e9f
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/requirements.txt
@@ -0,0 +1,9 @@
+infoblox-client
+pytest
+pytest-xdist
+mock
+pytest-mock
+pytest-cov==2.8.0
+coverage
+pygobject
+launchpadlib
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/__init__.py b/ansible_collections/infoblox/nios_modules/tests/unit/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/__init__.py
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/compat/__init__.py b/ansible_collections/infoblox/nios_modules/tests/unit/compat/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/compat/__init__.py
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/compat/mock.py b/ansible_collections/infoblox/nios_modules/tests/unit/compat/mock.py
new file mode 100644
index 00000000..ba8455bf
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/compat/mock.py
@@ -0,0 +1,120 @@
+# (c) 2014, Toshio Kuratomi <tkuratomi@ansible.com>
+#
+# 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/>.
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+'''
+Compat module for Python3.x's unittest.mock module
+'''
+import sys
+
+# Python 2.7
+
+# Note: Could use the pypi mock library on python3.x as well as python2.x. It
+# is the same as the python3 stdlib mock library
+
+try:
+ # Allow wildcard import because we really do want to import all of mock's
+ # symbols into this compat shim
+ # pylint: disable=wildcard-import,unused-wildcard-import
+ from unittest.mock import *
+except ImportError:
+ # Python 2
+ # pylint: disable=wildcard-import,unused-wildcard-import
+ try:
+ from mock import *
+ except ImportError:
+ print('You need the mock library installed on python2.x to run tests')
+
+
+# Prior to 3.4.4, mock_open cannot handle binary read_data
+if sys.version_info >= (3,) and sys.version_info < (3, 4, 4):
+ file_spec = None
+
+ def _iterate_read_data(read_data):
+ # Helper for mock_open:
+ # Retrieve lines from read_data via a generator so that separate calls to
+ # readline, read, and readlines are properly interleaved
+ sep = b'\n' if isinstance(read_data, bytes) else '\n'
+ data_as_list = [l + sep for l in read_data.split(sep)]
+
+ if data_as_list[-1] == sep:
+ # If the last line ended in a newline, the list comprehension will have an
+ # extra entry that's just a newline. Remove this.
+ data_as_list = data_as_list[:-1]
+ else:
+ # If there wasn't an extra newline by itself, then the file being
+ # emulated doesn't have a newline to end the last line remove the
+ # newline that our naive format() added
+ data_as_list[-1] = data_as_list[-1][:-1]
+
+ for line in data_as_list:
+ yield line
+
+ def mock_open(mock=None, read_data=''):
+ """
+ A helper function to create a mock to replace the use of `open`. It works
+ for `open` called directly or used as a context manager.
+ The `mock` argument is the mock object to configure. If `None` (the
+ default) then a `MagicMock` will be created for you, with the API limited
+ to methods or attributes available on standard file handles.
+ `read_data` is a string for the `read` methoddline`, and `readlines` of the
+ file handle to return. This is an empty string by default.
+ """
+ def _readlines_side_effect(*args, **kwargs):
+ if handle.readlines.return_value is not None:
+ return handle.readlines.return_value
+ return list(_data)
+
+ def _read_side_effect(*args, **kwargs):
+ if handle.read.return_value is not None:
+ return handle.read.return_value
+ return type(read_data)().join(_data)
+
+ def _readline_side_effect():
+ if handle.readline.return_value is not None:
+ while True:
+ yield handle.readline.return_value
+ for line in _data:
+ yield line
+
+ global file_spec
+ if file_spec is None:
+ import _io
+ file_spec = list(set(dir(_io.TextIOWrapper)).union(set(dir(_io.BytesIO))))
+
+ if mock is None:
+ mock = MagicMock(name='open', spec=open)
+
+ handle = MagicMock(spec=file_spec)
+ handle.__enter__.return_value = handle
+
+ _data = _iterate_read_data(read_data)
+
+ handle.write.return_value = None
+ handle.read.return_value = None
+ handle.readline.return_value = None
+ handle.readlines.return_value = None
+
+ handle.read.side_effect = _read_side_effect
+ handle.readline.side_effect = _readline_side_effect()
+ handle.readlines.side_effect = _readlines_side_effect
+
+ mock.return_value = handle
+ return mock
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/__init__.py b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/__init__.py
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/module_utils/__init__.py b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/module_utils/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/module_utils/__init__.py
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/module_utils/test_api.py b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/module_utils/test_api.py
new file mode 100644
index 00000000..550d1bd7
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/module_utils/test_api.py
@@ -0,0 +1,255 @@
+# (c) 2018 Red Hat, Inc.
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+__metaclass__ = type
+
+import copy
+
+from ansible_collections.infoblox.nios_modules.tests.unit.compat import unittest
+from ansible_collections.infoblox.nios_modules.tests.unit.compat.mock import patch, MagicMock, Mock
+from ansible.module_utils.common.validation import check_type_dict
+from ansible_collections.infoblox.nios_modules.plugins.module_utils import api
+
+
+class TestNiosApi(unittest.TestCase):
+
+ def setUp(self):
+ super(TestNiosApi, self).setUp()
+
+ self.module = MagicMock(name='AnsibleModule')
+ self.module.check_mode = False
+ self.module.params = {'provider': None}
+
+ self.mock_connector = patch('ansible_collections.infoblox.nios_modules.plugins.module_utils.api.get_connector')
+ self.mock_connector.start()
+ self.mock_check_type_dict = patch('ansible.module_utils.common.validation.check_type_dict')
+ self.mock_check_type_dict_obj = self.mock_check_type_dict.start()
+
+ def tearDown(self):
+ super(TestNiosApi, self).tearDown()
+
+ self.mock_connector.stop()
+ self.mock_check_type_dict.stop()
+
+ def test_get_provider_spec(self):
+ provider_options = ['host', 'username', 'password', 'cert', 'key', 'validate_certs', 'silent_ssl_warnings',
+ 'http_request_timeout', 'http_pool_connections',
+ 'http_pool_maxsize', 'max_retries', 'wapi_version', 'max_results']
+ res = api.WapiBase.provider_spec
+ self.assertIsNotNone(res)
+ self.assertIn('provider', res)
+ self.assertIn('options', res['provider'])
+ returned_options = res['provider']['options']
+ self.assertEqual(sorted(provider_options), sorted(returned_options.keys()))
+
+ def _get_wapi(self, test_object):
+ wapi = api.WapiModule(self.module)
+ wapi.get_object = Mock(name='get_object', return_value=test_object)
+ wapi.create_object = Mock(name='create_object')
+ wapi.update_object = Mock(name='update_object')
+ wapi.delete_object = Mock(name='delete_object')
+ return wapi
+
+ def test_wapi_no_change(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'default',
+ 'comment': 'test comment', 'extattrs': None}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "networkview/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "name": 'default',
+ "extattrs": {}
+ }
+ ]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertFalse(res['changed'])
+
+ def test_wapi_change(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'default',
+ 'comment': 'updated comment', 'extattrs': None}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "networkview/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "name": "default",
+ "extattrs": {}
+ }
+ ]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.update_object.called_once_with(test_object)
+
+ def test_wapi_change_false(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'default',
+ 'comment': 'updated comment', 'extattrs': None, 'fqdn': 'foo'}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "networkview/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "name": "default",
+ "extattrs": {}
+ }
+ ]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "fqdn": {"ib_req": True, 'update': False},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.update_object.called_once_with(test_object)
+
+ def test_wapi_extattrs_change(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'default',
+ 'comment': 'test comment', 'extattrs': {'Site': 'update'}}
+
+ ref = "networkview/ZG5zLm5ldHdvcmtfdmlldyQw:default/true"
+
+ test_object = [{
+ "comment": "test comment",
+ "_ref": ref,
+ "name": "default",
+ "extattrs": {'Site': {'value': 'test'}}
+ }]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ kwargs = copy.deepcopy(test_object[0])
+ kwargs['extattrs']['Site']['value'] = 'update'
+ kwargs['name'] = 'default'
+ del kwargs['_ref']
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.update_object.assert_called_once_with(ref, kwargs)
+
+ def test_wapi_extattrs_nochange(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'default',
+ 'comment': 'test comment', 'extattrs': {'Site': 'test'}}
+
+ test_object = [{
+ "comment": "test comment",
+ "_ref": "networkview/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "name": "default",
+ "extattrs": {'Site': {'value': 'test'}}
+ }]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertFalse(res['changed'])
+
+ def test_wapi_create(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'ansible',
+ 'comment': None, 'extattrs': None}
+
+ test_object = None
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'name': 'ansible'})
+
+ def test_wapi_delete(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'name': 'ansible',
+ 'comment': None, 'extattrs': None}
+
+ ref = "networkview/ZG5zLm5ldHdvcmtfdmlldyQw:ansible/false"
+
+ test_object = [{
+ "comment": "test comment",
+ "_ref": ref,
+ "name": "ansible",
+ "extattrs": {'Site': {'value': 'test'}}
+ }]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
+
+ def test_wapi_strip_network_view(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'ansible',
+ 'comment': 'updated comment', 'extattrs': None,
+ 'network_view': 'default'}
+
+ test_object = [{
+ "comment": "test comment",
+ "_ref": "view/ZG5zLm5ldHdvcmtfdmlldyQw:ansible/true",
+ "name": "ansible",
+ "extattrs": {},
+ "network_view": "default"
+ }]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "network_view": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ kwargs = test_object[0].copy()
+ ref = kwargs.pop('_ref')
+ kwargs['comment'] = 'updated comment'
+ kwargs['name'] = 'ansible'
+ del kwargs['network_view']
+ del kwargs['extattrs']
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.update_object.assert_called_once_with(ref, kwargs)
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/__init__.py b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/__init__.py
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/fixtures/nios_result.txt b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/fixtures/nios_result.txt
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/fixtures/nios_result.txt
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_a_record.py b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_a_record.py
new file mode 100644
index 00000000..b8722011
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_a_record.py
@@ -0,0 +1,163 @@
+# 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/>.
+
+# Make coding more python3-ish
+
+
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+
+from ansible_collections.infoblox.nios_modules.plugins.modules import nios_a_record
+from ansible_collections.infoblox.nios_modules.plugins.module_utils import api
+from ansible_collections.infoblox.nios_modules.tests.unit.compat.mock import patch, MagicMock, Mock
+from ansible.module_utils.common.validation import check_type_dict
+from .test_nios_module import TestNiosModule, load_fixture
+
+
+class TestNiosARecordModule(TestNiosModule):
+
+ module = nios_a_record
+
+ def setUp(self):
+ super(TestNiosARecordModule, self).setUp()
+ self.module = MagicMock(name='ansible_collections.infoblox.nios_modules.plugins.modules.nios_a_record.WapiModule')
+ self.module.check_mode = False
+ self.module.params = {'provider': None}
+ self.mock_wapi = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_a_record.WapiModule')
+ self.exec_command = self.mock_wapi.start()
+ self.mock_wapi_run = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_a_record.WapiModule.run')
+ self.mock_wapi_run.start()
+ self.load_config = self.mock_wapi_run.start()
+ self.mock_check_type_dict = patch('ansible.module_utils.common.validation.check_type_dict')
+ self.mock_check_type_dict_obj = self.mock_check_type_dict.start()
+
+ def tearDown(self):
+ super(TestNiosARecordModule, self).tearDown()
+ self.mock_wapi.stop()
+ self.mock_wapi_run.stop()
+ self.mock_check_type_dict.stop()
+
+ def _get_wapi(self, test_object):
+ wapi = api.WapiModule(self.module)
+ wapi.get_object = Mock(name='get_object', return_value=test_object)
+ wapi.create_object = Mock(name='create_object')
+ wapi.update_object = Mock(name='update_object')
+ wapi.delete_object = Mock(name='delete_object')
+ return wapi
+
+ def load_fixtures(self, commands=None):
+ self.exec_command.return_value = (0, load_fixture('nios_result.txt').strip(), None)
+ self.load_config.return_value = dict(diff=None, session='session')
+
+ def test_nios_a_record_create(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'a.ansible.com',
+ 'ipv4': '192.168.10.1', 'comment': None, 'extattrs': None}
+
+ test_object = None
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "ipv4": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ print("WAPI: ", wapi.__dict__)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'name': 'a.ansible.com',
+ 'ipv4': '192.168.10.1'})
+
+ def test_nios_a_record_update_comment(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'a.ansible.com', 'ipv4': '192.168.10.1',
+ 'comment': 'updated comment', 'extattrs': None}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "arecord/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "name": "a.ansible.com",
+ "ipv4": "192.168.10.1",
+ "extattrs": {}
+ }
+ ]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "ipv4": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+
+ def test_nios_a_record_remove(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'name': 'a.ansible.com', 'ipv4': '192.168.10.1',
+ 'comment': None, 'extattrs': None}
+
+ ref = "arecord/ZG5zLm5ldHdvcmtfdmlldyQw:default/false"
+
+ test_object = [{
+ "comment": "test comment",
+ "_ref": ref,
+ "name": "a.ansible.com",
+ "ipv4": "192.168.10.1",
+ "extattrs": {'Site': {'value': 'test'}}
+ }]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "ipv4": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
+
+ def test_nios_a_record_update_record_name(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': {'new_name': 'a_new.ansible.com', 'old_name': 'a.ansible.com'},
+ 'comment': 'comment', 'extattrs': None}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "arecord/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "name": "a_new.ansible.com",
+ "old_name": "a.ansible.com",
+ "extattrs": {}
+ }
+ ]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.update_object.called_once_with(test_object)
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_aaaa_record.py b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_aaaa_record.py
new file mode 100644
index 00000000..9bfa1c5f
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_aaaa_record.py
@@ -0,0 +1,163 @@
+# 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/>.
+
+# Make coding more python3-ish
+
+
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+
+from ansible_collections.infoblox.nios_modules.plugins.modules import nios_aaaa_record
+from ansible_collections.infoblox.nios_modules.plugins.module_utils import api
+from ansible_collections.infoblox.nios_modules.tests.unit.compat.mock import patch, MagicMock, Mock
+from ansible.module_utils.common.validation import check_type_dict
+from .test_nios_module import TestNiosModule, load_fixture
+
+
+class TestNiosAAAARecordModule(TestNiosModule):
+
+ module = nios_aaaa_record
+
+ def setUp(self):
+ super(TestNiosAAAARecordModule, self).setUp()
+ self.module = MagicMock(name='ansible_collections.infoblox.nios_modules.plugins.modules.nios_aaaa_record.WapiModule')
+ self.module.check_mode = False
+ self.module.params = {'provider': None}
+ self.mock_wapi = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_aaaa_record.WapiModule')
+ self.exec_command = self.mock_wapi.start()
+ self.mock_wapi_run = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_aaaa_record.WapiModule.run')
+ self.mock_wapi_run.start()
+ self.load_config = self.mock_wapi_run.start()
+ self.mock_check_type_dict = patch('ansible.module_utils.common.validation.check_type_dict')
+ self.mock_check_type_dict_obj = self.mock_check_type_dict.start()
+
+ def tearDown(self):
+ super(TestNiosAAAARecordModule, self).tearDown()
+ self.mock_wapi.stop()
+ self.mock_wapi_run.stop()
+ self.mock_check_type_dict.stop()
+
+ def _get_wapi(self, test_object):
+ wapi = api.WapiModule(self.module)
+ wapi.get_object = Mock(name='get_object', return_value=test_object)
+ wapi.create_object = Mock(name='create_object')
+ wapi.update_object = Mock(name='update_object')
+ wapi.delete_object = Mock(name='delete_object')
+ return wapi
+
+ def load_fixtures(self, commands=None):
+ self.exec_command.return_value = (0, load_fixture('nios_result.txt').strip(), None)
+ self.load_config.return_value = dict(diff=None, session='session')
+
+ def test_nios_aaaa_record_create(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'aaaa.ansible.com',
+ 'ipv6': '2001:0db8:85a3:0000:0000:8a2e:0370:7334', 'comment': None, 'extattrs': None}
+
+ test_object = None
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "ipv6": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ print("WAPI: ", wapi.__dict__)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'name': 'aaaa.ansible.com',
+ 'ipv6': '2001:0db8:85a3:0000:0000:8a2e:0370:7334'})
+
+ def test_nios_aaaa_record_update_comment(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'aaaa.ansible.com',
+ 'ipv6': '2001:0db8:85a3:0000:0000:8a2e:0370:7334', 'comment': 'updated comment', 'extattrs': None}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "aaaarecord/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "name": "aaaa.ansible.com",
+ "ipv6": "2001:0db8:85a3:0000:0000:8a2e:0370:7334",
+ "extattrs": {}
+ }
+ ]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "ipv6": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+
+ def test_nios_aaaa_record_remove(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'name': 'aaaa.ansible.com',
+ 'ipv6': '2001:0db8:85a3:0000:0000:8a2e:0370:7334', 'comment': None, 'extattrs': None}
+
+ ref = "aaaarecord/ZG5zLm5ldHdvcmtfdmlldyQw:default/false"
+
+ test_object = [{
+ "comment": "test comment",
+ "_ref": ref,
+ "name": "aaaa.ansible.com",
+ "ipv6": "2001:0db8:85a3:0000:0000:8a2e:0370:7334",
+ "extattrs": {'Site': {'value': 'test'}}
+ }]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "ipv6": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
+
+ def test_nios_aaaa_record_update_record_name(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': {'new_name': 'aaaa_new.ansible.com', 'old_name': 'aaaa.ansible.com'},
+ 'comment': 'comment', 'extattrs': None}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "aaaarecord/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "name": "aaaa_new.ansible.com",
+ "old_name": "aaaa.ansible.com",
+ "extattrs": {}
+ }
+ ]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.update_object.called_once_with(test_object)
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_cname_record.py b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_cname_record.py
new file mode 100644
index 00000000..3df06300
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_cname_record.py
@@ -0,0 +1,137 @@
+# 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/>.
+
+# Make coding more python3-ish
+
+
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+
+from ansible_collections.infoblox.nios_modules.plugins.modules import nios_cname_record
+from ansible_collections.infoblox.nios_modules.plugins.module_utils import api
+from ansible_collections.infoblox.nios_modules.tests.unit.compat.mock import patch, MagicMock, Mock
+from ansible.module_utils.common.validation import check_type_dict
+from .test_nios_module import TestNiosModule, load_fixture
+
+
+class TestNiosCNameRecordModule(TestNiosModule):
+
+ module = nios_cname_record
+
+ def setUp(self):
+ super(TestNiosCNameRecordModule, self).setUp()
+ self.module = MagicMock(name='ansible_collections.infoblox.nios_modules.plugins.modules.nios_cname_record.WapiModule')
+ self.module.check_mode = False
+ self.module.params = {'provider': None}
+ self.mock_wapi = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_cname_record.WapiModule')
+ self.exec_command = self.mock_wapi.start()
+ self.mock_wapi_run = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_cname_record.WapiModule.run')
+ self.mock_wapi_run.start()
+ self.load_config = self.mock_wapi_run.start()
+ self.mock_check_type_dict = patch('ansible.module_utils.common.validation.check_type_dict')
+ self.mock_check_type_dict_obj = self.mock_check_type_dict.start()
+
+ def tearDown(self):
+ super(TestNiosCNameRecordModule, self).tearDown()
+ self.mock_wapi.stop()
+ self.mock_wapi_run.stop()
+ self.mock_check_type_dict.stop()
+
+ def _get_wapi(self, test_object):
+ wapi = api.WapiModule(self.module)
+ wapi.get_object = Mock(name='get_object', return_value=test_object)
+ wapi.create_object = Mock(name='create_object')
+ wapi.update_object = Mock(name='update_object')
+ wapi.delete_object = Mock(name='delete_object')
+ return wapi
+
+ def load_fixtures(self, commands=None):
+ self.exec_command.return_value = (0, load_fixture('nios_result.txt').strip(), None)
+ self.load_config.return_value = dict(diff=None, session='session')
+
+ def test_nios_cname_record_create(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'cname.ansible.com',
+ 'canonical': 'realhost.ansible.com', 'comment': None, 'extattrs': None}
+
+ test_object = None
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "canonical": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ print("WAPI: ", wapi.__dict__)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'name': 'cname.ansible.com',
+ 'canonical': 'realhost.ansible.com'})
+
+ def test_nios_cname_record_update_comment(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'cname.ansible.com',
+ 'canonical': 'realhost.ansible.com', 'comment': 'updated comment', 'extattrs': None}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "cnamerecord/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "name": "cname.ansible.com",
+ "canonical": "realhost.ansible.com",
+ "extattrs": {}
+ }
+ ]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "canonical": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+
+ def test_nios_cname_record_remove(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'name': 'cname.ansible.com',
+ 'canonical': 'realhost.ansible.com', 'comment': None, 'extattrs': None}
+
+ ref = "cnamerecord/ZG5zLm5ldHdvcmtfdmlldyQw:default/false"
+
+ test_object = [{
+ "comment": "test comment",
+ "_ref": ref,
+ "name": "cname.ansible.com",
+ "canonical": "realhost.ansible.com",
+ "extattrs": {'Site': {'value': 'test'}}
+ }]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "canonical": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_dns_view.py b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_dns_view.py
new file mode 100644
index 00000000..a59f50f5
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_dns_view.py
@@ -0,0 +1,131 @@
+# 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/>.
+
+# Make coding more python3-ish
+
+
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+
+from ansible_collections.infoblox.nios_modules.plugins.modules import nios_dns_view
+from ansible_collections.infoblox.nios_modules.plugins.module_utils import api
+from ansible_collections.infoblox.nios_modules.tests.unit.compat.mock import patch, MagicMock, Mock
+from ansible.module_utils.common.validation import check_type_dict
+from .test_nios_module import TestNiosModule, load_fixture
+
+
+class TestNiosDnsViewModule(TestNiosModule):
+
+ module = nios_dns_view
+
+ def setUp(self):
+ super(TestNiosDnsViewModule, self).setUp()
+ self.module = MagicMock(name='ansible_collections.infoblox.nios_modules.plugins.modules.nios_dns_view.WapiModule')
+ self.module.check_mode = False
+ self.module.params = {'provider': None}
+ self.mock_wapi = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_dns_view.WapiModule')
+ self.exec_command = self.mock_wapi.start()
+ self.mock_wapi_run = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_dns_view.WapiModule.run')
+ self.mock_wapi_run.start()
+ self.load_config = self.mock_wapi_run.start()
+ self.mock_check_type_dict = patch('ansible.module_utils.common.validation.check_type_dict')
+ self.mock_check_type_dict_obj = self.mock_check_type_dict.start()
+
+ def tearDown(self):
+ super(TestNiosDnsViewModule, self).tearDown()
+ self.mock_wapi.stop()
+ self.mock_wapi_run.stop()
+ self.mock_check_type_dict.stop()
+
+ def _get_wapi(self, test_object):
+ wapi = api.WapiModule(self.module)
+ wapi.get_object = Mock(name='get_object', return_value=test_object)
+ wapi.create_object = Mock(name='create_object')
+ wapi.update_object = Mock(name='update_object')
+ wapi.delete_object = Mock(name='delete_object')
+ return wapi
+
+ def load_fixtures(self, commands=None):
+ self.exec_command.return_value = (0, load_fixture('nios_result.txt').strip(), None)
+ self.load_config.return_value = dict(diff=None, session='session')
+
+ def test_nios_dns_view_create(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'ansible-dns',
+ 'comment': None, 'extattrs': None}
+
+ test_object = None
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ print("WAPI: ", wapi)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'name': 'ansible-dns'})
+
+ def test_nios_dns_view_update_comment(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'ansible-dns',
+ 'comment': 'updated comment', 'extattrs': None}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "dnsview/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "name": "ansible-dns",
+ "extattrs": {}
+ }
+ ]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+
+ def test_nios_dns_view_remove(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'name': 'ansible-dns',
+ 'comment': None, 'extattrs': None}
+
+ ref = "dnsview/ZG5zLm5ldHdvcmtfdmlldyQw:ansible/false"
+
+ test_object = [{
+ "comment": "test comment",
+ "_ref": ref,
+ "name": "ansible-dns",
+ "extattrs": {'Site': {'value': 'test'}}
+ }]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_fixed_address.py b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_fixed_address.py
new file mode 100644
index 00000000..ae373fd3
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_fixed_address.py
@@ -0,0 +1,201 @@
+# 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/>.
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+
+from ansible_collections.infoblox.nios_modules.plugins.modules import nios_fixed_address
+from ansible_collections.infoblox.nios_modules.plugins.module_utils import api
+from ansible_collections.infoblox.nios_modules.tests.unit.compat.mock import patch, MagicMock, Mock
+from .test_nios_module import TestNiosModule, load_fixture
+
+
+class TestNiosFixedAddressModule(TestNiosModule):
+
+ module = nios_fixed_address
+
+ def setUp(self):
+ super(TestNiosFixedAddressModule, self).setUp()
+ self.module = MagicMock(name='ansible_collections.infoblox.nios_modules.plugins.modules.nios_fixed_address.WapiModule')
+ self.module.check_mode = False
+ self.module.params = {'provider': None}
+ self.mock_wapi = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_fixed_address.WapiModule')
+ self.exec_command = self.mock_wapi.start()
+ self.mock_wapi_run = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_fixed_address.WapiModule.run')
+ self.mock_wapi_run.start()
+ self.load_config = self.mock_wapi_run.start()
+
+ def tearDown(self):
+ super(TestNiosFixedAddressModule, self).tearDown()
+ self.mock_wapi.stop()
+ self.mock_wapi_run.stop()
+
+ def load_fixtures(self, commands=None):
+ self.exec_command.return_value = (0, load_fixture('nios_result.txt').strip(), None)
+ self.load_config.return_value = dict(diff=None, session='session')
+
+ def _get_wapi(self, test_object):
+ wapi = api.WapiModule(self.module)
+ wapi.get_object = Mock(name='get_object', return_value=test_object)
+ wapi.create_object = Mock(name='create_object')
+ wapi.update_object = Mock(name='update_object')
+ wapi.delete_object = Mock(name='delete_object')
+ return wapi
+
+ def test_nios_fixed_address_ipv4_create(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'test_fa', 'ipaddr': '192.168.10.1', 'mac': '08:6d:41:e8:fd:e8',
+ 'network': '192.168.10.0/24', 'network_view': 'default', 'comment': None, 'extattrs': None}
+
+ test_object = None
+ test_spec = {
+ "name": {},
+ "ipaddr": {"ib_req": True},
+ "mac": {"ib_req": True},
+ "network": {"ib_req": True},
+ "network_view": {},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'name': 'test_fa', 'ipaddr': '192.168.10.1', 'mac': '08:6d:41:e8:fd:e8',
+ 'network': '192.168.10.0/24', 'network_view': 'default'})
+
+ def test_nios_fixed_address_ipv4_dhcp_update(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'test_fa', 'ipaddr': '192.168.10.1', 'mac': '08:6d:41:e8:fd:e8',
+ 'network': '192.168.10.0/24', 'network_view': 'default', 'comment': 'updated comment', 'extattrs': None}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "name": "test_fa",
+ "_ref": "network/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "ipaddr": "192.168.10.1",
+ "mac": "08:6d:41:e8:fd:e8",
+ "network": "192.168.10.0/24",
+ "network_view": "default",
+ "extattrs": {'options': {'name': 'test', 'value': 'ansible.com'}}
+ }
+ ]
+
+ test_spec = {
+ "name": {},
+ "ipaddr": {"ib_req": True},
+ "mac": {"ib_req": True},
+ "network": {"ib_req": True},
+ "network_view": {},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+
+ def test_nios_fixed_address_ipv4_remove(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'name': 'test_fa', 'ipaddr': '192.168.10.1', 'mac': '08:6d:41:e8:fd:e8',
+ 'network': '192.168.10.0/24', 'network_view': 'default', 'comment': None, 'extattrs': None}
+
+ ref = "fixedaddress/ZG5zLm5ldHdvcmtfdmlldyQw:ansible/false"
+
+ test_object = [{
+ "comment": "test comment",
+ "name": "test_fa",
+ "_ref": ref,
+ "ipaddr": "192.168.10.1",
+ "mac": "08:6d:41:e8:fd:e8",
+ "network": "192.168.10.0/24",
+ "network_view": "default",
+ "extattrs": {'Site': {'value': 'test'}}
+ }]
+
+ test_spec = {
+ "name": {},
+ "ipaddr": {"ib_req": True},
+ "mac": {"ib_req": True},
+ "network": {"ib_req": True},
+ "network_view": {},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
+
+ def test_nios_fixed_address_ipv6_create(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'test_fa', 'ipaddr': 'fe80::1/10', 'mac': '08:6d:41:e8:fd:e8',
+ 'network': 'fe80::/64', 'network_view': 'default', 'comment': None, 'extattrs': None}
+
+ test_object = None
+
+ test_spec = {
+ "name": {},
+ "ipaddr": {"ib_req": True},
+ "mac": {"ib_req": True},
+ "network": {"ib_req": True},
+ "network_view": {},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ print("WAPI: ", wapi)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'name': 'test_fa', 'ipaddr': 'fe80::1/10', 'mac': '08:6d:41:e8:fd:e8',
+ 'network': 'fe80::/64', 'network_view': 'default'})
+
+ def test_nios_fixed_address_ipv6_remove(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'name': 'test_fa', 'ipaddr': 'fe80::1/10', 'mac': '08:6d:41:e8:fd:e8',
+ 'network': 'fe80::/64', 'network_view': 'default', 'comment': None, 'extattrs': None}
+
+ ref = "ipv6fixedaddress/ZG5zLm5ldHdvcmtfdmlldyQw:ansible/false"
+
+ test_object = [{
+ "comment": "test comment",
+ "name": "test_fa",
+ "_ref": ref,
+ "ipaddr": "fe80::1/10",
+ "mac": "08:6d:41:e8:fd:e8",
+ "network": "fe80::/64",
+ "network_view": "default",
+ "extattrs": {'Site': {'value': 'test'}}
+ }]
+
+ test_spec = {
+ "name": {},
+ "ipaddr": {"ib_req": True},
+ "mac": {"ib_req": True},
+ "network": {"ib_req": True},
+ "network_view": {},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_host_record.py b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_host_record.py
new file mode 100644
index 00000000..11489960
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_host_record.py
@@ -0,0 +1,156 @@
+# 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/>.
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+
+from ansible_collections.infoblox.nios_modules.plugins.modules import nios_host_record
+from ansible_collections.infoblox.nios_modules.plugins.module_utils import api
+from ansible_collections.infoblox.nios_modules.tests.unit.compat.mock import patch, MagicMock, Mock
+from ansible.module_utils.common.validation import check_type_dict
+from .test_nios_module import TestNiosModule, load_fixture
+
+
+class TestNiosHostRecordModule(TestNiosModule):
+
+ module = nios_host_record
+
+ def setUp(self):
+
+ super(TestNiosHostRecordModule, self).setUp()
+ self.module = MagicMock(name='ansible_collections.infoblox.nios_modules.plugins.modules.nios_host_record.WapiModule')
+ self.module.check_mode = False
+ self.module.params = {'provider': None}
+
+ self.mock_wapi = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_host_record.WapiModule')
+ self.exec_command = self.mock_wapi.start()
+ self.mock_wapi_run = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_host_record.WapiModule.run')
+ self.mock_wapi_run.start()
+
+ self.load_config = self.mock_wapi_run.start()
+ self.mock_check_type_dict = patch('ansible.module_utils.common.validation.check_type_dict')
+ self.mock_check_type_dict_obj = self.mock_check_type_dict.start()
+
+ def tearDown(self):
+ super(TestNiosHostRecordModule, self).tearDown()
+ self.mock_wapi.stop()
+ self.mock_check_type_dict.stop()
+
+ def _get_wapi(self, test_object):
+ wapi = api.WapiModule(self.module)
+ wapi.get_object = Mock(name='get_object', return_value=test_object)
+ wapi.create_object = Mock(name='create_object')
+ wapi.update_object = Mock(name='update_object')
+ wapi.delete_object = Mock(name='delete_object')
+ return wapi
+
+ def load_fixtures(self, commands=None):
+ self.exec_command.return_value = (0, load_fixture('nios_result.txt').strip(), None)
+ self.load_config.return_value = dict(diff=None, session='session')
+
+ def test_nios_host_record_create(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'ansible',
+ 'comment': None, 'extattrs': None}
+
+ test_object = None
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ print("WAPI: ", wapi)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'name': 'ansible'})
+
+ def test_nios_host_record_remove(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'name': 'ansible',
+ 'comment': None, 'extattrs': None}
+
+ ref = "record:host/ZG5zLm5ldHdvcmtfdmlldyQw:ansible/false"
+
+ test_object = [{
+ "comment": "test comment",
+ "_ref": ref,
+ "name": "ansible",
+ "extattrs": {'Site': {'value': 'test'}}
+ }]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
+
+ def test_nios_host_record_update_comment(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'default',
+ 'comment': 'updated comment', 'extattrs': None}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "record:host/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "name": "default",
+ "extattrs": {}
+ }
+ ]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.update_object.called_once_with(test_object)
+
+ def test_nios_host_record_update_record_name(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': {'new_name': 'default', 'old_name': 'old_default'},
+ 'comment': 'comment', 'extattrs': None}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "record:host/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "name": "default",
+ "old_name": "old_default",
+ "extattrs": {}
+ }
+ ]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.update_object.called_once_with(test_object)
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_member.py b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_member.py
new file mode 100644
index 00000000..a65b5df1
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_member.py
@@ -0,0 +1,162 @@
+# 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/>.
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+
+from ansible_collections.infoblox.nios_modules.plugins.modules import nios_member
+from ansible_collections.infoblox.nios_modules.plugins.module_utils import api
+from ansible_collections.infoblox.nios_modules.tests.unit.compat.mock import patch, MagicMock, Mock
+from .test_nios_module import TestNiosModule, load_fixture
+
+
+class TestNiosMemberModule(TestNiosModule):
+
+ module = nios_member
+
+ def setUp(self):
+ super(TestNiosMemberModule, self).setUp()
+ self.module = MagicMock(name='ansible_collections.infoblox.nios_modules.plugins.modules.nios_member.WapiModule')
+ self.module.check_mode = False
+ self.module.params = {'provider': None}
+ self.mock_wapi = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_member.WapiModule')
+ self.exec_command = self.mock_wapi.start()
+ self.mock_wapi_run = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_member.WapiModule.run')
+ self.mock_wapi_run.start()
+ self.load_config = self.mock_wapi_run.start()
+
+ def tearDown(self):
+ super(TestNiosMemberModule, self).tearDown()
+ self.mock_wapi.stop()
+ self.mock_wapi_run.stop()
+
+ def load_fixtures(self, commands=None):
+ self.exec_command.return_value = (0, load_fixture('nios_result.txt').strip(), None)
+ self.load_config.return_value = dict(diff=None, session='session')
+
+ def _get_wapi(self, test_object):
+ wapi = api.WapiModule(self.module)
+ wapi.get_object = Mock(name='get_object', return_value=test_object)
+ wapi.create_object = Mock(name='create_object')
+ wapi.update_object = Mock(name='update_object')
+ wapi.delete_object = Mock(name='delete_object')
+ return wapi
+
+ def test_nios_member_create(self):
+ self.module.params = {'provider': None, 'state': 'present', 'host_name': 'test_member',
+ 'vip_setting': {'address': '192.168.1.110', 'subnet_mask': '255.255.255.0', 'gateway': '192.168.1.1'},
+ 'config_addr_type': 'IPV4', 'platform': 'VNIOS', 'comment': None, 'extattrs': None}
+
+ test_object = None
+ test_spec = {
+ "host_name": {"ib_req": True},
+ "vip_setting": {},
+ "config_addr_type": {},
+ "platform": {},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'host_name': 'test_member',
+ 'vip_setting': {'address': '192.168.1.110', 'subnet_mask': '255.255.255.0',
+ 'gateway': '192.168.1.1'},
+ 'config_addr_type': 'IPV4', 'platform': 'VNIOS'})
+
+ def test_nios_member_update(self):
+ self.module.params = {'provider': None, 'state': 'present', 'host_name': 'test_member',
+ 'vip_setting': {'address': '192.168.1.110', 'subnet_mask': '255.255.255.0', 'gateway': '192.168.1.1'},
+ 'config_addr_type': 'IPV4', 'platform': 'VNIOS', 'comment': 'updated comment', 'extattrs': None}
+
+ test_object = [
+ {
+ "comment": "Created with Ansible",
+ "_ref": "member/b25lLnZpcnR1YWxfbm9kZSQ3:member01.ansible-dev.com",
+ "config_addr_type": "IPV4",
+ "host_name": "member01.ansible-dev.com",
+ "platform": "VNIOS",
+ "service_type_configuration": "ALL_V4",
+ "vip_setting":
+ {
+ "address": "192.168.1.100",
+ "dscp": 0,
+ "gateway": "192.168.1.1",
+ "primary": True,
+ "subnet_mask": "255.255.255.0",
+ "use_dscp": False
+ }
+ }
+ ]
+
+ test_spec = {
+ "host_name": {"ib_req": True},
+ "vip_setting": {},
+ "config_addr_type": {},
+ "platform": {},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+
+ def test_nios_member_remove(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'host_name': 'test_member',
+ 'vip_setting': {'address': '192.168.1.110', 'subnet_mask': '255.255.255.0', 'gateway': '192.168.1.1'},
+ 'config_addr_type': 'IPV4', 'platform': 'VNIOS', 'comment': 'updated comment', 'extattrs': None}
+
+ ref = "member/b25lLnZpcnR1YWxfbm9kZSQ3:member01.ansible-dev.com"
+
+ test_object = [
+ {
+ "comment": "Created with Ansible",
+ "_ref": "member/b25lLnZpcnR1YWxfbm9kZSQ3:member01.ansible-dev.com",
+ "config_addr_type": "IPV4",
+ "host_name": "member01.ansible-dev.com",
+ "platform": "VNIOS",
+ "service_type_configuration": "ALL_V4",
+ "vip_setting":
+ {
+ "address": "192.168.1.100",
+ "dscp": 0,
+ "gateway": "192.168.1.1",
+ "primary": True,
+ "subnet_mask": "255.255.255.0",
+ "use_dscp": False
+ }
+ }
+ ]
+
+ test_spec = {
+ "host_name": {"ib_req": True},
+ "vip_setting": {},
+ "config_addr_type": {},
+ "platform": {},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_module.py b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_module.py
new file mode 100644
index 00000000..6ffaa1f7
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_module.py
@@ -0,0 +1,88 @@
+# (c) 2018 Red Hat Inc.
+#
+# 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/>.
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+import os
+import json
+
+from ansible_collections.infoblox.nios_modules.tests.unit.plugins.modules.utils import AnsibleExitJson, AnsibleFailJson, ModuleTestCase
+
+
+fixture_path = os.path.join(os.path.dirname(__file__), 'fixtures')
+fixture_data = {}
+
+
+def load_fixture(name):
+ path = os.path.join(fixture_path, name)
+
+ if path in fixture_data:
+ return fixture_data[path]
+
+ with open(path) as f:
+ data = f.read()
+
+ try:
+ data = json.loads(data)
+ except Exception:
+ pass
+
+ fixture_data[path] = data
+ return data
+
+
+class TestNiosModule(ModuleTestCase):
+
+ def execute_module(self, failed=False, changed=False, commands=None, sort=True, defaults=False):
+
+ self.load_fixtures(commands)
+
+ if failed:
+ result = self.failed()
+ self.assertTrue(result['failed'], result)
+ else:
+ result = self.changed(changed)
+ self.assertEqual(result['changed'], changed, result)
+
+ if commands is not None:
+ if sort:
+ self.assertEqual(sorted(commands), sorted(result['commands']), result['commands'])
+ else:
+ self.assertEqual(commands, result['commands'], result['commands'])
+
+ return result
+
+ def failed(self):
+ with self.assertRaises(AnsibleFailJson) as exc:
+ self.module.main()
+
+ result = exc.exception.args[0]
+ self.assertTrue(result['failed'], result)
+ return result
+
+ def changed(self, changed=False):
+ with self.assertRaises(AnsibleExitJson) as exc:
+ self.module.main()
+
+ result = exc.exception.args[0]
+ self.assertEqual(result['changed'], changed, result)
+ return result
+
+ def load_fixtures(self, commands=None):
+ pass
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_mx_record.py b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_mx_record.py
new file mode 100644
index 00000000..e28cd0e1
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_mx_record.py
@@ -0,0 +1,141 @@
+# 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/>.
+
+# Make coding more python3-ish
+
+
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+
+from ansible_collections.infoblox.nios_modules.plugins.modules import nios_mx_record
+from ansible_collections.infoblox.nios_modules.plugins.module_utils import api
+from ansible_collections.infoblox.nios_modules.tests.unit.compat.mock import patch, MagicMock, Mock
+from ansible.module_utils.common.validation import check_type_dict
+from .test_nios_module import TestNiosModule, load_fixture
+
+
+class TestNiosMXRecordModule(TestNiosModule):
+
+ module = nios_mx_record
+
+ def setUp(self):
+ super(TestNiosMXRecordModule, self).setUp()
+ self.module = MagicMock(name='ansible_collections.infoblox.nios_modules.plugins.modules.nios_mx_record.WapiModule')
+ self.module.check_mode = False
+ self.module.params = {'provider': None}
+ self.mock_wapi = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_mx_record.WapiModule')
+ self.exec_command = self.mock_wapi.start()
+ self.mock_wapi_run = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_mx_record.WapiModule.run')
+ self.mock_wapi_run.start()
+ self.load_config = self.mock_wapi_run.start()
+ self.mock_check_type_dict = patch('ansible.module_utils.common.validation.check_type_dict')
+ self.mock_check_type_dict_obj = self.mock_check_type_dict.start()
+
+ def tearDown(self):
+ super(TestNiosMXRecordModule, self).tearDown()
+ self.mock_wapi.stop()
+ self.mock_wapi_run.stop()
+ self.mock_check_type_dict.stop()
+
+ def _get_wapi(self, test_object):
+ wapi = api.WapiModule(self.module)
+ wapi.get_object = Mock(name='get_object', return_value=test_object)
+ wapi.create_object = Mock(name='create_object')
+ wapi.update_object = Mock(name='update_object')
+ wapi.delete_object = Mock(name='delete_object')
+ return wapi
+
+ def load_fixtures(self, commands=None):
+ self.exec_command.return_value = (0, load_fixture('nios_result.txt').strip(), None)
+ self.load_config.return_value = dict(diff=None, session='session')
+
+ def test_nios_mx_record_create(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'ansible.com',
+ 'mx': 'mailhost.ansible.com', 'preference': 0, 'comment': None, 'extattrs': None}
+
+ test_object = None
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "mx": {"ib_req": True},
+ "preference": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ print("WAPI: ", wapi)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'name': 'ansible.com',
+ 'mx': 'mailhost.ansible.com', 'preference': 0})
+
+ def test_nios_mx_record_update_comment(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'ansible.com', 'mx': 'mailhost.ansible.com',
+ 'preference': 0, 'comment': 'updated comment', 'extattrs': None}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "mxrecord/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "name": "ansible.com",
+ "mx": "mailhost.ansible.com",
+ "preference": 0,
+ "extattrs": {}
+ }
+ ]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "mx": {"ib_req": True},
+ "preference": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+
+ def test_nios_mx_record_remove(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'name': 'ansible.com', 'mx': 'mailhost.ansible.com',
+ 'preference': 0, 'comment': None, 'extattrs': None}
+
+ ref = "mxrecord/ZG5zLm5ldHdvcmtfdmlldyQw:default/false"
+
+ test_object = [{
+ "comment": "test comment",
+ "_ref": ref,
+ "name": "ansible.com",
+ "mx": "mailhost.ansible.com",
+ "extattrs": {'Site': {'value': 'test'}}
+ }]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "mx": {"ib_req": True},
+ "preference": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_naptr_record.py b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_naptr_record.py
new file mode 100644
index 00000000..a546a90a
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_naptr_record.py
@@ -0,0 +1,151 @@
+# 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/>.
+
+# Make coding more python3-ish
+
+
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+
+from ansible_collections.infoblox.nios_modules.plugins.modules import nios_naptr_record
+from ansible_collections.infoblox.nios_modules.plugins.module_utils import api
+from ansible_collections.infoblox.nios_modules.tests.unit.compat.mock import patch, MagicMock, Mock
+from ansible.module_utils.common.validation import check_type_dict
+from .test_nios_module import TestNiosModule, load_fixture
+
+
+class TestNiosNAPTRRecordModule(TestNiosModule):
+
+ module = nios_naptr_record
+
+ def setUp(self):
+ super(TestNiosNAPTRRecordModule, self).setUp()
+ self.module = MagicMock(name='ansible_collections.infoblox.nios_modules.plugins.modules.nios_naptr_record.WapiModule')
+ self.module.check_mode = False
+ self.module.params = {'provider': None}
+ self.mock_wapi = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_naptr_record.WapiModule')
+ self.exec_command = self.mock_wapi.start()
+ self.mock_wapi_run = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_naptr_record.WapiModule.run')
+ self.mock_wapi_run.start()
+ self.load_config = self.mock_wapi_run.start()
+ self.mock_check_type_dict = patch('ansible.module_utils.common.validation.check_type_dict')
+ self.mock_check_type_dict_obj = self.mock_check_type_dict.start()
+
+ def tearDown(self):
+ super(TestNiosNAPTRRecordModule, self).tearDown()
+ self.mock_wapi.stop()
+ self.mock_wapi_run.stop()
+ self.mock_check_type_dict.stop()
+
+ def _get_wapi(self, test_object):
+ wapi = api.WapiModule(self.module)
+ wapi.get_object = Mock(name='get_object', return_value=test_object)
+ wapi.create_object = Mock(name='create_object')
+ wapi.update_object = Mock(name='update_object')
+ wapi.delete_object = Mock(name='delete_object')
+ return wapi
+
+ def load_fixtures(self, commands=None):
+ self.exec_command.return_value = (0, load_fixture('nios_result.txt').strip(), None)
+ self.load_config.return_value = dict(diff=None, session='session')
+
+ def test_nios_naptr_record_create(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': '*.subscriber-100.ansiblezone.com',
+ 'order': '1000', 'preference': '10', 'replacement': 'replacement1.network.ansiblezone.com',
+ 'comment': None, 'extattrs': None}
+
+ test_object = None
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "order": {"ib_req": True},
+ "preference": {"ib_req": True},
+ "replacement": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ print("WAPI: ", wapi.__dict__)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'name': '*.subscriber-100.ansiblezone.com',
+ 'order': '1000', 'preference': '10',
+ 'replacement': 'replacement1.network.ansiblezone.com'})
+
+ def test_nios_naptr_record_update_comment(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': '*.subscriber-100.ansiblezone.com',
+ 'order': '1000', 'preference': '10', 'replacement': 'replacement1.network.ansiblezone.com',
+ 'comment': 'updated comment', 'extattrs': None}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "naptrrecord/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "name": "*.subscriber-100.ansiblezone.com",
+ "order": "1000",
+ "preference": "10",
+ "replacement": "replacement1.network.ansiblezone.com",
+ "extattrs": {}
+ }
+ ]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "order": {"ib_req": True},
+ "preference": {"ib_req": True},
+ "replacement": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+
+ def test_nios_naptr_record_remove(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'name': '*.subscriber-100.ansiblezone.com',
+ 'order': '1000', 'preference': '10', 'replacement': 'replacement1.network.ansiblezone.com',
+ 'comment': None, 'extattrs': None}
+
+ ref = "naptrrecord/ZG5zLm5ldHdvcmtfdmlldyQw:default/false"
+
+ test_object = [{
+ "comment": "test comment",
+ "_ref": ref,
+ "name": "*.subscriber-100.ansiblezone.com",
+ "order": "1000",
+ "preference": "10",
+ "replacement": "replacement1.network.ansiblezone.com",
+ "extattrs": {'Site': {'value': 'test'}}
+ }]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "order": {"ib_req": True},
+ "preference": {"ib_req": True},
+ "replacement": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_network.py b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_network.py
new file mode 100644
index 00000000..0fad5aaa
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_network.py
@@ -0,0 +1,248 @@
+# 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/>.
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+
+from ansible_collections.infoblox.nios_modules.plugins.modules import nios_network
+from ansible_collections.infoblox.nios_modules.plugins.module_utils import api
+from ansible_collections.infoblox.nios_modules.tests.unit.compat.mock import patch, MagicMock, Mock
+from .test_nios_module import TestNiosModule, load_fixture
+
+
+class TestNiosNetworkModule(TestNiosModule):
+
+ module = nios_network
+
+ def setUp(self):
+ super(TestNiosNetworkModule, self).setUp()
+ self.module = MagicMock(name='ansible_collections.infoblox.nios_modules.plugins.modules.nios_network.WapiModule')
+ self.module.check_mode = False
+ self.module.params = {'provider': None}
+ self.mock_wapi = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_network.WapiModule')
+ self.exec_command = self.mock_wapi.start()
+ self.mock_wapi_run = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_network.WapiModule.run')
+ self.mock_wapi_run.start()
+ self.load_config = self.mock_wapi_run.start()
+
+ def tearDown(self):
+ super(TestNiosNetworkModule, self).tearDown()
+ self.mock_wapi.stop()
+ self.mock_wapi_run.stop()
+
+ def load_fixtures(self, commands=None):
+ self.exec_command.return_value = (0, load_fixture('nios_result.txt').strip(), None)
+ self.load_config.return_value = dict(diff=None, session='session')
+
+ def _get_wapi(self, test_object):
+ wapi = api.WapiModule(self.module)
+ wapi.get_object = Mock(name='get_object', return_value=test_object)
+ wapi.create_object = Mock(name='create_object')
+ wapi.update_object = Mock(name='update_object')
+ wapi.delete_object = Mock(name='delete_object')
+ return wapi
+
+ def test_nios_network_ipv4_create(self):
+ self.module.params = {'provider': None, 'state': 'present', 'network': '192.168.10.0/24',
+ 'comment': None, 'extattrs': None}
+
+ test_object = None
+ test_spec = {
+ "network": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ print("WAPI: ", wapi)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'network': '192.168.10.0/24'})
+
+ def test_nios_network_ipv4_dhcp_update(self):
+ self.module.params = {'provider': None, 'state': 'present', 'network': '192.168.10.0/24',
+ 'comment': 'updated comment', 'extattrs': None}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "network/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "network": "192.168.10.0/24",
+ "extattrs": {'options': {'name': 'test', 'value': 'ansible.com'}}
+ }
+ ]
+
+ test_spec = {
+ "network": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+
+ def test_nios_network_ipv6_dhcp_update(self):
+ self.module.params = {'provider': None, 'state': 'present', 'ipv6network': 'fe80::/64',
+ 'comment': 'updated comment', 'extattrs': None}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "ipv6network/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "ipv6network": "fe80::/64",
+ "extattrs": {'options': {'name': 'test', 'value': 'ansible.com'}}
+ }
+ ]
+
+ test_spec = {
+ "ipv6network": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+ self.assertTrue(res['changed'])
+
+ def test_nios_network_ipv4_remove(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'network': '192.168.10.0/24',
+ 'comment': None, 'extattrs': None}
+
+ ref = "network/ZG5zLm5ldHdvcmtfdmlldyQw:ansible/false"
+
+ test_object = [{
+ "comment": "test comment",
+ "_ref": ref,
+ "network": "192.168.10.0/24",
+ "extattrs": {'Site': {'value': 'test'}}
+ }]
+
+ test_spec = {
+ "network": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
+
+ def test_nios_network_ipv6_create(self):
+ self.module.params = {'provider': None, 'state': 'present', 'ipv6network': 'fe80::/64',
+ 'comment': None, 'extattrs': None}
+
+ test_object = None
+
+ test_spec = {
+ "ipv6network": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'ipv6network': 'fe80::/64'})
+
+ def test_nios_network_ipv6_remove(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'ipv6network': 'fe80::/64',
+ 'comment': None, 'extattrs': None}
+
+ ref = "ipv6network/ZG5zLm5ldHdvcmtfdmlldyQw:ansible/false"
+
+ test_object = [{
+ "comment": "test comment",
+ "_ref": ref,
+ "ipv6network": "fe80::/64",
+ "extattrs": {'Site': {'value': 'test'}}
+ }]
+
+ test_spec = {
+ "ipv6network": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
+
+ def test_nios_networkcontainer_ipv4_create(self):
+ self.module.params = {'provider': None, 'state': 'present', 'networkcontainer': '192.168.10.0/24',
+ 'comment': None, 'extattrs': None}
+
+ test_object = None
+ test_spec = {
+ "networkcontainer": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'networkcontainer': '192.168.10.0/24'})
+
+ def test_nios_networkcontainer_ipv4_remove(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'networkcontainer': '192.168.10.0/24',
+ 'comment': None, 'extattrs': None}
+
+ ref = "networkcontainer/ZG5zLm5ldHdvcmtfdmlldyQw:ansible/false"
+
+ test_object = [{
+ "comment": "test comment",
+ "_ref": ref,
+ "networkcontainer": "192.168.10.0/24"
+ }]
+
+ test_spec = {
+ "networkcontainer": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
+
+ def test_nios_networkcontainer_ipv6_create(self):
+ self.module.params = {'provider': None, 'state': 'present', 'ipv6networkcontainer': 'fe80::/64',
+ 'comment': None, 'extattrs': None}
+
+ test_object = None
+ test_spec = {
+ "ipv6networkcontainer": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'ipv6networkcontainer': 'fe80::/64'})
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_network_view.py b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_network_view.py
new file mode 100644
index 00000000..4756127c
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_network_view.py
@@ -0,0 +1,160 @@
+# 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/>.
+
+# Make coding more python3-ish
+
+
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+
+from ansible_collections.infoblox.nios_modules.plugins.modules import nios_network_view
+from ansible_collections.infoblox.nios_modules.plugins.module_utils import api
+from ansible_collections.infoblox.nios_modules.tests.unit.compat.mock import patch, MagicMock, Mock
+from ansible.module_utils.common.validation import check_type_dict
+from .test_nios_module import TestNiosModule, load_fixture
+
+
+class TestNiosNetworkViewModule(TestNiosModule):
+
+ module = nios_network_view
+
+ def setUp(self):
+ super(TestNiosNetworkViewModule, self).setUp()
+ self.module = MagicMock(name='ansible_collections.infoblox.nios_modules.plugins.modules.nios_network_view.WapiModule')
+ self.module.check_mode = False
+ self.module.params = {'provider': None}
+ self.mock_wapi = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_network_view.WapiModule')
+ self.exec_command = self.mock_wapi.start()
+ self.mock_wapi_run = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_network_view.WapiModule.run')
+ self.mock_wapi_run.start()
+ self.load_config = self.mock_wapi_run.start()
+ self.mock_check_type_dict = patch('ansible.module_utils.common.validation.check_type_dict')
+ self.mock_check_type_dict_obj = self.mock_check_type_dict.start()
+
+ def tearDown(self):
+ super(TestNiosNetworkViewModule, self).tearDown()
+ self.mock_wapi.stop()
+ self.mock_wapi_run.stop()
+ self.mock_check_type_dict.stop()
+
+ def _get_wapi(self, test_object):
+ wapi = api.WapiModule(self.module)
+ wapi.get_object = Mock(name='get_object', return_value=test_object)
+ wapi.create_object = Mock(name='create_object')
+ wapi.update_object = Mock(name='update_object')
+ wapi.delete_object = Mock(name='delete_object')
+ return wapi
+
+ def load_fixtures(self, commands=None):
+ self.exec_command.return_value = (0, load_fixture('nios_result.txt').strip(), None)
+ self.load_config.return_value = dict(diff=None, session='session')
+
+ def test_nios_network_view_create(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'ansible',
+ 'comment': None, 'extattrs': None}
+
+ test_object = None
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "extattrs": {},
+
+ }
+
+ wapi = self._get_wapi(test_object)
+ print("WAPI: ", wapi)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'name': 'ansible'})
+
+ def test_nios_network_view_update_comment(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'default',
+ 'comment': 'updated comment', 'extattrs': None, 'network_view': 'default'}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "networkview/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "name": "default",
+ "extattrs": {},
+ "network_view": "default"
+ }
+ ]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.update_object.called_once_with(test_object)
+
+ def test_nios_network_view_update_name(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'default', 'old_name': 'old_default',
+ 'comment': 'updated comment', 'extattrs': None, 'network_view': 'default'}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "networkview/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "name": "default",
+ "old_name": "old_default",
+ "extattrs": {},
+ "network_view": "default"
+ }
+ ]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.update_object.called_once_with(test_object)
+
+ def test_nios_network_view_remove(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'name': 'ansible',
+ 'comment': None, 'extattrs': None}
+
+ ref = "networkview/ZG5zLm5ldHdvcmtfdmlldyQw:ansible/false"
+
+ test_object = [{
+ "comment": "test comment",
+ "_ref": ref,
+ "name": "ansible",
+ "extattrs": {'Site': {'value': 'test'}}
+ }]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_nsgroup.py b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_nsgroup.py
new file mode 100644
index 00000000..d8ca9667
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_nsgroup.py
@@ -0,0 +1,130 @@
+# 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/>.
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+
+from ansible_collections.infoblox.nios_modules.plugins.modules import nios_nsgroup
+from ansible_collections.infoblox.nios_modules.plugins.module_utils import api
+from ansible_collections.infoblox.nios_modules.tests.unit.compat.mock import patch, MagicMock, Mock
+from ansible.module_utils.common.validation import check_type_dict
+from .test_nios_module import TestNiosModule, load_fixture
+
+
+class TestNiosNSGroupModule(TestNiosModule):
+
+ module = nios_nsgroup
+
+ def setUp(self):
+
+ super(TestNiosNSGroupModule, self).setUp()
+ self.module = MagicMock(name='ansible_collections.infoblox.nios_modules.plugins.modules.nios_nsgroup.WapiModule')
+ self.module.check_mode = False
+ self.module.params = {'provider': None}
+
+ self.mock_wapi = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_nsgroup.WapiModule')
+ self.exec_command = self.mock_wapi.start()
+ self.mock_wapi_run = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_nsgroup.WapiModule.run')
+ self.mock_wapi_run.start()
+
+ self.load_config = self.mock_wapi_run.start()
+
+ self.mock_check_type_dict = patch('ansible.module_utils.common.validation.check_type_dict')
+ self.mock_check_type_dict_obj = self.mock_check_type_dict.start()
+
+ def tearDown(self):
+ super(TestNiosNSGroupModule, self).tearDown()
+ self.mock_wapi.stop()
+ self.mock_check_type_dict.stop()
+
+ def _get_wapi(self, test_object):
+ wapi = api.WapiModule(self.module)
+ wapi.get_object = Mock(name='get_object', return_value=test_object)
+ wapi.create_object = Mock(name='create_object')
+ wapi.update_object = Mock(name='update_object')
+ wapi.delete_object = Mock(name='delete_object')
+ return wapi
+
+ def load_fixtures(self, commands=None):
+ self.exec_command.return_value = (0, load_fixture('nios_result.txt').strip(), None)
+ self.load_config.return_value = dict(diff=None, session='session')
+
+ def test_nios_nsgroup_create(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'my-simple-group',
+ 'comment': None, 'grid_primary': None}
+
+ test_object = None
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "grid_primary": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'name': 'my-simple-group'})
+
+ def test_nios_nsgroup_remove(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'name': 'my-simple-group',
+ 'comment': None, 'grid_primary': None}
+
+ ref = "nsgroup/ZG5zLm5ldHdvcmtfdmlldyQw:ansible/false"
+
+ test_object = [{
+ "comment": "test comment",
+ "_ref": ref,
+ "name": "my-simple-group",
+ "grid_primary": {'name': 'infoblox-test.example.com'}
+ }]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "grid_primary": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
+
+ def test_nios_nsgroup_update_comment(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': 'default',
+ 'comment': 'updated comment', 'grid_primary': None}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "nsgroup/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "name": "default",
+ "grid_primary": {}
+ }
+ ]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "comment": {},
+ "grid_primary": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.update_object.called_once_with(test_object)
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_ptr_record.py b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_ptr_record.py
new file mode 100644
index 00000000..5ffd6487
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_ptr_record.py
@@ -0,0 +1,184 @@
+# 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/>.
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+
+from ansible_collections.infoblox.nios_modules.plugins.modules import nios_ptr_record
+from ansible_collections.infoblox.nios_modules.plugins.module_utils import api
+from ansible_collections.infoblox.nios_modules.tests.unit.compat.mock import patch, MagicMock, Mock
+from .test_nios_module import TestNiosModule, load_fixture
+
+
+class TestNiosPTRRecordModule(TestNiosModule):
+
+ module = nios_ptr_record
+
+ def setUp(self):
+
+ super(TestNiosPTRRecordModule, self).setUp()
+ self.module = MagicMock(name='ansible_collections.infoblox.nios_modules.plugins.modules.nios_ptr_record.WapiModule')
+ self.module.check_mode = False
+ self.module.params = {'provider': None}
+
+ self.mock_wapi = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_ptr_record.WapiModule')
+ self.exec_command = self.mock_wapi.start()
+ self.mock_wapi_run = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_ptr_record.WapiModule.run')
+ self.mock_wapi_run.start()
+
+ self.load_config = self.mock_wapi_run.start()
+
+ def tearDown(self):
+ super(TestNiosPTRRecordModule, self).tearDown()
+ self.mock_wapi.stop()
+
+ def _get_wapi(self, test_object):
+ wapi = api.WapiModule(self.module)
+ wapi.get_object = Mock(name='get_object', return_value=test_object)
+ wapi.create_object = Mock(name='create_object')
+ wapi.update_object = Mock(name='update_object')
+ wapi.delete_object = Mock(name='delete_object')
+ return wapi
+
+ def load_fixtures(self, commands=None):
+ self.exec_command.return_value = (0, load_fixture('nios_result.txt').strip(), None)
+ self.load_config.return_value = dict(diff=None, session='session')
+
+ def test_nios_ptr_record_create(self):
+ self.module.params = {'provider': None, 'state': 'present', 'ptrdname': 'ansible.test.com',
+ 'ipv4addr': '10.36.241.14', 'comment': None, 'extattrs': None, 'view': 'default'}
+
+ test_object = None
+ test_spec = {
+ "ipv4addr": {"ib_req": True},
+ "ptrdname": {"ib_req": True},
+ "comment": {},
+ "extattrs": {},
+ "view": {"ib_req": True}
+ }
+
+ wapi = self._get_wapi(test_object)
+ print("WAPI: ", wapi)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'ipv4addr': '10.36.241.14', 'ptrdname': 'ansible.test.com', 'view': 'default'})
+
+ def test_nios_ptr_record_remove(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'ptrdname': 'ansible.test.com',
+ 'ipv4addr': '10.36.241.14', 'comment': None, 'extattrs': None, 'view': 'default'}
+
+ ref = "record:ptr/ZG5zLm5ldHdvcmtfdmlldyQw:14.241.36.10.in-addr.arpa/default"
+
+ test_object = [{
+ "comment": "test comment",
+ "_ref": ref,
+ "ptrdname": "ansible.test.com",
+ "ipv4addr": "10.36.241.14",
+ "view": "default",
+ "extattrs": {'Site': {'value': 'test'}}
+ }]
+
+ test_spec = {
+ "ipv4addr": {"ib_req": True},
+ "ptrdname": {"ib_req": True},
+ "comment": {},
+ "extattrs": {},
+ "view": {"ib_req": True}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
+
+ def test_nios_ptr_record_update_comment(self):
+ self.module.params = {'provider': None, 'state': 'present', 'ptrdname': 'ansible.test.com',
+ 'ipv4addr': '10.36.241.14', 'comment': 'updated comment', 'extattrs': None, 'view': 'default'}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "record:ptr/ZG5zLm5ldHdvcmtfdmlldyQw:14.241.36.10.in-addr.arpa/default",
+ "ptrdname": "ansible.test.com",
+ "ipv4addr": "10.36.241.14",
+ "extattrs": {},
+ "view": "default"
+ }
+ ]
+
+ test_spec = {
+ "ipv4addr": {"ib_req": True},
+ "ptrdname": {"ib_req": True},
+ "comment": {},
+ "extattrs": {},
+ "view": {"ib_req": True}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.update_object.called_once_with(test_object)
+
+ def test_nios_ptr_record_update_record_ptrdname(self):
+ self.module.params = {'provider': None, 'state': 'present', 'ptrdname': 'ansible.test.org',
+ 'ipv4addr': '10.36.241.14', 'comment': 'comment', 'extattrs': None, 'view': 'default'}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "record:ptr/ZG5zLm5ldHdvcmtfdmlldyQw:14.241.36.10.in-addr.arpa/default",
+ "ptrdname": "ansible.test.com",
+ "ipv4addr": "10.36.241.14",
+ "extattrs": {},
+ "view": "default"
+ }
+ ]
+
+ test_spec = {
+ "ipv4addr": {"ib_req": True},
+ "ptrdname": {"ib_req": True},
+ "comment": {},
+ "extattrs": {},
+ "view": {"ib_req": True}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.update_object.called_once_with(test_object)
+
+ def test_nios_ptr6_record_create(self):
+ self.module.params = {'provider': None, 'state': 'present', 'ptrdname': 'ansible6.test.com',
+ 'ipv6addr': '2002:8ac3:802d:1242:20d:60ff:fe38:6d16', 'comment': None, 'extattrs': None, 'view': 'default'}
+
+ test_object = None
+ test_spec = {"ipv6addr": {"ib_req": True},
+ "ptrdname": {"ib_req": True},
+ "comment": {},
+ "extattrs": {},
+ "view": {"ib_req": True}}
+
+ wapi = self._get_wapi(test_object)
+ print("WAPI: ", wapi)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'ipv6addr': '2002:8ac3:802d:1242:20d:60ff:fe38:6d16',
+ 'ptrdname': 'ansible6.test.com', 'view': 'default'})
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_srv_record.py b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_srv_record.py
new file mode 100644
index 00000000..3d7e6c98
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_srv_record.py
@@ -0,0 +1,157 @@
+# 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/>.
+
+# Make coding more python3-ish
+
+
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+
+from ansible_collections.infoblox.nios_modules.plugins.modules import nios_srv_record
+from ansible_collections.infoblox.nios_modules.plugins.module_utils import api
+from ansible_collections.infoblox.nios_modules.tests.unit.compat.mock import patch, MagicMock, Mock
+from ansible.module_utils.common.validation import check_type_dict
+from .test_nios_module import TestNiosModule, load_fixture
+
+
+class TestNiosSRVRecordModule(TestNiosModule):
+
+ module = nios_srv_record
+
+ def setUp(self):
+ super(TestNiosSRVRecordModule, self).setUp()
+ self.module = MagicMock(name='ansible_collections.infoblox.nios_modules.plugins.modules.nios_srv_record.WapiModule')
+ self.module.check_mode = False
+ self.module.params = {'provider': None}
+ self.mock_wapi = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_srv_record.WapiModule')
+ self.exec_command = self.mock_wapi.start()
+ self.mock_wapi_run = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_srv_record.WapiModule.run')
+ self.mock_wapi_run.start()
+ self.load_config = self.mock_wapi_run.start()
+ self.mock_check_type_dict = patch('ansible.module_utils.common.validation.check_type_dict')
+ self.mock_check_type_dict_obj = self.mock_check_type_dict.start()
+
+ def tearDown(self):
+ super(TestNiosSRVRecordModule, self).tearDown()
+ self.mock_wapi.stop()
+ self.mock_wapi_run.stop()
+ self.mock_check_type_dict.stop()
+
+ def _get_wapi(self, test_object):
+ wapi = api.WapiModule(self.module)
+ wapi.get_object = Mock(name='get_object', return_value=test_object)
+ wapi.create_object = Mock(name='create_object')
+ wapi.update_object = Mock(name='update_object')
+ wapi.delete_object = Mock(name='delete_object')
+ return wapi
+
+ def load_fixtures(self, commands=None):
+ self.exec_command.return_value = (0, load_fixture('nios_result.txt').strip(), None)
+ self.load_config.return_value = dict(diff=None, session='session')
+
+ def test_nios_srv_record_create(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': '_sip._tcp.service.ansible.com',
+ 'port': 5080, 'target': 'service1.ansible.com', 'priority': 10, 'weight': 10,
+ 'comment': None, 'extattrs': None}
+
+ test_object = None
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "port": {"ib_req": True},
+ "target": {"ib_req": True},
+ "priority": {"ib_req": True},
+ "weight": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ print("WAPI: ", wapi)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'name': '_sip._tcp.service.ansible.com',
+ 'port': 5080, 'target': 'service1.ansible.com', 'priority': 10, 'weight': 10})
+
+ def test_nios_srv_record_update_comment(self):
+ self.module.params = {'provider': None, 'state': 'present', 'name': '_sip._tcp.service.ansible.com',
+ 'port': 5080, 'target': 'service1.ansible.com', 'priority': 10, 'weight': 10,
+ 'comment': None, 'extattrs': None}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "srvrecord/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "name": "_sip._tcp.service.ansible.com",
+ 'port': 5080,
+ "target": "mailhost.ansible.com",
+ "priority": 10,
+ 'weight': 10,
+ "extattrs": {}
+ }
+ ]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "port": {"ib_req": True},
+ "target": {"ib_req": True},
+ "priority": {"ib_req": True},
+ "weight": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+
+ def test_nios_srv_record_remove(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'name': '_sip._tcp.service.ansible.com',
+ 'port': 5080, 'target': 'service1.ansible.com', 'priority': 10, 'weight': 10,
+ 'comment': None, 'extattrs': None}
+
+ ref = "srvrecord/ZG5zLm5ldHdvcmtfdmlldyQw:default/false"
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": ref,
+ "name": "_sip._tcp.service.ansible.com",
+ "port": 5080,
+ "target": "mailhost.ansible.com",
+ "priority": 10,
+ "weight": 10,
+ "extattrs": {'Site': {'value': 'test'}}
+ }
+ ]
+
+ test_spec = {
+ "name": {"ib_req": True},
+ "port": {"ib_req": True},
+ "target": {"ib_req": True},
+ "priority": {"ib_req": True},
+ "weight": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_zone.py b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_zone.py
new file mode 100644
index 00000000..693ab060
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/test_nios_zone.py
@@ -0,0 +1,287 @@
+# 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/>.
+
+# Make coding more python3-ish
+
+
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+
+from ansible_collections.infoblox.nios_modules.plugins.modules import nios_zone
+from ansible_collections.infoblox.nios_modules.plugins.module_utils import api
+from ansible_collections.infoblox.nios_modules.tests.unit.compat.mock import patch, MagicMock, Mock
+from .test_nios_module import TestNiosModule, load_fixture
+
+
+class TestNiosZoneModule(TestNiosModule):
+
+ module = nios_zone
+
+ def setUp(self):
+ super(TestNiosZoneModule, self).setUp()
+ self.module = MagicMock(name='ansible_collections.infoblox.nios_modules.plugins.modules.nios_zone.WapiModule')
+ self.module.check_mode = False
+ self.module.params = {'provider': None}
+ self.mock_wapi = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_zone.WapiModule')
+ self.exec_command = self.mock_wapi.start()
+ self.mock_wapi_run = patch('ansible_collections.infoblox.nios_modules.plugins.modules.nios_zone.WapiModule.run')
+ self.mock_wapi_run.start()
+ self.load_config = self.mock_wapi_run.start()
+
+ def tearDown(self):
+ super(TestNiosZoneModule, self).tearDown()
+ self.mock_wapi.stop()
+ self.mock_wapi_run.stop()
+
+ def _get_wapi(self, test_object):
+ wapi = api.WapiModule(self.module)
+ wapi.get_object = Mock(name='get_object', return_value=test_object)
+ wapi.create_object = Mock(name='create_object')
+ wapi.update_object = Mock(name='update_object')
+ wapi.delete_object = Mock(name='delete_object')
+ return wapi
+
+ def load_fixtures(self, commands=None):
+ self.exec_command.return_value = (0, load_fixture('nios_result.txt').strip(), None)
+ self.load_config.return_value = dict(diff=None, session='session')
+
+ def test_nios_zone_create(self):
+ self.module.params = {'provider': None, 'state': 'present', 'fqdn': 'ansible.com',
+ 'comment': None, 'extattrs': None}
+
+ test_object = None
+
+ test_spec = {
+ "fqdn": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ print("WAPI: ", wapi)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'fqdn': 'ansible.com'})
+
+ def test_nios_zone_remove(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'fqdn': 'ansible.com',
+ 'comment': None, 'extattrs': None}
+
+ ref = "zone/ZG5zLm5ldHdvcmtfdmlldyQw:ansible/false"
+
+ test_object = [{
+ "comment": "test comment",
+ "_ref": ref,
+ "fqdn": "ansible.com",
+ "extattrs": {'Site': {'value': 'test'}}
+ }]
+
+ test_spec = {
+ "fqdn": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
+
+ def test_nios_zone_update_comment(self):
+ self.module.params = {'provider': None, 'state': 'present', 'fqdn': 'ansible.com',
+ 'comment': 'updated comment', 'extattrs': None}
+
+ test_object = [
+ {
+ "comment": "test comment",
+ "_ref": "zone/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
+ "fqdn": "ansible.com",
+ "extattrs": {'Site': {'value': 'test'}}
+ }
+ ]
+
+ test_spec = {
+ "fqdn": {"ib_req": True},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+
+ def test_nios_zone_create_using_grid_primary_secondaries(self):
+ self.module.params = {'provider': None, 'state': 'present', 'fqdn': 'ansible.com',
+ 'grid_primary': [{"name": "gridprimary.grid.com"}],
+ 'grid_secondaries': [{"name": "gridsecondary1.grid.com"},
+ {"name": "gridsecondary2.grid.com"}],
+ 'restart_if_needed': True,
+ 'comment': None, 'extattrs': None}
+
+ test_object = None
+ grid_spec = dict(
+ name=dict(required=True),
+ )
+ test_spec = {
+ "fqdn": {"ib_req": True},
+ "grid_primary": {},
+ "grid_secondaries": {},
+ "restart_if_needed": {},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ print("WAPI: ", wapi)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'fqdn': 'ansible.com',
+ "grid_primary": [{"name": "gridprimary.grid.com"}],
+ "grid_secondaries": [{"name": "gridsecondary1.grid.com"},
+ {"name": "gridsecondary2.grid.com"}],
+ "restart_if_needed": True
+ })
+
+ def test_nios_zone_remove_using_grid_primary_secondaries(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'fqdn': 'ansible.com',
+ 'grid_primary': [{"name": "gridprimary.grid.com"}],
+ 'grid_secondaries': [{"name": "gridsecondary1.grid.com"},
+ {"name": "gridsecondary2.grid.com"}],
+ 'restart_if_needed': True,
+ 'comment': None, 'extattrs': None}
+
+ ref = "zone/ZG5zLm5ldHdvcmtfdmlldyQw:ansible/false"
+
+ test_object = [{
+ "comment": "test comment",
+ "_ref": ref,
+ "fqdn": "ansible.com",
+ "grid_primary": [{"name": "gridprimary.grid.com"}],
+ "grid_secondaries": [{"name": "gridsecondary1.grid.com"}, {"name": "gridsecondary2.grid.com"}],
+ "restart_if_needed": True,
+ "extattrs": {'Site': {'value': 'test'}}
+ }]
+
+ test_spec = {
+ "fqdn": {"ib_req": True},
+ "grid_primary": {},
+ "grid_secondaries": {},
+ "restart_if_needed": {},
+ "comment": {},
+ "extattrs": {}
+ }
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
+
+ def test_nios_zone_create_using_name_server_group(self):
+ self.module.params = {'provider': None, 'state': 'present', 'fqdn': 'ansible.com',
+ 'ns_group': 'examplensg', 'comment': None, 'extattrs': None}
+
+ test_object = None
+
+ test_spec = {
+ "fqdn": {"ib_req": True},
+ "ns_group": {},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ print("WAPI: ", wapi)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'fqdn': 'ansible.com',
+ 'ns_group': 'examplensg'})
+
+ def test_nios_zone_remove_using_name_server_group(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'fqdn': 'ansible.com',
+ 'ns_group': 'examplensg', 'comment': None, 'extattrs': None}
+
+ ref = "zone/ZG5zLm5ldHdvcmtfdmlldyQw:ansible/false"
+
+ test_object = [{
+ "comment": "test comment",
+ "_ref": ref,
+ "fqdn": "ansible.com",
+ "ns_group": "examplensg",
+ "extattrs": {'Site': {'value': 'test'}}
+ }]
+
+ test_spec = {
+ "fqdn": {"ib_req": True},
+ "ns_group": {},
+ "comment": {},
+ "extattrs": {}
+ }
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
+
+ def test_nios_zone_create_using_zone_format(self):
+ self.module.params = {'provider': None, 'state': 'present', 'fqdn': '10.10.10.in-addr.arpa',
+ 'zone_format': 'IPV4', 'comment': None, 'extattrs': None}
+
+ test_object = None
+
+ test_spec = {
+ "fqdn": {"ib_req": True},
+ "zone_format": {},
+ "comment": {},
+ "extattrs": {}
+ }
+
+ wapi = self._get_wapi(test_object)
+ print("WAPI: ", wapi)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.create_object.assert_called_once_with('testobject', {'fqdn': '10.10.10.in-addr.arpa',
+ 'zone_format': 'IPV4'})
+
+ def test_nios_zone_remove_using_using_zone_format(self):
+ self.module.params = {'provider': None, 'state': 'absent', 'fqdn': 'ansible.com',
+ 'zone_format': 'IPV4', 'comment': None, 'extattrs': None}
+
+ ref = "zone/ZG5zLm5ldHdvcmtfdmlldyQw:ansible/false"
+
+ test_object = [{
+ "comment": "test comment",
+ "_ref": ref,
+ "fqdn": "ansible.com",
+ "zone_format": "IPV4",
+ "extattrs": {'Site': {'value': 'test'}}
+ }]
+
+ test_spec = {
+ "fqdn": {"ib_req": True},
+ "zone_format": {},
+ "comment": {},
+ "extattrs": {}
+ }
+ wapi = self._get_wapi(test_object)
+ res = wapi.run('testobject', test_spec)
+
+ self.assertTrue(res['changed'])
+ wapi.delete_object.assert_called_once_with(ref)
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/utils.py b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/utils.py
new file mode 100644
index 00000000..6a00fd25
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/plugins/modules/utils.py
@@ -0,0 +1,52 @@
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+import json
+
+from ansible_collections.community.general.tests.unit.compat import unittest
+from ansible_collections.community.general.tests.unit.compat.mock import patch
+from ansible.module_utils import basic
+from ansible.module_utils.common.text.converters import to_bytes
+
+
+def set_module_args(args):
+ if '_ansible_remote_tmp' not in args:
+ args['_ansible_remote_tmp'] = '/tmp'
+ if '_ansible_keep_remote_files' not in args:
+ args['_ansible_keep_remote_files'] = False
+
+ args = json.dumps({'ANSIBLE_MODULE_ARGS': args})
+ basic._ANSIBLE_ARGS = to_bytes(args)
+
+
+class AnsibleExitJson(Exception):
+ pass
+
+
+class AnsibleFailJson(Exception):
+ pass
+
+
+def exit_json(*args, **kwargs):
+ if 'changed' not in kwargs:
+ kwargs['changed'] = False
+ raise AnsibleExitJson(kwargs)
+
+
+def fail_json(*args, **kwargs):
+ kwargs['failed'] = True
+ raise AnsibleFailJson(kwargs)
+
+
+class ModuleTestCase(unittest.TestCase):
+
+ def setUp(self):
+ self.mock_module = patch.multiple(basic.AnsibleModule, exit_json=exit_json, fail_json=fail_json)
+ self.mock_module.start()
+ self.mock_sleep = patch('time.sleep')
+ self.mock_sleep.start()
+ set_module_args({})
+ self.addCleanup(self.mock_module.stop)
+ self.addCleanup(self.mock_sleep.stop)
diff --git a/ansible_collections/infoblox/nios_modules/tests/unit/requirements.txt b/ansible_collections/infoblox/nios_modules/tests/unit/requirements.txt
new file mode 100644
index 00000000..a0a2eb7e
--- /dev/null
+++ b/ansible_collections/infoblox/nios_modules/tests/unit/requirements.txt
@@ -0,0 +1,8 @@
+infoblox-client
+pytest
+pytest-forked
+pytest-xdist
+mock
+pytest-mock
+pytest-cov
+coverage==4.5.4