dnscontrol/documentation/examples.md

214 lines
5.5 KiB
Markdown
Raw Normal View History

## Typical DNS Records ##
2017-03-23 03:20:19 +08:00
{% code title="dnsconfig.js" %}
```javascript
D("example.com", REG_MY_PROVIDER, DnsProvider(DSP_MY_PROVIDER),
A("@", "1.2.3.4"), // The naked or "apex" domain.
A("server1", "2.3.4.5"),
AAAA("wide", "2001:0db8:85a3:0000:0000:8a2e:0370:7334"),
CNAME("www", "server1"),
CNAME("another", "service.mycloud.com."),
MX("mail", 10, "mailserver"),
MX("mail", 20, "mailqueue"),
TXT("the", "message"),
NS("department2", "ns1.dnsexample.com."), // use different nameservers
NS("department2", "ns2.dnsexample.com.") // for department2.example.com
2017-03-23 03:20:19 +08:00
)
```
{% endcode %}
2017-03-23 03:20:19 +08:00
## Set TTLs ##
{% code title="dnsconfig.js" %}
```javascript
var mailTTL = TTL("1h");
D("example.com", registrar,
NAMESERVER_TTL("10m"), // On domain apex NS RRs
DefaultTTL("5m"), // Default for a domain
MX("@", 5, "1.2.3.4", mailTTL), // use variable to
MX("@", 10, "4.3.2.1", mailTTL), // set TTL
A("@", "1.2.3.4", TTL("10m")), // individual record
CNAME("mail", "mx01") // TTL of 5m, as defined per DefaultTTL()
);
```
{% endcode %}
2017-03-23 03:20:19 +08:00
## Variables for common IP Addresses ##
{% code title="dnsconfig.js" %}
```javascript
var addrA = IP("1.2.3.4")
2017-03-21 11:47:18 +08:00
var DSP_R53 = NewDnsProvider("route53_user1");
D("example.com", REG_MY_PROVIDER, DnsProvider(DSP_R53),
A("@", addrA), // 1.2.3.4
A("www", addrA + 1), // 1.2.3.5
2017-03-21 11:47:18 +08:00
)
```
{% endcode %}
2017-03-21 11:47:18 +08:00
{% hint style="info" %}
**NOTE**: The [`IP()`](functions/global/IP.md) function doesn't currently support IPv6 (PRs welcome!). IPv6 addresses are strings.
{% endhint %}
{% code title="dnsconfig.js" %}
```javascript
var addrAAAA = "0:0:0:0:0:0:0:0";
```
{% endcode %}
## Variables to swap active Data Center ##
{% code title="dnsconfig.js" %}
```javascript
var DSP_R53 = NewDnsProvider("route53_user1");
var dcA = IP("5.5.5.5");
var dcB = IP("6.6.6.6");
2017-03-21 11:47:18 +08:00
// switch to dcB to failover
var activeDC = dcA;
D("example.com", REG_MY_PROVIDER, DnsProvider(DSP_R53),
A("@", activeDC + 5), // fixed address based on activeDC
2017-03-21 11:47:18 +08:00
)
```
{% endcode %}
2017-03-21 11:47:18 +08:00
## Macro for repeated records ##
{% code title="dnsconfig.js" %}
```javascript
var GOOGLE_APPS_MX_RECORDS = [
MX("@", 1, "aspmx.l.google.com."),
MX("@", 5, "alt1.aspmx.l.google.com."),
MX("@", 5, "alt2.aspmx.l.google.com."),
MX("@", 10, "alt3.aspmx.l.google.com."),
MX("@", 10, "alt4.aspmx.l.google.com."),
]
var GOOGLE_APPS_CNAME_RECORDS = [
CNAME("calendar", "ghs.googlehosted.com."),
CNAME("drive", "ghs.googlehosted.com."),
CNAME("mail", "ghs.googlehosted.com."),
CNAME("groups", "ghs.googlehosted.com."),
CNAME("sites", "ghs.googlehosted.com."),
CNAME("start", "ghs.googlehosted.com."),
2017-03-21 11:47:18 +08:00
]
D("example.com", REG_MY_PROVIDER, DnsProvider(DSP_R53),
GOOGLE_APPS_MX_RECORDS,
GOOGLE_APPS_CNAME_RECORDS,
A("@", "1.2.3.4")
2017-03-21 11:47:18 +08:00
)
```
{% endcode %}
2017-03-21 11:47:18 +08:00
## Use SPF_BUILDER to add comments to SPF records ##
{% code title="dnsconfig.js" %}
```javascript
D("example.tld", REG_MY_PROVIDER, DSP, ...
A("@", "10.2.2.2"),
MX("@", "example.tld."),
SPF_BUILDER({
label: "@",
overflow: "_spf%d",
raw: "_rawspf",
ttl: "5m",
parts: [
"v=spf1",
"ip4:198.252.206.0/24", // ny-mail*
"ip4:192.111.0.0/24", // co-mail*
"include:_spf.google.com", // GSuite
"~all"
]
}),
);
```
{% endcode %}
## Set default records modifiers ##
{% code title="dnsconfig.js" %}
```javascript
DEFAULTS(
NAMESERVER_TTL("24h"),
DefaultTTL("12h"),
CF_PROXY_DEFAULT_OFF
);
```
{% endcode %}
# Advanced Examples #
## Dual DNS Providers ##
{% code title="dnsconfig.js" %}
```javascript
var DSP_R53 = NewDnsProvider("route53_user1");
var DSP_GCLOUD = NewDnsProvider("gcloud_admin");
D("example.com", REG_MY_PROVIDER, DnsProvider(DSP_R53), DnsProvider(DSP_GCLOUD),
A("@", "1.2.3.4")
2017-03-21 11:47:18 +08:00
)
// above zone uses 8 NS records total (4 from each provider dynamically gathered)
// below zone will only take 2 from each for a total of 4. May be better for performance reasons.
D("example2.com", REG_MY_PROVIDER, DnsProvider(DSP_R53, 2), DnsProvider(DSP_GCLOUD ,2),
A("@", "1.2.3.4")
2017-03-21 11:47:18 +08:00
)
// or set a Provider as a non-authoritative backup (don"t register its nameservers)
D("example3.com", REG_MY_PROVIDER, DnsProvider(DSP_R53), DnsProvider(DSP_GCLOUD, 0),
A("@", "1.2.3.4")
2017-03-21 11:47:18 +08:00
)
```
{% endcode %}
## Automate Fastmail DKIM records ##
In this example we need a macro that can dynamically change for each domain.
Suppose you have many domains that use Fastmail as an MX. Here's a macro that sets the MX records.
{% code title="dnsconfig.js" %}
```javascript
var FASTMAIL_MX = [
MX("@", 10, "in1-smtp.messagingengine.com."),
MX("@", 20, "in2-smtp.messagingengine.com."),
]
```
{% endcode %}
Fastmail also supplied CNAMES to implement DKIM, and they all match a pattern
that includes the domain name. We can't use a simple macro. Instead, we use
a function that takes the domain name as a parameter to generate the right
records dynamically.
{% code title="dnsconfig.js" %}
```javascript
var FASTMAIL_DKIM = function(the_domain){
return [
CNAME("fm1._domainkey", "fm1." + the_domain + ".dkim.fmhosted.com."),
CNAME("fm2._domainkey", "fm2." + the_domain + ".dkim.fmhosted.com."),
CNAME("fm3._domainkey", "fm3." + the_domain + ".dkim.fmhosted.com.")
]
}
```
{% endcode %}
We can then use the macros as such:
{% code title="dnsconfig.js" %}
```javascript
var REG_NONE = NewRegistrar("none");
var DSP_R53_MAIN = NewDnsProvider("r53_main");
D("example.com", REG_NONE, DnsProvider(DSP_R53_MAIN),
FASTMAIL_MX,
FASTMAIL_DKIM("example.com")
)
```
{% endcode %}
### More advanced examples
2023-05-19 03:43:37 +08:00
See the [Code Tricks](code-tricks.md) page.