feat(secrets): scaffold sops-nix for declarative secrets
Wires sops-nix as a flake input and bakes the NixOS module into
configuration.nix via modules/secrets.nix. Per-host defaults live in
modules/secrets.nix:
- defaultSopsFile = ../secrets/${settings.hostName}.yaml
- defaultSopsFormat = yaml
- age.keyFile = /home/${settings.user}/.config/sops/age/keys.txt
The whole sops block is gated on `builtins.pathExists` so flake eval
succeeds before the encrypted file is created — important during the
scaffold-bootstrap phase where the consumer hasn't yet generated an
age key.
Adds .sops.yaml with a placeholder admin recipient (overwrite with
your real age public key before encrypting anything) and a
creation_rules block matching `secrets/*.yaml`.
.gitignore loosened so `secrets/*.yaml` and `secrets/README.md` can
be checked in while plaintext key material (`*.key`, `*.pem`) and
anything else under `secrets/` stays ignored. The pre-commit secret
scanner most consumers use is the second line of defense.
secrets/README.md documents the workflow at the directory level.
The substantive beginner walkthrough lands in a follow-up commit at
docs/secrets-management.md.
`nix flake check --no-build` stays green.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
parent
8ebf16d069
commit
7af3bce544
7 changed files with 146 additions and 1 deletions
11
flake.nix
11
flake.nix
|
|
@ -21,6 +21,17 @@
|
|||
url = "github:lnbits/lnbits";
|
||||
flake = false;
|
||||
};
|
||||
|
||||
# sops-nix — declarative secrets via age-encrypted YAML files.
|
||||
# Decryption happens at NixOS activation; values are exposed to
|
||||
# services as files under /run/secrets/<name>. The host's age
|
||||
# key lives at ~/.config/sops/age/keys.txt by default; recipients
|
||||
# are declared in .sops.yaml. See modules/secrets.nix for wiring
|
||||
# and docs/secrets-management.md for a walkthrough.
|
||||
sops-nix = {
|
||||
url = "github:Mic92/sops-nix";
|
||||
inputs.nixpkgs.follows = "nixpkgs";
|
||||
};
|
||||
};
|
||||
|
||||
outputs =
|
||||
|
|
|
|||
Reference in a new issue