perkeep/pkg/netutil
mpl c55c8602d3 server/camlistored: use Let's Encrypt
Or to be more precise, golang.org/x/crypto/acme/autocert

The default behaviour regarding HTTPS certificates changes as such:

1) If the high-level config does not specify a certificate, the
low-level config used to be generated with a default certificate path.
This is no longer the case.
2) If the low-level config does not specify a certificate, we used to
generate self-signed ones at the default path. This is no longer always
the case. We only do this if our hostname does not look like an FQDN,
otherwise we try Let's Encrypt.
3) As a result, if the high-level config does not specify a certificate,
and the hostname looks like an FQDN, it is no longer the case that we'll
generate a self-signed. Let's Encrypt will be tried instead.

To sum up, the new rules are:
If cert/key files are specified, and found, use them.
If cert/key files are specified, not found, and the default values,
generate them (self-signed CA used as a cert), and use them.
If cert/key files are not specified, use Let's Encrypt if we have an
FQDN, otherwise generate self-signed.

Regarding cert caching:

On non-GCE, store the autocert cache dir in
osutil.CamliConfigDir()/letsencrypt.cache
On GCE, store in /tmp/camli-letsencrypt.cache

Fixes #701
Fixes #859

Change-Id: Id78a9c6f113fa93e38d690033c10a749d1844ea6
2016-12-05 19:43:37 +01:00
..
ident.go app/publisher: infinite scrolling of set members 2016-07-15 00:34:52 +02:00
ident_cgo.go app/publisher: infinite scrolling of set members 2016-07-15 00:34:52 +02:00
ident_nocgo.go app/publisher: infinite scrolling of set members 2016-07-15 00:34:52 +02:00
ident_test.go localhost auth: resolve localhost to [::1] if using ipv6 2013-10-21 17:02:03 +01:00
netutil.go server/camlistored: use Let's Encrypt 2016-12-05 19:43:37 +01:00
netutil_test.go pkg/netutil: test loopbackIP 2016-04-05 18:45:17 +02:00