Class: Google::Apis::ComputeAlpha::HttpHeaderMatch
- Inherits:
- 
      Object
      
        - Object
- Google::Apis::ComputeAlpha::HttpHeaderMatch
 
- Includes:
- Google::Apis::Core::Hashable, Google::Apis::Core::JsonObjectSupport
- Defined in:
- generated/google/apis/compute_alpha/classes.rb,
 generated/google/apis/compute_alpha/representations.rb,
 generated/google/apis/compute_alpha/representations.rb
Overview
matchRule criteria for request header matches.
Instance Attribute Summary collapse
- 
  
    
      #exact_match  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    The value should exactly match contents of exactMatch. 
- 
  
    
      #header_name  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    The name of the HTTP header to match. 
- 
  
    
      #invert_match  ⇒ Boolean 
    
    
      (also: #invert_match?)
    
  
  
  
  
    
    
  
  
  
  
  
  
    If set to false, the headerMatch is considered a match if the match criteria above are met. 
- 
  
    
      #prefix_match  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    The value of the header must start with the contents of prefixMatch. 
- 
  
    
      #present_match  ⇒ Boolean 
    
    
      (also: #present_match?)
    
  
  
  
  
    
    
  
  
  
  
  
  
    A header with the contents of headerName must exist. 
- 
  
    
      #range_match  ⇒ Google::Apis::ComputeAlpha::Int64RangeMatch 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    HttpRouteRuleMatch criteria for field values that must stay within the specified integer range. 
- 
  
    
      #regex_match  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    The value of the header must match the regular expression specified in regexMatch. 
- 
  
    
      #suffix_match  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    The value of the header must end with the contents of suffixMatch. 
Instance Method Summary collapse
- 
  
    
      #initialize(**args)  ⇒ HttpHeaderMatch 
    
    
  
  
  
    constructor
  
  
  
  
  
  
  
    A new instance of HttpHeaderMatch. 
- 
  
    
      #update!(**args)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Update properties of this object. 
Constructor Details
#initialize(**args) ⇒ HttpHeaderMatch
Returns a new instance of HttpHeaderMatch.
| 11337 11338 11339 | # File 'generated/google/apis/compute_alpha/classes.rb', line 11337 def initialize(**args) update!(**args) end | 
Instance Attribute Details
#exact_match ⇒ String
The value should exactly match contents of exactMatch.
Only one of exactMatch, prefixMatch, suffixMatch, regexMatch, presentMatch or
rangeMatch must be set.
Corresponds to the JSON property exactMatch
| 11268 11269 11270 | # File 'generated/google/apis/compute_alpha/classes.rb', line 11268 def exact_match @exact_match end | 
#header_name ⇒ String
The name of the HTTP header to match.
For matching against the HTTP request's authority, use a headerMatch with the
header name ":authority".
For matching a request's method, use the headerName ":method".
When the URL map is bound to target gRPC proxy that has validateForProxyless
field set to true, only non-binary user-specified custom metadata and the 
content-type header are supported. The following transport-level headers
cannot be used in header matching rules: :authority, :method, :path, :
scheme, user-agent, accept-encoding, content-encoding, grpc-accept-
encoding, grpc-encoding, grpc-previous-rpc-attempts, grpc-tags-bin, 
grpc-timeout and grpc-trace-bin.
Corresponds to the JSON propertyheaderName`
| 11283 11284 11285 | # File 'generated/google/apis/compute_alpha/classes.rb', line 11283 def header_name @header_name end | 
#invert_match ⇒ Boolean Also known as: invert_match?
If set to false, the headerMatch is considered a match if the match criteria
above are met. If set to true, the headerMatch is considered a match if the
match criteria above are NOT met.
The default setting is false.
Corresponds to the JSON property invertMatch
| 11291 11292 11293 | # File 'generated/google/apis/compute_alpha/classes.rb', line 11291 def invert_match @invert_match end | 
#prefix_match ⇒ String
The value of the header must start with the contents of prefixMatch.
Only one of exactMatch, prefixMatch, suffixMatch, regexMatch, presentMatch or
rangeMatch must be set.
Corresponds to the JSON property prefixMatch
| 11299 11300 11301 | # File 'generated/google/apis/compute_alpha/classes.rb', line 11299 def prefix_match @prefix_match end | 
#present_match ⇒ Boolean Also known as: present_match?
A header with the contents of headerName must exist. The match takes place
whether or not the request's header has a value.
Only one of exactMatch, prefixMatch, suffixMatch, regexMatch, presentMatch or
rangeMatch must be set.
Corresponds to the JSON property presentMatch
| 11307 11308 11309 | # File 'generated/google/apis/compute_alpha/classes.rb', line 11307 def present_match @present_match end | 
#range_match ⇒ Google::Apis::ComputeAlpha::Int64RangeMatch
HttpRouteRuleMatch criteria for field values that must stay within the
specified integer range.
Corresponds to the JSON property rangeMatch
| 11314 11315 11316 | # File 'generated/google/apis/compute_alpha/classes.rb', line 11314 def range_match @range_match end | 
#regex_match ⇒ String
The value of the header must match the regular expression specified in
regexMatch. For regular expression grammar, please see:  en.cppreference.com/w/
cpp/regex/ecmascript
For matching against a port specified in the HTTP request, use a headerMatch
with headerName set to PORT and a regular expression that satisfies the
RFC2616 Host header's port specifier.
Only one of exactMatch, prefixMatch, suffixMatch, regexMatch, presentMatch or
rangeMatch must be set.
Note that regexMatch only applies to Loadbalancers that have their
loadBalancingScheme set to INTERNAL_SELF_MANAGED.
Corresponds to the JSON property regexMatch
| 11328 11329 11330 | # File 'generated/google/apis/compute_alpha/classes.rb', line 11328 def regex_match @regex_match end | 
#suffix_match ⇒ String
The value of the header must end with the contents of suffixMatch.
Only one of exactMatch, prefixMatch, suffixMatch, regexMatch, presentMatch or
rangeMatch must be set.
Corresponds to the JSON property suffixMatch
| 11335 11336 11337 | # File 'generated/google/apis/compute_alpha/classes.rb', line 11335 def suffix_match @suffix_match end | 
Instance Method Details
#update!(**args) ⇒ Object
Update properties of this object
| 11342 11343 11344 11345 11346 11347 11348 11349 11350 11351 | # File 'generated/google/apis/compute_alpha/classes.rb', line 11342 def update!(**args) @exact_match = args[:exact_match] if args.key?(:exact_match) @header_name = args[:header_name] if args.key?(:header_name) @invert_match = args[:invert_match] if args.key?(:invert_match) @prefix_match = args[:prefix_match] if args.key?(:prefix_match) @present_match = args[:present_match] if args.key?(:present_match) @range_match = args[:range_match] if args.key?(:range_match) @regex_match = args[:regex_match] if args.key?(:regex_match) @suffix_match = args[:suffix_match] if args.key?(:suffix_match) end |