gin/binding/default_validator.go

52 lines
1.3 KiB
Go
Raw Normal View History

2017-06-12 14:04:52 +08:00
// Copyright 2017 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.
2015-05-31 16:18:50 +02:00
package binding
import (
"reflect"
"sync"
2016-01-26 19:28:26 +01:00
"gopkg.in/go-playground/validator.v8"
2015-05-31 16:18:50 +02:00
)
type defaultValidator struct {
once sync.Once
validate *validator.Validate
}
var _ StructValidator = &defaultValidator{}
// ValidateStruct receives any kind of type, but only performed struct or pointer to struct type.
2015-05-31 16:18:50 +02:00
func (v *defaultValidator) ValidateStruct(obj interface{}) error {
value := reflect.ValueOf(obj)
valueType := value.Kind()
if valueType == reflect.Ptr {
valueType = value.Elem().Kind()
}
if valueType == reflect.Struct {
2015-05-31 16:18:50 +02:00
v.lazyinit()
2015-05-31 16:30:00 +02:00
if err := v.validate.Struct(obj); err != nil {
return err
2015-05-31 16:30:00 +02:00
}
2015-05-31 16:18:50 +02:00
}
return nil
}
// Engine returns the underlying validator engine which powers the default
// Validator instance. This is useful if you want to register custom validations
// or struct level validations. See validator GoDoc for more info -
// https://godoc.org/gopkg.in/go-playground/validator.v8
func (v *defaultValidator) Engine() interface{} {
v.lazyinit()
return v.validate
}
2015-05-31 16:18:50 +02:00
func (v *defaultValidator) lazyinit() {
v.once.Do(func() {
2016-01-26 19:28:26 +01:00
config := &validator.Config{TagName: "binding"}
v.validate = validator.New(config)
2015-05-31 16:18:50 +02:00
})
}