Files
Olympus/system/services/docker/pihole/default.nix
2026-01-18 19:41:19 -06:00

50 lines
1.2 KiB
Nix

{ config, lib, ... }: {
options.sysconfig.docker.pihole.enable = with lib; mkOption {
type = with types; bool;
default = false;
};
config = lib.mkIf (config.sysconfig.docker.pihole.enable && config.sysconfig.docker.enable) {
networking = {
firewall.interfaces."docker0" = {
allowedTCPPorts = [ 53 ];
allowedUDPPorts = [ 53 ];
};
nameservers = lib.mkForce [
"127.0.0.1"
];
networkmanager = {
dns = lib.mkForce "none";
};
};
virtualisation.oci-containers.containers.pihole = {
image = "pihole/pihole:latest";
# unstable, waiting for 26.05
#pull = "newer";
hostname = "pihole.local";
ports = [
"127.0.0.1:9001:80"
"127.0.0.1:53:53/tcp"
"127.0.0.1:53:53/udp"
];
volumes = [
"vol_pihole:/etc/pihole"
];
environment = {
FTLCONF_webserver_api_password = "7567";
FTLCONF_dns_listeningMode = "ALL";
};
};
};
}