@ -66,6 +66,7 @@ var (
"required_with" : requiredWith ,
"required_with_all" : requiredWithAll ,
"required_without" : requiredWithout ,
"required_without_all" : requiredWithoutAll ,
"isdefault" : isDefault ,
"len" : hasLengthOf ,
"min" : hasMinOf ,
@ -1435,6 +1436,47 @@ func requiredWithout(fl FieldLevel) bool {
return true
}
// RequiredWithoutAll is the validation function
// The field under validation must be present and not empty only when all of the other specified fields are not present.
func requiredWithoutAll ( fl FieldLevel ) bool {
field := fl . Field ( )
isValidateCurrentField := true
params := parseOneOfParam2 ( fl . Param ( ) )
for _ , param := range params {
isParamFieldPresent := false
paramField := fl . Parent ( ) . FieldByName ( param )
switch paramField . Kind ( ) {
case reflect . Slice , reflect . Map , reflect . Ptr , reflect . Interface , reflect . Chan , reflect . Func :
isParamFieldPresent = ! paramField . IsNil ( )
default :
if fl . ( * validate ) . fldIsPointer && paramField . Interface ( ) != nil {
isParamFieldPresent = true
}
isParamFieldPresent = paramField . IsValid ( ) && paramField . Interface ( ) != reflect . Zero ( field . Type ( ) ) . Interface ( )
}
if isParamFieldPresent {
isValidateCurrentField = ! isParamFieldPresent
}
}
if isValidateCurrentField {
switch field . Kind ( ) {
case reflect . Slice , reflect . Map , reflect . Ptr , reflect . Interface , reflect . Chan , reflect . Func :
return ! field . IsNil ( )
default :
if fl . ( * validate ) . fldIsPointer && field . Interface ( ) != nil {
return true
}
return field . IsValid ( ) && field . Interface ( ) != reflect . Zero ( field . Type ( ) ) . Interface ( )
}
}
return true
}
// IsGteField is the validation function for validating if the current field's value is greater than or equal to the field specified by the param's value.
func isGteField ( fl FieldLevel ) bool {