mirror of
https://github.com/openshift/community.okd.git
synced 2026-03-27 03:13:08 +00:00
* Upgrade Ansible and OKD versions for CI * Use ubi9 and fix sanity * Use correct pip install * Try using quotes * Ensure python3.9 * Upgrade ansible and molecule versions * Remove DeploymentConfig DeploymentConfigs are deprecated and seem to now be causing idempotence problems. Replacing them with Deployments fixes it. * Attempt to fix ldap integration tests Signed-off-by: Alina Buzachis <abuzachis@redhat.com> * Move sanity and unit tests to GH actions Signed-off-by: Alina Buzachis <abuzachis@redhat.com> * Firt round of sanity fixes Signed-off-by: Alina Buzachis <abuzachis@redhat.com> * Add kubernetes.core collection as sanity requirement Signed-off-by: Alina Buzachis <abuzachis@redhat.com> * Add ignore-2.16.txt Signed-off-by: Alina Buzachis <abuzachis@redhat.com> * Attempt to fix units Signed-off-by: Alina Buzachis <abuzachis@redhat.com> * Add ignore-2.17 Signed-off-by: Alina Buzachis <abuzachis@redhat.com> * Attempt to fix unit tests Signed-off-by: Alina Buzachis <abuzachis@redhat.com> * Add pytest-ansible to test-requirements.txt Signed-off-by: Alina Buzachis <abuzachis@redhat.com> * Add changelog fragment Signed-off-by: Alina Buzachis <abuzachis@redhat.com> * Add workflow for ansible-lint Signed-off-by: Alina Buzachis <abuzachis@redhat.com> * Apply black Signed-off-by: Alina Buzachis <abuzachis@redhat.com> * Fix linters Signed-off-by: Alina Buzachis <abuzachis@redhat.com> * Add # fmt: skip Signed-off-by: Alina Buzachis <abuzachis@redhat.com> * Yet another round of linting Signed-off-by: Alina Buzachis <abuzachis@redhat.com> * Yet another round of linting Signed-off-by: Alina Buzachis <abuzachis@redhat.com> * Remove setup.cfg Signed-off-by: Alina Buzachis <abuzachis@redhat.com> * Revert #fmt Signed-off-by: Alina Buzachis <abuzachis@redhat.com> * Use ansible-core 2.14 Signed-off-by: Alina Buzachis <abuzachis@redhat.com> * Cleanup ansible-lint ignores Signed-off-by: Alina Buzachis <abuzachis@redhat.com> * Try using service instead of pod IP * Fix typo * Actually use the correct port * See if NetworkPolicy is preventing connection * using Pod internal IP * fix adm prune auth roles syntax * adding some retry steps * fix: openshift_builds target * add flag --force-with-deps when building downstream collection * Remove yamllint from tox linters, bump minimum python supported version to 3.9, Remove support for ansible-core < 2.14 --------- Signed-off-by: Alina Buzachis <abuzachis@redhat.com> Co-authored-by: Mike Graves <mgraves@redhat.com> Co-authored-by: Alina Buzachis <abuzachis@redhat.com>
142 lines
3.4 KiB
Python
142 lines
3.4 KiB
Python
#!/usr/bin/python
|
|
# -*- coding: utf-8 -*-
|
|
|
|
# Copyright (c) 2021, Red Hat
|
|
# 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
|
|
|
|
# STARTREMOVE (downstream)
|
|
DOCUMENTATION = r"""
|
|
|
|
module: openshift_adm_prune_auth
|
|
|
|
short_description: Removes references to the specified roles, clusterroles, users, and groups
|
|
|
|
version_added: "2.2.0"
|
|
|
|
author:
|
|
- Aubin Bikouo (@abikouo)
|
|
|
|
description:
|
|
- This module allow administrators to remove references to the specified roles, clusterroles, users, and groups.
|
|
- Analogous to C(oc adm prune auth).
|
|
|
|
extends_documentation_fragment:
|
|
- kubernetes.core.k8s_auth_options
|
|
|
|
options:
|
|
resource:
|
|
description:
|
|
- The specified resource to remove.
|
|
choices:
|
|
- roles
|
|
- clusterroles
|
|
- users
|
|
- groups
|
|
type: str
|
|
required: True
|
|
name:
|
|
description:
|
|
- Use to specify an object name to remove.
|
|
- Mutually exclusive with option I(label_selectors).
|
|
- If neither I(name) nor I(label_selectors) are specified, prune all resources in the namespace.
|
|
type: str
|
|
namespace:
|
|
description:
|
|
- Use to specify an object namespace.
|
|
- Ignored when I(resource) is set to C(clusterroles).
|
|
type: str
|
|
label_selectors:
|
|
description:
|
|
- Selector (label query) to filter on.
|
|
- Mutually exclusive with option I(name).
|
|
type: list
|
|
elements: str
|
|
|
|
requirements:
|
|
- python >= 3.6
|
|
- kubernetes >= 12.0.0
|
|
"""
|
|
|
|
EXAMPLES = r"""
|
|
- name: Prune all roles from default namespace
|
|
openshift_adm_prune_auth:
|
|
resource: roles
|
|
namespace: testing
|
|
|
|
- name: Prune clusterroles using label selectors
|
|
openshift_adm_prune_auth:
|
|
resource: roles
|
|
namespace: testing
|
|
label_selectors:
|
|
- phase=production
|
|
"""
|
|
|
|
|
|
RETURN = r"""
|
|
cluster_role_binding:
|
|
type: list
|
|
description: list of cluster role binding deleted.
|
|
returned: always
|
|
role_binding:
|
|
type: list
|
|
description: list of role binding deleted.
|
|
returned: I(resource=users) or I(resource=groups) or I(resource=clusterroles)
|
|
security_context_constraints:
|
|
type: list
|
|
description: list of Security Context Constraints deleted.
|
|
returned: I(resource=users) or I(resource=groups)
|
|
authorization:
|
|
type: list
|
|
description: list of OAuthClientAuthorization deleted.
|
|
returned: I(resource=users)
|
|
group:
|
|
type: list
|
|
description: list of Security Context Constraints deleted.
|
|
returned: I(resource=users)
|
|
"""
|
|
# ENDREMOVE (downstream)
|
|
|
|
import copy
|
|
|
|
from ansible_collections.kubernetes.core.plugins.module_utils.args_common import (
|
|
AUTH_ARG_SPEC,
|
|
)
|
|
|
|
|
|
def argument_spec():
|
|
args = copy.deepcopy(AUTH_ARG_SPEC)
|
|
args.update(
|
|
dict(
|
|
resource=dict(
|
|
type="str",
|
|
required=True,
|
|
choices=["roles", "clusterroles", "users", "groups"],
|
|
),
|
|
namespace=dict(type="str"),
|
|
name=dict(type="str"),
|
|
label_selectors=dict(type="list", elements="str"),
|
|
)
|
|
)
|
|
return args
|
|
|
|
|
|
def main():
|
|
from ansible_collections.community.okd.plugins.module_utils.openshift_adm_prune_auth import (
|
|
OpenShiftAdmPruneAuth,
|
|
)
|
|
|
|
module = OpenShiftAdmPruneAuth(
|
|
argument_spec=argument_spec(),
|
|
mutually_exclusive=[("name", "label_selectors")],
|
|
supports_check_mode=True,
|
|
)
|
|
module.run_module()
|
|
|
|
|
|
if __name__ == "__main__":
|
|
main()
|