diff options
author | Greg Karékinian <greg@karekinian.com> | 2018-12-11 16:46:12 +0100 |
---|---|---|
committer | techknowlogick <hello@techknowlogick.com> | 2018-12-11 16:46:12 +0100 |
commit | 15d6cf179d3b97b2ab88ece39617bcc4db1a2026 (patch) | |
tree | 70fcac1eb7ff3e7c8069f1edf6a1ad368dd5a0a8 /cmd/web.go | |
parent | Approvals at Branch Protection (#5350) (diff) | |
download | forgejo-15d6cf179d3b97b2ab88ece39617bcc4db1a2026.tar.xz forgejo-15d6cf179d3b97b2ab88ece39617bcc4db1a2026.zip |
Fix the Let's Encrypt handler by listening on a valid address (#5525)
* Fix the Let's Encrypt handler by listening on a valid address
Also handle errors in the HTTP server go routine, return a fatal error
when something goes wrong.
Thanks to @gbl08ma for finding the actual bug
Here is an example of the error handling:
2018/12/11 14:23:07 [....io/gitea/cmd/web.go:87 func1()] [E] Failed to
start the Let's Encrypt handler on port 30: listen tcp 0.0.0.0:30: bind:
permission denied
Closes #5280
* Fix a typo
Diffstat (limited to 'cmd/web.go')
-rw-r--r-- | cmd/web.go | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/cmd/web.go b/cmd/web.go index 4991721211..b6c014a2e3 100644 --- a/cmd/web.go +++ b/cmd/web.go @@ -80,7 +80,13 @@ func runLetsEncrypt(listenAddr, domain, directory, email string, m http.Handler) Cache: autocert.DirCache(directory), Email: email, } - go http.ListenAndServe(listenAddr+":"+setting.PortToRedirect, certManager.HTTPHandler(http.HandlerFunc(runLetsEncryptFallbackHandler))) // all traffic coming into HTTP will be redirect to HTTPS automatically (LE HTTP-01 validatio happens here) + go func() { + log.Info("Running Let's Encrypt handler on %s", setting.HTTPAddr+":"+setting.PortToRedirect) + var err = http.ListenAndServe(setting.HTTPAddr+":"+setting.PortToRedirect, certManager.HTTPHandler(http.HandlerFunc(runLetsEncryptFallbackHandler))) // all traffic coming into HTTP will be redirect to HTTPS automatically (LE HTTP-01 validation happens here) + if err != nil { + log.Fatal(4, "Failed to start the Let's Encrypt handler on port %s: %v", setting.PortToRedirect, err) + } + }() server := &http.Server{ Addr: listenAddr, Handler: m, |