Orwell is a validator package for the Go programming language.
- Quick and simple to use
- Easy to extend with custom validation rules
- Some of the most common validation rules baked in
- Cross-field validation rules (e.g. dependant struct fields)
- Pure Go, no tags
- No third party dependencies
- Avoids complex regexes and reflection whenever possible
Get a new validator instance:
import (
"github.com/Antipitch/orwell"
)
v := orwell.NewValidator()
Validate something:
i := 42
err := v.Validate(i, v.Required())
if err != nil {
log.Print(err.Error())
}
Add more Rules:
err := v.Validate(i, v.Required(), v.Max(42), v.DivBy(21))
Rules after failing rules wil not be applied:
// v.DivBy() will not be called
err := v.Validate(i, v.Required(), v.Max(41), v.DivBy(20))
Nil or empty values are always valid except for the Required(), NotNil(), NotEmpty() and X-Rules:
var (
i int
err error
)
// valid
err = v.Validate(i, v.Min(42))
// not valid
err = v.Validate(i, v.NotEmpty(), v.Min(42))
i = 41
// not valid
err = v.Validate(i, v.NotEmpty(), v.Min(42))
Use pointers both to the struct itself and to the fields to validate (fields passed as arguments to X-rules don't have to be pointers).
s := {
StringField: "somestring",
IntField: 1000,
StructField: {
ChildStringFiled: "",
ChildIntField: 0
}
}
// will return orwell.IterableError interface (s.Intfield is not valid)
err := v.ValidateStruct(&s,
v.FieldRules(&s.StringField, v.Required()),
v.FieldRules(&s.StructField.ChildIntField, v.XLt(s.IntField, 1000))
)
Orwell exports three error interfaces: InternalError, IterableError and FieldableError (all of them implement Go's error interface).
Orwell's Validate method will -for now- return a standard Go error, nothing special here. The ValidateStruct method will either return an InternalError or an IterableError. Proceed according to your needs with type assertion:
err := v.ValidateStruct(
// validate some struct
)
if err != nil {
// don't react specifically, maybe log
log.Print(err.Error())
// internal error
internalError, ok := err.(orwell.InternalError)
if ok {
// do something with internal error
}
// iterable error
iterableError, ok := err.(orwell.IterableError)
if ok {
l := iterableError.Len()
for i := 0; i < l; i++ {
if fe, ok := iterableError.ValueAt(i).(orwell.FieldableError); ok {
f := fe.FieldName
j := fe.JSONName
e := fe.Error()
}
}
}
}
DivBy(arg int)
Must be dividable by argIn(args ...interface{})
Must be equal to one of argsEmail(arg bool)
Must be RFC 5322 compliant address (uses net/mail.ParseAddress and optionally net.LookupMX)Max(arg int)
Must not be greater than argMin(arg int)
Must not be lower than argMatch(arg string)
Must match regular expression described by argNotNil()
Must not be nilRequired()
Must neither be nil nor empty
XAnd(arg interface{})
Required when arg is neither nil nor emptyXAndOr(arg interface{}, args ...interface{})
Required when arg is neither nil nor empty and all args are nil or emptyXGt(arg1 interface{}, arg2 int)
Required when arg1 is greater than arg2XGtOr(arg1 interface{}, arg2 int, args ...interface{})
Required when arg1 is greater than arg2 and all args are nil or emptyXLt(arg1 interface{}, arg2 int)
Required when arg1 is lower than arg2XLtOr(arg1 interface{}, arg2 int, args ...interface{})
Required when arg1 is lower than arg2 and all args are nil or emptyXNor(args ...interface{})
Must be nil or empty when all args are nil or emptyXNot(arg interface{})
Must be nil or empty when arg is neither nil nor emptyXOr(args ...interface{})
Required when all args are nil or empty
Orwell is a new project and not stable, yet. Don't use it in production! Thankful respects to asaskevich/govalidator and go-ozzo/ozzo-validation for inspiration. Feel free to contribute.