2023-11-19 00:51:50 +01:00
|
|
|
{ lib, ... }:
|
2021-05-11 20:58:03 +02:00
|
|
|
|
|
|
|
{
|
2023-11-19 00:51:50 +01:00
|
|
|
networking.nameservers = [ "127.0.0.1" "::1" ];
|
|
|
|
|
|
|
|
services.resolved = {
|
|
|
|
enable = true;
|
|
|
|
# don't use fallback resolvers
|
|
|
|
fallbackDns = [ "127.0.0.1" "::1" ];
|
2021-05-11 20:58:03 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
services.dnscrypt-proxy2 = {
|
|
|
|
enable = true;
|
|
|
|
settings = {
|
2022-07-13 14:35:32 +02:00
|
|
|
listen_addresses = [ "127.0.0.1:53" "[::1]:53" ];
|
|
|
|
|
2021-05-11 20:58:03 +02:00
|
|
|
ipv6_servers = true;
|
2022-08-14 13:53:21 +02:00
|
|
|
require_nolog = true;
|
2021-08-04 21:35:05 +02:00
|
|
|
require_dnssec = true;
|
2023-11-19 00:51:50 +01:00
|
|
|
http3 = true;
|
2021-05-11 20:58:03 +02:00
|
|
|
|
2022-11-01 10:50:42 +01:00
|
|
|
sources.public-resolvers = {
|
|
|
|
urls = [
|
|
|
|
"https://raw.githubusercontent.com/DNSCrypt/dnscrypt-resolvers/master/v3/public-resolvers.md"
|
|
|
|
"https://download.dnscrypt.info/resolvers-list/v3/public-resolvers.md"
|
|
|
|
];
|
|
|
|
cache_file = "/var/lib/dnscrypt-proxy2/public-resolvers.md";
|
|
|
|
minisign_key =
|
|
|
|
"RWQf6LRCGA9i53mlYecO4IzT51TGPpvWucNSCh1CBM0QTaLn73Y7GFO3";
|
2021-05-11 20:58:03 +02:00
|
|
|
};
|
|
|
|
|
2023-11-19 00:48:43 +01:00
|
|
|
server_names = [ "mullvad-doh" "controld-unfiltered" ];
|
2021-05-11 20:58:03 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
systemd.services.dnscrypt-proxy2.serviceConfig = {
|
|
|
|
StateDirectory = lib.mkForce "dnscrypt-proxy2";
|
|
|
|
};
|
|
|
|
}
|