diff --git a/.github/BOTMETA.yml b/.github/BOTMETA.yml index aeaffb58f0..ac48b04526 100644 --- a/.github/BOTMETA.yml +++ b/.github/BOTMETA.yml @@ -36,9 +36,6 @@ files: $connections/lxd.py: maintainers: mattclay labels: lxd - $connections/oc.py: - maintainers: chouseknecht fabianvf flaper87 maxamillion - labels: oc $connections/saltstack.py: labels: saltstack $doc_fragments/: diff --git a/changelogs/fragments/oc-migration-removal.yml b/changelogs/fragments/oc-migration-removal.yml new file mode 100644 index 0000000000..ddbd5f058a --- /dev/null +++ b/changelogs/fragments/oc-migration-removal.yml @@ -0,0 +1,14 @@ +removed_features: +- | + The ``oc`` connection plugin has been removed from this collection. + It has been migrated to the `community.okd `_ collection. + If you use ansible-base 2.10 or newer, redirections have been provided. + + If you use Ansible 2.9 and installed this collection, you need to adjust the FQCNs (``community.general.oc`` → ``community.okd.oc``) and make sure to install the community.okd collection. +breaking_changes: +- | + If you use Ansible 2.9 and the ``oc`` connection plugin from this collections, community.general 2.0.0 results in errors when trying to use the oc content by FQCN, like ``community.general.oc``. + Since Ansible 2.9 is not able to use redirections, you will have to adjust your inventories, variable files, playbooks and roles manually to use the new FQCN (``community.okd.oc``) and to make sure that you have ``community.okd`` installed. + + If you use ansible-base 2.10 or newer and did not install Ansible 3.0.0, but installed (and/or upgraded) community.general manually, you need to make sure to also install ``community.okd`` if you are using the ``oc`` plugin. + While ansible-base 2.10 or newer can use the redirects that community.general 2.0.0 adds, the collection they point to (community.okd) must be installed for them to work. diff --git a/meta/runtime.yml b/meta/runtime.yml index 28d3b71708..4bbcce41fa 100644 --- a/meta/runtime.yml +++ b/meta/runtime.yml @@ -37,6 +37,8 @@ plugin_routing: connection: docker: redirect: community.docker.docker + oc: + redirect: community.okd.oc modules: ali_instance_facts: deprecation: diff --git a/plugins/connection/oc.py b/plugins/connection/oc.py deleted file mode 100644 index 4b0353979d..0000000000 --- a/plugins/connection/oc.py +++ /dev/null @@ -1,173 +0,0 @@ -# Based on the docker connection plugin -# -# Connection plugin for configuring kubernetes containers with kubectl -# (c) 2017, XuXinkun -# -# 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 . -from __future__ import (absolute_import, division, print_function) -__metaclass__ = type - -DOCUMENTATION = ''' - author: - - xuxinkun (!UNKNOWN) - - connection: oc - - short_description: Execute tasks in pods running on OpenShift. - - description: - - Use the oc exec command to run tasks in, or put/fetch files to, pods running on the OpenShift - container platform. - - - requirements: - - oc (go binary) - - options: - oc_pod: - description: - - Pod name. Required when the host name does not match pod name. - default: '' - vars: - - name: ansible_oc_pod - env: - - name: K8S_AUTH_POD - oc_container: - description: - - Container name. Required when a pod contains more than one container. - default: '' - vars: - - name: ansible_oc_container - env: - - name: K8S_AUTH_CONTAINER - oc_namespace: - description: - - The namespace of the pod - default: '' - vars: - - name: ansible_oc_namespace - env: - - name: K8S_AUTH_NAMESPACE - oc_extra_args: - description: - - Extra arguments to pass to the oc command line. - default: '' - vars: - - name: ansible_oc_extra_args - env: - - name: K8S_AUTH_EXTRA_ARGS - oc_kubeconfig: - description: - - Path to a oc config file. Defaults to I(~/.kube/conig) - default: '' - vars: - - name: ansible_oc_kubeconfig - - name: ansible_oc_config - env: - - name: K8S_AUTH_KUBECONFIG - oc_context: - description: - - The name of a context found in the K8s config file. - default: '' - vars: - - name: ansible_oc_context - env: - - name: K8S_AUTH_CONTEXT - oc_host: - description: - - URL for accessing the API. - default: '' - vars: - - name: ansible_oc_host - - name: ansible_oc_server - env: - - name: K8S_AUTH_HOST - - name: K8S_AUTH_SERVER - oc_token: - description: - - API authentication bearer token. - vars: - - name: ansible_oc_token - - name: ansible_oc_api_key - env: - - name: K8S_AUTH_TOKEN - - name: K8S_AUTH_API_KEY - client_cert: - description: - - Path to a certificate used to authenticate with the API. - default: '' - vars: - - name: ansible_oc_cert_file - - name: ansible_oc_client_cert - env: - - name: K8S_AUTH_CERT_FILE - aliases: [ oc_cert_file ] - client_key: - description: - - Path to a key file used to authenticate with the API. - default: '' - vars: - - name: ansible_oc_key_file - - name: ansible_oc_client_key - env: - - name: K8S_AUTH_KEY_FILE - aliases: [ oc_key_file ] - ca_cert: - description: - - Path to a CA certificate used to authenticate with the API. - default: '' - vars: - - name: ansible_oc_ssl_ca_cert - - name: ansible_oc_ca_cert - env: - - name: K8S_AUTH_SSL_CA_CERT - aliases: [ oc_ssl_ca_cert ] - validate_certs: - description: - - Whether or not to verify the API server's SSL certificate. Defaults to I(true). - default: '' - vars: - - name: ansible_oc_verify_ssl - - name: ansible_oc_validate_certs - env: - - name: K8S_AUTH_VERIFY_SSL - aliases: [ oc_verify_ssl ] -''' - -from ansible_collections.community.kubernetes.plugins.connection.kubectl import Connection as KubectlConnection - - -CONNECTION_TRANSPORT = 'community.general.oc' - -CONNECTION_OPTIONS = { - 'oc_container': '-c', - 'oc_namespace': '-n', - 'oc_kubeconfig': '--config', - 'oc_context': '--context', - 'oc_host': '--server', - 'client_cert': '--client-certificate', - 'client_key': '--client-key', - 'ca_cert': '--certificate-authority', - 'validate_certs': '--insecure-skip-tls-verify', - 'oc_token': '--token' -} - - -class Connection(KubectlConnection): - ''' Local oc based connections ''' - transport = CONNECTION_TRANSPORT - connection_options = CONNECTION_OPTIONS - documentation = DOCUMENTATION