Starting with version 4.7.0, the PowerDNS Recursor has the ability to add additional records to query results.
This allows clients to learn useful information without having to do an extra query.
Examples of useful information are the related A and AAAA records to a query for an MX record:
;; ANSWER SECTION:
example.net.              86362   IN      MX      20 mx2.example.net.
example.net.              86362   IN      MX      10 mx1.example.net.
;; ADDITIONAL SECTION:
mx1.example.net.          86368   IN      A       192.168.1.2
mx2.example.net.          86400   IN      A       192.168.1.3
mx1.example.net.          86372   IN      AAAA    2001:db8::1
mx2.example.net.          86374   IN      AAAA    2001:db8::2
The default is that the Recursor never adds additional records to an answer it sends to the client.
The default behavior can be changed by using the addAllowedAdditionalQType() function in the lua-config-file.
For each query type allowing additional record processing the Recursor has code to determine the target name to add.
The target qtypes to add are configurable as is the mode, specifying how to retrieve the records to add.
An example of a configuration:
addAllowedAdditionalQType(pdns.MX, {pdns.A, pdns.AAAA})
addAllowedAdditionalQType(pdns.NAPTR, {pdns.A, pdns.AAAA, pdns.SRV}, {mode=pdns.AdditionalMode.ResolveImmediately})
The first line specifies that additional records should be added to the results of MX queries using the default mode.
The qtype of the records to be added are A and AAAA.
The default mode is pdns.AdditionalMode.CacheOnlyRequireAuth; this mode will only look in the record cache.
The second line specifies that three record types should be added to NAPTR answers.
If needed, the Recursor will do an active resolve to retrieve these records.
Note that with record types such as NAPTR which can return records such as SRV, which may themselves return additional
A or AAAA records, the above example would not be sufficient to return those additional A and/or AAAA records.
In such a case, you  would need to add an additional line to tell the recursor to fetch the additional records for the SRV
qtype as well. An example configuration for this case is shown below:
addAllowedAdditionalQType(pdns.NAPTR, {pdns.A, pdns.AAAA, pdns.SRV}, {mode=pdns.AdditionalMode.ResolveImmediately})
addAllowedAdditionalQType(pdns.SRV, {pdns.A, pdns.AAAA}, {mode=pdns.AdditionalMode.ResolveImmediately})
The modes available are:
pdns.AdditionalMode.IgnoreaddAllowedAdditionalQType() for the qtype.pdns.AdditionalMode.CacheOnlypdns.AdditionalMode.CacheOnlyRequireAuthpdns.AdditionalMode.ResolveImmediatelypdns.AdditionalMode.ResolveDeferredIf an additional record is not available at that time the query is stored into the packet cache the answer packet stored in the packet cache will not contain the additional record.
Clients repeating the same question will get an answer from the packet cache if the question is still in the packet cache.
These answers do not have the additional record, even if the record cache has learned it in the meantime .
Clients will only see the additional record once the packet cache entry expires and the record cache is consulted again.
The pdns.AdditionalMode.ResolveImmediately mode will not have this issue, at the cost of delaying the first query to resolve the additional records needed.
The pdns.AdditionalMode.ResolveDeferred mode will only store answers in the packet cache if it determines that no deferred tasks are needed, i.e. either a positive or negative answer for potential additional records is available.
If the additional records for an answer have low TTLs compared to the records in the answer section, tasks will be pushed often.
Until all tasks for the answer have completed the packet cache will not contain the answer, making the packet cache less effective for this specific answer.
The following function is available to configure additional record processing.
Reloading the Lua configuration will replace the current configuration with the new one.
Calling  addAllowedAdditionalQType() multiple times with a specific qtype will replace previous calls with the same qtype.
addAllowedAdditionalQType(qtype, targets [, options ]))¶New in version 4.7.0.
Allow additional processing for qtype.
| Parameters: | 
 | 
|---|