Module materialize.cloudtest.k8s.api.k8s_role_binding

Expand source code Browse git
# Copyright Materialize, Inc. and contributors. All rights reserved.
#
# Use of this software is governed by the Business Source License
# included in the LICENSE file at the root of this repository.
#
# As of the Change Date specified in that file, in accordance with
# the Business Source License, use of this software will be governed
# by the Apache License, Version 2.0.


from kubernetes.client import V1RoleBinding
from kubernetes.client.exceptions import ApiException

from materialize.cloudtest import DEFAULT_K8S_NAMESPACE
from materialize.cloudtest.k8s.api.k8s_resource import K8sResource


class K8sRoleBinding(K8sResource):
    role_binding: V1RoleBinding

    def __init__(self, namespace: str = DEFAULT_K8S_NAMESPACE):
        super().__init__(namespace)

    def kind(self) -> str:
        return "rolebinding"

    def create(self) -> None:
        rbac_api = self.rbac_api()

        # kubectl delete all -all does not clean up role bindings
        try:
            assert self.role_binding.metadata is not None
            assert self.role_binding.metadata.name is not None
            rbac_api.delete_namespaced_role_binding(
                name=self.role_binding.metadata.name, namespace=self.namespace()
            )
        except ApiException:
            pass

        rbac_api.create_namespaced_role_binding(
            body=self.role_binding,
            namespace=self.namespace(),
        )

Classes

class K8sRoleBinding (namespace: str = 'default')
Expand source code Browse git
class K8sRoleBinding(K8sResource):
    role_binding: V1RoleBinding

    def __init__(self, namespace: str = DEFAULT_K8S_NAMESPACE):
        super().__init__(namespace)

    def kind(self) -> str:
        return "rolebinding"

    def create(self) -> None:
        rbac_api = self.rbac_api()

        # kubectl delete all -all does not clean up role bindings
        try:
            assert self.role_binding.metadata is not None
            assert self.role_binding.metadata.name is not None
            rbac_api.delete_namespaced_role_binding(
                name=self.role_binding.metadata.name, namespace=self.namespace()
            )
        except ApiException:
            pass

        rbac_api.create_namespaced_role_binding(
            body=self.role_binding,
            namespace=self.namespace(),
        )

Ancestors

Subclasses

Class variables

var role_binding : kubernetes.client.models.v1_role_binding.V1RoleBinding

Methods

def create(self) ‑> None
Expand source code Browse git
def create(self) -> None:
    rbac_api = self.rbac_api()

    # kubectl delete all -all does not clean up role bindings
    try:
        assert self.role_binding.metadata is not None
        assert self.role_binding.metadata.name is not None
        rbac_api.delete_namespaced_role_binding(
            name=self.role_binding.metadata.name, namespace=self.namespace()
        )
    except ApiException:
        pass

    rbac_api.create_namespaced_role_binding(
        body=self.role_binding,
        namespace=self.namespace(),
    )
def kind(self) ‑> str
Expand source code Browse git
def kind(self) -> str:
    return "rolebinding"