2024-08-27 00:13:25 +02:00
|
|
|
|
# SPDX-FileCopyrightText: 2023-2024 Simon Bruder <simon@sbruder.de>
|
2024-01-06 01:19:35 +01:00
|
|
|
|
#
|
|
|
|
|
# SPDX-License-Identifier: AGPL-3.0-or-later
|
|
|
|
|
|
2023-10-18 20:12:41 +02:00
|
|
|
|
{ lib, ... }:
|
|
|
|
|
let
|
|
|
|
|
mkSubnet = v4: v6:
|
|
|
|
|
let
|
|
|
|
|
splitCidr = lib.splitString "/";
|
|
|
|
|
fst = lib.flip lib.elemAt 0;
|
|
|
|
|
snd = lib.flip lib.elemAt 1;
|
|
|
|
|
|
|
|
|
|
v4Split = splitCidr v4;
|
|
|
|
|
v6Split = splitCidr v6;
|
|
|
|
|
in
|
|
|
|
|
{
|
|
|
|
|
v4 = rec {
|
|
|
|
|
cidr = v4;
|
|
|
|
|
net = fst v4Split;
|
|
|
|
|
suffix = snd v4Split;
|
|
|
|
|
withoutLastComponent = lib.substring 0 ((lib.stringLength net) - 1) net;
|
|
|
|
|
gateway = "${withoutLastComponent}1";
|
|
|
|
|
gatewayCidr = "${gateway}/${suffix}";
|
|
|
|
|
};
|
|
|
|
|
v6 = rec {
|
|
|
|
|
cidr = v6;
|
|
|
|
|
net = fst v6Split;
|
|
|
|
|
suffix = snd v6Split;
|
2024-09-22 11:26:36 +02:00
|
|
|
|
withoutLocalComponent = lib.substring 0 ((lib.stringLength net) - 1) net;
|
2023-10-18 20:12:41 +02:00
|
|
|
|
gateway = "${net}1";
|
|
|
|
|
gatewayCidr = "${gateway}/${suffix}";
|
|
|
|
|
};
|
|
|
|
|
};
|
2024-09-22 11:26:36 +02:00
|
|
|
|
|
|
|
|
|
macToIpv6InterfaceIdentifier = mac:
|
|
|
|
|
let
|
|
|
|
|
macList = lib.splitString ":" mac;
|
|
|
|
|
macListIpv6 = lib.flatten [
|
2024-12-15 17:06:31 +01:00
|
|
|
|
(lib.toHexString (lib.bitXor (lib.fromHexString (lib.elemAt macList 0)) 2))
|
2024-09-22 11:26:36 +02:00
|
|
|
|
(lib.sublist 1 2 macList)
|
|
|
|
|
[ "ff" "fe" ]
|
|
|
|
|
(lib.sublist 3 3 macList)
|
|
|
|
|
];
|
|
|
|
|
interfaceIdentifierNoColons = lib.strings.toLower (lib.concatStrings macListIpv6);
|
|
|
|
|
interfaceIdentifier = lib.concatStrings [
|
|
|
|
|
(lib.substring 0 4 interfaceIdentifierNoColons)
|
|
|
|
|
":"
|
|
|
|
|
(lib.substring 4 4 interfaceIdentifierNoColons)
|
|
|
|
|
":"
|
|
|
|
|
(lib.substring 8 4 interfaceIdentifierNoColons)
|
|
|
|
|
":"
|
|
|
|
|
(lib.substring 12 4 interfaceIdentifierNoColons)
|
|
|
|
|
];
|
|
|
|
|
in
|
|
|
|
|
interfaceIdentifier;
|
2023-10-18 20:12:41 +02:00
|
|
|
|
in
|
2024-09-22 11:26:36 +02:00
|
|
|
|
rec {
|
2023-10-18 20:12:41 +02:00
|
|
|
|
vlan = {
|
|
|
|
|
lan = {
|
|
|
|
|
id = 10;
|
2024-08-27 00:13:25 +02:00
|
|
|
|
subnet = mkSubnet "10.80.1.0/24" "2001:470:73b9:1::/64";
|
2023-10-27 23:54:56 +02:00
|
|
|
|
domain = "lan.shinonome-lab.de";
|
2024-09-23 20:27:28 +02:00
|
|
|
|
avahi = true;
|
2023-10-18 20:12:41 +02:00
|
|
|
|
};
|
|
|
|
|
management = {
|
|
|
|
|
id = 20;
|
2024-08-27 00:13:25 +02:00
|
|
|
|
subnet = mkSubnet "10.80.2.0/24" "2001:470:73b9:2::/64";
|
2023-10-27 23:54:56 +02:00
|
|
|
|
domain = "management.shinonome-lab.de";
|
2024-09-23 20:27:28 +02:00
|
|
|
|
avahi = false;
|
2023-10-18 20:12:41 +02:00
|
|
|
|
};
|
|
|
|
|
guest = {
|
|
|
|
|
id = 30;
|
2024-08-27 00:13:25 +02:00
|
|
|
|
subnet = mkSubnet "10.80.3.0/24" "2001:470:73b9:3::/64";
|
2023-10-27 23:54:56 +02:00
|
|
|
|
domain = "guest.shinonome-lab.de";
|
2024-09-23 20:27:28 +02:00
|
|
|
|
avahi = false;
|
2023-10-18 20:12:41 +02:00
|
|
|
|
};
|
|
|
|
|
iot = {
|
|
|
|
|
id = 40;
|
2024-08-27 00:13:25 +02:00
|
|
|
|
subnet = mkSubnet "10.80.4.0/24" "2001:470:73b9:4::/64";
|
2023-10-27 23:54:56 +02:00
|
|
|
|
domain = "iot.shinonome-lab.de";
|
2024-09-23 20:27:28 +02:00
|
|
|
|
avahi = true;
|
2023-10-18 20:12:41 +02:00
|
|
|
|
};
|
2024-09-22 12:54:37 +02:00
|
|
|
|
printer = {
|
|
|
|
|
id = 41;
|
|
|
|
|
subnet = mkSubnet "10.80.5.0/24" "2001:470:73b9:5::/64";
|
|
|
|
|
domain = "printer.shinonome-lab.de";
|
2024-09-23 20:27:28 +02:00
|
|
|
|
avahi = true;
|
2024-09-22 12:54:37 +02:00
|
|
|
|
};
|
2023-10-18 20:12:41 +02:00
|
|
|
|
};
|
2023-10-07 22:31:29 +02:00
|
|
|
|
tc = {
|
|
|
|
|
interface = "enp1s0";
|
|
|
|
|
# 4160 kbit is slightly smaller than the average upload
|
|
|
|
|
rate = "4160kbit";
|
|
|
|
|
major = 1;
|
|
|
|
|
default = 2;
|
|
|
|
|
classes = [
|
|
|
|
|
# default
|
|
|
|
|
{
|
|
|
|
|
minor = 2;
|
2023-10-18 20:13:01 +02:00
|
|
|
|
rate = "800kbit";
|
2023-10-07 22:31:29 +02:00
|
|
|
|
prio = 50;
|
|
|
|
|
}
|
|
|
|
|
# DNS, small packets (e.g., TCP ACK)
|
|
|
|
|
{
|
|
|
|
|
minor = 3;
|
|
|
|
|
rate = "250kbit";
|
|
|
|
|
prio = 0;
|
|
|
|
|
qdiscArgs = [ "pfifo_fast" ];
|
|
|
|
|
}
|
|
|
|
|
# interactive SSH
|
|
|
|
|
{
|
|
|
|
|
minor = 4;
|
|
|
|
|
rate = "128kbit";
|
|
|
|
|
prio = 2;
|
|
|
|
|
}
|
|
|
|
|
# torrent
|
|
|
|
|
{
|
|
|
|
|
minor = 5;
|
|
|
|
|
rate = "250kbit";
|
|
|
|
|
ceil = "3000kbit";
|
|
|
|
|
prio = 100;
|
|
|
|
|
}
|
|
|
|
|
# HTTP
|
|
|
|
|
{
|
|
|
|
|
minor = 6;
|
|
|
|
|
rate = "1500kbit";
|
|
|
|
|
prio = 25;
|
|
|
|
|
}
|
|
|
|
|
# wg-home
|
|
|
|
|
{
|
|
|
|
|
minor = 7;
|
|
|
|
|
rate = "250kbit";
|
|
|
|
|
prio = 10;
|
|
|
|
|
}
|
|
|
|
|
# VoIP
|
|
|
|
|
{
|
|
|
|
|
minor = 8;
|
|
|
|
|
rate = "256kbit";
|
|
|
|
|
ceil = "384kbit";
|
|
|
|
|
prio = 3;
|
|
|
|
|
qdiscArgs = [ "pfifo_fast" ];
|
|
|
|
|
}
|
|
|
|
|
# Backup
|
|
|
|
|
{
|
|
|
|
|
minor = 9;
|
|
|
|
|
rate = "350kbit";
|
|
|
|
|
ceil = "3000kbit";
|
|
|
|
|
prio = 90;
|
|
|
|
|
}
|
2023-10-18 20:13:01 +02:00
|
|
|
|
# guest
|
|
|
|
|
{
|
|
|
|
|
minor = 10;
|
|
|
|
|
rate = "200kbit";
|
|
|
|
|
ceil = "2000kbit";
|
|
|
|
|
prio = 99;
|
|
|
|
|
}
|
2023-10-07 22:31:29 +02:00
|
|
|
|
];
|
|
|
|
|
};
|
2024-09-22 11:26:36 +02:00
|
|
|
|
staticHosts = lib.mapAttrs
|
|
|
|
|
(_: options: options // {
|
|
|
|
|
address6 = "${vlan.${options.vlan}.subnet.v6.withoutLocalComponent}${macToIpv6InterfaceIdentifier options.hwaddr}";
|
|
|
|
|
})
|
|
|
|
|
{
|
|
|
|
|
fuuko = {
|
|
|
|
|
hwaddr = "18:c0:4d:d2:93:f0";
|
|
|
|
|
address4 = "10.80.1.98";
|
|
|
|
|
vlan = "lan";
|
|
|
|
|
};
|
|
|
|
|
};
|
2023-09-24 14:41:22 +02:00
|
|
|
|
}
|