2023-11-27 13:15:03 +00:00
|
|
|
package validator
|
|
|
|
|
|
|
|
// Option represents a configurations option to be applied to validator during initialization.
|
|
|
|
type Option func(*Validate)
|
|
|
|
|
|
|
|
// WithRequiredStructEnabled enables required tag on non-pointer structs to be applied instead of ignored.
|
|
|
|
//
|
|
|
|
// This was made opt-in behaviour in order to maintain backward compatibility with the behaviour previous
|
|
|
|
// to being able to apply struct level validations on struct fields directly.
|
|
|
|
//
|
|
|
|
// It is recommended you enabled this as it will be the default behaviour in v11+
|
|
|
|
func WithRequiredStructEnabled() Option {
|
|
|
|
return func(v *Validate) {
|
|
|
|
v.requiredStructEnabled = true
|
|
|
|
}
|
|
|
|
}
|
2024-03-11 10:12:06 +00:00
|
|
|
|
|
|
|
// WithPrivateFieldValidation activates validation for unexported fields via the use of the `unsafe` package.
|
|
|
|
//
|
|
|
|
// By opting into this feature you are acknowledging that you are aware of the risks and accept any current or future
|
|
|
|
// consequences of using this feature.
|
|
|
|
func WithPrivateFieldValidation() Option {
|
|
|
|
return func(v *Validate) {
|
|
|
|
v.privateFieldValidation = true
|
|
|
|
}
|
|
|
|
}
|