处理AI胡乱生成的乱摊子
This commit is contained in:
		
							
								
								
									
										39
									
								
								vendor/github.com/go-playground/validator/v10/util.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										39
									
								
								vendor/github.com/go-playground/validator/v10/util.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,7 +1,9 @@ | ||||
| package validator | ||||
|  | ||||
| import ( | ||||
| 	"fmt" | ||||
| 	"reflect" | ||||
| 	"regexp" | ||||
| 	"strconv" | ||||
| 	"strings" | ||||
| 	"time" | ||||
| @@ -11,7 +13,6 @@ import ( | ||||
| // It will dive into pointers, customTypes and return you the | ||||
| // underlying value and it's kind. | ||||
| func (v *validate) extractTypeInternal(current reflect.Value, nullable bool) (reflect.Value, reflect.Kind, bool) { | ||||
|  | ||||
| BEGIN: | ||||
| 	switch current.Kind() { | ||||
| 	case reflect.Ptr: | ||||
| @@ -42,7 +43,6 @@ BEGIN: | ||||
| 	default: | ||||
|  | ||||
| 		if v.v.hasCustomFuncs { | ||||
|  | ||||
| 			if fn, ok := v.v.customFuncs[current.Type()]; ok { | ||||
| 				current = reflect.ValueOf(fn(current)) | ||||
| 				goto BEGIN | ||||
| @@ -59,7 +59,6 @@ BEGIN: | ||||
| // NOTE: when not successful ok will be false, this can happen when a nested struct is nil and so the field | ||||
| // could not be retrieved because it didn't exist. | ||||
| func (v *validate) getStructFieldOKInternal(val reflect.Value, namespace string) (current reflect.Value, kind reflect.Kind, nullable bool, found bool) { | ||||
|  | ||||
| BEGIN: | ||||
| 	current, kind, nullable = v.ExtractType(val) | ||||
| 	if kind == reflect.Invalid { | ||||
| @@ -72,7 +71,6 @@ BEGIN: | ||||
| 	} | ||||
|  | ||||
| 	switch kind { | ||||
|  | ||||
| 	case reflect.Ptr, reflect.Interface: | ||||
| 		return | ||||
|  | ||||
| @@ -83,7 +81,6 @@ BEGIN: | ||||
| 		var ns string | ||||
|  | ||||
| 		if !typ.ConvertibleTo(timeType) { | ||||
|  | ||||
| 			idx := strings.Index(namespace, namespaceSeparator) | ||||
|  | ||||
| 			if idx != -1 { | ||||
| @@ -220,7 +217,7 @@ BEGIN: | ||||
| 	panic("Invalid field namespace") | ||||
| } | ||||
|  | ||||
| // asInt returns the parameter as a int64 | ||||
| // asInt returns the parameter as an int64 | ||||
| // or panics if it can't convert | ||||
| func asInt(param string) int64 { | ||||
| 	i, err := strconv.ParseInt(param, 0, 64) | ||||
| @@ -254,27 +251,31 @@ func asIntFromType(t reflect.Type, param string) int64 { | ||||
| // asUint returns the parameter as a uint64 | ||||
| // or panics if it can't convert | ||||
| func asUint(param string) uint64 { | ||||
|  | ||||
| 	i, err := strconv.ParseUint(param, 0, 64) | ||||
| 	panicIf(err) | ||||
|  | ||||
| 	return i | ||||
| } | ||||
|  | ||||
| // asFloat returns the parameter as a float64 | ||||
| // asFloat64 returns the parameter as a float64 | ||||
| // or panics if it can't convert | ||||
| func asFloat(param string) float64 { | ||||
|  | ||||
| func asFloat64(param string) float64 { | ||||
| 	i, err := strconv.ParseFloat(param, 64) | ||||
| 	panicIf(err) | ||||
| 	return i | ||||
| } | ||||
|  | ||||
| // asFloat32 returns the parameter as a float32 | ||||
| // or panics if it can't convert | ||||
| func asFloat32(param string) float64 { | ||||
| 	i, err := strconv.ParseFloat(param, 32) | ||||
| 	panicIf(err) | ||||
| 	return i | ||||
| } | ||||
|  | ||||
| // asBool returns the parameter as a bool | ||||
| // or panics if it can't convert | ||||
| func asBool(param string) bool { | ||||
|  | ||||
| 	i, err := strconv.ParseBool(param) | ||||
| 	panicIf(err) | ||||
|  | ||||
| @@ -286,3 +287,19 @@ func panicIf(err error) { | ||||
| 		panic(err.Error()) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // Checks if field value matches regex. If fl.Field can be cast to Stringer, it uses the Stringer interfaces | ||||
| // String() return value. Otherwise, it uses fl.Field's String() value. | ||||
| func fieldMatchesRegexByStringerValOrString(regexFn func() *regexp.Regexp, fl FieldLevel) bool { | ||||
| 	regex := regexFn() | ||||
| 	switch fl.Field().Kind() { | ||||
| 	case reflect.String: | ||||
| 		return regex.MatchString(fl.Field().String()) | ||||
| 	default: | ||||
| 		if stringer, ok := getValue(fl.Field()).(fmt.Stringer); ok { | ||||
| 			return regex.MatchString(stringer.String()) | ||||
| 		} else { | ||||
| 			return regex.MatchString(fl.Field().String()) | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user