188 lines
5.4 KiB
Nix
188 lines
5.4 KiB
Nix
{ config, lib, ... }:
|
|
{
|
|
services.kea.dhcp4 = lib.mkIf config.cloonar-assistant.firewall.enable {
|
|
enable = true;
|
|
settings = {
|
|
interfaces-config = {
|
|
interfaces = [
|
|
"lan"
|
|
"server"
|
|
"infrastructure"
|
|
"multimedia"
|
|
"smart"
|
|
"guest"
|
|
];
|
|
};
|
|
lease-database = {
|
|
name = "/var/lib/kea/dhcp4.leases";
|
|
persist = true;
|
|
type = "memfile";
|
|
};
|
|
rebind-timer = 2000;
|
|
renew-timer = 1000;
|
|
subnet4 = [
|
|
{
|
|
id = 96;
|
|
pools = [
|
|
{
|
|
pool = "${config.cloonar-assistant.networkPrefix}.96.100 - ${config.cloonar-assistant.networkPrefix}.96.240";
|
|
}
|
|
];
|
|
subnet = "${config.cloonar-assistant.networkPrefix}.96.0/24";
|
|
interface = "lan";
|
|
option-data = [
|
|
{
|
|
name = "routers";
|
|
data = "${config.cloonar-assistant.networkPrefix}.96.1";
|
|
}
|
|
{
|
|
name = "domain-name";
|
|
data = config.cloonar-assistant.domain;
|
|
}
|
|
{
|
|
name = "domain-search";
|
|
data = config.cloonar-assistant.domain;
|
|
}
|
|
{
|
|
name = "domain-name-servers";
|
|
data = "${config.cloonar-assistant.networkPrefix}.96.1";
|
|
}
|
|
];
|
|
reservations = [
|
|
];
|
|
}
|
|
{
|
|
id = 97;
|
|
pools = [
|
|
{
|
|
pool = "${config.cloonar-assistant.networkPrefix}.97.100 - ${config.cloonar-assistant.networkPrefix}.97.240";
|
|
}
|
|
];
|
|
subnet = "${config.cloonar-assistant.networkPrefix}.97.0/24";
|
|
interface = "server";
|
|
option-data = [
|
|
{
|
|
name = "routers";
|
|
data = "${config.cloonar-assistant.networkPrefix}.97.1";
|
|
}
|
|
{
|
|
name = "domain-name";
|
|
data = config.cloonar-assistant.domain;
|
|
}
|
|
{
|
|
name = "domain-name-servers";
|
|
data = "${config.cloonar-assistant.networkPrefix}.97.1";
|
|
}
|
|
];
|
|
reservations = [
|
|
];
|
|
}
|
|
{
|
|
id = 101;
|
|
pools = [
|
|
{
|
|
pool = "${config.cloonar-assistant.networkPrefix}.101.100 - ${config.cloonar-assistant.networkPrefix}.101.240";
|
|
}
|
|
];
|
|
subnet = "${config.cloonar-assistant.networkPrefix}.101.0/24";
|
|
interface = "infrastructure";
|
|
option-data = [
|
|
{
|
|
name = "routers";
|
|
data = "${config.cloonar-assistant.networkPrefix}.101.1";
|
|
}
|
|
{
|
|
name = "domain-name";
|
|
data = config.cloonar-assistant.domain;
|
|
}
|
|
{
|
|
name = "domain-name-servers";
|
|
data = "${config.cloonar-assistant.networkPrefix}.101.1";
|
|
}
|
|
{
|
|
name = "capwap-ac-v4";
|
|
code = 138;
|
|
data = "${config.cloonar-assistant.networkPrefix}.97.2";
|
|
}
|
|
];
|
|
reservations = [
|
|
];
|
|
}
|
|
{
|
|
id = 99;
|
|
pools = [
|
|
{
|
|
pool = "${config.cloonar-assistant.networkPrefix}.99.100 - ${config.cloonar-assistant.networkPrefix}.99.240";
|
|
}
|
|
];
|
|
subnet = "${config.cloonar-assistant.networkPrefix}.99.0/24";
|
|
interface = "multimedia";
|
|
option-data = [
|
|
{
|
|
name = "routers";
|
|
data = "${config.cloonar-assistant.networkPrefix}.99.1";
|
|
}
|
|
{
|
|
name = "domain-name";
|
|
data = config.cloonar-assistant.domain;
|
|
}
|
|
{
|
|
name = "domain-name-servers";
|
|
data = "${config.cloonar-assistant.networkPrefix}.99.1";
|
|
}
|
|
];
|
|
reservations = [
|
|
];
|
|
}
|
|
{
|
|
id = 254;
|
|
pools = [
|
|
{
|
|
pool = "${config.cloonar-assistant.networkPrefix}.254.10 - ${config.cloonar-assistant.networkPrefix}.254.254";
|
|
}
|
|
];
|
|
subnet = "${config.cloonar-assistant.networkPrefix}.254.0/24";
|
|
interface = "guest";
|
|
option-data = [
|
|
{
|
|
name = "routers";
|
|
data = "${config.cloonar-assistant.networkPrefix}.254.1";
|
|
}
|
|
{
|
|
name = "domain-name-servers";
|
|
data = "9.9.9.9";
|
|
}
|
|
];
|
|
}
|
|
{
|
|
id = 100;
|
|
pools = [
|
|
{
|
|
pool = "${config.cloonar-assistant.networkPrefix}.100.100 - ${config.cloonar-assistant.networkPrefix}.100.240";
|
|
}
|
|
];
|
|
subnet = "${config.cloonar-assistant.networkPrefix}.100.0/24";
|
|
interface = "smart";
|
|
option-data = [
|
|
{
|
|
name = "routers";
|
|
data = "${config.cloonar-assistant.networkPrefix}.100.1";
|
|
}
|
|
{
|
|
name = "domain-name";
|
|
data = config.cloonar-assistant.domain;
|
|
}
|
|
{
|
|
name = "domain-name-servers";
|
|
data = "${config.cloonar-assistant.networkPrefix}.100.1";
|
|
}
|
|
];
|
|
reservations = [
|
|
];
|
|
}
|
|
];
|
|
valid-lifetime = 4000;
|
|
};
|
|
};
|
|
}
|