diff options
Diffstat (limited to 'modules/shared/users')
| -rw-r--r-- | modules/shared/users/default.nix | 1 | ||||
| -rw-r--r-- | modules/shared/users/seth.nix | 48 |
2 files changed, 49 insertions, 0 deletions
diff --git a/modules/shared/users/default.nix b/modules/shared/users/default.nix new file mode 100644 index 0000000..df767b4 --- /dev/null +++ b/modules/shared/users/default.nix @@ -0,0 +1 @@ +{ imports = [ ./seth.nix ]; } diff --git a/modules/shared/users/seth.nix b/modules/shared/users/seth.nix new file mode 100644 index 0000000..89203c1 --- /dev/null +++ b/modules/shared/users/seth.nix @@ -0,0 +1,48 @@ +{ + config, + lib, + pkgs, + inputs, + ... +}: + +let + cfg = config.borealis.users.seth; + + inherit (pkgs.stdenv.hostPlatform) isDarwin isLinux; +in + +{ + options.borealis.users.seth = { + enable = lib.mkEnableOption "Seth's user & home configurations"; + }; + + config = lib.mkMerge [ + (lib.mkIf cfg.enable { + users.users.seth.shell = pkgs.fish; + + programs.fish.enable = true; + + home-manager.users.seth = { + imports = [ (inputs.self + "/users/seth") ]; + seth = { + enable = true; + programs.fish.enable = true; + }; + }; + }) + + (lib.mkIf (cfg.enable && isDarwin) { + users.users.seth = { + home = lib.mkDefault "/Users/seth"; + }; + }) + + (lib.mkIf (cfg.enable && isLinux) { + users.users.seth = { + extraGroups = [ "wheel" ]; + isNormalUser = true; + }; + }) + ]; +} |
