summaryrefslogtreecommitdiffstats
path: root/tv/2configs/retiolum.nix
blob: 1b176e0b919a5cbd847a53d5d4897cb9def07c75 (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
with import ./lib;
{ config, pkgs, ... }: {
  krebs.tinc.retiolum = {
    enable = true;
    connectTo = filter (ne config.krebs.build.host.name) [
      "ni"
      "prism"
      "eve"
    ];
    extraConfig = ''
      LocalDiscovery = yes
    '';
    tincPackage = pkgs.tinc_pre;
    tincUp = lib.mkIf config.systemd.network.enable "";
  };
  systemd.network.networks.retiolum = {
    matchConfig.Name = "retiolum";
    address = let
      inherit (config.krebs.build.host.nets.retiolum) ip4 ip6;
    in [
      "${ip4.addr}/${toString ip4.prefixLength}"
      "${ip6.addr}/${toString ip6.prefixLength}"
    ];
  };
  tv.iptables.input-internet-accept-tcp = singleton "tinc";
  tv.iptables.input-internet-accept-udp = singleton "tinc";
}