summary refs log tree commit diff
path: root/roles/desktop.nix
blob: 0b5afc8c3c169091b93a7dba95f226c35b54e954 (plain)
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
48
49
50
51
52
53
54
55
56
57
58
{
  pkgs,
  auxiliaryPkgs,
  ...
}:

{
  imports = [
    ../modules/common.nix

    ../modules/gnome.nix
    ../modules/fonts.nix
    ../modules/flatpak.nix
    ../modules/libreoffice.nix
    #../modules/electronics.nix
    ../modules/hardware-keys.nix
  ];

  services = {
    sysprof.enable = true;
    tailscale = {
      enable = true;
      useRoutingFeatures = "both";
      extraUpFlags = [ "--ssh" ];
    };
    mullvad-vpn.enable = true;
  };

  programs = {
    # TODO: pull out gaming related configuration (like steam) into a seperate module.
    steam = {
      enable = true;
      remotePlay.openFirewall = true;
    };
    virt-manager.enable = true;

    ghidra = {
      enable = true;
      package = auxiliaryPkgs.ghidra;
      gdb = true;
    };

    wireshark = {
      enable = true;
      dumpcap.enable = true;
      usbmon.enable = true;
    };

    adb.enable = true;
  };

  # on desktop machines (a.k.a. minerals) we only use tailscale ssh
  # for access, so we don't generally have normal host keys, and
  # have to grab the ones tailscale uses.
  age.identityPaths = [ "/var/lib/tailscale/ssh/ssh_host_ed25519_key" ];

  environment.etc.openvpn.source = "${pkgs.update-resolv-conf}/libexec/openvpn";
}