feat(user): add app user capability

This commit is contained in:
514fpv 2024-01-07 21:51:34 +08:00
parent ec8116dd92
commit 010130cd69
Signed by: koishi
SSH key fingerprint: SHA256:axz0uIzzY+5W19i7QOUuiw5LSqhKfCBKPf3L4xFRxLw
2 changed files with 20 additions and 9 deletions

View file

@ -43,13 +43,8 @@ in {
description = "home manager modules imported into every profile"; description = "home manager modules imported into every profile";
}; };
home = { home = let
size = mkOption { persistOpts = {
type = with types; str;
default = "1G";
description = "default home tmpfs size, mounted to prevent accidentally filling up root";
};
persist = {
files = mkOption { files = mkOption {
type = with types; listOf (oneOf [ str (attrsOf str) ]); type = with types; listOf (oneOf [ str (attrsOf str) ]);
default = [ ]; default = [ ];
@ -59,6 +54,14 @@ in {
default = [ ]; default = [ ];
}; };
}; };
in {
size = mkOption {
type = with types; str;
default = "1G";
description = "default home tmpfs size, mounted to prevent accidentally filling up root";
};
persist = persistOpts;
persistApp = persistOpts;
}; };
}; };
@ -132,12 +135,15 @@ in {
# set up standard persistence for users # set up standard persistence for users
# this is registered internally for each software's configuration # this is registered internally for each software's configuration
environment.persistence."/nix/persist" = { environment.persistence."/nix/persist" = {
users = mapAttrs (name: _: cfg.home.persist // { users = (mapAttrs (name: _: cfg.home.persist // {
# root workaround, ugly but necessary # root workaround, ugly but necessary
# cannot get it properly for the same reason # cannot get it properly for the same reason
# mentioned above in fileSystems # mentioned above in fileSystems
home = mkIf (name == "root") "/root"; home = mkIf (name == "root") "/root";
}) cfg.profiles; }) cfg.profiles) // {
# extra persistence specific to the app user
app = cfg.home.persistApp;
};
hideMounts = true; hideMounts = true;
}; };

View file

@ -12,6 +12,11 @@
description = "Staging Environment"; description = "Staging Environment";
}; };
app = {
uid = 5800;
description = "Insecure Applications";
};
root.uid = 0; root.uid = 0;
}; };
} }