]> git.street.me.uk Git - andy/dehydrated.git/blame - README.md
use _exiterr helper in a few more places
[andy/dehydrated.git] / README.md
CommitLineData
7664f1c2 1# letsencrypt.sh [![Build Status](https://travis-ci.org/lukas2511/letsencrypt.sh.svg?branch=master)](https://travis-ci.org/lukas2511/letsencrypt.sh)
61f0b7ed 2
e567a87e 3This is a client for signing certificates with an ACME-server (currently only provided by letsencrypt) implemented as a relatively simple bash-script.
274e8e41
LS
4
5It uses the `openssl` utility for everything related to actually handling keys and certificates, so you need to have that installed.
6
7Other dependencies are (for now): curl, sed
8
9Perl no longer is a dependency.
77df80b5 10The only remaining perl code in this repository is the script you can use to convert your existing letsencrypt-keyfile into something openssl (and this script) can read.
274e8e41
LS
11
12Current features:
13- Signing of a list of domains
14- Renewal if a certificate is about to expire
12c566b1 15- Certificate revocation
274e8e41
LS
16
17Please keep in mind that this software and even the acme-protocol are relatively young and may still have some unresolved issues.
18Feel free to report any issues you find with this script or contribute by submitting a pullrequest.
0d7913ab
LS
19
20## Usage:
21
8662a000
LS
22```text
23Usage: ./letsencrypt.sh [-h] [command [argument]] [parameter [argument]] [parameter [argument]] ...
0d7913ab 24
083c6736 25Default command: help
8662a000
LS
26
27Commands:
083c6736 28 --cron (-c) Sign/renew non-existant/changed/expiring certificates.
8662a000
LS
29 --revoke (-r) path/to/cert.pem Revoke specified certificate
30 --help (-h) Show help text
31 --env (-e) Output configuration variables for use in other scripts
32
33Parameters:
92a822e0
LS
34 --domain (-d) domain.tld Use specified domain name(s) instead of domains.txt entry (one certificate!)
35 --force (-x) Force renew of certificate even if it is longer valid than value in RENEW_DAYS
8662a000 36 --privkey (-p) path/to/key.pem Use specified private key instead of account key (useful for revocation)
92a822e0 37 --config (-f) path/to/config.sh Use specified config file
0d7913ab 38```
8662a000
LS
39
40### domains.txt
41
42The file `domains.txt` should have the following format:
43
44```text
0d7913ab
LS
45example.com www.example.com
46example.net www.example.net wiki.example.net
47```
48
49This states that there should be two certificates `example.com` and `example.net`,
50with the other domains in the corresponding line being their alternative names.
51
7b968344 52### $WELLKNOWN / challenge-response
0d7913ab 53
7b968344 54Boulder (acme-server) is looking for challenge responses under your domain in the `.well-known/acme-challenge` directory
0d7913ab 55
92a822e0 56This script uses `http-01`-type verification (for now) so you need to have that directory available over normal http (no ssl).
7b968344
LS
57
58A full URL would look like `http://example.org/.well-known/acme-challenge/c3VjaC1jaGFsbGVuZ2UtbXVjaA-aW52YWxpZC13b3c`.
59
60An example setup to get this to work would be:
61
62nginx.conf:
0d7913ab 63```
7b968344 64...
0d7913ab 65location /.well-known/acme-challenge {
7b968344 66 alias /var/www/letsencrypt;
0d7913ab 67}
7b968344
LS
68...
69```
70
71config.sh:
72```bash
73...
74WELLKNOWN="/var/www/letsencrypt"
75...
0d7913ab
LS
76```
77
7b968344
LS
78An alternative to setting the WELLKNOWN variable would be to create a symlink to the default location next to the script (or BASEDIR):
79`ln -s /var/www/letsencrypt .acme-challenges`
8662a000 80
0d7913ab
LS
81## Import
82
83### import-account.pl
84
85This perl-script can be used to import the account key from the original letsencrypt client.
86
87You should copy `private_key.json` to the same directory as the script.
88The json-file can be found in a subdirectory of `/etc/letsencrypt/accounts/acme-v01.api.letsencrypt.org/directory`.
89
ffa35427 90Usage: `./import-account.pl`
0d7913ab
LS
91
92### import-certs.sh
93
94This script can be used to import private keys and certificates created by the original letsencrypt client.
95
96By default it expects the certificates to be found under `/etc/letsencrypt`, which is the default output directory of the original client.
97You can change the path by setting LETSENCRYPT in your config file: ```LETSENCRYPT="/etc/letsencrypt"```.
98
99Usage: `./import-certs.sh`