tmpfs root for x2100-laptop

This commit is contained in:
Alexander Bantyev 2021-06-08 19:35:21 +03:00
parent a4874b7976
commit 4ce902b536
Signed by: balsoft
GPG Key ID: E081FF12ADCB4AD5
25 changed files with 234 additions and 28 deletions

16
flake.lock generated
View File

@ -237,6 +237,21 @@
"type": "github"
}
},
"impermanence": {
"locked": {
"lastModified": 1611747548,
"narHash": "sha256-2z5wmWda1uI4IkTZrW52jiHq3bzhYLc+GgjvaSd544M=",
"owner": "nix-community",
"repo": "impermanence",
"rev": "58558845bc68dcf2bb32caa80564f7fe3f6cbc61",
"type": "github"
},
"original": {
"owner": "nix-community",
"repo": "impermanence",
"type": "github"
}
},
"lambda-launcher": {
"inputs": {
"nixpkgs": "nixpkgs_5"
@ -523,6 +538,7 @@
"flake-compat": "flake-compat_2",
"himalaya": "himalaya",
"home-manager": "home-manager",
"impermanence": "impermanence",
"lambda-launcher": "lambda-launcher",
"materia-theme": "materia-theme",
"nix": "nix",

View File

@ -52,6 +52,7 @@
flake = false;
};
himalaya.url = "github:soywod/himalaya";
impermanence.url = "github:nix-community/impermanence";
};
outputs = { nixpkgs, nix, self, deploy-rs, ... }@inputs: {

View File

@ -1,5 +1,8 @@
{ inputs, lib, config, pkgs, ... }: {
imports = [ ./hardware-configuration.nix inputs.self.nixosProfiles.desktop ];
imports = [
./hardware-configuration.nix
inputs.self.nixosProfiles.desktop
];
deviceSpecific.devInfo = {
cpu = {
vendor = "intel";
@ -13,12 +16,19 @@
};
ram = 16;
};
home-manager.users.balsoft.xdg.configFile."simple-osd/brightness".text = pkgs.my-lib.genIni {
default = {
"backlight backend" = "/sys/class/backlight/intel_backlight";
"refresh interval" = 100;
};
persist = {
enable = true;
cache.clean.enable = true;
};
home-manager.users.balsoft.xdg.configFile."simple-osd/brightness".text =
pkgs.my-lib.genIni {
default = {
"backlight backend" = "/sys/class/backlight/intel_backlight";
"refresh interval" = 100;
};
};
boot.extraModprobeConfig = ''
options iwlwifi bt_coex_active=0
'';

View File

@ -13,9 +13,10 @@
boot.kernelModules = [ "kvm-intel" ];
boot.extraModulePackages = [ ];
fileSystems."/" = {
fileSystems."/persist" = {
device = "/dev/disk/by-uuid/e50bd1d6-3613-465e-895a-9dde6ffaad46";
fsType = "ext4";
neededForBoot = true;
};
fileSystems."/boot" = {

View File

@ -15,6 +15,8 @@ in {
# directory = "emacs";
# };
persist.state.homeFiles = [ ".config/emacs/custom" ".config/emacs/eshell/history" ];
home-manager.users.balsoft = {
programs.emacs = {
enable = true;
@ -78,11 +80,6 @@ in {
systemd.user.services.emacs.Service.Environment =
"PATH=/run/current-system/sw/bin:/etc/profiles/per-user/balsoft/bin";
home.file.".emacs.d/init.el".source = ./init.el;
home.activation.emacs = {
before = [ ];
after = [ ];
data = "$DRY_RUN_CMD mkdir -p ~/.emacs.d/autosave";
};
xdg.configFile."emacs/init.el".source = ./init.el;
};
}

View File

@ -23,12 +23,6 @@
(line-number-mode)
(column-number-mode)
;; backup in one place. flat, no tree structure
(setq backup-directory-alist '(("" . "~/.emacs.d/backup")))
(setq auto-save-file-name-transforms
`((".*" "~/.emacs.d/autosave/" t)))
(setq-default indent-tabs-mode nil)
(setq-default tab-always-indent 't)

View File

@ -6,6 +6,9 @@ in {
MOZ_DBUS_REMOTE = "1";
};
programs.browserpass.enable = true;
persist.state.directories = [ "/home/balsoft/.mozilla/firefox/default" ];
home-manager.users.balsoft = lib.mkIf (config.deviceSpecific.goodMachine) {
programs.browserpass = {
enable = true;

View File

@ -54,6 +54,9 @@ let
};
in {
programs.geary.enable = true;
persist.cache.directories = [ "/home/balsoft/.local/share/geary" ];
home-manager.users.balsoft = {
xdg.configFile."geary/user-style.css".text = ''
*, html, body, body.plain div, body.plain a, body.plain p, body.plain span {

View File

@ -0,0 +1,8 @@
{ config, pkgs, lib, ... }:
{
home-manager.users.balsoft.home.packages = [ pkgs.nheko ];
persist.state.directories = [
"/home/balsoft/.local/share/nheko"
"/home/balsoft/.config/nheko"
];
}

View File

@ -17,7 +17,6 @@
github-cli
# Messaging
libnotify
nheko
# Audio/Video
vlc
pavucontrol
@ -32,7 +31,7 @@
gnumeric
gcalcli
xdg_utils
inputs.yt-utilities.defaultPackage.x86_64-linux
# inputs.yt-utilities.defaultPackage.x86_64-linux
lambda-launcher
nix-patch
pass-wayland

View File

@ -19,4 +19,5 @@
kernel.sysctl."vm.swappiness" = 0;
kernel.sysctl."kernel/sysrq" = 1;
};
persist.state.etcFiles = [ "machine-id" ];
}

View File

@ -11,6 +11,7 @@ builtins.listToAttrs (builtins.map (path: {
./applications/firefox.nix
./applications/geary.nix
./applications/himalaya.nix
./applications/nheko.nix
./applications/okular.nix
./applications/packages.nix
./applications/yt-utilities.nix
@ -21,6 +22,7 @@ builtins.listToAttrs (builtins.map (path: {
./network.nix
./nix.nix
./overlay.nix
./persist.nix
./power.nix
./secrets-envsubst.nix
./secrets.nix

View File

@ -51,6 +51,7 @@ in {
"\\x3d"
] cfg.serverKey
}".wantedBy = lib.mkForce [ ];
networking.wireguard.interfaces.wg0 = let
generateRangesScript =
builtins.toFile "exclusionary-wildcard-ranges-generator.py" ''

View File

@ -12,6 +12,8 @@ with deviceSpecific; {
hardware.bluetooth.enable = true;
hardware.bluetooth.package = pkgs.bluezFull;
persist.state.directories = [ "/var/lib/bluetooth" ];
systemd.services.systemd-udev-settle.enable = false;

View File

@ -24,6 +24,9 @@ in {
usePredictableInterfaceNames = false;
hostName = config.device;
};
persist.state.directories = [ "/etc/NetworkManager/system-connections" ];
networking.firewall.trustedInterfaces = [ "eth0" ];
systemd.services.ModemManager.wantedBy =
lib.optional (config.device == "T490s-Laptop") "network.target";

View File

@ -22,6 +22,9 @@
'';
requireSignedBinaryCaches = true;
};
persist.state.homeFiles = [ ".local/share/nix/repl-history" ];
environment.etc.nixpkgs.source = inputs.nixpkgs;
environment.etc.self.source = inputs.self;
}

133
modules/persist.nix Normal file
View File

@ -0,0 +1,133 @@
{ config, pkgs, lib, inputs, ... }:
let
cfg = config.persist;
takeAll = what: builtins.concatMap (x: x.${what});
persists = with cfg; [ state derivative cache ];
absoluteHomeFiles = map (x: "${cfg.homeDir}/${x}");
allHomeFiles = takeAll "homeFiles" persists;
absoluteEtcFiles = map (x: "/etc/${x}");
allEtcFiles = absoluteEtcFiles (takeAll "etcFiles" persists);
allDirectories = takeAll "directories" persists;
in {
options = with lib;
with types;
let
common = {
directories = mkOption {
type = listOf path;
default = [ ];
};
etcFiles = mkOption {
type = listOf str;
default = [ ];
};
homeFiles = mkOption {
type = listOf str;
default = [ ];
};
};
in {
persist = {
enable = mkEnableOption "a tmpfs root with explicit opt-in state";
persistRoot = mkOption {
type = path;
default = "/persist";
};
homeDir = mkOption {
type = path;
default = "/home/balsoft";
};
# Stuff that matters
# TODO backups of this stuff
state = {
# backup = {...};
} // common;
# Stuff that can be computed from declarative+state, but is never invalidated (so shouldn't be cleaned up)
derivative = common;
# Stuff that's just there to speed up the system
# It's cleaned up regularly, to solve the cache invalidation problem once and for all
cache = {
clean = {
enable = mkEnableOption "cleaning the cache files and directories";
dates = mkOption {
type = str;
default = "weekly";
description =
"A systemd.time calendar description of when to clean the cache files";
};
};
} // common;
};
};
imports = [
inputs.impermanence.nixosModules.impermanence
# Eugh
(let
module = (import "${inputs.impermanence}/home-manager.nix" {
inherit pkgs lib;
config = lib.recursiveUpdate config.home-manager.users.balsoft {
home.persistence."${cfg.persistRoot}${cfg.homeDir}" = {
directories = [ ];
files = allHomeFiles;
allowOther = false;
removePrefixDirectory = false;
};
};
});
in {
config.home-manager.users.balsoft = lib.mkIf cfg.enable module.config;
})
];
config = lib.mkIf cfg.enable {
environment.persistence.${cfg.persistRoot} = {
directories = allDirectories;
files = allEtcFiles;
};
fileSystems."/" = {
device = "none";
options = [ "defaults" "size=4G" "mode=755" ];
fsType = "tmpfs";
};
boot.initrd.postMountCommands = assert
config.fileSystems ? ${cfg.persistRoot}
&& config.fileSystems.${cfg.persistRoot}.neededForBoot;
''
mkdir -p /mnt-root/nix
mount --bind /mnt-root${cfg.persistRoot}/nix /mnt-root/nix
chmod 755 /mnt-root
'';
# Euuuugh
systemd.services.persist-cache-cleanup = lib.mkIf cfg.cache.clean.enable {
description = "Cleaning up cache files and directories";
script = ''
${builtins.concatStringsSep "\n" (map (x: "rm ${lib.escapeShellArg x}")
(absoluteEtcFiles cfg.cache.etcFiles
++ absoluteHomeFiles cfg.cache.homeFiles))}
${builtins.concatStringsSep "\n"
(map (x: "rm -rf ${lib.escapeShellArg x}") cfg.cache.directories)}
'';
startAt = cfg.cache.clean.dates;
};
};
}

View File

@ -124,6 +124,9 @@ in {
}];
}];
config.persist.derivative.directories =
[ "/var/secrets" "/home/balsoft/.password-store" ];
config.home-manager.users.balsoft = {
wayland.windowManager.sway = {
config.startup = [{ command = "activate-secrets"; }];

View File

@ -15,11 +15,21 @@
environment.sessionVariables.XDG_CURRENT_DESKTOP = "X-Generic";
persist.state.directories = map (x: "/home/balsoft/${x}") [
"Pictures"
"Documents"
"Downloads"
"Music"
"projects"
"Videos"
];
services.gvfs.enable = true;
services.geoclue2.enable = true;
home-manager.users.balsoft = {
xdg.userDirs.enable = true;
home.activation.gnome = ''
$DRY_RUN_CMD mkdir -p "$XDG_DATA_HOME/keyrings"
$DRY_RUN_CMD ln -sf ${config.secrets-envsubst.gnome-keyring} "$XDG_DATA_HOME/keyrings/Default_keyring.keyring"

View File

@ -2,6 +2,8 @@
services.pcscd.enable = true;
services.udev.packages = [ pkgs.yubikey-personalization ];
persist.derivative.directories = [ "/home/balsoft/.local/share/gnupg" ];
home-manager.users.balsoft = {
services.gpg-agent = {
enable = true;

View File

@ -29,6 +29,8 @@
home.stateVersion = "20.09";
};
services.avahi.enable = true;
system.stateVersion = "18.03";

View File

@ -8,6 +8,13 @@
ports = [ 22 ];
};
persist.state.etcFiles = [
"ssh/ssh_host_ed25519_key"
"ssh/ssh_host_ed25519_key.pub"
"ssh/ssh_host_rsa_key"
"ssh/ssh_host_rsa_key.pub"
];
users.users.balsoft.openssh.authorizedKeys.keys =
["ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDd2OdcSHUsgezuV+cpFqk9+Svtup6PxIolv1zokVZdqvS8qxLsA/rwYmQgTnuq4/zK/GIxcUCH4OxYlW6Or4M4G7qrDKcLAUrRPWkectqEooWRflZXkfHduMJhzeOAsBdMfYZQ9024GwKr/4yriw2BGa8GbbAnQxiSeTipzvXHoXuRME+/2GsMFAfHFvxzXRG7dNOiLtLaXEjUPUTcw/fffKy55kHtWxMkEvvcdyR53/24fmO3kLVpEuoI+Mp1XFtX3DvRM9ulgfwZUn8/CLhwSLwWX4Xf9iuzVi5vJOJtMOktQj/MwGk4tY/NPe+sIk+nAUKSdVf0y9k9JrJT98S/ comment"];

View File

@ -2,6 +2,9 @@
environment.pathsToLink = [ "/share/zsh" ];
environment.sessionVariables.SHELL = "zsh";
persist.state.homeFiles = [ ".zsh_history" ];
home-manager.users.balsoft.programs.zsh = {
enable = true;
enableAutosuggestions = true;

View File

@ -6,16 +6,17 @@
secrets
secrets-envsubst
locale
network
overlay
devices
nix
security
ssh
git
gpg
zsh
locale
misc
network
nix
overlay
persist
security
ssh
zsh
];
}

View File

@ -14,6 +14,7 @@
firefox
geary
himalaya
nheko
packages
yt-utilities