gin/mode.go

84 lines
1.9 KiB
Go
Raw Normal View History

2014-08-29 17:49:50 +00:00
// Copyright 2014 Manu Martinez-Almeida. All rights reserved.
// Use of this source code is governed by a MIT style
// license that can be found in the LICENSE file.
package gin
import (
2016-04-15 08:12:07 +00:00
"io"
"os"
2015-04-07 16:37:17 +00:00
"github.com/gin-gonic/gin/binding"
)
// ENV_GIN_MODE indicates environment name for gin mode.
2015-05-22 14:55:16 +00:00
const ENV_GIN_MODE = "GIN_MODE"
const (
// DebugMode indicates gin mode is debug.
DebugMode = "debug"
// ReleaseMode indicates gin mode is relase.
ReleaseMode = "release"
// TestMode indicates gin mode is test.
TestMode = "test"
)
const (
2017-03-11 13:35:29 +00:00
debugCode = iota
releaseCode
testCode
)
// DefaultWriter is the default io.Writer used by Gin for debug output and
// middleware output like Logger() or Recovery().
// Note that both Logger and Recovery provides custom ways to configure their
// output io.Writer.
// To support coloring in Windows use:
2016-01-26 21:40:29 +00:00
// import "github.com/mattn/go-colorable"
// gin.DefaultWriter = colorable.NewColorableStdout()
2016-04-15 08:12:07 +00:00
var DefaultWriter io.Writer = os.Stdout
// DefaultErrorWriter is the default io.Writer used by Gin to debug errors
2016-04-15 08:12:07 +00:00
var DefaultErrorWriter io.Writer = os.Stderr
2016-04-14 23:16:46 +00:00
var ginMode = debugCode
var modeName = DebugMode
2014-10-08 23:40:42 +00:00
func init() {
2015-05-22 14:55:16 +00:00
mode := os.Getenv(ENV_GIN_MODE)
SetMode(mode)
2014-10-08 23:40:42 +00:00
}
// SetMode sets gin mode according to input string.
func SetMode(value string) {
switch value {
case DebugMode, "":
2015-04-07 10:27:23 +00:00
ginMode = debugCode
case ReleaseMode:
2015-04-07 10:27:23 +00:00
ginMode = releaseCode
2014-08-20 23:01:05 +00:00
case TestMode:
2015-04-07 10:27:23 +00:00
ginMode = testCode
default:
2015-04-08 00:58:35 +00:00
panic("gin mode unknown: " + value)
}
if value == "" {
value = DebugMode
}
2015-04-07 10:27:23 +00:00
modeName = value
}
// DisableBindValidation closes the default validator.
func DisableBindValidation() {
binding.Validator = nil
}
// EnableJsonDecoderUseNumber sets true for binding.EnableDecoderUseNumberto to
// call the UseNumber method on the JSON Decoder instance.
func EnableJsonDecoderUseNumber() {
binding.EnableDecoderUseNumber = true
}
// Mode returns currently gin mode.
func Mode() string {
2015-04-07 10:27:23 +00:00
return modeName
}