/pkg/api/envoy/config/core/v3/http_uri.pb.validate.go
https://github.com/datawire/ambassador · Go · 155 lines · 112 code · 29 blank · 14 comment · 15 complexity · d45878b2328c14a43d85a74d05488527 MD5 · raw file
- // Code generated by protoc-gen-validate. DO NOT EDIT.
- // source: envoy/config/core/v3/http_uri.proto
- package envoy_config_core_v3
- import (
- "bytes"
- "errors"
- "fmt"
- "net"
- "net/mail"
- "net/url"
- "regexp"
- "strings"
- "time"
- "unicode/utf8"
- "github.com/golang/protobuf/ptypes"
- )
- // ensure the imports are used
- var (
- _ = bytes.MinRead
- _ = errors.New("")
- _ = fmt.Print
- _ = utf8.UTFMax
- _ = (*regexp.Regexp)(nil)
- _ = (*strings.Reader)(nil)
- _ = net.IPv4len
- _ = time.Duration(0)
- _ = (*url.URL)(nil)
- _ = (*mail.Address)(nil)
- _ = ptypes.DynamicAny{}
- )
- // define the regex for a UUID once up-front
- var _http_uri_uuidPattern = regexp.MustCompile("^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$")
- // Validate checks the field values on HttpUri with the rules defined in the
- // proto definition for this message. If any rules are violated, an error is returned.
- func (m *HttpUri) Validate() error {
- if m == nil {
- return nil
- }
- if len(m.GetUri()) < 1 {
- return HttpUriValidationError{
- field: "Uri",
- reason: "value length must be at least 1 bytes",
- }
- }
- if m.GetTimeout() == nil {
- return HttpUriValidationError{
- field: "Timeout",
- reason: "value is required",
- }
- }
- if d := m.GetTimeout(); d != nil {
- dur, err := ptypes.Duration(d)
- if err != nil {
- return HttpUriValidationError{
- field: "Timeout",
- reason: "value is not a valid duration",
- cause: err,
- }
- }
- gte := time.Duration(0*time.Second + 0*time.Nanosecond)
- if dur < gte {
- return HttpUriValidationError{
- field: "Timeout",
- reason: "value must be greater than or equal to 0s",
- }
- }
- }
- switch m.HttpUpstreamType.(type) {
- case *HttpUri_Cluster:
- if len(m.GetCluster()) < 1 {
- return HttpUriValidationError{
- field: "Cluster",
- reason: "value length must be at least 1 bytes",
- }
- }
- default:
- return HttpUriValidationError{
- field: "HttpUpstreamType",
- reason: "value is required",
- }
- }
- return nil
- }
- // HttpUriValidationError is the validation error returned by HttpUri.Validate
- // if the designated constraints aren't met.
- type HttpUriValidationError struct {
- field string
- reason string
- cause error
- key bool
- }
- // Field function returns field value.
- func (e HttpUriValidationError) Field() string { return e.field }
- // Reason function returns reason value.
- func (e HttpUriValidationError) Reason() string { return e.reason }
- // Cause function returns cause value.
- func (e HttpUriValidationError) Cause() error { return e.cause }
- // Key function returns key value.
- func (e HttpUriValidationError) Key() bool { return e.key }
- // ErrorName returns error name.
- func (e HttpUriValidationError) ErrorName() string { return "HttpUriValidationError" }
- // Error satisfies the builtin error interface
- func (e HttpUriValidationError) Error() string {
- cause := ""
- if e.cause != nil {
- cause = fmt.Sprintf(" | caused by: %v", e.cause)
- }
- key := ""
- if e.key {
- key = "key for "
- }
- return fmt.Sprintf(
- "invalid %sHttpUri.%s: %s%s",
- key,
- e.field,
- e.reason,
- cause)
- }
- var _ error = HttpUriValidationError{}
- var _ interface {
- Field() string
- Reason() string
- Key() bool
- Cause() error
- ErrorName() string
- } = HttpUriValidationError{}