summaryrefslogtreecommitdiffstats
path: root/makefu/1systems/x.nix
blob: adbf372abf2dfccd55a9e5e1905a018a244439be (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
#
#
#
{ config, pkgs, ... }:

{
  imports =
    [ # base
      ../.
      ../2configs/main-laptop.nix
      ../2configs/laptop-utils.nix
      ../2configs/laptop-backup.nix

      # testing
      ../2configs/openvpn/vpngate.nix
      #../2configs/temp/share-samba.nix
      # ../2configs/mediawiki.nix
      # ../2configs/wordpress.nix
      # ../2configs/nginx/public_html.nix
      # ../2configs/nginx/icecult.nix

      # ../2configs/elchos/irc-token.nix
      # ../2configs/elchos/log.nix

      #../2configs/elchos/search.nix
      #../2configs/elchos/stats.nix
      #../2configs/elchos/test/ftpservers.nix

      ../2configs/laptop-backup.nix
      # ../2configs/tinc/siem.nix
      #../2configs/torrent.nix
      # temporary modules

      # ../2configs/torrent.nix
      #../2configs/temp/elkstack.nix
      # ../2configs/temp/sabnzbd.nix



      # Krebs
      # ../2configs/disable_v6.nix
      ../2configs/tinc/retiolum.nix

      # applications
      ../2configs/exim-retiolum.nix
      ../2configs/mail-client.nix
      ../2configs/printer.nix
      ../2configs/virtualization.nix
      ../2configs/virtualization-virtualbox.nix
      ../2configs/wwan.nix
      ../2configs/rad1o.nix

      # services
      #../2configs/git/brain-retiolum.nix
      ../2configs/tor.nix
      ../2configs/steam.nix
      # ../2configs/buildbot-standalone.nix

      # hardware specifics are in here
      ../2configs/hw/tp-x230.nix
      ../2configs/hw/rtl8812au.nix
      ../2configs/hw/bcm4352.nix
      # mount points
      ../2configs/fs/sda-crypto-root-home.nix

    ];
  makefu.server.primary-itf = "wlp2s0";
  makefu.full-populate = true;

  nixpkgs.config.allowUnfree = true;
  krebs.nginx = {
    default404 = false;
    servers.default.listen = [ "80 default_server" ];
    servers.default.server-names = [ "_" ];
  };

  environment.systemPackages = [ pkgs.passwdqc-utils pkgs.bintray-upload ];

  virtualisation.docker.enable = true;

  # configure pulseAudio to provide a HDMI sink as well
  networking.firewall.enable = true;
  networking.firewall.allowedTCPPorts = [ 80 24800 26061 8000 3000 ];
  networking.firewall.allowedUDPPorts = [ 665 26061 ];

  krebs.build.host = config.krebs.hosts.x;

  krebs.tinc.retiolum.connectTo = [ "omo" "gum" "prism" ];

  networking.extraHosts = ''
    192.168.1.11 omo.local
  '';
  # hard dependency because otherwise the device will not be unlocked
  boot.initrd.luks.devices = [ { name = "luksroot"; device = "/dev/sda2"; allowDiscards=true; }];
}