132 lines
3.9 KiB
Markdown
Raw Permalink Normal View History

2019-05-15 23:22:14 -06:00
# [acme-dns-01-cli](https://git.rootprojects.org/root/acme-dns-01-cli.js) | a [Root](https://rootprojects.org) project
2018-05-01 14:14:15 -06:00
An extremely simple reference implementation
2019-05-15 23:08:24 -06:00
of an ACME (Let's Encrypt) dns-01 challenge strategy.
This generic implementation can be adapted to work with any node.js ACME client,
although it was built for [Greenlock](https://git.rootprojects.org/root/greenlock-express.js)
and [ACME.js](https://git.rootprojects.org/root/acme-v2.js).
2016-10-14 13:39:54 -06:00
```
_acme-challenge.example.com TXT xxxxxxxxxxxxxxxx TTL 60
```
- Prints the ACME challenge DNS Host and DNS Key Authorization Digest to the terminal
- (waits for you to hit enter before continuing)
- Let's you know when the challenge as succeeded or failed, and is safe to remove.
Other ACME Challenge Reference Implementations:
- [acme-http-01-cli](https://git.rootprojects.org/root/acme-http-01-cli.js.git)
- [acme-http-01-fs](https://git.rootprojects.org/root/acme-http-01-webroot.js.git)
- [**acme-dns-01-cli**](https://git.rootprojects.org/root/acme-dns-01-cli.js.git)
2019-04-02 20:59:11 -06:00
## Install
2016-10-14 13:39:54 -06:00
```bash
2019-05-15 23:30:38 -06:00
npm install --save acme-dns-01-cli@3.x
2016-10-14 13:39:54 -06:00
```
2019-05-15 23:08:24 -06:00
If you have `greenlock@v2.6` or lower, you'll need the old `le-challenge-dns@2.x` instead.
2019-04-02 20:59:11 -06:00
## Usage
2016-10-14 13:39:54 -06:00
```js
2018-05-12 19:22:09 -06:00
var Greenlock = require('greenlock');
2016-10-14 13:39:54 -06:00
2018-05-12 19:22:09 -06:00
Greenlock.create({
challenges: {
'http-01': require('acme-http-01-fs'),
'dns-01': require('acme-dns-01-cli').create({ debug: true }),
'tls-alpn-01': require('acme-tls-alpn-01-cli')
}
// ...
});
2018-05-12 19:22:09 -06:00
```
2019-04-02 20:59:11 -06:00
You can also switch between different implementations by
overwriting the default with the one that you want in `approveDomains()`:
2019-04-02 20:59:11 -06:00
```js
2019-05-15 23:08:24 -06:00
function approveDomains(opts) {
// ...
2019-04-02 20:59:11 -06:00
if (!opts.challenges) { opts.challenges = {}; }
2019-05-15 23:08:24 -06:00
opts.challenges['dns-01'] = acmeDns01Cli;
2019-04-02 20:59:11 -06:00
2019-05-15 23:08:24 -06:00
return Promise.resolve({ ... });
2018-05-12 19:22:09 -06:00
}
```
2016-10-14 13:39:54 -06:00
NOTE: If you request a certificate with 6 domains listed,
it will require 6 individual challenges.
## Exposed (Promise) Methods
2016-10-14 13:39:54 -06:00
For ACME Challenge:
- `set(opts)`
- `remove(opts)`
2019-04-02 20:59:11 -06:00
The `dns-01` strategy supports wildcards (whereas `http-01` does not).
The options object has whatever options were set in `approveDomains()`
as well as the `challenge`, which looks like this:
2019-04-02 20:59:11 -06:00
```json
{
"challenge": {
"identifier": { "type": "dns", "value": "example.com" },
"wildcard": true,
"altname": "*.example.com",
"type": "dns-01",
"token": "xxxxxx",
"keyAuthorization": "xxxxxx.abc123",
"dnsHost": "_acme-challenge.example.com",
"dnsAuthorization": "xyz567",
"expires": "1970-01-01T00:00:00Z"
2019-04-02 20:59:11 -06:00
}
}
```
2016-10-14 13:39:54 -06:00
2018-05-12 19:22:09 -06:00
For greenlock.js internals:
2016-10-14 13:39:54 -06:00
- `options` stores the internal defaults merged with the user-supplied options
Optional:
- `get(limitedOpts)`
Note: Typically there wouldn't be a `get()` for DNS because the NameServer (not Greenlock) answers the requests.
It could be used for testing implementations, but that's about it.
(though I suppose you could implement it if you happen to run your DNS and webserver together... kinda weird though)
If there were an implementation of Greenlock integrated directly into
a NameServer (which currently there is not), it would probably look like this:
```json
{
"challenge": {
"type": "dns-01",
"identifier": { "type": "dns", "value": "example.com" },
"token": "abc123",
"dnsHost": "_acme-challenge.example.com"
}
}
```
2019-05-15 23:08:24 -06:00
# Legal & Rules of the Road
Greenlock™ and Bluecrypt™ are [trademarks](https://rootprojects.org/legal/#trademark) of AJ ONeal
The rule of thumb is "attribute, but don't confuse". For example:
> Built with [Greenlock](https://git.rootprojects.org/root/greenlock.js) (a [Root](https://rootprojects.org) project).
Please [contact us](mailto:aj@therootcompany.com) if you have any questions in regards to our trademark,
attribution, and/or visible source policies. We want to build great software and a great community.
[Greenlock™](https://git.rootprojects.org/root/greenlock.js) |
MPL-2.0 |
[Terms of Use](https://therootcompany.com/legal/#terms) |
[Privacy Policy](https://therootcompany.com/legal/#privacy)