aboutsummaryrefslogtreecommitdiffstats
path: root/cmd
diff options
context:
space:
mode:
authorLunny Xiao <xiaolunwen@gmail.com>2016-12-31 17:16:02 +0800
committerLunny Xiao <xiaolunwen@gmail.com>2016-12-31 17:16:02 +0800
commitbf85c82087adaf5e9bebdcd3c863e2e0a061c746 (patch)
tree5f874b736b0fbb796ac735d064bb9a714a856025 /cmd
parentc0904f1942071ce870ab9d87bd6c7f49f614ee82 (diff)
downloadgitea-bf85c82087adaf5e9bebdcd3c863e2e0a061c746.tar.gz
gitea-bf85c82087adaf5e9bebdcd3c863e2e0a061c746.zip
fix windows build broken by #416
Diffstat (limited to 'cmd')
-rw-r--r--cmd/web.go26
-rw-r--r--cmd/web_graceful.go44
-rw-r--r--cmd/web_windows.go19
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)
+}