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.



30112
30113
30114
# File 'lib/google/apis/compute_alpha/classes.rb', line 30112

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



30101
30102
30103
# File 'lib/google/apis/compute_alpha/classes.rb', line 30101

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)


30110
30111
30112
# File 'lib/google/apis/compute_alpha/classes.rb', line 30110

def filter_match_criteria
  @filter_match_criteria
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



30117
30118
30119
30120
# File 'lib/google/apis/compute_alpha/classes.rb', line 30117

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