query

package
v2.1.4 Latest Latest
Warning

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

Go to latest
Published: Feb 15, 2024 License: Apache-2.0 Imports: 14 Imported by: 1

README

Query

This package offers a set of predefined protobuf message types to be used as collection query parameters, which are also called collection operators. These types are:

  • infoblox.api.Filtering
  • infoblox.api.Sorting
  • infoblox.api.Pagination
  • infoblox.api.PageInfo(used in response)
  • infoblox.api.FieldSelection
  • infoblox.api.Searching

Enabling collection operators in your application

In order to get collection operators in your app you need the following:

  • Add collection operator types to a request message. You're free to use any subset of them.
import "github.com/lunchroum/atlas-app-toolkit/query/collection_operators.proto";

message MyListRequest {
    infoblox.api.Filtering filtering = 1;
    infoblox.api.Sorting sorting = 2;
    infoblox.api.Pagination pagination = 3;
    infoblox.api.FieldSelection fields = 4;
    infoblox.api.Searching searching = 5;
}
  • Enable gateway.ClientUnaryInterceptor and gateway.MetadataAnnotator in your gRPC gateway. This will make collection operators to be automatically parsed on gRPC gateway side. If you're using our server wrapper, you need to explicitly set only gateway.ClientUnaryInterceptor since gateway.MetadataAnnotator is enabled by default.
server.WithGateway(
  gateway.WithDialOptions(
    []grpc.DialOption{grpc.WithInsecure(), grpc.WithUnaryInterceptor(
      grpc_middleware.ChainUnaryClient(
        []grpc.UnaryClientInterceptor{gateway.ClientUnaryInterceptor...})},
      ),
  )
)

Filtering

The syntax of REST representation of infoblox.api.Filtering is the following.

REST Query Parameter Description
_filter A string expression containing JSON tags, literal values, and logical operators.

Literal values include numbers (integer and floating-point), quoted (both single- or double-quoted) literal strings, “null” , arrays with numbers (integer and floating-point) and arrays with quoted (both single- or double-quoted) literal strings. The following operators are commonly used in filter expressions.

Operator Description Example
== eq Equal
!= ne Not Equal
> gt Greater Than
>= ge Greater Than or Equal To
< lt Less Than
<= le Less Than or Equal To
and Logical AND price <= 200 and price > 3.5
~ match Matches Regex
!~ nomatch Does Not Match Regex
or Logical OR price <= 3.5 or price > 200
not Logical NOT not price <= 3.5
() Grouping (priority == 1 or city == ‘Santa Clara’) and price > 100
:= ieq Insensitive equal
in Check existence in set city in [‘Santa Clara’, ‘New York’] or price in [1,2,3]

In order to escape string literal delimiter duplicate it, e.g. for single-quoted string literals: _filter=field == 'dup single quote '' ', for double-quoted literals: _filter=field == "dup double quote "" ".

JSONB Filtering

Also our filtering support custom jsonb conditions if you use postgresql as a database. In order to use this feathure you have to use special type Jsonb. If you plan to use special jsonb filtering on a field it's type should be *dialects.Jsonb. Syntax for jsonb filtering is similar to the one you use for StringCondition and StringArrayCondition, as well as you can use operators from StringCondition and StringArrayCondition.

Example:

Consider that you have a following object where info field is a jsonb field:

{
 name: "my object",
 info: {
     Address: {
         "City": "Tacoma",
         "Country": "USA"
     }
 }
}

Filterting request with jsonb query will look like:

...?_filter=info.Address.City=='Tacoma'

if you want to compare enclosed object with json you are able to write:

...?_filter=info.Address=='{"City": "Tacoma", "Country": "USA"}'

Note: if you decide to use toolkit provided infoblox.api.Filtering proto type, then you'll not be able to use vanilla swagger schema generation, since this plugin doesn't work with recursive nature of infoblox.api.Filtering. In this case you can use our fork which has a fix for this issue. You can also use atlas-gentool which contains both versions of the plugin.

Sorting

The syntax of REST representation of infoblox.api.Sorting is the following.

Request Parameter Description Example
_order_by A comma-separated list of JSON tag names. The sort direction can be specified by a suffix separated by whitespace before the tag name. The suffix “asc” sorts the data in ascending order. The suffix “desc” sorts the data in descending order. If no suffix is specified the data is sorted in ascending order. work_address.addresss desc,first_name

Pagination

The syntax of REST representation of infoblox.api.Pagination and infoblox.api.PageInfo is the following.

Paging Mode Request Parameters Response Parameters Description
Client-driven paging _offset The integer index (zero-origin) of the offset into a collection of resources. If omitted or null, the value is assumed to be “0”.
_limit The integer number of resources to be returned in the response. The service may impose maximum value. If omitted, the service may impose a default value.
_offset The service may optionally* include the offset of the next page of resources. A null value indicates no more pages.
_size The service may optionally include the total number of resources being paged.
Server-driven paging _page_token The service-defined string used to identify a page of resources. A null value indicates the first page.
_page_token The service response should contain a string to indicate the next page of resources. A null value indicates no more pages.
_size The service may optionally include the total number of resources being paged.

Field Selection

The syntax of REST representation of infoblox.api.FieldSelection is the following.

Request Parameter Description Example
_fields A comma-separated list of JSON tag names. work_address.addresss,first_name

As it is not possible to completely remove all the fields(such as primitives) from proto.Message on gRPC server side, fields are additionally truncated on gRPC Gateway side. This is done by gateway.ResponseForwarder.

Field Presence

Using the toolkit's server package functionality, you can optionally enable automatic filling of a google.protobuf.FieldMask within the gRPC Gateway.

As a prerequisite, the request passing through the gateway must match the list of given HTTP methods (e.g. POST, PUT, PATCH) and contain a FieldMask at the top level.

import "google/protobuf/field_mask.proto";
message MyRequest {
  bytes data = 1;
  google.protobuf.FieldMask fields = 2;
}

To enable the functionality, use the following args in the WithGateway method:

server.WithGateway(
  gateway.WithGatewayOptions(
    runtime.WithMetadata(gateway.NewPresenceAnnotator("POST", ...)),
    ...
  ),
  gateway.WithDialOptions(
    []grpc.DialOption{grpc.WithInsecure(), grpc.WithUnaryInterceptor(
      grpc_middleware.ChainUnaryClient(
        []grpc.UnaryClientInterceptor{gateway.ClientUnaryInterceptor, gateway.PresenceClientInterceptor()}...)},
      ),
  )
)

Searching

The syntax of REST representation of infoblox.api.Searching is the following.

Request Parameter Description
_fts A string expression which performs a full-text-search on the DB

Full-text-search is an optimized mechanism to retrieve data from the DB efficiently when the user is only aware of some portion of the data they are searching.

Example:

Consider that you have the following objects:

{
 name: "my first object",
 city: "Santa Clara",
 country: "USA"
},
{
 name: "my second object",
 city: "Tacoma",
 country: "USA"
}

If "name" is provided as a field for FTS, the Searching query will look like:

...?_fts=my first object

In this case, only the first object would be returned.

If "country" is provided as a field for FTS, the Searching query will look like:

...?_fts=USA

In this case, both the objects would be returned.

Documentation

Index

Constants

View Source
const (
	// Default pagination limit
	DefaultLimit = 1000
)

Variables

View Source
var (
	SortCriteria_Order_name = map[int32]string{
		0: "ASC",
		1: "DESC",
	}
	SortCriteria_Order_value = map[string]int32{
		"ASC":  0,
		"DESC": 1,
	}
)

Enum value maps for SortCriteria_Order.

View Source
var (
	LogicalOperator_Type_name = map[int32]string{
		0: "AND",
		1: "OR",
	}
	LogicalOperator_Type_value = map[string]int32{
		"AND": 0,
		"OR":  1,
	}
)

Enum value maps for LogicalOperator_Type.

View Source
var (
	StringCondition_Type_name = map[int32]string{
		0: "EQ",
		1: "MATCH",
		2: "GT",
		3: "GE",
		4: "LT",
		5: "LE",
		6: "IEQ",
	}
	StringCondition_Type_value = map[string]int32{
		"EQ":    0,
		"MATCH": 1,
		"GT":    2,
		"GE":    3,
		"LT":    4,
		"LE":    5,
		"IEQ":   6,
	}
)

Enum value maps for StringCondition_Type.

View Source
var (
	NumberCondition_Type_name = map[int32]string{
		0: "EQ",
		1: "GT",
		2: "GE",
		3: "LT",
		4: "LE",
	}
	NumberCondition_Type_value = map[string]int32{
		"EQ": 0,
		"GT": 1,
		"GE": 2,
		"LT": 3,
		"LE": 4,
	}
)

Enum value maps for NumberCondition_Type.

View Source
var (
	StringArrayCondition_Type_name = map[int32]string{
		0: "IN",
	}
	StringArrayCondition_Type_value = map[string]int32{
		"IN": 0,
	}
)

Enum value maps for StringArrayCondition_Type.

View Source
var (
	NumberArrayCondition_Type_name = map[int32]string{
		0: "IN",
	}
	NumberArrayCondition_Type_value = map[string]int32{
		"IN": 0,
	}
)

Enum value maps for NumberArrayCondition_Type.

View Source
var File_github_com_lunchroum_atlas_app_toolkit_query_collection_operators_proto protoreflect.FileDescriptor

Functions

func DecodePageToken

func DecodePageToken(ptoken string) (offset, limit int32, err error)

DecodePageToken decodes page token from the user's request. Return error if provided token is malformed or contains ivalid values, otherwise return offset, limit.

func EncodePageToken

func EncodePageToken(offset, limit int32) string

EncodePageToken encodes offset and limit to a string in application specific format (offset:limit) in base64 encoding.

func Filter

func Filter(obj interface{}, filter string) (bool, error)

Filter is a shortcut to parse a filter string using default FilteringParser implementation and call Filter on the returned filtering expression.

Types

type AndToken

type AndToken struct {
	TokenBase
}

AndToken represents logical and.

func (AndToken) String

func (t AndToken) String() string

type EOFToken

type EOFToken struct {
	TokenBase
}

EOFToken represents end of an expression.

func (EOFToken) String

func (t EOFToken) String() string

type EqToken

type EqToken struct {
	TokenBase
}

EqToken represents equals operator.

func (EqToken) String

func (t EqToken) String() string

type Field

type Field struct {
	Name string            `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"`
	Subs map[string]*Field `` /* 149-byte string literal not displayed */
	// contains filtered or unexported fields
}

Field represents a single field for an object. It contains fields name and also may contain a group of sub-fields for cases when a fields represents some structure.

func (*Field) Descriptor deprecated

func (*Field) Descriptor() ([]byte, []int)

Deprecated: Use Field.ProtoReflect.Descriptor instead.

func (*Field) GetName

func (x *Field) GetName() string

func (*Field) GetSubs

func (x *Field) GetSubs() map[string]*Field

func (*Field) ProtoMessage

func (*Field) ProtoMessage()

func (*Field) ProtoReflect

func (x *Field) ProtoReflect() protoreflect.Message

func (*Field) Reset

func (x *Field) Reset()

func (*Field) String

func (x *Field) String() string

type FieldSelection

type FieldSelection struct {
	Fields map[string]*Field `` /* 153-byte string literal not displayed */
	// contains filtered or unexported fields
}

FieldSelection represents a group of fields for some object. Main use case for if is to store information about object fields that need to be ratained prior to sending object as a response

func ParseFieldSelection

func ParseFieldSelection(input string, delimiter ...string) *FieldSelection

ParseFieldSelection transforms a string with comma-separated fields that comes from client to FieldSelection struct. For complex fields dot is used as a delimeter by default, but it is also possible to specify a different delimiter.

func (*FieldSelection) Add

func (f *FieldSelection) Add(field string, delimiter ...string)

Add allows to add new fields to FieldSelection

func (*FieldSelection) AllFieldStrings

func (f *FieldSelection) AllFieldStrings() []string

AllFieldStrings returns a slice of dot-notated fields

func (*FieldSelection) Delete

func (f *FieldSelection) Delete(field string, delimiter ...string) bool

Delete allows to remove fields from FieldSelection

func (*FieldSelection) Descriptor deprecated

func (*FieldSelection) Descriptor() ([]byte, []int)

Deprecated: Use FieldSelection.ProtoReflect.Descriptor instead.

func (*FieldSelection) Get

func (f *FieldSelection) Get(field string, delimiter ...string) *Field

Get allows to get specified field from FieldSelection

func (*FieldSelection) GetFields

func (x *FieldSelection) GetFields() map[string]*Field

func (*FieldSelection) GoString

func (f *FieldSelection) GoString() string

GoString converts FieldSelection to a string representation It implements fmt.GoStringer interface and returns dot-notated fields separated by commas

func (*FieldSelection) ProtoMessage

func (*FieldSelection) ProtoMessage()

func (*FieldSelection) ProtoReflect

func (x *FieldSelection) ProtoReflect() protoreflect.Message

func (*FieldSelection) Reset

func (x *FieldSelection) Reset()

func (*FieldSelection) String

func (x *FieldSelection) String() string

type FieldSelectionMap

type FieldSelectionMap map[string]*Field

FieldSelectionMap is a convenience type that represents map[string]*Field used in FieldSelection and Field structs

type FieldToken

type FieldToken struct {
	TokenBase
	Value string
}

FieldToken represents a reference to a value of a resource. Value is a value of the reference.

func (FieldToken) String

func (t FieldToken) String() string

type Filtering

type Filtering struct {

	// Types that are assignable to Root:
	//	*Filtering_Operator
	//	*Filtering_StringCondition
	//	*Filtering_NumberCondition
	//	*Filtering_NullCondition
	//	*Filtering_StringArrayCondition
	//	*Filtering_NumberArrayCondition
	Root isFiltering_Root `protobuf_oneof:"root"`
	// contains filtered or unexported fields
}

Filtering represents filtering expression. root could be either LogicalOperator or one of the supported conditions.

func ParseFiltering

func ParseFiltering(text string) (*Filtering, error)

ParseFiltering is a shortcut to parse a filtering expression using default FilteringParser implementation

func (*Filtering) Descriptor deprecated

func (*Filtering) Descriptor() ([]byte, []int)

Deprecated: Use Filtering.ProtoReflect.Descriptor instead.

func (*Filtering) Filter

func (m *Filtering) Filter(obj interface{}) (bool, error)

Filter evaluates underlying filtering expression against obj. If obj implements Matcher, call it's custom implementation.

func (*Filtering) GetNullCondition

func (x *Filtering) GetNullCondition() *NullCondition

func (*Filtering) GetNumberArrayCondition

func (x *Filtering) GetNumberArrayCondition() *NumberArrayCondition

func (*Filtering) GetNumberCondition

func (x *Filtering) GetNumberCondition() *NumberCondition

func (*Filtering) GetOperator

func (x *Filtering) GetOperator() *LogicalOperator

func (*Filtering) GetRoot

func (m *Filtering) GetRoot() isFiltering_Root

func (*Filtering) GetStringArrayCondition

func (x *Filtering) GetStringArrayCondition() *StringArrayCondition

func (*Filtering) GetStringCondition

func (x *Filtering) GetStringCondition() *StringCondition

func (*Filtering) ProtoMessage

func (*Filtering) ProtoMessage()

func (*Filtering) ProtoReflect

func (x *Filtering) ProtoReflect() protoreflect.Message

func (*Filtering) Reset

func (x *Filtering) Reset()

func (*Filtering) SetRoot

func (m *Filtering) SetRoot(r interface{}) error

SetRoot automatically wraps r into appropriate oneof structure and sets it to Root.

func (*Filtering) String

func (x *Filtering) String() string

type FilteringExpression

type FilteringExpression interface {
	Filter(interface{}) (bool, error)
}

FilteringExpression is the interface implemented by types that represent nodes in a filtering expression AST.

type FilteringLexer

type FilteringLexer interface {
	NextToken() (Token, error)
}

FilteringLexer is impemented by lexical analyzers that are used by filtering expression parsers.

func NewFilteringLexer

func NewFilteringLexer(text string) FilteringLexer

NewFilteringLexer returns a default FilteringLexer implementation. text is a filtering expression to analyze.

type FilteringParser

type FilteringParser interface {
	Parse(string) (*Filtering, error)
}

FilteringParser is implemented by parsers of a filtering expression that conforms to REST API Syntax Specification.

func NewFilteringParser

func NewFilteringParser() FilteringParser

NewFilteringParser returns a default FilteringParser implementation.

type Filtering_NullCondition

type Filtering_NullCondition struct {
	NullCondition *NullCondition `protobuf:"bytes,4,opt,name=null_condition,json=nullCondition,proto3,oneof"`
}

func (*Filtering_NullCondition) Filter

func (m *Filtering_NullCondition) Filter(obj interface{}) (bool, error)

type Filtering_NumberArrayCondition

type Filtering_NumberArrayCondition struct {
	NumberArrayCondition *NumberArrayCondition `protobuf:"bytes,6,opt,name=number_array_condition,json=numberArrayCondition,proto3,oneof"`
}

func (*Filtering_NumberArrayCondition) Filter

func (m *Filtering_NumberArrayCondition) Filter(obj interface{}) (bool, error)

type Filtering_NumberCondition

type Filtering_NumberCondition struct {
	NumberCondition *NumberCondition `protobuf:"bytes,3,opt,name=number_condition,json=numberCondition,proto3,oneof"`
}

func (*Filtering_NumberCondition) Filter

func (m *Filtering_NumberCondition) Filter(obj interface{}) (bool, error)

type Filtering_Operator

type Filtering_Operator struct {
	Operator *LogicalOperator `protobuf:"bytes,1,opt,name=operator,proto3,oneof"`
}

func (*Filtering_Operator) Filter

func (m *Filtering_Operator) Filter(obj interface{}) (bool, error)

type Filtering_StringArrayCondition

type Filtering_StringArrayCondition struct {
	StringArrayCondition *StringArrayCondition `protobuf:"bytes,5,opt,name=string_array_condition,json=stringArrayCondition,proto3,oneof"`
}

func (*Filtering_StringArrayCondition) Filter

func (m *Filtering_StringArrayCondition) Filter(obj interface{}) (bool, error)

type Filtering_StringCondition

type Filtering_StringCondition struct {
	StringCondition *StringCondition `protobuf:"bytes,2,opt,name=string_condition,json=stringCondition,proto3,oneof"`
}

func (*Filtering_StringCondition) Filter

func (m *Filtering_StringCondition) Filter(obj interface{}) (bool, error)

type GeToken

type GeToken struct {
	TokenBase
}

GeToken represents greater than or equals operator.

func (GeToken) String

func (t GeToken) String() string

type GtToken

type GtToken struct {
	TokenBase
}

GtToken represents greater than operator.

func (GtToken) String

func (t GtToken) String() string

type InToken

type InToken struct {
	TokenBase
}

InToken represent in operation for string and numbers arrays

func (InToken) String

func (t InToken) String() string

type InsensitiveEqToken

type InsensitiveEqToken struct {
	TokenBase
}

func (InsensitiveEqToken) String

func (t InsensitiveEqToken) String() string

type LeToken

type LeToken struct {
	TokenBase
}

LeToken represents less than or equals operator.

func (LeToken) String

func (t LeToken) String() string

type LogicalOperator

type LogicalOperator struct {

	// Types that are assignable to Left:
	//	*LogicalOperator_LeftOperator
	//	*LogicalOperator_LeftStringCondition
	//	*LogicalOperator_LeftNumberCondition
	//	*LogicalOperator_LeftNullCondition
	//	*LogicalOperator_LeftStringArrayCondition
	//	*LogicalOperator_LeftNumberArrayCondition
	Left isLogicalOperator_Left `protobuf_oneof:"left"`
	// Types that are assignable to Right:
	//	*LogicalOperator_RightOperator
	//	*LogicalOperator_RightStringCondition
	//	*LogicalOperator_RightNumberCondition
	//	*LogicalOperator_RightNullCondition
	//	*LogicalOperator_RightStringArrayCondition
	//	*LogicalOperator_RightNumberArrayCondition
	Right      isLogicalOperator_Right `protobuf_oneof:"right"`
	Type       LogicalOperator_Type    `protobuf:"varint,9,opt,name=type,proto3,enum=infoblox.api.LogicalOperator_Type" json:"type,omitempty"`
	IsNegative bool                    `protobuf:"varint,10,opt,name=is_negative,json=isNegative,proto3" json:"is_negative,omitempty"`
	// contains filtered or unexported fields
}

LogicalOperator represents binary logical operator, either AND or OR depending on type. left and right are respectively left and right operands of the operator, could be either LogicalOperator or one of the supported conditions. is_negative is set to true if the operator is negated.

func (*LogicalOperator) Descriptor deprecated

func (*LogicalOperator) Descriptor() ([]byte, []int)

Deprecated: Use LogicalOperator.ProtoReflect.Descriptor instead.

func (*LogicalOperator) Filter

func (lop *LogicalOperator) Filter(obj interface{}) (bool, error)

Filter evaluates filtering expression against obj.

func (*LogicalOperator) GetIsNegative

func (x *LogicalOperator) GetIsNegative() bool

func (*LogicalOperator) GetLeft

func (m *LogicalOperator) GetLeft() isLogicalOperator_Left

func (*LogicalOperator) GetLeftNullCondition

func (x *LogicalOperator) GetLeftNullCondition() *NullCondition

func (*LogicalOperator) GetLeftNumberArrayCondition

func (x *LogicalOperator) GetLeftNumberArrayCondition() *NumberArrayCondition

func (*LogicalOperator) GetLeftNumberCondition

func (x *LogicalOperator) GetLeftNumberCondition() *NumberCondition

func (*LogicalOperator) GetLeftOperator

func (x *LogicalOperator) GetLeftOperator() *LogicalOperator

func (*LogicalOperator) GetLeftStringArrayCondition

func (x *LogicalOperator) GetLeftStringArrayCondition() *StringArrayCondition

func (*LogicalOperator) GetLeftStringCondition

func (x *LogicalOperator) GetLeftStringCondition() *StringCondition

func (*LogicalOperator) GetRight

func (m *LogicalOperator) GetRight() isLogicalOperator_Right

func (*LogicalOperator) GetRightNullCondition

func (x *LogicalOperator) GetRightNullCondition() *NullCondition

func (*LogicalOperator) GetRightNumberArrayCondition

func (x *LogicalOperator) GetRightNumberArrayCondition() *NumberArrayCondition

func (*LogicalOperator) GetRightNumberCondition

func (x *LogicalOperator) GetRightNumberCondition() *NumberCondition

func (*LogicalOperator) GetRightOperator

func (x *LogicalOperator) GetRightOperator() *LogicalOperator

func (*LogicalOperator) GetRightStringArrayCondition

func (x *LogicalOperator) GetRightStringArrayCondition() *StringArrayCondition

func (*LogicalOperator) GetRightStringCondition

func (x *LogicalOperator) GetRightStringCondition() *StringCondition

func (*LogicalOperator) GetType

func (*LogicalOperator) ProtoMessage

func (*LogicalOperator) ProtoMessage()

func (*LogicalOperator) ProtoReflect

func (x *LogicalOperator) ProtoReflect() protoreflect.Message

func (*LogicalOperator) Reset

func (x *LogicalOperator) Reset()

func (*LogicalOperator) SetLeft

func (m *LogicalOperator) SetLeft(l interface{}) error

SetLeft automatically wraps l into appropriate oneof structure and sets it to Root.

func (*LogicalOperator) SetRight

func (m *LogicalOperator) SetRight(r interface{}) error

SetRight automatically wraps r into appropriate oneof structure and sets it to Root.

func (*LogicalOperator) String

func (x *LogicalOperator) String() string

type LogicalOperator_LeftNullCondition

type LogicalOperator_LeftNullCondition struct {
	LeftNullCondition *NullCondition `protobuf:"bytes,4,opt,name=left_null_condition,json=leftNullCondition,proto3,oneof"`
}

func (*LogicalOperator_LeftNullCondition) Filter

func (m *LogicalOperator_LeftNullCondition) Filter(obj interface{}) (bool, error)

type LogicalOperator_LeftNumberArrayCondition

type LogicalOperator_LeftNumberArrayCondition struct {
	LeftNumberArrayCondition *NumberArrayCondition `protobuf:"bytes,12,opt,name=left_number_array_condition,json=leftNumberArrayCondition,proto3,oneof"`
}

func (*LogicalOperator_LeftNumberArrayCondition) Filter

func (m *LogicalOperator_LeftNumberArrayCondition) Filter(obj interface{}) (bool, error)

type LogicalOperator_LeftNumberCondition

type LogicalOperator_LeftNumberCondition struct {
	LeftNumberCondition *NumberCondition `protobuf:"bytes,3,opt,name=left_number_condition,json=leftNumberCondition,proto3,oneof"`
}

func (*LogicalOperator_LeftNumberCondition) Filter

func (m *LogicalOperator_LeftNumberCondition) Filter(obj interface{}) (bool, error)

type LogicalOperator_LeftOperator

type LogicalOperator_LeftOperator struct {
	LeftOperator *LogicalOperator `protobuf:"bytes,1,opt,name=left_operator,json=leftOperator,proto3,oneof"`
}

func (*LogicalOperator_LeftOperator) Filter

func (m *LogicalOperator_LeftOperator) Filter(obj interface{}) (bool, error)

type LogicalOperator_LeftStringArrayCondition

type LogicalOperator_LeftStringArrayCondition struct {
	LeftStringArrayCondition *StringArrayCondition `protobuf:"bytes,11,opt,name=left_string_array_condition,json=leftStringArrayCondition,proto3,oneof"`
}

func (*LogicalOperator_LeftStringArrayCondition) Filter

func (m *LogicalOperator_LeftStringArrayCondition) Filter(obj interface{}) (bool, error)

type LogicalOperator_LeftStringCondition

type LogicalOperator_LeftStringCondition struct {
	LeftStringCondition *StringCondition `protobuf:"bytes,2,opt,name=left_string_condition,json=leftStringCondition,proto3,oneof"`
}

func (*LogicalOperator_LeftStringCondition) Filter

func (m *LogicalOperator_LeftStringCondition) Filter(obj interface{}) (bool, error)

type LogicalOperator_RightNullCondition

type LogicalOperator_RightNullCondition struct {
	RightNullCondition *NullCondition `protobuf:"bytes,8,opt,name=right_null_condition,json=rightNullCondition,proto3,oneof"`
}

func (*LogicalOperator_RightNullCondition) Filter

func (m *LogicalOperator_RightNullCondition) Filter(obj interface{}) (bool, error)

type LogicalOperator_RightNumberArrayCondition

type LogicalOperator_RightNumberArrayCondition struct {
	RightNumberArrayCondition *NumberArrayCondition `protobuf:"bytes,14,opt,name=right_number_array_condition,json=rightNumberArrayCondition,proto3,oneof"`
}

func (*LogicalOperator_RightNumberArrayCondition) Filter

func (m *LogicalOperator_RightNumberArrayCondition) Filter(obj interface{}) (bool, error)

type LogicalOperator_RightNumberCondition

type LogicalOperator_RightNumberCondition struct {
	RightNumberCondition *NumberCondition `protobuf:"bytes,7,opt,name=right_number_condition,json=rightNumberCondition,proto3,oneof"`
}

func (*LogicalOperator_RightNumberCondition) Filter

func (m *LogicalOperator_RightNumberCondition) Filter(obj interface{}) (bool, error)

type LogicalOperator_RightOperator

type LogicalOperator_RightOperator struct {
	RightOperator *LogicalOperator `protobuf:"bytes,5,opt,name=right_operator,json=rightOperator,proto3,oneof"`
}

func (*LogicalOperator_RightOperator) Filter

func (m *LogicalOperator_RightOperator) Filter(obj interface{}) (bool, error)

type LogicalOperator_RightStringArrayCondition

type LogicalOperator_RightStringArrayCondition struct {
	RightStringArrayCondition *StringArrayCondition `protobuf:"bytes,13,opt,name=right_string_array_condition,json=rightStringArrayCondition,proto3,oneof"`
}

func (*LogicalOperator_RightStringArrayCondition) Filter

func (m *LogicalOperator_RightStringArrayCondition) Filter(obj interface{}) (bool, error)

type LogicalOperator_RightStringCondition

type LogicalOperator_RightStringCondition struct {
	RightStringCondition *StringCondition `protobuf:"bytes,6,opt,name=right_string_condition,json=rightStringCondition,proto3,oneof"`
}

func (*LogicalOperator_RightStringCondition) Filter

func (m *LogicalOperator_RightStringCondition) Filter(obj interface{}) (bool, error)

type LogicalOperator_Type

type LogicalOperator_Type int32
const (
	LogicalOperator_AND LogicalOperator_Type = 0
	LogicalOperator_OR  LogicalOperator_Type = 1
)

func (LogicalOperator_Type) Descriptor

func (LogicalOperator_Type) Enum

func (LogicalOperator_Type) EnumDescriptor deprecated

func (LogicalOperator_Type) EnumDescriptor() ([]byte, []int)

Deprecated: Use LogicalOperator_Type.Descriptor instead.

func (LogicalOperator_Type) Number

func (LogicalOperator_Type) String

func (x LogicalOperator_Type) String() string

func (LogicalOperator_Type) Type

type LparenToken

type LparenToken struct {
	TokenBase
}

LparenToken represents left parenthesis.

func (LparenToken) String

func (t LparenToken) String() string

type LtToken

type LtToken struct {
	TokenBase
}

LtToken represents less than operator.

func (LtToken) String

func (t LtToken) String() string

type MatchToken

type MatchToken struct {
	TokenBase
}

MatchToken represents regular expression match.

func (MatchToken) String

func (t MatchToken) String() string

type Matcher

type Matcher interface {
	Match(*Filtering) (bool, error)
}

Matcher is implemented by structs that require custom filtering logic.

type NeToken

type NeToken struct {
	TokenBase
}

NeToken represents not equals operator.

func (NeToken) String

func (t NeToken) String() string

type NmatchToken

type NmatchToken struct {
	TokenBase
}

NmatchToken represents negation of regular expression match.

func (NmatchToken) String

func (t NmatchToken) String() string

type NotToken

type NotToken struct {
	TokenBase
}

NotToken represents logical not.

func (NotToken) String

func (t NotToken) String() string

type NullCondition

type NullCondition struct {
	FieldPath  []string `protobuf:"bytes,1,rep,name=field_path,json=fieldPath,proto3" json:"field_path,omitempty"`
	IsNegative bool     `protobuf:"varint,2,opt,name=is_negative,json=isNegative,proto3" json:"is_negative,omitempty"`
	// contains filtered or unexported fields
}

NullCondition represents a condition with a null literal, e.g. field == null. field_path is a reference to a value of a resource. is_negative is set to true if the condition is negated.

func (*NullCondition) Descriptor deprecated

func (*NullCondition) Descriptor() ([]byte, []int)

Deprecated: Use NullCondition.ProtoReflect.Descriptor instead.

func (*NullCondition) Filter

func (c *NullCondition) Filter(obj interface{}) (bool, error)

Filter evaluates null condition against obj. If obj is a proto message, then 'protobuf' tag is used to map FieldPath to obj's struct fields, otherwise 'json' tag is used.

func (*NullCondition) GetFieldPath

func (x *NullCondition) GetFieldPath() []string

func (*NullCondition) GetIsNegative

func (x *NullCondition) GetIsNegative() bool

func (*NullCondition) ProtoMessage

func (*NullCondition) ProtoMessage()

func (*NullCondition) ProtoReflect

func (x *NullCondition) ProtoReflect() protoreflect.Message

func (*NullCondition) Reset

func (x *NullCondition) Reset()

func (*NullCondition) String

func (x *NullCondition) String() string

type NullToken

type NullToken struct {
	TokenBase
}

NullToken represents null literal.

func (NullToken) String

func (t NullToken) String() string

type NumberArrayCondition

type NumberArrayCondition struct {
	FieldPath  []string                  `protobuf:"bytes,1,rep,name=field_path,json=fieldPath,proto3" json:"field_path,omitempty"`
	Values     []float64                 `protobuf:"fixed64,2,rep,packed,name=values,proto3" json:"values,omitempty"`
	Type       NumberArrayCondition_Type `protobuf:"varint,3,opt,name=type,proto3,enum=infoblox.api.NumberArrayCondition_Type" json:"type,omitempty"`
	IsNegative bool                      `protobuf:"varint,4,opt,name=is_negative,json=isNegative,proto3" json:"is_negative,omitempty"`
	// contains filtered or unexported fields
}

NumberArrayCondition represents a condition with string arrays, e.g. field in [1, 5, 7] field_path is a reference to a value of a resource. is_negative is set to true if the condition is negated

func (*NumberArrayCondition) Descriptor deprecated

func (*NumberArrayCondition) Descriptor() ([]byte, []int)

Deprecated: Use NumberArrayCondition.ProtoReflect.Descriptor instead.

func (*NumberArrayCondition) Filter

func (c *NumberArrayCondition) Filter(obj interface{}) (bool, error)

func (*NumberArrayCondition) GetFieldPath

func (x *NumberArrayCondition) GetFieldPath() []string

func (*NumberArrayCondition) GetIsNegative

func (x *NumberArrayCondition) GetIsNegative() bool

func (*NumberArrayCondition) GetType

func (*NumberArrayCondition) GetValues

func (x *NumberArrayCondition) GetValues() []float64

func (*NumberArrayCondition) ProtoMessage

func (*NumberArrayCondition) ProtoMessage()

func (*NumberArrayCondition) ProtoReflect

func (x *NumberArrayCondition) ProtoReflect() protoreflect.Message

func (*NumberArrayCondition) Reset

func (x *NumberArrayCondition) Reset()

func (*NumberArrayCondition) String

func (x *NumberArrayCondition) String() string

type NumberArrayCondition_Type

type NumberArrayCondition_Type int32
const (
	NumberArrayCondition_IN NumberArrayCondition_Type = 0
)

func (NumberArrayCondition_Type) Descriptor

func (NumberArrayCondition_Type) Enum

func (NumberArrayCondition_Type) EnumDescriptor deprecated

func (NumberArrayCondition_Type) EnumDescriptor() ([]byte, []int)

Deprecated: Use NumberArrayCondition_Type.Descriptor instead.

func (NumberArrayCondition_Type) Number

func (NumberArrayCondition_Type) String

func (x NumberArrayCondition_Type) String() string

func (NumberArrayCondition_Type) Type

type NumberArrayToken

type NumberArrayToken struct {
	TokenBase
	Values []float64
}

NumberArrayToken represent number array e.g. [1,2,5]

func (NumberArrayToken) String

func (t NumberArrayToken) String() string

type NumberCondition

type NumberCondition struct {
	FieldPath  []string             `protobuf:"bytes,1,rep,name=field_path,json=fieldPath,proto3" json:"field_path,omitempty"`
	Value      float64              `protobuf:"fixed64,2,opt,name=value,proto3" json:"value,omitempty"`
	Type       NumberCondition_Type `protobuf:"varint,3,opt,name=type,proto3,enum=infoblox.api.NumberCondition_Type" json:"type,omitempty"`
	IsNegative bool                 `protobuf:"varint,4,opt,name=is_negative,json=isNegative,proto3" json:"is_negative,omitempty"`
	// contains filtered or unexported fields
}

NumberCondition represents a condition with a number literal, e.g. field > 3. field_path is a reference to a value of a resource. value is the number literal. type is a type of the condition. is_negative is set to true if the condition is negated.

func (*NumberCondition) Descriptor deprecated

func (*NumberCondition) Descriptor() ([]byte, []int)

Deprecated: Use NumberCondition.ProtoReflect.Descriptor instead.

func (*NumberCondition) Filter

func (c *NumberCondition) Filter(obj interface{}) (bool, error)

Filter evaluates number condition against obj. If obj is a proto message, then 'protobuf' tag is used to map FieldPath to obj's struct fields, otherwise 'json' tag is used.

func (*NumberCondition) GetFieldPath

func (x *NumberCondition) GetFieldPath() []string

func (*NumberCondition) GetIsNegative

func (x *NumberCondition) GetIsNegative() bool

func (*NumberCondition) GetType

func (*NumberCondition) GetValue

func (x *NumberCondition) GetValue() float64

func (*NumberCondition) ProtoMessage

func (*NumberCondition) ProtoMessage()

func (*NumberCondition) ProtoReflect

func (x *NumberCondition) ProtoReflect() protoreflect.Message

func (*NumberCondition) Reset

func (x *NumberCondition) Reset()

func (*NumberCondition) String

func (x *NumberCondition) String() string

type NumberCondition_Type

type NumberCondition_Type int32
const (
	NumberCondition_EQ NumberCondition_Type = 0
	NumberCondition_GT NumberCondition_Type = 1
	NumberCondition_GE NumberCondition_Type = 2
	NumberCondition_LT NumberCondition_Type = 3
	NumberCondition_LE NumberCondition_Type = 4
)

func (NumberCondition_Type) Descriptor

func (NumberCondition_Type) Enum

func (NumberCondition_Type) EnumDescriptor deprecated

func (NumberCondition_Type) EnumDescriptor() ([]byte, []int)

Deprecated: Use NumberCondition_Type.Descriptor instead.

func (NumberCondition_Type) Number

func (NumberCondition_Type) String

func (x NumberCondition_Type) String() string

func (NumberCondition_Type) Type

type NumberToken

type NumberToken struct {
	TokenBase
	Value float64
}

NumberToken represents a number literal. Value is a value of the literal.

func (NumberToken) String

func (t NumberToken) String() string

type OrToken

type OrToken struct {
	TokenBase
}

OrToken represents logical or.

func (OrToken) String

func (t OrToken) String() string

type PageInfo

type PageInfo struct {

	// The service response should contain a string to indicate
	// the next page of resources.
	// A null value indicates no more pages.
	PageToken string `protobuf:"bytes,1,opt,name=page_token,json=pageToken,proto3" json:"page_token,omitempty"`
	// The service may optionally include the total number of resources being paged.
	Size int32 `protobuf:"varint,2,opt,name=size,proto3" json:"size,omitempty"`
	// The service may optionally include the offset of the next page of resources.
	// A null value indicates no more pages.
	Offset int32 `protobuf:"varint,3,opt,name=offset,proto3" json:"offset,omitempty"`
	// contains filtered or unexported fields
}

PageInfo represents both server-driven and client-driven pagination response. Server-driven pagination is a model in which the server returns some amount of data along with an token indicating there is more data and where subsequent queries can get the next page of data. Client-driven pagination is a model in which rows are addressable by offset and page size (limit).

func (*PageInfo) Descriptor deprecated

func (*PageInfo) Descriptor() ([]byte, []int)

Deprecated: Use PageInfo.ProtoReflect.Descriptor instead.

func (*PageInfo) GetOffset

func (x *PageInfo) GetOffset() int32

func (*PageInfo) GetPageToken

func (x *PageInfo) GetPageToken() string

func (*PageInfo) GetSize

func (x *PageInfo) GetSize() int32

func (*PageInfo) NoMore

func (p *PageInfo) NoMore() bool

NoMore reports whether page info indicates no more pages are available

func (*PageInfo) ProtoMessage

func (*PageInfo) ProtoMessage()

func (*PageInfo) ProtoReflect

func (x *PageInfo) ProtoReflect() protoreflect.Message

func (*PageInfo) Reset

func (x *PageInfo) Reset()

func (*PageInfo) SetLastOffset

func (p *PageInfo) SetLastOffset()

SetLastOffset sets page info to indicate no more pages are available

func (*PageInfo) SetLastToken

func (p *PageInfo) SetLastToken()

SetLastToken sets page info to indicate no more pages are available

func (*PageInfo) String

func (x *PageInfo) String() string

type Pagination

type Pagination struct {

	// The service-defined string used to identify a page of resources.
	// A null value indicates the first page.
	PageToken string `protobuf:"bytes,1,opt,name=page_token,json=pageToken,proto3" json:"page_token,omitempty"`
	// The integer index of the offset into a collection of resources.
	// If omitted or null, the value is assumed to be "0".
	Offset int32 `protobuf:"varint,2,opt,name=offset,proto3" json:"offset,omitempty"`
	// The integer number of resources to be returned in the response.
	// The service may impose maximum value.
	// If omitted, the service may impose a default value.
	Limit int32 `protobuf:"varint,3,opt,name=limit,proto3" json:"limit,omitempty"`
	// contains filtered or unexported fields
}

Pagination represents both server-driven and client-driven pagination request. Server-driven pagination is a model in which the server returns some amount of data along with an token indicating there is more data and where subsequent queries can get the next page of data. Client-driven pagination is a model in which rows are addressable by offset and page size (limit).

func ParsePagination

func ParsePagination(limit, offset, ptoken string) (*Pagination, error)

Pagination parses string representation of pagination limit, offset. Returns error if limit or offset has invalid syntax or out of range.

func (*Pagination) DefaultLimit

func (p *Pagination) DefaultLimit(dl ...int32) int32

DefaultLimit returns DefaultLimit if limit was not specified otherwise returns either requested or specified one.

func (*Pagination) Descriptor deprecated

func (*Pagination) Descriptor() ([]byte, []int)

Deprecated: Use Pagination.ProtoReflect.Descriptor instead.

func (*Pagination) FirstPage

func (p *Pagination) FirstPage() bool

FirstPage returns true if requested first page

func (*Pagination) GetLimit

func (x *Pagination) GetLimit() int32

func (*Pagination) GetOffset

func (x *Pagination) GetOffset() int32

func (*Pagination) GetPageToken

func (x *Pagination) GetPageToken() string

func (*Pagination) ProtoMessage

func (*Pagination) ProtoMessage()

func (*Pagination) ProtoReflect

func (x *Pagination) ProtoReflect() protoreflect.Message

func (*Pagination) Reset

func (x *Pagination) Reset()

func (*Pagination) String

func (x *Pagination) String() string

type RparenToken

type RparenToken struct {
	TokenBase
}

RparenToken represents right parenthesis.

func (RparenToken) String

func (t RparenToken) String() string

type Searching

type Searching struct {
	Query string `protobuf:"bytes,1,opt,name=query,proto3" json:"query,omitempty"`
	// contains filtered or unexported fields
}

Searching represents search by.

func ParseSearching

func ParseSearching(s string) *Searching

ParseSearching parses raw string that represent search criteria into a Searching data structure.

func (*Searching) Descriptor deprecated

func (*Searching) Descriptor() ([]byte, []int)

Deprecated: Use Searching.ProtoReflect.Descriptor instead.

func (*Searching) GetQuery

func (x *Searching) GetQuery() string

func (*Searching) GoString

func (s *Searching) GoString() string

GoString implements fmt.GoStringer interface return string representation of searching in next form:

func (*Searching) ProtoMessage

func (*Searching) ProtoMessage()

func (*Searching) ProtoReflect

func (x *Searching) ProtoReflect() protoreflect.Message

func (*Searching) Reset

func (x *Searching) Reset()

func (*Searching) String

func (x *Searching) String() string

type SortCriteria

type SortCriteria struct {

	// Tag is a JSON tag.
	Tag   string             `protobuf:"bytes,1,opt,name=tag,proto3" json:"tag,omitempty"`
	Order SortCriteria_Order `protobuf:"varint,2,opt,name=order,proto3,enum=infoblox.api.SortCriteria_Order" json:"order,omitempty"`
	// contains filtered or unexported fields
}

SortCriteria represents sort criteria

func (*SortCriteria) Descriptor deprecated

func (*SortCriteria) Descriptor() ([]byte, []int)

Deprecated: Use SortCriteria.ProtoReflect.Descriptor instead.

func (*SortCriteria) GetOrder

func (x *SortCriteria) GetOrder() SortCriteria_Order

func (*SortCriteria) GetTag

func (x *SortCriteria) GetTag() string

func (SortCriteria) GoString

func (c SortCriteria) GoString() string

GoString implements fmt.GoStringer interface return string representation of a sort criteria in next form: "<tag_name> (ASC|DESC)".

func (SortCriteria) IsAsc

func (c SortCriteria) IsAsc() bool

IsAsc returns true if sort criteria has ascending sort order, otherwise false.

func (SortCriteria) IsDesc

func (c SortCriteria) IsDesc() bool

IsDesc returns true if sort criteria has descending sort order, otherwise false.

func (*SortCriteria) ProtoMessage

func (*SortCriteria) ProtoMessage()

func (*SortCriteria) ProtoReflect

func (x *SortCriteria) ProtoReflect() protoreflect.Message

func (*SortCriteria) Reset

func (x *SortCriteria) Reset()

func (*SortCriteria) String

func (x *SortCriteria) String() string

type SortCriteria_Order

type SortCriteria_Order int32

Order is a sort order.

const (
	// ascending sort order
	SortCriteria_ASC SortCriteria_Order = 0
	// descending sort order
	SortCriteria_DESC SortCriteria_Order = 1
)

func (SortCriteria_Order) Descriptor

func (SortCriteria_Order) Enum

func (SortCriteria_Order) EnumDescriptor deprecated

func (SortCriteria_Order) EnumDescriptor() ([]byte, []int)

Deprecated: Use SortCriteria_Order.Descriptor instead.

func (SortCriteria_Order) Number

func (SortCriteria_Order) String

func (x SortCriteria_Order) String() string

func (SortCriteria_Order) Type

type Sorting

type Sorting struct {
	Criterias []*SortCriteria `protobuf:"bytes,1,rep,name=criterias,proto3" json:"criterias,omitempty"`
	// contains filtered or unexported fields
}

Sorting represents list of sort criterias.

func ParseSorting

func ParseSorting(s string) (*Sorting, error)

ParseSorting parses raw string that represent sort criteria into a Sorting data structure. Provided string is supposed to be in accordance with the sorting collection operator from REST API Syntax. See: https://github.com/lunchroum/atlas-app-toolkit#sorting

func (*Sorting) Descriptor deprecated

func (*Sorting) Descriptor() ([]byte, []int)

Deprecated: Use Sorting.ProtoReflect.Descriptor instead.

func (*Sorting) GetCriterias

func (x *Sorting) GetCriterias() []*SortCriteria

func (Sorting) GoString

func (s Sorting) GoString() string

GoString implements fmt.GoStringer interface Returns string representation of sorting in next form: "<name> (ASC|DESC) [, <tag_name> (ASC|DESC)]"

func (*Sorting) ProtoMessage

func (*Sorting) ProtoMessage()

func (*Sorting) ProtoReflect

func (x *Sorting) ProtoReflect() protoreflect.Message

func (*Sorting) Reset

func (x *Sorting) Reset()

func (*Sorting) String

func (x *Sorting) String() string

type StringArrayCondition

type StringArrayCondition struct {
	FieldPath  []string                  `protobuf:"bytes,1,rep,name=field_path,json=fieldPath,proto3" json:"field_path,omitempty"`
	Values     []string                  `protobuf:"bytes,2,rep,name=values,proto3" json:"values,omitempty"`
	Type       StringArrayCondition_Type `protobuf:"varint,3,opt,name=type,proto3,enum=infoblox.api.StringArrayCondition_Type" json:"type,omitempty"`
	IsNegative bool                      `protobuf:"varint,4,opt,name=is_negative,json=isNegative,proto3" json:"is_negative,omitempty"`
	// contains filtered or unexported fields
}

StringArrayCondition represents a condition with string arrays, e.g. field in ['hello','world'] field_path is a reference to a value of a resource. is_negative is set to true if the condition is negated

func (*StringArrayCondition) Descriptor deprecated

func (*StringArrayCondition) Descriptor() ([]byte, []int)

Deprecated: Use StringArrayCondition.ProtoReflect.Descriptor instead.

func (*StringArrayCondition) Filter

func (c *StringArrayCondition) Filter(obj interface{}) (bool, error)

func (*StringArrayCondition) GetFieldPath

func (x *StringArrayCondition) GetFieldPath() []string

func (*StringArrayCondition) GetIsNegative

func (x *StringArrayCondition) GetIsNegative() bool

func (*StringArrayCondition) GetType

func (*StringArrayCondition) GetValues

func (x *StringArrayCondition) GetValues() []string

func (*StringArrayCondition) ProtoMessage

func (*StringArrayCondition) ProtoMessage()

func (*StringArrayCondition) ProtoReflect

func (x *StringArrayCondition) ProtoReflect() protoreflect.Message

func (*StringArrayCondition) Reset

func (x *StringArrayCondition) Reset()

func (*StringArrayCondition) String

func (x *StringArrayCondition) String() string

type StringArrayCondition_Type

type StringArrayCondition_Type int32
const (
	StringArrayCondition_IN StringArrayCondition_Type = 0
)

func (StringArrayCondition_Type) Descriptor

func (StringArrayCondition_Type) Enum

func (StringArrayCondition_Type) EnumDescriptor deprecated

func (StringArrayCondition_Type) EnumDescriptor() ([]byte, []int)

Deprecated: Use StringArrayCondition_Type.Descriptor instead.

func (StringArrayCondition_Type) Number

func (StringArrayCondition_Type) String

func (x StringArrayCondition_Type) String() string

func (StringArrayCondition_Type) Type

type StringArrayToken

type StringArrayToken struct {
	TokenBase
	Values []string
}

NumberArrayToken represent number array e.g. [1,2,5]

func (StringArrayToken) String

func (t StringArrayToken) String() string

type StringCondition

type StringCondition struct {
	FieldPath  []string             `protobuf:"bytes,1,rep,name=field_path,json=fieldPath,proto3" json:"field_path,omitempty"`
	Value      string               `protobuf:"bytes,2,opt,name=value,proto3" json:"value,omitempty"`
	Type       StringCondition_Type `protobuf:"varint,3,opt,name=type,proto3,enum=infoblox.api.StringCondition_Type" json:"type,omitempty"`
	IsNegative bool                 `protobuf:"varint,4,opt,name=is_negative,json=isNegative,proto3" json:"is_negative,omitempty"`
	// contains filtered or unexported fields
}

StringCondition represents a condition with a string literal, e.g. field == 'string'. field_path is a reference to a value of a resource. value is the string literal. type is a type of the condition. is_negative is set to true if the condition is negated.

func (*StringCondition) Descriptor deprecated

func (*StringCondition) Descriptor() ([]byte, []int)

Deprecated: Use StringCondition.ProtoReflect.Descriptor instead.

func (*StringCondition) Filter

func (c *StringCondition) Filter(obj interface{}) (bool, error)

Filter evaluates string condition against obj. If obj is a proto message, then 'protobuf' tag is used to map FieldPath to obj's struct fields, otherwise 'json' tag is used.

func (*StringCondition) GetFieldPath

func (x *StringCondition) GetFieldPath() []string

func (*StringCondition) GetIsNegative

func (x *StringCondition) GetIsNegative() bool

func (*StringCondition) GetType

func (*StringCondition) GetValue

func (x *StringCondition) GetValue() string

func (*StringCondition) ProtoMessage

func (*StringCondition) ProtoMessage()

func (*StringCondition) ProtoReflect

func (x *StringCondition) ProtoReflect() protoreflect.Message

func (*StringCondition) Reset

func (x *StringCondition) Reset()

func (*StringCondition) String

func (x *StringCondition) String() string

type StringCondition_Type

type StringCondition_Type int32
const (
	StringCondition_EQ    StringCondition_Type = 0
	StringCondition_MATCH StringCondition_Type = 1
	StringCondition_GT    StringCondition_Type = 2
	StringCondition_GE    StringCondition_Type = 3
	StringCondition_LT    StringCondition_Type = 4
	StringCondition_LE    StringCondition_Type = 5
	StringCondition_IEQ   StringCondition_Type = 6
)

func (StringCondition_Type) Descriptor

func (StringCondition_Type) Enum

func (StringCondition_Type) EnumDescriptor deprecated

func (StringCondition_Type) EnumDescriptor() ([]byte, []int)

Deprecated: Use StringCondition_Type.Descriptor instead.

func (StringCondition_Type) Number

func (StringCondition_Type) String

func (x StringCondition_Type) String() string

func (StringCondition_Type) Type

type StringToken

type StringToken struct {
	TokenBase
	Value string
}

StringToken represents a string literal. Value is a value of the literal.

func (StringToken) String

func (t StringToken) String() string

type Token

type Token interface {
	Token()
}

Token is impelemented by all supported tokens in a filtering expression.

type TokenBase

type TokenBase struct{}

TokenBase is used as a base type for all types which are tokens.

func (TokenBase) Token

func (t TokenBase) Token()

Token distinguishes tokens from other types.

type TypeMismatchError

type TypeMismatchError struct {
	ReqType   string
	FieldPath []string
}

TypeMismatchError representes a type that is required for a value under FieldPath.

func (*TypeMismatchError) Error

func (e *TypeMismatchError) Error() string

type UnexpectedSymbolError

type UnexpectedSymbolError struct {
	S   rune
	Pos int
}

UnexpectedSymbolError describes symbol S in position Pos that was not appropriate according to REST API Syntax Specification.

func (*UnexpectedSymbolError) Error

func (e *UnexpectedSymbolError) Error() string

type UnexpectedTokenError

type UnexpectedTokenError struct {
	T Token
}

UnexpectedTokenError describes a token that was not appropriate according to REST API Syntax Specification.

func (*UnexpectedTokenError) Error

func (e *UnexpectedTokenError) Error() string

type UnsupportedOperatorError

type UnsupportedOperatorError struct {
	Type string
	Op   string
}

UnsupportedOperatorError represents an operator that is not supported by a particular field type.

func (*UnsupportedOperatorError) Error

func (e *UnsupportedOperatorError) Error() string

Jump to

Keyboard shortcuts

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