Andrew Timberlake Andrew Timberlake

Hi, I’m Andrew, a programmer and entrepreneur from South Africa,
building Mailcast for taking control of your email.
Thanks for visiting and reading.


How to get a letsencrypt dev certificate on a mac

For a number of my projects, I purchase a .dev domain for local development. I configure DNS to point to 127.0.0.1 or similar.

Most of the time I can get away with using a self-signed certificate, which I generate using the following commands:

Generating a self-signed certificate

This generates a wildcard certificate for *.domain.dev as well as the raw domain domain.dev.

Things to change if you’re going to use this for your own projects:

mkdir -p priv/cert/
openssl genrsa -out priv/cert/server.key 2048
openssl req -new -sha256 \
  -key priv/cert/server.key \
  -subj "/C=ZA/ST=Gauteng/O=ProjectName/CN=*.domain.dev" \
  -reqexts SAN -extensions SAN -config <(cat /private/etc/ssl/openssl.cnf \
  <(printf '[SAN]\nsubjectAltName=@alt_names\n\n[alt_names]\nDNS.1 = domain.dev\nDNS.2 = *.domain.dev')) \
  -out priv/cert/server.csr
openssl x509 -req \
  -extfile <(printf "subjectAltName=@alt_names\n\n[alt_names]\nDNS.1 = domain.dev\nDNS.2 = *.domain.dev") \
  -in priv/cert/server.csr \
  -CA ~/.ssh/myCA.pem -CAkey ~/.ssh/myCA.key -CAcreateserial \
  -days 397 -sha256 \
  -out priv/cert/server.crt

This works fine for most of my projects, but for a few I need a proper SSL certificate.

Generating a LetsEncrypt certificate

For some things, you need a certificate with a trusted root CA.

Typically, I would just SSH onto one of my Linux servers and generate a certificate there, then copy it back to my Mac. It’s not too tedious because each certificate from LetsEncrypt lasts 3 months.

Last night, I decided that there must be a way to do it directly on my Mac. I use Cloudflare so I can use DNS validation, which means no hosting needs to be running for this to work. (You could also do it with manual DNS validation)

Install certbot (this is the easy part):

brew install certbot

but then you can’t just install the Cloudflare plugin via Homebrew. You have to install it via PIP, but Hombrew’s certbot has it’s own virtual environment.

This then is how to install the Cloudflare plugin (from this issue):

$(brew --prefix certbot)/libexec/bin/python -mpip install certbot-dns-cloudflare

Update

When I tried to update a previous certificate, I had errors with upgrading the acme package. This worked:

$(brew --prefix certbot)/libexec/bin/python -mpip install certbot-dns-cloudflare --ignore-installed

Before you create the certificate, create a ~/.cloudflare.ini file with the following

dns_cloudflare_api_token=<your token>

This is the command to generate the certificate:

sudo certbot certonly --agree-tos -m '<your email>' \
-d '<your domain>' -d '*.<your domain>' \
--dns-cloudflare \
--dns-cloudflare-credentials ~/.cloudflare.ini \
--dns-cloudflare-propagation-seconds 30 \
--preferred-challenges dns-01

You can then find the certificate and key files in /etc/letsencrypt/live/<your domain>/
cert.pem, chain.pem, fullchain.pem, and privkey.pem

3 Sep 2024
dev, mac,