Class: Google::Apis::ComputeV1::PathMatcher
- Inherits:
-
Object
- Object
- Google::Apis::ComputeV1::PathMatcher
- Includes:
- Google::Apis::Core::Hashable, Google::Apis::Core::JsonObjectSupport
- Defined in:
- generated/google/apis/compute_v1/classes.rb,
generated/google/apis/compute_v1/representations.rb,
generated/google/apis/compute_v1/representations.rb
Overview
A matcher for the path portion of the URL. The BackendService from the longest- matched rule will serve the URL. If no rule was matched, the default service will be used.
Instance Attribute Summary collapse
-
#default_route_action ⇒ Google::Apis::ComputeV1::HttpRouteAction
defaultRouteAction takes effect when none of the pathRules or routeRules match.
-
#default_service ⇒ String
The full or partial URL to the BackendService resource.
-
#default_url_redirect ⇒ Google::Apis::ComputeV1::HttpRedirectAction
Specifies settings for an HTTP redirect.
-
#description ⇒ String
An optional description of this resource.
-
#header_action ⇒ Google::Apis::ComputeV1::HttpHeaderAction
The request and response header transformations that take effect before the request is passed along to the selected backendService.
-
#name ⇒ String
The name to which this PathMatcher is referred by the HostRule.
-
#path_rules ⇒ Array<Google::Apis::ComputeV1::PathRule>
The list of path rules.
-
#route_rules ⇒ Array<Google::Apis::ComputeV1::HttpRouteRule>
The list of HTTP route rules.
Instance Method Summary collapse
-
#initialize(**args) ⇒ PathMatcher
constructor
A new instance of PathMatcher.
-
#update!(**args) ⇒ Object
Update properties of this object.
Constructor Details
#initialize(**args) ⇒ PathMatcher
Returns a new instance of PathMatcher.
21888 21889 21890 |
# File 'generated/google/apis/compute_v1/classes.rb', line 21888 def initialize(**args) update!(**args) end |
Instance Attribute Details
#default_route_action ⇒ Google::Apis::ComputeV1::HttpRouteAction
defaultRouteAction takes effect when none of the pathRules or routeRules
match. The load balancer performs advanced routing actions like URL rewrites,
header transformations, etc. prior to forwarding the request to the selected
backend. If defaultRouteAction specifies any weightedBackendServices,
defaultService must not be set. Conversely if defaultService is set,
defaultRouteAction cannot contain any weightedBackendServices.
Only one of defaultRouteAction or defaultUrlRedirect must be set.
UrlMaps for external HTTP(S) load balancers support only the urlRewrite action
within a pathMatcher's defaultRouteAction.
Corresponds to the JSON property defaultRouteAction
21823 21824 21825 |
# File 'generated/google/apis/compute_v1/classes.rb', line 21823 def default_route_action @default_route_action end |
#default_service ⇒ String
The full or partial URL to the BackendService resource. This will be used if none of the pathRules or routeRules defined by this PathMatcher are matched. For example, the following are all valid URLs to a BackendService resource:
- https://www.googleapis.com/compute/v1/projects/project/global/ backendServices/backendService
- compute/v1/projects/project/global/backendServices/backendService
- global/backendServices/backendService If defaultRouteAction is additionally specified, advanced routing actions like URL Rewrites, etc. take effect prior to sending the request to the backend. However, if defaultService is specified, defaultRouteAction cannot contain any weightedBackendServices. Conversely, if defaultRouteAction specifies any weightedBackendServices, defaultService must not be specified. Only one of defaultService, defaultUrlRedirect or defaultRouteAction. weightedBackendService must be set. Authorization requires one or more of the following Google IAM permissions on the specified resource default_service:
- compute.backendBuckets.use
- compute.backendServices.use
Corresponds to the JSON property
defaultService
21845 21846 21847 |
# File 'generated/google/apis/compute_v1/classes.rb', line 21845 def default_service @default_service end |
#default_url_redirect ⇒ Google::Apis::ComputeV1::HttpRedirectAction
Specifies settings for an HTTP redirect.
Corresponds to the JSON property defaultUrlRedirect
21850 21851 21852 |
# File 'generated/google/apis/compute_v1/classes.rb', line 21850 def default_url_redirect @default_url_redirect end |
#description ⇒ String
An optional description of this resource. Provide this property when you
create the resource.
Corresponds to the JSON property description
21856 21857 21858 |
# File 'generated/google/apis/compute_v1/classes.rb', line 21856 def description @description end |
#header_action ⇒ Google::Apis::ComputeV1::HttpHeaderAction
The request and response header transformations that take effect before the
request is passed along to the selected backendService.
Corresponds to the JSON property headerAction
21862 21863 21864 |
# File 'generated/google/apis/compute_v1/classes.rb', line 21862 def header_action @header_action end |
#name ⇒ String
The name to which this PathMatcher is referred by the HostRule.
Corresponds to the JSON property name
21867 21868 21869 |
# File 'generated/google/apis/compute_v1/classes.rb', line 21867 def name @name end |
#path_rules ⇒ Array<Google::Apis::ComputeV1::PathRule>
The list of path rules. Use this list instead of routeRules when routing based
on simple path matching is all that's required. The order by which path rules
are specified does not matter. Matches are always done on the longest-path-
first basis.
For example: a pathRule with a path /a/b/c/* will match before /a/b/*
irrespective of the order in which those paths appear in this list.
Within a given pathMatcher, only one of pathRules or routeRules must be set.
Corresponds to the JSON property pathRules
21878 21879 21880 |
# File 'generated/google/apis/compute_v1/classes.rb', line 21878 def path_rules @path_rules end |
#route_rules ⇒ Array<Google::Apis::ComputeV1::HttpRouteRule>
The list of HTTP route rules. Use this list instead of pathRules when advanced
route matching and routing actions are desired. routeRules are evaluated in
order of priority, from the lowest to highest number.
Within a given pathMatcher, you can set only one of pathRules or routeRules.
Corresponds to the JSON property routeRules
21886 21887 21888 |
# File 'generated/google/apis/compute_v1/classes.rb', line 21886 def route_rules @route_rules end |
Instance Method Details
#update!(**args) ⇒ Object
Update properties of this object
21893 21894 21895 21896 21897 21898 21899 21900 21901 21902 |
# File 'generated/google/apis/compute_v1/classes.rb', line 21893 def update!(**args) @default_route_action = args[:default_route_action] if args.key?(:default_route_action) @default_service = args[:default_service] if args.key?(:default_service) @default_url_redirect = args[:default_url_redirect] if args.key?(:default_url_redirect) @description = args[:description] if args.key?(:description) @header_action = args[:header_action] if args.key?(:header_action) @name = args[:name] if args.key?(:name) @path_rules = args[:path_rules] if args.key?(:path_rules) @route_rules = args[:route_rules] if args.key?(:route_rules) end |