2023-11-15 12:06:59 +00:00
|
|
|
{
|
|
|
|
jefke = {
|
2024-01-28 10:48:13 +00:00
|
|
|
type = "physical";
|
2023-12-17 15:22:22 +00:00
|
|
|
|
2024-01-28 11:55:58 +00:00
|
|
|
nixosModule = {
|
|
|
|
lab = {
|
|
|
|
terraformDatabase.enable = true;
|
|
|
|
|
|
|
|
storage = {
|
|
|
|
osDisk = "/dev/sda";
|
|
|
|
dataPartition = "/dev/nvme0n1p1";
|
|
|
|
};
|
|
|
|
|
|
|
|
ssh = {
|
|
|
|
useCertificates = true;
|
|
|
|
# TODO: automatically set this?
|
|
|
|
hostCert = builtins.readFile ./jefke_host_ed25519-cert.pub;
|
|
|
|
userCert = builtins.readFile ./jefke_user_ed25519-cert.pub;
|
|
|
|
};
|
2023-11-25 20:00:21 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2023-11-29 16:21:18 +00:00
|
|
|
atlas = {
|
2024-01-28 10:48:13 +00:00
|
|
|
type = "physical";
|
2023-11-25 20:00:21 +00:00
|
|
|
|
2024-01-30 21:32:09 +00:00
|
|
|
nixosModule.lab = {
|
|
|
|
storage = {
|
|
|
|
osDisk = "/dev/sda";
|
|
|
|
dataPartition = "/dev/nvme0n1p1";
|
|
|
|
};
|
|
|
|
|
|
|
|
ssh = {
|
|
|
|
useCertificates = true;
|
|
|
|
hostCert = builtins.readFile ./atlas_host_ed25519-cert.pub;
|
|
|
|
userCert = builtins.readFile ./atlas_user_ed25519-cert.pub;
|
2023-11-29 16:21:18 +00:00
|
|
|
};
|
2024-01-30 21:32:09 +00:00
|
|
|
};
|
2023-11-15 12:06:59 +00:00
|
|
|
};
|
2023-12-17 15:22:22 +00:00
|
|
|
|
2023-12-25 18:22:22 +00:00
|
|
|
lewis = {
|
2024-01-28 10:48:13 +00:00
|
|
|
type = "physical";
|
2023-12-25 18:22:22 +00:00
|
|
|
|
2024-01-30 21:32:09 +00:00
|
|
|
nixosModule.lab = {
|
|
|
|
dataHost.enable = true;
|
2023-12-25 18:22:22 +00:00
|
|
|
|
2024-01-30 21:32:09 +00:00
|
|
|
storage = {
|
|
|
|
osDisk = "/dev/sda";
|
|
|
|
dataPartition = "/dev/nvme0n1p1";
|
|
|
|
};
|
2024-01-17 20:28:15 +00:00
|
|
|
|
2024-01-30 21:32:09 +00:00
|
|
|
ssh = {
|
|
|
|
useCertificates = true;
|
|
|
|
hostCert = builtins.readFile ./lewis_host_ed25519-cert.pub;
|
|
|
|
userCert = builtins.readFile ./lewis_user_ed25519-cert.pub;
|
2023-12-25 18:22:22 +00:00
|
|
|
};
|
2024-01-28 10:48:13 +00:00
|
|
|
};
|
|
|
|
};
|
2023-12-25 18:22:22 +00:00
|
|
|
|
2024-01-28 10:48:13 +00:00
|
|
|
my-microvm = {
|
|
|
|
type = "virtual";
|
|
|
|
hypervisorName = "lewis";
|
2024-01-17 20:28:15 +00:00
|
|
|
|
2024-01-28 12:57:36 +00:00
|
|
|
nixosModule = { pkgs, ... }: {
|
2024-01-30 21:32:09 +00:00
|
|
|
# TODO: would be cool to create a check that a mac address is only ever assigned to one VM.
|
|
|
|
lab.vm.macAddress = "BA:DB:EE:F0:00:00";
|
2024-01-28 12:57:36 +00:00
|
|
|
|
2024-01-28 10:48:13 +00:00
|
|
|
programs.bash.interactiveShellInit = ''
|
2024-01-28 11:30:13 +00:00
|
|
|
echo "Hello world from inside a virtual machine!!" | ${pkgs.lolcat}/bin/lolcat
|
2024-01-28 10:48:13 +00:00
|
|
|
'';
|
2023-12-25 18:22:22 +00:00
|
|
|
};
|
|
|
|
};
|
2024-01-29 21:21:15 +00:00
|
|
|
|
|
|
|
hermes = {
|
|
|
|
type = "virtual";
|
|
|
|
hypervisorName = "lewis";
|
2024-01-30 21:32:09 +00:00
|
|
|
|
|
|
|
nixosModule = { config, ... }: {
|
2024-01-29 21:21:15 +00:00
|
|
|
lab = {
|
2024-01-31 20:58:23 +00:00
|
|
|
networking.dmz.services.enable = true;
|
2024-01-30 21:32:09 +00:00
|
|
|
|
|
|
|
vm = {
|
|
|
|
macAddress = "BA:DB:EE:F0:00:07";
|
|
|
|
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-01-30 21:32:09 +00:00
|
|
|
};
|
2024-01-29 21:21:15 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
2023-11-15 12:06:59 +00:00
|
|
|
}
|