stockholm/lass/1systems/yellow/config.nix

46 lines
1.5 KiB
Nix
Raw Normal View History

{ config, lib, pkgs, ... }: let
2023-07-28 12:32:43 +02:00
vpnPort = 1637;
torrentport = 56709; # port forwarded in airvpn webinterface
in {
2018-11-30 04:35:00 +01:00
imports = [
<stockholm/lass>
<stockholm/lass/2configs>
<stockholm/lass/2configs/retiolum.nix>
2023-02-21 11:15:26 +01:00
<stockholm/lass/2configs/services/flix>
2018-11-30 04:35:00 +01:00
];
krebs.build.host = config.krebs.hosts.yellow;
2023-01-30 20:53:24 +01:00
krebs.sync-containers3.inContainer = {
2023-01-02 01:23:42 +01:00
enable = true;
pubkey = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIN737BAP36KiZO97mPKTIUGJUcr97ps8zjfFag6cUiYL";
};
networking.useHostResolvConf = false;
networking.useNetworkd = true;
2018-11-30 04:35:00 +01:00
2023-07-28 12:32:43 +02:00
networking.wg-quick.interfaces.airvpn.configFile = "/var/src/secrets/airvpn.conf";
services.transmission.settings.peer-port = torrentport;
2020-09-15 22:33:29 +02:00
2023-07-28 12:32:43 +02:00
# only allow traffic through openvpn
2023-02-21 11:15:26 +01:00
krebs.iptables = {
2023-01-08 12:35:37 +01:00
enable = true;
2023-07-28 12:32:43 +02:00
tables.filter.INPUT.rules = [
{ predicate = "-i airvpn -p tcp --dport ${toString torrentport}"; target = "ACCEPT"; }
{ predicate = "-i airvpn -p udp --dport ${toString torrentport}"; target = "ACCEPT"; }
];
2023-02-21 11:15:26 +01:00
tables.filter.OUTPUT = {
policy = "DROP";
rules = [
{ predicate = "-o lo"; target = "ACCEPT"; }
2023-07-28 12:32:43 +02:00
{ predicate = "-p udp --dport ${toString vpnPort}"; target = "ACCEPT"; }
{ predicate = "-o airvpn"; target = "ACCEPT"; }
2023-02-21 11:15:26 +01:00
{ predicate = "-o retiolum"; target = "ACCEPT"; }
{ v6 = false; predicate = "-d 1.1.1.1/32"; target = "ACCEPT"; }
{ v6 = false; predicate = "-d 1.0.0.1/32"; target = "ACCEPT"; }
{ v6 = false; predicate = "-o eth0 -d 10.233.2.0/24"; target = "ACCEPT"; }
];
};
2023-01-08 12:35:37 +01:00
};
2018-11-30 04:35:00 +01:00
}