minio/pkg/server/httpserver/httpserver.go

70 lines
1.9 KiB
Go
Raw Normal View History

2015-01-21 02:16:06 -05:00
/*
* Minimalist Object Storage, (C) 2014 Minio, Inc.
2015-01-21 02:16:06 -05:00
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package httpserver
import (
"net/http"
"github.com/minio-io/minio/pkg/utils/log"
)
2015-03-06 00:07:19 -05:00
// Config - http server config
type Config struct {
Address string
TLS bool
CertFile string
KeyFile string
2015-03-06 00:07:19 -05:00
Websocket bool // TODO
}
2015-03-06 00:07:19 -05:00
// Server - http server related
type Server struct{}
2015-03-03 05:36:12 -05:00
// Start http server
2015-03-06 00:09:16 -05:00
func Start(handler http.Handler, config Config) (chan<- string, <-chan error, *Server) {
ctrlChannel := make(chan string)
errorChannel := make(chan error)
2015-03-06 00:09:16 -05:00
server := Server{}
go start(ctrlChannel, errorChannel, handler, config, &server)
return ctrlChannel, errorChannel, &server
}
func start(ctrlChannel <-chan string, errorChannel chan<- error,
2015-03-06 00:07:19 -05:00
router http.Handler, config Config, server *Server) {
var err error
2015-01-21 03:50:23 -05:00
// Minio server config
httpServer := &http.Server{
Addr: config.Address,
Handler: router,
// TODO add this later with a proper timer thread
// ReadTimeout: 20 * time.Second,
// WriteTimeout: 20 * time.Second,
2015-01-21 03:50:23 -05:00
MaxHeaderBytes: 1 << 20,
}
log.Println("Starting HTTP Server on:", config.Address)
if config.TLS {
httpServer.TLSConfig = getDefaultTLSConfig()
err = httpServer.ListenAndServeTLS(config.CertFile, config.KeyFile)
} else {
err = httpServer.ListenAndServe()
}
errorChannel <- err
close(errorChannel)
}