-
Notifications
You must be signed in to change notification settings - Fork 0
/
flake.nix
103 lines (96 loc) · 3.44 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
100
101
102
103
{
inputs = {
nixpkgs.follows = "nixpkgs-unstable";
nixpkgs-stable.follows = "nixpkgs-24_05";
nixpkgs-unstable.url = "nixpkgs/nixos-unstable";
nixpkgs-24_05.url = "nixpkgs/nixos-24.05";
nixpkgs-23_11.url = "nixpkgs/nixos-23.11";
nixpkgs-23_05.url = "nixpkgs/nixos-23.05";
conch = {
url = "github:mibmo/conch";
inputs = {
nixpkgs.follows = "nixpkgs";
nixos-anywhere.follows = "nixos-anywhere";
};
};
deploy-rs.url = "github:serokell/deploy-rs";
agenix.url = "github:ryantm/agenix";
nixos-anywhere.url = "github:nix-community/nixos-anywhere";
disko.url = "github:nix-community/disko";
impermanence.url = "github:nix-community/impermanence";
nixos-hardware.url = "github:NixOS/nixos-hardware";
nix-fast-build.url = "github:Mic92/nix-fast-build";
conduit.url = "gitlab:famedly/conduit/next";
};
outputs = inputs@{ self, nixpkgs, conch, ... }:
let
lib = inputs.nixpkgs.lib // import ./lib.nix { inherit inputs; settings = config; };
config = import ./config.nix { inherit lib inputs; };
in
conch.load [
"x86_64-darwin"
"x86_64-linux"
]
({ system, pkgs, ... }: {
packages = [
inputs.agenix.packages.${system}.default
inputs.disko.packages.${system}.default
inputs.nix-fast-build.packages.${system}.default
pkgs.deploy-rs
pkgs.nixos-generators
];
development.python = {
enable = true;
package = pkgs.python311.withPackages (pkgs: with pkgs; [
braceexpand
]);
};
operations = {
terranix.enable = true;
nixos-anywhere.enable = true;
};
shellHook = ''
function _installers() {
installers="$(basename --multiple ${./installers}/* | awk '$1 !~ "base" { print }')"
COMPREPLY=($(compgen -W "$installers" -- ''${COMP_WORDS[$COMP_CWORD]}))
return 0
}
complete -F _installers build-image
'';
flake = {
nixosConfigurations = import ./hosts { inherit lib config; };
deploy = {
sshUser = "root";
sshOpts = [ "-p" "12248" ];
nodes = builtins.foldl'
(acc: machine: acc // {
${machine.name} =
let
deployPkgs = import nixpkgs {
system = machine.system;
overlays = [
inputs.deploy-rs.overlay
(self: super: {
deploy-rs = {
inherit (super.deploy-rs) lib;
deploy-rs =
if machine.system == pkgs.system
then pkgs.deploy-rs
else super.deploy-rs.deploy-rs;
};
})
];
};
in
{
hostname = "${machine.name}.kanpai";
profiles.system.path = deployPkgs.deploy-rs.lib.activate.nixos self.nixosConfigurations.${machine.name};
};
})
{ }
(lib.attrsets.collect (m: m ? name) config.machines);
};
checks = builtins.mapAttrs (system: deployLib: deployLib.deployChecks self.deploy) inputs.deploy-rs.lib;
};
});
}