2019-10-15 22:39:51 +09:00
|
|
|
// Copyright 2019 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 graceful
|
|
|
|
|
|
|
|
import (
|
2021-05-31 15:18:11 +09:00
|
|
|
"context"
|
2019-10-15 22:39:51 +09:00
|
|
|
"crypto/tls"
|
2021-05-31 15:18:11 +09:00
|
|
|
"net"
|
2019-10-15 22:39:51 +09:00
|
|
|
"net/http"
|
|
|
|
)
|
|
|
|
|
2021-03-08 11:43:59 +09:00
|
|
|
func newHTTPServer(network, address, name string, handler http.Handler) (*Server, ServeFunction) {
|
|
|
|
server := NewServer(network, address, name)
|
2019-10-15 22:39:51 +09:00
|
|
|
httpServer := http.Server{
|
|
|
|
ReadTimeout: DefaultReadTimeOut,
|
|
|
|
WriteTimeout: DefaultWriteTimeOut,
|
|
|
|
MaxHeaderBytes: DefaultMaxHeaderBytes,
|
|
|
|
Handler: handler,
|
2021-05-31 15:18:11 +09:00
|
|
|
BaseContext: func(net.Listener) context.Context { return GetManager().HammerContext() },
|
2019-10-15 22:39:51 +09:00
|
|
|
}
|
|
|
|
server.OnShutdown = func() {
|
|
|
|
httpServer.SetKeepAlivesEnabled(false)
|
|
|
|
}
|
|
|
|
return server, httpServer.Serve
|
|
|
|
}
|
|
|
|
|
|
|
|
// HTTPListenAndServe listens on the provided network address and then calls Serve
|
|
|
|
// to handle requests on incoming connections.
|
2021-03-08 11:43:59 +09:00
|
|
|
func HTTPListenAndServe(network, address, name string, handler http.Handler) error {
|
|
|
|
server, lHandler := newHTTPServer(network, address, name, handler)
|
2019-10-15 22:39:51 +09:00
|
|
|
return server.ListenAndServe(lHandler)
|
|
|
|
}
|
|
|
|
|
|
|
|
// HTTPListenAndServeTLS listens on the provided network address and then calls Serve
|
|
|
|
// to handle requests on incoming connections.
|
2021-03-08 11:43:59 +09:00
|
|
|
func HTTPListenAndServeTLS(network, address, name, certFile, keyFile string, handler http.Handler) error {
|
|
|
|
server, lHandler := newHTTPServer(network, address, name, handler)
|
2019-10-15 22:39:51 +09:00
|
|
|
return server.ListenAndServeTLS(certFile, keyFile, lHandler)
|
|
|
|
}
|
|
|
|
|
|
|
|
// HTTPListenAndServeTLSConfig listens on the provided network address and then calls Serve
|
|
|
|
// to handle requests on incoming connections.
|
2021-03-08 11:43:59 +09:00
|
|
|
func HTTPListenAndServeTLSConfig(network, address, name string, tlsConfig *tls.Config, handler http.Handler) error {
|
|
|
|
server, lHandler := newHTTPServer(network, address, name, handler)
|
2019-10-15 22:39:51 +09:00
|
|
|
return server.ListenAndServeTLSConfig(tlsConfig, lHandler)
|
|
|
|
}
|