multi-user toggle init

This commit is contained in:
Danilo Reyes
2026-01-16 10:19:36 -06:00
parent 597f9ee5b8
commit 4e835aca1b
31 changed files with 304 additions and 119 deletions

View File

@@ -11,7 +11,10 @@ in
{
options.my.shell.tools.enable = lib.mkEnableOption "shell tools and utilities";
config = lib.mkIf config.my.shell.tools.enable {
home-manager.users.jawz.programs = {
home-manager.users = let
users = if lib.isString config.my.toggleUsers.shell then [ config.my.toggleUsers.shell ] else config.my.toggleUsers.shell;
in lib.mkMerge (map (user: {
${user}.programs = {
hstr.enable = true;
htop = {
enable = true;
@@ -52,7 +55,7 @@ in
PASSWORD_STORE_NOPAGER = "false";
PASSWORD_STORE_NOTIFICATIONS = "false";
PASSWORD_STORE_PARSING = "true";
PASSWORD_STORE_PATH = "/home/jawz/.local/share/pass";
PASSWORD_STORE_PATH = "/home/${user}/.local/share/pass";
PASSWORD_STORE_SAFECONTENT = "true";
};
};
@@ -84,7 +87,8 @@ in
source "$(fzf-share)/completion.bash"
fi
'';
};
};
}) users);
programs = {
starship.enable = true;
tmux.enable = true;
@@ -94,7 +98,9 @@ in
vimAlias = true;
};
};
users.users.jawz.packages = builtins.attrValues {
users.users = let
users = if lib.isString config.my.toggleUsers.shell then [ config.my.toggleUsers.shell ] else config.my.toggleUsers.shell;
packages = builtins.attrValues {
inherit (pkgs)
ripgrep # modern grep
dust # rusty du similar to gdu
@@ -108,7 +114,10 @@ in
smartmontools # check hard drie health
rmlint # amazing dupe finder that integrates well with BTRFS
;
};
};
in lib.mkMerge (map (user: {
${user}.packages = packages;
}) users);
environment.variables = {
HISTFILE = "\${XDG_STATE_HOME}/bash/history";
LESSHISTFILE = "-";