summaryrefslogtreecommitdiff
path: root/nixos/hosts/ev/default.nix
blob: ce7aace752b82622a5f057effbd8c8d6809f40be (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
# 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 = [
    ./hardware-configuration.nix
    <top/profiles/server>
    <top/shared/postgresql.nix>
    <top/shared/tailscale.nix>
    <top/shared/basics-physical.nix>
    <top/shared/vpn.nix>
    ./ente.nix
    ./home-automation.nix
    ./kodi.nix
    ./torrent.nix
  ];

  ente.minioPort = 3200;
  home-automation.zigbee2mqttPort = 8080;
  torrent.qbittorrentWebUiPort = 7777;
  torrent.networkNamespace = "se";

  home-automation.zigbeeSerialPort = "/dev/serial/by-id/usb-ITead_Sonoff_Zigbee_3.0_USB_Dongle_Plus_e2fed465c59ded11962fd7a5a7669f5d-if00-port0";

  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" ];
    };
  };

  ente.minioDataDir = "/mnt/personal/ente-test"; # TODO: change to /mnt/personal/ente

  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 = [];

  # 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?

}