gin/mode.go

100 lines
2.3 KiB
Go
Raw Permalink Normal View History

// Copyright 2014 Manu Martinez-Almeida. All rights reserved.
2014-08-29 21:49:50 +04:00
// Use of this source code is governed by a MIT style
// license that can be found in the LICENSE file.
package gin
import (
"flag"
2016-04-15 11:12:07 +03:00
"io"
"os"
2015-04-07 19:37:17 +03:00
"github.com/gin-gonic/gin/binding"
)
// EnvGinMode indicates environment name for gin mode.
const EnvGinMode = "GIN_MODE"
const (
// DebugMode indicates gin mode is debug.
DebugMode = "debug"
2018-11-12 13:58:24 +03:00
// ReleaseMode indicates gin mode is release.
ReleaseMode = "release"
// TestMode indicates gin mode is test.
TestMode = "test"
)
const (
2017-03-11 16:35:29 +03: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-27 00:40:29 +03:00
// import "github.com/mattn/go-colorable"
// gin.DefaultWriter = colorable.NewColorableStdout()
2016-04-15 11:12:07 +03:00
var DefaultWriter io.Writer = os.Stdout
// DefaultErrorWriter is the default io.Writer used by Gin to debug errors
2016-04-15 11:12:07 +03:00
var DefaultErrorWriter io.Writer = os.Stderr
var (
ginMode = debugCode
modeName = DebugMode
)
2014-10-09 03:40:42 +04:00
func init() {
mode := os.Getenv(EnvGinMode)
SetMode(mode)
2014-10-09 03:40:42 +04:00
}
// SetMode sets gin mode according to input string.
func SetMode(value string) {
2020-04-16 17:31:58 +03:00
if value == "" {
if flag.Lookup("test.v") != nil {
value = TestMode
} else {
value = DebugMode
}
2020-04-16 17:31:58 +03:00
}
switch value {
2020-04-16 17:31:58 +03:00
case DebugMode:
2015-04-07 13:27:23 +03:00
ginMode = debugCode
case ReleaseMode:
2015-04-07 13:27:23 +03:00
ginMode = releaseCode
2014-08-21 03:01:05 +04:00
case TestMode:
2015-04-07 13:27:23 +03:00
ginMode = testCode
default:
panic("gin mode unknown: " + value + " (available mode: debug release test)")
}
2020-04-16 17:31:58 +03:00
2015-04-07 13:27:23 +03:00
modeName = value
}
// DisableBindValidation closes the default validator.
func DisableBindValidation() {
binding.Validator = nil
}
// EnableJsonDecoderUseNumber sets true for binding.EnableDecoderUseNumber to
// call the UseNumber method on the JSON Decoder instance.
func EnableJsonDecoderUseNumber() {
binding.EnableDecoderUseNumber = true
}
// EnableJsonDecoderDisallowUnknownFields sets true for binding.EnableDecoderDisallowUnknownFields to
// call the DisallowUnknownFields method on the JSON Decoder instance.
func EnableJsonDecoderDisallowUnknownFields() {
binding.EnableDecoderDisallowUnknownFields = true
}
2021-12-15 18:27:23 +03:00
// Mode returns current gin mode.
func Mode() string {
2015-04-07 13:27:23 +03:00
return modeName
}