mirror of
https://github.com/kataras/iris.git
synced 2025-01-24 19:21:03 +01:00
6f83c48a10
## 4.0.0-alpha.4 -> 4.0.0-alpha.5 - **NEW FEATURE**: Letsencrypt.org integration[*](https://github.com/kataras/iris/issues/220) - example [here](https://github.com/iris-contrib/examples/blob/master/letsencrypt/main.go) - **FIX**: (ListenUNIX adds :80 to filename)[https://github.com/kataras/iris/issues/321] - **FIX**: (Go-Bindata + ctx.Render)[https://github.com/kataras/iris/issues/315] - **FIX** (auto-gzip doesn't really compress data in latest code)[https://github.com/kataras/iris/issues/312]
172 lines
5.4 KiB
Go
172 lines
5.4 KiB
Go
package config
|
|
|
|
import (
|
|
"os"
|
|
"strconv"
|
|
"strings"
|
|
|
|
"github.com/imdario/mergo"
|
|
"github.com/valyala/fasthttp"
|
|
)
|
|
|
|
// Default values for base Server conf
|
|
const (
|
|
// DefaultServerHostname returns the default hostname which is 0.0.0.0
|
|
DefaultServerHostname = "0.0.0.0"
|
|
// DefaultServerPort returns the default port which is 8080
|
|
DefaultServerPort = 8080
|
|
// DefaultMaxRequestBodySize is 8MB
|
|
DefaultMaxRequestBodySize = 2 * fasthttp.DefaultMaxRequestBodySize
|
|
|
|
// Per-connection buffer size for requests' reading.
|
|
// This also limits the maximum header size.
|
|
//
|
|
// Increase this buffer if your clients send multi-KB RequestURIs
|
|
// and/or multi-KB headers (for example, BIG cookies).
|
|
//
|
|
// Default buffer size is 8MB
|
|
DefaultReadBufferSize = 8096
|
|
|
|
// Per-connection buffer size for responses' writing.
|
|
//
|
|
// Default buffer size is 8MB
|
|
DefaultWriteBufferSize = 8096
|
|
|
|
// DefaultServerName the response header of the 'Server' value when writes to the client
|
|
DefaultServerName = "iris"
|
|
)
|
|
|
|
var (
|
|
// DefaultServerAddr the default server addr which is: 0.0.0.0:8080
|
|
DefaultServerAddr = DefaultServerHostname + ":" + strconv.Itoa(DefaultServerPort)
|
|
)
|
|
|
|
// Server used inside server for listening
|
|
type Server struct {
|
|
// ListenningAddr the addr that server listens to
|
|
ListeningAddr string
|
|
CertFile string
|
|
KeyFile string
|
|
// AutoTLS enable to get certifications from the Letsencrypt
|
|
// when this configuration field is true, the CertFile & KeyFile are empty, no need to provide a key.
|
|
//
|
|
// example: https://github.com/iris-contrib/examples/blob/master/letsencyrpt/main.go
|
|
AutoTLS bool
|
|
// Mode this is for unix only
|
|
Mode os.FileMode
|
|
// MaxRequestBodySize Maximum request body size.
|
|
//
|
|
// The server rejects requests with bodies exceeding this limit.
|
|
//
|
|
// By default request body size is 8MB.
|
|
MaxRequestBodySize int
|
|
|
|
// Per-connection buffer size for requests' reading.
|
|
// This also limits the maximum header size.
|
|
//
|
|
// Increase this buffer if your clients send multi-KB RequestURIs
|
|
// and/or multi-KB headers (for example, BIG cookies).
|
|
//
|
|
// Default buffer size is used if not set.
|
|
ReadBufferSize int
|
|
|
|
// Per-connection buffer size for responses' writing.
|
|
//
|
|
// Default buffer size is used if not set.
|
|
WriteBufferSize int
|
|
|
|
// RedirectTo, defaults to empty, set it in order to override the station's handler and redirect all requests to this address which is of form(HOST:PORT or :PORT)
|
|
//
|
|
// NOTE: the http status is 'StatusMovedPermanently', means one-time-redirect(the browser remembers the new addr and goes to the new address without need to request something from this server
|
|
// which means that if you want to change this address you have to clear your browser's cache in order this to be able to change to the new addr.
|
|
//
|
|
// example: https://github.com/iris-contrib/examples/tree/master/multiserver_listening2
|
|
RedirectTo string
|
|
// Virtual If this server is not really listens to a real host, it mostly used in order to achieve testing without system modifications
|
|
Virtual bool
|
|
// VListeningAddr, can be used for both virtual = true or false,
|
|
// if it's setted to not empty, then the server's Host() will return this addr instead of the ListeningAddr.
|
|
// server's Host() is used inside global template helper funcs
|
|
// set it when you are sure you know what it does.
|
|
//
|
|
// Default is empty ""
|
|
VListeningAddr string
|
|
// VScheme if setted to not empty value then all template's helper funcs prepends that as the url scheme instead of the real scheme
|
|
// server's .Scheme returns VScheme if not empty && differs from real scheme
|
|
//
|
|
// Default is empty ""
|
|
VScheme string
|
|
// Name the server's name, defaults to "iris".
|
|
// You're free to change it, but I will trust you to don't, this is the only setting whose somebody, like me, can see if iris web framework is used
|
|
Name string
|
|
}
|
|
|
|
// ServerParseAddr parses the listening addr and returns this
|
|
func ServerParseAddr(listeningAddr string) string {
|
|
// check if addr has :port, if not do it +:80 ,we need the hostname for many cases
|
|
a := listeningAddr
|
|
if a == "" {
|
|
// check for os environments
|
|
if oshost := os.Getenv("HOST"); oshost != "" {
|
|
a = oshost
|
|
} else if oshost := os.Getenv("ADDR"); oshost != "" {
|
|
a = oshost
|
|
} else if osport := os.Getenv("PORT"); osport != "" {
|
|
a = ":" + osport
|
|
}
|
|
|
|
if a == "" {
|
|
a = DefaultServerAddr
|
|
}
|
|
|
|
}
|
|
if portIdx := strings.IndexByte(a, ':'); portIdx == 0 {
|
|
// if contains only :port ,then the : is the first letter, so we dont have setted a hostname, lets set it
|
|
a = DefaultServerHostname + a
|
|
}
|
|
if portIdx := strings.IndexByte(a, ':'); portIdx < 0 {
|
|
// missing port part, add it
|
|
a = a + ":80"
|
|
}
|
|
|
|
return a
|
|
}
|
|
|
|
// DefaultServer returns the default configs for the server
|
|
func DefaultServer() Server {
|
|
return Server{
|
|
ListeningAddr: DefaultServerAddr,
|
|
Name: DefaultServerName,
|
|
MaxRequestBodySize: DefaultMaxRequestBodySize,
|
|
ReadBufferSize: DefaultReadBufferSize,
|
|
WriteBufferSize: DefaultWriteBufferSize,
|
|
RedirectTo: "",
|
|
Virtual: false,
|
|
VListeningAddr: "",
|
|
VScheme: "",
|
|
}
|
|
}
|
|
|
|
// Merge merges the default with the given config and returns the result
|
|
func (c Server) Merge(cfg []Server) (config Server) {
|
|
|
|
if len(cfg) > 0 {
|
|
config = cfg[0]
|
|
mergo.Merge(&config, c)
|
|
} else {
|
|
_default := c
|
|
config = _default
|
|
}
|
|
|
|
return
|
|
}
|
|
|
|
// MergeSingle merges the default with the given config and returns the result
|
|
func (c Server) MergeSingle(cfg Server) (config Server) {
|
|
|
|
config = cfg
|
|
mergo.Merge(&config, c)
|
|
|
|
return
|
|
}
|