mirror of
https://gitlab.com/upRootNutrition/dotfiles.git
synced 2025-12-06 21:17:14 -06:00
feat: moved impermanence import
This commit is contained in:
parent
90fd1aad9b
commit
5ab7ffb1a3
4 changed files with 119 additions and 43 deletions
|
|
@ -138,7 +138,7 @@
|
||||||
config.nixosModules.mantle
|
config.nixosModules.mantle
|
||||||
config.nixosModules.crust
|
config.nixosModules.crust
|
||||||
inputs.home-manager.nixosModules.home-manager
|
inputs.home-manager.nixosModules.home-manager
|
||||||
inputs.lix-module.nixosModules.default
|
# inputs.lix-module.nixosModules.default
|
||||||
inputs.nur.modules.nixos.default
|
inputs.nur.modules.nixos.default
|
||||||
inputs.sops-nix.nixosModules.sops
|
inputs.sops-nix.nixosModules.sops
|
||||||
];
|
];
|
||||||
|
|
@ -149,7 +149,6 @@
|
||||||
config.nixosModules.core
|
config.nixosModules.core
|
||||||
config.nixosModules.mantle
|
config.nixosModules.mantle
|
||||||
inputs.home-manager.nixosModules.home-manager
|
inputs.home-manager.nixosModules.home-manager
|
||||||
inputs.impermanence.nixosModules.impermanence
|
|
||||||
# inputs.lix-module.nixosModules.default
|
# inputs.lix-module.nixosModules.default
|
||||||
inputs.microvm.nixosModules.host
|
inputs.microvm.nixosModules.host
|
||||||
inputs.sops-nix.nixosModules.sops
|
inputs.sops-nix.nixosModules.sops
|
||||||
|
|
@ -161,7 +160,7 @@
|
||||||
config.nixosModules.core
|
config.nixosModules.core
|
||||||
config.nixosModules.mantle
|
config.nixosModules.mantle
|
||||||
inputs.home-manager.nixosModules.home-manager
|
inputs.home-manager.nixosModules.home-manager
|
||||||
inputs.lix-module.nixosModules.default
|
# inputs.lix-module.nixosModules.default
|
||||||
inputs.sops-nix.nixosModules.sops
|
inputs.sops-nix.nixosModules.sops
|
||||||
];
|
];
|
||||||
iso = inputs.self.lib.mkLinuxSystem [
|
iso = inputs.self.lib.mkLinuxSystem [
|
||||||
|
|
|
||||||
|
|
@ -50,6 +50,7 @@ in
|
||||||
comfyui
|
comfyui
|
||||||
firefly-iii
|
firefly-iii
|
||||||
forgejo
|
forgejo
|
||||||
|
impermanence
|
||||||
jellyfin
|
jellyfin
|
||||||
mastodon
|
mastodon
|
||||||
microvm
|
microvm
|
||||||
|
|
@ -71,10 +72,9 @@ in
|
||||||
inherit (modules)
|
inherit (modules)
|
||||||
acme
|
acme
|
||||||
caddy
|
caddy
|
||||||
logrotate
|
impermanence
|
||||||
microvm
|
microvm
|
||||||
sambaEris
|
sambaEris
|
||||||
postgresEris
|
|
||||||
;
|
;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
|
||||||
6
modules/nixos/impermanence/default.nix
Normal file
6
modules/nixos/impermanence/default.nix
Normal file
|
|
@ -0,0 +1,6 @@
|
||||||
|
{ flake, ... }:
|
||||||
|
{
|
||||||
|
imports = [
|
||||||
|
flake.inputs.impermanence.nixosModules.impermanence
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
@ -1,42 +1,45 @@
|
||||||
{
|
{
|
||||||
flake,
|
flake,
|
||||||
config,
|
config,
|
||||||
|
lib,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
inherit (flake.config.machines.devices) ceres;
|
inherit (flake.config.people) user0;
|
||||||
ceresSecrets = config.sops.secrets."network/server".path;
|
rootDevice = "/dev/disk/by-label/root";
|
||||||
|
bootDevice = "/dev/disk/by-label/BOOT";
|
||||||
sambaDrives = [
|
|
||||||
"samba0"
|
|
||||||
];
|
|
||||||
|
|
||||||
sambaFolders = [
|
|
||||||
"storage"
|
|
||||||
];
|
|
||||||
|
|
||||||
sambaMounts = sambaDrive: folder: {
|
|
||||||
name = "${ceres.${sambaDrive}.mount}/${folder}";
|
|
||||||
value = {
|
|
||||||
device = "${ceres.${sambaDrive}.device}/${folder}";
|
|
||||||
fsType = "cifs";
|
|
||||||
options = ceres.${sambaDrive}.options ++ [
|
|
||||||
"credentials=${ceresSecrets}"
|
|
||||||
];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
in
|
in
|
||||||
|
|
||||||
{
|
{
|
||||||
fileSystems = {
|
fileSystems = {
|
||||||
"/" = {
|
"/" = {
|
||||||
device = "/dev/disk/by-uuid/df2d42e7-e91c-4525-a8d9-80aa0897b1be";
|
device = rootDevice;
|
||||||
fsType = "ext4";
|
fsType = "btrfs";
|
||||||
|
options = [
|
||||||
|
"subvol=root"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
"/nix" = {
|
||||||
|
device = rootDevice;
|
||||||
|
fsType = "btrfs";
|
||||||
|
options = [
|
||||||
|
"subvol=nix"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
"/persist" = {
|
||||||
|
device = rootDevice;
|
||||||
|
fsType = "btrfs";
|
||||||
|
neededForBoot = true;
|
||||||
|
options = [
|
||||||
|
"subvol=persist"
|
||||||
|
];
|
||||||
};
|
};
|
||||||
"/boot" = {
|
"/boot" = {
|
||||||
device = "/dev/disk/by-uuid/B645-7527";
|
device = bootDevice;
|
||||||
fsType = "vfat";
|
fsType = "vfat";
|
||||||
|
options = [
|
||||||
|
"fmask=0077"
|
||||||
|
"dmask=0077"
|
||||||
|
];
|
||||||
};
|
};
|
||||||
"/mnt/storage" = {
|
"/mnt/storage" = {
|
||||||
device = "/dev/md0";
|
device = "/dev/md0";
|
||||||
|
|
@ -47,23 +50,91 @@ in
|
||||||
"x-systemd.device-timeout=10"
|
"x-systemd.device-timeout=10"
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
}
|
"/etc/ssh" = {
|
||||||
// (builtins.listToAttrs (
|
neededForBoot = true;
|
||||||
builtins.concatMap (drive: map (folder: sambaMounts drive folder) sambaFolders) sambaDrives
|
};
|
||||||
));
|
};
|
||||||
|
environment.persistence."/persist" = {
|
||||||
|
directories = [
|
||||||
|
"/var/cache"
|
||||||
|
"/var/lib"
|
||||||
|
{
|
||||||
|
directory = "/etc/ssh";
|
||||||
|
mode = "u=rwx,g=rx,o=rx";
|
||||||
|
user = "root";
|
||||||
|
}
|
||||||
|
];
|
||||||
|
hideMounts = true;
|
||||||
|
users.${user0} = {
|
||||||
|
directories = [
|
||||||
|
".cache"
|
||||||
|
".config"
|
||||||
|
".local/share/direnv"
|
||||||
|
".local/state/nix"
|
||||||
|
{
|
||||||
|
directory = ".ssh";
|
||||||
|
mode = "u=rwx,g=,o=";
|
||||||
|
}
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
boot = {
|
||||||
|
initrd.postResumeCommands = lib.mkAfter ''
|
||||||
|
mkdir /btrfs_tmp
|
||||||
|
mount -o subvolid=5 ${rootDevice} /btrfs_tmp
|
||||||
|
|
||||||
swapDevices = [
|
if [[ -e /btrfs_tmp/root ]]; then
|
||||||
{ device = "/dev/disk/by-uuid/9a2e032d-8627-49cf-8f3f-8fdf2be5fed4"; }
|
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
|
||||||
|
|
||||||
boot.swraid.enable = true;
|
delete_subvolume_recursively() {
|
||||||
boot.swraid.mdadmConf = ''
|
IFS=$'\n'
|
||||||
ARRAY /dev/md0 metadata=1.2 name=eris:storage UUID=64659038:a939a18d:8cdc0f3f:97171a50
|
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
|
||||||
|
'';
|
||||||
|
swraid.enable = true;
|
||||||
|
mdadmConf = ''
|
||||||
|
ARRAY /dev/md0 metadata=1.2 name=eris:storage UUID=64659038:a939a18d:8cdc0f3f:97171a50
|
||||||
|
'';
|
||||||
|
};
|
||||||
systemd.tmpfiles.rules = [
|
systemd.tmpfiles.rules = [
|
||||||
|
"Z ${config.home-manager.users.${user0}.home.homeDirectory} 0755 ${user0} users -"
|
||||||
"d /mnt/storage 2775 root root -"
|
"d /mnt/storage 2775 root root -"
|
||||||
];
|
];
|
||||||
|
|
||||||
services.udisks2.enable = true;
|
services.udisks2.enable = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# sudo mount /dev/disk/by-label/root /mnt
|
||||||
|
# sudo btrfs subvolume create /mnt/persist
|
||||||
|
# sudo btsfs subvolume create /mnt/rootDevice
|
||||||
|
# sudo btrfs subvolume create /mnt/nix
|
||||||
|
# sudo umount /mnt
|
||||||
|
|
||||||
|
# sudo mount -o subvol=root /dev/disk/by-label/root /mnt
|
||||||
|
|
||||||
|
# sudo mount -o subvol=nix /dev/disk/by-label/root /mnt/nix
|
||||||
|
# sudo mount -o subvol=persist /dev/disk/by-label/root /mnt/persist
|
||||||
|
|
||||||
|
# sudo mount /dev/disk/by-label/BOOT /mnt/boot
|
||||||
|
|
||||||
|
# sudo nixos-generate-config --root /mnt
|
||||||
|
|
||||||
|
# sudo nixos-install --root /mnt
|
||||||
|
|
||||||
|
# sudo nixos-enter --root /mnt
|
||||||
|
# nixos-rebuild boot
|
||||||
|
# exit
|
||||||
|
|
||||||
|
# sudo reboot
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue