mirror of
https://github.com/ansible-collections/kubernetes.core.git
synced 2026-03-26 21:33:02 +00:00
* Rename from community.kubernetes to kubernetes.core This goes through and renames community.kubernetes to kubernetes.core. Most of this was generated from the downstream build script that was used on the community repository, plus whatever hand edits I could find that were needed. The downstream build and test process has also been removed as this repository is now the downstream repository. * Fix CONTRIBUTING.md
220 lines
5.6 KiB
Python
220 lines
5.6 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 OpenShift 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 >= 2.7"
|
|
- "openshift >= 0.6"
|
|
- "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:
|
|
- The API(s) that exists in dictionary
|
|
returned: success
|
|
type: dict
|
|
contains:
|
|
api_version:
|
|
description: API version
|
|
returned: success
|
|
type: str
|
|
categories:
|
|
description: API categories
|
|
returned: success
|
|
type: list
|
|
group_version:
|
|
description: Resource Group version
|
|
returned: success
|
|
type: str
|
|
kind:
|
|
description: Resource kind
|
|
returned: success
|
|
type: str
|
|
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
|
|
available_api_version:
|
|
description: All available versions of the given API
|
|
returned: success
|
|
type: list
|
|
preferred_api_version:
|
|
description: Preferred version of the given API
|
|
returned: success
|
|
type: str
|
|
'''
|
|
|
|
|
|
import copy
|
|
|
|
from ansible_collections.kubernetes.core.plugins.module_utils.ansiblemodule import AnsibleModule
|
|
from ansible.module_utils.parsing.convert_bool import boolean
|
|
from ansible_collections.kubernetes.core.plugins.module_utils.args_common import (AUTH_ARG_SPEC)
|
|
|
|
|
|
def execute_module(module, client):
|
|
invalidate_cache = boolean(module.params.get('invalidate_cache', True), strict=False)
|
|
if invalidate_cache:
|
|
client.resources.invalidate_cache()
|
|
results = {}
|
|
from openshift.dynamic.resource import ResourceList
|
|
for resource in list(client.resources):
|
|
resource = resource[0]
|
|
if isinstance(resource, ResourceList):
|
|
continue
|
|
results[resource.group] = {
|
|
'api_version': resource.group_version,
|
|
'categories': resource.categories if resource.categories else [],
|
|
'kind': resource.kind,
|
|
'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 openshift import __version__ as version
|
|
version_info = {
|
|
'client': version,
|
|
'server': 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 = AnsibleModule(argument_spec=argspec(), supports_check_mode=True)
|
|
from ansible_collections.kubernetes.core.plugins.module_utils.common import get_api_client
|
|
execute_module(module, client=get_api_client(module=module))
|
|
|
|
|
|
if __name__ == '__main__':
|
|
main()
|