from pathlib import Path from clan_cli.machines.machines import Machine from clan_cli.secrets.folders import sops_secrets_folder from clan_cli.secrets.machines import add_machine, has_machine from clan_cli.secrets.secrets import decrypt_secret, encrypt_secret, has_secret from clan_cli.secrets.sops import generate_private_key class SecretStore: def __init__(self, machine: Machine) -> None: self.machine = machine if has_machine(self.machine.flake_dir, self.machine.name): return priv_key, pub_key = generate_private_key() encrypt_secret( self.machine.flake_dir, sops_secrets_folder(self.machine.flake_dir) / f"{self.machine.name}-age.key", priv_key, ) add_machine(self.machine.flake_dir, self.machine.name, pub_key, False) def set(self, _service: str, name: str, value: str): encrypt_secret( self.machine.flake_dir, sops_secrets_folder(self.machine.flake_dir) / f"{self.machine.name}-{name}", value, add_machines=[self.machine.name], ) def get(self, _service: str, _name: str) -> bytes: raise NotImplementedError() def exists(self, _service: str, name: str) -> bool: return has_secret( self.machine.flake_dir, f"{self.machine.name}-{name}", ) def upload(self, output_dir: Path, _secrets: list[str]) -> None: key_name = f"{self.machine.name}-age.key" if not has_secret(self.machine.flake_dir, key_name): # skip uploading the secret, not managed by us return key = decrypt_secret(self.machine.flake_dir, key_name) (output_dir / "key.txt").write_text(key)