about summary refs log tree commit diff
path: root/nixos/modules/hardware/cpu/intel-sgx.nix
blob: 046479400587f90b78acd6e7af5ceb548c5840bc (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
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
{ config, lib, ... }:
with lib;
let
  cfg = config.hardware.cpu.intel.sgx.provision;
  defaultGroup = "sgx_prv";
in
{
  options.hardware.cpu.intel.sgx.provision = {
    enable = mkEnableOption "access to the Intel SGX provisioning device";
    user = mkOption {
      description = "Owner to assign to the SGX provisioning device.";
      type = types.str;
      default = "root";
    };
    group = mkOption {
      description = "Group to assign to the SGX provisioning device.";
      type = types.str;
      default = defaultGroup;
    };
    mode = mkOption {
      description = "Mode to set for the SGX provisioning device.";
      type = types.str;
      default = "0660";
    };
  };

  config = mkIf cfg.enable {
    assertions = [
      {
        assertion = hasAttr cfg.user config.users.users;
        message = "Given user does not exist";
      }
      {
        assertion = (cfg.group == defaultGroup) || (hasAttr cfg.group config.users.groups);
        message = "Given group does not exist";
      }
    ];

    users.groups = optionalAttrs (cfg.group == defaultGroup) {
      "${cfg.group}" = { };
    };

    services.udev.extraRules = ''
      SUBSYSTEM=="misc", KERNEL=="sgx_provision", OWNER="${cfg.user}", GROUP="${cfg.group}", MODE="${cfg.mode}"
    '';
  };
}