Modular NixOS configuration.
hosts | ||
lib | ||
modules | ||
.gitattributes | ||
.gitignore | ||
flake.lock | ||
flake.nix | ||
install.sh | ||
README.md | ||
shell.nix |
dotnix
Prerequisites
You need to prepare a couple things before installation due to the way secrets are managed.
Prepare secrets repo
- Ensure all required dependencies are present.
nix-shell -p sops age git
- Initialize your secrets repo. You can do this anywhere on your system except this repository.
mkdir secrets
cd secrets
git init
- Create your gitignore. You want this to make sure that you do not accidentally push your private key.
echo "keys.txt" > .gitignore
- Generate your private key.
age-keygen -o ./keys.txt
- Create your sops configuration file.
cat <<EOF > .sops.yaml
keys:
- &master $(age-keygen -y ./keys.txt)
creation_rules:
- path_regex: .*\.(yaml|json|env|ini)$
key_groups:
- age:
- *master
EOF
?. Update the submodule to use your secrets repository.
git submodule set-url -- secrets <ssh uri to your repository>