nixos-servers/nixos/machines/default.nix

128 lines
2.7 KiB
Nix
Raw Normal View History

{
atlas = {
type = "physical";
nixosModule.lab = {
storage = {
osDisk = "/dev/sda";
dataPartition = "/dev/nvme0n1p1";
};
ssh = {
useCertificates = true;
hostCert = builtins.readFile ./certificates/atlas/host_ed25519.crt;
userCert = builtins.readFile ./certificates/atlas/user_ed25519.crt;
};
};
};
jefke = {
2024-01-28 10:48:13 +00:00
type = "physical";
nixosModule = {
lab = {
terraformDatabase.enable = true;
storage = {
osDisk = "/dev/sda";
dataPartition = "/dev/nvme0n1p1";
};
ssh = {
useCertificates = true;
hostCert = builtins.readFile ./certificates/jefke/host_ed25519.crt;
userCert = builtins.readFile ./certificates/jefke/user_ed25519.crt;
};
};
};
};
lewis = {
2024-01-28 10:48:13 +00:00
type = "physical";
nixosModule.lab = {
backups.enable = true;
data-sharing.enable = true;
networking.dmz.allowConnectivity = true;
storage = {
osDisk = "/dev/sda";
dataPartition = "/dev/nvme0n1p1";
};
2024-01-17 20:28:15 +00:00
ssh = {
useCertificates = true;
hostCert = builtins.readFile ./certificates/lewis/host_ed25519.crt;
userCert = builtins.readFile ./certificates/lewis/user_ed25519.crt;
};
2024-01-28 10:48:13 +00:00
};
};
2024-02-06 21:03:25 +00:00
# TODO: make leases persistent!
2024-01-29 21:21:15 +00:00
hermes = {
type = "virtual";
hypervisorName = "lewis";
nixosModule = { config, ... }: {
2024-01-29 21:21:15 +00:00
lab = {
2024-01-31 20:58:23 +00:00
networking.dmz.services.enable = true;
vm = {
# TODO: would be cool to create a check that a mac address is only ever assigned to one VM.
id = 7;
staticNetworking = true;
2024-01-31 20:58:23 +00:00
staticIPv4 = config.lab.networking.dmz.ipv4.services;
staticIPv6 = config.lab.networking.dmz.ipv6.services;
2024-02-07 22:15:48 +00:00
shares = [{
name = "dnsmasq";
mountPoint = "/var/lib/dnsmasq";
}];
};
2024-01-29 21:21:15 +00:00
};
};
};
maestro2 = {
type = "virtual";
2024-02-06 21:03:25 +00:00
hypervisorName = "atlas";
nixosModule = { pkgs, lib, config, ... }: {
2024-02-07 22:15:48 +00:00
lab = {
dockerSwarm.enable = true;
2024-02-07 22:15:48 +00:00
vm = {
id = 1;
staticNetworking = true;
staticIPv4 = "192.168.30.42";
staticIPv6 = "2a0d:6e00:1a77:30::42";
};
};
};
};
bancomart2 = {
type = "virtual";
2024-02-06 21:03:25 +00:00
hypervisorName = "jefke";
nixosModule = { pkgs, lib, config, ... }: {
2024-02-07 22:15:48 +00:00
lab = {
dockerSwarm.enable = true;
vm.id = 2;
2024-02-06 21:03:25 +00:00
};
};
};
vpay2 = {
type = "virtual";
hypervisorName = "lewis";
nixosModule = { pkgs, lib, config, ... }: {
2024-02-07 22:15:48 +00:00
lab = {
dockerSwarm.enable = true;
vm.id = 3;
};
};
};
}