surrealpatch/web/web.go

114 lines
2.2 KiB
Go
Raw Normal View History

2016-04-03 21:48:57 +00:00
// Copyright © 2016 Abcum Ltd
//
// 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 web
import (
"github.com/abcum/fibre"
"github.com/abcum/fibre/mw"
2017-02-19 19:36:29 +00:00
2016-04-03 21:48:57 +00:00
"github.com/abcum/surreal/cnf"
2016-04-10 15:59:01 +00:00
"github.com/abcum/surreal/log"
2016-04-03 21:48:57 +00:00
)
// Setup sets up the server for remote connections
func Setup(opts *cnf.Options) (err error) {
2016-06-18 13:42:06 +00:00
log.WithPrefix("web").Infof("Starting web server on %s", opts.Conn.Web)
2016-04-03 21:48:57 +00:00
s := fibre.Server()
2016-04-03 21:48:57 +00:00
routes(s)
2016-07-06 18:12:14 +00:00
s.SetWait("15s")
2016-06-18 13:42:06 +00:00
s.SetName("web")
2017-02-23 21:47:39 +00:00
s.SetIdleTimeout("60s")
2016-04-03 21:48:57 +00:00
s.SetHTTPErrorHandler(errors)
2016-04-10 15:59:01 +00:00
s.Logger().SetLogger(log.Instance())
2016-04-03 21:48:57 +00:00
// Setup middleware
2017-02-19 19:36:29 +00:00
s.Use(mw.Uniq()) // Add uniq id
2016-04-03 21:48:57 +00:00
s.Use(mw.Fail()) // Catch panics
2017-02-19 19:36:29 +00:00
s.Use(mw.Logs()) // Log requests
2017-11-16 20:50:57 +00:00
s.Use(mw.Sock()) // Setup sockets
2016-04-03 21:48:57 +00:00
// Add trace information
s.Use(tracer())
2017-11-16 20:46:54 +00:00
// Add cors headers
s.Use(mw.Cors(&mw.CorsOpts{
AllowedOrigin: "*",
AllowedMethods: []string{
"GET",
"PUT",
"POST",
"PATCH",
"DELETE",
"TRACE",
"OPTIONS",
},
AllowedHeaders: []string{
"Accept",
"Authorization",
"Content-Type",
"Origin",
"NS",
"DB",
},
AccessControlMaxAge: 600,
}))
2016-04-03 21:48:57 +00:00
// Check body size
s.Use(mw.Size(&mw.SizeOpts{
AllowedLength: 1 << 20, // 1mb
2016-04-03 21:48:57 +00:00
}))
// Setup authentication
s.Use(auth())
// Compress responses
s.Use(mw.Gzip())
// Log successful start
log.WithPrefix("web").Infof("Started web server on %s", opts.Conn.Web)
2016-04-03 21:48:57 +00:00
// Run the server
2016-06-18 13:42:06 +00:00
if len(opts.Cert.Crt) == 0 || len(opts.Cert.Key) == 0 {
s.Run(opts.Conn.Web)
2016-04-13 14:40:19 +00:00
}
2016-06-18 13:42:06 +00:00
if len(opts.Cert.Crt) != 0 && len(opts.Cert.Key) != 0 {
s.Run(opts.Conn.Web, opts.Cert.Crt, opts.Cert.Key)
2016-04-13 14:40:19 +00:00
}
2016-04-03 21:48:57 +00:00
return nil
}
// Exit tears down the server gracefully
func Exit() (err error) {
2016-06-18 13:42:06 +00:00
log.WithPrefix("web").Infof("Gracefully shutting down %s protocol", "web")
return
2016-04-03 21:48:57 +00:00
}