mirror of
https://github.com/gogf/gf.git
synced 2025-04-05 11:18:50 +08:00
parent
14568562e3
commit
7415ec32c8
@ -239,6 +239,7 @@ func (v *Validator) doCheckStruct(ctx context.Context, object interface{}) Error
|
||||
continue
|
||||
}
|
||||
if field.IsEmbedded() {
|
||||
// The attributes of embedded struct are considered as direct attributes of its parent struct.
|
||||
if err = v.doCheckStruct(ctx, field.Value); err != nil {
|
||||
// It merges the errors into single error map.
|
||||
for k, m := range err.(*validationError).errors {
|
||||
@ -257,7 +258,7 @@ func (v *Validator) doCheckStruct(ctx context.Context, object interface{}) Error
|
||||
value = getPossibleValueFromMap(
|
||||
inputParamMap, field.Name(), fieldToAliasNameMap[field.Name()],
|
||||
)
|
||||
if value == nil {
|
||||
if empty.IsNil(value) {
|
||||
switch field.Kind() {
|
||||
case reflect.Map, reflect.Ptr, reflect.Slice, reflect.Array:
|
||||
// Nothing to do.
|
||||
|
@ -23,7 +23,7 @@ import (
|
||||
)
|
||||
|
||||
type doCheckValueInput struct {
|
||||
Name string // Name specifies the name of parameter `value`.
|
||||
Name string // Name specifies the name of parameter `value`, which might be the custom tag name of the parameter.
|
||||
Value interface{} // Value specifies the value for the rules to be validated.
|
||||
ValueType reflect.Type // ValueType specifies the type of the value, mainly used for value type id retrieving.
|
||||
Rule string // Rule specifies the validation rules string, like "required", "required|between:1,100", etc.
|
||||
|
36
util/gvalid/gvalid_z_unit_issue_test.go
Normal file
36
util/gvalid/gvalid_z_unit_issue_test.go
Normal file
@ -0,0 +1,36 @@
|
||||
// Copyright GoFrame Author(https://goframe.org). All Rights Reserved.
|
||||
//
|
||||
// This Source Code Form is subject to the terms of the MIT License.
|
||||
// If a copy of the MIT was not distributed with this file,
|
||||
// You can obtain one at https://github.com/gogf/gf.
|
||||
|
||||
package gvalid_test
|
||||
|
||||
import (
|
||||
"context"
|
||||
"testing"
|
||||
|
||||
"github.com/gogf/gf/v2/util/gvalid"
|
||||
)
|
||||
|
||||
type Foo struct {
|
||||
Bar *Bar `p:"bar" v:"required-without:Baz"`
|
||||
Baz *Baz `p:"baz" v:"required-without:Bar"`
|
||||
}
|
||||
type Bar struct {
|
||||
BarKey string `p:"bar_key" v:"required"`
|
||||
}
|
||||
type Baz struct {
|
||||
BazKey string `p:"baz_key" v:"required"`
|
||||
}
|
||||
|
||||
// https://github.com/gogf/gf/issues/2503
|
||||
func Test_Issue2503(t *testing.T) {
|
||||
foo := &Foo{
|
||||
Bar: &Bar{BarKey: "value"},
|
||||
}
|
||||
err := gvalid.New().Data(foo).Run(context.Background())
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
}
|
@ -36,6 +36,8 @@ func (r RuleRequired) Run(in RunInput) error {
|
||||
return nil
|
||||
}
|
||||
|
||||
// isRequiredEmpty checks and returns whether given value is empty string.
|
||||
// Note that if given value is a zero integer, it will be considered as not empty.
|
||||
func isRequiredEmpty(value interface{}) bool {
|
||||
reflectValue := reflect.ValueOf(value)
|
||||
for reflectValue.Kind() == reflect.Ptr {
|
||||
|
Loading…
x
Reference in New Issue
Block a user