Please note, this module is now in deprecated status. It is provided as-is as an example of how to use the Porkbun API to download and install a SSL certificate, but is no longer maintained.
Porkbun's minimalist Certbot alternative leaves the certificate generation to Porkbun and simply downloads certs to the location of your choosing, then reloads your web server with the command of your choosing.
Automated SSL cert generation software such as Certbot can be tricky to set up, especially if you want a wildcard certificate, which requires DNS access, or you use an unusual web server. Porkbun already has a massive certificate generation infrastructure, and a certificate API. You can let Porkbun handle the hassle of generating the certificate, and use certbun to pull it via the API and install it locally.
We recommend manually downloading the certificate bundle and getting it working with your web server first, before trying to automate the process via certbun. Once your web server is reliably serving HTTPS traffic with no issue, you can automate the renewal process with certbun.
- Install Python if it's not already installed. This client is Python 2-compatible so it should run out of the box on MacOS and many Linux distributions. If you're running Windows, you should download the most recent production Python version.
- Download and uncompress certbun to the folder of your choice
- Install the requests library:
pip install requests
- Rename config.json.example to config.json and paste in your generated API and Secret keys. Save the config file. If you haven't yet generated the keys, check out our Getting Started Guide.
- Configure the config file's domain field with the domain you wish to pull certs from.
- Configure the config file's domainCertLocation, privateKeyLocation, intermediateCertLocation, and publicKeyLocation fields with where you want the retrieved certificates to be saved. If your web server doesn't need the intermediate cert and public key, you can specify /dev/null as the filename.
- Configure the config file's commandToReloadWebserver field with the command you typically execute to get your web server to load the new certificate bundle. This command will run immediately after the files have been copied into place. I usually use
/sbin/service nginx reload
on Amazon Linux VPS instances I administer, but the command will vary depending on your web server and operating system.
python certbun.py /path/to/config.json
Since this client works in a fairly non-sophisticated way, you probably just want to download certs every week or so and restart your web server.
Edit your crontab with:
crontab -e
If you've never done this before, you may want to read a guide on how to do it.
Assuming you wanted certbun to run once per week, you'd add a line like:
23 1 * * 1 python /path/to/certbun.py /path/to/config.json | logger