3.1 KiB
dotnix
Installation
Setting up your secrets repository
This step is required to install the system as it is built around nix-sops with encrypted files in a private repository in order to not expose even the encrypted secrets to the public. You don't need to be in a NixOS livecd or system in order to complete this step as long as you can install all requirements from step 1.
1. Ensure all required dependencies are present.
nix-shell -p sops age git wl-clipboard
2. Initialize your secrets repo. You can do this anywhere on your system except this repository.
mkdir secrets
cd secrets
git init
3. Create your gitignore. You want this to make sure that you do not accidentally push your private key.
echo "keys.txt" > .gitignore
4. Generate your private key.
age-keygen -o ./keys.txt
5. 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
6. Create your secrets file
mkpasswd | wl-copy
sops secrets.yaml
Then edit the file to look like this
upasswd: [The pasted password from mkpasswd]
7. Create the flake to expose the secrets
cat <<EOF > flake.nix
{
outputs = { self, ... }: {
path = self + "./secrets.yaml";
};
}
EOF
8. Commit and push your changes.
If your git forge supports creating the repository on push you can simply run the commands below, if it does not, like GitHub, create a private repository named "secrets" first before running the below commands.
git remote add origin git@git.example.net:username/secrets
git add .
git commit -m "batman"
git push --set-upstream origin master
9. Back up your keys.txt.
THIS STEP IS VERY IMPORTANT
Back up your keys.txt in a safe location where you can later transfer it on to the livecd. Keep it safe afterwards as it is required to decrypt your secrets. Do not share this with anyone else as it'd allow them to decrypt all your secrets.
You also need to have a copy of your ssh private key or (preferably) deployment key to the repository ready to later clone your secrets repository.
Installing the system
0. Boot in to a livcd image
Any of the official NixOS livecds will work as long as you're able securely transfer files on to it. Non-nixos livecds might work if you install the required tools manually but is out of scope of this document.
1. Clone this repository
git clone https://github.com/c4em/dotnix.git
cd dotnix
2. Fetch your keys.txt and ssh key
Fetch your keys.txt from wherever you've stored them and place them at the root of the configuration directory. If you place them anywhere else the installation will fail. Do not move them later either.
For your ssh key, place it in ~/.ssh
and create a symlink for the root user.
sudo ln -sf /home/nixos/.ssh /root/.ssh
3. Run the installation script
./install.sh --host [your host] --device [the device to install NixOS on]