dnscontrol/docs/cli-variables.md
Jan-Philipp Benecke d759b7b4da
Document: CLI variables (#918)
* Initial version of CLI variables doc

* Add example based on comments

Co-authored-by: Tom Limoncelli <tlimoncelli@stackoverflow.com>
2020-11-13 12:18:38 -05:00

64 lines
1.9 KiB
Markdown

---
layout: default
title: CLI variables
---
# CLI variables
With dnscontrol you can pass variables from CLI into your `dnsconfig.js`.
This gives you the opportunity to run different code when a value is passed.
## 1. Passing variables
To pass a variable from CLI, just use the parameter `-v key=value` of the commands `preview` or `push`.
Example: `dnscontrol push -v testKey=testValue`
This would pass the variable with the name `testKey` and the value of `testValue` to `dnsconfig.js`
## 2. Define defaults
If you want to define some default values, that are used when no variable is passed from CLI,
you can do this with the following function:
```js
CLI_DEFAULTS({
'testValue': 'defaultValue'
});
```
You need to define this defaults just once in your `dnsconfig.js`.
Define the defaults **before** using it.
_Please keep in mind, if there is no default value and you do not pass a variable, but you are using it in your `dnsconfig.js` it will fail!_
## 3. Use cases
See some use cases for CLI variables.
#### Different IPs for internal/external DNS
```js
CLI_DEFAULTS({
'cliServer': 'external'
});
if (this.view == "internal") {
var host01 = "192.168.0.16";
var host02 = "192.168.0.17";
} else {
var host01 = "10.0.0.16";
var host02 = "10.0.0.17";
}
D("example.org", registrar, DnsProvider(public), DnsProvider(bind),
A('sitea', host01, TTL(1800)),
A('siteb', host01, TTL(1800)),
A('sitec', host02, TTL(1800)),
A('sited', host02, TTL(1800))
);
```
Running `dnscontrol push -v view=internal` would generate the zone for your internal dns.
Just running `dnscontrol push` would generate the zone for your external dns.
So you can use the same zone for external and internal resolution and there is no need to duplicate it.
#### ProTip
The cli variables functionality permits you to create very complex and
sophisticated configurations, but you shouldn't. Be nice to the next
person that edits the file, who may not be as expert as yourself.