2023-07-01 09:46:19 -07:00
|
|
|
|
{ config, pkgs, ... }:
|
|
|
|
|
|
2023-12-09 08:32:28 -08:00
|
|
|
|
let
|
|
|
|
|
targetUser = "nixos";
|
|
|
|
|
targetPort = 2222;
|
|
|
|
|
in
|
2023-07-01 09:46:19 -07:00
|
|
|
|
{
|
2023-11-19 09:06:53 -08:00
|
|
|
|
imports =
|
|
|
|
|
[ # Include the results of the hardware scan.
|
|
|
|
|
./hardware-configuration.nix
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
boot.loader.grub.enable = true;
|
2023-07-01 09:46:19 -07:00
|
|
|
|
boot.kernelModules = [ "kvm-intel" ];
|
|
|
|
|
system.stateVersion = "22.11";
|
|
|
|
|
|
2023-11-19 09:06:53 -08:00
|
|
|
|
# Options above are generate by running nixos-generate-config on the VM.
|
|
|
|
|
|
|
|
|
|
# Needed otherwise deploy will say system won't be able to boot.
|
|
|
|
|
boot.loader.grub.device = "/dev/vdb";
|
2023-12-09 10:14:35 -08:00
|
|
|
|
# Needed to avoid getting into not available disk space in /boot.
|
|
|
|
|
boot.loader.grub.configurationLimit = 1;
|
2023-11-19 09:06:53 -08:00
|
|
|
|
# The NixOS /nix/.rw-store mountpoint is backed by tmpfs which uses memory. We need to increase
|
|
|
|
|
# the available disk space to install home-assistant.
|
|
|
|
|
virtualisation.vmVariantWithBootLoader.virtualisation.memorySize = 8192;
|
|
|
|
|
|
|
|
|
|
# Options above are needed to deploy in a VM.
|
|
|
|
|
|
2023-11-19 23:11:03 -08:00
|
|
|
|
nix.settings.experimental-features = [ "nix-command" "flakes" ];
|
|
|
|
|
|
|
|
|
|
# We need to create the user we will deploy with.
|
2023-12-09 08:32:28 -08:00
|
|
|
|
users.users.${targetUser} = {
|
2023-07-01 09:46:19 -07:00
|
|
|
|
isNormalUser = true;
|
|
|
|
|
extraGroups = [ "wheel" ]; # Enable ‘sudo’ for the user.
|
|
|
|
|
initialPassword = "nixos";
|
2023-11-19 23:11:03 -08:00
|
|
|
|
# With this option, you don't need to use ssh-copy-id to copy the public ssh key to the VM.
|
2023-11-19 09:06:53 -08:00
|
|
|
|
openssh.authorizedKeys.keyFiles = [
|
|
|
|
|
./sshkey.pub
|
|
|
|
|
];
|
2023-07-01 09:46:19 -07:00
|
|
|
|
};
|
|
|
|
|
|
2023-11-19 23:11:03 -08:00
|
|
|
|
# The user we're deploying with must be able to run sudo without password.
|
2023-07-01 09:46:19 -07:00
|
|
|
|
security.sudo.extraRules = [
|
2023-12-09 08:32:28 -08:00
|
|
|
|
{ users = [ targetUser ];
|
2023-07-01 09:46:19 -07:00
|
|
|
|
commands = [
|
|
|
|
|
{ command = "ALL";
|
|
|
|
|
options = [ "NOPASSWD" ];
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
2023-11-19 23:11:03 -08:00
|
|
|
|
# Needed to allow the user we're deploying with to write to the nix store.
|
2023-11-19 09:06:53 -08:00
|
|
|
|
nix.settings.trusted-users = [
|
2023-12-09 08:32:28 -08:00
|
|
|
|
targetUser
|
2023-11-19 09:06:53 -08:00
|
|
|
|
];
|
|
|
|
|
|
2023-11-19 23:11:03 -08:00
|
|
|
|
# We need to enable the ssh daemon to be able to deploy.
|
2023-07-01 09:46:19 -07:00
|
|
|
|
services.openssh = {
|
2023-11-19 09:06:53 -08:00
|
|
|
|
enable = true;
|
2023-12-09 08:32:28 -08:00
|
|
|
|
ports = [ targetPort ];
|
2023-07-01 09:46:19 -07:00
|
|
|
|
permitRootLogin = "no";
|
2023-11-19 23:11:03 -08:00
|
|
|
|
passwordAuthentication = false;
|
2023-07-01 09:46:19 -07:00
|
|
|
|
};
|
|
|
|
|
}
|