Module materialize.cloudtest.k8s.api.k8s_cluster_role
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 V1ClusterRole
from kubernetes.client.exceptions import ApiException
from materialize.cloudtest import DEFAULT_K8S_NAMESPACE
from materialize.cloudtest.k8s.api.k8s_resource import K8sResource
class K8sClusterRole(K8sResource):
role: V1ClusterRole
def __init__(self, namespace: str = DEFAULT_K8S_NAMESPACE):
super().__init__(namespace)
def kind(self) -> str:
return "clusterrole"
def create(self) -> None:
rbac_api = self.rbac_api()
# kubectl delete all -all does not clean up role bindings
try:
assert self.role.metadata is not None
assert self.role.metadata.name is not None
rbac_api.delete_cluster_role(name=self.role.metadata.name)
except ApiException:
pass
rbac_api.create_cluster_role(
body=self.role,
)
Classes
class K8sClusterRole (namespace: str = 'default')
-
Expand source code Browse git
class K8sClusterRole(K8sResource): role: V1ClusterRole def __init__(self, namespace: str = DEFAULT_K8S_NAMESPACE): super().__init__(namespace) def kind(self) -> str: return "clusterrole" def create(self) -> None: rbac_api = self.rbac_api() # kubectl delete all -all does not clean up role bindings try: assert self.role.metadata is not None assert self.role.metadata.name is not None rbac_api.delete_cluster_role(name=self.role.metadata.name) except ApiException: pass rbac_api.create_cluster_role( body=self.role, )
Ancestors
Subclasses
Class variables
var role : kubernetes.client.models.v1_cluster_role.V1ClusterRole
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.metadata is not None assert self.role.metadata.name is not None rbac_api.delete_cluster_role(name=self.role.metadata.name) except ApiException: pass rbac_api.create_cluster_role( body=self.role, )
def kind(self) ‑> str
-
Expand source code Browse git
def kind(self) -> str: return "clusterrole"