2019-03-08 20:47:06 +02:00
|
|
|
Name = "External program"
|
|
|
|
Description = "Solving the DNS-01 challenge using an external program."
|
|
|
|
URL = "/dns/exec"
|
|
|
|
Code = "exec"
|
2019-04-17 21:32:38 +02:00
|
|
|
Since = "v0.5.0"
|
2019-03-08 20:47:06 +02:00
|
|
|
|
|
|
|
Example = '''
|
|
|
|
EXEC_PATH=/the/path/to/myscript.sh \
|
2020-11-27 21:40:44 +02:00
|
|
|
lego --email myemail@example.com --dns exec --domains my.example.org run
|
2019-03-08 20:47:06 +02:00
|
|
|
'''
|
|
|
|
|
|
|
|
Additional = '''
|
|
|
|
|
|
|
|
## Base Configuration
|
|
|
|
|
2019-05-06 19:37:51 +02:00
|
|
|
| Environment Variable Name | Description |
|
|
|
|
|---------------------------|---------------------------------------|
|
|
|
|
| `EXEC_MODE` | `RAW`, none |
|
|
|
|
| `EXEC_PATH` | The path of the the external program. |
|
2019-03-08 20:47:06 +02:00
|
|
|
|
|
|
|
|
|
|
|
## Additional Configuration
|
|
|
|
|
2019-05-06 19:37:51 +02:00
|
|
|
| Environment Variable Name | Description |
|
|
|
|
|----------------------------|-------------------------------------------|
|
|
|
|
| `EXEC_POLLING_INTERVAL` | Time between DNS propagation check. |
|
|
|
|
| `EXEC_PROPAGATION_TIMEOUT` | Maximum waiting time for DNS propagation. |
|
2021-10-21 23:33:38 +02:00
|
|
|
| `EXEC_SEQUENCE_INTERVAL` | Time between sequential requests. |
|
2018-12-06 23:50:17 +02:00
|
|
|
|
|
|
|
|
|
|
|
## Description
|
|
|
|
|
|
|
|
The file name of the external program is specified in the environment variable `EXEC_PATH`.
|
|
|
|
|
|
|
|
When it is run by lego, three command-line parameters are passed to it:
|
|
|
|
The action ("present" or "cleanup"), the fully-qualified domain name and the value for the record.
|
|
|
|
|
2020-11-27 21:40:44 +02:00
|
|
|
For example, requesting a certificate for the domain 'my.example.org' can be achieved by calling lego as follows:
|
2018-12-06 23:50:17 +02:00
|
|
|
|
|
|
|
```bash
|
|
|
|
EXEC_PATH=./update-dns.sh \
|
2020-11-27 21:40:44 +02:00
|
|
|
lego --email myemail@example.com \
|
|
|
|
--dns exec \
|
|
|
|
--domains my.example.org run
|
2018-12-06 23:50:17 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
It will then call the program './update-dns.sh' with like this:
|
|
|
|
|
|
|
|
```bash
|
2020-11-27 21:40:44 +02:00
|
|
|
./update-dns.sh "present" "_acme-challenge.my.example.org." "MsijOYZxqyjGnFGwhjrhfg-Xgbl5r68WPda0J9EgqqI"
|
2018-12-06 23:50:17 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
The program then needs to make sure the record is inserted.
|
|
|
|
When it returns an error via a non-zero exit code, lego aborts.
|
|
|
|
|
|
|
|
When the record is to be removed again,
|
|
|
|
the program is called with the first command-line parameter set to `cleanup` instead of `present`.
|
|
|
|
|
|
|
|
If you want to use the raw domain, token, and keyAuth values with your program, you can set `EXEC_MODE=RAW`:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
EXEC_MODE=RAW \
|
|
|
|
EXEC_PATH=./update-dns.sh \
|
2020-11-27 21:40:44 +02:00
|
|
|
lego --email myemail@example.com \
|
|
|
|
--dns exec \
|
|
|
|
--domains my.example.org run
|
2018-12-06 23:50:17 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
It will then call the program `./update-dns.sh` like this:
|
|
|
|
|
|
|
|
```bash
|
2020-11-27 21:40:44 +02:00
|
|
|
./update-dns.sh "present" "my.example.org." "--" "some-token" "KxAy-J3NwUmg9ZQuM-gP_Mq1nStaYSaP9tYQs5_-YsE.ksT-qywTd8058G-SHHWA3RAN72Pr0yWtPYmmY5UBpQ8"
|
2018-12-06 23:50:17 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
## Commands
|
|
|
|
|
2019-03-08 20:47:06 +02:00
|
|
|
{{% notice note %}}
|
|
|
|
The `--` is because the token MAY start with a `-`, and the called program may try and interpret a `-` as indicating a flag.
|
|
|
|
In the case of urfave, which is commonly used,
|
|
|
|
you can use the `--` delimiter to specify the start of positional arguments, and handle such a string safely.
|
|
|
|
{{% /notice %}}
|
|
|
|
|
2018-12-06 23:50:17 +02:00
|
|
|
### Present
|
|
|
|
|
|
|
|
| Mode | Command |
|
|
|
|
|---------|----------------------------------------------------|
|
|
|
|
| default | `myprogram present -- <FQDN> <record>` |
|
|
|
|
| `RAW` | `myprogram present -- <domain> <token> <key_auth>` |
|
|
|
|
|
|
|
|
### Cleanup
|
|
|
|
|
|
|
|
| Mode | Command |
|
|
|
|
|---------|----------------------------------------------------|
|
|
|
|
| default | `myprogram cleanup -- <FQDN> <record>` |
|
|
|
|
| `RAW` | `myprogram cleanup -- <domain> <token> <key_auth>` |
|
|
|
|
|
|
|
|
### Timeout
|
|
|
|
|
|
|
|
The command have to display propagation timeout and polling interval into Stdout.
|
|
|
|
|
|
|
|
The values must be formatted as JSON, and times are in seconds.
|
|
|
|
Example: `{"timeout": 30, "interval": 5}`
|
|
|
|
|
|
|
|
If an error occurs or if the command is not provided:
|
|
|
|
the default display propagation timeout and polling interval are used.
|
|
|
|
|
|
|
|
| Mode | Command |
|
|
|
|
|---------|----------------------------------------------------|
|
|
|
|
| default | `myprogram timeout` |
|
|
|
|
| `RAW` | `myprogram timeout` |
|
|
|
|
|
2019-03-08 20:47:06 +02:00
|
|
|
'''
|