[nix] mv host declarations to hosts.nix, add util to host_builer.nix
This commit is contained in:
71
machines/hosts.nix
Normal file
71
machines/hosts.nix
Normal file
@@ -0,0 +1,71 @@
|
|||||||
|
{ ... }:
|
||||||
|
|
||||||
|
{
|
||||||
|
malobeo = {
|
||||||
|
hosts = {
|
||||||
|
louise = {
|
||||||
|
type = "host";
|
||||||
|
};
|
||||||
|
|
||||||
|
bakunin = {
|
||||||
|
type = "host";
|
||||||
|
};
|
||||||
|
|
||||||
|
fanny = {
|
||||||
|
type = "host";
|
||||||
|
};
|
||||||
|
|
||||||
|
lucia = {
|
||||||
|
type = "rpi";
|
||||||
|
};
|
||||||
|
|
||||||
|
durruti = {
|
||||||
|
type = "microvm";
|
||||||
|
network = {
|
||||||
|
address = "10.0.0.5";
|
||||||
|
mac = "52:DA:0D:F9:EF:F9";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
vpn = {
|
||||||
|
type = "microvm";
|
||||||
|
network = {
|
||||||
|
address = "10.0.0.10";
|
||||||
|
mac = "D0:E5:CA:F0:D7:E6";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
infradocs = {
|
||||||
|
type = "microvm";
|
||||||
|
network = {
|
||||||
|
address = "10.0.0.11";
|
||||||
|
mac = "D0:E5:CA:F0:D7:E7";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
uptimekuma = {
|
||||||
|
type = "microvm";
|
||||||
|
network = {
|
||||||
|
address = "10.0.0.12";
|
||||||
|
mac = "D0:E5:CA:F0:D7:E8";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
nextcloud = {
|
||||||
|
type = "microvm";
|
||||||
|
network = {
|
||||||
|
address = "10.0.0.13";
|
||||||
|
mac = "D0:E5:CA:F0:D7:E9";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
overwatch = {
|
||||||
|
type = "microvm";
|
||||||
|
network = {
|
||||||
|
address = "10.0.0.14";
|
||||||
|
mac = "D0:E5:CA:F0:D7:E0";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -1,71 +1,110 @@
|
|||||||
{ ... }:
|
{ self
|
||||||
|
, nixpkgs-unstable
|
||||||
|
, nixpkgs
|
||||||
|
, sops-nix
|
||||||
|
, inputs
|
||||||
|
, nixos-hardware
|
||||||
|
, home-manager
|
||||||
|
, ...
|
||||||
|
}:
|
||||||
|
|
||||||
{
|
rec {
|
||||||
malobeo = {
|
nixosSystem = nixpkgs.lib.makeOverridable nixpkgs.lib.nixosSystem;
|
||||||
hosts = {
|
nixosSystemUnstable = nixpkgs-unstable.lib.makeOverridable nixpkgs-unstable.lib.nixosSystem;
|
||||||
louise = {
|
|
||||||
type = "host";
|
baseModules = [
|
||||||
|
# make flake inputs accessiable in NixOS
|
||||||
|
{ _module.args.inputs = inputs; }
|
||||||
|
{
|
||||||
|
imports = [
|
||||||
|
({ pkgs, ... }: {
|
||||||
|
nix = {
|
||||||
|
extraOptions = ''
|
||||||
|
experimental-features = nix-command flakes
|
||||||
|
'';
|
||||||
|
|
||||||
|
settings = {
|
||||||
|
substituters = [
|
||||||
|
"https://cache.dynamicdiscord.de"
|
||||||
|
"https://cache.nixos.org/"
|
||||||
|
];
|
||||||
|
trusted-public-keys = [
|
||||||
|
"cache.dynamicdiscord.de:DKueZicqi2NhJJXz9MYgUbiyobMs10fTyHCgAUibRP4="
|
||||||
|
];
|
||||||
|
trusted-users = [ "root" "@wheel" ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
})
|
||||||
|
|
||||||
|
sops-nix.nixosModules.sops
|
||||||
|
];
|
||||||
|
}
|
||||||
|
];
|
||||||
|
defaultModules = baseModules;
|
||||||
|
|
||||||
|
makeMicroVM = hostName: ipv4Addr: macAddr: modules: [
|
||||||
|
inputs.microvm.nixosModules.microvm
|
||||||
|
{
|
||||||
|
microvm = {
|
||||||
|
hypervisor = "cloud-hypervisor";
|
||||||
|
mem = 2560;
|
||||||
|
shares = [
|
||||||
|
{
|
||||||
|
source = "/nix/store";
|
||||||
|
mountPoint = "/nix/.ro-store";
|
||||||
|
tag = "store";
|
||||||
|
proto = "virtiofs";
|
||||||
|
socket = "store.socket";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
source = "/var/lib/microvms/${hostName}/etc";
|
||||||
|
mountPoint = "/etc";
|
||||||
|
tag = "etc";
|
||||||
|
proto = "virtiofs";
|
||||||
|
socket = "etc.socket";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
source = "/var/lib/microvms/${hostName}/var";
|
||||||
|
mountPoint = "/var";
|
||||||
|
tag = "var";
|
||||||
|
proto = "virtiofs";
|
||||||
|
socket = "var.socket";
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
interfaces = [
|
||||||
|
{
|
||||||
|
type = "tap";
|
||||||
|
id = "vm-${hostName}";
|
||||||
|
mac = "${macAddr}";
|
||||||
|
}
|
||||||
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
bakunin = {
|
systemd.network.enable = true;
|
||||||
type = "host";
|
|
||||||
};
|
systemd.network.networks."20-lan" = {
|
||||||
|
matchConfig.Type = "ether";
|
||||||
fanny = {
|
networkConfig = {
|
||||||
type = "host";
|
Address = [ "${ipv4Addr}/24" ];
|
||||||
};
|
Gateway = "10.0.0.1";
|
||||||
|
DNS = ["1.1.1.1"];
|
||||||
lucia = {
|
DHCP = "no";
|
||||||
type = "rpi";
|
|
||||||
};
|
|
||||||
|
|
||||||
durruti = {
|
|
||||||
type = "microvm";
|
|
||||||
network = {
|
|
||||||
address = "10.0.0.5";
|
|
||||||
mac = "52:DA:0D:F9:EF:F9";
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
}
|
||||||
|
] ++ defaultModules ++ modules;
|
||||||
|
|
||||||
vpn = {
|
inputsMod = inputs // { malobeo = self; };
|
||||||
type = "microvm";
|
|
||||||
network = {
|
|
||||||
address = "10.0.0.10";
|
|
||||||
mac = "D0:E5:CA:F0:D7:E6";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
infradocs = {
|
buildHost = hosts: (builtins.mapAttrs (host: settings: nixosSystem {
|
||||||
type = "microvm";
|
system = if (settings.type == "rpi") then "aarch64-linux" else "x86_64-linux";
|
||||||
network = {
|
specialArgs.inputs = inputsMod;
|
||||||
address = "10.0.0.11";
|
modules = (if (settings.type != "microvm") then
|
||||||
mac = "D0:E5:CA:F0:D7:E7";
|
defaultModules ++ [ ../${host}/configuration.nix ]
|
||||||
};
|
else
|
||||||
};
|
makeMicroVM "${host}" "${settings.network.address}" "${settings.network.mac}" [
|
||||||
|
./${host}/configuration.nix
|
||||||
uptimekuma = {
|
]);
|
||||||
type = "microvm";
|
}) hosts);
|
||||||
network = {
|
|
||||||
address = "10.0.0.12";
|
|
||||||
mac = "D0:E5:CA:F0:D7:E8";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
nextcloud = {
|
|
||||||
type = "microvm";
|
|
||||||
network = {
|
|
||||||
address = "10.0.0.13";
|
|
||||||
mac = "D0:E5:CA:F0:D7:E9";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
overwatch = {
|
|
||||||
type = "microvm";
|
|
||||||
network = {
|
|
||||||
address = "10.0.0.14";
|
|
||||||
mac = "D0:E5:CA:F0:D7:E0";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user