diff options
author | Andrey Nering <andrey.nering@gmail.com> | 2017-01-01 10:45:51 -0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-01-01 10:45:51 -0200 |
commit | aea1b2b02e495012e7cf93cb6b66d401e5a7fb5a (patch) | |
tree | cf4a6eed19f279260ea2d5741a61423ed8dda910 | |
parent | 787fda53efc65916294caa6faf4aa8ecaf6cf86c (diff) | |
parent | bf85c82087adaf5e9bebdcd3c863e2e0a061c746 (diff) | |
download | gitea-aea1b2b02e495012e7cf93cb6b66d401e5a7fb5a.tar.gz gitea-aea1b2b02e495012e7cf93cb6b66d401e5a7fb5a.zip |
Merge pull request #543 from lunny/lunny/fallback_graceful_windows
Fix windows build broken by #416
-rw-r--r-- | cmd/web.go | 26 | ||||
-rw-r--r-- | cmd/web_graceful.go | 44 | ||||
-rw-r--r-- | cmd/web_windows.go | 19 |
3 files changed, 65 insertions, 24 deletions
diff --git a/cmd/web.go b/cmd/web.go index ecaf74daaa..7ba7a7ded4 100644 --- a/cmd/web.go +++ b/cmd/web.go @@ -5,7 +5,6 @@ package cmd import ( - "crypto/tls" "fmt" "net" "net/http" @@ -31,7 +30,6 @@ import ( "code.gitea.io/gitea/routers/repo" "code.gitea.io/gitea/routers/user" - "github.com/facebookgo/grace/gracehttp" "github.com/go-macaron/binding" "github.com/go-macaron/cache" "github.com/go-macaron/captcha" @@ -616,29 +614,9 @@ func runWeb(ctx *cli.Context) error { var err error switch setting.Protocol { case setting.HTTP: - err = gracehttp.Serve(&http.Server{ - Addr: listenAddr, - Handler: m, - }) + err = runHTTP(listenAddr, m) case setting.HTTPS: - config := &tls.Config{ - MinVersion: tls.VersionTLS10, - } - if config.NextProtos == nil { - config.NextProtos = []string{"http/1.1"} - } - - config.Certificates = make([]tls.Certificate, 1) - config.Certificates[0], err = tls.LoadX509KeyPair(setting.CertFile, setting.KeyFile) - if err != nil { - log.Fatal(4, "Failed to load https cert file %s: %v", listenAddr, err) - } - - err = gracehttp.Serve(&http.Server{ - Addr: listenAddr, - Handler: m, - TLSConfig: config, - }) + err = runHTTPS(listenAddr, setting.CertFile, setting.KeyFile, m) case setting.FCGI: err = fcgi.Serve(nil, m) case setting.UnixSocket: diff --git a/cmd/web_graceful.go b/cmd/web_graceful.go new file mode 100644 index 0000000000..488cd4036a --- /dev/null +++ b/cmd/web_graceful.go @@ -0,0 +1,44 @@ +// +build !windows + +// Copyright 2016 The Gitea Authors. All rights reserved. +// Use of this source code is governed by a MIT-style +// license that can be found in the LICENSE file. + +package cmd + +import ( + "crypto/tls" + "log" + "net/http" + + "github.com/facebookgo/grace/gracehttp" +) + +func runHTTP(listenAddr string, m http.Handler) error { + return gracehttp.Serve(&http.Server{ + Addr: listenAddr, + Handler: m, + }) +} + +func runHTTPS(listenAddr, certFile, keyFile string, m http.Handler) error { + config := &tls.Config{ + MinVersion: tls.VersionTLS10, + } + if config.NextProtos == nil { + config.NextProtos = []string{"http/1.1"} + } + + config.Certificates = make([]tls.Certificate, 1) + var err error + config.Certificates[0], err = tls.LoadX509KeyPair(certFile, keyFile) + if err != nil { + log.Fatal(4, "Failed to load https cert file %s: %v", listenAddr, err) + } + + return gracehttp.Serve(&http.Server{ + Addr: listenAddr, + Handler: m, + TLSConfig: config, + }) +} diff --git a/cmd/web_windows.go b/cmd/web_windows.go new file mode 100644 index 0000000000..0fc6cbea0d --- /dev/null +++ b/cmd/web_windows.go @@ -0,0 +1,19 @@ +// +build windows + +// Copyright 2016 The Gitea Authors. All rights reserved. +// Use of this source code is governed by a MIT-style +// license that can be found in the LICENSE file. + +package cmd + +import ( + "net/http" +) + +func runHTTP(listenAddr string, m http.Handler) error { + return http.ListenAndServe(listenAddr, m) +} + +func runHTTPS(listenAddr, certFile, keyFile string, m http.Handler) error { + return http.ListenAndServeTLS(listenAddr, certFile, keyFile, m) +} |