[getdns-api] Spec change request: Set suffixes from OS
Willem Toorop
willem at nlnetlabs.nl
Thu Mar 24 09:30:45 UTC 2016
Op 23-03-16 om 22:46 schreef Willem Toorop:
> Dear all,
>
> The current spec (in paragraph 8.5 https://getdnsapi.net/spec.html#8.5 )
> states that the default suffixes is "an empty list".
>
> I propose to change this to "set from the OS when the context is created
> with the "set_from_os" parameter set, otherwise an empty list".
>
> This would be consistent with how other settings are "set from the OS",
> such as for example the upstream recursive servers.
>
> The complete text will then become:
>
>
> getdns_return_t
> getdns_context_set_suffix(
> getdns_context *context,
> getdns_list *value
> );
>
> The value is a list of bindatas that are strings that are to
> be appended based on getdns_context_set_append_name; the
> default is an set from the OS when the context is created with
Sorry, the "an" was unintended. "set" was meant to be a verb. So the
sentence should be:
the default is set from the OS when the context is created with
the "set_from_os" parameter set, otherwise an empty list.
The terminology "set from OS" is perhaps a little vague, but it is
coming from the spec (and not from me the implementer). The spec
elaborates a little more in 4th paragraph of section 8 (
https://getdnsapi.net/spec.html#8. ) where it says:
When the context is used in the API for the first time and
set_from_os is 1, the API starts replacing some of the values
with values from the OS, such as those that would be found in
res_query(3), /etc/resolv.conf, and so on, then proceeds with
the new function.
In our implementation we construct the suffix list from the "domain" and
"search" options from /etc/resolv.conf in unix like systems, and read it
from the registry location
HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/Tcpip/Parameters
or HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/VxD/MSTCP
keys "Domain", "DhcpDomain" and "SearchList" on windows. This is also
what ldns and Net::DNS do, and what getaddrinfo() does by default.
Note that the text also mentions that you have to create the context
with the set_from_OS argument of the getdns_context_create() function
set. If you create a context without that parameter, then you do not
read the upstreams and suffixes from /etc/resolv.conf.
I would also be happy to have the getdns_context_set_append_name()
default value to be GETDNS_APPEND_NAME_NEVER . It is just that current
default value is not what people are used to expect, so I want it to be
more what is conventional.
-- Willem
> the "set_from_os" parameter set, otherwise an empty list. The
> values here follow the rules in section 2.1 of RFC 4343 to
> allow non-ASCII octets and special characters in labels.
>
>
> Do you agree?
>
> I would appreciate a response on short notice as I am about to do the
> 1.0beta release very soon (preferable before the DNS-OARC and IETF95).
>
> Thanks,
>
> -- Willem
> _______________________________________________
> spec mailing list
> spec at getdnsapi.net
>
More information about the spec
mailing list