diff options
Diffstat (limited to '')
33 files changed, 0 insertions, 2015 deletions
diff --git a/ansible_collections/community/skydive/plugins/doc_fragments/__init__.py b/ansible_collections/amazon/aws/tests/unit/plugins/modules/ec2_eip/__init__.py index e69de29bb..e69de29bb 100644 --- a/ansible_collections/community/skydive/plugins/doc_fragments/__init__.py +++ b/ansible_collections/amazon/aws/tests/unit/plugins/modules/ec2_eip/__init__.py diff --git a/ansible_collections/community/skydive/plugins/lookup/__init__.py b/ansible_collections/amazon/aws/tests/unit/plugins/modules/ec2_instance/__init__.py index e69de29bb..e69de29bb 100644 --- a/ansible_collections/community/skydive/plugins/lookup/__init__.py +++ b/ansible_collections/amazon/aws/tests/unit/plugins/modules/ec2_instance/__init__.py diff --git a/ansible_collections/community/skydive/plugins/module_utils/__init__.py b/ansible_collections/amazon/aws/tests/unit/plugins/modules/ec2_security_group/__init__.py index e69de29bb..e69de29bb 100644 --- a/ansible_collections/community/skydive/plugins/module_utils/__init__.py +++ b/ansible_collections/amazon/aws/tests/unit/plugins/modules/ec2_security_group/__init__.py diff --git a/ansible_collections/community/skydive/plugins/module_utils/network/skydive/__init__.py b/ansible_collections/amazon/aws/tests/unit/plugins/modules/fixtures/__init__.py index e69de29bb..e69de29bb 100644 --- a/ansible_collections/community/skydive/plugins/module_utils/network/skydive/__init__.py +++ b/ansible_collections/amazon/aws/tests/unit/plugins/modules/fixtures/__init__.py diff --git a/ansible_collections/community/skydive/plugins/modules/__init__.py b/ansible_collections/amazon/aws/tests/unit/plugins/modules/fixtures/certs/__init__.py index e69de29bb..e69de29bb 100644 --- a/ansible_collections/community/skydive/plugins/modules/__init__.py +++ b/ansible_collections/amazon/aws/tests/unit/plugins/modules/fixtures/certs/__init__.py diff --git a/ansible_collections/community/skydive/tests/unit/__init__.py b/ansible_collections/amazon/aws/tests/unit/utils/__init__.py index e69de29bb..e69de29bb 100644 --- a/ansible_collections/community/skydive/tests/unit/__init__.py +++ b/ansible_collections/amazon/aws/tests/unit/utils/__init__.py diff --git a/ansible_collections/community/skydive/.github/workflows/ansible-test.yml b/ansible_collections/community/skydive/.github/workflows/ansible-test.yml deleted file mode 100644 index 76923befb..000000000 --- a/ansible_collections/community/skydive/.github/workflows/ansible-test.yml +++ /dev/null @@ -1,179 +0,0 @@ -name: CI -on: -# Run CI against all pushes (direct commits) and Pull Requests -- push -- pull_request - -jobs: - -### -# Sanity tests (REQUIRED) -# -# https://docs.ansible.com/ansible/latest/dev_guide/testing_sanity.html - - sanity: - name: Sanity (Ⓐ${{ matrix.ansible }}) - strategy: - matrix: - ansible: - # It's important that Sanity is tested against all stable-X.Y branches - # Testing against `devel` may fail as new tests are added. - - stable-2.9 # Only if your collection supports Ansible 2.9 - - stable-2.10 - - devel - runs-on: ubuntu-latest - steps: - - # ansible-test requires the collection to be in a directory in the form - # .../ansible_collections/community/skydive/ - - - name: Check out code - uses: actions/checkout@v2 - with: - path: ansible_collections/community/skydive - - - name: Set up Python - uses: actions/setup-python@v2 - 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.8 - - # Install the head of the given branch (devel, stable-2.10) - - name: Install ansible-base (${{ matrix.ansible }}) - run: pip install https://github.com/ansible/ansible/archive/${{ matrix.ansible }}.tar.gz --disable-pip-version-check - - # 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: ./ansible_collections/community/skydive - -#### -## Unit tests (OPTIONAL) -## -## https://docs.ansible.com/ansible/latest/dev_guide/testing_units.html -# -# units: -# runs-on: ubuntu-latest -# name: Units (Ⓐ${{ matrix.ansible }}+py${{ matrix.python }}) -# strategy: -# # As soon as the first unit test fails, cancel the others to free up the CI queue -# fail-fast: true -# matrix: -# ansible: -# # - stable-2.9 # Only if your collection supports Ansible 2.9 -# - stable-2.10 -# - devel -# python: -# - 2.6 -# - 2.7 -# - 3.5 -# - 3.6 -# - 3.7 -# - 3.8 -# - 3.9 -# exclude: -# - ansible: stable-2.9 -# python: 3.9 -# -# steps: -# - name: Check out code -# uses: actions/checkout@v2 -# with: -# path: ansible_collections/community/skydive -# -# - name: Set up Python ${{ matrix.ansible }} -# uses: actions/setup-python@v2 -# with: -# python-version: ${{ matrix.python }} -# -# - name: Install ansible-base (${{ matrix.ansible }}) -# run: pip install https://github.com/ansible/ansible/archive/${{ matrix.ansible }}.tar.gz --disable-pip-version-check -# -# # OPTIONAL If your unit test requires Python libraries from other collections -# # Install them like this -# - name: Install collection dependencies -# run: ansible-galaxy collection install ansible.netcommon -p . -# -# # Run the unit tests -# - name: Run unit test -# run: ansible-test units -v --color --python ${{ matrix.python }} --docker --coverage -# working-directory: ./ansible_collections/community/skydive -# -# # 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: ./ansible_collections/community/skydive -# -# # See the reports at https://codecov.io/gh/ansible_collections/GITHUBORG/REPONAME -# - uses: codecov/codecov-action@v1 -# with: -# fail_ci_if_error: false - -#### -## Integration tests (RECOMMENDED) -## -## https://docs.ansible.com/ansible/latest/dev_guide/testing_integration.html -# -# -## If the application you are testing is available as a docker container and you want to test -## multiple versions see the following for an example: -## https://github.com/ansible-collections/community.zabbix/tree/master/.github/workflows -# -# integration: -# runs-on: ubuntu-latest -# name: I (Ⓐ${{ matrix.ansible }}+py${{ matrix.python }}}) -# strategy: -# fail-fast: false -# matrix: -# ansible: -# # - stable-2.9 # Only if your collection supports Ansible 2.9 -# - stable-2.10 -# - devel -# python: -# - 2.6 -# - 2.7 -# - 3.5 -# - 3.6 -# - 3.7 -# - 3.8 -# - 3.9 -# exclude: -# - ansible: stable-2.9 -# python: 3.9 -# -# steps: -# - name: Check out code -# uses: actions/checkout@v2 -# with: -# path: ansible_collections/community/skydive -# -# - name: Set up Python ${{ matrix.ansible }} -# uses: actions/setup-python@v2 -# with: -# python-version: ${{ matrix.python }} -# -# - name: Install ansible-base (${{ matrix.ansible }}) -# run: pip install https://github.com/ansible/ansible/archive/${{ matrix.ansible }}.tar.gz --disable-pip-version-check -# -# # OPTIONAL If your integration test requires Python libraries or modules from other collections -# # Install them like this -# - name: Install collection dependencies -# run: ansible-galaxy collection install ansible.netcommon -p . -# -# # Run the integration tests -# - name: Run integration test -# run: ansible-test integration -v --color --retry-on-error --continue-on-error --diff --python ${{ matrix.python }} --docker --coverage -# working-directory: ./ansible_collections/community/skydive -# -# # 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: ./ansible_collections/community/skydive -# -# # See the reports at https://codecov.io/gh/ansible_collections/GITHUBORG/REPONAME -# - uses: codecov/codecov-action@v1 -# with: -# fail_ci_if_error: false diff --git a/ansible_collections/community/skydive/.gitignore b/ansible_collections/community/skydive/.gitignore deleted file mode 100644 index 740c81154..000000000 --- a/ansible_collections/community/skydive/.gitignore +++ /dev/null @@ -1,132 +0,0 @@ -/tests/output/ -/changelogs/.plugin-cache.yaml - -# Byte-compiled / optimized / DLL files -__pycache__/ -*.py[cod] -*$py.class - -# C extensions -*.so - -# Distribution / packaging -.Python -build/ -develop-eggs/ -dist/ -downloads/ -eggs/ -.eggs/ -lib/ -lib64/ -parts/ -sdist/ -var/ -wheels/ -pip-wheel-metadata/ -share/python-wheels/ -*.egg-info/ -.installed.cfg -*.egg -MANIFEST - -# 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/ -.nox/ -.coverage -.coverage.* -.cache -nosetests.xml -coverage.xml -*.cover -*.py,cover -.hypothesis/ -.pytest_cache/ - -# Translations -*.mo -*.pot - -# Django stuff: -*.log -local_settings.py -db.sqlite3 -db.sqlite3-journal - -# Flask stuff: -instance/ -.webassets-cache - -# Scrapy stuff: -.scrapy - -# Sphinx documentation -docs/_build/ - -# PyBuilder -target/ - -# Jupyter Notebook -.ipynb_checkpoints - -# IPython -profile_default/ -ipython_config.py - -# pyenv -.python-version - -# pipenv -# According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control. -# However, in case of collaboration, if having platform-specific dependencies or dependencies -# having no cross-platform support, pipenv may install dependencies that don't work, or not -# install all needed dependencies. -#Pipfile.lock - -# PEP 582; used by e.g. github.com/David-OConnor/pyflow -__pypackages__/ - -# Celery stuff -celerybeat-schedule -celerybeat.pid - -# SageMath parsed files -*.sage.py - -# Environments -.env -.venv -env/ -venv/ -ENV/ -env.bak/ -venv.bak/ - -# Spyder project settings -.spyderproject -.spyproject - -# Rope project settings -.ropeproject - -# mkdocs documentation -/site - -# mypy -.mypy_cache/ -.dmypy.json -dmypy.json - -# Pyre type checker -.pyre/ diff --git a/ansible_collections/community/skydive/.yamllint b/ansible_collections/community/skydive/.yamllint deleted file mode 100644 index 6f0d12b3a..000000000 --- a/ansible_collections/community/skydive/.yamllint +++ /dev/null @@ -1,14 +0,0 @@ ---- -extends: default - -ignore: | - .tox - -rules: - braces: - max-spaces-inside: 1 - level: error - brackets: - max-spaces-inside: 1 - level: error - line-length: disable diff --git a/ansible_collections/community/skydive/CHANGELOG.rst b/ansible_collections/community/skydive/CHANGELOG.rst deleted file mode 100644 index fe7cbe650..000000000 --- a/ansible_collections/community/skydive/CHANGELOG.rst +++ /dev/null @@ -1,16 +0,0 @@ -===================== -Skydive Release Notes -===================== - -.. contents:: Topics - - -v1.0.0 -====== - -Release Summary ---------------- - -| Release Date: 2020-08-18 -| Adapt to Ansible 2.10 collections - diff --git a/ansible_collections/community/skydive/FILES.json b/ansible_collections/community/skydive/FILES.json deleted file mode 100644 index 7163b815c..000000000 --- a/ansible_collections/community/skydive/FILES.json +++ /dev/null @@ -1,327 +0,0 @@ -{ - "files": [ - { - "format": 1, - "ftype": "dir", - "chksum_sha256": null, - "name": ".", - "chksum_type": null - }, - { - "ftype": "file", - "chksum_sha256": "3d452a1344d28ffe1f8eb2f305d59252ef000b0e827e2f777d4e70b635376247", - "name": "CHANGELOG.rst", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "51aed152ad949ba2a2965a2db34fd378ac9b9bfcddf3e019c8db640d6f681b5c", - "name": "test-requirements.txt", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "c68f4100f7f923dd7e15403829b2a53852d8f167a53d42ff8b814e5ca39cc7f2", - "name": ".gitignore", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "dir", - "chksum_sha256": null, - "name": "tests", - "chksum_type": null, - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "b5726d3ec9335a09c124469eca039523847a6b0f08a083efaefd002b83326600", - "name": "tests/.gitignore", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "dir", - "chksum_sha256": null, - "name": "tests/sanity", - "chksum_type": null, - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "1d4fb7dbb1ce0bbc4b047df8cc0725d80463573bf505dd386bfcc8ae84299902", - "name": "tests/sanity/ignore-2.11.txt", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "5dd8da6c473730effea03be910fae0307afe0352c6f27034ea5e9e71c033af73", - "name": "tests/sanity/ignore-2.9.txt", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "1d4fb7dbb1ce0bbc4b047df8cc0725d80463573bf505dd386bfcc8ae84299902", - "name": "tests/sanity/ignore-2.10.txt", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "c8a4ac4bfdef88e75d6e748e35a42fb4915947dfa2b7dd788626fd829600e014", - "name": "tests/sanity/requirements.txt", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "dir", - "chksum_sha256": null, - "name": "tests/unit", - "chksum_type": null, - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855", - "name": "tests/unit/__init__.py", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "49ba996dc4735c3463e9af561344346dfae14bcc1a68096ce78364b377f0df1f", - "name": "tests/unit/requirements.txt", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "3972dc9744f6499f0f9b2dbf76696f2ae7ad8af9b23dde66d6af86c9dfb36986", - "name": "LICENSE", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "80645079eb025b3a905b4775ac545d080a3d7d35d537c31e04f7197c94315ab5", - "name": "bindep.txt", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "dir", - "chksum_sha256": null, - "name": "meta", - "chksum_type": null, - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "df18179bb2f5447a56ac92261a911649b96821c0b2c08eea62d5cc6b0195203f", - "name": "meta/runtime.yml", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "dir", - "chksum_sha256": null, - "name": "plugins", - "chksum_type": null, - "format": 1 - }, - { - "ftype": "dir", - "chksum_sha256": null, - "name": "plugins/modules", - "chksum_type": null, - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "85b5e33f24911147e83fa6f7df4c73989a47a50af1370760b60601c2d0028e05", - "name": "plugins/modules/skydive_node.py", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855", - "name": "plugins/modules/__init__.py", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "2285a8247bfb4ac7d026b6df0a33c6a873cadba6b42859a5a35ed52c73bdb2ff", - "name": "plugins/modules/skydive_edge.py", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "fc4661883071c7ff3231a163cfa42604f875ed7b0653057f0574bb549b4abf9d", - "name": "plugins/modules/skydive_capture.py", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "dir", - "chksum_sha256": null, - "name": "plugins/module_utils", - "chksum_type": null, - "format": 1 - }, - { - "ftype": "dir", - "chksum_sha256": null, - "name": "plugins/module_utils/network", - "chksum_type": null, - "format": 1 - }, - { - "ftype": "dir", - "chksum_sha256": null, - "name": "plugins/module_utils/network/skydive", - "chksum_type": null, - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855", - "name": "plugins/module_utils/network/skydive/__init__.py", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "8b902f7373d7ab08fdeb7a56d1d130243a239fa45efee975639a262448982614", - "name": "plugins/module_utils/network/skydive/api.py", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855", - "name": "plugins/module_utils/__init__.py", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "dir", - "chksum_sha256": null, - "name": "plugins/lookup", - "chksum_type": null, - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "8118cc779916f5d0e191d0267c6c3d8ed5ce5b6a9bb79095800e19743403c886", - "name": "plugins/lookup/skydive.py", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855", - "name": "plugins/lookup/__init__.py", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "dir", - "chksum_sha256": null, - "name": "plugins/doc_fragments", - "chksum_type": null, - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "2e22b0b58e3b2c0159cebc5a43651d7bb935aa465e752bade6bf707a5a593531", - "name": "plugins/doc_fragments/skydive.py", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855", - "name": "plugins/doc_fragments/__init__.py", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "0d40aece0cd4887e7f29dd479b350b614bf15b73f1168af0ea0bac71f1ef1600", - "name": "tox.ini", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "dir", - "chksum_sha256": null, - "name": ".github", - "chksum_type": null, - "format": 1 - }, - { - "ftype": "dir", - "chksum_sha256": null, - "name": ".github/workflows", - "chksum_type": null, - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "115cb022e870c680fed48de248e1e81c06def5bda86bfe5be49681e1117a7184", - "name": ".github/workflows/ansible-test.yml", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "241f61c1280d6cd3fea93a8e6e804ebe521441f8e0e53fbf19331d7d090342e1", - "name": "README.md", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "6cfd68f9160b620f26d34a82dc0f6bee28e97d6e78f61774bba63dbb143144ae", - "name": "requirements.txt", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "dir", - "chksum_sha256": null, - "name": "changelogs", - "chksum_type": null, - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "e6a47ddc8d122cbfed7befbe3ebbc04649c6f75da7e8fd1095b14b22d1983af3", - "name": "changelogs/config.yaml", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "33819adecd8320a3b2fc609996606654396b7941c7cb51d25a1f25ac737a4f1a", - "name": "changelogs/changelog.yaml", - "chksum_type": "sha256", - "format": 1 - }, - { - "ftype": "file", - "chksum_sha256": "5f8b92f9b2c5645d9086cdb2d96378b445156e01d5ebeab075f0ac76da82e7c1", - "name": ".yamllint", - "chksum_type": "sha256", - "format": 1 - } - ], - "format": 1 -}
\ No newline at end of file diff --git a/ansible_collections/community/skydive/MANIFEST.json b/ansible_collections/community/skydive/MANIFEST.json deleted file mode 100644 index b2a558cab..000000000 --- a/ansible_collections/community/skydive/MANIFEST.json +++ /dev/null @@ -1,32 +0,0 @@ -{ - "collection_info": { - "description": "Collection allowing to create nodes, edges and captures in Skydive", - "repository": "https://github.com/ansible-collections/skydive", - "tags": [ - "skydive", - "monitoring", - "network" - ], - "dependencies": {}, - "authors": [ - "Sumit Jaiswal (@sjaiswal)" - ], - "issues": "https://github.com/ansible-collections/skydive/issues", - "name": "skydive", - "license": [], - "documentation": null, - "namespace": "community", - "version": "1.0.0", - "readme": "README.md", - "license_file": "LICENSE", - "homepage": "https://github.com/ansible-collections/skydive" - }, - "file_manifest_file": { - "format": 1, - "ftype": "file", - "chksum_sha256": "bdd31aafa321b782d131afb9dabfb6d2e832283c628f004e45fddacb28dd501c", - "name": "FILES.json", - "chksum_type": "sha256" - }, - "format": 1 -}
\ No newline at end of file diff --git a/ansible_collections/community/skydive/README.md b/ansible_collections/community/skydive/README.md deleted file mode 100644 index 7f697ac77..000000000 --- a/ansible_collections/community/skydive/README.md +++ /dev/null @@ -1,3 +0,0 @@ -# Skydive Ansible Collection - -Ansible Collection for the [Skydive](http://skydive.network) network / protocols analyzer. diff --git a/ansible_collections/community/skydive/changelogs/changelog.yaml b/ansible_collections/community/skydive/changelogs/changelog.yaml deleted file mode 100644 index ae02485cd..000000000 --- a/ansible_collections/community/skydive/changelogs/changelog.yaml +++ /dev/null @@ -1,12 +0,0 @@ -ancestor: null -releases: - 1.0.0: - changes: - release_summary: '| Release Date: 2020-08-18 - - | Adapt to Ansible 2.10 collections - - ' - fragments: - - v1.0.0_summary.yaml - release_date: '2020-08-18' diff --git a/ansible_collections/community/skydive/changelogs/config.yaml b/ansible_collections/community/skydive/changelogs/config.yaml deleted file mode 100644 index 92d466964..000000000 --- a/ansible_collections/community/skydive/changelogs/config.yaml +++ /dev/null @@ -1,31 +0,0 @@ -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 -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: Skydive -trivial_section_name: trivial -use_fqcn: true diff --git a/ansible_collections/community/skydive/meta/runtime.yml b/ansible_collections/community/skydive/meta/runtime.yml deleted file mode 100644 index 2ee3c9fa9..000000000 --- a/ansible_collections/community/skydive/meta/runtime.yml +++ /dev/null @@ -1,2 +0,0 @@ ---- -requires_ansible: '>=2.9.10' diff --git a/ansible_collections/community/skydive/plugins/doc_fragments/skydive.py b/ansible_collections/community/skydive/plugins/doc_fragments/skydive.py deleted file mode 100644 index 08c2e17b7..000000000 --- a/ansible_collections/community/skydive/plugins/doc_fragments/skydive.py +++ /dev/null @@ -1,55 +0,0 @@ -# -# (c) 2019, Sumit Jaiswal (@sjaiswal) -# -# 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/>. - - -class ModuleDocFragment(object): - - # Standard files documentation fragment - DOCUMENTATION = """options: - provider: - description: - - A dict object containing connection details. - suboptions: - endpoint: - description: - - Specifies the hostname/address along with the port as C(localhost:8082)for - connecting to the remote instance of SKYDIVE client over the REST API. - required: true - user: - description: - - Configures the username to use to authenticate the connection to the remote - instance of SKYDIVE client. - password: - description: - - Specifies the password to use to authenticate the connection to the remote - instance of SKYDIVE client. - insecure: - description: - - Ignore SSL certification verification. - type: bool - default: false - ssl: - description: - - Specifies the ssl parameter that decides if the connection type shall be - http or https. - type: bool - default: false -notes: -- 'This module must be run locally, which can be achieved by specifying C(connection: - local).' -""" diff --git a/ansible_collections/community/skydive/plugins/lookup/skydive.py b/ansible_collections/community/skydive/plugins/lookup/skydive.py deleted file mode 100644 index bd85fc72e..000000000 --- a/ansible_collections/community/skydive/plugins/lookup/skydive.py +++ /dev/null @@ -1,79 +0,0 @@ -# -# Copyright 2018 Red Hat | Ansible -# -# 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/>. - -from __future__ import absolute_import, division, print_function - -__metaclass__ = type - -DOCUMENTATION = r""" -lookup: skydive -short_description: Query Skydive objects -description: -- Uses the Skydive python REST client to return the queried object from Skydive network - analyzer. -requirements: -- skydive-client -extends_documentation_fragment: -- community.skydive.skydive -options: - filter: - description: a dict object that is used to filter the return objects -""" - -EXAMPLES = r""" -- name: return skydive metdata if present based on Name - set_fact: - skydive_meta: >- - {{ lookup('community.skydive.skydive', filter={'query': "G.V().Has('Name', 'sumit-VirtualBox')"}) }} - -- name: return all the skydive metdata having parameter Name - set_fact: - skydive: >- - {{ lookup('community.skydive.skydive', filter={'query': "G.V().Has('Name')"}, - provider={'endpoint': 'localhost:8082', 'username': 'admin', 'password': 'password'}) }} -""" - -RETURN = r""" -_list: - description: - - The list of queried object metadata - returned: always - type: list -""" - - -from ansible.plugins.lookup import LookupBase -from ansible_collections.community.skydive.plugins.module_utils.network.skydive.api import ( - skydive_lookup, -) -from ansible.module_utils._text import to_text -from ansible.errors import AnsibleError - - -class LookupModule(LookupBase): - def run(self, terms, variables=None, **kwargs): - - provider = kwargs.pop("provider", {}) - filter_data = kwargs.pop("filter", {}) - try: - skydive_obj = skydive_lookup(provider) - result = skydive_obj.lookup_query(filter_data) - except Exception as exc: - raise AnsibleError(to_text(exc)) - - return [result] diff --git a/ansible_collections/community/skydive/plugins/module_utils/network/skydive/api.py b/ansible_collections/community/skydive/plugins/module_utils/network/skydive/api.py deleted file mode 100644 index 06a6f5f53..000000000 --- a/ansible_collections/community/skydive/plugins/module_utils/network/skydive/api.py +++ /dev/null @@ -1,465 +0,0 @@ -# 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. -# -# (c) 2019 Red Hat 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 os -import uuid - -from ansible.module_utils.six import iteritems -from ansible.module_utils.six import iterkeys -from ansible.module_utils._text import to_text -from ansible.module_utils.basic import env_fallback - -try: - from skydive.graph import Node, Edge - from skydive.rest.client import RESTClient - from skydive.websocket.client import ( - NodeAddedMsgType, - NodeUpdatedMsgType, - NodeDeletedMsgType, - ) - from skydive.websocket.client import ( - EdgeAddedMsgType, - EdgeUpdatedMsgType, - EdgeDeletedMsgType, - ) - from skydive.websocket.client import ( - WSClient, - WSClientDefaultProtocol, - WSMessage, - ) - - HAS_SKYDIVE_CLIENT = True -except ImportError: - HAS_SKYDIVE_CLIENT = False - -# defining skydive constants -SKYDIVE_GREMLIN_QUERY = "G.V().Has" -SKYDIVE_GREMLIN_EDGE_QUERY = "G.E().Has" - -SKYDIVE_PROVIDER_SPEC = { - "endpoint": dict(fallback=(env_fallback, ["SKYDIVE_ENDPOINT"])), - "username": dict(fallback=(env_fallback, ["SKYDIVE_USERNAME"])), - "password": dict( - fallback=(env_fallback, ["SKYDIVE_PASSWORD"]), no_log=True - ), - "insecure": dict( - type="bool", - default=False, - fallback=(env_fallback, ["SKYDIVE_INSECURE"]), - ), - "ssl": dict( - type="bool", default=False, fallback=(env_fallback, ["SKYDIVE_SSL"]) - ), -} - - -class skydive_client_check(object): - """ Base class for implementing Skydive Rest API """ - - provider_spec = { - "provider": dict(type="dict", options=SKYDIVE_PROVIDER_SPEC) - } - - def __init__(self, **kwargs): - """ Base class for implementing Skydive Rest API """ - if not HAS_SKYDIVE_CLIENT: - raise Exception( - "skydive-client is required but does not appear " - "to be installed. It can be installed using the " - "command `pip install skydive-client`" - ) - - if not set(kwargs.keys()).issubset(SKYDIVE_PROVIDER_SPEC.keys()): - raise Exception( - "invalid or unsupported keyword argument for skydive_restclient connection." - ) - for key, value in iteritems(SKYDIVE_PROVIDER_SPEC): - if key not in kwargs: - # apply default values from SKYDIVE_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 = ("SKYDIVE_%s" % key).upper() - if env in os.environ: - kwargs[key] = os.environ.get(env) - - -class skydive_inject_protocol(object): - """ Implements inject protocol for node and edge modules """ - - def onOpen(self): - module = self.factory.kwargs["module"] - params = self.factory.kwargs["params"] - result = self.factory.kwargs["result"] - if "node1" and "node2" in self.factory.kwargs: - node1 = self.factory.kwargs["node1"] - node2 = self.factory.kwargs["node2"] - - if module.check_mode: - self.stop() - return - try: - host = params["host"] - if params["metadata"]: - metadata = module._check_type_dict(params["metadata"]) - else: - metadata = {} - if "node_type" in params: - metadata["Name"] = params["name"] - metadata["Type"] = params["node_type"] - seed = params["seed"] - if not seed: - seed = "%s:%s" % (params["name"], params["node_type"]) - if ( - module.params["state"] == "present" - or module.params["state"] == "update" - ): - uid = str(uuid.uuid5(uuid.NAMESPACE_OID, seed)) - node = Node(uid, host, metadata=metadata) - if module.params["state"] == "present": - msg = WSMessage("Graph", NodeAddedMsgType, node) - else: - msg = WSMessage("Graph", NodeUpdatedMsgType, node) - else: - uid = params["id"] - node = Node(uid, host, metadata=metadata) - msg = WSMessage("Graph", NodeDeletedMsgType, node) - elif "relation_type" in params: - metadata["RelationType"] = params["relation_type"] - if ( - module.params["state"] == "present" - or module.params["state"] == "update" - ): - uid = str( - uuid.uuid5( - uuid.NAMESPACE_OID, - "%s:%s:%s" - % (node1, node2, params["relation_type"]), - ) - ) - edge = Edge(uid, host, node1, node2, metadata=metadata) - if module.params["state"] == "present": - msg = WSMessage("Graph", EdgeAddedMsgType, edge) - else: - msg = WSMessage("Graph", EdgeUpdatedMsgType, edge) - else: - uid = module.params["id"] - edge = Edge(uid, host, node1, node2, metadata=metadata) - msg = WSMessage("Graph", EdgeDeletedMsgType, edge) - - self.sendWSMessage(msg) - if uid: - result["UUID"] = uid - result["changed"] = True - except Exception as e: - module.fail_json( - msg="Error during topology update %s" % e, **result - ) - finally: - self.stop_when_complete() - - -class skydive_wsclient(skydive_client_check): - """ Base class for implementing Skydive Websocket API """ - - def __init__(self, module, **kwargs): - super(skydive_wsclient, self).__init__(**kwargs) - - class skydive_full_inject_protocol( - skydive_inject_protocol, WSClientDefaultProtocol - ): - pass - - kwargs["scheme"] = "ws" - if "ssl" in kwargs: - if kwargs["ssl"]: - kwargs["scheme"] = "wss" - if "insecure" not in kwargs: - kwargs["insecure"] = False - scheme = kwargs["scheme"] - self.result = dict(changed=False) - if "node_type" in module.params: - self.wsclient_object = WSClient( - "ansible-" + str(os.getpid()) + "-" + module.params["host"], - "%s://%s/ws/publisher" % (scheme, kwargs["endpoint"]), - protocol=type( - "skydive_full_inject_protocol", - (skydive_inject_protocol, WSClientDefaultProtocol), - dict(), - ), - persistent=True, - insecure=kwargs["insecure"], - username=kwargs["username"], - password=kwargs["password"], - module=module, - params=module.params, - result=self.result, - ) - elif "relation_type" in module.params: - self.parent_node = self.get_node_id(module.params["parent_node"]) - self.child_node = self.get_node_id(module.params["child_node"]) - - self.wsclient_object = WSClient( - "ansible-" + str(os.getpid()) + "-" + module.params["host"], - "%s://%s/ws/publisher" % (scheme, kwargs["endpoint"]), - protocol=type( - "skydive_full_inject_protocol", - (skydive_inject_protocol, WSClientDefaultProtocol), - dict(), - ), - persistent=True, - insecure=kwargs["insecure"], - username=kwargs["username"], - password=kwargs["password"], - module=module, - params=module.params, - node1=self.parent_node, - node2=self.child_node, - result=self.result, - ) - - def get_node_id(self, node_selector): - """ Checks if Gremlin expresssion is passed as input to get the nodes UUID """ - if node_selector.startswith("G.") or node_selector.startswith("g."): - nodes = self.restclient_object.lookup_nodes(node_selector) - if len(nodes) == 0: - raise self.module.fail_json( - msg=to_text("Node not found: {0}".format(node_selector)) - ) - elif len(nodes) > 1: - raise self.module.fail_json( - msg=to_text( - "Node selection should return only one node: {0}".format( - node_selector - ) - ) - ) - return str(nodes[0].id) - return node_selector - - -class skydive_restclient(skydive_client_check): - """ Base class for implementing Skydive Rest API """ - - def __init__(self, **kwargs): - super(skydive_restclient, self).__init__(**kwargs) - kwargs["scheme"] = "http" - if "ssl" in kwargs: - if kwargs["ssl"]: - kwargs["scheme"] = "https" - if "insecure" not in kwargs: - kwargs["insecure"] = False - self.restclient_object = RESTClient( - kwargs["endpoint"], - scheme=kwargs["scheme"], - insecure=kwargs["insecure"], - username=kwargs["username"], - password=kwargs["password"], - ) - - -class skydive_lookup(skydive_restclient): - """ Implements Skydive Lookup queries """ - - provider_spec = { - "provider": dict(type="dict", options=SKYDIVE_PROVIDER_SPEC) - } - - def __init__(self, provider): - super(skydive_lookup, self).__init__(**provider) - self.query_str = "" - - def lookup_query(self, filter_data): - query_key = filter_data.keys()[0] - self.query_str = filter_data[query_key] - nodes = self.restclient_object.lookup_nodes(self.query_str) - result = [] - for each in nodes: - result.append(each.__dict__) - if len(result) == 0: - raise Exception( - "Cannot find any entry for the input Gremlin query!" - ) - return result - - -class skydive_flow_capture(skydive_restclient): - """ Implements Skydive Flow capture modules """ - - def __init__(self, module): - self.module = module - provider = module.params["provider"] - - super(skydive_flow_capture, self).__init__(**provider) - - def run(self, ib_spec): - 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") - ] - ) - - proposed_object = {} - for key in iterkeys(ib_spec): - if self.module.params[key] is not None: - proposed_object[key] = self.module.params[key] - - if obj_filter["query"]: - cature_query = obj_filter["query"] - elif obj_filter["interface_name"] and obj_filter["type"]: - cature_query = ( - SKYDIVE_GREMLIN_QUERY - + "('Name', '{0}', 'Type', '{1}')".format( - obj_filter["interface_name"], obj_filter["type"] - ) - ) - else: - raise self.module.fail_json( - msg="Interface name and Type is required if gremlin query is not defined!" - ) - - # to check current object ref for idempotency - captured_list_objs = self.restclient_object.capture_list() - current_ref_uuid = None - for each_capture in captured_list_objs: - if cature_query == each_capture.__dict__["query"]: - current_ref_uuid = each_capture.__dict__["uuid"] - break - if state == "present": - if not current_ref_uuid: - try: - self.restclient_object.capture_create( - cature_query, - obj_filter["capture_name"], - obj_filter["description"], - obj_filter["extra_tcp_metric"], - obj_filter["ip_defrag"], - obj_filter["reassemble_tcp"], - obj_filter["layer_key_mode"], - ) - except Exception as e: - self.module.fail_json(msg=to_text(e)) - result["changed"] = True - if state == "absent": - if current_ref_uuid: - try: - self.restclient_object.capture_delete(current_ref_uuid) - except Exception as e: - self.module.fail_json(msg=to_text(e)) - result["changed"] = True - - return result - - -class skydive_node(skydive_wsclient, skydive_restclient): - """ Implements Skydive Node modules """ - - def __init__(self, module): - self.module = module - provider = module.params["provider"] - super(skydive_node, self).__init__(self.module, **provider) - - def run(self): - try: - lookup_query = ( - SKYDIVE_GREMLIN_QUERY - + "('Name', '{0}', 'Type', '{1}')".format( - self.module.params["name"], self.module.params["node_type"] - ) - ) - node_exists = self.restclient_object.lookup_nodes(lookup_query) - - if not node_exists and self.module.params["state"] == "present": - self.wsclient_object.connect() - self.wsclient_object.start() - elif ( - len(node_exists) > 0 - and self.module.params["state"] == "update" - ): - self.wsclient_object.connect() - self.wsclient_object.start() - elif ( - len(node_exists) > 0 - and self.module.params["state"] == "absent" - ): - self.module.params["id"] = node_exists[0].__dict__["id"] - self.wsclient_object.connect() - self.wsclient_object.start() - except Exception as e: - self.module.fail_json(msg=to_text(e)) - return self.result - - -class skydive_edge(skydive_wsclient, skydive_restclient): - """ Implements Skydive Edge modules """ - - def __init__(self, module): - self.module = module - provider = module.params["provider"] - - super(skydive_edge, self).__init__(self.module, **provider) - - def run(self): - try: - edge_exists = False - edge_query = ( - SKYDIVE_GREMLIN_EDGE_QUERY - + "('Parent', '{0}', 'Child', '{1}')".format( - self.parent_node, self.child_node - ) - ) - query_result = self.restclient_object.lookup_edges(edge_query) - if query_result: - query_result = query_result[0].__dict__ - edge_exists = True - - if not edge_exists and self.module.params["state"] == "present": - self.wsclient_object.connect() - self.wsclient_object.start() - elif edge_exists and self.module.params["state"] == "update": - self.wsclient_object.connect() - self.wsclient_object.start() - elif edge_exists and self.module.params["state"] == "absent": - self.module.params["id"] = query_result["id"] - self.wsclient_object.connect() - self.wsclient_object.start() - except Exception as e: - self.module.fail_json(msg=to_text(e)) - return self.result diff --git a/ansible_collections/community/skydive/plugins/modules/skydive_capture.py b/ansible_collections/community/skydive/plugins/modules/skydive_capture.py deleted file mode 100644 index f884a0cfa..000000000 --- a/ansible_collections/community/skydive/plugins/modules/skydive_capture.py +++ /dev/null @@ -1,189 +0,0 @@ -#!/usr/bin/python -# -*- coding: utf-8 -*- - -# (c) 2019, Ansible by 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 - - -ANSIBLE_METADATA = { - "metadata_version": "1.1", - "status": ["preview"], - "supported_by": "network", -} - -DOCUMENTATION = r""" ---- -module: skydive_capture -author: -- Sumit Jaiswal (@sjaiswal) -short_description: Module which manages flow capture on interfaces -description: -- This module manages flow capture on interfaces. The Gremlin expression is continuously - evaluated which means that it is possible to define a capture on nodes that do not - exist yet. -- It is useful when you want to start a capture on all OpenvSwitch whatever the number - of Skydive agents you will start. -- While starting the capture, user can specify the capture name, capture description - and capture type optionally. -requirements: -- skydive-client -extends_documentation_fragment: -- community.skydive.skydive -options: - query: - description: - - It's the complete gremlin query which the users can input, I(G.V().Has('Name', - 'eth0', 'Type', 'device')), to create the capture. And, if the user directly - inputs the gremlin query then user is not required to input any other module - parameter as gremlin query takes care of creating the flow capture. - required: false - interface_name: - description: - - To define flow capture interface name. - required: false - type: - description: - - To define flow capture interface type. - required: false - capture_name: - description: - - To define flow capture name. - required: false - default: '' - description: - description: - - Configures a text string to be associated with the instance of this object. - default: '' - extra_tcp_metric: - description: - - To define flow capture ExtraTCPMetric. - type: bool - default: false - ip_defrag: - description: - - To define flow capture IPDefrag. - type: bool - default: false - reassemble_tcp: - description: - - To define flow capture ReassembleTCP. - type: bool - default: false - layer_key_mode: - description: - - To define flow capture Layer KeyMode. - type: str - default: L2 - state: - description: - - State of the flow capture. If value is I(present) flow capture will be created - else if it is I(absent) it will be deleted. - default: present - choices: - - present - - absent -""" - -EXAMPLES = r""" -- name: start a new flow capture directly from gremlin query - community.skydive.skydive_capture: - query: G.V().Has('Name', 'eth0', 'Type', 'device') - state: present - provider: - endpoint: localhost:8082 - username: admin - password: admin - -- name: stop the flow capture directly from gremlin query - community.skydive.skydive_capture: - query: G.V().Has('Name', 'eth0', 'Type', 'device') - state: absent - provider: - endpoint: localhost:8082 - username: admin - password: admin - -- name: start a new flow capture from user's input - community.skydive.skydive_capture: - interface_name: Node1 - type: myhost - capture_name: test_capture - description: test description - extra_tcp_metric: true - ip_defrag: true - reassemble_tcp: true - state: present - provider: - endpoint: localhost:8082 - username: admin - password: admin - -- name: stop the flow capture - community.skydive.skydive_capture: - interface_name: Node1 - type: myhost - capture_name: test_capture - description: test description - extra_tcp_metric: true - ip_defrag: true - reassemble_tcp: true - state: absent - provider: - endpoint: localhost:8082 - username: admin - password: admin -""" - -RETURN = r""" # """ - -from ansible.module_utils.basic import AnsibleModule -from ansible_collections.community.skydive.plugins.module_utils.network.skydive.api import ( - skydive_flow_capture, -) - - -def main(): - """ Main entry point for module execution - """ - ib_spec = dict( - query=dict(required=False, ib_req=True), - interface_name=dict(required=False, ib_req=True), - type=dict(required=False, ib_req=True), - capture_name=dict(required=False, default="", ib_req=True), - description=dict(default="", ib_req=True), - extra_tcp_metric=dict( - type="bool", required=False, ib_req=True, default=False - ), - ip_defrag=dict( - type="bool", required=False, ib_req=True, default=False - ), - reassemble_tcp=dict( - type="bool", required=False, ib_req=True, default=False - ), - layer_key_mode=dict(required=False, ib_req=True, default="L2"), - ) - - argument_spec = dict( - provider=dict(required=False), - state=dict(default="present", choices=["present", "absent"]), - ) - - argument_spec.update(ib_spec) - argument_spec.update(skydive_flow_capture.provider_spec) - - module = AnsibleModule( - argument_spec=argument_spec, supports_check_mode=True - ) - - skydive_obj = skydive_flow_capture(module) - result = skydive_obj.run(ib_spec) - - module.exit_json(**result) - - -if __name__ == "__main__": - main() diff --git a/ansible_collections/community/skydive/plugins/modules/skydive_edge.py b/ansible_collections/community/skydive/plugins/modules/skydive_edge.py deleted file mode 100644 index 88c3c1c41..000000000 --- a/ansible_collections/community/skydive/plugins/modules/skydive_edge.py +++ /dev/null @@ -1,202 +0,0 @@ -#!/usr/bin/python -# -*- coding: utf-8 -*- - -# (c) 2019, Ansible by 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 - - -ANSIBLE_METADATA = { - "metadata_version": "1.1", - "status": ["preview"], - "supported_by": "network", -} - -DOCUMENTATION = r""" -module: skydive_edge -author: -- Sumit Jaiswal (@sjaiswal) -short_description: Module to add edges to Skydive topology -description: -- This module handles setting up edges between two nodes based on the relationship - type to the Skydive topology. -requirements: -- skydive-client -extends_documentation_fragment: -- community.skydive.skydive -options: - parent_node: - description: - - To defined the first node of the link, it can be either an ID or a gremlin expression - required: true - child_node: - description: - - To defined the second node of the link, it can be either an ID or a gremlin - expression - required: true - relation_type: - description: - - To define relation type of the node I(ownership, layer2, layer3). - required: true - host: - description: - - To define the host of the node. - default: '' - required: false - metadata: - description: - - To define metadata for the edge. - required: false - state: - description: - - State of the Skydive Edge. If value is I(present) new edge will be created else - if it is I(absent) it will be deleted. - default: present - choices: - - present - - absent -""" - -EXAMPLES = r""" -- name: create tor - community.skydive.skydive_node: - name: 'TOR' - node_type: "fabric" - seed: TOR - metadata: - Model: Cisco xxxx - provider: - endpoint: localhost:8082 - username: admin - password: admin - register: tor_result - -- name: create port 1 - community.skydive.skydive_node: - name: 'PORT1' - node_type: 'fabric' - seed: PORT1 - provider: - endpoint: localhost:8082 - username: admin - password: admin - register: port1_result - -- name: create port 2 - community.skydive.skydive_node: - name: 'PORT2' - node_type: 'fabric' - seed: PORT2 - provider: - endpoint: localhost:8082 - username: admin - password: admin - register: port2_result - -- name: link node tor and port 1 - community.skydive.skydive_edge: - parent_node: "{{ tor_result.UUID }}" - child_node: "{{ port1_result.UUID }}" - relation_type: ownership - state: present - provider: - endpoint: localhost:8082 - username: admin - password: admin - -- name: link node tor and port 2 - community.skydive.skydive_edge: - parent_node: "{{ tor_result.UUID }}" - child_node: "{{ port2_result.UUID }}" - relation_type: ownership - state: present - provider: - endpoint: localhost:8082 - username: admin - password: admin - -- name: update link node tor and port 1 relation - community.skydive.skydive_edge: - parent_node: "{{ tor_result.UUID }}" - child_node: "{{ port2_result.UUID }}" - relation_type: layer2 - state: upadte - provider: - endpoint: localhost:8082 - username: admin - password: admin - -- name: Unlink tor and port 2 - community.skydive.skydive_edge: - parent_node: "{{ tor_result.UUID }}" - child_node: "{{ port2_result.UUID }}" - relation_type: ownership - state: absent - provider: - endpoint: localhost:8082 - username: admin - password: admin - -- name: link tor and port 2 via Gremlin expression - community.skydive.skydive_edge: - parent_node: G.V().Has('Name', 'TOR') - child_node: G.V().Has('Name', 'PORT2') - relation_type: ownership - state: present - provider: - endpoint: localhost:8082 - username: admin - password: admin - -- name: Unlink tor and port 2 via Gremlin expression - community.skydive.skydive_edge: - parent_node: G.V().Has('Name', 'TOR') - child_node: G.V().Has('Name', 'PORT2') - relation_type: ownership - state: absent - provider: - endpoint: localhost:8082 - username: admin - password: admin -""" - -RETURN = r""" # """ - -from ansible.module_utils.basic import AnsibleModule -from ansible_collections.community.skydive.plugins.module_utils.network.skydive.api import ( - skydive_edge, -) - - -def main(): - """ Main entry point for module execution - """ - ib_spec = dict( - relation_type=dict(type="str", required=True), - parent_node=dict(type="str", required=True), - child_node=dict(type="str", required=True), - host=dict(type="str", default=""), - metadata=dict(type="dict", default=dict()), - ) - - argument_spec = dict( - provider=dict(required=False), - state=dict(default="present", choices=["present", "absent"]), - ) - - argument_spec.update(ib_spec) - argument_spec.update(skydive_edge.provider_spec) - module = AnsibleModule( - argument_spec=argument_spec, supports_check_mode=True - ) - - skydive_obj = skydive_edge(module) - result = skydive_obj.run() - module.exit_json(**result) - - -if __name__ == "__main__": - main() diff --git a/ansible_collections/community/skydive/plugins/modules/skydive_node.py b/ansible_collections/community/skydive/plugins/modules/skydive_node.py deleted file mode 100644 index fcfa2a221..000000000 --- a/ansible_collections/community/skydive/plugins/modules/skydive_node.py +++ /dev/null @@ -1,138 +0,0 @@ -#!/usr/bin/python -# -*- coding: utf-8 -*- - -# (c) 2019, Ansible by 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 - - -ANSIBLE_METADATA = { - "metadata_version": "1.1", - "status": ["preview"], - "supported_by": "network", -} - -DOCUMENTATION = r""" -module: skydive_node -author: -- Sumit Jaiswal (@sjaiswal) -short_description: Module which add nodes to Skydive topology -description: -- This module handles adding node to the Skydive topology. -requirements: -- skydive-client -extends_documentation_fragment: -- community.skydive.skydive -options: - name: - description: - - To define name for the node. - required: true - node_type: - description: - - To define type for the node. - required: true - host: - description: - - To define host for the node. - required: false - seed: - description: - - used to generate the UUID of the node - default: '' - metadata: - description: - - To define metadata for the node. - required: false - state: - description: - - State of the Skydive Node. If value is I(present) new node will be created else - if it is I(absent) it will be deleted. - default: present - choices: - - present - - update - - absent -""" - -EXAMPLES = r""" -- name: create tor node - community.skydive.skydive_node: - name: TOR - node_type: fabric - seed: TOR1 - metadata: - Model: Cisco 5300 - state: present - provider: - endpoint: localhost:8082 - username: admin - password: admin - -- name: update tor node - community.skydive.skydive_node: - name: TOR - node_type: host - seed: TOR1 - metadata: - Model: Cisco 3400 - state: update - provider: - endpoint: localhost:8082 - username: admin - password: admin - -- name: Delete the tor node - community.skydive.skydive_node: - name: TOR - node_type: host - seed: TOR1 - metadata: - Model: Cisco 3400 - state: absent - provider: - endpoint: localhost:8082 - username: admin - password: admin -""" - -RETURN = r""" # """ - -from ansible.module_utils.basic import AnsibleModule -from ansible_collections.community.skydive.plugins.module_utils.network.skydive.api import ( - skydive_node, -) - - -def main(): - """ Main entry point for module execution - """ - ib_spec = dict( - name=dict(required=True, ib_req=True), - node_type=dict(required=True, ib_req=True), - host=dict(required=False, ib_req=True, default=""), - seed=dict(required=False, ib_req=True, default=""), - metadata=dict(required=False, ib_req=True, default=dict()), - ) - - argument_spec = dict( - provider=dict(required=False), - state=dict(default="present", choices=["present", "update", "absent"]), - ) - - argument_spec.update(ib_spec) - argument_spec.update(skydive_node.provider_spec) - module = AnsibleModule( - argument_spec=argument_spec, supports_check_mode=True - ) - - skydive_obj = skydive_node(module) - result = skydive_obj.run() - module.exit_json(**result) - - -if __name__ == "__main__": - main() diff --git a/ansible_collections/community/skydive/requirements.txt b/ansible_collections/community/skydive/requirements.txt deleted file mode 100644 index 90d40550b..000000000 --- a/ansible_collections/community/skydive/requirements.txt +++ /dev/null @@ -1 +0,0 @@ -ansible diff --git a/ansible_collections/community/skydive/test-requirements.txt b/ansible_collections/community/skydive/test-requirements.txt deleted file mode 100644 index 238108317..000000000 --- a/ansible_collections/community/skydive/test-requirements.txt +++ /dev/null @@ -1,2 +0,0 @@ -black==19.3b0 -flake8 diff --git a/ansible_collections/community/skydive/tests/.gitignore b/ansible_collections/community/skydive/tests/.gitignore deleted file mode 100644 index ea1472ec1..000000000 --- a/ansible_collections/community/skydive/tests/.gitignore +++ /dev/null @@ -1 +0,0 @@ -output/ diff --git a/ansible_collections/community/skydive/tests/sanity/ignore-2.10.txt b/ansible_collections/community/skydive/tests/sanity/ignore-2.10.txt deleted file mode 100644 index 121eab686..000000000 --- a/ansible_collections/community/skydive/tests/sanity/ignore-2.10.txt +++ /dev/null @@ -1,21 +0,0 @@ -plugins/module_utils/network/skydive/api.py future-import-boilerplate -plugins/module_utils/network/skydive/api.py metaclass-boilerplate -plugins/modules/skydive_capture.py validate-modules:doc-missing-type -plugins/modules/skydive_capture.py validate-modules:doc-required-mismatch -plugins/modules/skydive_capture.py validate-modules:invalid-ansiblemodule-schema -plugins/modules/skydive_capture.py validate-modules:nonexistent-parameter-documented -plugins/modules/skydive_capture.py validate-modules:parameter-type-not-in-doc -plugins/modules/skydive_capture.py validate-modules:undocumented-parameter -plugins/modules/skydive_edge.py validate-modules:doc-missing-type -plugins/modules/skydive_edge.py validate-modules:doc-required-mismatch -plugins/modules/skydive_edge.py validate-modules:nonexistent-parameter-documented -plugins/modules/skydive_edge.py validate-modules:parameter-type-not-in-doc -plugins/modules/skydive_edge.py validate-modules:undocumented-parameter -plugins/modules/skydive_node.py validate-modules:doc-missing-type -plugins/modules/skydive_node.py validate-modules:doc-required-mismatch -plugins/modules/skydive_node.py validate-modules:invalid-ansiblemodule-schema -plugins/modules/skydive_node.py validate-modules:nonexistent-parameter-documented -plugins/modules/skydive_node.py validate-modules:parameter-type-not-in-doc -plugins/modules/skydive_node.py validate-modules:undocumented-parameter -plugins/doc_fragments/skydive.py future-import-boilerplate -plugins/doc_fragments/skydive.py metaclass-boilerplate
\ No newline at end of file diff --git a/ansible_collections/community/skydive/tests/sanity/ignore-2.11.txt b/ansible_collections/community/skydive/tests/sanity/ignore-2.11.txt deleted file mode 100644 index 121eab686..000000000 --- a/ansible_collections/community/skydive/tests/sanity/ignore-2.11.txt +++ /dev/null @@ -1,21 +0,0 @@ -plugins/module_utils/network/skydive/api.py future-import-boilerplate -plugins/module_utils/network/skydive/api.py metaclass-boilerplate -plugins/modules/skydive_capture.py validate-modules:doc-missing-type -plugins/modules/skydive_capture.py validate-modules:doc-required-mismatch -plugins/modules/skydive_capture.py validate-modules:invalid-ansiblemodule-schema -plugins/modules/skydive_capture.py validate-modules:nonexistent-parameter-documented -plugins/modules/skydive_capture.py validate-modules:parameter-type-not-in-doc -plugins/modules/skydive_capture.py validate-modules:undocumented-parameter -plugins/modules/skydive_edge.py validate-modules:doc-missing-type -plugins/modules/skydive_edge.py validate-modules:doc-required-mismatch -plugins/modules/skydive_edge.py validate-modules:nonexistent-parameter-documented -plugins/modules/skydive_edge.py validate-modules:parameter-type-not-in-doc -plugins/modules/skydive_edge.py validate-modules:undocumented-parameter -plugins/modules/skydive_node.py validate-modules:doc-missing-type -plugins/modules/skydive_node.py validate-modules:doc-required-mismatch -plugins/modules/skydive_node.py validate-modules:invalid-ansiblemodule-schema -plugins/modules/skydive_node.py validate-modules:nonexistent-parameter-documented -plugins/modules/skydive_node.py validate-modules:parameter-type-not-in-doc -plugins/modules/skydive_node.py validate-modules:undocumented-parameter -plugins/doc_fragments/skydive.py future-import-boilerplate -plugins/doc_fragments/skydive.py metaclass-boilerplate
\ No newline at end of file diff --git a/ansible_collections/community/skydive/tests/sanity/ignore-2.9.txt b/ansible_collections/community/skydive/tests/sanity/ignore-2.9.txt deleted file mode 100644 index a3bb73edc..000000000 --- a/ansible_collections/community/skydive/tests/sanity/ignore-2.9.txt +++ /dev/null @@ -1,16 +0,0 @@ -plugins/module_utils/network/skydive/api.py future-import-boilerplate -plugins/module_utils/network/skydive/api.py metaclass-boilerplate -plugins/modules/skydive_capture.py validate-modules:doc-missing-type -plugins/modules/skydive_capture.py validate-modules:nonexistent-parameter-documented -plugins/modules/skydive_capture.py validate-modules:parameter-type-not-in-doc -plugins/modules/skydive_capture.py validate-modules:undocumented-parameter -plugins/modules/skydive_edge.py validate-modules:doc-missing-type -plugins/modules/skydive_edge.py validate-modules:nonexistent-parameter-documented -plugins/modules/skydive_edge.py validate-modules:parameter-type-not-in-doc -plugins/modules/skydive_edge.py validate-modules:undocumented-parameter -plugins/modules/skydive_node.py validate-modules:doc-missing-type -plugins/modules/skydive_node.py validate-modules:nonexistent-parameter-documented -plugins/modules/skydive_node.py validate-modules:parameter-type-not-in-doc -plugins/modules/skydive_node.py validate-modules:undocumented-parameter -plugins/doc_fragments/skydive.py future-import-boilerplate -plugins/doc_fragments/skydive.py metaclass-boilerplate diff --git a/ansible_collections/community/skydive/tests/sanity/requirements.txt b/ansible_collections/community/skydive/tests/sanity/requirements.txt deleted file mode 100644 index 3e3a96692..000000000 --- a/ansible_collections/community/skydive/tests/sanity/requirements.txt +++ /dev/null @@ -1,4 +0,0 @@ -packaging # needed for update-bundled and changelog -sphinx ; python_version >= '3.5' # docs build requires python 3+ -sphinx-notfound-page ; python_version >= '3.5' # docs build requires python 3+ -straight.plugin ; python_version >= '3.5' # needed for hacking/build-ansible.py which will host changelog generation and requires python 3+ diff --git a/ansible_collections/community/skydive/tests/unit/requirements.txt b/ansible_collections/community/skydive/tests/unit/requirements.txt deleted file mode 100644 index a9772bea1..000000000 --- a/ansible_collections/community/skydive/tests/unit/requirements.txt +++ /dev/null @@ -1,42 +0,0 @@ -boto3 -placebo -pycrypto -passlib -pypsrp -python-memcached -pytz -pyvmomi -redis -requests -setuptools > 0.6 # pytest-xdist installed via requirements does not work with very old setuptools (sanity_ok) -unittest2 ; python_version < '2.7' -importlib ; python_version < '2.7' -netaddr -ipaddress -netapp-lib -solidfire-sdk-python - -# requirements for F5 specific modules -f5-sdk ; python_version >= '2.7' -f5-icontrol-rest ; python_version >= '2.7' -deepdiff - -# requirement for Fortinet specific modules -pyFMG - -# requirement for aci_rest module -xmljson - -# requirement for winrm connection plugin tests -pexpect - -# requirement for the linode module -linode-python # APIv3 -linode_api4 ; python_version > '2.6' # APIv4 - -# requirement for the gitlab module -python-gitlab -httmock - -# requirment for kubevirt modules -openshift ; python_version >= '2.7' diff --git a/ansible_collections/community/skydive/tox.ini b/ansible_collections/community/skydive/tox.ini deleted file mode 100644 index 1aceac0a0..000000000 --- a/ansible_collections/community/skydive/tox.ini +++ /dev/null @@ -1,31 +0,0 @@ -[tox] -minversion = 1.4.2 -envlist = linters -skipsdist = True - -[testenv] -deps = -r{toxinidir}/requirements.txt - -r{toxinidir}/test-requirements.txt - -[testenv:black] -install_command = pip install {opts} {packages} -commands = - black -v -l79 {toxinidir} - -[testenv:linters] -install_command = pip install {opts} {packages} -commands = - black -v -l79 --check {toxinidir} - flake8 {posargs} - -[testenv:venv] -commands = {posargs} - -[flake8] -# E123, E125 skipped as they are invalid PEP-8. - -show-source = True -ignore = E123,E125,E402,E501,E741,W503 -max-line-length = 160 -builtins = _ -exclude = .git,.tox,tests/unit/compat/ diff --git a/ansible_collections/community/skydive/bindep.txt b/ansible_collections/dellemc/enterprise_sonic/bindep.txt index ba9c980fb..ba9c980fb 100644 --- a/ansible_collections/community/skydive/bindep.txt +++ b/ansible_collections/dellemc/enterprise_sonic/bindep.txt diff --git a/ansible_collections/community/skydive/LICENSE b/ansible_collections/telekom_mms/icinga_director/LICENSE index f288702d2..f288702d2 100644 --- a/ansible_collections/community/skydive/LICENSE +++ b/ansible_collections/telekom_mms/icinga_director/LICENSE |