Source code for runhouse.resources.secrets.secret_factory

from typing import Dict, Optional

from runhouse.resources.secrets.provider_secrets.provider_secret import ProviderSecret
from runhouse.resources.secrets.secret import Secret

from .provider_secrets.providers import _get_provider_class


[docs]def secret( name: Optional[str] = None, values: Optional[Dict] = None, provider: Optional[str] = None, load_from_den: bool = True, dryrun: bool = False, ) -> Secret: """Builds an instance of :class:`Secret`. Args: name (str, optional): Name to assign the secret resource. values (Dict, optional): Dictionary of secret key-value pairs. load_from_den (bool): Whether to try loading the secret from Den. (Default: ``True``) dryrun (bool, optional): Whether to create in dryrun mode. (Default: False) Returns: Secret: The resulting Secret object. Example: >>> rh.secret("in_memory_secret", values={"secret_key": "secret_val"}) """ from runhouse.globals import rns_client if provider: return provider_secret( name=name, provider=provider, values=values, dryrun=dryrun ) if name and not values: if "/" not in name and rns_client.username: name = f"/{rns_client.username}/{name}" return Secret.from_name(name, load_from_den=load_from_den, dryrun=dryrun) if not values: raise ValueError("values must be provided for an in-memory secret.") return Secret(name, values, dryrun)
[docs]def provider_secret( provider: Optional[str] = None, name: Optional[str] = None, values: Optional[Dict] = None, path: Optional[str] = None, env_vars: Optional[Dict] = None, load_from_den: bool = True, dryrun: bool = False, ) -> ProviderSecret: """ Builds an instance of :class:`ProviderSecret`. At most one of values, path, and env_vars can be provided, to maintain one source of truth. If None are provided, will infer the values from the default path or env vars for the given provider. Args: provider (str): Provider corresponding to the secret. Currently supported options are: ["aws", "azure", "huggingface", "lambda", "github", "gcp", "ssh"] name (str, optional): Name to assign the resource. If none is provided, resource name defaults to the provider name. values (Dict, optional): Dictionary mapping of secret keys and values. path (str, optional): Path where the secret values are held. env_vars (Dict, optional): Dictionary mapping secret keys to the corresponding environment variable key. load_from_den (bool): Whether to try loading the secret from Den. (Default: ``True``) dryrun (bool): Whether to create in dryrun mode. (Default: False) Returns: ProviderSecret: The resulting provider secret object. Example: >>> aws_secret = rh.provider_secret("aws") >>> gcp_secret = rh.provider("gcp", path="~/.gcp/credentials") >>> lamdba_secret = rh.provider_secret("lambda", values={"api_key": "xxxxx"}) """ from runhouse.globals import rns_client if name and "/" not in name and rns_client.username: name = f"/{rns_client.username}/{name}" if not provider: if not name: raise ValueError("Either name or provider must be provided.") if not any([values, path, env_vars]): return Secret.from_name(name, load_from_den=load_from_den) elif not any([values, path, env_vars]): if provider in Secret.builtin_providers(as_str=True): secret_class = _get_provider_class(provider) return secret_class(name=name, provider=provider, dryrun=dryrun) else: return ProviderSecret.from_name( name, provider=provider, load_from_den=load_from_den ) elif sum([bool(x) for x in [values, path, env_vars]]) == 1: secret_class = _get_provider_class(provider) return secret_class( name=name, provider=provider, values=values, path=path, env_vars=env_vars, dryrun=dryrun, ) raise ValueError("Only one of values, path, and env_vars should be set.")