No description
Find a file
2025-10-08 14:00:13 +00:00
_sources Add statech 2025-07-27 09:49:07 +00:00
hosts Update mender hash 2025-10-08 14:00:13 +00:00
modules Add mender-cli 2025-10-08 13:33:09 +00:00
.envrc Add sops-nix 2025-01-17 20:46:50 +00:00
.gitignore Add sops-nix 2025-01-17 20:46:50 +00:00
.sops.yaml Add murk age to sops 2025-08-02 21:18:06 +00:00
flake.lock Update layout 2025-09-27 09:54:25 +00:00
flake.nix Add muin install host 2025-08-04 09:04:27 +00:00
nvfetcher.toml Update valheim mods 2025-06-16 18:37:45 +00:00
README.md Update nix 2025-08-01 09:49:07 +00:00
shell.nix Add nvfetcher 2025-05-24 09:19:56 +00:00
utils.nix Fix sops user passwd 2025-07-31 21:36:11 +00:00

Installation

sudo nix --experimental-features "nix-command flakes" run github:nix-community/disko/latest -- --mode destroy,format,mount hosts/$(hostname)/disk-config.nix
sudo mkdir /tmp/mnt
sudo mount /dev/mapper/crypted /tmp/mnt
sudo btrfs subvolume snapshot -r /tmp/mnt/root /tmp/mnt/root-blank
sudo umount /tmp/mnt
sudo nixos-generate-config --no-filesystems --root /mnt
cp /mnt/etc/nixos/hardware-configuration.nix hosts/$(hostname)/hardware-configuration.nix
rbw config set email admin@muon.host
rbw config set base_url https://vault.muon.host
rbw login
sudo mkdir -p /mnt{,/persist}/var/lib/sops-nix
sudo chown muon:users /mnt/persist/var/lib/sops-nix -R
rbw get sops > /mnt/var/lib/sops-nix/key.txt
sudo cp {/mnt,/mnt/persist}/var/lib/sops-nix/key.txt
sudo nixos-install --root /mnt --no-root-passwd --flake .#$(hostname)
sudo cp -r /mnt/var/lib/nixos/* /mnt/persist/var/lib/nixos/
sudo cp {/mnt,/mnt/persist}/etc/machine-id

Impermanence

Erasure

  boot.initrd.postResumeCommands = lib.mkAfter ''
    mkdir /btrfs_tmp
    mount /dev/mapper/crypted /btrfs_tmp
    if [[ -e /btrfs_tmp/root ]]; then
        mkdir -p /btrfs_tmp/old_roots
        timestamp=$(date --date="@$(stat -c %Y /btrfs_tmp/root)" "+%Y-%m-%-d_%H:%M:%S")
        mv /btrfs_tmp/root "/btrfs_tmp/old_roots/$timestamp"
    fi

    delete_subvolume_recursively() {
        IFS=$'\n'
        for i in $(btrfs subvolume list -o "$1" | cut -f 9- -d ' '); do
            delete_subvolume_recursively "/btrfs_tmp/$i"
        done
        btrfs subvolume delete "$1"
    }

    for i in $(find /btrfs_tmp/old_roots/ -maxdepth 1 -mtime +30); do
        delete_subvolume_recursively "$i"
    done

    btrfs subvolume create /btrfs_tmp/root
    umount /btrfs_tmp
  '';