Class: Google::Apis::ComputeAlpha::MetadataFilter

Inherits:
Object
  • Object
show all
Includes:
Google::Apis::Core::Hashable, Google::Apis::Core::JsonObjectSupport
Defined in:
lib/google/apis/compute_alpha/classes.rb,
lib/google/apis/compute_alpha/representations.rb,
lib/google/apis/compute_alpha/representations.rb

Overview

Opaque filter criteria used by load balancers to restrict routing configuration to a limited set of load balancing proxies. Proxies and sidecars involved in load balancing would typically present metadata to the load balancers that need to match criteria specified here. If a match takes place, the relevant configuration is made available to those proxies. For each metadataFilter in this list, if its filterMatchCriteria is set to MATCH_ANY, at least one of the filterLabels must match the corresponding label provided in the metadata. If its filterMatchCriteria is set to MATCH_ALL, then all of its filterLabels must match with corresponding labels provided in the metadata. An example for using metadataFilters would be: if load balancing involves Envoys, they receive routing configuration when values in metadataFilters match values supplied in of their XDS requests to loadbalancers.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(**args) ⇒ MetadataFilter

Returns a new instance of MetadataFilter.



25078
25079
25080
# File 'lib/google/apis/compute_alpha/classes.rb', line 25078

def initialize(**args)
   update!(**args)
end

Instance Attribute Details

#filter_labelsArray<Google::Apis::ComputeAlpha::MetadataFilterLabelMatch>

The list of label value pairs that must match labels in the provided metadata based on filterMatchCriteria This list must not be empty and can have at the most 64 entries. Corresponds to the JSON property filterLabels



25067
25068
25069
# File 'lib/google/apis/compute_alpha/classes.rb', line 25067

def filter_labels
  @filter_labels
end

#filter_match_criteriaString

Specifies how individual filter label matches within the list of filterLabels and contributes toward the overall metadataFilter match. Supported values are:

  • MATCH_ANY: at least one of the filterLabels must have a matching label in the provided metadata. - MATCH_ALL: all filterLabels must have matching labels in the provided metadata. Corresponds to the JSON property filterMatchCriteria

Returns:

  • (String)


25076
25077
25078
# File 'lib/google/apis/compute_alpha/classes.rb', line 25076

def filter_match_criteria
  @filter_match_criteria
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



25083
25084
25085
25086
# File 'lib/google/apis/compute_alpha/classes.rb', line 25083

def update!(**args)
  @filter_labels = args[:filter_labels] if args.key?(:filter_labels)
  @filter_match_criteria = args[:filter_match_criteria] if args.key?(:filter_match_criteria)
end