gin/mode.go

84 lines
1.9 KiB
Go
Raw Normal View History

2014-08-29 19:49:50 +02: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 14:12:07 +06:00
"io"
"os"
2015-04-07 18:37:17 +02:00
"github.com/gin-gonic/gin/binding"
)
// ENV_GIN_MODE indicates environment name for gin mode.
2015-05-22 16:55:16 +02: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 07:35:29 -06: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 22:40:29 +01:00
// import "github.com/mattn/go-colorable"
// gin.DefaultWriter = colorable.NewColorableStdout()
2016-04-15 14:12:07 +06:00
var DefaultWriter io.Writer = os.Stdout
// DefaultErrorWriter is the default io.Writer used by Gin to debug errors
2016-04-15 14:12:07 +06:00
var DefaultErrorWriter io.Writer = os.Stderr
2016-04-15 01:16:46 +02:00
var ginMode = debugCode
var modeName = DebugMode
2014-10-09 01:40:42 +02:00
func init() {
2015-05-22 16:55:16 +02:00
mode := os.Getenv(ENV_GIN_MODE)
SetMode(mode)
2014-10-09 01:40:42 +02:00
}
// SetMode sets gin mode according to input string.
func SetMode(value string) {
switch value {
case DebugMode, "":
2015-04-07 12:27:23 +02:00
ginMode = debugCode
case ReleaseMode:
2015-04-07 12:27:23 +02:00
ginMode = releaseCode
2014-08-21 01:01:05 +02:00
case TestMode:
2015-04-07 12:27:23 +02:00
ginMode = testCode
default:
2015-04-08 02:58:35 +02:00
panic("gin mode unknown: " + value)
}
if value == "" {
value = DebugMode
}
2015-04-07 12:27:23 +02: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 12:27:23 +02:00
return modeName
}