Views and ACLs

Views allow to differentiate resolver behavior based on “who asked the query”. This allows you to achieve access control, personalized blacklists and filters based on how the DNS request came.

views:
  # only allow answering to specific subnets
  - subnets: [ 0.0.0.0/0, "::/0" ] # words starting with :: need quoting
    answer: refused
  - subnets: [ 10.0.10.0/24, 127.0.0.1, "::1" ]
    answer: allow

Views allow you to combine query source information with other policy rules using tags.

views:
  # Apply `malware` and `localnames` rules to these clients and turn off dns64.
  # We'd also need to use these tags inside local-data: to really change anything.
  - subnets: [ 2001:db8:1::/56 ]
    tags: [ malware, localnames ]
    options:
      dns64: false

views: <list>

Views define a list of rules where each rule contains some matching condition(s) and some action(s).

For each request, the resolver chooses a single rule matching all of its conditions. Rules with more precise client subnets have preference, but other priorities are undefined. The chosen rule may tell the resolver to refuse to answer, set some additional options, or choose which groups of content rules would apply.

Conditions

subnets: <list of subnets>

Identifies the client based on their source address. This is the only mandatory part of each rule. You may use [ 0.0.0.0/0, "::/0" ] to match all external requests.

dst-subnet: <string>

Destination subnet, i.e. restricting the IP address that accepted the query.

Warning

If you configured listening on wildcards 0.0.0.0 or ::, the destination address for UDP queries will be just that instead of the real address.

protocols: <list of strings>

List of protocols for the query; subset of: udp53, tcp53, dot, doh, doq.

Actions

tags: <list of tags>

Tags to link view with other policy. Read more about tags here.

answer: allow|refused|noanswer

Direct approach how to handle request from clients identified by a view.

  • refused - Terminate query resolution and return REFUSED to the requestor.

  • allow - Query resolution is allowed. This option is useful for cutting exceptions inside larger disallowed subnets.

  • noanswer - Terminate query resolution and do not return any answer to the requestor.

Warning

During normal operation, an answer should always be returned. Deliberate query drops are indistinguishable from packet loss and may cause problems as described in RFC 8906. Only use noanswer on very specific occasions, e.g. as a defense mechanism during an attack, and prefer other actions (e.g. refused) for normal operation.

options:

Specific options for clients identified by the view.

minimize: true|false

Send minimum amount of information in recursive queries to enhance privacy.

dns64: true|false

Enable/disable DNS64.

price-factor: <float>
Default:

1.0

Multiplies prices of operations in rate limiting and defer; i.e. the number of queries is multiplied by the value for rate limiting and the measured time for defer. In other words, we can say that both instant-limit and rate-limit are divided by the value and similarly all limits are divided for defer.

Use 0.0 to never use rate limiting and always assign the highest priority level in defer.

Warning

The effect on defer may be currently limited, because some of the measured operations on incoming data occur before processing views and the default price-factor value is thus used for them.