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.



26146
26147
26148
# File 'lib/google/apis/compute_alpha/classes.rb', line 26146

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



26135
26136
26137
# File 'lib/google/apis/compute_alpha/classes.rb', line 26135

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)


26144
26145
26146
# File 'lib/google/apis/compute_alpha/classes.rb', line 26144

def filter_match_criteria
  @filter_match_criteria
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



26151
26152
26153
26154
# File 'lib/google/apis/compute_alpha/classes.rb', line 26151

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