summaryrefslogtreecommitdiff
path: root/nixos/ev-configuration.nix
blob: 95c139638832e9731fb8e5efe1ad0345e7673e3d (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
102
103
104
105
# channel="nixos-small"
# Edit this configuration file to define what should be installed on
# your system.  Help is available in the configuration.nix(5) man page
# and in the NixOS manual (accessible by running ‘nixos-help’).

{ config, pkgs, ... }:

{
  imports = [
    ./ev-hardware-configuration.nix
    ./sanix.nix
    ./parts/server.nix
    ./parts/tailscale.nix
    ./parts/basics.nix
    ./parts/basics-physical.nix
  ];

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

  networking.hostName = "ev";

  networking.networkmanager.enable = true;

  time.timeZone = "Europe/Vienna";

  users.users.martin = {
    isNormalUser = true;
    extraGroups = [
      "networkmanager"
      "wheel"
    ];
  };

  # Open ports in the firewall.
  networking.firewall.allowedTCPPorts = [
    # Enabling openssh automatically opens its port in the firewall.
    # For all other services we need to manually list the ports here.
  ];
  networking.firewall.allowedUDPPorts = [];

  fileSystems = {
    "/mnt/personal" = {
      device = "UUID=5587670d-9a50-4068-baca-17f5360f9ff9";
      fsType = "ext4";
      options = [ "nofail" "noatime" "rw" ];
    };
    "/mnt/lib" = {
      device = "UUID=a5f90083-d604-4218-b4d4-aac421b9d732";
      fsType = "ext4";
      options = [ "nofail" "noatime" "rw" ];
    };
  };

  users.extraUsers.kodi.isNormalUser = true;

  services = {
    pipewire = {
      enable = true;
      alsa.enable = true;
      alsa.support32Bit = true;
      pulse.enable = true;
    };

    cage =
      let
        kodi-package = pkgs.kodi-wayland.withPackages (kodiPkgs: with kodiPkgs; [
          joystick
        ]);
      in
      {
        enable = true;
        user = "kodi";
        program = "${kodi-package}/bin/kodi-standalone";
        environment = {
          KODI_AE_SINK = "PIPEWIRE"; # TODO: remove with new Kodi which defaults to pipewire
        };
      };

    zigbee2mqtt = {
      enable = true;
      settings = {
        serial = {
          port = "/dev/serial/by-id/usb-ITead_Sonoff_Zigbee_3.0_USB_Dongle_Plus_e2fed465c59ded11962fd7a5a7669f5d-if00-port0";
        };
        frontend = {
          port = 8080;
        };
      };
    };

    mosquitto = {
      enable = true;
    };
  };

  # This value determines the NixOS release from which the default
  # settings for stateful data, like file locations and database versions
  # on your system were taken. It‘s perfectly fine and recommended to leave
  # this value at the release version of the first install of this system.
  # Before changing this value read the documentation for this option
  # (e.g. man configuration.nix or on https://nixos.org/nixos/options.html).
  system.stateVersion = "24.11"; # Did you read the comment?

}