-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathflake.nix
99 lines (87 loc) · 2.45 KB
/
flake.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
{
description = "NixOS config flake";
inputs = {
nixpkgs = {
url = "github:nixos/nixpkgs/nixos-unstable";
};
sops-nix = {
url = "github:Mic92/sops-nix";
inputs.nixpkgs.follows = "nixpkgs";
};
disko = {
url = "github:nix-community/disko";
inputs.nixpkgs.follows = "nixpkgs";
};
lanzaboote = {
url = "github:nix-community/lanzaboote/v0.3.0";
inputs.nixpkgs.follows = "nixpkgs";
};
impermanence = {
url = "github:nix-community/impermanence";
};
nur = {
url = "github:nix-community/NUR";
};
home-manager = {
url = "github:nix-community/home-manager";
inputs.nixpkgs.follows = "nixpkgs";
};
code-insiders = {
url = "github:iosmanthus/code-insider-flake";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs = inputs @ {...}:
let
onInstallMedia = builtins.pathExists /home/nixos;
mkSystem = { entry, arch, extraModules, users, ... }:
inputs.nixpkgs.lib.nixosSystem {
system = arch;
specialArgs = {
inherit inputs;
inherit onInstallMedia;
};
modules = [
{
nix.settings.experimental-features = ["nix-command" "flakes"];
}
inputs.disko.nixosModules.disko
inputs.sops-nix.nixosModules.sops
inputs.nur.nixosModules.nur
inputs.home-manager.nixosModules.home-manager
entry
{
home-manager = {
extraSpecialArgs = {
inherit inputs;
inherit onInstallMedia;
};
useGlobalPkgs = true;
useUserPackages = true;
sharedModules = [
inputs.sops-nix.homeManagerModules.sops
inputs.nur.hmModules.nur
];
users = users;
};
}
] ++ extraModules;
};
in rec {
formatter.x86_64-linux = inputs.nixpkgs.legacyPackages.x86_64-linux.alejandra;
nixosConfigurations = {
feanor = mkSystem {
entry = ./host/feanor;
arch = "x86_64-linux";
extraModules = [
./module/disko/single-disk.nix
inputs.lanzaboote.nixosModules.lanzaboote
inputs.impermanence.nixosModules.impermanence
];
users = {
mahtaran = import ./user/mahtaran;
};
};
};
};
}