summaryrefslogtreecommitdiffstats
path: root/configs/sshd.nix
blob: 281d498b2882fc35b92ae7d75db332494b932b93 (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
{ config, lib, ... }: let
  cfg.host = config.krebs.build.host;
  nets =
    lib.optional (cfg.host.nets?retiolum) cfg.host.nets.retiolum ++
    lib.optional (cfg.host.nets?wiregrill) cfg.host.nets.wiregrill;
in {
  services.openssh = {
    enable = true;
  };
  tv.iptables.input-internet-accept-tcp = [ "ssh" ];
  tv.iptables.extra.nat.OUTPUT = [
    "-o lo -p tcp --dport 11423 -j REDIRECT --to-ports 22"
  ];
  tv.iptables.extra4.nat.PREROUTING =
    map
      (net: "-d ${net.ip4.addr} -p tcp --dport 22 -j ACCEPT")
      (builtins.filter (net: net.ip4 != null) nets);
  tv.iptables.extra6.nat.PREROUTING =
    map
      (net: "-d ${net.ip6.addr} -p tcp --dport 22 -j ACCEPT")
      (builtins.filter (net: net.ip6 != null) nets);
  tv.iptables.extra.nat.PREROUTING = [
    "-p tcp --dport 22 -j REDIRECT --to-ports 0"
    "-p tcp --dport 11423 -j REDIRECT --to-ports 22"
  ];
}