mirror of
https://github.com/astaxie/beego.git
synced 2024-11-15 09:50:54 +00:00
513 lines
14 KiB
Go
513 lines
14 KiB
Go
|
// Copyright 2014 beego Author. All Rights Reserved.
|
||
|
//
|
||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||
|
// you may not use this file except in compliance with the License.
|
||
|
// You may obtain a copy of the License at
|
||
|
//
|
||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||
|
//
|
||
|
// Unless required by applicable law or agreed to in writing, software
|
||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||
|
// See the License for the specific language governing permissions and
|
||
|
// limitations under the License.
|
||
|
|
||
|
package validation
|
||
|
|
||
|
import (
|
||
|
"sync"
|
||
|
|
||
|
"github.com/astaxie/beego/pkg/infrastructure/validation"
|
||
|
)
|
||
|
|
||
|
// CanSkipFuncs will skip valid if RequiredFirst is true and the struct field's value is empty
|
||
|
var CanSkipFuncs = validation.CanSkipFuncs
|
||
|
|
||
|
// MessageTmpls store commond validate template
|
||
|
var MessageTmpls = map[string]string{
|
||
|
"Required": "Can not be empty",
|
||
|
"Min": "Minimum is %d",
|
||
|
"Max": "Maximum is %d",
|
||
|
"Range": "Range is %d to %d",
|
||
|
"MinSize": "Minimum size is %d",
|
||
|
"MaxSize": "Maximum size is %d",
|
||
|
"Length": "Required length is %d",
|
||
|
"Alpha": "Must be valid alpha characters",
|
||
|
"Numeric": "Must be valid numeric characters",
|
||
|
"AlphaNumeric": "Must be valid alpha or numeric characters",
|
||
|
"Match": "Must match %s",
|
||
|
"NoMatch": "Must not match %s",
|
||
|
"AlphaDash": "Must be valid alpha or numeric or dash(-_) characters",
|
||
|
"Email": "Must be a valid email address",
|
||
|
"IP": "Must be a valid ip address",
|
||
|
"Base64": "Must be valid base64 characters",
|
||
|
"Mobile": "Must be valid mobile number",
|
||
|
"Tel": "Must be valid telephone number",
|
||
|
"Phone": "Must be valid telephone or mobile phone number",
|
||
|
"ZipCode": "Must be valid zipcode",
|
||
|
}
|
||
|
|
||
|
var once sync.Once
|
||
|
|
||
|
// SetDefaultMessage set default messages
|
||
|
// if not set, the default messages are
|
||
|
// "Required": "Can not be empty",
|
||
|
// "Min": "Minimum is %d",
|
||
|
// "Max": "Maximum is %d",
|
||
|
// "Range": "Range is %d to %d",
|
||
|
// "MinSize": "Minimum size is %d",
|
||
|
// "MaxSize": "Maximum size is %d",
|
||
|
// "Length": "Required length is %d",
|
||
|
// "Alpha": "Must be valid alpha characters",
|
||
|
// "Numeric": "Must be valid numeric characters",
|
||
|
// "AlphaNumeric": "Must be valid alpha or numeric characters",
|
||
|
// "Match": "Must match %s",
|
||
|
// "NoMatch": "Must not match %s",
|
||
|
// "AlphaDash": "Must be valid alpha or numeric or dash(-_) characters",
|
||
|
// "Email": "Must be a valid email address",
|
||
|
// "IP": "Must be a valid ip address",
|
||
|
// "Base64": "Must be valid base64 characters",
|
||
|
// "Mobile": "Must be valid mobile number",
|
||
|
// "Tel": "Must be valid telephone number",
|
||
|
// "Phone": "Must be valid telephone or mobile phone number",
|
||
|
// "ZipCode": "Must be valid zipcode",
|
||
|
func SetDefaultMessage(msg map[string]string) {
|
||
|
validation.SetDefaultMessage(msg)
|
||
|
}
|
||
|
|
||
|
// Validator interface
|
||
|
type Validator interface {
|
||
|
IsSatisfied(interface{}) bool
|
||
|
DefaultMessage() string
|
||
|
GetKey() string
|
||
|
GetLimitValue() interface{}
|
||
|
}
|
||
|
|
||
|
// Required struct
|
||
|
type Required validation.Required
|
||
|
|
||
|
// IsSatisfied judge whether obj has value
|
||
|
func (r Required) IsSatisfied(obj interface{}) bool {
|
||
|
return validation.Required(r).IsSatisfied(obj)
|
||
|
}
|
||
|
|
||
|
// DefaultMessage return the default error message
|
||
|
func (r Required) DefaultMessage() string {
|
||
|
return validation.Required(r).DefaultMessage()
|
||
|
}
|
||
|
|
||
|
// GetKey return the r.Key
|
||
|
func (r Required) GetKey() string {
|
||
|
return validation.Required(r).GetKey()
|
||
|
}
|
||
|
|
||
|
// GetLimitValue return nil now
|
||
|
func (r Required) GetLimitValue() interface{} {
|
||
|
return validation.Required(r).GetLimitValue()
|
||
|
}
|
||
|
|
||
|
// Min check struct
|
||
|
type Min validation.Min
|
||
|
|
||
|
// IsSatisfied judge whether obj is valid
|
||
|
// not support int64 on 32-bit platform
|
||
|
func (m Min) IsSatisfied(obj interface{}) bool {
|
||
|
return validation.Min(m).IsSatisfied(obj)
|
||
|
}
|
||
|
|
||
|
// DefaultMessage return the default min error message
|
||
|
func (m Min) DefaultMessage() string {
|
||
|
return validation.Min(m).DefaultMessage()
|
||
|
}
|
||
|
|
||
|
// GetKey return the m.Key
|
||
|
func (m Min) GetKey() string {
|
||
|
return validation.Min(m).GetKey()
|
||
|
}
|
||
|
|
||
|
// GetLimitValue return the limit value, Min
|
||
|
func (m Min) GetLimitValue() interface{} {
|
||
|
return validation.Min(m).GetLimitValue()
|
||
|
}
|
||
|
|
||
|
// Max validate struct
|
||
|
type Max validation.Max
|
||
|
|
||
|
// IsSatisfied judge whether obj is valid
|
||
|
// not support int64 on 32-bit platform
|
||
|
func (m Max) IsSatisfied(obj interface{}) bool {
|
||
|
return validation.Max(m).IsSatisfied(obj)
|
||
|
}
|
||
|
|
||
|
// DefaultMessage return the default max error message
|
||
|
func (m Max) DefaultMessage() string {
|
||
|
return validation.Max(m).DefaultMessage()
|
||
|
}
|
||
|
|
||
|
// GetKey return the m.Key
|
||
|
func (m Max) GetKey() string {
|
||
|
return validation.Max(m).GetKey()
|
||
|
}
|
||
|
|
||
|
// GetLimitValue return the limit value, Max
|
||
|
func (m Max) GetLimitValue() interface{} {
|
||
|
return validation.Max(m).GetLimitValue()
|
||
|
}
|
||
|
|
||
|
// Range Requires an integer to be within Min, Max inclusive.
|
||
|
type Range validation.Range
|
||
|
|
||
|
// IsSatisfied judge whether obj is valid
|
||
|
// not support int64 on 32-bit platform
|
||
|
func (r Range) IsSatisfied(obj interface{}) bool {
|
||
|
return validation.Range(r).IsSatisfied(obj)
|
||
|
}
|
||
|
|
||
|
// DefaultMessage return the default Range error message
|
||
|
func (r Range) DefaultMessage() string {
|
||
|
return validation.Range(r).DefaultMessage()
|
||
|
}
|
||
|
|
||
|
// GetKey return the m.Key
|
||
|
func (r Range) GetKey() string {
|
||
|
return validation.Range(r).GetKey()
|
||
|
}
|
||
|
|
||
|
// GetLimitValue return the limit value, Max
|
||
|
func (r Range) GetLimitValue() interface{} {
|
||
|
return validation.Range(r).GetLimitValue()
|
||
|
}
|
||
|
|
||
|
// MinSize Requires an array or string to be at least a given length.
|
||
|
type MinSize validation.MinSize
|
||
|
|
||
|
// IsSatisfied judge whether obj is valid
|
||
|
func (m MinSize) IsSatisfied(obj interface{}) bool {
|
||
|
return validation.MinSize(m).IsSatisfied(obj)
|
||
|
}
|
||
|
|
||
|
// DefaultMessage return the default MinSize error message
|
||
|
func (m MinSize) DefaultMessage() string {
|
||
|
return validation.MinSize(m).DefaultMessage()
|
||
|
}
|
||
|
|
||
|
// GetKey return the m.Key
|
||
|
func (m MinSize) GetKey() string {
|
||
|
return validation.MinSize(m).GetKey()
|
||
|
}
|
||
|
|
||
|
// GetLimitValue return the limit value
|
||
|
func (m MinSize) GetLimitValue() interface{} {
|
||
|
return validation.MinSize(m).GetLimitValue()
|
||
|
}
|
||
|
|
||
|
// MaxSize Requires an array or string to be at most a given length.
|
||
|
type MaxSize validation.MaxSize
|
||
|
|
||
|
// IsSatisfied judge whether obj is valid
|
||
|
func (m MaxSize) IsSatisfied(obj interface{}) bool {
|
||
|
return validation.MaxSize(m).IsSatisfied(obj)
|
||
|
}
|
||
|
|
||
|
// DefaultMessage return the default MaxSize error message
|
||
|
func (m MaxSize) DefaultMessage() string {
|
||
|
return validation.MaxSize(m).DefaultMessage()
|
||
|
}
|
||
|
|
||
|
// GetKey return the m.Key
|
||
|
func (m MaxSize) GetKey() string {
|
||
|
return validation.MaxSize(m).GetKey()
|
||
|
}
|
||
|
|
||
|
// GetLimitValue return the limit value
|
||
|
func (m MaxSize) GetLimitValue() interface{} {
|
||
|
return validation.MaxSize(m).GetLimitValue()
|
||
|
}
|
||
|
|
||
|
// Length Requires an array or string to be exactly a given length.
|
||
|
type Length validation.Length
|
||
|
|
||
|
// IsSatisfied judge whether obj is valid
|
||
|
func (l Length) IsSatisfied(obj interface{}) bool {
|
||
|
return validation.Length(l).IsSatisfied(obj)
|
||
|
}
|
||
|
|
||
|
// DefaultMessage return the default Length error message
|
||
|
func (l Length) DefaultMessage() string {
|
||
|
return validation.Length(l).DefaultMessage()
|
||
|
}
|
||
|
|
||
|
// GetKey return the m.Key
|
||
|
func (l Length) GetKey() string {
|
||
|
return validation.Length(l).GetKey()
|
||
|
}
|
||
|
|
||
|
// GetLimitValue return the limit value
|
||
|
func (l Length) GetLimitValue() interface{} {
|
||
|
return validation.Length(l).GetLimitValue()
|
||
|
}
|
||
|
|
||
|
// Alpha check the alpha
|
||
|
type Alpha validation.Alpha
|
||
|
|
||
|
// IsSatisfied judge whether obj is valid
|
||
|
func (a Alpha) IsSatisfied(obj interface{}) bool {
|
||
|
return validation.Alpha(a).IsSatisfied(obj)
|
||
|
}
|
||
|
|
||
|
// DefaultMessage return the default Length error message
|
||
|
func (a Alpha) DefaultMessage() string {
|
||
|
return validation.Alpha(a).DefaultMessage()
|
||
|
}
|
||
|
|
||
|
// GetKey return the m.Key
|
||
|
func (a Alpha) GetKey() string {
|
||
|
return validation.Alpha(a).GetKey()
|
||
|
}
|
||
|
|
||
|
// GetLimitValue return the limit value
|
||
|
func (a Alpha) GetLimitValue() interface{} {
|
||
|
return validation.Alpha(a).GetLimitValue()
|
||
|
}
|
||
|
|
||
|
// Numeric check number
|
||
|
type Numeric validation.Numeric
|
||
|
|
||
|
// IsSatisfied judge whether obj is valid
|
||
|
func (n Numeric) IsSatisfied(obj interface{}) bool {
|
||
|
return validation.Numeric(n).IsSatisfied(obj)
|
||
|
}
|
||
|
|
||
|
// DefaultMessage return the default Length error message
|
||
|
func (n Numeric) DefaultMessage() string {
|
||
|
return validation.Numeric(n).DefaultMessage()
|
||
|
}
|
||
|
|
||
|
// GetKey return the n.Key
|
||
|
func (n Numeric) GetKey() string {
|
||
|
return validation.Numeric(n).GetKey()
|
||
|
}
|
||
|
|
||
|
// GetLimitValue return the limit value
|
||
|
func (n Numeric) GetLimitValue() interface{} {
|
||
|
return validation.Numeric(n).GetLimitValue()
|
||
|
}
|
||
|
|
||
|
// AlphaNumeric check alpha and number
|
||
|
type AlphaNumeric validation.AlphaNumeric
|
||
|
|
||
|
// IsSatisfied judge whether obj is valid
|
||
|
func (a AlphaNumeric) IsSatisfied(obj interface{}) bool {
|
||
|
return validation.AlphaNumeric(a).IsSatisfied(obj)
|
||
|
}
|
||
|
|
||
|
// DefaultMessage return the default Length error message
|
||
|
func (a AlphaNumeric) DefaultMessage() string {
|
||
|
return validation.AlphaNumeric(a).DefaultMessage()
|
||
|
}
|
||
|
|
||
|
// GetKey return the a.Key
|
||
|
func (a AlphaNumeric) GetKey() string {
|
||
|
return validation.AlphaNumeric(a).GetKey()
|
||
|
}
|
||
|
|
||
|
// GetLimitValue return the limit value
|
||
|
func (a AlphaNumeric) GetLimitValue() interface{} {
|
||
|
return validation.AlphaNumeric(a).GetLimitValue()
|
||
|
}
|
||
|
|
||
|
// Match Requires a string to match a given regex.
|
||
|
type Match validation.Match
|
||
|
|
||
|
// IsSatisfied judge whether obj is valid
|
||
|
func (m Match) IsSatisfied(obj interface{}) bool {
|
||
|
return validation.Match(m).IsSatisfied(obj)
|
||
|
}
|
||
|
|
||
|
// DefaultMessage return the default Match error message
|
||
|
func (m Match) DefaultMessage() string {
|
||
|
return validation.Match(m).DefaultMessage()
|
||
|
}
|
||
|
|
||
|
// GetKey return the m.Key
|
||
|
func (m Match) GetKey() string {
|
||
|
return validation.Match(m).GetKey()
|
||
|
}
|
||
|
|
||
|
// GetLimitValue return the limit value
|
||
|
func (m Match) GetLimitValue() interface{} {
|
||
|
return validation.Match(m).GetLimitValue()
|
||
|
}
|
||
|
|
||
|
// NoMatch Requires a string to not match a given regex.
|
||
|
type NoMatch validation.NoMatch
|
||
|
|
||
|
// IsSatisfied judge whether obj is valid
|
||
|
func (n NoMatch) IsSatisfied(obj interface{}) bool {
|
||
|
return validation.NoMatch(n).IsSatisfied(obj)
|
||
|
}
|
||
|
|
||
|
// DefaultMessage return the default NoMatch error message
|
||
|
func (n NoMatch) DefaultMessage() string {
|
||
|
return validation.NoMatch(n).DefaultMessage()
|
||
|
}
|
||
|
|
||
|
// GetKey return the n.Key
|
||
|
func (n NoMatch) GetKey() string {
|
||
|
return validation.NoMatch(n).GetKey()
|
||
|
}
|
||
|
|
||
|
// GetLimitValue return the limit value
|
||
|
func (n NoMatch) GetLimitValue() interface{} {
|
||
|
return validation.NoMatch(n).GetLimitValue()
|
||
|
}
|
||
|
|
||
|
// AlphaDash check not Alpha
|
||
|
type AlphaDash validation.AlphaDash
|
||
|
|
||
|
// DefaultMessage return the default AlphaDash error message
|
||
|
func (a AlphaDash) DefaultMessage() string {
|
||
|
return validation.AlphaDash(a).DefaultMessage()
|
||
|
}
|
||
|
|
||
|
// GetKey return the n.Key
|
||
|
func (a AlphaDash) GetKey() string {
|
||
|
return validation.AlphaDash(a).GetKey()
|
||
|
}
|
||
|
|
||
|
// GetLimitValue return the limit value
|
||
|
func (a AlphaDash) GetLimitValue() interface{} {
|
||
|
return validation.AlphaDash(a).GetLimitValue()
|
||
|
}
|
||
|
|
||
|
// Email check struct
|
||
|
type Email validation.Email
|
||
|
|
||
|
// DefaultMessage return the default Email error message
|
||
|
func (e Email) DefaultMessage() string {
|
||
|
return validation.Email(e).DefaultMessage()
|
||
|
}
|
||
|
|
||
|
// GetKey return the n.Key
|
||
|
func (e Email) GetKey() string {
|
||
|
return validation.Email(e).GetKey()
|
||
|
}
|
||
|
|
||
|
// GetLimitValue return the limit value
|
||
|
func (e Email) GetLimitValue() interface{} {
|
||
|
return validation.Email(e).GetLimitValue()
|
||
|
}
|
||
|
|
||
|
// IP check struct
|
||
|
type IP validation.IP
|
||
|
|
||
|
// DefaultMessage return the default IP error message
|
||
|
func (i IP) DefaultMessage() string {
|
||
|
return validation.IP(i).DefaultMessage()
|
||
|
}
|
||
|
|
||
|
// GetKey return the i.Key
|
||
|
func (i IP) GetKey() string {
|
||
|
return validation.IP(i).GetKey()
|
||
|
}
|
||
|
|
||
|
// GetLimitValue return the limit value
|
||
|
func (i IP) GetLimitValue() interface{} {
|
||
|
return validation.IP(i).GetLimitValue()
|
||
|
}
|
||
|
|
||
|
// Base64 check struct
|
||
|
type Base64 validation.Base64
|
||
|
|
||
|
// DefaultMessage return the default Base64 error message
|
||
|
func (b Base64) DefaultMessage() string {
|
||
|
return validation.Base64(b).DefaultMessage()
|
||
|
}
|
||
|
|
||
|
// GetKey return the b.Key
|
||
|
func (b Base64) GetKey() string {
|
||
|
return validation.Base64(b).GetKey()
|
||
|
}
|
||
|
|
||
|
// GetLimitValue return the limit value
|
||
|
func (b Base64) GetLimitValue() interface{} {
|
||
|
return validation.Base64(b).GetLimitValue()
|
||
|
}
|
||
|
|
||
|
// Mobile check struct
|
||
|
type Mobile validation.Mobile
|
||
|
|
||
|
// DefaultMessage return the default Mobile error message
|
||
|
func (m Mobile) DefaultMessage() string {
|
||
|
return validation.Mobile(m).DefaultMessage()
|
||
|
}
|
||
|
|
||
|
// GetKey return the m.Key
|
||
|
func (m Mobile) GetKey() string {
|
||
|
return validation.Mobile(m).GetKey()
|
||
|
}
|
||
|
|
||
|
// GetLimitValue return the limit value
|
||
|
func (m Mobile) GetLimitValue() interface{} {
|
||
|
return validation.Mobile(m).GetLimitValue()
|
||
|
}
|
||
|
|
||
|
// Tel check telephone struct
|
||
|
type Tel validation.Tel
|
||
|
|
||
|
// DefaultMessage return the default Tel error message
|
||
|
func (t Tel) DefaultMessage() string {
|
||
|
return validation.Tel(t).DefaultMessage()
|
||
|
}
|
||
|
|
||
|
// GetKey return the t.Key
|
||
|
func (t Tel) GetKey() string {
|
||
|
return validation.Tel(t).GetKey()
|
||
|
}
|
||
|
|
||
|
// GetLimitValue return the limit value
|
||
|
func (t Tel) GetLimitValue() interface{} {
|
||
|
return validation.Tel(t).GetLimitValue()
|
||
|
}
|
||
|
|
||
|
// Phone just for chinese telephone or mobile phone number
|
||
|
type Phone validation.Phone
|
||
|
|
||
|
// IsSatisfied judge whether obj is valid
|
||
|
func (p Phone) IsSatisfied(obj interface{}) bool {
|
||
|
return validation.Phone(p).IsSatisfied(obj)
|
||
|
}
|
||
|
|
||
|
// DefaultMessage return the default Phone error message
|
||
|
func (p Phone) DefaultMessage() string {
|
||
|
return validation.Phone(p).DefaultMessage()
|
||
|
}
|
||
|
|
||
|
// GetKey return the p.Key
|
||
|
func (p Phone) GetKey() string {
|
||
|
return validation.Phone(p).GetKey()
|
||
|
}
|
||
|
|
||
|
// GetLimitValue return the limit value
|
||
|
func (p Phone) GetLimitValue() interface{} {
|
||
|
return validation.Phone(p).GetLimitValue()
|
||
|
}
|
||
|
|
||
|
// ZipCode check the zip struct
|
||
|
type ZipCode validation.ZipCode
|
||
|
|
||
|
// DefaultMessage return the default Zip error message
|
||
|
func (z ZipCode) DefaultMessage() string {
|
||
|
return validation.ZipCode(z).DefaultMessage()
|
||
|
}
|
||
|
|
||
|
// GetKey return the z.Key
|
||
|
func (z ZipCode) GetKey() string {
|
||
|
return validation.ZipCode(z).GetKey()
|
||
|
}
|
||
|
|
||
|
// GetLimitValue return the limit value
|
||
|
func (z ZipCode) GetLimitValue() interface{} {
|
||
|
return validation.ZipCode(z).GetLimitValue()
|
||
|
}
|