-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathflake-utils.nix
114 lines (106 loc) · 3.53 KB
/
flake-utils.nix
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
102
103
104
105
106
107
108
109
110
111
112
113
114
{ self
, lib
, inputs
, fop-utils
, defaultNixpkgsConfig
, ...
}:
rec {
nixosModules = (import ./nixos/modules { inherit lib; });
homeManagerModules = (import ./home-manager/modules { inherit lib; });
homeSharedConfigs = (import ./home-manager/cfgs/shared { inherit lib; });
#region Home
mkHome = name:
{ extraModules ? [ ]
, graphicalModules ? [ ] # TODO: I actually hate everything about how this is done but I'm out of patience to fix this shit - hf future me :3
, specialArgs ? { }
}: {
"${name}" = { graphical ? false }: # Wrapper for requesting different variants
{ config, lib, pkgs, ... }@homeArgs:
let
baseArgs = {
inherit inputs fop-utils homeManagerModules; # Do NOT pass homeSharedConfigs through here or skibidi toilet will appear in your room at 3 AM
};
homeArgs' = { inherit config lib pkgs; } // homeArgs; # stupid but just to make sure nixd doesn't cry about unused arguments
fullArgs = baseArgs // homeArgs' // specialArgs;
sharedModules = [
homeManagerModules.mutability
homeManagerModules.nixgl
homeManagerModules.apparmor
inputs.chaotic.homeManagerModules.default
homeSharedConfigs.base
]
++ lib.lists.optional graphical homeSharedConfigs.base-graphical;
wrappedModules = builtins.map (mod: (mod fullArgs)) (
sharedModules
++ extraModules
++ lib.lists.optionals graphical graphicalModules
);
userModule = import ./home-manager/cfgs/${name} fullArgs;
graphicalModule = import ./home-manager/cfgs/${name}/graphical fullArgs;
in
{
imports =
wrappedModules
++ [ userModule ]
++ lib.lists.optional graphical graphicalModule;
home = lib.mkDefault {
username = name;
homeDirectory = "/home/${name}";
stateVersion = "23.05";
};
};
};
mkHomeConfiguration = name:
{ homeUser ? self.homeUsers.${name}
, variantArgs ? { }
, extraModules ? [ ]
, extraOverlays ? [ ]
, targetNixpkgs ? inputs.nixpkgs
, targetHomeManager ? inputs.home-manager
, system
}: {
"${name}" = targetHomeManager.lib.homeManagerConfiguration {
pkgs = import targetNixpkgs (
defaultNixpkgsConfig system {
extraOverlays = [
inputs.nixgl.overlay
]
++ extraOverlays;
}
);
modules = [ (homeUser variantArgs) ] ++ extraModules;
};
};
#region System
mkSystem = name:
{ extraModules ? [ ]
, extraOverlays ? [ ]
# TODO: Set up users arg
, targetNixpkgs ? inputs.nixpkgs-unstable
, targetHomeManager ? inputs.home-manager-unstable
, system
}:
{
"${name}" = targetNixpkgs.lib.nixosSystem {
inherit system;
modules = [
{
networking.hostName = name;
nixpkgs = defaultNixpkgsConfig system { inherit extraOverlays; };
}
./nixos/cfgs/base
./nixos/cfgs/${name}
targetHomeManager.nixosModules.home-manager
inputs.sops-nix.nixosModules.sops
inputs.chaotic.nixosModules.default
inputs.flake-programs-sqlite.nixosModules.programs-sqlite
]
++ extraModules;
specialArgs = {
inherit inputs fop-utils homeManagerModules homeSharedConfigs nixosModules;
inherit (self) homeUsers;
};
};
};
}