This repository has been archived by the owner on Nov 10, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
flake.nix
80 lines (69 loc) · 2.22 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
{
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable";
flake-utils.url = "github:numtide/flake-utils";
extra-container = {
url = "github:erikarvstedt/extra-container";
inputs.nixpkgs.follows = "nixpkgs";
inputs.flake-utils.follows = "flake-utils";
};
sops-nix = {
url = "github:Mic92/sops-nix";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs = { self, extra-container, nixpkgs, flake-utils, sops-nix, ... }@inputs:
let
localOverlay = final: prev: {
glorytun = final.callPackage ./packages/glorytun { };
mlvpn = final.callPackage ./packages/mlvpn { };
inherit inputs;
};
nixpkgsFor = system: import nixpkgs {
inherit system;
overlays = [
sops-nix.overlay
localOverlay
];
config = {
allowUnfreePredicate = pkg: builtins.elem (nixpkgs.lib.getName pkg) [
"unifi-controller"
"ookla-speedtest"
];
};
};
in
flake-utils.lib.eachSystem extra-container.lib.supportedSystems (system: {
overlay = localOverlay;
devShells.default = with (nixpkgsFor system); mkShell {
nativeBuildInputs = [
sops-import-keys-hook
];
sopsPGPKeyDirs = [
"./keys/hosts"
"./keys/users"
];
};
packages.default = extra-container.lib.buildContainers {
# The system of the container host
inherit system nixpkgs;
config.containers =
let
pkgs = nixpkgsFor system;
makeContainer = x: import x { inherit pkgs; };
buildContainerList = path:
let content = builtins.readDir path; in
builtins.listToAttrs (
builtins.map
(n:
{
name = nixpkgs.lib.removeSuffix ".nix" n;
value = makeContainer (path + ("/" + n));
})
(builtins.filter (n: builtins.match ".*\\.nix" n != null || builtins.pathExists (path + ("/" + n + "/default.nix"))) (builtins.attrNames content))
);
in
buildContainerList ./containers;
};
});
}