2018-05-03 12:13:14 +02:00
|
|
|
{ config, pkgs, ... }:
|
|
|
|
with import <stockholm/lib>;
|
|
|
|
let
|
|
|
|
wifi = "wlp0s29u1u2";
|
|
|
|
in {
|
|
|
|
boot.extraModulePackages = [
|
|
|
|
pkgs.linuxPackages.rtl8814au
|
|
|
|
];
|
2018-05-16 23:07:27 +02:00
|
|
|
networking.networkmanager.unmanaged = [ wifi "et0" ];
|
2018-05-03 12:13:14 +02:00
|
|
|
|
|
|
|
systemd.services.hostapd = {
|
|
|
|
description = "hostapd wireless AP";
|
|
|
|
path = [ pkgs.hostapd ];
|
|
|
|
wantedBy = [ "network.target" ];
|
|
|
|
|
|
|
|
after = [ "${wifi}-cfg.service" "nat.service" "bind.service" "dhcpd.service" "sys-subsystem-net-devices-${wifi}.device" ];
|
|
|
|
|
|
|
|
serviceConfig = {
|
|
|
|
ExecStart = "${pkgs.hostapd}/bin/hostapd ${pkgs.writeText "hostapd.conf" ''
|
|
|
|
interface=${wifi}
|
|
|
|
hw_mode=a
|
|
|
|
channel=36
|
|
|
|
ieee80211d=1
|
|
|
|
country_code=DE
|
|
|
|
ieee80211n=1
|
|
|
|
ieee80211ac=1
|
|
|
|
wmm_enabled=1
|
|
|
|
|
|
|
|
# 5ghz
|
|
|
|
ssid=krebsing
|
|
|
|
auth_algs=1
|
|
|
|
wpa=2
|
|
|
|
wpa_key_mgmt=WPA-PSK
|
|
|
|
rsn_pairwise=CCMP
|
|
|
|
wpa_passphrase=aidsballz
|
|
|
|
''}";
|
|
|
|
Restart = "always";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2018-05-16 23:07:27 +02:00
|
|
|
networking.bridges.br0.interfaces = [
|
|
|
|
wifi
|
|
|
|
"et0"
|
|
|
|
];
|
|
|
|
|
|
|
|
networking.interfaces.br0.ipv4.addresses = [
|
2018-05-03 12:13:14 +02:00
|
|
|
{ address = "10.99.0.1"; prefixLength = 24; }
|
|
|
|
];
|
|
|
|
services.dhcpd4 = {
|
|
|
|
enable = true;
|
2018-05-16 23:07:27 +02:00
|
|
|
interfaces = [ "br0" ];
|
2018-05-03 12:13:14 +02:00
|
|
|
extraConfig = ''
|
|
|
|
option subnet-mask 255.255.255.0;
|
|
|
|
option routers 10.99.0.1;
|
|
|
|
option domain-name-servers 1.1.1.1, 8.8.8.8;
|
|
|
|
subnet 10.99.0.0 netmask 255.255.255.0 {
|
|
|
|
range 10.99.0.100 10.99.0.200;
|
|
|
|
}
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
boot.kernel.sysctl."net.ipv4.ip_forward" = 1;
|
|
|
|
krebs.iptables.tables.filter.FORWARD.rules = [
|
2018-05-16 23:07:27 +02:00
|
|
|
{ v6 = false; predicate = "-d 10.99.0.0/24 -o br0 -m conntrack --ctstate RELATED,ESTABLISHED"; target = "ACCEPT"; }
|
|
|
|
{ v6 = false; predicate = "-s 10.99.0.0/24 -i br0"; target = "ACCEPT"; }
|
|
|
|
{ v6 = false; predicate = "-i br0 -o br0"; target = "ACCEPT"; }
|
|
|
|
{ v6 = false; predicate = "-i br0 -o br0"; target = "ACCEPT"; }
|
|
|
|
{ v6 = false; predicate = "-o br0"; target = "REJECT --reject-with icmp-port-unreachable"; }
|
|
|
|
{ v6 = false; predicate = "-i br0"; target = "REJECT --reject-with icmp-port-unreachable"; }
|
2018-05-03 12:13:14 +02:00
|
|
|
];
|
2022-12-30 21:34:05 +01:00
|
|
|
krebs.iptables.tables.nat.PREROUTING.rules = mkBefore [
|
|
|
|
{ v6 = false; predicate = "-s 10.99.0.0/24"; target = "ACCEPT"; }
|
2018-05-03 12:13:14 +02:00
|
|
|
];
|
|
|
|
krebs.iptables.tables.nat.POSTROUTING.rules = [
|
|
|
|
#TODO find out what this is about?
|
|
|
|
{ v6 = false; predicate = "-s 10.99.0.0/24 -d 224.0.0.0/24"; target = "RETURN"; }
|
|
|
|
{ v6 = false; predicate = "-s 10.99.0.0/24 -d 255.255.255.255"; target = "RETURN"; }
|
|
|
|
|
|
|
|
{ v6 = false; predicate = "-s 10.99.0.0/24 ! -d 10.99.0.0/24"; target = "MASQUERADE"; }
|
|
|
|
{ v6 = false; predicate = "-s 10.99.0.0/24 ! -d 10.99.0.0/24 -p tcp"; target = "MASQUERADE --to-ports 1024-65535"; }
|
|
|
|
{ v6 = false; predicate = "-s 10.99.0.0/24 ! -d 10.99.0.0/24 -p udp"; target = "MASQUERADE --to-ports 1024-65535"; }
|
|
|
|
];
|
|
|
|
}
|