gvalid

package
v0.0.0-...-4ecba65 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Apr 12, 2021 License: MIT Imports: 15 Imported by: 0

Documentation

Overview

Package gvalid implements powerful and useful data/form validation functionality.

Index

Examples

Constants

This section is empty.

Variables

This section is empty.

Functions

func DeleteRule

func DeleteRule(rule string)

DeleteRule deletes custom defined validation rule and its function from global package.

func RegisterRule

func RegisterRule(rule string, f RuleFunc) error

RegisterRule registers custom validation rule and function for package. It returns error if there's already the same rule registered previously.

Example
package main

import (
	"errors"
	"fmt"

	"github.com/dxasu/gf/frame/g"
	"github.com/dxasu/gf/util/gconv"
	"github.com/dxasu/gf/util/gvalid"
)

func main() {
	rule := "unique-name"
	gvalid.RegisterRule(rule, func(rule string, value interface{}, message string, params map[string]interface{}) error {
		var (
			id   = gconv.Int(params["Id"])
			name = gconv.String(value)
		)
		n, err := g.Table("user").Where("id != ? and name = ?", id, name).Count()
		if err != nil {
			return err
		}
		if n > 0 {
			return errors.New(message)
		}
		return nil
	})
	type User struct {
		Id   int
		Name string `v:"required|unique-name # 请输入用户名称|用户名称已被占用"`
		Pass string `v:"required|length:6,18"`
	}
	user := &User{
		Id:   1,
		Name: "john",
		Pass: "123456",
	}
	err := gvalid.CheckStruct(user, nil)
	fmt.Println(err.Error())
	// May Output:
	// 用户名称已被占用
}
Output:

Types

type CustomMsg

type CustomMsg = map[string]interface{}

CustomMsg is the custom error message type, like: map[field] => string|map[rule]string

type Error

type Error struct {
	// contains filtered or unexported fields
}

Error is the validation error for validation result.

func Check

func Check(value interface{}, rules string, messages interface{}, params ...interface{}) *Error

Check checks single value with specified rules. It returns nil if successful validation.

The parameter `value` can be any type of variable, which will be converted to string for validation. The parameter `rules` can be one or more rules, multiple rules joined using char '|'. The parameter `messages` specifies the custom error messages, which can be type of: string/map/struct/*struct. The optional parameter `params` specifies the extra validation parameters for some rules like: required-*、same、different, etc.

func CheckMap

func CheckMap(params interface{}, rules interface{}, messages ...CustomMsg) *Error

CheckMap validates map and returns the error result. It returns nil if with successful validation.

The parameter `rules` can be type of []string/map[string]string. It supports sequence in error result if `rules` is type of []string. The optional parameter `messages` specifies the custom error messages for specified keys and rules.

Example
package main

import (
	"fmt"

	"github.com/dxasu/gf/util/gvalid"
)

func main() {
	params := map[string]interface{}{
		"passport":  "",
		"password":  "123456",
		"password2": "1234567",
	}
	rules := []string{
		"passport@required|length:6,16#账号不能为空|账号长度应当在:min到:max之间",
		"password@required|length:6,16|same:password2#密码不能为空|密码长度应当在:min到:max之间|两次密码输入不相等",
		"password2@required|length:6,16#",
	}
	if e := gvalid.CheckMap(params, rules); e != nil {
		fmt.Println(e.Map())
		fmt.Println(e.FirstItem())
		fmt.Println(e.FirstString())
	}
	// May Output:
	// map[required:账号不能为空 length:账号长度应当在6到16之间]
	// passport map[required:账号不能为空 length:账号长度应当在6到16之间]
	// 账号不能为空
}
Output:

func CheckStruct

func CheckStruct(object interface{}, rules interface{}, messages ...CustomMsg) *Error

CheckStruct validates strcut and returns the error result.

The parameter `object` should be type of struct/*struct. The parameter `rules` can be type of []string/map[string]string. It supports sequence in error result if `rules` is type of []string. The optional parameter `messages` specifies the custom error messages for specified keys and rules.

Example

Empty string attribute.

package main

import (
	"fmt"

	"github.com/dxasu/gf/util/gvalid"
)

func main() {
	type Params struct {
		Page      int    `v:"required|min:1         # page is required"`
		Size      int    `v:"required|between:1,100 # size is required"`
		ProjectId string `v:"between:1,10000        # project id must between :min, :max"`
	}
	obj := &Params{
		Page: 1,
		Size: 10,
	}
	err := gvalid.CheckStruct(obj, nil)
	fmt.Println(err == nil)
}
Output:

true

func (*Error) Current

func (e *Error) Current() error

Current is alis of FirstString, which implements interface gerror.ApiCurrent.

func (*Error) Error

func (e *Error) Error() string

Error implements interface of error.Error.

func (*Error) FirstItem

func (e *Error) FirstItem() (key string, messages map[string]string)

FirstItem returns the field name and error messages for the first validation rule error.

func (*Error) FirstRule

func (e *Error) FirstRule() (rule string, err string)

FirstRule returns the first error rule and message string.

func (*Error) FirstString

func (e *Error) FirstString() (err string)

FirstString returns the first error message as string. Note that the returned message might be different if it has no sequence.

func (*Error) Map

func (e *Error) Map() map[string]string

Map returns the first error message as map.

func (*Error) Maps

func (e *Error) Maps() ErrorMap

Maps returns all error messages as map.

func (*Error) String

func (e *Error) String() string

String returns all error messages as string, multiple error messages joined using char ';'.

func (*Error) Strings

func (e *Error) Strings() (errs []string)

Strings returns all error messages as string array.

type ErrorMap

type ErrorMap map[string]map[string]string

ErrorMap is the validation error map: map[field]map[rule]message

type RuleFunc

type RuleFunc func(rule string, value interface{}, message string, params map[string]interface{}) error

RuleFunc is the custom function for data validation. The parameter `rule` specifies the validation rule string, like "required", "between:1,100", etc. The parameter `value` specifies the value for this rule to validate. The parameter `message` specifies the custom error message or configured i18n message for this rule. The parameter `params` specifies all the parameters that needs. You can ignore parameter `params` if you do not really need it in your custom validation rule.

type Validator

type Validator struct {
	// contains filtered or unexported fields
}

Validator is the validation manager.

func New

func New() *Validator

New creates and returns a new Validator.

func (*Validator) Check

func (v *Validator) Check(value interface{}, rules string, messages interface{}, params ...interface{}) *Error

Check checks single value with specified rules. It returns nil if successful validation.

The parameter `value` can be any type of variable, which will be converted to string for validation. The parameter `rules` can be one or more rules, multiple rules joined using char '|'. The parameter `messages` specifies the custom error messages, which can be type of: string/map/struct/*struct. The optional parameter `params` specifies the extra validation parameters for some rules like: required-*、same、different, etc.

func (*Validator) CheckMap

func (v *Validator) CheckMap(params interface{}, rules interface{}, messages ...CustomMsg) *Error

CheckMap validates map and returns the error result. It returns nil if with successful validation.

The parameter `rules` can be type of []string/map[string]string. It supports sequence in error result if `rules` is type of []string. The optional parameter `messages` specifies the custom error messages for specified keys and rules.

func (*Validator) CheckStruct

func (v *Validator) CheckStruct(object interface{}, rules interface{}, messages ...CustomMsg) *Error

CheckStruct validates struct and returns the error result.

The parameter `object` should be type of struct/*struct. The parameter `rules` can be type of []string/map[string]string. It supports sequence in error result if `rules` is type of []string. The optional parameter `messages` specifies the custom error messages for specified keys and rules.

func (*Validator) Clone

func (v *Validator) Clone() *Validator

Clone creates and returns a new Validator which is a shallow copy of current one.

func (*Validator) I18n

func (v *Validator) I18n(language string) *Validator

I18n is a chaining operation function which sets the I18n language for next validation.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL