dnscontrol/docs/_functions/global/NewDnsProvider.md
Tom Limoncelli 9e6d642e35
NEW FEATURE: Moving provider TYPE from dnsconfig.js to creds.json (#1500)
Fixes https://github.com/StackExchange/dnscontrol/issues/1457

* New-style creds.json implememented backwards compatible

* Update tests

* Update docs

* Assume new-style TYPE
2022-05-08 14:23:45 -04:00

1.5 KiB

name parameters return
NewDnsProvider
name
type
meta
string

NewDnsProvider activates a DNS Service Provider (DSP) specified in creds.json. A DSP stores a DNS zone's records and provides DNS service for the zone (i.e. answers on port 53 to queries related to the zone).

  • name must match the name of an entry in creds.json.
  • type specifies a valid DNS provider type identifier listed on the provider page..
    • Starting with v3.16, the type is optional. If it is absent, the TYPE field in creds.json is used instead. You can leave it out. (Thanks to JavaScript magic, you can leave it out even when there are more fields).
    • Starting with v4.0, specifying the type may be an error. Please add the TYPE field to creds.json and remove this parameter from dnsconfig.js to prepare.
  • meta is a way to send additional parameters to the provider. It is optional and only certain providers use it. See the individual provider docs for details.

This function will return an opaque string that should be assigned to a variable name for use in D directives.

Prior to v3.16:

var REG_MYNDC = NewRegistrar("mynamedotcom", "NAMEDOTCOM");
var DNS_MYAWS = NewDnsProvider("myaws", "ROUTE53");

D("example.com", REG_MYNDC, DnsProvider(DNS_MYAWS),
  A("@","1.2.3.4")
);

In v3.16 and later:

var REG_MYNDC = NewRegistrar("mynamedotcom");
var DNS_MYAWS = NewDnsProvider("myaws");

D("example.com", REG_MYNDC, DnsProvider(DNS_MYAWS),
  A("@","1.2.3.4")
);