nix-infra/flake.nix

103 lines
2.8 KiB
Nix
Raw Normal View History

2023-07-10 15:30:51 +02:00
{
inputs = {
2023-07-27 21:59:24 +02:00
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable-small";
2023-07-26 01:09:38 +02:00
nixos-generators = {
url = "github:nix-community/nixos-generators";
inputs.nixpkgs.follows = "nixpkgs";
};
2023-07-10 15:30:51 +02:00
};
2023-07-27 21:59:24 +02:00
outputs = { self, nixpkgs, nixos-generators, ... }@inputs: let
helper = (import ./helper.nix) inputs;
in {
hosts = {
2023-07-26 01:49:39 +02:00
hydra = {
site = "vs";
2023-07-10 15:30:51 +02:00
};
2023-07-26 01:49:39 +02:00
iperf = {
site = "vs";
};
2023-07-26 01:49:39 +02:00
jackett = {
site = "vs";
};
2023-07-26 01:49:39 +02:00
nitter = {
site = "vs";
2023-07-10 15:30:51 +02:00
};
2023-07-26 01:49:39 +02:00
nixos-coturn = {
site = "vs";
};
tor-relay = {
site = "vs";
};
2023-07-20 06:29:15 +02:00
web-public-2 = {
site = "vs";
};
};
2023-07-10 15:30:51 +02:00
2023-07-27 21:59:24 +02:00
generateColmenaHost = name: host: {
deployment = {
targetHost = "${name}.${host.site}.grzb.de";
targetUser = "colmena-deploy";
2023-07-10 15:30:51 +02:00
};
2023-07-15 23:29:19 +02:00
imports = [
./configuration/common
./configuration/proxmox-vm
2023-07-26 01:09:38 +02:00
./configuration/proxmox-vm/hardware-configuration.nix
./hosts/${name}
2023-07-27 21:59:24 +02:00
] ++ nixpkgs.lib.optional (builtins.pathExists ./hosts/${name}/secrets.nix) ./hosts/${name}/secrets.nix;
};
colmena = {
meta = {
nixpkgs = import nixpkgs {
system = "x86_64-linux";
2023-07-15 23:29:19 +02:00
};
};
} // builtins.mapAttrs (self.generateColmenaHost) self.hosts;
2023-07-27 21:59:24 +02:00
nixosConfigurations = nixpkgs.lib.mapAttrs (name: config: let
nodeNixpkgs = self.outputs.colmena.meta.nodeNixpkgs.${name} or self.outputs.colmena.meta.nixpkgs;
nodeNixos = import (nodeNixpkgs.path + "/nixos/lib/eval-config.nix");
in nodeNixos {
modules = [
2023-07-27 21:59:24 +02:00
#self.outputs.colmena.defaults
config
#inputs.colmena.nixosModules.deploymentOptions
{
_module.args.name = nixpkgs.lib.mkForce name;
_module.args.nodes = self.outputs.nixosConfigurations;
#nixpkgs.overlays = nixpkgs.lib.attrValues self.overlays;
}
];
2023-07-27 21:59:24 +02:00
inherit (nodeNixpkgs) system;
}
) (builtins.removeAttrs self.outputs.colmena ["meta" "defaults"]);
hydraJobs = {
nixosConfigurations = nixpkgs.lib.mapAttrs (_: config: config.config.system.build.toplevel) self.outputs.nixosConfigurations;
};
2023-07-26 01:09:38 +02:00
2023-07-27 21:59:24 +02:00
/*
nixosConfigurations = (builtins.mapAttrs (helper.mapToNixosConfigurations) self.hosts);
hydraJobs = {
nixConfigurations = helper.buildHosts self.nixosConfigurations;
};
*/
2023-07-26 01:09:38 +02:00
# Generate a base VM image for Proxmox with `nix build .#base-proxmox`
packages.x86_64-linux = {
base-proxmox = nixos-generators.nixosGenerate {
system = "x86_64-linux";
modules = [
./configuration/common
./configuration/nixos-generators
./configuration/proxmox-vm
];
format = "proxmox";
};
};
2023-07-27 21:59:24 +02:00
2023-07-10 15:30:51 +02:00
};
}