aboutsummaryrefslogtreecommitdiff
path: root/modules/common/adguard/default.nix
blob: 9929bc1bace0124dfa5dd4170bad5415280ab9cb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
{ config, lib, ... }:
{
  services = {
    adguardhome = {
      enable = false;
      openFirewall = false;
      mutableSettings = false;

      settings = {
        http = {
          address = "127.0.0.1:3000";
        };

        dns = {
          bind_hosts = [ "10.0.0.5" "127.0.0.1" ];
          port = 53;

          upstream_dns = [
            "9.9.9.9"
            "149.112.112.112"
          ];
          fallback_dns = [
            "1.1.1.1"
            "1.0.0.1"
          ];
          bootstrap_dns = [
            "9.9.9.9"
            "149.112.112.112"
          ];
        };

        filtering = {
          rewrites = [
            # jellyfin
            {
              domain = "media.internal";
              answer = "10.0.0.5";
            } 
            # immich
            {
              domain = "photos.internal";
              answer = "10.0.0.5";
            } 
            # calibre-web
            {
              domain = "library.internal";
              answer = "10.0.0.5";
            } 
            # searxng
            {
              domain = "search.internal";
              answer = "10.0.0.5";
            } 
            # ollama api
            {
              domain = "ollama.internal";
              answer = "10.0.0.5";
            } 
            # open-webui
            {
              domain = "chat.internal";
              answer = "10.0.0.5";
            } 
            # forgejo
            {
              domain = "forge.internal";
              answer = "10.0.0.5";
            } 
            # cgit
            {
              domain = "code.internal";
              answer = "10.0.0.5";
            }
            # adguard
            {
              domain = "dns.internal";
              answer = "10.0.0.5";
            } 
            # grafana
            {
              domain = "monitor.internal";
              answer = "10.0.0.5";
            }
          ];
        };
      };
    };

    nginx.virtualHosts = {
      "dns.internal" = {
        locations."/" = {
          proxyPass = "http://127.0.0.1:3000";
          proxyWebsockets = true;
        };
      };
    };
  };

  # networking = {
  #   nameservers = [
  #     "9.9.9.9"
  #     "127.0.0.1"
  #     "10.0.0.5"
  #   ];
  # };
}
Directive (EU) 2019/790, Article 4(3); all rights regarding Text and Data Mining (TDM) are reserved.