-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathflake.nix
99 lines (81 loc) · 2.25 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 = "My NixOS configuration";
inputs = {
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
archix = {
inputs.nixpkgs.follows = "nixpkgs";
url = "github:SamLukeYes/archix";
};
deploy-rs = {
inputs.nixpkgs.follows = "nixpkgs";
url = "github:serokell/deploy-rs";
};
flake-utils-plus.url = "github:gytis-ivaskevicius/flake-utils-plus";
nix-index-database = {
inputs.nixpkgs.follows = "nixpkgs";
url = "github:nix-community/nix-index-database";
};
};
outputs = { self, nixpkgs, flake-utils-plus, ... }@inputs:
let
system = "x86_64-linux";
channel-patches = [
# Add nixpkgs patches here
];
in flake-utils-plus.lib.mkFlake rec {
inherit self inputs;
supportedSystems = [ system ];
channels = {
nixos-unstable = {
input = nixpkgs;
patches = channel-patches;
};
};
hostDefaults = {
inherit system;
channelName = "nixos-unstable";
specialArgs = { inherit system; };
modules = [
{
nix = {
generateNixPathFromInputs = true;
generateRegistryFromInputs = true;
linkInputs = true;
};
}
inputs.nix-index-database.nixosModules.nix-index
{ programs.nix-index-database.comma.enable = true; }
./common.nix
];
};
hosts = {
azure.modules = [
inputs.archix.nixosModules.default
./programs/pacman.nix
./machines/azure.nix
];
bandwagon.modules = [
./machines/bandwagon/configuration.nix
];
};
checks = builtins.mapAttrs (system: deployLib: deployLib.deployChecks self.deploy) inputs.deploy-rs.lib;
deploy.nodes = {
azure = {
hostname = "azure";
profiles.system = {
path = inputs.deploy-rs.lib.${system}.activate.nixos self.nixosConfigurations.azure;
sshUser = "azureuser";
user = "root";
};
};
bandwagon = {
hostname = "bandwagon";
profiles.system = {
path = inputs.deploy-rs.lib.${system}.activate.nixos self.nixosConfigurations.bandwagon;
sshUser = "root";
};
};
};
nixosModules.synced = import ./services/synced;
};
}