matcher

package
v1.42.0-dev Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 21, 2021 License: Apache-2.0 Imports: 7 Imported by: 0

Documentation

Overview

Package matcher contains types that need to be shared between code under google.golang.org/grpc/xds/... and the rest of gRPC.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type HeaderContainsMatcher

type HeaderContainsMatcher struct {
	// contains filtered or unexported fields
}

HeaderContainsMatcher matches on whether the header value contains the value passed into this struct.

func NewHeaderContainsMatcher

func NewHeaderContainsMatcher(key string, contains string) *HeaderContainsMatcher

NewHeaderContainsMatcher returns a new HeaderContainsMatcher. key is the HTTP Header key to match on, and contains is the value that the header should should contain for a successful match. An empty contains string does not work, use HeaderPresentMatcher in that case.

func (*HeaderContainsMatcher) Match

func (hcm *HeaderContainsMatcher) Match(md metadata.MD) bool

Match returns whether the passed in HTTP Headers match according to the HeaderContainsMatcher.

func (*HeaderContainsMatcher) String

func (hcm *HeaderContainsMatcher) String() string

type HeaderExactMatcher

type HeaderExactMatcher struct {
	// contains filtered or unexported fields
}

HeaderExactMatcher matches on an exact match of the value of the header.

func NewHeaderExactMatcher

func NewHeaderExactMatcher(key, exact string) *HeaderExactMatcher

NewHeaderExactMatcher returns a new HeaderExactMatcher.

func (*HeaderExactMatcher) Match

func (hem *HeaderExactMatcher) Match(md metadata.MD) bool

Match returns whether the passed in HTTP Headers match according to the HeaderExactMatcher.

func (*HeaderExactMatcher) String

func (hem *HeaderExactMatcher) String() string

type HeaderMatcher

type HeaderMatcher interface {
	Match(metadata.MD) bool
	String() string
}

HeaderMatcher is an interface for header matchers. These are documented in (EnvoyProxy link here?). These matchers will match on different aspects of HTTP header name/value pairs.

type HeaderPrefixMatcher

type HeaderPrefixMatcher struct {
	// contains filtered or unexported fields
}

HeaderPrefixMatcher matches on whether the prefix of the header value matches the prefix passed into this struct.

func NewHeaderPrefixMatcher

func NewHeaderPrefixMatcher(key string, prefix string) *HeaderPrefixMatcher

NewHeaderPrefixMatcher returns a new HeaderPrefixMatcher.

func (*HeaderPrefixMatcher) Match

func (hpm *HeaderPrefixMatcher) Match(md metadata.MD) bool

Match returns whether the passed in HTTP Headers match according to the HeaderPrefixMatcher.

func (*HeaderPrefixMatcher) String

func (hpm *HeaderPrefixMatcher) String() string

type HeaderPresentMatcher

type HeaderPresentMatcher struct {
	// contains filtered or unexported fields
}

HeaderPresentMatcher will match based on whether the header is present in the whole request.

func NewHeaderPresentMatcher

func NewHeaderPresentMatcher(key string, present bool) *HeaderPresentMatcher

NewHeaderPresentMatcher returns a new HeaderPresentMatcher.

func (*HeaderPresentMatcher) Match

func (hpm *HeaderPresentMatcher) Match(md metadata.MD) bool

Match returns whether the passed in HTTP Headers match according to the HeaderPresentMatcher.

func (*HeaderPresentMatcher) String

func (hpm *HeaderPresentMatcher) String() string

type HeaderRangeMatcher

type HeaderRangeMatcher struct {
	// contains filtered or unexported fields
}

HeaderRangeMatcher matches on whether the request header value is within the range. The header value must be an integer in base 10 notation.

func NewHeaderRangeMatcher

func NewHeaderRangeMatcher(key string, start, end int64) *HeaderRangeMatcher

NewHeaderRangeMatcher returns a new HeaderRangeMatcher.

func (*HeaderRangeMatcher) Match

func (hrm *HeaderRangeMatcher) Match(md metadata.MD) bool

Match returns whether the passed in HTTP Headers match according to the HeaderRangeMatcher.

func (*HeaderRangeMatcher) String

func (hrm *HeaderRangeMatcher) String() string

type HeaderRegexMatcher

type HeaderRegexMatcher struct {
	// contains filtered or unexported fields
}

HeaderRegexMatcher matches on whether the entire request header value matches the regex.

func NewHeaderRegexMatcher

func NewHeaderRegexMatcher(key string, re *regexp.Regexp) *HeaderRegexMatcher

NewHeaderRegexMatcher returns a new HeaderRegexMatcher.

func (*HeaderRegexMatcher) Match

func (hrm *HeaderRegexMatcher) Match(md metadata.MD) bool

Match returns whether the passed in HTTP Headers match according to the HeaderRegexMatcher.

func (*HeaderRegexMatcher) String

func (hrm *HeaderRegexMatcher) String() string

type HeaderSuffixMatcher

type HeaderSuffixMatcher struct {
	// contains filtered or unexported fields
}

HeaderSuffixMatcher matches on whether the suffix of the header value matches the suffix passed into this struct.

func NewHeaderSuffixMatcher

func NewHeaderSuffixMatcher(key string, suffix string) *HeaderSuffixMatcher

NewHeaderSuffixMatcher returns a new HeaderSuffixMatcher.

func (*HeaderSuffixMatcher) Match

func (hsm *HeaderSuffixMatcher) Match(md metadata.MD) bool

Match returns whether the passed in HTTP Headers match according to the HeaderSuffixMatcher.

func (*HeaderSuffixMatcher) String

func (hsm *HeaderSuffixMatcher) String() string

type InvertMatcher

type InvertMatcher struct {
	// contains filtered or unexported fields
}

InvertMatcher inverts the match result of the underlying header matcher.

func NewInvertMatcher

func NewInvertMatcher(m HeaderMatcher) *InvertMatcher

NewInvertMatcher returns a new InvertMatcher.

func (*InvertMatcher) Match

func (i *InvertMatcher) Match(md metadata.MD) bool

Match returns whether the passed in HTTP Headers match according to the InvertMatcher.

func (*InvertMatcher) String

func (i *InvertMatcher) String() string

type StringMatcher

type StringMatcher struct {
	// contains filtered or unexported fields
}

StringMatcher contains match criteria for matching a string, and is an internal representation of the `StringMatcher` proto defined at https://github.com/envoyproxy/envoy/blob/main/api/envoy/type/matcher/v3/string.proto.

func StringMatcherForTesting

func StringMatcherForTesting(exact, prefix, suffix, contains *string, regex *regexp.Regexp, ignoreCase bool) StringMatcher

StringMatcherForTesting is a helper function to create a StringMatcher based on the given arguments. Intended only for testing purposes.

func StringMatcherFromProto

func StringMatcherFromProto(matcherProto *v3matcherpb.StringMatcher) (StringMatcher, error)

StringMatcherFromProto is a helper function to create a StringMatcher from the corresponding StringMatcher proto.

Returns a non-nil error if matcherProto is invalid.

func (StringMatcher) Equal

func (sm StringMatcher) Equal(other StringMatcher) bool

Equal returns true if other and sm are equivalent to each other.

func (StringMatcher) ExactMatch

func (sm StringMatcher) ExactMatch() string

ExactMatch returns the value of the configured exact match or an empty string if exact match criteria was not specified.

func (StringMatcher) Match

func (sm StringMatcher) Match(input string) bool

Match returns true if input matches the criteria in the given StringMatcher.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL