This is a little pet project to install TLS certificates into your FRITZ!Box. I use Let’s Encrypt to get free certificates and I got tired using this tedious process to update the certs all the time. So I started to poke at my FRITZ!Box Fon WLAN 7390 and now it is automated!
Although it should work with other versions as well, it is only tested with:
- FRITZ!Box Fon WLAN 7530 (FRITZ!OS: 8.02)
- FRITZ!Box 7490 (FRITZ!OS: 07.57)
In case you want to know how to do that manually, take a look at AVM's knowledge base articles:
Homebrew:
brew install --cask tisba/taps/fritz-tlsGo
go install -ldflags="-s -w" github.com/tisba/fritz-tls@latestfritz-tls --domain fritz.example.comDone :)
General options for fritz-tls are:
- --helpto get usage information
- --host(default:- http://fritz.box) to specify how to talk to your FRITZ!Box. If you want to login with username and password, specify the user in the URL:- --host http://[email protected]:8080. The default username (which is sometimes randomly generated) can be found under- System>- FRITZ!Box Users.
- --password(optional, default: '') to specify the user's password. If unspecified,- fritz-tlswill prompt the user instead. Alternatively, you may set the environment variable- FRITZTLS_ADMIN_PASS.
- --insecure(optional) to skip TLS verification when talking to- --hostin case it's HTTPS and you currently have a broken or expired TLS certificate, or if your FRITZ!Box has its own self-signed certificate.
- --verification-url(optional) to specify what URL to use to check certificate installation. Defaults to- --host.
- --authcheck(optional) to only check if the provided credentials are valid.
- --versionPrint- fritz-tlsversion and exit. All other options are ignored.
fritz-tls can install any TLS certificate or acquire one using Let's Encrypt.
By default, Let's Encrypt is used to acquire a certificate, options are:
- --domainthe domain you want to have your certificate generated for (if- --hostis not- fritz.box,- --domainit will default to the host name in- --host).
- --email(optional) your mail address you want to have registered with Let’s Encrypt expiration service.
- --save(optional) to save generated private key and acquired certificate.
- --dns-provider(default- manual) to specify one of lego's supported DNS providers. Note that you might have to set environment variables to configure your provider, e.g.- AWS_ACCESS_KEY_ID,- AWS_SECRET_ACCESS_KEY,- AWS_REGIONand- AWS_HOSTED_ZONE_ID. I use name servers by AWS/Route53 and inwx, so I have to provide- INWX_USERNAME,- INWX_PASSWORD. I'm not sure if there is a overview, so for now you have to consult the source.
- --dns-resolver(optional) to specify the resolver to be used for recursive DNS queries. If not provided, the system default will be used. Supported format is- host:port.
- --force-renewto force a renewal, even if the current certificate is valid for the requested domain and still valid for at least the next 30 days.
- --acme-server(Optional, default- https://acme-v02.api.letsencrypt.org/directory) The server URL of the ACME server. Use- https://acme-staging-v02.api.letsencrypt.org/directoryfor Let's Encrypt staging environment.
You can also provide a certificate bundle (cert + private key) directly to fritz-tls so they can be installed:
- obtain your TLS certificate, e.g. via Let’s Encrypt.
- install the newly generated certificate:
fritz-tls --key=./certbot/live/demo.example.com/privkey.pem --fullchain=./certbot/live/demo.example.com/fullchain.pem- --manualto use a locally stored TLS material. This option is required when using either- --keyand- --fullchainor- --bundle.
- --keyand- --fullchainto provide the private key and the certificate chain.
- --bundleas an alternative for- --keyand- --fullchain. The bundle where the password-less private key and certificate are both present.
You can use cron (on Linux) or launchd (on macOS) to run fritz-tls automatically. By default, it will check if the cert is still valid and only renew if the remaining validity is less then 30 days. Check out https://www.launchd.info to learn how launchd can be used or use https://launched.zerowidth.com to generate a plist file.
These are some things I'd like to to in the future:
- add validation for private keys and certificate before uploading (avoid trying to upload garbage)
- allow password protected private keys (when not provisioned by LE)
Releases are done via Github Actions on push of a git tag. To make a release, run
git tag va.b.c
git push --tags