Source code for mlrun.common.schemas.secret

# Copyright 2023 Iguazio
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#   http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

from datetime import datetime

from pydantic.v1 import BaseModel, Field

import mlrun.common.types


[docs] class SecretProviderName(mlrun.common.types.StrEnum): """Enum containing names of valid providers for secrets.""" vault = "vault" kubernetes = "kubernetes"
class SecretsData(BaseModel): provider: SecretProviderName = Field(SecretProviderName.vault) secrets: dict | None = {} class AuthSecretData(BaseModel): provider: SecretProviderName = Field(SecretProviderName.kubernetes) username: str access_key: str @staticmethod def get_field_secret_key(field: str): return { "username": "username", "access_key": "accessKey", }[field] class SecretKeysData(BaseModel): provider: SecretProviderName = Field(SecretProviderName.vault) secret_keys: list | None = [] class SecretToken(BaseModel): name: str token: str class StoreSecretTokensResponse(BaseModel): created_tokens: list[str] = [] updated_tokens: list[str] = [] class SecretTokenInfo(BaseModel): name: str expiration: datetime issued_at: datetime user_id: str username: str class ListSecretTokensResponse(BaseModel): secret_tokens: list[SecretTokenInfo] class DeleteSecretTokenResponse(BaseModel): """Response for single token deletion.""" deleted: bool = Field( default=True, description="True if token was deleted, False if token was not found", ) username: str | None = Field( default=None, description="The resolved username of the token owner", ) class DeleteSecretTokensResponse(BaseModel): """Response for bulk token deletion.""" deleted_count: int = Field( default=0, description="Number of tokens successfully deleted", ) failed_tokens: list[str] = Field( default_factory=list, description="List of token names that failed to delete", ) username: str | None = Field( default=None, description="The resolved username of the token owner", )