1
Fork 0
Modular NixOS configuration.
Find a file
2025-01-24 13:40:40 +01:00
assets stuff 2025-01-22 02:18:47 +01:00
hosts more stuff 2025-01-19 13:18:30 +01:00
lib tcnta3h5 2025-01-23 15:52:18 +01:00
modules if this is the fucking reason I'm fucking killing someone 2025-01-24 13:40:40 +01:00
overlays/nixpkgs very tidy yes yes 2025-01-23 16:10:40 +01:00
.gitattributes kde: Add sddm background and persist more stuff 2024-08-28 22:41:29 +02:00
.gitignore prevent huge oopsie daisies 2025-01-19 23:45:42 +01:00
flake.lock flake.lock: Update 2025-01-23 16:15:11 +01:00
flake.nix 3ukxwl2j 2025-01-23 15:49:17 +01:00
install.sh stuff 2025-01-22 02:18:47 +01:00
README.md stuff 2025-01-22 02:18:47 +01:00

caenix

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

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 upasswd.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, ... }: {
    paths = {
      upasswd = self + "/upasswd.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/caenix.git
cd caenix

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. Update the flake input for your secret

In flake.nix, replace

  inputs = {
    secrets.url = "git+ssh://git@git.caem.dev/caem/secrets";

with your url.

  inputs = {
    secrets.url = "git+ssh://git@git.example.com/username/secrets";

4. Update flake.lock (optional)

nix --extra-experimental-features 'nix-command flakes' flake update

5. Run the installation script

./install.sh --host [your host] --device [the device to install NixOS on]