about summary refs log tree commit diff
path: root/modules/nixos/libvirtd.nix
diff options
context:
space:
mode:
authorAzat Bahawi <azat@bahawi.net>2022-12-17 16:39:09 +0300
committerAzat Bahawi <azat@bahawi.net>2022-12-17 16:39:09 +0300
commit8f137c28230623259a964484adcf31fe00756594 (patch)
tree82bce6a13fda125087cf6d9dc80aa91d9230d6c4 /modules/nixos/libvirtd.nix
parent2022-11-20 (diff)
2022-12-17
Diffstat (limited to 'modules/nixos/libvirtd.nix')
-rw-r--r--modules/nixos/libvirtd.nix44
1 files changed, 44 insertions, 0 deletions
diff --git a/modules/nixos/libvirtd.nix b/modules/nixos/libvirtd.nix
new file mode 100644
index 0000000..ae8b336
--- /dev/null
+++ b/modules/nixos/libvirtd.nix
@@ -0,0 +1,44 @@
+{
+  config,
+  lib,
+  pkgs,
+  ...
+}:
+with lib; let
+  cfg = config.nixfiles.modules.libvirtd;
+in {
+  options.nixfiles.modules.libvirtd.enable = mkEnableOption "libvirtd";
+
+  config = mkIf cfg.enable {
+    virtualisation.libvirtd = {
+      enable = true;
+
+      onBoot = "ignore";
+      onShutdown = "shutdown";
+
+      extraConfig = ''
+        log_level = 4
+        log_outputs = "4:stderr"
+      '';
+
+      qemu = {
+        package = pkgs.qemu_kvm;
+        runAsRoot = false;
+
+        ovmf = {
+          enable = true;
+          packages = [pkgs.OVMFFull.fd];
+        };
+
+        swtpm = {
+          enable = false; # Is this required for Windows 11?
+          package = pkgs.swtpm-tpm2;
+        };
+      };
+    };
+
+    environment.systemPackages = with pkgs; [virt-manager qemu-utils];
+
+    my.extraGroups = ["libvirtd"];
+  };
+}

Consider giving Nix/NixOS a try! <3