2017-04-01 21:44:35 +08:00
---
name: Cloudflare
layout: default
jsId: CLOUDFLAREAPI
---
# Cloudflare Provider
## Configuration
In your providers config json file you must provide your cloudflare.com api
username and access token:
{% highlight json %}
{
"cloudflare.com":{
"apikey": "your-cloudflare-api-key",
2017-04-20 00:41:12 +08:00
"apiuser": "your-cloudflare-email-address"
2017-04-01 21:44:35 +08:00
}
}
{% endhighlight %}
## Metadata
Record level metadata availible:
2017-05-20 02:15:57 +08:00
* `cloudflare_proxy` ("on", "off", or "full")
2017-04-01 21:44:35 +08:00
Domain level metadata availible:
2017-05-20 02:15:57 +08:00
* `cloudflare_proxy_default` ("on", "off", or "full")
2017-04-01 21:44:35 +08:00
Provider level metadata availible:
2017-05-20 02:15:57 +08:00
* `ip_conversions`
* `manage_redirects` : set to `true` to manage page-rule based redirects
2017-04-01 21:44:35 +08:00
2017-05-17 03:55:51 +08:00
What does on/off/full mean?
2017-05-11 13:02:57 +08:00
2017-05-17 03:55:51 +08:00
* "off" disables the Cloudflare proxy
* "on" enables the Cloudflare proxy (turns on the "orange cloud")
* "full" is the same as "on" but also enables Railgun. DNSControl will prevent you from accidentally enabling "full" on a CNAME that points to an A record that is set to "off", as this is generally not desired.
**Aliases:**
2017-05-11 13:02:57 +08:00
2017-05-17 03:55:51 +08:00
To make configuration files more readable and less prone to typos,
the following aliases are pre-defined:
2017-05-11 13:02:57 +08:00
{% highlight json %}
2017-05-17 03:55:51 +08:00
// Meta settings for individual records.
var CF_PROXY_OFF = {'cloudflare_proxy': 'off'}; // Proxy disabled.
var CF_PROXY_ON = {'cloudflare_proxy': 'on'}; // Proxy enabled.
var CF_PROXY_FULL = {'cloudflare_proxy': 'full'}; // Proxy+Railgun enabled.
// Per-domain meta settings:
// Proxy default off for entire domain (the default):
var CF_PROXY_DEFAULT_OFF = {'cloudflare_proxy_default': 'off'};
// Proxy default on for entire domain:
var CF_PROXY_DEFAULT_ON = {'cloudflare_proxy_default': 'on'};
2017-05-11 13:02:57 +08:00
{% endhighlight %}
2017-05-17 03:55:51 +08:00
The following example shows how to set meta variables with and without aliases:
2017-05-11 13:02:57 +08:00
{% highlight json %}
2017-05-17 03:55:51 +08:00
D('example.tld', REG_NAMECOM, DnsProvider(CFLARE),
A('www1','1.2.3.11', CF_PROXY_ON), // turn proxy ON.
A('www2','1.2.3.12', CF_PROXY_OFF), // default is OFF, this is a no-op.
A('www3','1.2.3.13', {'cloudflare_proxy': 'on'}) // why would anyone do this?
2017-05-11 13:02:57 +08:00
);
{% endhighlight %}
2017-04-01 21:44:35 +08:00
## Usage
Example javascript:
{% highlight js %}
2017-05-17 03:55:51 +08:00
var REG_NAMECOM = NewRegistrar('name.com','NAMEDOTCOM');
var CFLARE = NewDnsProvider('cloudflare.com','CLOUDFLAREAPI');
// Example domain where the CF proxy abides by the default (off).
D('example.tld', REG_NAMECOM, DnsProvider(CFLARE),
A('proxied','1.2.3.4', CF_PROXY_ON),
A('notproxied','1.2.3.5'),
A('another','1.2.3.6', CF_PROXY_ON),
ALIAS('@','www.example.tld.', CF_PROXY_ON),
CNAME('myalias','www.example.tld.', CF_PROXY_ON)
);
2017-04-01 21:44:35 +08:00
2017-05-17 03:55:51 +08:00
// Example domain where the CF proxy default is set to "on":
D('example2.tld', REG_NAMECOM, DnsProvider(CFLARE),
CF_PROXY_DEFAULT_ON, // Enable CF proxy for all items unless otherwise noted.
A('proxied','1.2.3.4'),
A('notproxied','1.2.3.5', CF_PROXY_OFF),
A('another','1.2.3.6'),
ALIAS('@','www.example2.tld.'),
CNAME('myalias','www.example2.tld.')
2017-04-01 21:44:35 +08:00
);
{%endhighlight%}
## Activation
DNSControl depends on a Cloudflare Global API Key that's available under "My Settings".
2017-05-03 21:32:47 +08:00
## New domains
If a domain does not exist in your CloudFlare account, DNSControl
will *not* automatically add it. You'll need to do that via the
2017-05-17 03:55:51 +08:00
control panel manually or via the `dnscontrol create-domains` command.
2017-05-20 02:15:57 +08:00
## Redirects
The cloudflare provider can manage Page-Rule based redirects for your domains. Simply use the `CF_REDIRECT` and `CF_TEMP_REDIRECT` functions to make redirects:
{% highlight js %}
// chiphacker.com is an alias for electronics.stackexchange.com
2017-08-03 01:51:13 +08:00
var CFLARE = NewDnsProvider('cloudflare.com','CLOUDFLAREAPI', {"manage_redirects": true}); // enable manage_redirects
2017-05-20 02:15:57 +08:00
D("chiphacker.com", REG_NAMECOM, DnsProvider(CFLARE),
// must have A records with orange cloud on. Otherwise page rule will never run.
A("@","1.2.3.4", CF_PROXY_ON),
A("www", "1.2.3.4", CF_PROXY_ON)
A("meta", "1.2.3.4", CF_PROXY_ON),
// 302 for meta subdomain
2017-08-03 01:51:13 +08:00
CF_TEMP_REDIRECT("meta.chiphacker.com/*", "https://electronics.meta.stackexchange.com/$1"),
2017-05-20 02:15:57 +08:00
// 301 all subdomains and preserve path
2017-08-03 01:51:13 +08:00
CF_REDIRECT("*chiphacker.com/*", "https://electronics.stackexchange.com/$2"),
2017-05-20 02:15:57 +08:00
);
{%endhighlight%}
Notice a few details:
2017-08-30 01:49:39 +08:00
1. We need an A record with cloudflare proxy on, or the page rule will never run.
2017-05-20 02:15:57 +08:00
2. The IP address in those A records may be mostly irrelevant, as cloudflare should handle all requests (assuming some page rule matches).
2017-05-26 08:38:48 +08:00
3. Ordering matters for priority. CF_REDIRECT records will be added in the order they appear in your js. So put catch-alls at the bottom.