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.



24758
24759
24760
# File 'lib/google/apis/compute_alpha/classes.rb', line 24758

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



24747
24748
24749
# File 'lib/google/apis/compute_alpha/classes.rb', line 24747

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)


24756
24757
24758
# File 'lib/google/apis/compute_alpha/classes.rb', line 24756

def filter_match_criteria
  @filter_match_criteria
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



24763
24764
24765
24766
# File 'lib/google/apis/compute_alpha/classes.rb', line 24763

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