2017-02-11 13:24:00 +08:00
# Using deploy api
2017-02-08 21:02:00 -05:00
2017-02-23 19:04:08 +08:00
Before you can deploy your cert, you must [issue the cert first ](https://github.com/Neilpang/acme.sh/wiki/How-to-issue-a-cert ).
2017-02-11 13:24:00 +08:00
Here are the scripts to deploy the certs/key to the server/services.
2017-10-02 15:04:02 +02:00
## 1. Deploy the certs to your cpanel host
2017-02-11 13:24:00 +08:00
2017-09-03 13:35:20 +04:00
If you want to deploy using cpanel UAPI see 7.
2017-02-11 13:24:00 +08:00
(cpanel deploy hook is not finished yet, this is just an example.)
2017-02-23 19:04:08 +08:00
2017-02-11 13:24:00 +08:00
Then you can deploy now:
```sh
export DEPLOY_CPANEL_USER=myusername
export DEPLOY_CPANEL_PASSWORD=PASSWORD
2017-02-23 19:01:48 +08:00
acme.sh --deploy -d example.com --deploy-hook cpanel
2017-02-11 13:24:00 +08:00
```
2017-10-02 15:04:02 +02:00
## 2. Deploy ssl cert on kong proxy engine based on api
2017-02-11 13:24:00 +08:00
Before you can deploy your cert, you must [issue the cert first ](https://github.com/Neilpang/acme.sh/wiki/How-to-issue-a-cert ).
2017-04-27 20:06:47 +08:00
Currently supports Kong-v0.10.x.
2017-02-11 13:24:00 +08:00
2017-04-27 20:06:47 +08:00
```sh
acme.sh --deploy -d ftp.example.com --deploy-hook kong
```
2017-02-11 13:24:00 +08:00
2017-10-02 15:04:02 +02:00
## 3. Deploy the cert to remote server through SSH access
2017-02-08 21:02:00 -05:00
The ssh deploy plugin allows you to deploy certificates to a remote host
using SSH command to connect to the remote server. The ssh plugin is invoked
with the following command...
2017-02-12 11:24:00 -05:00
```sh
2017-02-08 21:02:00 -05:00
acme.sh --deploy -d example.com --deploy-hook ssh
```
Prior to running this for the first time you must tell the plugin where
and how to deploy the certificates. This is done by exporting the following
2017-02-08 21:13:00 -05:00
environment variables. This is not required for subsequent runs as the
2017-02-08 21:02:00 -05:00
values are stored by acme.sh in the domain configuration files.
Required...
2017-02-12 11:24:00 -05:00
```
2017-03-07 11:57:03 -05:00
export DEPLOY_SSH_USER=username
2017-02-08 21:02:00 -05:00
```
Optional...
2017-02-12 11:24:00 -05:00
```
2017-03-07 11:57:03 -05:00
export DEPLOY_SSH_CMD=custom ssh command
export DEPLOY_SSH_SERVER=url or ip address of remote host
export DEPLOY_SSH_KEYFILE=filename for private key
export DEPLOY_SSH_CERTFILE=filename for certificate file
export DEPLOY_SSH_CAFILE=filename for intermediate CA file
export DEPLOY_SSH_FULLCHAIN=filename for fullchain file
export DEPLOY_SSH_REMOTE_CMD=command to execute on remote host
export DEPLOY_SSH_BACKUP=yes or no
2017-02-08 21:02:00 -05:00
```
2017-03-07 11:57:03 -05:00
**DEPLOY_SSH_USER**
2017-02-08 21:02:00 -05:00
Username at the remote host that SSH will login with. Note that
SSH must be able to login to remote host without a password... SSH Keys
must have been exchanged with the remote host. Validate and test that you
can login to USER@URL from the host running acme.sh before using this script.
The USER@URL at the remote server must also have has permissions to write to
the target location of the certificate files and to execute any commands
(e.g. to stop/start services).
2017-02-12 11:17:23 -05:00
2017-03-07 11:57:03 -05:00
**DEPLOY_SSH_CMD**
2017-02-11 16:11:27 -05:00
You can customize the ssh command used to connect to the remote host. For example
if you need to connect to a specific port at the remote server you can set this
2017-02-12 11:17:23 -05:00
to, for example, "ssh -p 22" or to use `sshpass` to provide password inline
instead of exchanging ssh keys (this is not recommended, using keys is
more secure).
2017-03-07 11:57:03 -05:00
**DEPLOY_SSH_SERVER**
2017-02-08 21:02:00 -05:00
URL or IP Address of the remote server. If not provided then the domain
name provided on the acme.sh --deploy command line is used.
2017-02-12 11:17:23 -05:00
2017-03-07 11:57:03 -05:00
**DEPLOY_SSH_KEYFILE**
2017-02-08 21:13:00 -05:00
Target filename for the private key issued by LetsEncrypt.
2017-02-12 11:17:23 -05:00
2017-03-07 11:57:03 -05:00
**DEPLOY_SSH_CERTFILE**
2017-02-12 11:17:23 -05:00
Target filename for the certificate issued by LetsEncrypt.
If this is the same as the previous filename (for keyfile) then it is
appended to the same file.
2017-03-07 11:57:03 -05:00
**DEPLOY_SSH_CAFILE**
2017-02-08 21:13:00 -05:00
Target filename for the CA intermediate certificate issued by LetsEncrypt.
2017-02-12 11:17:23 -05:00
If this is the same as a previous filename (for keyfile or certfile) then
it is appended to the same file.
2017-03-07 11:57:03 -05:00
**DEPLOY_SSH_FULLCHAIN**
2017-02-08 21:13:00 -05:00
Target filename for the fullchain certificate issued by LetsEncrypt.
2017-02-12 11:17:23 -05:00
If this is the same as a previous filename (for keyfile, certfile or
cafile) then it is appended to the same file.
2017-03-07 11:57:03 -05:00
**DEPLOY_SSH_REMOTE_CMD**
2017-02-08 21:02:00 -05:00
Command to execute on the remote server after copying any certificates. This
2017-02-11 16:11:27 -05:00
could be any additional command required for example to stop and restart
the service.
2017-02-12 11:17:23 -05:00
2017-03-07 11:57:03 -05:00
**DEPLOY_SSH_BACKUP**
2017-02-08 21:02:00 -05:00
Before writing a certificate file to the remote server the existing
certificate will be copied to a backup directory on the remote server.
These are placed in a hidden directory in the home directory of the SSH
user
2017-02-12 11:24:00 -05:00
```sh
2017-02-08 21:02:00 -05:00
~/.acme_ssh_deploy/[domain name]-backup-[timestamp]
```
Any backups older than 180 days will be deleted when new certificates
2017-02-11 16:42:44 -05:00
are deployed. This defaults to "yes" set to "no" to disable backup.
2017-02-12 11:17:23 -05:00
2018-03-03 16:27:17 +01:00
###Examples using SSH deploy
The following example illustrates deploying certificates to a QNAP NAS
2017-02-13 20:32:12 -05:00
(tested with QTS version 4.2.3)
2017-02-12 11:17:23 -05:00
2017-02-12 11:24:00 -05:00
```sh
2017-03-07 11:57:03 -05:00
export DEPLOY_SSH_USER="admin"
export DEPLOY_SSH_KEYFILE="/etc/stunnel/stunnel.pem"
export DEPLOY_SSH_CERTFILE="/etc/stunnel/stunnel.pem"
export DEPLOY_SSH_CAFILE="/etc/stunnel/uca.pem"
export DEPLOY_SSH_REMOTE_CMD="/etc/init.d/stunnel.sh restart"
2017-02-12 11:17:23 -05:00
acme.sh --deploy -d qnap.example.com --deploy-hook ssh
```
2017-02-13 20:32:12 -05:00
Note how in this example both the private key and certificate point to
the same file. This will result in the certificate being appended
to the same file as the private key... a common requirement of several
services.
2017-02-12 11:17:23 -05:00
2018-03-03 16:27:17 +01:00
The next example illustrates deploying certificates to a Unifi
Controller (tested with version 5.4.11).
2017-02-12 11:17:23 -05:00
2017-02-12 11:24:00 -05:00
```sh
2017-03-07 11:57:03 -05:00
export DEPLOY_SSH_USER="root"
export DEPLOY_SSH_KEYFILE="/var/lib/unifi/unifi.example.com.key"
export DEPLOY_SSH_FULLCHAIN="/var/lib/unifi/unifi.example.com.cer"
export DEPLOY_SSH_REMOTE_CMD="openssl pkcs12 -export \
2017-02-12 11:17:23 -05:00
-inkey /var/lib/unifi/unifi.example.com.key \
-in /var/lib/unifi/unifi.example.com.cer \
-out /var/lib/unifi/unifi.example.com.p12 \
-name ubnt -password pass:temppass \
& & keytool -importkeystore -deststorepass aircontrolenterprise \
2017-02-12 11:20:16 -05:00
-destkeypass aircontrolenterprise \
-destkeystore /var/lib/unifi/keystore \
2017-02-12 11:17:23 -05:00
-srckeystore /var/lib/unifi/unifi.example.com.p12 \
-srcstoretype PKCS12 -srcstorepass temppass -alias ubnt -noprompt \
& & service unifi restart"
2017-02-12 11:20:16 -05:00
acme.sh --deploy -d unifi.example.com --deploy-hook ssh
2017-02-12 11:17:23 -05:00
```
2018-03-03 16:27:17 +01:00
In this example we execute several commands on the remote host
2017-02-12 11:17:23 -05:00
after the certificate files have been copied... to generate a pkcs12 file
2018-03-03 16:27:17 +01:00
compatible with Unifi, to import it into the Unifi keystore and then finally
2017-02-12 11:17:23 -05:00
to restart the service.
2017-02-12 18:08:17 -05:00
Note also that once the certificate is imported
into the keystore the individual certificate files are no longer
required. We could if we desired delete those files immediately. If we
do that then we should disable backup at the remote host (as there are
no files to backup -- they were erased during deployment). For example...
```sh
2017-03-07 11:57:03 -05:00
export DEPLOY_SSH_BACKUP=no
2017-02-12 18:20:43 -05:00
# modify the end of the remote command...
2017-02-12 18:08:17 -05:00
& & rm /var/lib/unifi/unifi.example.com.key \
/var/lib/unifi/unifi.example.com.cer \
/var/lib/unifi/unifi.example.com.p12 \
& & service unifi restart
```
2017-02-11 13:24:00 +08:00
2017-10-02 15:04:02 +02:00
## 4. Deploy the cert to local vsftpd server
2017-02-11 13:24:00 +08:00
2017-02-21 23:18:11 +08:00
```sh
acme.sh --deploy -d ftp.example.com --deploy-hook vsftpd
```
The default vsftpd conf file is `/etc/vsftpd.conf` , if your vsftpd conf is not in the default location, you can specify one:
```sh
export DEPLOY_VSFTPD_CONF="/etc/vsftpd.conf"
acme.sh --deploy -d ftp.example.com --deploy-hook vsftpd
```
The default command to restart vsftpd server is `service vsftpd restart` , if it doesn't work, you can specify one:
```sh
export DEPLOY_VSFTPD_RELOAD="/etc/init.d/vsftpd restart"
acme.sh --deploy -d ftp.example.com --deploy-hook vsftpd
```
2017-02-11 13:24:00 +08:00
2017-10-02 15:04:02 +02:00
## 5. Deploy the cert to local exim4 server
2017-02-23 20:03:03 +08:00
```sh
acme.sh --deploy -d ftp.example.com --deploy-hook exim4
```
The default exim4 conf file is `/etc/exim/exim.conf` , if your exim4 conf is not in the default location, you can specify one:
```sh
export DEPLOY_EXIM4_CONF="/etc/exim4/exim4.conf.template"
acme.sh --deploy -d ftp.example.com --deploy-hook exim4
```
The default command to restart exim4 server is `service exim4 restart` , if it doesn't work, you can specify one:
```sh
export DEPLOY_EXIM4_RELOAD="/etc/init.d/exim4 restart"
acme.sh --deploy -d ftp.example.com --deploy-hook exim4
```
2017-03-08 08:00:17 +09:00
## 6. Deploy the cert to OSX Keychain
```sh
acme.sh --deploy -d ftp.example.com --deploy-hook keychain
```
2017-08-25 20:51:31 +08:00
2017-09-03 13:35:20 +04:00
## 7. Deploy to cpanel host using UAPI
2017-08-25 20:51:31 +08:00
2017-09-03 13:35:20 +04:00
This hook is using UAPI and works in cPanel & WHM version 56 or newer.
2017-08-25 20:51:31 +08:00
```
acme.sh --deploy -d example.com --deploy-hook cpanel_uapi
```
2017-09-03 13:35:20 +04:00
DEPLOY_CPANEL_USER is required only if you run the script as root and it should contain cpanel username.
2017-08-25 20:51:31 +08:00
```sh
export DEPLOY_CPANEL_USER=username
acme.sh --deploy -d example.com --deploy-hook cpanel_uapi
```
2018-03-03 16:27:17 +01:00
Please note, that the cpanel_uapi hook will deploy only the first domain when your certificate will automatically renew. Therefore you should issue a separate certificate for each domain.
2017-08-25 20:51:31 +08:00
2017-08-30 00:45:03 +02:00
## 8. Deploy the cert to your FRITZ!Box router
2017-08-25 20:51:31 +08:00
2017-08-30 00:45:03 +02:00
You must specify the credentials that have administrative privileges on the FRITZ!Box in order to deploy the certificate, plus the URL of your FRITZ!Box, through the following environment variables:
```sh
$ export DEPLOY_FRITZBOX_USERNAME=my_username
$ export DEPLOY_FRITZBOX_PASSWORD=the_password
$ export DEPLOY_FRITZBOX_URL=https://fritzbox.example.com
```
2017-08-25 20:51:31 +08:00
2017-08-30 00:45:03 +02:00
After the first deployment, these values will be stored in your $HOME/.acme.sh/account.conf. You may now deploy the certificate like this:
2017-08-25 20:51:31 +08:00
2017-08-30 00:45:03 +02:00
```sh
2017-09-12 11:35:21 +02:00
acme.sh --deploy -d fritzbox.example.com --deploy-hook fritzbox
2017-08-30 00:45:03 +02:00
```
2017-08-25 20:51:31 +08:00
2017-10-02 08:39:55 +09:00
## 9. Deploy the cert to strongswan
2017-08-25 20:51:31 +08:00
2017-10-02 08:39:55 +09:00
```sh
acme.sh --deploy -d ftp.example.com --deploy-hook strongswan
```
2018-05-03 01:33:06 -05:00
## 10. Deploy the cert to HAProxy
You must specify the path where you want the concatenated key and certificate chain written.
```sh
export DEPLOY_HAPROXY_PEM_PATH=/etc/haproxy
```
2018-05-04 13:03:27 -05:00
You may optionally define the command to reload HAProxy. The value shown below will be used as the default if you don't set this environment variable.
```sh
export DEPLOY_HAPROXY_RELOAD="/usr/sbin/service haproxy restart"
```
2018-05-03 01:33:06 -05:00
You can then deploy the certificate as follows
```sh
acme.sh --deploy -d haproxy.example.com --deploy-hook haproxy
```
The path for the PEM file will be stored with the domain configuration and will be available when renewing, so that deploy will happen automatically when renewed.
2018-08-15 18:36:24 +02:00
## 11. Deploy your cert to Gitlab pages
You must define the API key and the informations for the project and Gitlab page you are updating the certificate for.
```sh
# The token can be created in your user settings under "Access Tokens"
export GITLAB_TOKEN="xxxxxxxxxxx"
# The project ID is displayed on the home page of the project
export GITLAB_PROJECT_ID=12345678
# The domain must match the one defined for the Gitlab page, without "https://"
export GITLAB_DOMAIN="www.mydomain.com"
```
You can then deploy the certificate as follows
```sh
acme.sh --deploy -d www.mydomain.com --deploy-hook gitlab
2018-12-10 18:17:18 +03:00
```
## 12. Deploy your cert to Hashicorp Vault
```sh
export VAULT_PREFIX="acme"
```
You can then deploy the certificate as follows
```sh
acme.sh --deploy -d www.mydomain.com --deploy-hook vault_cli
```
Your certs will be saved in Vault using this structure:
```sh
vault write "${VAULT_PREFIX}/${domain}/cert.pem" value=@"..."
vault write "${VAULT_PREFIX}/${domain}/cert.key" value=@"..."
vault write "${VAULT_PREFIX}/${domain}/chain.pem" value=@"..."
vault write "${VAULT_PREFIX}/${domain}/fullchain.pem" value=@"..."
```
You might be using Fabio load balancer (which can get certs from
Vault). It needs a bit different structure of your certs in Vault. It
gets certs only from keys that were saved in `prefix/domain` , like this:
```bash
vault write < PREFIX > /www.domain.com cert=@cert .pem key=@key .pem
```
If you want to save certs in Vault this way just set "FABIO" env
variable to anything (ex: "1") before running `acme.sh` :
```sh
export FABIO="1"
```