mirror of
https://github.com/ansible-collections/kubernetes.core.git
synced 2026-03-26 21:33:02 +00:00
* Cleanup gha * test by removing matrix excludes * Rename sanity tests * trigger integration tests * Fix ansible-lint workflow * Fix concurrency * Add ansible-lint config * Add ansible-lint config * Fix integration and lint issues * integration wf * fix yamllint issues * fix yamllint issues * update readme and add ignore-2.16.txt * fix ansible-doc * Add version * Use /dev/random to generate random data The GHA environment has difficultly generating entropy. Trying to read from /dev/urandom just blocks forever. We don't care if the random data is cryptographically secure; it's just garbage data for the test. Read from /dev/random, instead. This is only used during the k8s_copy test target. This also removes the custom test module that was being used to generate the files. It's not worth maintaining this for two task that can be replaced with some simple command/shell tasks. * Fix saniry errors * test github_action fix * Address review comments * Remove default types * review comments * isort fixes * remove tags * Add setuptools to venv * Test gh changes * update changelog * update ignore-2.16 * Fix indentation in inventory plugin example * Update .github/workflows/integration-tests.yaml * Update integration-tests.yaml --------- Co-authored-by: Mike Graves <mgraves@redhat.com> Co-authored-by: Bikouo Aubin <79859644+abikouo@users.noreply.github.com>
233 lines
5.7 KiB
Python
233 lines
5.7 KiB
Python
#!/usr/bin/python
|
|
# -*- coding: utf-8 -*-
|
|
# Copyright (c) 2020, Abhijeet Kasurde
|
|
# 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 = r"""
|
|
module: k8s_cluster_info
|
|
|
|
version_added: "0.11.1"
|
|
|
|
short_description: Describe Kubernetes (K8s) cluster, APIs available and their respective versions
|
|
|
|
author:
|
|
- Abhijeet Kasurde (@Akasurde)
|
|
|
|
description:
|
|
- Use the Kubernetes Python client to perform read operations on K8s objects.
|
|
- Authenticate using either a config file, certificates, password or token.
|
|
- Supports check mode.
|
|
|
|
options:
|
|
invalidate_cache:
|
|
description:
|
|
- Invalidate cache before retrieving information about cluster.
|
|
type: bool
|
|
default: True
|
|
|
|
extends_documentation_fragment:
|
|
- kubernetes.core.k8s_auth_options
|
|
|
|
requirements:
|
|
- "python >= 3.6"
|
|
- "kubernetes >= 12.0.0"
|
|
- "PyYAML >= 3.11"
|
|
"""
|
|
|
|
EXAMPLES = r"""
|
|
- name: Get Cluster information
|
|
kubernetes.core.k8s_cluster_info:
|
|
register: api_status
|
|
|
|
- name: Do not invalidate cache before getting information
|
|
kubernetes.core.k8s_cluster_info:
|
|
invalidate_cache: False
|
|
register: api_status
|
|
"""
|
|
|
|
RETURN = r"""
|
|
connection:
|
|
description:
|
|
- Connection information
|
|
returned: success
|
|
type: dict
|
|
contains:
|
|
cert_file:
|
|
description:
|
|
- Path to client certificate.
|
|
type: str
|
|
returned: success
|
|
host:
|
|
description:
|
|
- Host URL
|
|
type: str
|
|
returned: success
|
|
password:
|
|
description:
|
|
- User password
|
|
type: str
|
|
returned: success
|
|
proxy:
|
|
description:
|
|
- Proxy details
|
|
type: str
|
|
returned: success
|
|
ssl_ca_cert:
|
|
description:
|
|
- Path to CA certificate
|
|
type: str
|
|
returned: success
|
|
username:
|
|
description:
|
|
- Username
|
|
type: str
|
|
returned: success
|
|
verify_ssl:
|
|
description:
|
|
- SSL verification status
|
|
type: bool
|
|
returned: success
|
|
version:
|
|
description:
|
|
- Information about server and client version
|
|
returned: success
|
|
type: dict
|
|
contains:
|
|
server:
|
|
description: Server version
|
|
returned: success
|
|
type: dict
|
|
client:
|
|
description: Client version
|
|
returned: success
|
|
type: str
|
|
apis:
|
|
description:
|
|
- dictionary of group + version of resource found from cluster
|
|
returned: success
|
|
type: dict
|
|
elements: dict
|
|
contains:
|
|
categories:
|
|
description: API categories
|
|
returned: success
|
|
type: list
|
|
name:
|
|
description: Resource short name
|
|
returned: success
|
|
type: str
|
|
namespaced:
|
|
description: If resource is namespaced
|
|
returned: success
|
|
type: bool
|
|
preferred:
|
|
description: If resource version preferred
|
|
returned: success
|
|
type: bool
|
|
short_names:
|
|
description: Resource short names
|
|
returned: success
|
|
type: str
|
|
singular_name:
|
|
description: Resource singular name
|
|
returned: success
|
|
type: str
|
|
"""
|
|
|
|
|
|
import copy
|
|
from collections import defaultdict
|
|
|
|
try:
|
|
from ansible_collections.kubernetes.core.plugins.module_utils.client.resource import (
|
|
ResourceList,
|
|
)
|
|
except ImportError:
|
|
# Handled during module setup
|
|
pass
|
|
|
|
from ansible_collections.kubernetes.core.plugins.module_utils.ansiblemodule import (
|
|
AnsibleModule,
|
|
)
|
|
from ansible_collections.kubernetes.core.plugins.module_utils.args_common import (
|
|
AUTH_ARG_SPEC,
|
|
)
|
|
from ansible_collections.kubernetes.core.plugins.module_utils.k8s.core import (
|
|
AnsibleK8SModule,
|
|
)
|
|
from ansible_collections.kubernetes.core.plugins.module_utils.k8s.exceptions import (
|
|
CoreException,
|
|
)
|
|
|
|
|
|
def execute_module(module, client):
|
|
if module.params.get("invalidate_cache"):
|
|
client.resources.invalidate_cache()
|
|
results = defaultdict(dict)
|
|
for resource in list(client.resources):
|
|
resource = resource[0]
|
|
if isinstance(resource, ResourceList):
|
|
continue
|
|
key = (
|
|
resource.group_version
|
|
if resource.group == ""
|
|
else "/".join([resource.group, resource.group_version.split("/")[-1]])
|
|
)
|
|
results[key][resource.kind] = {
|
|
"categories": resource.categories if resource.categories else [],
|
|
"name": resource.name,
|
|
"namespaced": resource.namespaced,
|
|
"preferred": resource.preferred,
|
|
"short_names": resource.short_names if resource.short_names else [],
|
|
"singular_name": resource.singular_name,
|
|
}
|
|
configuration = client.configuration
|
|
connection = {
|
|
"cert_file": configuration.cert_file,
|
|
"host": configuration.host,
|
|
"password": configuration.password,
|
|
"proxy": configuration.proxy,
|
|
"ssl_ca_cert": configuration.ssl_ca_cert,
|
|
"username": configuration.username,
|
|
"verify_ssl": configuration.verify_ssl,
|
|
}
|
|
from kubernetes import __version__ as version
|
|
|
|
version_info = {
|
|
"client": version,
|
|
"server": client.client.version,
|
|
}
|
|
module.exit_json(
|
|
changed=False, apis=results, connection=connection, version=version_info
|
|
)
|
|
|
|
|
|
def argspec():
|
|
spec = copy.deepcopy(AUTH_ARG_SPEC)
|
|
spec["invalidate_cache"] = dict(type="bool", default=True)
|
|
return spec
|
|
|
|
|
|
def main():
|
|
module = AnsibleK8SModule(
|
|
module_class=AnsibleModule, argument_spec=argspec(), supports_check_mode=True
|
|
)
|
|
|
|
from ansible_collections.kubernetes.core.plugins.module_utils.k8s.client import (
|
|
get_api_client,
|
|
)
|
|
|
|
try:
|
|
execute_module(module, client=get_api_client(module=module))
|
|
except CoreException as e:
|
|
module.fail_from_exception(e)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
main()
|