當前位置: 首頁>>代碼示例>>Python>>正文


Python client.V1Secret方法代碼示例

本文整理匯總了Python中kubernetes.client.V1Secret方法的典型用法代碼示例。如果您正苦於以下問題:Python client.V1Secret方法的具體用法?Python client.V1Secret怎麽用?Python client.V1Secret使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在kubernetes.client的用法示例。


在下文中一共展示了client.V1Secret方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: create_secret

# 需要導入模塊: from kubernetes import client [as 別名]
# 或者: from kubernetes.client import V1Secret [as 別名]
def create_secret(
    kube_client: KubeClient,
    secret: str,
    service: str,
    secret_provider: BaseSecretProvider,
) -> None:
    service = sanitise_kubernetes_name(service)
    sanitised_secret = sanitise_kubernetes_name(secret)
    kube_client.core.create_namespaced_secret(
        namespace="paasta",
        body=V1Secret(
            metadata=V1ObjectMeta(
                name=f"paasta-secret-{service}-{sanitised_secret}",
                labels={
                    "yelp.com/paasta_service": service,
                    "paasta.yelp.com/service": service,
                },
            ),
            data={
                secret: base64.b64encode(
                    secret_provider.decrypt_secret_raw(secret)
                ).decode("utf-8")
            },
        ),
    ) 
開發者ID:Yelp,項目名稱:paasta,代碼行數:27,代碼來源:kubernetes_tools.py

示例2: install_github_secret

# 需要導入模塊: from kubernetes import client [as 別名]
# 或者: from kubernetes.client import V1Secret [as 別名]
def install_github_secret(api_client, namespace, secret_name, github_token):
  """Install Github secret on the cluster.
  Return:
    secret: Secret for Github token
  """
  logging.info("Install Github secret.")

  corev1_api = k8s_client.CoreV1Api(api_client)
  try:
    secret = k8s_client.V1Secret()
    secret.metadata = k8s_client.V1ObjectMeta(name=secret_name)
    secret.type = "Opaque"
    secret.data = {"GITHUB_TOKEN": github_token}

    corev1_api.create_namespaced_secret(namespace, secret)
  except rest.ApiException as e:
    # Status appears to be a string.
    if e.status == 409:
      logging.info("Github token has already been installed")
    else:
      raise 
開發者ID:aws-samples,項目名稱:aws-eks-deep-learning-benchmark,代碼行數:23,代碼來源:install_github_secret.py

示例3: install_aws_secret

# 需要導入模塊: from kubernetes import client [as 別名]
# 或者: from kubernetes.client import V1Secret [as 別名]
def install_aws_secret(api_client, namespace, secret_name, aws_access_key_id, aws_secret_access_key):
  """Install AWS secret on the cluster.
  Return:
    secret: Secret for AWS credentials
  """
  logging.info("Install AWS secret %s", secret_name)

  corev1_api = k8s_client.CoreV1Api(api_client)
  try:
    secret = k8s_client.V1Secret()
    secret.metadata = k8s_client.V1ObjectMeta(name=secret_name)
    secret.type = "Opaque"
    secret.data = {
      "AWS_ACCESS_KEY_ID": aws_access_key_id,
      "AWS_SECRET_ACCESS_KEY": aws_secret_access_key
      }

    corev1_api.create_namespaced_secret(namespace, secret)
  except rest.ApiException as e:
    # Status appears to be a string.
    if e.status == 409:
      logging.info("Github token has already been installed")
    else:
      raise 
開發者ID:aws-samples,項目名稱:aws-eks-deep-learning-benchmark,代碼行數:26,代碼來源:install_aws_secret.py

示例4: secret_create

# 需要導入模塊: from kubernetes import client [as 別名]
# 或者: from kubernetes.client import V1Secret [as 別名]
def secret_create(secret_data, name, namespace="default"):
    """Create a K8S Secret.

    Args:
        secret_data (dict): Data to store in t as key/value hash.
        name (str): Name of the Secret.
        namespace (str): Name of namespace.
    """
    # Encode the data in a copy of the input dictionary
    # TODO: We should check that Secret exists before we create it
    secret_data = secret_data.copy()
    for key, value in secret_data.items():
        if isinstance(value, str):
            value = value.encode("ascii")
        secret_data[key] = base64.b64encode(value).decode("utf-8")
    secret = client.V1Secret()
    secret.metadata = client.V1ObjectMeta(name=name)
    secret.type = "Opaque"
    secret.data = secret_data
    api.create_namespaced_secret(namespace=namespace, body=secret)
    logging.info(f"Created Secret {name} in namespace {namespace}") 
開發者ID:hyperledger-labs,項目名稱:nephos,代碼行數:23,代碼來源:k8s.py

示例5: createSecret

# 需要導入模塊: from kubernetes import client [as 別名]
# 或者: from kubernetes.client import V1Secret [as 別名]
def createSecret(cls, secret_name: str, namespace: str, secret_data: Dict[str, str],
                     labels: Optional[Dict[str, str]] = None) -> client.V1Secret:
        """
        Creates a secret object.
        :param secret_name: The name of the secret.
        :param namespace: The name space for the secret.
        :param secret_data: The secret data.
        :param labels: Optional labels for this secret, defaults to the default labels (see `cls.createDefaultLabels`).
        :return: The secret model object.
        """
        return client.V1Secret(
            metadata=client.V1ObjectMeta(
                name=secret_name,
                namespace=namespace,
                labels=cls.createDefaultLabels(secret_name) if labels is None else labels
            ),
            string_data=secret_data,
        ) 
開發者ID:Ultimaker,項目名稱:k8s-mongo-operator,代碼行數:20,代碼來源:KubernetesResources.py

示例6: update_secret

# 需要導入模塊: from kubernetes import client [as 別名]
# 或者: from kubernetes.client import V1Secret [as 別名]
def update_secret(
    kube_client: KubeClient,
    secret: str,
    service: str,
    secret_provider: BaseSecretProvider,
) -> None:
    service = sanitise_kubernetes_name(service)
    sanitised_secret = sanitise_kubernetes_name(secret)
    kube_client.core.replace_namespaced_secret(
        name=f"paasta-secret-{service}-{sanitised_secret}",
        namespace="paasta",
        body=V1Secret(
            metadata=V1ObjectMeta(
                name=f"paasta-secret-{service}-{sanitised_secret}",
                labels={
                    "yelp.com/paasta_service": service,
                    "paasta.yelp.com/service": service,
                },
            ),
            data={
                secret: base64.b64encode(
                    secret_provider.decrypt_secret_raw(secret)
                ).decode("utf-8")
            },
        ),
    ) 
開發者ID:Yelp,項目名稱:paasta,代碼行數:28,代碼來源:kubernetes_tools.py

示例7: create_secret

# 需要導入模塊: from kubernetes import client [as 別名]
# 或者: from kubernetes.client import V1Secret [as 別名]
def create_secret(name, cert, id_token):
    cert_secret_metadata = k8s_client.V1ObjectMeta(name=CERT_SECRET_NAME)
    cert_secret_data = {"ca.crt": cert}
    cert_secret = k8s_client.V1Secret(api_version="v1", data=cert_secret_data,
                                      kind="Secret", metadata=cert_secret_metadata,
                                      type="Opaque")
    api_instance = get_k8s_api_client(id_token)
    try:
        response = api_instance.create_namespaced_secret(namespace=name,
                                                         body=cert_secret)
    except ApiException as apiException:
        raise KubernetesCreateException('secret', apiException)

    logger.info('Secret {} created'.format(CERT_SECRET_NAME))
    return response 
開發者ID:IntelAI,項目名稱:inference-model-manager,代碼行數:17,代碼來源:tenants_utils.py

示例8: listResources

# 需要導入模塊: from kubernetes import client [as 別名]
# 或者: from kubernetes.client import V1Secret [as 別名]
def listResources(self) -> List[V1Secret]:
        return self.kubernetes_service.listAllSecretsWithLabels().items 
開發者ID:Ultimaker,項目名稱:k8s-mongo-operator,代碼行數:4,代碼來源:AdminSecretChecker.py

示例9: getResource

# 需要導入模塊: from kubernetes import client [as 別名]
# 或者: from kubernetes.client import V1Secret [as 別名]
def getResource(self, cluster_object: V1MongoClusterConfiguration) -> V1Secret:
        name = self.getSecretName(cluster_object.metadata.name)
        return self.kubernetes_service.getSecret(name, cluster_object.metadata.namespace) 
開發者ID:Ultimaker,項目名稱:k8s-mongo-operator,代碼行數:5,代碼來源:AdminSecretChecker.py

示例10: createResource

# 需要導入模塊: from kubernetes import client [as 別名]
# 或者: from kubernetes.client import V1Secret [as 別名]
def createResource(self, cluster_object: V1MongoClusterConfiguration) -> V1Secret:
        name = self.getSecretName(cluster_object.metadata.name)
        return self.kubernetes_service.createSecret(name, cluster_object.metadata.namespace, self._generateSecretData()) 
開發者ID:Ultimaker,項目名稱:k8s-mongo-operator,代碼行數:5,代碼來源:AdminSecretChecker.py

示例11: updateResource

# 需要導入模塊: from kubernetes import client [as 別名]
# 或者: from kubernetes.client import V1Secret [as 別名]
def updateResource(self, cluster_object: V1MongoClusterConfiguration) -> V1Secret:
        name = self.getSecretName(cluster_object.metadata.name)
        return self.kubernetes_service.updateSecret(name, cluster_object.metadata.namespace, self._generateSecretData()) 
開發者ID:Ultimaker,項目名稱:k8s-mongo-operator,代碼行數:5,代碼來源:AdminSecretChecker.py

示例12: getSecret

# 需要導入模塊: from kubernetes import client [as 別名]
# 或者: from kubernetes.client import V1Secret [as 別名]
def getSecret(self, secret_name: str, namespace: str) -> client.V1Secret:
        """
        Retrieves the secret with the given name.
        :param secret_name: The name of the secret.
        :param namespace: The namespace of the secret.
        :return: The secret object.
        """
        return self.core_api.read_namespaced_secret(secret_name, namespace) 
開發者ID:Ultimaker,項目名稱:k8s-mongo-operator,代碼行數:10,代碼來源:KubernetesService.py

示例13: createSecret

# 需要導入模塊: from kubernetes import client [as 別名]
# 或者: from kubernetes.client import V1Secret [as 別名]
def createSecret(self, secret_name: str, namespace: str, secret_data: Dict[str, str],
                     labels: Optional[Dict[str, str]] = None) -> Optional[client.V1Secret]:
        """
        Creates a new Kubernetes secret.
        :param secret_name: Unique name of the secret.
        :param namespace: Namespace to add secret to.
        :param secret_data: The data to store in the secret as key/value pair dict.
        :param labels: Optional labels for this secret, defaults to the default labels (see `cls.createDefaultLabels`).
        :return: The secret if successful, None otherwise.
        """
        secret_body = KubernetesResources.createSecret(secret_name, namespace, secret_data, labels)
        logging.info("Creating secret %s in namespace %s", secret_name, namespace)
        with IgnoreIfExists():
            return self.core_api.create_namespaced_secret(namespace, secret_body) 
開發者ID:Ultimaker,項目名稱:k8s-mongo-operator,代碼行數:16,代碼來源:KubernetesService.py

示例14: updateSecret

# 需要導入模塊: from kubernetes import client [as 別名]
# 或者: from kubernetes.client import V1Secret [as 別名]
def updateSecret(self, secret_name: str, namespace: str, secret_data: Dict[str, str]) -> client.V1Secret:
        """
        Updates the given Kubernetes secret.
        :param secret_name: Unique name of the secret.
        :param namespace: Namespace to add secret to.
        :param secret_data: The data to store in the secret as key/value pair dict.
        :return: The secret if successful, None otherwise.
        """
        secret = self.getSecret(secret_name, namespace)
        secret.string_data = secret_data
        logging.info("Updating secret %s @ ns/%s", secret_name, namespace)
        return self.core_api.patch_namespaced_secret(secret_name, namespace, secret) 
開發者ID:Ultimaker,項目名稱:k8s-mongo-operator,代碼行數:14,代碼來源:KubernetesService.py

示例15: setUp

# 需要導入模塊: from kubernetes import client [as 別名]
# 或者: from kubernetes.client import V1Secret [as 別名]
def setUp(self):
        self.cluster_dict = getExampleClusterDefinitionWithRestore()
        self.cluster_object = V1MongoClusterConfiguration(**self.cluster_dict)
        self.kubernetes_service = MagicMock()
        self.restore_helper = RestoreHelper(self.kubernetes_service)

        self.dummy_credentials = b64encode(json.dumps({"user": "password"}).encode())
        self.kubernetes_service.getSecret.return_value = V1Secret(data={"json": self.dummy_credentials})

        self.expected_cluster_members = [
            "mongo-cluster-0.mongo-cluster.mongo-operator-cluster.svc.cluster.local",
            "mongo-cluster-1.mongo-cluster.mongo-operator-cluster.svc.cluster.local",
            "mongo-cluster-2.mongo-cluster.mongo-operator-cluster.svc.cluster.local"
        ] 
開發者ID:Ultimaker,項目名稱:k8s-mongo-operator,代碼行數:16,代碼來源:TestRestoreHelper.py


注:本文中的kubernetes.client.V1Secret方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。