66 lines
1.4 KiB
Nix
66 lines
1.4 KiB
Nix
{ nixpkgs, nixpkgs-unstable, ... }:
|
|
let
|
|
# Set of environment specific modules
|
|
environments = {
|
|
"proxmox" = [
|
|
./configuration/proxmox-vm
|
|
];
|
|
};
|
|
generateDefaults = hosts: builtins.mapAttrs (name: {
|
|
hostNixpkgs ? nixpkgs,
|
|
system ? "x86_64-linux",
|
|
# pkgs is explicitly defined so that overlays for each host can easily be created
|
|
pkgs ? hostNixpkgs.legacyPackages.${system},
|
|
environment ? "proxmox",
|
|
site
|
|
}: {
|
|
inherit hostNixpkgs system pkgs environment site;
|
|
# define common and host modules and additionally add environment specific modules
|
|
modules = [
|
|
./configuration/common
|
|
./hosts/${name}
|
|
] ++ environments.${environment};
|
|
}) hosts;
|
|
in
|
|
generateDefaults {
|
|
hydra = {
|
|
hostNixpkgs = nixpkgs-unstable;
|
|
site = "vs";
|
|
};
|
|
iperf = {
|
|
site = "vs";
|
|
};
|
|
jackett = {
|
|
site = "vs";
|
|
};
|
|
jellyfin = {
|
|
hostNixpkgs = nixpkgs-unstable;
|
|
site = "vs";
|
|
};
|
|
netbox = {
|
|
site = "vs";
|
|
};
|
|
nextcloud = {
|
|
hostNixpkgs = nixpkgs-unstable;
|
|
site = "vs";
|
|
};
|
|
nitter = {
|
|
hostNixpkgs = nixpkgs-unstable;
|
|
site = "vs";
|
|
};
|
|
nixos-coturn = {
|
|
site = "vs";
|
|
};
|
|
tor-relay = {
|
|
site = "vs";
|
|
};
|
|
web-public-2 = {
|
|
hostNixpkgs = nixpkgs-unstable;
|
|
site = "vs";
|
|
};
|
|
web-nonpublic-linuxcrewd = {
|
|
hostNixpkgs = nixpkgs-unstable;
|
|
site = "vs";
|
|
};
|
|
}
|