Merge pull request #362 from mrd0ll4r/default-timeout

http: add default ReadTimeout, WriteTimeout
This commit is contained in:
mrd0ll4r 2017-10-03 13:01:53 +02:00 committed by GitHub
commit b314b5003a

View file

@ -86,6 +86,40 @@ func (cfg Config) LogFields() log.Fields {
} }
} }
// Default config constants.
const (
defaultReadTimeout = 2 * time.Second
defaultWriteTimeout = 2 * time.Second
)
// Validate sanity checks values set in a config and returns a new config with
// default values replacing anything that is invalid.
//
// This function warns to the logger when a value is changed.
func (cfg Config) Validate() Config {
validcfg := cfg
if cfg.ReadTimeout <= 0 {
validcfg.ReadTimeout = defaultReadTimeout
log.Warn("falling back to default configuration", log.Fields{
"name": "http.ReadTimeout",
"provided": cfg.ReadTimeout,
"default": validcfg.ReadTimeout,
})
}
if cfg.WriteTimeout <= 0 {
validcfg.WriteTimeout = defaultWriteTimeout
log.Warn("falling back to default configuration", log.Fields{
"name": "http.WriteTimeout",
"provided": cfg.WriteTimeout,
"default": validcfg.WriteTimeout,
})
}
return validcfg
}
// Frontend represents the state of an HTTP BitTorrent Frontend. // Frontend represents the state of an HTTP BitTorrent Frontend.
type Frontend struct { type Frontend struct {
srv *http.Server srv *http.Server
@ -97,7 +131,9 @@ type Frontend struct {
// NewFrontend creates a new instance of an HTTP Frontend that asynchronously // NewFrontend creates a new instance of an HTTP Frontend that asynchronously
// serves requests. // serves requests.
func NewFrontend(logic frontend.TrackerLogic, cfg Config) (*Frontend, error) { func NewFrontend(logic frontend.TrackerLogic, provided Config) (*Frontend, error) {
cfg := provided.Validate()
f := &Frontend{ f := &Frontend{
logic: logic, logic: logic,
Config: cfg, Config: cfg,