feat: Basic recursive dns
This commit is contained in:
parent
48fb68c2fd
commit
c294e159e2
6 changed files with 112 additions and 0 deletions
16
modules/apps/bind9/db.depeuter.dev
Normal file
16
modules/apps/bind9/db.depeuter.dev
Normal file
|
|
@ -0,0 +1,16 @@
|
||||||
|
$TTL 604800
|
||||||
|
@ IN SOA ns1.depeuter.dev. admin.depeuter.dev. (
|
||||||
|
5 ; Serial
|
||||||
|
604800 ; Refresh
|
||||||
|
86400 ; Retry
|
||||||
|
2419200 ; Expire
|
||||||
|
604800 ) ; Negative Cache TTL
|
||||||
|
|
||||||
|
; name servers - NS records
|
||||||
|
IN NS ns1.depeuter.dev.
|
||||||
|
; IN NS ns2.depeuter.dev.
|
||||||
|
|
||||||
|
ns1.depeuter.dev. IN A 192.168.0.91
|
||||||
|
;ns1.depeuter.dev. IN A 192.158.0.X
|
||||||
|
|
||||||
|
hugo.depeuter.dev. IN A 192.168.0.11
|
||||||
54
modules/apps/bind9/default.nix
Normal file
54
modules/apps/bind9/default.nix
Normal file
|
|
@ -0,0 +1,54 @@
|
||||||
|
{ config, lib, ... }:
|
||||||
|
|
||||||
|
let
|
||||||
|
cfg = config.homelab.apps.bind9;
|
||||||
|
in {
|
||||||
|
options.homelab.apps.bind9.enable = lib.mkEnableOption "ISC BIND 9 (Docker)";
|
||||||
|
|
||||||
|
config = lib.mkIf cfg.enable {
|
||||||
|
homelab.virtualisation.containers.enable = true;
|
||||||
|
|
||||||
|
environment.etc = {
|
||||||
|
"bind/named.conf" = {
|
||||||
|
source = ./named.conf;
|
||||||
|
mode = "0555";
|
||||||
|
};
|
||||||
|
"bind/named.conf.options" = {
|
||||||
|
source = ./named.conf.options;
|
||||||
|
mode = "0555";
|
||||||
|
};
|
||||||
|
"bind/named.conf.local" = {
|
||||||
|
source = ./named.conf.local;
|
||||||
|
mode = "0555";
|
||||||
|
};
|
||||||
|
"bind/zones/db.depeuter.dev" = {
|
||||||
|
source = ./db.depeuter.dev;
|
||||||
|
mode = "0555";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
virtualisation.oci-containers.containers.bind9 = {
|
||||||
|
hostname = "bind9";
|
||||||
|
#image = "internetsystemsconsortium/bind9:9.20"; # Current stable
|
||||||
|
image = "ubuntu/bind9"; # Current stable
|
||||||
|
autoStart = true;
|
||||||
|
ports = [
|
||||||
|
"53:53/udp"
|
||||||
|
"53:53/tcp"
|
||||||
|
"953:953/tcp"
|
||||||
|
];
|
||||||
|
extraOptions = [
|
||||||
|
];
|
||||||
|
environment = {
|
||||||
|
};
|
||||||
|
volumes = [
|
||||||
|
"/etc/bind:/etc/bind" # For configuration, your `named.conf` lives here
|
||||||
|
"bind9-cache:/var/cache/bind"
|
||||||
|
#"...:/var/lib/bind" # Secondary zones
|
||||||
|
"bind9-logs:/var/log" # Logfiles
|
||||||
|
];
|
||||||
|
labels = {
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
2
modules/apps/bind9/named.conf
Normal file
2
modules/apps/bind9/named.conf
Normal file
|
|
@ -0,0 +1,2 @@
|
||||||
|
include "/etc/bind/named.conf.options";
|
||||||
|
include "/etc/bind/named.conf.local";
|
||||||
4
modules/apps/bind9/named.conf.local
Normal file
4
modules/apps/bind9/named.conf.local
Normal file
|
|
@ -0,0 +1,4 @@
|
||||||
|
zone "depeuter.dev" {
|
||||||
|
type primary;
|
||||||
|
file "/etc/bind/zones/db.depeuter.dev";
|
||||||
|
};
|
||||||
35
modules/apps/bind9/named.conf.options
Normal file
35
modules/apps/bind9/named.conf.options
Normal file
|
|
@ -0,0 +1,35 @@
|
||||||
|
http local {
|
||||||
|
endpoints { "/dns-query"; };
|
||||||
|
};
|
||||||
|
|
||||||
|
acl bogusnets {
|
||||||
|
};
|
||||||
|
|
||||||
|
acl trusted {
|
||||||
|
192.168.0.0/16;
|
||||||
|
};
|
||||||
|
|
||||||
|
options {
|
||||||
|
directory "/var/cache/bind";
|
||||||
|
|
||||||
|
version "not currently available";
|
||||||
|
|
||||||
|
listen-on { any; };
|
||||||
|
listen-on-v6 { any; };
|
||||||
|
listen-on tls ephemeral { any; };
|
||||||
|
listen-on-v6 tls ephemeral { any; };
|
||||||
|
listen-on tls ephemeral http local { any; };
|
||||||
|
listen-on-v6 tls ephemeral http local { any; };
|
||||||
|
|
||||||
|
recursion yes;
|
||||||
|
forwarders {
|
||||||
|
9.9.9.9;
|
||||||
|
149.112.112.112;
|
||||||
|
};
|
||||||
|
forward only;
|
||||||
|
|
||||||
|
allow-query { any; };
|
||||||
|
allow-recursion { any; };
|
||||||
|
allow-transfer { none; };
|
||||||
|
blackhole { bogusnets; };
|
||||||
|
};
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
./arr
|
./arr
|
||||||
|
./bind9
|
||||||
./calibre
|
./calibre
|
||||||
./changedetection
|
./changedetection
|
||||||
./freshrss
|
./freshrss
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue