summary refs log tree commit diff
path: root/nixos/modules/virtualisation/spice-usb-redirection.nix
blob: 4168cebe79b182cf7fe85137aaa2ac85f8cc7cf2 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
{ config, pkgs, lib, ... }:
{
  options.virtualisation.spiceUSBRedirection.enable = lib.mkOption {
    type = lib.types.bool;
    default = false;
    description = ''
      Install the SPICE USB redirection helper with setuid
      privileges. This allows unprivileged users to pass USB devices
      connected to this machine to libvirt VMs, both local and
      remote. Note that this allows users arbitrary access to USB
      devices.
    '';
  };

  config = lib.mkIf config.virtualisation.spiceUSBRedirection.enable {
    environment.systemPackages = [ pkgs.spice-gtk ]; # For polkit actions
    security.wrappers.spice-client-glib-usb-acl-helper ={
      source = "${pkgs.spice-gtk}/bin/spice-client-glib-usb-acl-helper";
      capabilities = "cap_fowner+ep";
    };
  };

  meta.maintainers = [ lib.maintainers.lheckemann ];
}