zaphyra's git: nixfiles

zaphyra's nixfiles

1 
2 
3 
4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
27 
28 
29 
30 
31 
32 
33 
34 
35 
36 
37 
38 
39 
40 
41 
42 
43 
44 
45 
46 
47 
48 
49 
50 
51 
52 
53 
54 
55 
56 
57 
58 
59 
60 
61 
62 
63 
64 
65 
66 
67 
68 
69 
70 
71 
72 
73 
74 
75 
76 
77 
78 
79 
80 
81 
82 
83 
84 
85 
86 
87 
88 
89 
90 
91 
92 
93 
94 
95 
96 
97 
98 
99 
100 
101 
{
  povSelf,
  config,
  lib,
  pkgs,
  ...
}:

let
  inherit (lib) types;
  cfg = lib.getAttrFromPath povSelf config;

in
{

  options = {
    enable = {
      type = types.bool;
      default = false;
    };
    greeter = {
      type = types.enum [
        "tuigreet"
      ];
      default = "tuigreet";
    };
    autoLogin = {
      enable = {
        type = types.bool;
        default = false;
      };
      user.type = types.str;
      command.type = types.str;
    };
  };

  config = lib.mkIf cfg.enable (
    lib.mkMerge [
      {
        security.pam.services.greetd = {
          fprintAuth = false; # This would break gnome-keyring auto unlocking
          fprintAuthSkipLidClose = false;
          enableGnomeKeyring = true;
        };

        services.greetd = {
          enable = true;
          settings = {
            default_session.user = "greeter";
          };
        };
      }
      (lib.mkIf cfg.autoLogin.enable {
        services.greetd.settings = {
          initial_session = {
            inherit (cfg.autoLogin) user command;
          };
        };
      })
      (lib.mkIf (cfg.greeter == "tuigreet") {
        modules.filesystem.impermanence.system.dirs = [
          {
            directory = "/var/cache/tuigreet";
            mode = "755";
            user = "greeter";
            group = "greeter";
          }
        ];

        systemd.tmpfiles.settings."greetd" = {
          "/var/cache/tuigreet" = {
            d = {
              mode = "755";
              user = "greeter";
              group = "greeter";
            };
          };
        };

        services.greetd.settings = {
          default_session = {
            command = lib.concatStringsSep " " [
              (lib.getExe pkgs.greetd.tuigreet)
              "--no-xsession-wrapper"
              "--remember"
              "--remember-session"
              "--time"
              "--user-menu"
              "--asterisks"
              "--power-shutdown"
              "'systemctl poweroff'"
              "--power-reboot"
              "'systemctl reboot'"
            ];
          };
        };
      })
    ]
  );

}