mirror of
https://github.com/certbot/certbot.git
synced 2026-06-05 06:42:10 -04:00
* Add external snap docs and clean up dev docs * Correctly refer to content identifiers * Expand plugin interface docs and add line breaks |
||
|---|---|---|
| .. | ||
| build_remote.py | ||
| generate_dnsplugins_postrefreshhook.sh | ||
| generate_dnsplugins_snapcraft.sh | ||
| README.md | ||
Certbot Snaps
Local Testing and Development
Initial VM Set Up
These steps need to be done once to set up your VM and do not need to be run again to rebuild the snap.
- Start with a Focal VM. You need a full virtual machine using something like DigitalOcean, EC2, or VirtualBox. Docker won't work. Another version of Ubuntu can probably be used, but Focal was used when writing these instructions.
- Set up a user other than root with sudo privileges for use with snapcraft and run all of the following commands with it. A command to do this for a user named certbot looks like
adduser certbot && usermod -aG sudo certbot && su - certbot. - Install git and python with
sudo apt update && sudo apt install -y git python. - Set up lxd for use with snapcraft by running
sudo snap install lxd && sudo /snap/bin/lxd.migrate -yes && sudo /snap/bin/lxd waitready && sudo /snap/bin/lxd init --auto(errors here are ok; it may already have been installed on your system). - Add your current user to the lxd group and update your shell to have the new assignment by running
sudo usermod -a -G lxd ${USER} && newgrp lxd. - Install snapcraft with
sudo snap install --classic snapcraft. cd ~(or any other directory where you want our source files to be)- Run
git clone git://github.com/certbot/certbot cd certbot
Build the Snaps
These are the steps to build and install the snaps. If you have run these steps before, you may want to run the commands in the section below to clean things up before building the snap again.
- Run
snapcraft --use-lxd. - Install the generated snap with
sudo snap install --dangerous --classic certbot_*_amd64.snap. You can transfer the snap to a different machine to run it there instead if you prefer. - Run
tools/merge_requirements.py tools/dev_constraints.txt <(tools/strip_hashes.py letsencrypt-auto-source/pieces/dependency-requirements.txt) > certbot-dns-dnsimple/snap-constraints.txt(this is a workaround for https://github.com/certbot/certbot/issues/8100). cd certbot-dns-dnsimplesnapcraft --use-lxd- Run
sudo snap set certbot trust-plugin-with-root=ok. - Install the generated snap with
sudo snap install --dangerous certbot-dns-dnsimple_*_amd64.snap. Again, you can transfer the snap to a different machine to run it there instead if you prefer. - Connect the plugin with
sudo snap connect certbot:plugin certbot-dns-dnsimple. - Connect the plugin metadata with
sudo snap connect certbot-dns-dnsimple:certbot-metadata certbot:certbot-metadata. Install the plugin again to test refresh; logs are at/var/snap/certbot-dns-dnsimple/current/debuglog. - Now you can run Certbot as normal. For example,
certbot pluginsshould display the DNSimple plugin as installed.
Reset the Environment
The instructions below clean up the build environment so it can reliably be used again.
cd ~/certbot(or to an alternate path where you put our source files)snapcraft clean --use-lxdrm certbot_*_amd64.snapcd certbot-dns-dnsimplerm certbot-dns-dnsimple_*_amd64.snapsnapcraft clean --use-lxdcd ..