summaryrefslogtreecommitdiff
path: root/host/athena.nix
blob: 211f155a1378bf19f1bdf90ed797bb3425f81585 (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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
{ pkgs, ... }:

{
  imports = [
    ./hardware/athena.nix
    ./software/desktop
  ];

  boot = {
    loader = {
      systemd-boot.enable = true;
      efi.canTouchEfiVariables = true;
    };

    initrd.luks.devices = [ {
      name   = "encrypted";
      device = "/dev/nvme0n1p2";
      preLVM        = true;
      allowDiscards = true;
    } ];
  };

  networking = {
    hostName = "athena";
    firewall.enable = false;
    networkmanager.enable = true;
  };

  users.extraUsers.common.extraGroups  = [ "networkmanager" "libvirtd" ];

  networking.wireguard.interfaces = {
    wg0 = {
      ips = [ "10.100.0.4/24" ];

      privateKeyFile = "/etc/wireguard/private";

      peers = [
        { # automatix
          publicKey  = "B0tkjq+5SfECKx1gWEP5JVWOIaRWL2JNE7iSpMmN4F0=";
          allowedIPs = [ "10.100.0.0/24" ];
          endpoint   = "kummerlaender.eu:54321";

          persistentKeepalive = 10;
        }
      ];
    };
  };

  services = {
    upower.enable = true;
    acpid.enable  = true;

    xserver = {
      videoDrivers = [ "intel" ];

      synaptics = {
        enable = true;
        twoFingerScroll  = true;
        horizontalScroll = false;
        palmDetect       = true;
        minSpeed         = "1.5";
      };
    };

    printing.enable = true;

    avahi = {
      enable  = true;
      nssmdns = true;
    };
  };

  virtualisation.libvirtd.enable = true;

  hardware.trackpoint = {
    enable       = true;
    emulateWheel = true;
    speed        = 250;
  };

  hardware.bluetooth.enable = true;

  hardware.opengl.extraPackages = [ pkgs.intel-ocl ];

  services.tlp = {
    enable = true;
    extraConfig = ''
     RESTORE_DEVICE_STATE_ON_STARTUP=1
     DEVICES_TO_DISABLE_ON_STARTUP="wwan"
    '';
  };

  powerManagement.powertop.enable = true;

  i18n = {
    consoleFont = "ter-132n";
    consolePackages = [ pkgs.terminus_font ];
  };

  boot.earlyVconsoleSetup = true;
}