aboutsummaryrefslogtreecommitdiffstats
path: root/modules/nixos/sils/roles.nix
blob: 52bfb54b859ccd6dd61d2281bcc81c6a0a4f8c00 (plain) (blame)
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
{
  config,
  lib,
  ...
}: let
  roleCmp = string: config.role.sils == string;
in {
  config.sils =
    if roleCmp "laptop"
    then {
      apparmor.enable = lib.mkDefault true;
      basesystem.enable = lib.mkDefault true;
      bluetooth.enable = lib.mkDefault true;
      bootloader = lib.mkDefault "lanzaboote";
      disks.enable = lib.mkDefault true;
      gnome.enable = lib.mkDefault true;
      graphics.enable = lib.mkDefault true;
      environment.enable = lib.mkDefault true;
      firejail.enable = false;
      font.enable = lib.mkDefault true;
      hyprland.enable = lib.mkDefault true;
      impermanence.enable = lib.mkDefault true;
      networking.enable = lib.mkDefault true;
      nix-config.enable = lib.mkDefault true;
      pamconfig.enable = lib.mkDefault true;
      plasma.enable = lib.mkDefault false;
      plymouth.enable = lib.mkDefault true;
      printing.enable = lib.mkDefault true;
      sound.enable = lib.mkDefault true;
      steam.enable = lib.mkDefault true;
      sway.enable = lib.mkDefault false;
      theming.enable = lib.mkDefault true;
      tailscale = {
        enable = lib.mkDefault false;
        role = "client";
      };
      tor.enable = lib.mkDefault true;
    }
    else if roleCmp "laptop-light"
    then {
      apparmor.enable = lib.mkDefault true;
      basesystem.enable = lib.mkDefault true;
      bluetooth.enable = lib.mkDefault true;
      bootloader = lib.mkDefault "lanzaboote";
      disks.enable = lib.mkDefault true;
      graphics.enable = lib.mkDefault true;
      environment.enable = lib.mkDefault true;
      firejail.enable = false;
      font.enable = lib.mkDefault true;
      hyprland.enable = lib.mkDefault true;
      impermanence.enable = lib.mkDefault true;
      networking.enable = lib.mkDefault true;
      nix-config.enable = lib.mkDefault true;
      pamconfig.enable = lib.mkDefault true;
      plymouth.enable = lib.mkDefault false;
      printing.enable = lib.mkDefault true;
      sound.enable = lib.mkDefault true;
      sway.enable = lib.mkDefault false;
      theming.enable = lib.mkDefault true;
    }
    else if roleCmp "vm"
    then {}
    else if roleCmp "workstation"
    then {
      apparmor.enable = lib.mkDefault true;
      basesystem.enable = lib.mkDefault true;
      bluetooth.enable = lib.mkDefault true;
      bootloader = lib.mkDefault "lanzaboote";
      disks.enable = lib.mkDefault true;
      graphics.enable = lib.mkDefault true;
      environment.enable = lib.mkDefault true;
      firejail.enable = false;
      font.enable = lib.mkDefault true;
      hyprland.enable = lib.mkDefault true;
      impermanence.enable = lib.mkDefault true;
      networking.enable = lib.mkDefault true;
      nix-config.enable = lib.mkDefault true;
      pamconfig.enable = lib.mkDefault true;
      plymouth.enable = lib.mkDefault false;
      printing.enable = lib.mkDefault true;
      sound.enable = lib.mkDefault true;
      sway.enable = lib.mkDefault false;
      theming.enable = lib.mkDefault true;
    }
    else {};
}