mirror of
https://github.com/ansible-collections/google.cloud.git
synced 2025-04-05 02:10:27 -07:00
Updating the maintainers guide with updated intructions from Ansible engineers. Fixing linting issues, and adding the linter as a GitHub workflow to ensure there are no regressions.
4984 lines
228 KiB
Python
4984 lines
228 KiB
Python
#!/usr/bin/python
|
|
# -*- coding: utf-8 -*-
|
|
#
|
|
# Copyright (C) 2017 Google
|
|
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
|
|
# ----------------------------------------------------------------------------
|
|
#
|
|
# *** AUTO GENERATED CODE *** Type: MMv1 ***
|
|
#
|
|
# ----------------------------------------------------------------------------
|
|
#
|
|
# This file is automatically generated by Magic Modules and manual
|
|
# changes will be clobbered when the file is regenerated.
|
|
#
|
|
# Please read more about how to change this file at
|
|
# https://www.github.com/GoogleCloudPlatform/magic-modules
|
|
#
|
|
# ----------------------------------------------------------------------------
|
|
|
|
from __future__ import absolute_import, division, print_function
|
|
|
|
__metaclass__ = type
|
|
|
|
################################################################################
|
|
# Documentation
|
|
################################################################################
|
|
|
|
ANSIBLE_METADATA = {'metadata_version': '1.1', 'status': ["preview"], 'supported_by': 'community'}
|
|
|
|
DOCUMENTATION = '''
|
|
---
|
|
module: gcp_compute_region_url_map
|
|
description:
|
|
- UrlMaps are used to route requests to a backend service based on rules that you
|
|
define for the host and path of an incoming URL.
|
|
short_description: Creates a GCP RegionUrlMap
|
|
author: Google Inc. (@googlecloudplatform)
|
|
requirements:
|
|
- python >= 2.6
|
|
- requests >= 2.18.4
|
|
- google-auth >= 1.3.0
|
|
options:
|
|
state:
|
|
description:
|
|
- Whether the given object should exist in GCP
|
|
choices:
|
|
- present
|
|
- absent
|
|
default: present
|
|
type: str
|
|
default_service:
|
|
description:
|
|
- The full or partial URL of the defaultService resource to which traffic is directed
|
|
if none of the hostRules match. 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 routeAction specifies
|
|
any weightedBackendServices, service must not be specified. Only one of defaultService,
|
|
defaultUrlRedirect or defaultRouteAction.weightedBackendService must be set.
|
|
- 'This field represents a link to a RegionBackendService resource in GCP. It
|
|
can be specified in two ways. First, you can place a dictionary with key ''selfLink''
|
|
and value of your resource''s selfLink Alternatively, you can add `register:
|
|
name-of-resource` to a gcp_compute_region_backend_service task and then set
|
|
this default_service field to "{{ name-of-resource }}"'
|
|
required: false
|
|
type: dict
|
|
description:
|
|
description:
|
|
- An optional description of this resource. Provide this property when you create
|
|
the resource.
|
|
required: false
|
|
type: str
|
|
host_rules:
|
|
description:
|
|
- The list of HostRules to use against the URL.
|
|
elements: dict
|
|
required: false
|
|
type: list
|
|
suboptions:
|
|
description:
|
|
description:
|
|
- An optional description of this HostRule. Provide this property when you
|
|
create the resource.
|
|
required: false
|
|
type: str
|
|
hosts:
|
|
description:
|
|
- The list of host patterns to match. They must be valid hostnames, except
|
|
* will match any string of ([a-z0-9-.]*). In that case, * must be the first
|
|
character and must be followed in the pattern by either - or .
|
|
elements: str
|
|
required: true
|
|
type: list
|
|
path_matcher:
|
|
description:
|
|
- The name of the PathMatcher to use to match the path portion of the URL
|
|
if the hostRule matches the URL's host portion.
|
|
required: true
|
|
type: str
|
|
name:
|
|
description:
|
|
- Name of the resource. Provided by the client when the resource is created. The
|
|
name must be 1-63 characters long, and comply with RFC1035. Specifically, the
|
|
name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?`
|
|
which means the first character must be a lowercase letter, and all following
|
|
characters must be a dash, lowercase letter, or digit, except the last character,
|
|
which cannot be a dash.
|
|
required: true
|
|
type: str
|
|
path_matchers:
|
|
description:
|
|
- The list of named PathMatchers to use against the URL.
|
|
elements: dict
|
|
required: false
|
|
type: list
|
|
suboptions:
|
|
default_service:
|
|
description:
|
|
- A reference to a RegionBackendService resource. This will be used if none
|
|
of the pathRules defined by this PathMatcher is matched by the URL's path
|
|
portion.
|
|
- 'This field represents a link to a RegionBackendService resource in GCP.
|
|
It can be specified in two ways. First, you can place a dictionary with
|
|
key ''selfLink'' and value of your resource''s selfLink Alternatively, you
|
|
can add `register: name-of-resource` to a gcp_compute_region_backend_service
|
|
task and then set this default_service field to "{{ name-of-resource }}"'
|
|
required: false
|
|
type: dict
|
|
description:
|
|
description:
|
|
- An optional description of this resource.
|
|
required: false
|
|
type: str
|
|
name:
|
|
description:
|
|
- The name to which this PathMatcher is referred by the HostRule.
|
|
required: true
|
|
type: str
|
|
route_rules:
|
|
description:
|
|
- 'The list of ordered HTTP route rules. Use this list instead of pathRules
|
|
when advanced route matching and routing actions are desired. The order
|
|
of specifying routeRules matters: the first rule that matches will cause
|
|
its specified routing action to take effect. Within a given pathMatcher,
|
|
only one of pathRules or routeRules must be set. routeRules are not supported
|
|
in UrlMaps intended for External load balancers.'
|
|
elements: dict
|
|
required: false
|
|
type: list
|
|
suboptions:
|
|
priority:
|
|
description:
|
|
- For routeRules within a given pathMatcher, priority determines the order
|
|
in which load balancer will interpret routeRules. RouteRules are evaluated
|
|
in order of priority, from the lowest to highest number. The priority
|
|
of a rule decreases as its number increases (1, 2, 3, N+1). The first
|
|
rule that matches the request is applied.
|
|
- You cannot configure two or more routeRules with the same priority.
|
|
- Priority for each rule must be set to a number between 0 and 2147483647
|
|
inclusive.
|
|
- Priority numbers can have gaps, which enable you to add or remove rules
|
|
in the future without affecting the rest of the rules. For example,
|
|
1, 2, 3, 4, 5, 9, 12, 16 is a valid series of priority numbers to which
|
|
you could add rules numbered from 6 to 8, 10 to 11, and 13 to 15 in
|
|
the future without any impact on existing rules.
|
|
required: true
|
|
type: int
|
|
service:
|
|
description:
|
|
- The region backend service resource to which traffic is directed if
|
|
this rule is matched. If routeAction is additionally specified, advanced
|
|
routing actions like URL Rewrites, etc. take effect prior to sending
|
|
the request to the backend. However, if service is specified, routeAction
|
|
cannot contain any weightedBackendService s. Conversely, if routeAction
|
|
specifies any weightedBackendServices, service must not be specified.
|
|
Only one of urlRedirect, service or routeAction.weightedBackendService
|
|
must be set.
|
|
- 'This field represents a link to a RegionBackendService resource in
|
|
GCP. It can be specified in two ways. First, you can place a dictionary
|
|
with key ''selfLink'' and value of your resource''s selfLink Alternatively,
|
|
you can add `register: name-of-resource` to a gcp_compute_region_backend_service
|
|
task and then set this service field to "{{ name-of-resource }}"'
|
|
required: false
|
|
type: dict
|
|
header_action:
|
|
description:
|
|
- Specifies changes to request and response headers that need to take
|
|
effect for the selected backendService. The headerAction specified here
|
|
are applied before the matching pathMatchers[].headerAction and after
|
|
pathMatchers[].routeRules[].r outeAction.weightedBackendService.backendServiceWeightAction[].headerAction
|
|
.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
request_headers_to_add:
|
|
description:
|
|
- Headers to add to a matching request prior to forwarding the request
|
|
to the backendService.
|
|
elements: dict
|
|
required: false
|
|
type: list
|
|
suboptions:
|
|
header_name:
|
|
description:
|
|
- The name of the header.
|
|
required: true
|
|
type: str
|
|
header_value:
|
|
description:
|
|
- The value of the header to add.
|
|
required: true
|
|
type: str
|
|
replace:
|
|
description:
|
|
- If false, headerValue is appended to any values that already
|
|
exist for the header. If true, headerValue is set for the header,
|
|
discarding any values that were set for that header.
|
|
required: true
|
|
type: bool
|
|
request_headers_to_remove:
|
|
description:
|
|
- A list of header names for headers that need to be removed from
|
|
the request prior to forwarding the request to the backendService.
|
|
elements: str
|
|
required: false
|
|
type: list
|
|
response_headers_to_add:
|
|
description:
|
|
- Headers to add the response prior to sending the response back to
|
|
the client.
|
|
elements: dict
|
|
required: false
|
|
type: list
|
|
suboptions:
|
|
header_name:
|
|
description:
|
|
- The name of the header.
|
|
required: true
|
|
type: str
|
|
header_value:
|
|
description:
|
|
- The value of the header to add.
|
|
required: true
|
|
type: str
|
|
replace:
|
|
description:
|
|
- If false, headerValue is appended to any values that already
|
|
exist for the header. If true, headerValue is set for the header,
|
|
discarding any values that were set for that header.
|
|
required: true
|
|
type: bool
|
|
response_headers_to_remove:
|
|
description:
|
|
- A list of header names for headers that need to be removed from
|
|
the response prior to sending the response back to the client.
|
|
elements: str
|
|
required: false
|
|
type: list
|
|
match_rules:
|
|
description:
|
|
- The rules for determining a match.
|
|
elements: dict
|
|
required: false
|
|
type: list
|
|
suboptions:
|
|
full_path_match:
|
|
description:
|
|
- For satisfying the matchRule condition, the path of the request
|
|
must exactly match the value specified in fullPathMatch after removing
|
|
any query parameters and anchor that may be part of the original
|
|
URL. FullPathMatch must be between 1 and 1024 characters. Only one
|
|
of prefixMatch, fullPathMatch or regexMatch must be specified.
|
|
required: false
|
|
type: str
|
|
header_matches:
|
|
description:
|
|
- Specifies a list of header match criteria, all of which must match
|
|
corresponding headers in the request.
|
|
elements: dict
|
|
required: false
|
|
type: list
|
|
suboptions:
|
|
exact_match:
|
|
description:
|
|
- The value should exactly match contents of exactMatch. Only
|
|
one of exactMatch, prefixMatch, suffixMatch, regexMatch, presentMatch
|
|
or rangeMatch must be set.
|
|
required: false
|
|
type: str
|
|
header_name:
|
|
description:
|
|
- 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".
|
|
required: true
|
|
type: str
|
|
invert_match:
|
|
description:
|
|
- 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.
|
|
Defaults to false.
|
|
required: false
|
|
default: 'false'
|
|
type: bool
|
|
prefix_match:
|
|
description:
|
|
- 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.
|
|
required: false
|
|
type: str
|
|
present_match:
|
|
description:
|
|
- A header with the contents of headerName must exist. The match
|
|
takes place whether or not the request's header has a value
|
|
or not. Only one of exactMatch, prefixMatch, suffixMatch, regexMatch,
|
|
presentMatch or rangeMatch must be set.
|
|
required: false
|
|
type: bool
|
|
range_match:
|
|
description:
|
|
- The header value must be an integer and its value must be in
|
|
the range specified in rangeMatch. If the header does not contain
|
|
an integer, number or is empty, the match fails. For example
|
|
for a range [-5, 0] * -3 will match * 0 will not match * 0.25
|
|
will not match * -3someString will not match.
|
|
- Only one of exactMatch, prefixMatch, suffixMatch, regexMatch,
|
|
presentMatch or rangeMatch must be set.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
range_end:
|
|
description:
|
|
- The end of the range (exclusive).
|
|
required: true
|
|
type: int
|
|
range_start:
|
|
description:
|
|
- The start of the range (inclusive).
|
|
required: true
|
|
type: int
|
|
regex_match:
|
|
description:
|
|
- '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.
|
|
required: false
|
|
type: str
|
|
suffix_match:
|
|
description:
|
|
- 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.
|
|
required: false
|
|
type: str
|
|
ignore_case:
|
|
description:
|
|
- Specifies that prefixMatch and fullPathMatch matches are case sensitive.
|
|
- Defaults to false.
|
|
required: false
|
|
default: 'false'
|
|
type: bool
|
|
metadata_filters:
|
|
description:
|
|
- Opaque filter criteria used by Loadbalancer to restrict routing
|
|
configuration to a limited set xDS compliant clients. In their xDS
|
|
requests to Loadbalancer, xDS clients present node metadata. If
|
|
a match takes place, the relevant routing 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 in
|
|
the provided metadata. metadataFilters specified here can be overrides
|
|
those specified in ForwardingRule that refers to this UrlMap. metadataFilters
|
|
only applies to Loadbalancers that have their loadBalancingScheme
|
|
set to INTERNAL_SELF_MANAGED.
|
|
elements: dict
|
|
required: false
|
|
type: list
|
|
suboptions:
|
|
filter_labels:
|
|
description:
|
|
- 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.
|
|
elements: dict
|
|
required: true
|
|
type: list
|
|
suboptions:
|
|
name:
|
|
description:
|
|
- Name of metadata label. The name can have a maximum length
|
|
of 1024 characters and must be at least 1 character long.
|
|
required: true
|
|
type: str
|
|
value:
|
|
description:
|
|
- The value of the label must match the specified value. value
|
|
can have a maximum length of 1024 characters.
|
|
required: true
|
|
type: str
|
|
filter_match_criteria:
|
|
description:
|
|
- 'Specifies how individual filterLabel matches within the list
|
|
of filterLabels contribute towards 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."
|
|
- 'Some valid choices include: "MATCH_ALL", "MATCH_ANY"'
|
|
required: true
|
|
type: str
|
|
prefix_match:
|
|
description:
|
|
- For satisfying the matchRule condition, the request's path must
|
|
begin with the specified prefixMatch. prefixMatch must begin with
|
|
a /. The value must be between 1 and 1024 characters. Only one of
|
|
prefixMatch, fullPathMatch or regexMatch must be specified.
|
|
required: false
|
|
type: str
|
|
query_parameter_matches:
|
|
description:
|
|
- Specifies a list of query parameter match criteria, all of which
|
|
must match corresponding query parameters in the request.
|
|
elements: dict
|
|
required: false
|
|
type: list
|
|
suboptions:
|
|
exact_match:
|
|
description:
|
|
- The queryParameterMatch matches if the value of the parameter
|
|
exactly matches the contents of exactMatch. Only one of presentMatch,
|
|
exactMatch and regexMatch must be set.
|
|
required: false
|
|
type: str
|
|
name:
|
|
description:
|
|
- The name of the query parameter to match. The query parameter
|
|
must exist in the request, in the absence of which the request
|
|
match fails.
|
|
required: true
|
|
type: str
|
|
present_match:
|
|
description:
|
|
- Specifies that the queryParameterMatch matches if the request
|
|
contains the query parameter, irrespective of whether the parameter
|
|
has a value or not. Only one of presentMatch, exactMatch and
|
|
regexMatch must be set.
|
|
required: false
|
|
type: bool
|
|
regex_match:
|
|
description:
|
|
- The queryParameterMatch matches if the value of the parameter
|
|
matches the regular expression specified by regexMatch. For
|
|
the regular expression grammar, please see en.cppreference.com/w/cpp/regex/ecmascript
|
|
Only one of presentMatch, exactMatch and regexMatch must be
|
|
set.
|
|
required: false
|
|
type: str
|
|
regex_match:
|
|
description:
|
|
- For satisfying the matchRule condition, the path of the request
|
|
must satisfy the regular expression specified in regexMatch after
|
|
removing any query parameters and anchor supplied with the original
|
|
URL. For regular expression grammar please see en.cppreference.com/w/cpp/regex/ecmascript
|
|
Only one of prefixMatch, fullPathMatch or regexMatch must be specified.
|
|
required: false
|
|
type: str
|
|
route_action:
|
|
description:
|
|
- In response to a matching matchRule, the load balancer performs advanced
|
|
routing actions like URL rewrites, header transformations, etc. prior
|
|
to forwarding the request to the selected backend. If routeAction specifies
|
|
any weightedBackendServices, service must not be set. Conversely if
|
|
service is set, routeAction cannot contain any weightedBackendServices.
|
|
Only one of routeAction or urlRedirect must be set.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
cors_policy:
|
|
description:
|
|
- The specification for allowing client side cross-origin requests.
|
|
Please see W3C Recommendation for Cross Origin Resource Sharing
|
|
.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
allow_credentials:
|
|
description:
|
|
- In response to a preflight request, setting this to true indicates
|
|
that the actual request can include user credentials. This translates
|
|
to the Access- Control-Allow-Credentials header. Defaults to
|
|
false.
|
|
required: false
|
|
default: 'false'
|
|
type: bool
|
|
allow_headers:
|
|
description:
|
|
- Specifies the content for the Access-Control-Allow-Headers header.
|
|
elements: str
|
|
required: false
|
|
type: list
|
|
allow_methods:
|
|
description:
|
|
- Specifies the content for the Access-Control-Allow-Methods header.
|
|
elements: str
|
|
required: false
|
|
type: list
|
|
allow_origin_regexes:
|
|
description:
|
|
- Specifies the regular expression patterns that match allowed
|
|
origins. For regular expression grammar please see en.cppreference.com/w/cpp/regex/ecmascript
|
|
An origin is allowed if it matches either allow_origins or allow_origin_regex.
|
|
elements: str
|
|
required: false
|
|
type: list
|
|
allow_origins:
|
|
description:
|
|
- Specifies the list of origins that will be allowed to do CORS
|
|
requests. An origin is allowed if it matches either allow_origins
|
|
or allow_origin_regex.
|
|
elements: str
|
|
required: false
|
|
type: list
|
|
disabled:
|
|
description:
|
|
- If true, specifies the CORS policy is disabled.
|
|
- which indicates that the CORS policy is in effect. Defaults
|
|
to false.
|
|
required: false
|
|
default: 'false'
|
|
type: bool
|
|
expose_headers:
|
|
description:
|
|
- Specifies the content for the Access-Control-Expose-Headers
|
|
header.
|
|
elements: str
|
|
required: false
|
|
type: list
|
|
max_age:
|
|
description:
|
|
- Specifies how long the results of a preflight request can be
|
|
cached. This translates to the content for the Access-Control-Max-Age
|
|
header.
|
|
required: false
|
|
type: int
|
|
fault_injection_policy:
|
|
description:
|
|
- The specification for fault injection introduced into traffic to
|
|
test the resiliency of clients to backend service failure. As part
|
|
of fault injection, when clients send requests to a backend service,
|
|
delays can be introduced by Loadbalancer on a percentage of requests
|
|
before sending those request to the backend service. Similarly requests
|
|
from clients can be aborted by the Loadbalancer for a percentage
|
|
of requests. timeout and retry_policy will be ignored by clients
|
|
that are configured with a fault_injection_policy.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
abort:
|
|
description:
|
|
- The specification for how client requests are aborted as part
|
|
of fault injection.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
http_status:
|
|
description:
|
|
- The HTTP status code used to abort the request. The value
|
|
must be between 200 and 599 inclusive.
|
|
required: false
|
|
type: int
|
|
percentage:
|
|
description:
|
|
- The percentage of traffic (connections/operations/requests)
|
|
which will be aborted as part of fault injection. The value
|
|
must be between 0.0 and 100.0 inclusive.
|
|
required: false
|
|
type: str
|
|
delay:
|
|
description:
|
|
- The specification for how client requests are delayed as part
|
|
of fault injection, before being sent to a backend service.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
fixed_delay:
|
|
description:
|
|
- Specifies the value of the fixed delay interval.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
nanos:
|
|
description:
|
|
- Span of time that's a fraction of a second at nanosecond
|
|
resolution. Durations less than one second are represented
|
|
with a 0 `seconds` field and a positive `nanos` field.
|
|
Must be from 0 to 999,999,999 inclusive.
|
|
required: false
|
|
type: int
|
|
seconds:
|
|
description:
|
|
- Span of time at a resolution of a second. Must be from
|
|
0 to 315,576,000,000 inclusive.
|
|
required: true
|
|
type: str
|
|
percentage:
|
|
description:
|
|
- The percentage of traffic (connections/operations/requests)
|
|
on which delay will be introduced as part of fault injection.
|
|
The value must be between 0.0 and 100.0 inclusive.
|
|
required: false
|
|
type: str
|
|
request_mirror_policy:
|
|
description:
|
|
- Specifies the policy on how requests intended for the route's backends
|
|
are shadowed to a separate mirrored backend service. Loadbalancer
|
|
does not wait for responses from the shadow service. Prior to sending
|
|
traffic to the shadow service, the host / authority header is suffixed
|
|
with -shadow.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
backend_service:
|
|
description:
|
|
- The RegionBackendService resource being mirrored to.
|
|
- 'This field represents a link to a RegionBackendService resource
|
|
in GCP. It can be specified in two ways. First, you can place
|
|
a dictionary with key ''selfLink'' and value of your resource''s
|
|
selfLink Alternatively, you can add `register: name-of-resource`
|
|
to a gcp_compute_region_backend_service task and then set this
|
|
backend_service field to "{{ name-of-resource }}"'
|
|
required: true
|
|
type: dict
|
|
retry_policy:
|
|
description:
|
|
- Specifies the retry policy associated with this route.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
num_retries:
|
|
description:
|
|
- Specifies the allowed number retries. This number must be >
|
|
0.
|
|
required: true
|
|
type: int
|
|
per_try_timeout:
|
|
description:
|
|
- Specifies a non-zero timeout per retry attempt.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
nanos:
|
|
description:
|
|
- Span of time that's a fraction of a second at nanosecond
|
|
resolution. Durations less than one second are represented
|
|
with a 0 `seconds` field and a positive `nanos` field. Must
|
|
be from 0 to 999,999,999 inclusive.
|
|
required: false
|
|
type: int
|
|
seconds:
|
|
description:
|
|
- Span of time at a resolution of a second. Must be from 0
|
|
to 315,576,000,000 inclusive.
|
|
required: true
|
|
type: str
|
|
retry_conditions:
|
|
description:
|
|
- 'Specifies one or more conditions when this retry rule applies.
|
|
Valid values are: * 5xx: Loadbalancer will attempt a retry if
|
|
the backend service responds with any 5xx response code, or
|
|
if the backend service does not respond at all, example: disconnects,
|
|
reset, read timeout, connection failure, and refused streams.'
|
|
- "* gateway-error: Similar to 5xx, but only applies to response
|
|
codes 502, 503 or 504."
|
|
- "* connect-failure: Loadbalancer will retry on failures connecting
|
|
to backend services, for example due to connection timeouts."
|
|
- "* retriable-4xx: Loadbalancer will retry for retriable 4xx
|
|
response codes."
|
|
- Currently the only retriable error supported is 409.
|
|
- "* refused-stream: Loadbalancer will retry if the backend service
|
|
resets the stream with a REFUSED_STREAM error code. This reset
|
|
type indicates that it is safe to retry."
|
|
- "* cancelled: Loadbalancer will retry if the gRPC status code
|
|
in the response header is set to cancelled * deadline-exceeded:
|
|
Loadbalancer will retry if the gRPC status code in the response
|
|
header is set to deadline-exceeded * resource-exhausted: Loadbalancer
|
|
will retry if the gRPC status code in the response header is
|
|
set to resource-exhausted * unavailable: Loadbalancer will retry
|
|
if the gRPC status code in the response header is set to unavailable
|
|
."
|
|
elements: str
|
|
required: false
|
|
type: list
|
|
timeout:
|
|
description:
|
|
- Specifies the timeout for the selected route. Timeout is computed
|
|
from the time the request is has been fully processed (i.e. end-of-stream)
|
|
up until the response has been completely processed. Timeout includes
|
|
all retries. If not specified, the default value is 15 seconds.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
nanos:
|
|
description:
|
|
- Span of time that's a fraction of a second at nanosecond resolution.
|
|
Durations less than one second are represented with a 0 `seconds`
|
|
field and a positive `nanos` field. Must be from 0 to 999,999,999
|
|
inclusive.
|
|
required: false
|
|
type: int
|
|
seconds:
|
|
description:
|
|
- Span of time at a resolution of a second. Must be from 0 to
|
|
315,576,000,000 inclusive.
|
|
required: true
|
|
type: str
|
|
url_rewrite:
|
|
description:
|
|
- The spec to modify the URL of the request, prior to forwarding the
|
|
request to the matched service .
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
host_rewrite:
|
|
description:
|
|
- Prior to forwarding the request to the selected service, the
|
|
request's host header is replaced with contents of hostRewrite.
|
|
The value must be between 1 and 255 characters.
|
|
required: false
|
|
type: str
|
|
path_prefix_rewrite:
|
|
description:
|
|
- Prior to forwarding the request to the selected backend service,
|
|
the matching portion of the request's path is replaced by pathPrefixRewrite.
|
|
The value must be between 1 and 1024 characters.
|
|
required: false
|
|
type: str
|
|
weighted_backend_services:
|
|
description:
|
|
- A list of weighted backend services to send traffic to when a route
|
|
match occurs. The weights determine the fraction of traffic that
|
|
flows to their corresponding backend service. If all traffic needs
|
|
to go to a single backend service, there must be one weightedBackendService
|
|
with weight set to a non 0 number. Once a backendService is identified
|
|
and before forwarding the request to the backend service, advanced
|
|
routing actions like Url rewrites and header transformations are
|
|
applied depending on additional settings specified in this HttpRouteAction.
|
|
elements: dict
|
|
required: false
|
|
type: list
|
|
suboptions:
|
|
backend_service:
|
|
description:
|
|
- The default RegionBackendService resource. Before forwarding
|
|
the request to backendService, the loadbalancer applies any
|
|
relevant headerActions specified as part of this backendServiceWeight.
|
|
- 'This field represents a link to a RegionBackendService resource
|
|
in GCP. It can be specified in two ways. First, you can place
|
|
a dictionary with key ''selfLink'' and value of your resource''s
|
|
selfLink Alternatively, you can add `register: name-of-resource`
|
|
to a gcp_compute_region_backend_service task and then set this
|
|
backend_service field to "{{ name-of-resource }}"'
|
|
required: true
|
|
type: dict
|
|
header_action:
|
|
description:
|
|
- Specifies changes to request and response headers that need
|
|
to take effect for the selected backendService. headerAction
|
|
specified here take effect before headerAction in the enclosing
|
|
HttpRouteRule, PathMatcher and UrlMap.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
request_headers_to_add:
|
|
description:
|
|
- Headers to add to a matching request prior to forwarding
|
|
the request to the backendService.
|
|
elements: dict
|
|
required: false
|
|
type: list
|
|
suboptions:
|
|
header_name:
|
|
description:
|
|
- The name of the header.
|
|
required: true
|
|
type: str
|
|
header_value:
|
|
description:
|
|
- The value of the header to add.
|
|
required: true
|
|
type: str
|
|
replace:
|
|
description:
|
|
- If false, headerValue is appended to any values that
|
|
already exist for the header. If true, headerValue is
|
|
set for the header, discarding any values that were
|
|
set for that header.
|
|
required: true
|
|
type: bool
|
|
request_headers_to_remove:
|
|
description:
|
|
- A list of header names for headers that need to be removed
|
|
from the request prior to forwarding the request to the
|
|
backendService.
|
|
elements: str
|
|
required: false
|
|
type: list
|
|
response_headers_to_add:
|
|
description:
|
|
- Headers to add the response prior to sending the response
|
|
back to the client.
|
|
elements: dict
|
|
required: false
|
|
type: list
|
|
suboptions:
|
|
header_name:
|
|
description:
|
|
- The name of the header.
|
|
required: true
|
|
type: str
|
|
header_value:
|
|
description:
|
|
- The value of the header to add.
|
|
required: true
|
|
type: str
|
|
replace:
|
|
description:
|
|
- If false, headerValue is appended to any values that
|
|
already exist for the header. If true, headerValue is
|
|
set for the header, discarding any values that were
|
|
set for that header.
|
|
required: true
|
|
type: bool
|
|
response_headers_to_remove:
|
|
description:
|
|
- A list of header names for headers that need to be removed
|
|
from the response prior to sending the response back to
|
|
the client.
|
|
elements: str
|
|
required: false
|
|
type: list
|
|
weight:
|
|
description:
|
|
- Specifies the fraction of traffic sent to backendService, computed
|
|
as weight / (sum of all weightedBackendService weights in routeAction)
|
|
. The selection of a backend service is determined only for
|
|
new traffic. Once a user's request has been directed to a backendService,
|
|
subsequent requests will be sent to the same backendService
|
|
as determined by the BackendService's session affinity policy.
|
|
- The value must be between 0 and 1000 .
|
|
required: true
|
|
type: int
|
|
url_redirect:
|
|
description:
|
|
- When this rule is matched, the request is redirected to a URL specified
|
|
by urlRedirect. If urlRedirect is specified, service or routeAction
|
|
must not be set.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
host_redirect:
|
|
description:
|
|
- The host that will be used in the redirect response instead of the
|
|
one that was supplied in the request. The value must be between
|
|
1 and 255 characters.
|
|
required: false
|
|
type: str
|
|
https_redirect:
|
|
description:
|
|
- If set to true, the URL scheme in the redirected request is set
|
|
to https.
|
|
- If set to false, the URL scheme of the redirected request will remain
|
|
the same as that of the request. This must only be set for UrlMaps
|
|
used in TargetHttpProxys. Setting this true for TargetHttpsProxy
|
|
is not permitted. The default is set to false.
|
|
required: false
|
|
default: 'false'
|
|
type: bool
|
|
path_redirect:
|
|
description:
|
|
- The path that will be used in the redirect response instead of the
|
|
one that was supplied in the request. pathRedirect cannot be supplied
|
|
together with prefixRedirect. Supply one alone or neither. If neither
|
|
is supplied, the path of the original request will be used for the
|
|
redirect.
|
|
- The value must be between 1 and 1024 characters.
|
|
required: false
|
|
type: str
|
|
prefix_redirect:
|
|
description:
|
|
- The prefix that replaces the prefixMatch specified in the HttpRouteRuleMatch,
|
|
retaining the remaining portion of the URL before redirecting the
|
|
request. prefixRedirect cannot be supplied together with pathRedirect.
|
|
Supply one alone or neither. If neither is supplied, the path of
|
|
the original request will be used for the redirect. The value must
|
|
be between 1 and 1024 characters.
|
|
required: false
|
|
type: str
|
|
redirect_response_code:
|
|
description:
|
|
- 'The HTTP Status code to use for this RedirectAction. Supported
|
|
values are: * MOVED_PERMANENTLY_DEFAULT, which is the default value
|
|
and corresponds to 301.'
|
|
- "* FOUND, which corresponds to 302."
|
|
- "* SEE_OTHER which corresponds to 303."
|
|
- "* TEMPORARY_REDIRECT, which corresponds to 307. In this case, the
|
|
request method will be retained."
|
|
- "* PERMANENT_REDIRECT, which corresponds to 308. In this case, the
|
|
request method will be retained."
|
|
- 'Some valid choices include: "FOUND", "MOVED_PERMANENTLY_DEFAULT",
|
|
"PERMANENT_REDIRECT", "SEE_OTHER", "TEMPORARY_REDIRECT"'
|
|
required: false
|
|
type: str
|
|
strip_query:
|
|
description:
|
|
- If set to true, any accompanying query portion of the original URL
|
|
is removed prior to redirecting the request. If set to false, the
|
|
query portion of the original URL is retained. The default value
|
|
is false.
|
|
required: false
|
|
default: 'false'
|
|
type: bool
|
|
path_rules:
|
|
description:
|
|
- '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.'
|
|
elements: dict
|
|
required: false
|
|
type: list
|
|
suboptions:
|
|
service:
|
|
description:
|
|
- The region backend service resource to which traffic is directed if
|
|
this rule is matched. If routeAction is additionally specified, advanced
|
|
routing actions like URL Rewrites, etc. take effect prior to sending
|
|
the request to the backend. However, if service is specified, routeAction
|
|
cannot contain any weightedBackendService s. Conversely, if routeAction
|
|
specifies any weightedBackendServices, service must not be specified.
|
|
Only one of urlRedirect, service or routeAction.weightedBackendService
|
|
must be set.
|
|
- 'This field represents a link to a RegionBackendService resource in
|
|
GCP. It can be specified in two ways. First, you can place a dictionary
|
|
with key ''selfLink'' and value of your resource''s selfLink Alternatively,
|
|
you can add `register: name-of-resource` to a gcp_compute_region_backend_service
|
|
task and then set this service field to "{{ name-of-resource }}"'
|
|
required: false
|
|
type: dict
|
|
paths:
|
|
description:
|
|
- 'The list of path patterns to match. Each must start with / and the
|
|
only place a \\ * is allowed is at the end following a /. The string fed
|
|
to the path matcher does not include any text after the first ? or #,
|
|
and those chars are not allowed here.'
|
|
elements: str
|
|
required: true
|
|
type: list
|
|
route_action:
|
|
description:
|
|
- In response to a matching path, the load balancer performs advanced
|
|
routing actions like URL rewrites, header transformations, etc. prior
|
|
to forwarding the request to the selected backend. If routeAction specifies
|
|
any weightedBackendServices, service must not be set. Conversely if
|
|
service is set, routeAction cannot contain any weightedBackendServices.
|
|
Only one of routeAction or urlRedirect must be set.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
cors_policy:
|
|
description:
|
|
- The specification for allowing client side cross-origin requests.
|
|
Please see W3C Recommendation for Cross Origin Resource Sharing
|
|
.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
allow_credentials:
|
|
description:
|
|
- In response to a preflight request, setting this to true indicates
|
|
that the actual request can include user credentials. This translates
|
|
to the Access- Control-Allow-Credentials header. Defaults to
|
|
false.
|
|
required: false
|
|
default: 'false'
|
|
type: bool
|
|
allow_headers:
|
|
description:
|
|
- Specifies the content for the Access-Control-Allow-Headers header.
|
|
elements: str
|
|
required: false
|
|
type: list
|
|
allow_methods:
|
|
description:
|
|
- Specifies the content for the Access-Control-Allow-Methods header.
|
|
elements: str
|
|
required: false
|
|
type: list
|
|
allow_origin_regexes:
|
|
description:
|
|
- Specifies the regular expression patterns that match allowed
|
|
origins. For regular expression grammar please see en.cppreference.com/w/cpp/regex/ecmascript
|
|
An origin is allowed if it matches either allow_origins or allow_origin_regex.
|
|
elements: str
|
|
required: false
|
|
type: list
|
|
allow_origins:
|
|
description:
|
|
- Specifies the list of origins that will be allowed to do CORS
|
|
requests. An origin is allowed if it matches either allow_origins
|
|
or allow_origin_regex.
|
|
elements: str
|
|
required: false
|
|
type: list
|
|
disabled:
|
|
description:
|
|
- If true, specifies the CORS policy is disabled.
|
|
required: true
|
|
type: bool
|
|
expose_headers:
|
|
description:
|
|
- Specifies the content for the Access-Control-Expose-Headers
|
|
header.
|
|
elements: str
|
|
required: false
|
|
type: list
|
|
max_age:
|
|
description:
|
|
- Specifies how long the results of a preflight request can be
|
|
cached. This translates to the content for the Access-Control-Max-Age
|
|
header.
|
|
required: false
|
|
type: int
|
|
fault_injection_policy:
|
|
description:
|
|
- The specification for fault injection introduced into traffic to
|
|
test the resiliency of clients to backend service failure. As part
|
|
of fault injection, when clients send requests to a backend service,
|
|
delays can be introduced by Loadbalancer on a percentage of requests
|
|
before sending those request to the backend service. Similarly requests
|
|
from clients can be aborted by the Loadbalancer for a percentage
|
|
of requests. timeout and retry_policy will be ignored by clients
|
|
that are configured with a fault_injection_policy.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
abort:
|
|
description:
|
|
- The specification for how client requests are aborted as part
|
|
of fault injection.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
http_status:
|
|
description:
|
|
- The HTTP status code used to abort the request. The value
|
|
must be between 200 and 599 inclusive.
|
|
required: true
|
|
type: int
|
|
percentage:
|
|
description:
|
|
- The percentage of traffic (connections/operations/requests)
|
|
which will be aborted as part of fault injection. The value
|
|
must be between 0.0 and 100.0 inclusive.
|
|
required: true
|
|
type: str
|
|
delay:
|
|
description:
|
|
- The specification for how client requests are delayed as part
|
|
of fault injection, before being sent to a backend service.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
fixed_delay:
|
|
description:
|
|
- Specifies the value of the fixed delay interval.
|
|
required: true
|
|
type: dict
|
|
suboptions:
|
|
nanos:
|
|
description:
|
|
- Span of time that's a fraction of a second at nanosecond
|
|
resolution. Durations less than one second are represented
|
|
with a 0 `seconds` field and a positive `nanos` field.
|
|
Must be from 0 to 999,999,999 inclusive.
|
|
required: false
|
|
type: int
|
|
seconds:
|
|
description:
|
|
- Span of time at a resolution of a second. Must be from
|
|
0 to 315,576,000,000 inclusive.
|
|
required: true
|
|
type: str
|
|
percentage:
|
|
description:
|
|
- The percentage of traffic (connections/operations/requests)
|
|
on which delay will be introduced as part of fault injection.
|
|
The value must be between 0.0 and 100.0 inclusive.
|
|
required: true
|
|
type: str
|
|
request_mirror_policy:
|
|
description:
|
|
- Specifies the policy on how requests intended for the route's backends
|
|
are shadowed to a separate mirrored backend service. Loadbalancer
|
|
does not wait for responses from the shadow service. Prior to sending
|
|
traffic to the shadow service, the host / authority header is suffixed
|
|
with -shadow.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
backend_service:
|
|
description:
|
|
- The RegionBackendService resource being mirrored to.
|
|
- 'This field represents a link to a RegionBackendService resource
|
|
in GCP. It can be specified in two ways. First, you can place
|
|
a dictionary with key ''selfLink'' and value of your resource''s
|
|
selfLink Alternatively, you can add `register: name-of-resource`
|
|
to a gcp_compute_region_backend_service task and then set this
|
|
backend_service field to "{{ name-of-resource }}"'
|
|
required: true
|
|
type: dict
|
|
retry_policy:
|
|
description:
|
|
- Specifies the retry policy associated with this route.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
num_retries:
|
|
description:
|
|
- Specifies the allowed number retries. This number must be >
|
|
0.
|
|
required: false
|
|
type: int
|
|
per_try_timeout:
|
|
description:
|
|
- Specifies a non-zero timeout per retry attempt.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
nanos:
|
|
description:
|
|
- Span of time that's a fraction of a second at nanosecond
|
|
resolution. Durations less than one second are represented
|
|
with a 0 `seconds` field and a positive `nanos` field. Must
|
|
be from 0 to 999,999,999 inclusive.
|
|
required: false
|
|
type: int
|
|
seconds:
|
|
description:
|
|
- Span of time at a resolution of a second. Must be from 0
|
|
to 315,576,000,000 inclusive.
|
|
required: true
|
|
type: str
|
|
retry_conditions:
|
|
description:
|
|
- 'Specifies one or more conditions when this retry rule applies.
|
|
Valid values are: - 5xx: Loadbalancer will attempt a retry if
|
|
the backend service responds with any 5xx response code, or
|
|
if the backend service does not respond at all, example: disconnects,
|
|
reset, read timeout, connection failure, and refused streams.'
|
|
- "- gateway-error: Similar to 5xx, but only applies to response
|
|
codes 502, 503 or 504."
|
|
- "- connect-failure: Loadbalancer will retry on failures connecting
|
|
to backend services, for example due to connection timeouts."
|
|
- "- retriable-4xx: Loadbalancer will retry for retriable 4xx
|
|
response codes."
|
|
- Currently the only retriable error supported is 409.
|
|
- "- refused-stream: Loadbalancer will retry if the backend service
|
|
resets the stream with a REFUSED_STREAM error code. This reset
|
|
type indicates that it is safe to retry."
|
|
- "- cancelled: Loadbalancer will retry if the gRPC status code
|
|
in the response header is set to cancelled - deadline-exceeded:
|
|
Loadbalancer will retry if the gRPC status code in the response
|
|
header is set to deadline-exceeded - resource-exhausted: Loadbalancer
|
|
will retry if the gRPC status code in the response header is
|
|
set to resource-exhausted - unavailable: Loadbalancer will retry
|
|
if the gRPC status code in the response header is set to unavailable
|
|
."
|
|
elements: str
|
|
required: false
|
|
type: list
|
|
timeout:
|
|
description:
|
|
- Specifies the timeout for the selected route. Timeout is computed
|
|
from the time the request is has been fully processed (i.e. end-of-stream)
|
|
up until the response has been completely processed. Timeout includes
|
|
all retries. If not specified, the default value is 15 seconds.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
nanos:
|
|
description:
|
|
- Span of time that's a fraction of a second at nanosecond resolution.
|
|
Durations less than one second are represented with a 0 `seconds`
|
|
field and a positive `nanos` field. Must be from 0 to 999,999,999
|
|
inclusive.
|
|
required: false
|
|
type: int
|
|
seconds:
|
|
description:
|
|
- Span of time at a resolution of a second. Must be from 0 to
|
|
315,576,000,000 inclusive.
|
|
required: true
|
|
type: str
|
|
url_rewrite:
|
|
description:
|
|
- The spec to modify the URL of the request, prior to forwarding the
|
|
request to the matched service .
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
host_rewrite:
|
|
description:
|
|
- Prior to forwarding the request to the selected service, the
|
|
request's host header is replaced with contents of hostRewrite.
|
|
The value must be between 1 and 255 characters.
|
|
required: false
|
|
type: str
|
|
path_prefix_rewrite:
|
|
description:
|
|
- Prior to forwarding the request to the selected backend service,
|
|
the matching portion of the request's path is replaced by pathPrefixRewrite.
|
|
The value must be between 1 and 1024 characters.
|
|
required: false
|
|
type: str
|
|
weighted_backend_services:
|
|
description:
|
|
- A list of weighted backend services to send traffic to when a route
|
|
match occurs. The weights determine the fraction of traffic that
|
|
flows to their corresponding backend service. If all traffic needs
|
|
to go to a single backend service, there must be one weightedBackendService
|
|
with weight set to a non 0 number. Once a backendService is identified
|
|
and before forwarding the request to the backend service, advanced
|
|
routing actions like Url rewrites and header transformations are
|
|
applied depending on additional settings specified in this HttpRouteAction.
|
|
elements: dict
|
|
required: false
|
|
type: list
|
|
suboptions:
|
|
backend_service:
|
|
description:
|
|
- The default RegionBackendService resource. Before forwarding
|
|
the request to backendService, the loadbalancer applies any
|
|
relevant headerActions specified as part of this backendServiceWeight.
|
|
- 'This field represents a link to a RegionBackendService resource
|
|
in GCP. It can be specified in two ways. First, you can place
|
|
a dictionary with key ''selfLink'' and value of your resource''s
|
|
selfLink Alternatively, you can add `register: name-of-resource`
|
|
to a gcp_compute_region_backend_service task and then set this
|
|
backend_service field to "{{ name-of-resource }}"'
|
|
required: true
|
|
type: dict
|
|
header_action:
|
|
description:
|
|
- Specifies changes to request and response headers that need
|
|
to take effect for the selected backendService. headerAction
|
|
specified here take effect before headerAction in the enclosing
|
|
HttpRouteRule, PathMatcher and UrlMap.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
request_headers_to_add:
|
|
description:
|
|
- Headers to add to a matching request prior to forwarding
|
|
the request to the backendService.
|
|
elements: dict
|
|
required: false
|
|
type: list
|
|
suboptions:
|
|
header_name:
|
|
description:
|
|
- The name of the header.
|
|
required: true
|
|
type: str
|
|
header_value:
|
|
description:
|
|
- The value of the header to add.
|
|
required: true
|
|
type: str
|
|
replace:
|
|
description:
|
|
- If false, headerValue is appended to any values that
|
|
already exist for the header. If true, headerValue is
|
|
set for the header, discarding any values that were
|
|
set for that header.
|
|
required: true
|
|
type: bool
|
|
request_headers_to_remove:
|
|
description:
|
|
- A list of header names for headers that need to be removed
|
|
from the request prior to forwarding the request to the
|
|
backendService.
|
|
elements: str
|
|
required: false
|
|
type: list
|
|
response_headers_to_add:
|
|
description:
|
|
- Headers to add the response prior to sending the response
|
|
back to the client.
|
|
elements: dict
|
|
required: false
|
|
type: list
|
|
suboptions:
|
|
header_name:
|
|
description:
|
|
- The name of the header.
|
|
required: true
|
|
type: str
|
|
header_value:
|
|
description:
|
|
- The value of the header to add.
|
|
required: true
|
|
type: str
|
|
replace:
|
|
description:
|
|
- If false, headerValue is appended to any values that
|
|
already exist for the header. If true, headerValue is
|
|
set for the header, discarding any values that were
|
|
set for that header.
|
|
required: true
|
|
type: bool
|
|
response_headers_to_remove:
|
|
description:
|
|
- A list of header names for headers that need to be removed
|
|
from the response prior to sending the response back to
|
|
the client.
|
|
elements: str
|
|
required: false
|
|
type: list
|
|
weight:
|
|
description:
|
|
- Specifies the fraction of traffic sent to backendService, computed
|
|
as weight / (sum of all weightedBackendService weights in routeAction)
|
|
. The selection of a backend service is determined only for
|
|
new traffic. Once a user's request has been directed to a backendService,
|
|
subsequent requests will be sent to the same backendService
|
|
as determined by the BackendService's session affinity policy.
|
|
- The value must be between 0 and 1000 .
|
|
required: true
|
|
type: int
|
|
url_redirect:
|
|
description:
|
|
- When a path pattern is matched, the request is redirected to a URL specified
|
|
by urlRedirect. If urlRedirect is specified, service or routeAction
|
|
must not be set.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
host_redirect:
|
|
description:
|
|
- The host that will be used in the redirect response instead of the
|
|
one that was supplied in the request. The value must be between
|
|
1 and 255 characters.
|
|
required: false
|
|
type: str
|
|
https_redirect:
|
|
description:
|
|
- If set to true, the URL scheme in the redirected request is set
|
|
to https.
|
|
- If set to false, the URL scheme of the redirected request will remain
|
|
the same as that of the request. This must only be set for UrlMaps
|
|
used in TargetHttpProxys. Setting this true for TargetHttpsProxy
|
|
is not permitted. The default is set to false.
|
|
required: false
|
|
default: 'false'
|
|
type: bool
|
|
path_redirect:
|
|
description:
|
|
- The path that will be used in the redirect response instead of the
|
|
one that was supplied in the request. pathRedirect cannot be supplied
|
|
together with prefixRedirect. Supply one alone or neither. If neither
|
|
is supplied, the path of the original request will be used for the
|
|
redirect.
|
|
- The value must be between 1 and 1024 characters.
|
|
required: false
|
|
type: str
|
|
prefix_redirect:
|
|
description:
|
|
- The prefix that replaces the prefixMatch specified in the HttpRouteRuleMatch,
|
|
retaining the remaining portion of the URL before redirecting the
|
|
request. prefixRedirect cannot be supplied together with pathRedirect.
|
|
Supply one alone or neither. If neither is supplied, the path of
|
|
the original request will be used for the redirect. The value must
|
|
be between 1 and 1024 characters.
|
|
required: false
|
|
type: str
|
|
redirect_response_code:
|
|
description:
|
|
- 'The HTTP Status code to use for this RedirectAction. Supported
|
|
values are: * MOVED_PERMANENTLY_DEFAULT, which is the default value
|
|
and corresponds to 301.'
|
|
- "* FOUND, which corresponds to 302."
|
|
- "* SEE_OTHER which corresponds to 303."
|
|
- "* TEMPORARY_REDIRECT, which corresponds to 307. In this case, the
|
|
request method will be retained."
|
|
- "* PERMANENT_REDIRECT, which corresponds to 308. In this case, the
|
|
request method will be retained."
|
|
- 'Some valid choices include: "FOUND", "MOVED_PERMANENTLY_DEFAULT",
|
|
"PERMANENT_REDIRECT", "SEE_OTHER", "TEMPORARY_REDIRECT"'
|
|
required: false
|
|
type: str
|
|
strip_query:
|
|
description:
|
|
- If set to true, any accompanying query portion of the original URL
|
|
is removed prior to redirecting the request. If set to false, the
|
|
query portion of the original URL is retained.
|
|
required: false
|
|
default: 'false'
|
|
type: bool
|
|
default_url_redirect:
|
|
description:
|
|
- When none of the specified hostRules match, the request is redirected to
|
|
a URL specified by defaultUrlRedirect. If defaultUrlRedirect is specified,
|
|
defaultService or defaultRouteAction must not be set.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
host_redirect:
|
|
description:
|
|
- The host that will be used in the redirect response instead of the one
|
|
that was supplied in the request. The value must be between 1 and 255
|
|
characters.
|
|
required: false
|
|
type: str
|
|
https_redirect:
|
|
description:
|
|
- If set to true, the URL scheme in the redirected request is set to https.
|
|
If set to false, the URL scheme of the redirected request will remain
|
|
the same as that of the request. This must only be set for UrlMaps used
|
|
in TargetHttpProxys. Setting this true for TargetHttpsProxy is not permitted.
|
|
The default is set to false.
|
|
required: false
|
|
default: 'false'
|
|
type: bool
|
|
path_redirect:
|
|
description:
|
|
- The path that will be used in the redirect response instead of the one
|
|
that was supplied in the request. pathRedirect cannot be supplied together
|
|
with prefixRedirect. Supply one alone or neither. If neither is supplied,
|
|
the path of the original request will be used for the redirect. The
|
|
value must be between 1 and 1024 characters.
|
|
required: false
|
|
type: str
|
|
prefix_redirect:
|
|
description:
|
|
- The prefix that replaces the prefixMatch specified in the HttpRouteRuleMatch,
|
|
retaining the remaining portion of the URL before redirecting the request.
|
|
- prefixRedirect cannot be supplied together with pathRedirect. Supply
|
|
one alone or neither. If neither is supplied, the path of the original
|
|
request will be used for the redirect. The value must be between 1 and
|
|
1024 characters.
|
|
required: false
|
|
type: str
|
|
redirect_response_code:
|
|
description:
|
|
- 'The HTTP Status code to use for this RedirectAction. Supported values
|
|
are: * MOVED_PERMANENTLY_DEFAULT, which is the default value and corresponds
|
|
to 301.'
|
|
- "* FOUND, which corresponds to 302."
|
|
- "* SEE_OTHER which corresponds to 303."
|
|
- "* TEMPORARY_REDIRECT, which corresponds to 307. In this case, the request
|
|
method will be retained."
|
|
- "* PERMANENT_REDIRECT, which corresponds to 308. In this case, the request
|
|
method will be retained."
|
|
- 'Some valid choices include: "FOUND", "MOVED_PERMANENTLY_DEFAULT", "PERMANENT_REDIRECT",
|
|
"SEE_OTHER", "TEMPORARY_REDIRECT"'
|
|
required: false
|
|
type: str
|
|
strip_query:
|
|
description:
|
|
- If set to true, any accompanying query portion of the original URL is
|
|
removed prior to redirecting the request. If set to false, the query
|
|
portion of the original URL is retained.
|
|
required: false
|
|
default: 'false'
|
|
type: bool
|
|
tests:
|
|
description:
|
|
- The list of expected URL mappings. Requests to update this UrlMap will succeed
|
|
only if all of the test cases pass.
|
|
elements: dict
|
|
required: false
|
|
type: list
|
|
suboptions:
|
|
description:
|
|
description:
|
|
- Description of this test case.
|
|
required: false
|
|
type: str
|
|
host:
|
|
description:
|
|
- Host portion of the URL.
|
|
required: true
|
|
type: str
|
|
path:
|
|
description:
|
|
- Path portion of the URL.
|
|
required: true
|
|
type: str
|
|
service:
|
|
description:
|
|
- A reference to expected RegionBackendService resource the given URL should
|
|
be mapped to.
|
|
- 'This field represents a link to a RegionBackendService resource in GCP.
|
|
It can be specified in two ways. First, you can place a dictionary with
|
|
key ''selfLink'' and value of your resource''s selfLink Alternatively, you
|
|
can add `register: name-of-resource` to a gcp_compute_region_backend_service
|
|
task and then set this service field to "{{ name-of-resource }}"'
|
|
required: true
|
|
type: dict
|
|
default_url_redirect:
|
|
description:
|
|
- When none of the specified hostRules match, the request is redirected to a URL
|
|
specified by defaultUrlRedirect. If defaultUrlRedirect is specified, defaultService
|
|
or defaultRouteAction must not be set.
|
|
required: false
|
|
type: dict
|
|
suboptions:
|
|
host_redirect:
|
|
description:
|
|
- The host that will be used in the redirect response instead of the one that
|
|
was supplied in the request. The value must be between 1 and 255 characters.
|
|
required: false
|
|
type: str
|
|
https_redirect:
|
|
description:
|
|
- If set to true, the URL scheme in the redirected request is set to https.
|
|
If set to false, the URL scheme of the redirected request will remain the
|
|
same as that of the request. This must only be set for UrlMaps used in TargetHttpProxys.
|
|
Setting this true for TargetHttpsProxy is not permitted. The default is
|
|
set to false.
|
|
required: false
|
|
default: 'false'
|
|
type: bool
|
|
path_redirect:
|
|
description:
|
|
- The path that will be used in the redirect response instead of the one that
|
|
was supplied in the request. pathRedirect cannot be supplied together with
|
|
prefixRedirect. Supply one alone or neither. If neither is supplied, the
|
|
path of the original request will be used for the redirect. The value must
|
|
be between 1 and 1024 characters.
|
|
required: false
|
|
type: str
|
|
prefix_redirect:
|
|
description:
|
|
- The prefix that replaces the prefixMatch specified in the HttpRouteRuleMatch,
|
|
retaining the remaining portion of the URL before redirecting the request.
|
|
- prefixRedirect cannot be supplied together with pathRedirect. Supply one
|
|
alone or neither. If neither is supplied, the path of the original request
|
|
will be used for the redirect. The value must be between 1 and 1024 characters.
|
|
required: false
|
|
type: str
|
|
redirect_response_code:
|
|
description:
|
|
- 'The HTTP Status code to use for this RedirectAction. Supported values are:
|
|
* MOVED_PERMANENTLY_DEFAULT, which is the default value and corresponds
|
|
to 301.'
|
|
- "* FOUND, which corresponds to 302."
|
|
- "* SEE_OTHER which corresponds to 303."
|
|
- "* TEMPORARY_REDIRECT, which corresponds to 307. In this case, the request
|
|
method will be retained."
|
|
- "* PERMANENT_REDIRECT, which corresponds to 308. In this case, the request
|
|
method will be retained."
|
|
- 'Some valid choices include: "FOUND", "MOVED_PERMANENTLY_DEFAULT", "PERMANENT_REDIRECT",
|
|
"SEE_OTHER", "TEMPORARY_REDIRECT"'
|
|
required: false
|
|
type: str
|
|
strip_query:
|
|
description:
|
|
- If set to true, any accompanying query portion of the original URL is removed
|
|
prior to redirecting the request. If set to false, the query portion of
|
|
the original URL is retained.
|
|
required: false
|
|
default: 'false'
|
|
type: bool
|
|
region:
|
|
description:
|
|
- A reference to the region where the url map resides.
|
|
required: true
|
|
type: str
|
|
project:
|
|
description:
|
|
- The Google Cloud Platform project to use.
|
|
type: str
|
|
auth_kind:
|
|
description:
|
|
- The type of credential used.
|
|
type: str
|
|
required: true
|
|
choices:
|
|
- application
|
|
- machineaccount
|
|
- serviceaccount
|
|
service_account_contents:
|
|
description:
|
|
- The contents of a Service Account JSON file, either in a dictionary or as a
|
|
JSON string that represents it.
|
|
type: jsonarg
|
|
service_account_file:
|
|
description:
|
|
- The path of a Service Account JSON file if serviceaccount is selected as type.
|
|
type: path
|
|
service_account_email:
|
|
description:
|
|
- An optional service account email address if machineaccount is selected and
|
|
the user does not wish to use the default email.
|
|
type: str
|
|
scopes:
|
|
description:
|
|
- Array of scopes to be used
|
|
type: list
|
|
elements: str
|
|
env_type:
|
|
description:
|
|
- Specifies which Ansible environment you're running this module within.
|
|
- This should not be set unless you know what you're doing.
|
|
- This only alters the User Agent string for any API requests.
|
|
type: str
|
|
'''
|
|
|
|
EXAMPLES = '''
|
|
- name: create a health check
|
|
google.cloud.gcp_compute_health_check:
|
|
name: "{{ resource_name }}"
|
|
type: HTTP
|
|
http_health_check:
|
|
port: 80
|
|
check_interval_sec: 1
|
|
timeout_sec: 1
|
|
project: "{{ gcp_project }}"
|
|
auth_kind: "{{ gcp_cred_kind }}"
|
|
service_account_file: "{{ gcp_cred_file }}"
|
|
state: present
|
|
register: healthcheck
|
|
|
|
- name: create a region backend service
|
|
google.cloud.gcp_compute_region_backend_service:
|
|
name: "{{ resource_name }}"
|
|
region: us-central1
|
|
health_checks:
|
|
- "{{ healthcheck.selfLink }}"
|
|
protocol: HTTP
|
|
project: "{{ gcp_project }}"
|
|
auth_kind: "{{ gcp_cred_kind }}"
|
|
service_account_file: "{{ gcp_cred_file }}"
|
|
state: present
|
|
register: backendservice
|
|
|
|
- name: create a region URL map
|
|
google.cloud.gcp_compute_region_url_map:
|
|
name: test_object
|
|
region: us-central1
|
|
default_service: "{{ backendservice }}"
|
|
project: test_project
|
|
auth_kind: serviceaccount
|
|
service_account_file: "/tmp/auth.pem"
|
|
state: present
|
|
'''
|
|
|
|
RETURN = '''
|
|
creationTimestamp:
|
|
description:
|
|
- Creation timestamp in RFC3339 text format.
|
|
returned: success
|
|
type: str
|
|
defaultService:
|
|
description:
|
|
- The full or partial URL of the defaultService resource to which traffic is directed
|
|
if none of the hostRules match. 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 routeAction specifies
|
|
any weightedBackendServices, service must not be specified. Only one of defaultService,
|
|
defaultUrlRedirect or defaultRouteAction.weightedBackendService must be set.
|
|
returned: success
|
|
type: dict
|
|
description:
|
|
description:
|
|
- An optional description of this resource. Provide this property when you create
|
|
the resource.
|
|
returned: success
|
|
type: str
|
|
hostRules:
|
|
description:
|
|
- The list of HostRules to use against the URL.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
description:
|
|
description:
|
|
- An optional description of this HostRule. Provide this property when you create
|
|
the resource.
|
|
returned: success
|
|
type: str
|
|
hosts:
|
|
description:
|
|
- The list of host patterns to match. They must be valid hostnames, except *
|
|
will match any string of ([a-z0-9-.]*). In that case, * must be the first
|
|
character and must be followed in the pattern by either - or .
|
|
returned: success
|
|
type: list
|
|
pathMatcher:
|
|
description:
|
|
- The name of the PathMatcher to use to match the path portion of the URL if
|
|
the hostRule matches the URL's host portion.
|
|
returned: success
|
|
type: str
|
|
id:
|
|
description:
|
|
- The unique identifier for the resource.
|
|
returned: success
|
|
type: int
|
|
fingerprint:
|
|
description:
|
|
- Fingerprint of this resource. This field is used internally during updates of
|
|
this resource.
|
|
returned: success
|
|
type: str
|
|
name:
|
|
description:
|
|
- Name of the resource. Provided by the client when the resource is created. The
|
|
name must be 1-63 characters long, and comply with RFC1035. Specifically, the
|
|
name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?`
|
|
which means the first character must be a lowercase letter, and all following
|
|
characters must be a dash, lowercase letter, or digit, except the last character,
|
|
which cannot be a dash.
|
|
returned: success
|
|
type: str
|
|
pathMatchers:
|
|
description:
|
|
- The list of named PathMatchers to use against the URL.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
defaultService:
|
|
description:
|
|
- A reference to a RegionBackendService resource. This will be used if none
|
|
of the pathRules defined by this PathMatcher is matched by the URL's path
|
|
portion.
|
|
returned: success
|
|
type: dict
|
|
description:
|
|
description:
|
|
- An optional description of this resource.
|
|
returned: success
|
|
type: str
|
|
name:
|
|
description:
|
|
- The name to which this PathMatcher is referred by the HostRule.
|
|
returned: success
|
|
type: str
|
|
routeRules:
|
|
description:
|
|
- 'The list of ordered HTTP route rules. Use this list instead of pathRules
|
|
when advanced route matching and routing actions are desired. The order of
|
|
specifying routeRules matters: the first rule that matches will cause its
|
|
specified routing action to take effect. Within a given pathMatcher, only
|
|
one of pathRules or routeRules must be set. routeRules are not supported in
|
|
UrlMaps intended for External load balancers.'
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
priority:
|
|
description:
|
|
- For routeRules within a given pathMatcher, priority determines the order
|
|
in which load balancer will interpret routeRules. RouteRules are evaluated
|
|
in order of priority, from the lowest to highest number. The priority
|
|
of a rule decreases as its number increases (1, 2, 3, N+1). The first
|
|
rule that matches the request is applied.
|
|
- You cannot configure two or more routeRules with the same priority.
|
|
- Priority for each rule must be set to a number between 0 and 2147483647
|
|
inclusive.
|
|
- Priority numbers can have gaps, which enable you to add or remove rules
|
|
in the future without affecting the rest of the rules. For example, 1,
|
|
2, 3, 4, 5, 9, 12, 16 is a valid series of priority numbers to which you
|
|
could add rules numbered from 6 to 8, 10 to 11, and 13 to 15 in the future
|
|
without any impact on existing rules.
|
|
returned: success
|
|
type: int
|
|
service:
|
|
description:
|
|
- The region backend service resource to which traffic is directed if this
|
|
rule is matched. If routeAction is additionally specified, advanced routing
|
|
actions like URL Rewrites, etc. take effect prior to sending the request
|
|
to the backend. However, if service is specified, routeAction cannot contain
|
|
any weightedBackendService s. Conversely, if routeAction specifies any
|
|
weightedBackendServices, service must not be specified. Only one of urlRedirect,
|
|
service or routeAction.weightedBackendService must be set.
|
|
returned: success
|
|
type: dict
|
|
headerAction:
|
|
description:
|
|
- Specifies changes to request and response headers that need to take effect
|
|
for the selected backendService. The headerAction specified here are applied
|
|
before the matching pathMatchers[].headerAction and after pathMatchers[].routeRules[].r
|
|
outeAction.weightedBackendService.backendServiceWeightAction[].headerAction
|
|
.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
requestHeadersToAdd:
|
|
description:
|
|
- Headers to add to a matching request prior to forwarding the request
|
|
to the backendService.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
headerName:
|
|
description:
|
|
- The name of the header.
|
|
returned: success
|
|
type: str
|
|
headerValue:
|
|
description:
|
|
- The value of the header to add.
|
|
returned: success
|
|
type: str
|
|
replace:
|
|
description:
|
|
- If false, headerValue is appended to any values that already exist
|
|
for the header. If true, headerValue is set for the header, discarding
|
|
any values that were set for that header.
|
|
returned: success
|
|
type: bool
|
|
requestHeadersToRemove:
|
|
description:
|
|
- A list of header names for headers that need to be removed from the
|
|
request prior to forwarding the request to the backendService.
|
|
returned: success
|
|
type: list
|
|
responseHeadersToAdd:
|
|
description:
|
|
- Headers to add the response prior to sending the response back to
|
|
the client.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
headerName:
|
|
description:
|
|
- The name of the header.
|
|
returned: success
|
|
type: str
|
|
headerValue:
|
|
description:
|
|
- The value of the header to add.
|
|
returned: success
|
|
type: str
|
|
replace:
|
|
description:
|
|
- If false, headerValue is appended to any values that already exist
|
|
for the header. If true, headerValue is set for the header, discarding
|
|
any values that were set for that header.
|
|
returned: success
|
|
type: bool
|
|
responseHeadersToRemove:
|
|
description:
|
|
- A list of header names for headers that need to be removed from the
|
|
response prior to sending the response back to the client.
|
|
returned: success
|
|
type: list
|
|
matchRules:
|
|
description:
|
|
- The rules for determining a match.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
fullPathMatch:
|
|
description:
|
|
- For satisfying the matchRule condition, the path of the request must
|
|
exactly match the value specified in fullPathMatch after removing
|
|
any query parameters and anchor that may be part of the original URL.
|
|
FullPathMatch must be between 1 and 1024 characters. Only one of prefixMatch,
|
|
fullPathMatch or regexMatch must be specified.
|
|
returned: success
|
|
type: str
|
|
headerMatches:
|
|
description:
|
|
- Specifies a list of header match criteria, all of which must match
|
|
corresponding headers in the request.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
exactMatch:
|
|
description:
|
|
- The value should exactly match contents of exactMatch. Only one
|
|
of exactMatch, prefixMatch, suffixMatch, regexMatch, presentMatch
|
|
or rangeMatch must be set.
|
|
returned: success
|
|
type: str
|
|
headerName:
|
|
description:
|
|
- 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".
|
|
returned: success
|
|
type: str
|
|
invertMatch:
|
|
description:
|
|
- 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.
|
|
Defaults to false.
|
|
returned: success
|
|
type: bool
|
|
prefixMatch:
|
|
description:
|
|
- 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.
|
|
returned: success
|
|
type: str
|
|
presentMatch:
|
|
description:
|
|
- A header with the contents of headerName must exist. The match
|
|
takes place whether or not the request's header has a value or
|
|
not. Only one of exactMatch, prefixMatch, suffixMatch, regexMatch,
|
|
presentMatch or rangeMatch must be set.
|
|
returned: success
|
|
type: bool
|
|
rangeMatch:
|
|
description:
|
|
- The header value must be an integer and its value must be in the
|
|
range specified in rangeMatch. If the header does not contain
|
|
an integer, number or is empty, the match fails. For example for
|
|
a range [-5, 0] * -3 will match * 0 will not match * 0.25 will
|
|
not match * -3someString will not match.
|
|
- Only one of exactMatch, prefixMatch, suffixMatch, regexMatch,
|
|
presentMatch or rangeMatch must be set.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
rangeEnd:
|
|
description:
|
|
- The end of the range (exclusive).
|
|
returned: success
|
|
type: int
|
|
rangeStart:
|
|
description:
|
|
- The start of the range (inclusive).
|
|
returned: success
|
|
type: int
|
|
regexMatch:
|
|
description:
|
|
- '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.
|
|
returned: success
|
|
type: str
|
|
suffixMatch:
|
|
description:
|
|
- 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.
|
|
returned: success
|
|
type: str
|
|
ignoreCase:
|
|
description:
|
|
- Specifies that prefixMatch and fullPathMatch matches are case sensitive.
|
|
- Defaults to false.
|
|
returned: success
|
|
type: bool
|
|
metadataFilters:
|
|
description:
|
|
- Opaque filter criteria used by Loadbalancer to restrict routing configuration
|
|
to a limited set xDS compliant clients. In their xDS requests to Loadbalancer,
|
|
xDS clients present node metadata. If a match takes place, the relevant
|
|
routing 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 in the provided metadata. metadataFilters specified here can
|
|
be overrides those specified in ForwardingRule that refers to this
|
|
UrlMap. metadataFilters only applies to Loadbalancers that have their
|
|
loadBalancingScheme set to INTERNAL_SELF_MANAGED.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
filterLabels:
|
|
description:
|
|
- 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.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
name:
|
|
description:
|
|
- Name of metadata label. The name can have a maximum length
|
|
of 1024 characters and must be at least 1 character long.
|
|
returned: success
|
|
type: str
|
|
value:
|
|
description:
|
|
- The value of the label must match the specified value. value
|
|
can have a maximum length of 1024 characters.
|
|
returned: success
|
|
type: str
|
|
filterMatchCriteria:
|
|
description:
|
|
- 'Specifies how individual filterLabel matches within the list
|
|
of filterLabels contribute towards 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."
|
|
returned: success
|
|
type: str
|
|
prefixMatch:
|
|
description:
|
|
- For satisfying the matchRule condition, the request's path must begin
|
|
with the specified prefixMatch. prefixMatch must begin with a /. The
|
|
value must be between 1 and 1024 characters. Only one of prefixMatch,
|
|
fullPathMatch or regexMatch must be specified.
|
|
returned: success
|
|
type: str
|
|
queryParameterMatches:
|
|
description:
|
|
- Specifies a list of query parameter match criteria, all of which must
|
|
match corresponding query parameters in the request.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
exactMatch:
|
|
description:
|
|
- The queryParameterMatch matches if the value of the parameter
|
|
exactly matches the contents of exactMatch. Only one of presentMatch,
|
|
exactMatch and regexMatch must be set.
|
|
returned: success
|
|
type: str
|
|
name:
|
|
description:
|
|
- The name of the query parameter to match. The query parameter
|
|
must exist in the request, in the absence of which the request
|
|
match fails.
|
|
returned: success
|
|
type: str
|
|
presentMatch:
|
|
description:
|
|
- Specifies that the queryParameterMatch matches if the request
|
|
contains the query parameter, irrespective of whether the parameter
|
|
has a value or not. Only one of presentMatch, exactMatch and regexMatch
|
|
must be set.
|
|
returned: success
|
|
type: bool
|
|
regexMatch:
|
|
description:
|
|
- The queryParameterMatch matches if the value of the parameter
|
|
matches the regular expression specified by regexMatch. For the
|
|
regular expression grammar, please see en.cppreference.com/w/cpp/regex/ecmascript
|
|
Only one of presentMatch, exactMatch and regexMatch must be set.
|
|
returned: success
|
|
type: str
|
|
regexMatch:
|
|
description:
|
|
- For satisfying the matchRule condition, the path of the request must
|
|
satisfy the regular expression specified in regexMatch after removing
|
|
any query parameters and anchor supplied with the original URL. For
|
|
regular expression grammar please see en.cppreference.com/w/cpp/regex/ecmascript
|
|
Only one of prefixMatch, fullPathMatch or regexMatch must be specified.
|
|
returned: success
|
|
type: str
|
|
routeAction:
|
|
description:
|
|
- In response to a matching matchRule, the load balancer performs advanced
|
|
routing actions like URL rewrites, header transformations, etc. prior
|
|
to forwarding the request to the selected backend. If routeAction specifies
|
|
any weightedBackendServices, service must not be set. Conversely if service
|
|
is set, routeAction cannot contain any weightedBackendServices. Only one
|
|
of routeAction or urlRedirect must be set.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
corsPolicy:
|
|
description:
|
|
- The specification for allowing client side cross-origin requests.
|
|
Please see W3C Recommendation for Cross Origin Resource Sharing .
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
allowCredentials:
|
|
description:
|
|
- In response to a preflight request, setting this to true indicates
|
|
that the actual request can include user credentials. This translates
|
|
to the Access- Control-Allow-Credentials header. Defaults to false.
|
|
returned: success
|
|
type: bool
|
|
allowHeaders:
|
|
description:
|
|
- Specifies the content for the Access-Control-Allow-Headers header.
|
|
returned: success
|
|
type: list
|
|
allowMethods:
|
|
description:
|
|
- Specifies the content for the Access-Control-Allow-Methods header.
|
|
returned: success
|
|
type: list
|
|
allowOriginRegexes:
|
|
description:
|
|
- Specifies the regular expression patterns that match allowed origins.
|
|
For regular expression grammar please see en.cppreference.com/w/cpp/regex/ecmascript
|
|
An origin is allowed if it matches either allow_origins or allow_origin_regex.
|
|
returned: success
|
|
type: list
|
|
allowOrigins:
|
|
description:
|
|
- Specifies the list of origins that will be allowed to do CORS
|
|
requests. An origin is allowed if it matches either allow_origins
|
|
or allow_origin_regex.
|
|
returned: success
|
|
type: list
|
|
disabled:
|
|
description:
|
|
- If true, specifies the CORS policy is disabled.
|
|
- which indicates that the CORS policy is in effect. Defaults to
|
|
false.
|
|
returned: success
|
|
type: bool
|
|
exposeHeaders:
|
|
description:
|
|
- Specifies the content for the Access-Control-Expose-Headers header.
|
|
returned: success
|
|
type: list
|
|
maxAge:
|
|
description:
|
|
- Specifies how long the results of a preflight request can be cached.
|
|
This translates to the content for the Access-Control-Max-Age
|
|
header.
|
|
returned: success
|
|
type: int
|
|
faultInjectionPolicy:
|
|
description:
|
|
- The specification for fault injection introduced into traffic to test
|
|
the resiliency of clients to backend service failure. As part of fault
|
|
injection, when clients send requests to a backend service, delays
|
|
can be introduced by Loadbalancer on a percentage of requests before
|
|
sending those request to the backend service. Similarly requests from
|
|
clients can be aborted by the Loadbalancer for a percentage of requests.
|
|
timeout and retry_policy will be ignored by clients that are configured
|
|
with a fault_injection_policy.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
abort:
|
|
description:
|
|
- The specification for how client requests are aborted as part
|
|
of fault injection.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
httpStatus:
|
|
description:
|
|
- The HTTP status code used to abort the request. The value
|
|
must be between 200 and 599 inclusive.
|
|
returned: success
|
|
type: int
|
|
percentage:
|
|
description:
|
|
- The percentage of traffic (connections/operations/requests)
|
|
which will be aborted as part of fault injection. The value
|
|
must be between 0.0 and 100.0 inclusive.
|
|
returned: success
|
|
type: str
|
|
delay:
|
|
description:
|
|
- The specification for how client requests are delayed as part
|
|
of fault injection, before being sent to a backend service.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
fixedDelay:
|
|
description:
|
|
- Specifies the value of the fixed delay interval.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
nanos:
|
|
description:
|
|
- Span of time that's a fraction of a second at nanosecond
|
|
resolution. Durations less than one second are represented
|
|
with a 0 `seconds` field and a positive `nanos` field.
|
|
Must be from 0 to 999,999,999 inclusive.
|
|
returned: success
|
|
type: int
|
|
seconds:
|
|
description:
|
|
- Span of time at a resolution of a second. Must be from
|
|
0 to 315,576,000,000 inclusive.
|
|
returned: success
|
|
type: str
|
|
percentage:
|
|
description:
|
|
- The percentage of traffic (connections/operations/requests)
|
|
on which delay will be introduced as part of fault injection.
|
|
The value must be between 0.0 and 100.0 inclusive.
|
|
returned: success
|
|
type: str
|
|
requestMirrorPolicy:
|
|
description:
|
|
- Specifies the policy on how requests intended for the route's backends
|
|
are shadowed to a separate mirrored backend service. Loadbalancer
|
|
does not wait for responses from the shadow service. Prior to sending
|
|
traffic to the shadow service, the host / authority header is suffixed
|
|
with -shadow.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
backendService:
|
|
description:
|
|
- The RegionBackendService resource being mirrored to.
|
|
returned: success
|
|
type: dict
|
|
retryPolicy:
|
|
description:
|
|
- Specifies the retry policy associated with this route.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
numRetries:
|
|
description:
|
|
- Specifies the allowed number retries. This number must be > 0.
|
|
returned: success
|
|
type: int
|
|
perTryTimeout:
|
|
description:
|
|
- Specifies a non-zero timeout per retry attempt.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
nanos:
|
|
description:
|
|
- Span of time that's a fraction of a second at nanosecond resolution.
|
|
Durations less than one second are represented with a 0 `seconds`
|
|
field and a positive `nanos` field. Must be from 0 to 999,999,999
|
|
inclusive.
|
|
returned: success
|
|
type: int
|
|
seconds:
|
|
description:
|
|
- Span of time at a resolution of a second. Must be from 0 to
|
|
315,576,000,000 inclusive.
|
|
returned: success
|
|
type: str
|
|
retryConditions:
|
|
description:
|
|
- 'Specifies one or more conditions when this retry rule applies.
|
|
Valid values are: * 5xx: Loadbalancer will attempt a retry if
|
|
the backend service responds with any 5xx response code, or if
|
|
the backend service does not respond at all, example: disconnects,
|
|
reset, read timeout, connection failure, and refused streams.'
|
|
- "* gateway-error: Similar to 5xx, but only applies to response
|
|
codes 502, 503 or 504."
|
|
- "* connect-failure: Loadbalancer will retry on failures connecting
|
|
to backend services, for example due to connection timeouts."
|
|
- "* retriable-4xx: Loadbalancer will retry for retriable 4xx response
|
|
codes."
|
|
- Currently the only retriable error supported is 409.
|
|
- "* refused-stream: Loadbalancer will retry if the backend service
|
|
resets the stream with a REFUSED_STREAM error code. This reset
|
|
type indicates that it is safe to retry."
|
|
- "* cancelled: Loadbalancer will retry if the gRPC status code
|
|
in the response header is set to cancelled * deadline-exceeded:
|
|
Loadbalancer will retry if the gRPC status code in the response
|
|
header is set to deadline-exceeded * resource-exhausted: Loadbalancer
|
|
will retry if the gRPC status code in the response header is set
|
|
to resource-exhausted * unavailable: Loadbalancer will retry if
|
|
the gRPC status code in the response header is set to unavailable
|
|
."
|
|
returned: success
|
|
type: list
|
|
timeout:
|
|
description:
|
|
- Specifies the timeout for the selected route. Timeout is computed
|
|
from the time the request is has been fully processed (i.e. end-of-stream)
|
|
up until the response has been completely processed. Timeout includes
|
|
all retries. If not specified, the default value is 15 seconds.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
nanos:
|
|
description:
|
|
- Span of time that's a fraction of a second at nanosecond resolution.
|
|
Durations less than one second are represented with a 0 `seconds`
|
|
field and a positive `nanos` field. Must be from 0 to 999,999,999
|
|
inclusive.
|
|
returned: success
|
|
type: int
|
|
seconds:
|
|
description:
|
|
- Span of time at a resolution of a second. Must be from 0 to 315,576,000,000
|
|
inclusive.
|
|
returned: success
|
|
type: str
|
|
urlRewrite:
|
|
description:
|
|
- The spec to modify the URL of the request, prior to forwarding the
|
|
request to the matched service .
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
hostRewrite:
|
|
description:
|
|
- Prior to forwarding the request to the selected service, the request's
|
|
host header is replaced with contents of hostRewrite. The value
|
|
must be between 1 and 255 characters.
|
|
returned: success
|
|
type: str
|
|
pathPrefixRewrite:
|
|
description:
|
|
- Prior to forwarding the request to the selected backend service,
|
|
the matching portion of the request's path is replaced by pathPrefixRewrite.
|
|
The value must be between 1 and 1024 characters.
|
|
returned: success
|
|
type: str
|
|
weightedBackendServices:
|
|
description:
|
|
- A list of weighted backend services to send traffic to when a route
|
|
match occurs. The weights determine the fraction of traffic that flows
|
|
to their corresponding backend service. If all traffic needs to go
|
|
to a single backend service, there must be one weightedBackendService
|
|
with weight set to a non 0 number. Once a backendService is identified
|
|
and before forwarding the request to the backend service, advanced
|
|
routing actions like Url rewrites and header transformations are applied
|
|
depending on additional settings specified in this HttpRouteAction.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
backendService:
|
|
description:
|
|
- The default RegionBackendService resource. Before forwarding the
|
|
request to backendService, the loadbalancer applies any relevant
|
|
headerActions specified as part of this backendServiceWeight.
|
|
returned: success
|
|
type: dict
|
|
headerAction:
|
|
description:
|
|
- Specifies changes to request and response headers that need to
|
|
take effect for the selected backendService. headerAction specified
|
|
here take effect before headerAction in the enclosing HttpRouteRule,
|
|
PathMatcher and UrlMap.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
requestHeadersToAdd:
|
|
description:
|
|
- Headers to add to a matching request prior to forwarding the
|
|
request to the backendService.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
headerName:
|
|
description:
|
|
- The name of the header.
|
|
returned: success
|
|
type: str
|
|
headerValue:
|
|
description:
|
|
- The value of the header to add.
|
|
returned: success
|
|
type: str
|
|
replace:
|
|
description:
|
|
- If false, headerValue is appended to any values that already
|
|
exist for the header. If true, headerValue is set for
|
|
the header, discarding any values that were set for that
|
|
header.
|
|
returned: success
|
|
type: bool
|
|
requestHeadersToRemove:
|
|
description:
|
|
- A list of header names for headers that need to be removed
|
|
from the request prior to forwarding the request to the backendService.
|
|
returned: success
|
|
type: list
|
|
responseHeadersToAdd:
|
|
description:
|
|
- Headers to add the response prior to sending the response
|
|
back to the client.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
headerName:
|
|
description:
|
|
- The name of the header.
|
|
returned: success
|
|
type: str
|
|
headerValue:
|
|
description:
|
|
- The value of the header to add.
|
|
returned: success
|
|
type: str
|
|
replace:
|
|
description:
|
|
- If false, headerValue is appended to any values that already
|
|
exist for the header. If true, headerValue is set for
|
|
the header, discarding any values that were set for that
|
|
header.
|
|
returned: success
|
|
type: bool
|
|
responseHeadersToRemove:
|
|
description:
|
|
- A list of header names for headers that need to be removed
|
|
from the response prior to sending the response back to the
|
|
client.
|
|
returned: success
|
|
type: list
|
|
weight:
|
|
description:
|
|
- Specifies the fraction of traffic sent to backendService, computed
|
|
as weight / (sum of all weightedBackendService weights in routeAction)
|
|
. The selection of a backend service is determined only for new
|
|
traffic. Once a user's request has been directed to a backendService,
|
|
subsequent requests will be sent to the same backendService as
|
|
determined by the BackendService's session affinity policy.
|
|
- The value must be between 0 and 1000 .
|
|
returned: success
|
|
type: int
|
|
urlRedirect:
|
|
description:
|
|
- When this rule is matched, the request is redirected to a URL specified
|
|
by urlRedirect. If urlRedirect is specified, service or routeAction must
|
|
not be set.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
hostRedirect:
|
|
description:
|
|
- The host that will be used in the redirect response instead of the
|
|
one that was supplied in the request. The value must be between 1
|
|
and 255 characters.
|
|
returned: success
|
|
type: str
|
|
httpsRedirect:
|
|
description:
|
|
- If set to true, the URL scheme in the redirected request is set to
|
|
https.
|
|
- If set to false, the URL scheme of the redirected request will remain
|
|
the same as that of the request. This must only be set for UrlMaps
|
|
used in TargetHttpProxys. Setting this true for TargetHttpsProxy is
|
|
not permitted. The default is set to false.
|
|
returned: success
|
|
type: bool
|
|
pathRedirect:
|
|
description:
|
|
- The path that will be used in the redirect response instead of the
|
|
one that was supplied in the request. pathRedirect cannot be supplied
|
|
together with prefixRedirect. Supply one alone or neither. If neither
|
|
is supplied, the path of the original request will be used for the
|
|
redirect.
|
|
- The value must be between 1 and 1024 characters.
|
|
returned: success
|
|
type: str
|
|
prefixRedirect:
|
|
description:
|
|
- The prefix that replaces the prefixMatch specified in the HttpRouteRuleMatch,
|
|
retaining the remaining portion of the URL before redirecting the
|
|
request. prefixRedirect cannot be supplied together with pathRedirect.
|
|
Supply one alone or neither. If neither is supplied, the path of the
|
|
original request will be used for the redirect. The value must be
|
|
between 1 and 1024 characters.
|
|
returned: success
|
|
type: str
|
|
redirectResponseCode:
|
|
description:
|
|
- 'The HTTP Status code to use for this RedirectAction. Supported values
|
|
are: * MOVED_PERMANENTLY_DEFAULT, which is the default value and corresponds
|
|
to 301.'
|
|
- "* FOUND, which corresponds to 302."
|
|
- "* SEE_OTHER which corresponds to 303."
|
|
- "* TEMPORARY_REDIRECT, which corresponds to 307. In this case, the
|
|
request method will be retained."
|
|
- "* PERMANENT_REDIRECT, which corresponds to 308. In this case, the
|
|
request method will be retained."
|
|
returned: success
|
|
type: str
|
|
stripQuery:
|
|
description:
|
|
- If set to true, any accompanying query portion of the original URL
|
|
is removed prior to redirecting the request. If set to false, the
|
|
query portion of the original URL is retained. The default value is
|
|
false.
|
|
returned: success
|
|
type: bool
|
|
pathRules:
|
|
description:
|
|
- '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.'
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
service:
|
|
description:
|
|
- The region backend service resource to which traffic is directed if this
|
|
rule is matched. If routeAction is additionally specified, advanced routing
|
|
actions like URL Rewrites, etc. take effect prior to sending the request
|
|
to the backend. However, if service is specified, routeAction cannot contain
|
|
any weightedBackendService s. Conversely, if routeAction specifies any
|
|
weightedBackendServices, service must not be specified. Only one of urlRedirect,
|
|
service or routeAction.weightedBackendService must be set.
|
|
returned: success
|
|
type: dict
|
|
paths:
|
|
description:
|
|
- 'The list of path patterns to match. Each must start with / and the only
|
|
place a \\* is allowed is at the end following a /. The string fed to the
|
|
path matcher does not include any text after the first ? or #, and those
|
|
chars are not allowed here.'
|
|
returned: success
|
|
type: list
|
|
routeAction:
|
|
description:
|
|
- In response to a matching path, the load balancer performs advanced routing
|
|
actions like URL rewrites, header transformations, etc. prior to forwarding
|
|
the request to the selected backend. If routeAction specifies any weightedBackendServices,
|
|
service must not be set. Conversely if service is set, routeAction cannot
|
|
contain any weightedBackendServices. Only one of routeAction or urlRedirect
|
|
must be set.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
corsPolicy:
|
|
description:
|
|
- The specification for allowing client side cross-origin requests.
|
|
Please see W3C Recommendation for Cross Origin Resource Sharing .
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
allowCredentials:
|
|
description:
|
|
- In response to a preflight request, setting this to true indicates
|
|
that the actual request can include user credentials. This translates
|
|
to the Access- Control-Allow-Credentials header. Defaults to false.
|
|
returned: success
|
|
type: bool
|
|
allowHeaders:
|
|
description:
|
|
- Specifies the content for the Access-Control-Allow-Headers header.
|
|
returned: success
|
|
type: list
|
|
allowMethods:
|
|
description:
|
|
- Specifies the content for the Access-Control-Allow-Methods header.
|
|
returned: success
|
|
type: list
|
|
allowOriginRegexes:
|
|
description:
|
|
- Specifies the regular expression patterns that match allowed origins.
|
|
For regular expression grammar please see en.cppreference.com/w/cpp/regex/ecmascript
|
|
An origin is allowed if it matches either allow_origins or allow_origin_regex.
|
|
returned: success
|
|
type: list
|
|
allowOrigins:
|
|
description:
|
|
- Specifies the list of origins that will be allowed to do CORS
|
|
requests. An origin is allowed if it matches either allow_origins
|
|
or allow_origin_regex.
|
|
returned: success
|
|
type: list
|
|
disabled:
|
|
description:
|
|
- If true, specifies the CORS policy is disabled.
|
|
returned: success
|
|
type: bool
|
|
exposeHeaders:
|
|
description:
|
|
- Specifies the content for the Access-Control-Expose-Headers header.
|
|
returned: success
|
|
type: list
|
|
maxAge:
|
|
description:
|
|
- Specifies how long the results of a preflight request can be cached.
|
|
This translates to the content for the Access-Control-Max-Age
|
|
header.
|
|
returned: success
|
|
type: int
|
|
faultInjectionPolicy:
|
|
description:
|
|
- The specification for fault injection introduced into traffic to test
|
|
the resiliency of clients to backend service failure. As part of fault
|
|
injection, when clients send requests to a backend service, delays
|
|
can be introduced by Loadbalancer on a percentage of requests before
|
|
sending those request to the backend service. Similarly requests from
|
|
clients can be aborted by the Loadbalancer for a percentage of requests.
|
|
timeout and retry_policy will be ignored by clients that are configured
|
|
with a fault_injection_policy.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
abort:
|
|
description:
|
|
- The specification for how client requests are aborted as part
|
|
of fault injection.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
httpStatus:
|
|
description:
|
|
- The HTTP status code used to abort the request. The value
|
|
must be between 200 and 599 inclusive.
|
|
returned: success
|
|
type: int
|
|
percentage:
|
|
description:
|
|
- The percentage of traffic (connections/operations/requests)
|
|
which will be aborted as part of fault injection. The value
|
|
must be between 0.0 and 100.0 inclusive.
|
|
returned: success
|
|
type: str
|
|
delay:
|
|
description:
|
|
- The specification for how client requests are delayed as part
|
|
of fault injection, before being sent to a backend service.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
fixedDelay:
|
|
description:
|
|
- Specifies the value of the fixed delay interval.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
nanos:
|
|
description:
|
|
- Span of time that's a fraction of a second at nanosecond
|
|
resolution. Durations less than one second are represented
|
|
with a 0 `seconds` field and a positive `nanos` field.
|
|
Must be from 0 to 999,999,999 inclusive.
|
|
returned: success
|
|
type: int
|
|
seconds:
|
|
description:
|
|
- Span of time at a resolution of a second. Must be from
|
|
0 to 315,576,000,000 inclusive.
|
|
returned: success
|
|
type: str
|
|
percentage:
|
|
description:
|
|
- The percentage of traffic (connections/operations/requests)
|
|
on which delay will be introduced as part of fault injection.
|
|
The value must be between 0.0 and 100.0 inclusive.
|
|
returned: success
|
|
type: str
|
|
requestMirrorPolicy:
|
|
description:
|
|
- Specifies the policy on how requests intended for the route's backends
|
|
are shadowed to a separate mirrored backend service. Loadbalancer
|
|
does not wait for responses from the shadow service. Prior to sending
|
|
traffic to the shadow service, the host / authority header is suffixed
|
|
with -shadow.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
backendService:
|
|
description:
|
|
- The RegionBackendService resource being mirrored to.
|
|
returned: success
|
|
type: dict
|
|
retryPolicy:
|
|
description:
|
|
- Specifies the retry policy associated with this route.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
numRetries:
|
|
description:
|
|
- Specifies the allowed number retries. This number must be > 0.
|
|
returned: success
|
|
type: int
|
|
perTryTimeout:
|
|
description:
|
|
- Specifies a non-zero timeout per retry attempt.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
nanos:
|
|
description:
|
|
- Span of time that's a fraction of a second at nanosecond resolution.
|
|
Durations less than one second are represented with a 0 `seconds`
|
|
field and a positive `nanos` field. Must be from 0 to 999,999,999
|
|
inclusive.
|
|
returned: success
|
|
type: int
|
|
seconds:
|
|
description:
|
|
- Span of time at a resolution of a second. Must be from 0 to
|
|
315,576,000,000 inclusive.
|
|
returned: success
|
|
type: str
|
|
retryConditions:
|
|
description:
|
|
- 'Specifies one or more conditions when this retry rule applies.
|
|
Valid values are: - 5xx: Loadbalancer will attempt a retry if
|
|
the backend service responds with any 5xx response code, or if
|
|
the backend service does not respond at all, example: disconnects,
|
|
reset, read timeout, connection failure, and refused streams.'
|
|
- "- gateway-error: Similar to 5xx, but only applies to response
|
|
codes 502, 503 or 504."
|
|
- "- connect-failure: Loadbalancer will retry on failures connecting
|
|
to backend services, for example due to connection timeouts."
|
|
- "- retriable-4xx: Loadbalancer will retry for retriable 4xx response
|
|
codes."
|
|
- Currently the only retriable error supported is 409.
|
|
- "- refused-stream: Loadbalancer will retry if the backend service
|
|
resets the stream with a REFUSED_STREAM error code. This reset
|
|
type indicates that it is safe to retry."
|
|
- "- cancelled: Loadbalancer will retry if the gRPC status code
|
|
in the response header is set to cancelled - deadline-exceeded:
|
|
Loadbalancer will retry if the gRPC status code in the response
|
|
header is set to deadline-exceeded - resource-exhausted: Loadbalancer
|
|
will retry if the gRPC status code in the response header is set
|
|
to resource-exhausted - unavailable: Loadbalancer will retry if
|
|
the gRPC status code in the response header is set to unavailable
|
|
."
|
|
returned: success
|
|
type: list
|
|
timeout:
|
|
description:
|
|
- Specifies the timeout for the selected route. Timeout is computed
|
|
from the time the request is has been fully processed (i.e. end-of-stream)
|
|
up until the response has been completely processed. Timeout includes
|
|
all retries. If not specified, the default value is 15 seconds.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
nanos:
|
|
description:
|
|
- Span of time that's a fraction of a second at nanosecond resolution.
|
|
Durations less than one second are represented with a 0 `seconds`
|
|
field and a positive `nanos` field. Must be from 0 to 999,999,999
|
|
inclusive.
|
|
returned: success
|
|
type: int
|
|
seconds:
|
|
description:
|
|
- Span of time at a resolution of a second. Must be from 0 to 315,576,000,000
|
|
inclusive.
|
|
returned: success
|
|
type: str
|
|
urlRewrite:
|
|
description:
|
|
- The spec to modify the URL of the request, prior to forwarding the
|
|
request to the matched service .
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
hostRewrite:
|
|
description:
|
|
- Prior to forwarding the request to the selected service, the request's
|
|
host header is replaced with contents of hostRewrite. The value
|
|
must be between 1 and 255 characters.
|
|
returned: success
|
|
type: str
|
|
pathPrefixRewrite:
|
|
description:
|
|
- Prior to forwarding the request to the selected backend service,
|
|
the matching portion of the request's path is replaced by pathPrefixRewrite.
|
|
The value must be between 1 and 1024 characters.
|
|
returned: success
|
|
type: str
|
|
weightedBackendServices:
|
|
description:
|
|
- A list of weighted backend services to send traffic to when a route
|
|
match occurs. The weights determine the fraction of traffic that flows
|
|
to their corresponding backend service. If all traffic needs to go
|
|
to a single backend service, there must be one weightedBackendService
|
|
with weight set to a non 0 number. Once a backendService is identified
|
|
and before forwarding the request to the backend service, advanced
|
|
routing actions like Url rewrites and header transformations are applied
|
|
depending on additional settings specified in this HttpRouteAction.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
backendService:
|
|
description:
|
|
- The default RegionBackendService resource. Before forwarding the
|
|
request to backendService, the loadbalancer applies any relevant
|
|
headerActions specified as part of this backendServiceWeight.
|
|
returned: success
|
|
type: dict
|
|
headerAction:
|
|
description:
|
|
- Specifies changes to request and response headers that need to
|
|
take effect for the selected backendService. headerAction specified
|
|
here take effect before headerAction in the enclosing HttpRouteRule,
|
|
PathMatcher and UrlMap.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
requestHeadersToAdd:
|
|
description:
|
|
- Headers to add to a matching request prior to forwarding the
|
|
request to the backendService.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
headerName:
|
|
description:
|
|
- The name of the header.
|
|
returned: success
|
|
type: str
|
|
headerValue:
|
|
description:
|
|
- The value of the header to add.
|
|
returned: success
|
|
type: str
|
|
replace:
|
|
description:
|
|
- If false, headerValue is appended to any values that already
|
|
exist for the header. If true, headerValue is set for
|
|
the header, discarding any values that were set for that
|
|
header.
|
|
returned: success
|
|
type: bool
|
|
requestHeadersToRemove:
|
|
description:
|
|
- A list of header names for headers that need to be removed
|
|
from the request prior to forwarding the request to the backendService.
|
|
returned: success
|
|
type: list
|
|
responseHeadersToAdd:
|
|
description:
|
|
- Headers to add the response prior to sending the response
|
|
back to the client.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
headerName:
|
|
description:
|
|
- The name of the header.
|
|
returned: success
|
|
type: str
|
|
headerValue:
|
|
description:
|
|
- The value of the header to add.
|
|
returned: success
|
|
type: str
|
|
replace:
|
|
description:
|
|
- If false, headerValue is appended to any values that already
|
|
exist for the header. If true, headerValue is set for
|
|
the header, discarding any values that were set for that
|
|
header.
|
|
returned: success
|
|
type: bool
|
|
responseHeadersToRemove:
|
|
description:
|
|
- A list of header names for headers that need to be removed
|
|
from the response prior to sending the response back to the
|
|
client.
|
|
returned: success
|
|
type: list
|
|
weight:
|
|
description:
|
|
- Specifies the fraction of traffic sent to backendService, computed
|
|
as weight / (sum of all weightedBackendService weights in routeAction)
|
|
. The selection of a backend service is determined only for new
|
|
traffic. Once a user's request has been directed to a backendService,
|
|
subsequent requests will be sent to the same backendService as
|
|
determined by the BackendService's session affinity policy.
|
|
- The value must be between 0 and 1000 .
|
|
returned: success
|
|
type: int
|
|
urlRedirect:
|
|
description:
|
|
- When a path pattern is matched, the request is redirected to a URL specified
|
|
by urlRedirect. If urlRedirect is specified, service or routeAction must
|
|
not be set.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
hostRedirect:
|
|
description:
|
|
- The host that will be used in the redirect response instead of the
|
|
one that was supplied in the request. The value must be between 1
|
|
and 255 characters.
|
|
returned: success
|
|
type: str
|
|
httpsRedirect:
|
|
description:
|
|
- If set to true, the URL scheme in the redirected request is set to
|
|
https.
|
|
- If set to false, the URL scheme of the redirected request will remain
|
|
the same as that of the request. This must only be set for UrlMaps
|
|
used in TargetHttpProxys. Setting this true for TargetHttpsProxy is
|
|
not permitted. The default is set to false.
|
|
returned: success
|
|
type: bool
|
|
pathRedirect:
|
|
description:
|
|
- The path that will be used in the redirect response instead of the
|
|
one that was supplied in the request. pathRedirect cannot be supplied
|
|
together with prefixRedirect. Supply one alone or neither. If neither
|
|
is supplied, the path of the original request will be used for the
|
|
redirect.
|
|
- The value must be between 1 and 1024 characters.
|
|
returned: success
|
|
type: str
|
|
prefixRedirect:
|
|
description:
|
|
- The prefix that replaces the prefixMatch specified in the HttpRouteRuleMatch,
|
|
retaining the remaining portion of the URL before redirecting the
|
|
request. prefixRedirect cannot be supplied together with pathRedirect.
|
|
Supply one alone or neither. If neither is supplied, the path of the
|
|
original request will be used for the redirect. The value must be
|
|
between 1 and 1024 characters.
|
|
returned: success
|
|
type: str
|
|
redirectResponseCode:
|
|
description:
|
|
- 'The HTTP Status code to use for this RedirectAction. Supported values
|
|
are: * MOVED_PERMANENTLY_DEFAULT, which is the default value and corresponds
|
|
to 301.'
|
|
- "* FOUND, which corresponds to 302."
|
|
- "* SEE_OTHER which corresponds to 303."
|
|
- "* TEMPORARY_REDIRECT, which corresponds to 307. In this case, the
|
|
request method will be retained."
|
|
- "* PERMANENT_REDIRECT, which corresponds to 308. In this case, the
|
|
request method will be retained."
|
|
returned: success
|
|
type: str
|
|
stripQuery:
|
|
description:
|
|
- If set to true, any accompanying query portion of the original URL
|
|
is removed prior to redirecting the request. If set to false, the
|
|
query portion of the original URL is retained.
|
|
returned: success
|
|
type: bool
|
|
defaultUrlRedirect:
|
|
description:
|
|
- When none of the specified hostRules match, the request is redirected to a
|
|
URL specified by defaultUrlRedirect. If defaultUrlRedirect is specified, defaultService
|
|
or defaultRouteAction must not be set.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
hostRedirect:
|
|
description:
|
|
- The host that will be used in the redirect response instead of the one
|
|
that was supplied in the request. The value must be between 1 and 255
|
|
characters.
|
|
returned: success
|
|
type: str
|
|
httpsRedirect:
|
|
description:
|
|
- If set to true, the URL scheme in the redirected request is set to https.
|
|
If set to false, the URL scheme of the redirected request will remain
|
|
the same as that of the request. This must only be set for UrlMaps used
|
|
in TargetHttpProxys. Setting this true for TargetHttpsProxy is not permitted.
|
|
The default is set to false.
|
|
returned: success
|
|
type: bool
|
|
pathRedirect:
|
|
description:
|
|
- The path that will be used in the redirect response instead of the one
|
|
that was supplied in the request. pathRedirect cannot be supplied together
|
|
with prefixRedirect. Supply one alone or neither. If neither is supplied,
|
|
the path of the original request will be used for the redirect. The value
|
|
must be between 1 and 1024 characters.
|
|
returned: success
|
|
type: str
|
|
prefixRedirect:
|
|
description:
|
|
- The prefix that replaces the prefixMatch specified in the HttpRouteRuleMatch,
|
|
retaining the remaining portion of the URL before redirecting the request.
|
|
- prefixRedirect cannot be supplied together with pathRedirect. Supply one
|
|
alone or neither. If neither is supplied, the path of the original request
|
|
will be used for the redirect. The value must be between 1 and 1024 characters.
|
|
returned: success
|
|
type: str
|
|
redirectResponseCode:
|
|
description:
|
|
- 'The HTTP Status code to use for this RedirectAction. Supported values
|
|
are: * MOVED_PERMANENTLY_DEFAULT, which is the default value and corresponds
|
|
to 301.'
|
|
- "* FOUND, which corresponds to 302."
|
|
- "* SEE_OTHER which corresponds to 303."
|
|
- "* TEMPORARY_REDIRECT, which corresponds to 307. In this case, the request
|
|
method will be retained."
|
|
- "* PERMANENT_REDIRECT, which corresponds to 308. In this case, the request
|
|
method will be retained."
|
|
returned: success
|
|
type: str
|
|
stripQuery:
|
|
description:
|
|
- If set to true, any accompanying query portion of the original URL is
|
|
removed prior to redirecting the request. If set to false, the query portion
|
|
of the original URL is retained.
|
|
returned: success
|
|
type: bool
|
|
tests:
|
|
description:
|
|
- The list of expected URL mappings. Requests to update this UrlMap will succeed
|
|
only if all of the test cases pass.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
description:
|
|
description:
|
|
- Description of this test case.
|
|
returned: success
|
|
type: str
|
|
host:
|
|
description:
|
|
- Host portion of the URL.
|
|
returned: success
|
|
type: str
|
|
path:
|
|
description:
|
|
- Path portion of the URL.
|
|
returned: success
|
|
type: str
|
|
service:
|
|
description:
|
|
- A reference to expected RegionBackendService resource the given URL should
|
|
be mapped to.
|
|
returned: success
|
|
type: dict
|
|
defaultUrlRedirect:
|
|
description:
|
|
- When none of the specified hostRules match, the request is redirected to a URL
|
|
specified by defaultUrlRedirect. If defaultUrlRedirect is specified, defaultService
|
|
or defaultRouteAction must not be set.
|
|
returned: success
|
|
type: complex
|
|
contains:
|
|
hostRedirect:
|
|
description:
|
|
- The host that will be used in the redirect response instead of the one that
|
|
was supplied in the request. The value must be between 1 and 255 characters.
|
|
returned: success
|
|
type: str
|
|
httpsRedirect:
|
|
description:
|
|
- If set to true, the URL scheme in the redirected request is set to https.
|
|
If set to false, the URL scheme of the redirected request will remain the
|
|
same as that of the request. This must only be set for UrlMaps used in TargetHttpProxys.
|
|
Setting this true for TargetHttpsProxy is not permitted. The default is set
|
|
to false.
|
|
returned: success
|
|
type: bool
|
|
pathRedirect:
|
|
description:
|
|
- The path that will be used in the redirect response instead of the one that
|
|
was supplied in the request. pathRedirect cannot be supplied together with
|
|
prefixRedirect. Supply one alone or neither. If neither is supplied, the path
|
|
of the original request will be used for the redirect. The value must be between
|
|
1 and 1024 characters.
|
|
returned: success
|
|
type: str
|
|
prefixRedirect:
|
|
description:
|
|
- The prefix that replaces the prefixMatch specified in the HttpRouteRuleMatch,
|
|
retaining the remaining portion of the URL before redirecting the request.
|
|
- prefixRedirect cannot be supplied together with pathRedirect. Supply one alone
|
|
or neither. If neither is supplied, the path of the original request will
|
|
be used for the redirect. The value must be between 1 and 1024 characters.
|
|
returned: success
|
|
type: str
|
|
redirectResponseCode:
|
|
description:
|
|
- 'The HTTP Status code to use for this RedirectAction. Supported values are:
|
|
* MOVED_PERMANENTLY_DEFAULT, which is the default value and corresponds to
|
|
301.'
|
|
- "* FOUND, which corresponds to 302."
|
|
- "* SEE_OTHER which corresponds to 303."
|
|
- "* TEMPORARY_REDIRECT, which corresponds to 307. In this case, the request
|
|
method will be retained."
|
|
- "* PERMANENT_REDIRECT, which corresponds to 308. In this case, the request
|
|
method will be retained."
|
|
returned: success
|
|
type: str
|
|
stripQuery:
|
|
description:
|
|
- If set to true, any accompanying query portion of the original URL is removed
|
|
prior to redirecting the request. If set to false, the query portion of the
|
|
original URL is retained.
|
|
returned: success
|
|
type: bool
|
|
region:
|
|
description:
|
|
- A reference to the region where the url map resides.
|
|
returned: success
|
|
type: str
|
|
'''
|
|
|
|
################################################################################
|
|
# Imports
|
|
################################################################################
|
|
|
|
from ansible_collections.google.cloud.plugins.module_utils.gcp_utils import (
|
|
navigate_hash,
|
|
GcpSession,
|
|
GcpModule,
|
|
GcpRequest,
|
|
remove_nones_from_dict,
|
|
replace_resource_dict,
|
|
)
|
|
import json
|
|
import time
|
|
|
|
################################################################################
|
|
# Main
|
|
################################################################################
|
|
|
|
|
|
def main():
|
|
"""Main function"""
|
|
|
|
module = GcpModule(
|
|
argument_spec=dict(
|
|
state=dict(default='present', choices=['present', 'absent'], type='str'),
|
|
default_service=dict(type='dict'),
|
|
description=dict(type='str'),
|
|
host_rules=dict(
|
|
type='list',
|
|
elements='dict',
|
|
options=dict(
|
|
description=dict(type='str'), hosts=dict(required=True, type='list', elements='str'), path_matcher=dict(required=True, type='str')
|
|
),
|
|
),
|
|
name=dict(required=True, type='str'),
|
|
path_matchers=dict(
|
|
type='list',
|
|
elements='dict',
|
|
options=dict(
|
|
default_service=dict(type='dict'),
|
|
description=dict(type='str'),
|
|
name=dict(required=True, type='str'),
|
|
route_rules=dict(
|
|
type='list',
|
|
elements='dict',
|
|
options=dict(
|
|
priority=dict(required=True, type='int'),
|
|
service=dict(type='dict'),
|
|
header_action=dict(
|
|
type='dict',
|
|
options=dict(
|
|
request_headers_to_add=dict(
|
|
type='list',
|
|
elements='dict',
|
|
options=dict(
|
|
header_name=dict(required=True, type='str'),
|
|
header_value=dict(required=True, type='str'),
|
|
replace=dict(required=True, type='bool'),
|
|
),
|
|
),
|
|
request_headers_to_remove=dict(type='list', elements='str'),
|
|
response_headers_to_add=dict(
|
|
type='list',
|
|
elements='dict',
|
|
options=dict(
|
|
header_name=dict(required=True, type='str'),
|
|
header_value=dict(required=True, type='str'),
|
|
replace=dict(required=True, type='bool'),
|
|
),
|
|
),
|
|
response_headers_to_remove=dict(type='list', elements='str'),
|
|
),
|
|
),
|
|
match_rules=dict(
|
|
type='list',
|
|
elements='dict',
|
|
options=dict(
|
|
full_path_match=dict(type='str'),
|
|
header_matches=dict(
|
|
type='list',
|
|
elements='dict',
|
|
options=dict(
|
|
exact_match=dict(type='str'),
|
|
header_name=dict(required=True, type='str'),
|
|
invert_match=dict(type='bool'),
|
|
prefix_match=dict(type='str'),
|
|
present_match=dict(type='bool'),
|
|
range_match=dict(
|
|
type='dict',
|
|
options=dict(range_end=dict(required=True, type='int'), range_start=dict(required=True, type='int')),
|
|
),
|
|
regex_match=dict(type='str'),
|
|
suffix_match=dict(type='str'),
|
|
),
|
|
),
|
|
ignore_case=dict(type='bool'),
|
|
metadata_filters=dict(
|
|
type='list',
|
|
elements='dict',
|
|
options=dict(
|
|
filter_labels=dict(
|
|
required=True,
|
|
type='list',
|
|
elements='dict',
|
|
options=dict(name=dict(required=True, type='str'), value=dict(required=True, type='str')),
|
|
),
|
|
filter_match_criteria=dict(required=True, type='str'),
|
|
),
|
|
),
|
|
prefix_match=dict(type='str'),
|
|
query_parameter_matches=dict(
|
|
type='list',
|
|
elements='dict',
|
|
options=dict(
|
|
exact_match=dict(type='str'),
|
|
name=dict(required=True, type='str'),
|
|
present_match=dict(type='bool'),
|
|
regex_match=dict(type='str'),
|
|
),
|
|
),
|
|
regex_match=dict(type='str'),
|
|
),
|
|
),
|
|
route_action=dict(
|
|
type='dict',
|
|
options=dict(
|
|
cors_policy=dict(
|
|
type='dict',
|
|
options=dict(
|
|
allow_credentials=dict(type='bool'),
|
|
allow_headers=dict(type='list', elements='str'),
|
|
allow_methods=dict(type='list', elements='str'),
|
|
allow_origin_regexes=dict(type='list', elements='str'),
|
|
allow_origins=dict(type='list', elements='str'),
|
|
disabled=dict(type='bool'),
|
|
expose_headers=dict(type='list', elements='str'),
|
|
max_age=dict(type='int'),
|
|
),
|
|
),
|
|
fault_injection_policy=dict(
|
|
type='dict',
|
|
options=dict(
|
|
abort=dict(type='dict', options=dict(http_status=dict(type='int'), percentage=dict(type='str'))),
|
|
delay=dict(
|
|
type='dict',
|
|
options=dict(
|
|
fixed_delay=dict(
|
|
type='dict', options=dict(nanos=dict(type='int'), seconds=dict(required=True, type='str'))
|
|
),
|
|
percentage=dict(type='str'),
|
|
),
|
|
),
|
|
),
|
|
),
|
|
request_mirror_policy=dict(type='dict', options=dict(backend_service=dict(required=True, type='dict'))),
|
|
retry_policy=dict(
|
|
type='dict',
|
|
options=dict(
|
|
num_retries=dict(required=True, type='int'),
|
|
per_try_timeout=dict(type='dict', options=dict(nanos=dict(type='int'), seconds=dict(required=True, type='str'))),
|
|
retry_conditions=dict(type='list', elements='str'),
|
|
),
|
|
),
|
|
timeout=dict(type='dict', options=dict(nanos=dict(type='int'), seconds=dict(required=True, type='str'))),
|
|
url_rewrite=dict(type='dict', options=dict(host_rewrite=dict(type='str'), path_prefix_rewrite=dict(type='str'))),
|
|
weighted_backend_services=dict(
|
|
type='list',
|
|
elements='dict',
|
|
options=dict(
|
|
backend_service=dict(required=True, type='dict'),
|
|
header_action=dict(
|
|
type='dict',
|
|
options=dict(
|
|
request_headers_to_add=dict(
|
|
type='list',
|
|
elements='dict',
|
|
options=dict(
|
|
header_name=dict(required=True, type='str'),
|
|
header_value=dict(required=True, type='str'),
|
|
replace=dict(required=True, type='bool'),
|
|
),
|
|
),
|
|
request_headers_to_remove=dict(type='list', elements='str'),
|
|
response_headers_to_add=dict(
|
|
type='list',
|
|
elements='dict',
|
|
options=dict(
|
|
header_name=dict(required=True, type='str'),
|
|
header_value=dict(required=True, type='str'),
|
|
replace=dict(required=True, type='bool'),
|
|
),
|
|
),
|
|
response_headers_to_remove=dict(type='list', elements='str'),
|
|
),
|
|
),
|
|
weight=dict(required=True, type='int'),
|
|
),
|
|
),
|
|
),
|
|
),
|
|
url_redirect=dict(
|
|
type='dict',
|
|
options=dict(
|
|
host_redirect=dict(type='str'),
|
|
https_redirect=dict(type='bool'),
|
|
path_redirect=dict(type='str'),
|
|
prefix_redirect=dict(type='str'),
|
|
redirect_response_code=dict(type='str'),
|
|
strip_query=dict(type='bool'),
|
|
),
|
|
),
|
|
),
|
|
),
|
|
path_rules=dict(
|
|
type='list',
|
|
elements='dict',
|
|
options=dict(
|
|
service=dict(type='dict'),
|
|
paths=dict(required=True, type='list', elements='str'),
|
|
route_action=dict(
|
|
type='dict',
|
|
options=dict(
|
|
cors_policy=dict(
|
|
type='dict',
|
|
options=dict(
|
|
allow_credentials=dict(type='bool'),
|
|
allow_headers=dict(type='list', elements='str'),
|
|
allow_methods=dict(type='list', elements='str'),
|
|
allow_origin_regexes=dict(type='list', elements='str'),
|
|
allow_origins=dict(type='list', elements='str'),
|
|
disabled=dict(required=True, type='bool'),
|
|
expose_headers=dict(type='list', elements='str'),
|
|
max_age=dict(type='int'),
|
|
),
|
|
),
|
|
fault_injection_policy=dict(
|
|
type='dict',
|
|
options=dict(
|
|
abort=dict(
|
|
type='dict',
|
|
options=dict(http_status=dict(required=True, type='int'), percentage=dict(required=True, type='str')),
|
|
),
|
|
delay=dict(
|
|
type='dict',
|
|
options=dict(
|
|
fixed_delay=dict(
|
|
required=True,
|
|
type='dict',
|
|
options=dict(nanos=dict(type='int'), seconds=dict(required=True, type='str')),
|
|
),
|
|
percentage=dict(required=True, type='str'),
|
|
),
|
|
),
|
|
),
|
|
),
|
|
request_mirror_policy=dict(type='dict', options=dict(backend_service=dict(required=True, type='dict'))),
|
|
retry_policy=dict(
|
|
type='dict',
|
|
options=dict(
|
|
num_retries=dict(type='int'),
|
|
per_try_timeout=dict(type='dict', options=dict(nanos=dict(type='int'), seconds=dict(required=True, type='str'))),
|
|
retry_conditions=dict(type='list', elements='str'),
|
|
),
|
|
),
|
|
timeout=dict(type='dict', options=dict(nanos=dict(type='int'), seconds=dict(required=True, type='str'))),
|
|
url_rewrite=dict(type='dict', options=dict(host_rewrite=dict(type='str'), path_prefix_rewrite=dict(type='str'))),
|
|
weighted_backend_services=dict(
|
|
type='list',
|
|
elements='dict',
|
|
options=dict(
|
|
backend_service=dict(required=True, type='dict'),
|
|
header_action=dict(
|
|
type='dict',
|
|
options=dict(
|
|
request_headers_to_add=dict(
|
|
type='list',
|
|
elements='dict',
|
|
options=dict(
|
|
header_name=dict(required=True, type='str'),
|
|
header_value=dict(required=True, type='str'),
|
|
replace=dict(required=True, type='bool'),
|
|
),
|
|
),
|
|
request_headers_to_remove=dict(type='list', elements='str'),
|
|
response_headers_to_add=dict(
|
|
type='list',
|
|
elements='dict',
|
|
options=dict(
|
|
header_name=dict(required=True, type='str'),
|
|
header_value=dict(required=True, type='str'),
|
|
replace=dict(required=True, type='bool'),
|
|
),
|
|
),
|
|
response_headers_to_remove=dict(type='list', elements='str'),
|
|
),
|
|
),
|
|
weight=dict(required=True, type='int'),
|
|
),
|
|
),
|
|
),
|
|
),
|
|
url_redirect=dict(
|
|
type='dict',
|
|
options=dict(
|
|
host_redirect=dict(type='str'),
|
|
https_redirect=dict(type='bool'),
|
|
path_redirect=dict(type='str'),
|
|
prefix_redirect=dict(type='str'),
|
|
redirect_response_code=dict(type='str'),
|
|
strip_query=dict(type='bool'),
|
|
),
|
|
),
|
|
),
|
|
),
|
|
default_url_redirect=dict(
|
|
type='dict',
|
|
options=dict(
|
|
host_redirect=dict(type='str'),
|
|
https_redirect=dict(type='bool'),
|
|
path_redirect=dict(type='str'),
|
|
prefix_redirect=dict(type='str'),
|
|
redirect_response_code=dict(type='str'),
|
|
strip_query=dict(type='bool'),
|
|
),
|
|
),
|
|
),
|
|
),
|
|
tests=dict(
|
|
type='list',
|
|
elements='dict',
|
|
options=dict(
|
|
description=dict(type='str'),
|
|
host=dict(required=True, type='str'),
|
|
path=dict(required=True, type='str'),
|
|
service=dict(required=True, type='dict'),
|
|
),
|
|
),
|
|
default_url_redirect=dict(
|
|
type='dict',
|
|
options=dict(
|
|
host_redirect=dict(type='str'),
|
|
https_redirect=dict(type='bool'),
|
|
path_redirect=dict(type='str'),
|
|
prefix_redirect=dict(type='str'),
|
|
redirect_response_code=dict(type='str'),
|
|
strip_query=dict(type='bool'),
|
|
),
|
|
),
|
|
region=dict(required=True, type='str'),
|
|
)
|
|
)
|
|
|
|
if not module.params['scopes']:
|
|
module.params['scopes'] = ['https://www.googleapis.com/auth/compute']
|
|
|
|
state = module.params['state']
|
|
kind = 'compute#urlMap'
|
|
|
|
fetch = fetch_resource(module, self_link(module), kind)
|
|
changed = False
|
|
|
|
if fetch:
|
|
if state == 'present':
|
|
if is_different(module, fetch):
|
|
update(module, self_link(module), kind)
|
|
fetch = fetch_resource(module, self_link(module), kind)
|
|
changed = True
|
|
else:
|
|
delete(module, self_link(module), kind)
|
|
fetch = {}
|
|
changed = True
|
|
else:
|
|
if state == 'present':
|
|
fetch = create(module, collection(module), kind)
|
|
changed = True
|
|
else:
|
|
fetch = {}
|
|
|
|
fetch.update({'changed': changed})
|
|
|
|
module.exit_json(**fetch)
|
|
|
|
|
|
def create(module, link, kind):
|
|
auth = GcpSession(module, 'compute')
|
|
return wait_for_operation(module, auth.post(link, resource_to_request(module)))
|
|
|
|
|
|
def update(module, link, kind):
|
|
auth = GcpSession(module, 'compute')
|
|
return wait_for_operation(module, auth.put(link, resource_to_request(module)))
|
|
|
|
|
|
def delete(module, link, kind):
|
|
auth = GcpSession(module, 'compute')
|
|
return wait_for_operation(module, auth.delete(link))
|
|
|
|
|
|
def resource_to_request(module):
|
|
request = {
|
|
u'kind': 'compute#urlMap',
|
|
u'defaultService': replace_resource_dict(module.params.get(u'default_service', {}), 'selfLink'),
|
|
u'description': module.params.get('description'),
|
|
u'hostRules': RegionUrlMapHostrulesArray(module.params.get('host_rules', []), module).to_request(),
|
|
u'name': module.params.get('name'),
|
|
u'pathMatchers': RegionUrlMapPathmatchersArray(module.params.get('path_matchers', []), module).to_request(),
|
|
u'tests': RegionUrlMapTestsArray(module.params.get('tests', []), module).to_request(),
|
|
u'defaultUrlRedirect': RegionUrlMapDefaulturlredirect(module.params.get('default_url_redirect', {}), module).to_request(),
|
|
}
|
|
return_vals = {}
|
|
for k, v in request.items():
|
|
if v or v is False:
|
|
return_vals[k] = v
|
|
|
|
return return_vals
|
|
|
|
|
|
def fetch_resource(module, link, kind, allow_not_found=True):
|
|
auth = GcpSession(module, 'compute')
|
|
return return_if_object(module, auth.get(link), kind, allow_not_found)
|
|
|
|
|
|
def self_link(module):
|
|
return "https://compute.googleapis.com/compute/v1/projects/{project}/regions/{region}/urlMaps/{name}".format(**module.params)
|
|
|
|
|
|
def collection(module):
|
|
return "https://compute.googleapis.com/compute/v1/projects/{project}/regions/{region}/urlMaps".format(**module.params)
|
|
|
|
|
|
def return_if_object(module, response, kind, allow_not_found=False):
|
|
# If not found, return nothing.
|
|
if allow_not_found and response.status_code == 404:
|
|
return None
|
|
|
|
# If no content, return nothing.
|
|
if response.status_code == 204:
|
|
return None
|
|
|
|
try:
|
|
module.raise_for_status(response)
|
|
result = response.json()
|
|
except getattr(json.decoder, 'JSONDecodeError', ValueError):
|
|
module.fail_json(msg="Invalid JSON response with error: %s" % response.text)
|
|
|
|
if navigate_hash(result, ['error', 'errors']):
|
|
module.fail_json(msg=navigate_hash(result, ['error', 'errors']))
|
|
|
|
return result
|
|
|
|
|
|
def is_different(module, response):
|
|
request = resource_to_request(module)
|
|
response = response_to_hash(module, response)
|
|
|
|
# Remove all output-only from response.
|
|
response_vals = {}
|
|
for k, v in response.items():
|
|
if k in request:
|
|
response_vals[k] = v
|
|
|
|
request_vals = {}
|
|
for k, v in request.items():
|
|
if k in response:
|
|
request_vals[k] = v
|
|
|
|
return GcpRequest(request_vals) != GcpRequest(response_vals)
|
|
|
|
|
|
# Remove unnecessary properties from the response.
|
|
# This is for doing comparisons with Ansible's current parameters.
|
|
def response_to_hash(module, response):
|
|
return {
|
|
u'creationTimestamp': response.get(u'creationTimestamp'),
|
|
u'defaultService': response.get(u'defaultService'),
|
|
u'description': response.get(u'description'),
|
|
u'hostRules': RegionUrlMapHostrulesArray(response.get(u'hostRules', []), module).from_response(),
|
|
u'id': response.get(u'id'),
|
|
u'fingerprint': response.get(u'fingerprint'),
|
|
u'name': module.params.get('name'),
|
|
u'pathMatchers': RegionUrlMapPathmatchersArray(response.get(u'pathMatchers', []), module).from_response(),
|
|
u'tests': RegionUrlMapTestsArray(response.get(u'tests', []), module).from_response(),
|
|
u'defaultUrlRedirect': RegionUrlMapDefaulturlredirect(response.get(u'defaultUrlRedirect', {}), module).from_response(),
|
|
}
|
|
|
|
|
|
def async_op_url(module, extra_data=None):
|
|
if extra_data is None:
|
|
extra_data = {}
|
|
url = "https://compute.googleapis.com/compute/v1/projects/{project}/regions/{region}/operations/{op_id}"
|
|
combined = extra_data.copy()
|
|
combined.update(module.params)
|
|
return url.format(**combined)
|
|
|
|
|
|
def wait_for_operation(module, response):
|
|
op_result = return_if_object(module, response, 'compute#operation')
|
|
if op_result is None:
|
|
return {}
|
|
status = navigate_hash(op_result, ['status'])
|
|
wait_done = wait_for_completion(status, op_result, module)
|
|
return fetch_resource(module, navigate_hash(wait_done, ['targetLink']), 'compute#urlMap')
|
|
|
|
|
|
def wait_for_completion(status, op_result, module):
|
|
op_id = navigate_hash(op_result, ['name'])
|
|
op_uri = async_op_url(module, {'op_id': op_id})
|
|
while status != 'DONE':
|
|
raise_if_errors(op_result, ['error', 'errors'], module)
|
|
time.sleep(1.0)
|
|
op_result = fetch_resource(module, op_uri, 'compute#operation', False)
|
|
status = navigate_hash(op_result, ['status'])
|
|
return op_result
|
|
|
|
|
|
def raise_if_errors(response, err_path, module):
|
|
errors = navigate_hash(response, err_path)
|
|
if errors is not None:
|
|
module.fail_json(msg=errors)
|
|
|
|
|
|
class RegionUrlMapHostrulesArray(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = []
|
|
|
|
def to_request(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._request_for_item(item))
|
|
return items
|
|
|
|
def from_response(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._response_from_item(item))
|
|
return items
|
|
|
|
def _request_for_item(self, item):
|
|
return remove_nones_from_dict({u'description': item.get('description'), u'hosts': item.get('hosts'), u'pathMatcher': item.get('path_matcher')})
|
|
|
|
def _response_from_item(self, item):
|
|
return remove_nones_from_dict({u'description': item.get(u'description'), u'hosts': item.get(u'hosts'), u'pathMatcher': item.get(u'pathMatcher')})
|
|
|
|
|
|
class RegionUrlMapPathmatchersArray(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = []
|
|
|
|
def to_request(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._request_for_item(item))
|
|
return items
|
|
|
|
def from_response(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._response_from_item(item))
|
|
return items
|
|
|
|
def _request_for_item(self, item):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'defaultService': replace_resource_dict(item.get(u'default_service', {}), 'selfLink'),
|
|
u'description': item.get('description'),
|
|
u'name': item.get('name'),
|
|
u'routeRules': RegionUrlMapRouterulesArray(item.get('route_rules', []), self.module).to_request(),
|
|
u'pathRules': RegionUrlMapPathrulesArray(item.get('path_rules', []), self.module).to_request(),
|
|
u'defaultUrlRedirect': RegionUrlMapDefaulturlredirect(item.get('default_url_redirect', {}), self.module).to_request(),
|
|
}
|
|
)
|
|
|
|
def _response_from_item(self, item):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'defaultService': item.get(u'defaultService'),
|
|
u'description': item.get(u'description'),
|
|
u'name': item.get(u'name'),
|
|
u'routeRules': RegionUrlMapRouterulesArray(item.get(u'routeRules', []), self.module).from_response(),
|
|
u'pathRules': RegionUrlMapPathrulesArray(item.get(u'pathRules', []), self.module).from_response(),
|
|
u'defaultUrlRedirect': RegionUrlMapDefaulturlredirect(item.get(u'defaultUrlRedirect', {}), self.module).from_response(),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapRouterulesArray(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = []
|
|
|
|
def to_request(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._request_for_item(item))
|
|
return items
|
|
|
|
def from_response(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._response_from_item(item))
|
|
return items
|
|
|
|
def _request_for_item(self, item):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'priority': item.get('priority'),
|
|
u'service': replace_resource_dict(item.get(u'service', {}), 'selfLink'),
|
|
u'headerAction': RegionUrlMapHeaderaction(item.get('header_action', {}), self.module).to_request(),
|
|
u'matchRules': RegionUrlMapMatchrulesArray(item.get('match_rules', []), self.module).to_request(),
|
|
u'routeAction': RegionUrlMapRouteaction(item.get('route_action', {}), self.module).to_request(),
|
|
u'urlRedirect': RegionUrlMapUrlredirect(item.get('url_redirect', {}), self.module).to_request(),
|
|
}
|
|
)
|
|
|
|
def _response_from_item(self, item):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'priority': item.get(u'priority'),
|
|
u'service': item.get(u'service'),
|
|
u'headerAction': RegionUrlMapHeaderaction(item.get(u'headerAction', {}), self.module).from_response(),
|
|
u'matchRules': RegionUrlMapMatchrulesArray(item.get(u'matchRules', []), self.module).from_response(),
|
|
u'routeAction': RegionUrlMapRouteaction(item.get(u'routeAction', {}), self.module).from_response(),
|
|
u'urlRedirect': RegionUrlMapUrlredirect(item.get(u'urlRedirect', {}), self.module).from_response(),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapHeaderaction(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'requestHeadersToAdd': RegionUrlMapRequestheaderstoaddArray(self.request.get('request_headers_to_add', []), self.module).to_request(),
|
|
u'requestHeadersToRemove': self.request.get('request_headers_to_remove'),
|
|
u'responseHeadersToAdd': RegionUrlMapResponseheaderstoaddArray(self.request.get('response_headers_to_add', []), self.module).to_request(),
|
|
u'responseHeadersToRemove': self.request.get('response_headers_to_remove'),
|
|
}
|
|
)
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'requestHeadersToAdd': RegionUrlMapRequestheaderstoaddArray(self.request.get(u'requestHeadersToAdd', []), self.module).from_response(),
|
|
u'requestHeadersToRemove': self.request.get(u'requestHeadersToRemove'),
|
|
u'responseHeadersToAdd': RegionUrlMapResponseheaderstoaddArray(self.request.get(u'responseHeadersToAdd', []), self.module).from_response(),
|
|
u'responseHeadersToRemove': self.request.get(u'responseHeadersToRemove'),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapRequestheaderstoaddArray(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = []
|
|
|
|
def to_request(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._request_for_item(item))
|
|
return items
|
|
|
|
def from_response(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._response_from_item(item))
|
|
return items
|
|
|
|
def _request_for_item(self, item):
|
|
return remove_nones_from_dict({u'headerName': item.get('header_name'), u'headerValue': item.get('header_value'), u'replace': item.get('replace')})
|
|
|
|
def _response_from_item(self, item):
|
|
return remove_nones_from_dict({u'headerName': item.get(u'headerName'), u'headerValue': item.get(u'headerValue'), u'replace': item.get(u'replace')})
|
|
|
|
|
|
class RegionUrlMapResponseheaderstoaddArray(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = []
|
|
|
|
def to_request(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._request_for_item(item))
|
|
return items
|
|
|
|
def from_response(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._response_from_item(item))
|
|
return items
|
|
|
|
def _request_for_item(self, item):
|
|
return remove_nones_from_dict({u'headerName': item.get('header_name'), u'headerValue': item.get('header_value'), u'replace': item.get('replace')})
|
|
|
|
def _response_from_item(self, item):
|
|
return remove_nones_from_dict({u'headerName': item.get(u'headerName'), u'headerValue': item.get(u'headerValue'), u'replace': item.get(u'replace')})
|
|
|
|
|
|
class RegionUrlMapMatchrulesArray(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = []
|
|
|
|
def to_request(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._request_for_item(item))
|
|
return items
|
|
|
|
def from_response(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._response_from_item(item))
|
|
return items
|
|
|
|
def _request_for_item(self, item):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'fullPathMatch': item.get('full_path_match'),
|
|
u'headerMatches': RegionUrlMapHeadermatchesArray(item.get('header_matches', []), self.module).to_request(),
|
|
u'ignoreCase': item.get('ignore_case'),
|
|
u'metadataFilters': RegionUrlMapMetadatafiltersArray(item.get('metadata_filters', []), self.module).to_request(),
|
|
u'prefixMatch': item.get('prefix_match'),
|
|
u'queryParameterMatches': RegionUrlMapQueryparametermatchesArray(item.get('query_parameter_matches', []), self.module).to_request(),
|
|
u'regexMatch': item.get('regex_match'),
|
|
}
|
|
)
|
|
|
|
def _response_from_item(self, item):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'fullPathMatch': item.get(u'fullPathMatch'),
|
|
u'headerMatches': RegionUrlMapHeadermatchesArray(item.get(u'headerMatches', []), self.module).from_response(),
|
|
u'ignoreCase': item.get(u'ignoreCase'),
|
|
u'metadataFilters': RegionUrlMapMetadatafiltersArray(item.get(u'metadataFilters', []), self.module).from_response(),
|
|
u'prefixMatch': item.get(u'prefixMatch'),
|
|
u'queryParameterMatches': RegionUrlMapQueryparametermatchesArray(item.get(u'queryParameterMatches', []), self.module).from_response(),
|
|
u'regexMatch': item.get(u'regexMatch'),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapHeadermatchesArray(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = []
|
|
|
|
def to_request(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._request_for_item(item))
|
|
return items
|
|
|
|
def from_response(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._response_from_item(item))
|
|
return items
|
|
|
|
def _request_for_item(self, item):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'exactMatch': item.get('exact_match'),
|
|
u'headerName': item.get('header_name'),
|
|
u'invertMatch': item.get('invert_match'),
|
|
u'prefixMatch': item.get('prefix_match'),
|
|
u'presentMatch': item.get('present_match'),
|
|
u'rangeMatch': RegionUrlMapRangematch(item.get('range_match', {}), self.module).to_request(),
|
|
u'regexMatch': item.get('regex_match'),
|
|
u'suffixMatch': item.get('suffix_match'),
|
|
}
|
|
)
|
|
|
|
def _response_from_item(self, item):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'exactMatch': item.get(u'exactMatch'),
|
|
u'headerName': item.get(u'headerName'),
|
|
u'invertMatch': item.get(u'invertMatch'),
|
|
u'prefixMatch': item.get(u'prefixMatch'),
|
|
u'presentMatch': item.get(u'presentMatch'),
|
|
u'rangeMatch': RegionUrlMapRangematch(item.get(u'rangeMatch', {}), self.module).from_response(),
|
|
u'regexMatch': item.get(u'regexMatch'),
|
|
u'suffixMatch': item.get(u'suffixMatch'),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapRangematch(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict({u'rangeEnd': self.request.get('range_end'), u'rangeStart': self.request.get('range_start')})
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict({u'rangeEnd': self.request.get(u'rangeEnd'), u'rangeStart': self.request.get(u'rangeStart')})
|
|
|
|
|
|
class RegionUrlMapMetadatafiltersArray(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = []
|
|
|
|
def to_request(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._request_for_item(item))
|
|
return items
|
|
|
|
def from_response(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._response_from_item(item))
|
|
return items
|
|
|
|
def _request_for_item(self, item):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'filterLabels': RegionUrlMapFilterlabelsArray(item.get('filter_labels', []), self.module).to_request(),
|
|
u'filterMatchCriteria': item.get('filter_match_criteria'),
|
|
}
|
|
)
|
|
|
|
def _response_from_item(self, item):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'filterLabels': RegionUrlMapFilterlabelsArray(item.get(u'filterLabels', []), self.module).from_response(),
|
|
u'filterMatchCriteria': item.get(u'filterMatchCriteria'),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapFilterlabelsArray(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = []
|
|
|
|
def to_request(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._request_for_item(item))
|
|
return items
|
|
|
|
def from_response(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._response_from_item(item))
|
|
return items
|
|
|
|
def _request_for_item(self, item):
|
|
return remove_nones_from_dict({u'name': item.get('name'), u'value': item.get('value')})
|
|
|
|
def _response_from_item(self, item):
|
|
return remove_nones_from_dict({u'name': item.get(u'name'), u'value': item.get(u'value')})
|
|
|
|
|
|
class RegionUrlMapQueryparametermatchesArray(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = []
|
|
|
|
def to_request(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._request_for_item(item))
|
|
return items
|
|
|
|
def from_response(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._response_from_item(item))
|
|
return items
|
|
|
|
def _request_for_item(self, item):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'exactMatch': item.get('exact_match'),
|
|
u'name': item.get('name'),
|
|
u'presentMatch': item.get('present_match'),
|
|
u'regexMatch': item.get('regex_match'),
|
|
}
|
|
)
|
|
|
|
def _response_from_item(self, item):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'exactMatch': item.get(u'exactMatch'),
|
|
u'name': item.get(u'name'),
|
|
u'presentMatch': item.get(u'presentMatch'),
|
|
u'regexMatch': item.get(u'regexMatch'),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapRouteaction(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'corsPolicy': RegionUrlMapCorspolicy(self.request.get('cors_policy', {}), self.module).to_request(),
|
|
u'faultInjectionPolicy': RegionUrlMapFaultinjectionpolicy(self.request.get('fault_injection_policy', {}), self.module).to_request(),
|
|
u'requestMirrorPolicy': RegionUrlMapRequestmirrorpolicy(self.request.get('request_mirror_policy', {}), self.module).to_request(),
|
|
u'retryPolicy': RegionUrlMapRetrypolicy(self.request.get('retry_policy', {}), self.module).to_request(),
|
|
u'timeout': RegionUrlMapTimeout(self.request.get('timeout', {}), self.module).to_request(),
|
|
u'urlRewrite': RegionUrlMapUrlrewrite(self.request.get('url_rewrite', {}), self.module).to_request(),
|
|
u'weightedBackendServices': RegionUrlMapWeightedbackendservicesArray(
|
|
self.request.get('weighted_backend_services', []), self.module
|
|
).to_request(),
|
|
}
|
|
)
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'corsPolicy': RegionUrlMapCorspolicy(self.request.get(u'corsPolicy', {}), self.module).from_response(),
|
|
u'faultInjectionPolicy': RegionUrlMapFaultinjectionpolicy(self.request.get(u'faultInjectionPolicy', {}), self.module).from_response(),
|
|
u'requestMirrorPolicy': RegionUrlMapRequestmirrorpolicy(self.request.get(u'requestMirrorPolicy', {}), self.module).from_response(),
|
|
u'retryPolicy': RegionUrlMapRetrypolicy(self.request.get(u'retryPolicy', {}), self.module).from_response(),
|
|
u'timeout': RegionUrlMapTimeout(self.request.get(u'timeout', {}), self.module).from_response(),
|
|
u'urlRewrite': RegionUrlMapUrlrewrite(self.request.get(u'urlRewrite', {}), self.module).from_response(),
|
|
u'weightedBackendServices': RegionUrlMapWeightedbackendservicesArray(
|
|
self.request.get(u'weightedBackendServices', []), self.module
|
|
).from_response(),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapCorspolicy(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'allowCredentials': self.request.get('allow_credentials'),
|
|
u'allowHeaders': self.request.get('allow_headers'),
|
|
u'allowMethods': self.request.get('allow_methods'),
|
|
u'allowOriginRegexes': self.request.get('allow_origin_regexes'),
|
|
u'allowOrigins': self.request.get('allow_origins'),
|
|
u'disabled': self.request.get('disabled'),
|
|
u'exposeHeaders': self.request.get('expose_headers'),
|
|
u'maxAge': self.request.get('max_age'),
|
|
}
|
|
)
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'allowCredentials': self.request.get(u'allowCredentials'),
|
|
u'allowHeaders': self.request.get(u'allowHeaders'),
|
|
u'allowMethods': self.request.get(u'allowMethods'),
|
|
u'allowOriginRegexes': self.request.get(u'allowOriginRegexes'),
|
|
u'allowOrigins': self.request.get(u'allowOrigins'),
|
|
u'disabled': self.request.get(u'disabled'),
|
|
u'exposeHeaders': self.request.get(u'exposeHeaders'),
|
|
u'maxAge': self.request.get(u'maxAge'),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapFaultinjectionpolicy(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'abort': RegionUrlMapAbort(self.request.get('abort', {}), self.module).to_request(),
|
|
u'delay': RegionUrlMapDelay(self.request.get('delay', {}), self.module).to_request(),
|
|
}
|
|
)
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'abort': RegionUrlMapAbort(self.request.get(u'abort', {}), self.module).from_response(),
|
|
u'delay': RegionUrlMapDelay(self.request.get(u'delay', {}), self.module).from_response(),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapAbort(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict({u'httpStatus': self.request.get('http_status'), u'percentage': self.request.get('percentage')})
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict({u'httpStatus': self.request.get(u'httpStatus'), u'percentage': self.request.get(u'percentage')})
|
|
|
|
|
|
class RegionUrlMapDelay(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'fixedDelay': RegionUrlMapFixeddelay(self.request.get('fixed_delay', {}), self.module).to_request(),
|
|
u'percentage': self.request.get('percentage'),
|
|
}
|
|
)
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'fixedDelay': RegionUrlMapFixeddelay(self.request.get(u'fixedDelay', {}), self.module).from_response(),
|
|
u'percentage': self.request.get(u'percentage'),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapFixeddelay(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict({u'nanos': self.request.get('nanos'), u'seconds': self.request.get('seconds')})
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict({u'nanos': self.request.get(u'nanos'), u'seconds': self.request.get(u'seconds')})
|
|
|
|
|
|
class RegionUrlMapRequestmirrorpolicy(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict({u'backendService': replace_resource_dict(self.request.get(u'backend_service', {}), 'selfLink')})
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict({u'backendService': self.request.get(u'backendService')})
|
|
|
|
|
|
class RegionUrlMapRetrypolicy(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'numRetries': self.request.get('num_retries'),
|
|
u'perTryTimeout': RegionUrlMapPertrytimeout(self.request.get('per_try_timeout', {}), self.module).to_request(),
|
|
u'retryConditions': self.request.get('retry_conditions'),
|
|
}
|
|
)
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'numRetries': self.request.get(u'numRetries'),
|
|
u'perTryTimeout': RegionUrlMapPertrytimeout(self.request.get(u'perTryTimeout', {}), self.module).from_response(),
|
|
u'retryConditions': self.request.get(u'retryConditions'),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapPertrytimeout(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict({u'nanos': self.request.get('nanos'), u'seconds': self.request.get('seconds')})
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict({u'nanos': self.request.get(u'nanos'), u'seconds': self.request.get(u'seconds')})
|
|
|
|
|
|
class RegionUrlMapTimeout(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict({u'nanos': self.request.get('nanos'), u'seconds': self.request.get('seconds')})
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict({u'nanos': self.request.get(u'nanos'), u'seconds': self.request.get(u'seconds')})
|
|
|
|
|
|
class RegionUrlMapUrlrewrite(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict({u'hostRewrite': self.request.get('host_rewrite'), u'pathPrefixRewrite': self.request.get('path_prefix_rewrite')})
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict({u'hostRewrite': self.request.get(u'hostRewrite'), u'pathPrefixRewrite': self.request.get(u'pathPrefixRewrite')})
|
|
|
|
|
|
class RegionUrlMapWeightedbackendservicesArray(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = []
|
|
|
|
def to_request(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._request_for_item(item))
|
|
return items
|
|
|
|
def from_response(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._response_from_item(item))
|
|
return items
|
|
|
|
def _request_for_item(self, item):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'backendService': replace_resource_dict(item.get(u'backend_service', {}), 'selfLink'),
|
|
u'headerAction': RegionUrlMapHeaderaction(item.get('header_action', {}), self.module).to_request(),
|
|
u'weight': item.get('weight'),
|
|
}
|
|
)
|
|
|
|
def _response_from_item(self, item):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'backendService': item.get(u'backendService'),
|
|
u'headerAction': RegionUrlMapHeaderaction(item.get(u'headerAction', {}), self.module).from_response(),
|
|
u'weight': item.get(u'weight'),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapHeaderaction(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'requestHeadersToAdd': RegionUrlMapRequestheaderstoaddArray(self.request.get('request_headers_to_add', []), self.module).to_request(),
|
|
u'requestHeadersToRemove': self.request.get('request_headers_to_remove'),
|
|
u'responseHeadersToAdd': RegionUrlMapResponseheaderstoaddArray(self.request.get('response_headers_to_add', []), self.module).to_request(),
|
|
u'responseHeadersToRemove': self.request.get('response_headers_to_remove'),
|
|
}
|
|
)
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'requestHeadersToAdd': RegionUrlMapRequestheaderstoaddArray(self.request.get(u'requestHeadersToAdd', []), self.module).from_response(),
|
|
u'requestHeadersToRemove': self.request.get(u'requestHeadersToRemove'),
|
|
u'responseHeadersToAdd': RegionUrlMapResponseheaderstoaddArray(self.request.get(u'responseHeadersToAdd', []), self.module).from_response(),
|
|
u'responseHeadersToRemove': self.request.get(u'responseHeadersToRemove'),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapRequestheaderstoaddArray(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = []
|
|
|
|
def to_request(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._request_for_item(item))
|
|
return items
|
|
|
|
def from_response(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._response_from_item(item))
|
|
return items
|
|
|
|
def _request_for_item(self, item):
|
|
return remove_nones_from_dict({u'headerName': item.get('header_name'), u'headerValue': item.get('header_value'), u'replace': item.get('replace')})
|
|
|
|
def _response_from_item(self, item):
|
|
return remove_nones_from_dict({u'headerName': item.get(u'headerName'), u'headerValue': item.get(u'headerValue'), u'replace': item.get(u'replace')})
|
|
|
|
|
|
class RegionUrlMapResponseheaderstoaddArray(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = []
|
|
|
|
def to_request(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._request_for_item(item))
|
|
return items
|
|
|
|
def from_response(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._response_from_item(item))
|
|
return items
|
|
|
|
def _request_for_item(self, item):
|
|
return remove_nones_from_dict({u'headerName': item.get('header_name'), u'headerValue': item.get('header_value'), u'replace': item.get('replace')})
|
|
|
|
def _response_from_item(self, item):
|
|
return remove_nones_from_dict({u'headerName': item.get(u'headerName'), u'headerValue': item.get(u'headerValue'), u'replace': item.get(u'replace')})
|
|
|
|
|
|
class RegionUrlMapUrlredirect(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'hostRedirect': self.request.get('host_redirect'),
|
|
u'httpsRedirect': self.request.get('https_redirect'),
|
|
u'pathRedirect': self.request.get('path_redirect'),
|
|
u'prefixRedirect': self.request.get('prefix_redirect'),
|
|
u'redirectResponseCode': self.request.get('redirect_response_code'),
|
|
u'stripQuery': self.request.get('strip_query'),
|
|
}
|
|
)
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'hostRedirect': self.request.get(u'hostRedirect'),
|
|
u'httpsRedirect': self.request.get(u'httpsRedirect'),
|
|
u'pathRedirect': self.request.get(u'pathRedirect'),
|
|
u'prefixRedirect': self.request.get(u'prefixRedirect'),
|
|
u'redirectResponseCode': self.request.get(u'redirectResponseCode'),
|
|
u'stripQuery': self.request.get(u'stripQuery'),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapPathrulesArray(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = []
|
|
|
|
def to_request(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._request_for_item(item))
|
|
return items
|
|
|
|
def from_response(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._response_from_item(item))
|
|
return items
|
|
|
|
def _request_for_item(self, item):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'service': replace_resource_dict(item.get(u'service', {}), 'selfLink'),
|
|
u'paths': item.get('paths'),
|
|
u'routeAction': RegionUrlMapRouteaction(item.get('route_action', {}), self.module).to_request(),
|
|
u'urlRedirect': RegionUrlMapUrlredirect(item.get('url_redirect', {}), self.module).to_request(),
|
|
}
|
|
)
|
|
|
|
def _response_from_item(self, item):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'service': item.get(u'service'),
|
|
u'paths': item.get(u'paths'),
|
|
u'routeAction': RegionUrlMapRouteaction(item.get(u'routeAction', {}), self.module).from_response(),
|
|
u'urlRedirect': RegionUrlMapUrlredirect(item.get(u'urlRedirect', {}), self.module).from_response(),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapRouteaction(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'corsPolicy': RegionUrlMapCorspolicy(self.request.get('cors_policy', {}), self.module).to_request(),
|
|
u'faultInjectionPolicy': RegionUrlMapFaultinjectionpolicy(self.request.get('fault_injection_policy', {}), self.module).to_request(),
|
|
u'requestMirrorPolicy': RegionUrlMapRequestmirrorpolicy(self.request.get('request_mirror_policy', {}), self.module).to_request(),
|
|
u'retryPolicy': RegionUrlMapRetrypolicy(self.request.get('retry_policy', {}), self.module).to_request(),
|
|
u'timeout': RegionUrlMapTimeout(self.request.get('timeout', {}), self.module).to_request(),
|
|
u'urlRewrite': RegionUrlMapUrlrewrite(self.request.get('url_rewrite', {}), self.module).to_request(),
|
|
u'weightedBackendServices': RegionUrlMapWeightedbackendservicesArray(
|
|
self.request.get('weighted_backend_services', []), self.module
|
|
).to_request(),
|
|
}
|
|
)
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'corsPolicy': RegionUrlMapCorspolicy(self.request.get(u'corsPolicy', {}), self.module).from_response(),
|
|
u'faultInjectionPolicy': RegionUrlMapFaultinjectionpolicy(self.request.get(u'faultInjectionPolicy', {}), self.module).from_response(),
|
|
u'requestMirrorPolicy': RegionUrlMapRequestmirrorpolicy(self.request.get(u'requestMirrorPolicy', {}), self.module).from_response(),
|
|
u'retryPolicy': RegionUrlMapRetrypolicy(self.request.get(u'retryPolicy', {}), self.module).from_response(),
|
|
u'timeout': RegionUrlMapTimeout(self.request.get(u'timeout', {}), self.module).from_response(),
|
|
u'urlRewrite': RegionUrlMapUrlrewrite(self.request.get(u'urlRewrite', {}), self.module).from_response(),
|
|
u'weightedBackendServices': RegionUrlMapWeightedbackendservicesArray(
|
|
self.request.get(u'weightedBackendServices', []), self.module
|
|
).from_response(),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapCorspolicy(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'allowCredentials': self.request.get('allow_credentials'),
|
|
u'allowHeaders': self.request.get('allow_headers'),
|
|
u'allowMethods': self.request.get('allow_methods'),
|
|
u'allowOriginRegexes': self.request.get('allow_origin_regexes'),
|
|
u'allowOrigins': self.request.get('allow_origins'),
|
|
u'disabled': self.request.get('disabled'),
|
|
u'exposeHeaders': self.request.get('expose_headers'),
|
|
u'maxAge': self.request.get('max_age'),
|
|
}
|
|
)
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'allowCredentials': self.request.get(u'allowCredentials'),
|
|
u'allowHeaders': self.request.get(u'allowHeaders'),
|
|
u'allowMethods': self.request.get(u'allowMethods'),
|
|
u'allowOriginRegexes': self.request.get(u'allowOriginRegexes'),
|
|
u'allowOrigins': self.request.get(u'allowOrigins'),
|
|
u'disabled': self.request.get(u'disabled'),
|
|
u'exposeHeaders': self.request.get(u'exposeHeaders'),
|
|
u'maxAge': self.request.get(u'maxAge'),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapFaultinjectionpolicy(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'abort': RegionUrlMapAbort(self.request.get('abort', {}), self.module).to_request(),
|
|
u'delay': RegionUrlMapDelay(self.request.get('delay', {}), self.module).to_request(),
|
|
}
|
|
)
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'abort': RegionUrlMapAbort(self.request.get(u'abort', {}), self.module).from_response(),
|
|
u'delay': RegionUrlMapDelay(self.request.get(u'delay', {}), self.module).from_response(),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapAbort(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict({u'httpStatus': self.request.get('http_status'), u'percentage': self.request.get('percentage')})
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict({u'httpStatus': self.request.get(u'httpStatus'), u'percentage': self.request.get(u'percentage')})
|
|
|
|
|
|
class RegionUrlMapDelay(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'fixedDelay': RegionUrlMapFixeddelay(self.request.get('fixed_delay', {}), self.module).to_request(),
|
|
u'percentage': self.request.get('percentage'),
|
|
}
|
|
)
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'fixedDelay': RegionUrlMapFixeddelay(self.request.get(u'fixedDelay', {}), self.module).from_response(),
|
|
u'percentage': self.request.get(u'percentage'),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapFixeddelay(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict({u'nanos': self.request.get('nanos'), u'seconds': self.request.get('seconds')})
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict({u'nanos': self.request.get(u'nanos'), u'seconds': self.request.get(u'seconds')})
|
|
|
|
|
|
class RegionUrlMapRequestmirrorpolicy(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict({u'backendService': replace_resource_dict(self.request.get(u'backend_service', {}), 'selfLink')})
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict({u'backendService': self.request.get(u'backendService')})
|
|
|
|
|
|
class RegionUrlMapRetrypolicy(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'numRetries': self.request.get('num_retries'),
|
|
u'perTryTimeout': RegionUrlMapPertrytimeout(self.request.get('per_try_timeout', {}), self.module).to_request(),
|
|
u'retryConditions': self.request.get('retry_conditions'),
|
|
}
|
|
)
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'numRetries': self.request.get(u'numRetries'),
|
|
u'perTryTimeout': RegionUrlMapPertrytimeout(self.request.get(u'perTryTimeout', {}), self.module).from_response(),
|
|
u'retryConditions': self.request.get(u'retryConditions'),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapPertrytimeout(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict({u'nanos': self.request.get('nanos'), u'seconds': self.request.get('seconds')})
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict({u'nanos': self.request.get(u'nanos'), u'seconds': self.request.get(u'seconds')})
|
|
|
|
|
|
class RegionUrlMapTimeout(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict({u'nanos': self.request.get('nanos'), u'seconds': self.request.get('seconds')})
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict({u'nanos': self.request.get(u'nanos'), u'seconds': self.request.get(u'seconds')})
|
|
|
|
|
|
class RegionUrlMapUrlrewrite(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict({u'hostRewrite': self.request.get('host_rewrite'), u'pathPrefixRewrite': self.request.get('path_prefix_rewrite')})
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict({u'hostRewrite': self.request.get(u'hostRewrite'), u'pathPrefixRewrite': self.request.get(u'pathPrefixRewrite')})
|
|
|
|
|
|
class RegionUrlMapWeightedbackendservicesArray(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = []
|
|
|
|
def to_request(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._request_for_item(item))
|
|
return items
|
|
|
|
def from_response(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._response_from_item(item))
|
|
return items
|
|
|
|
def _request_for_item(self, item):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'backendService': replace_resource_dict(item.get(u'backend_service', {}), 'selfLink'),
|
|
u'headerAction': RegionUrlMapHeaderaction(item.get('header_action', {}), self.module).to_request(),
|
|
u'weight': item.get('weight'),
|
|
}
|
|
)
|
|
|
|
def _response_from_item(self, item):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'backendService': item.get(u'backendService'),
|
|
u'headerAction': RegionUrlMapHeaderaction(item.get(u'headerAction', {}), self.module).from_response(),
|
|
u'weight': item.get(u'weight'),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapHeaderaction(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'requestHeadersToAdd': RegionUrlMapRequestheaderstoaddArray(self.request.get('request_headers_to_add', []), self.module).to_request(),
|
|
u'requestHeadersToRemove': self.request.get('request_headers_to_remove'),
|
|
u'responseHeadersToAdd': RegionUrlMapResponseheaderstoaddArray(self.request.get('response_headers_to_add', []), self.module).to_request(),
|
|
u'responseHeadersToRemove': self.request.get('response_headers_to_remove'),
|
|
}
|
|
)
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'requestHeadersToAdd': RegionUrlMapRequestheaderstoaddArray(self.request.get(u'requestHeadersToAdd', []), self.module).from_response(),
|
|
u'requestHeadersToRemove': self.request.get(u'requestHeadersToRemove'),
|
|
u'responseHeadersToAdd': RegionUrlMapResponseheaderstoaddArray(self.request.get(u'responseHeadersToAdd', []), self.module).from_response(),
|
|
u'responseHeadersToRemove': self.request.get(u'responseHeadersToRemove'),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapRequestheaderstoaddArray(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = []
|
|
|
|
def to_request(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._request_for_item(item))
|
|
return items
|
|
|
|
def from_response(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._response_from_item(item))
|
|
return items
|
|
|
|
def _request_for_item(self, item):
|
|
return remove_nones_from_dict({u'headerName': item.get('header_name'), u'headerValue': item.get('header_value'), u'replace': item.get('replace')})
|
|
|
|
def _response_from_item(self, item):
|
|
return remove_nones_from_dict({u'headerName': item.get(u'headerName'), u'headerValue': item.get(u'headerValue'), u'replace': item.get(u'replace')})
|
|
|
|
|
|
class RegionUrlMapResponseheaderstoaddArray(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = []
|
|
|
|
def to_request(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._request_for_item(item))
|
|
return items
|
|
|
|
def from_response(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._response_from_item(item))
|
|
return items
|
|
|
|
def _request_for_item(self, item):
|
|
return remove_nones_from_dict({u'headerName': item.get('header_name'), u'headerValue': item.get('header_value'), u'replace': item.get('replace')})
|
|
|
|
def _response_from_item(self, item):
|
|
return remove_nones_from_dict({u'headerName': item.get(u'headerName'), u'headerValue': item.get(u'headerValue'), u'replace': item.get(u'replace')})
|
|
|
|
|
|
class RegionUrlMapUrlredirect(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'hostRedirect': self.request.get('host_redirect'),
|
|
u'httpsRedirect': self.request.get('https_redirect'),
|
|
u'pathRedirect': self.request.get('path_redirect'),
|
|
u'prefixRedirect': self.request.get('prefix_redirect'),
|
|
u'redirectResponseCode': self.request.get('redirect_response_code'),
|
|
u'stripQuery': self.request.get('strip_query'),
|
|
}
|
|
)
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'hostRedirect': self.request.get(u'hostRedirect'),
|
|
u'httpsRedirect': self.request.get(u'httpsRedirect'),
|
|
u'pathRedirect': self.request.get(u'pathRedirect'),
|
|
u'prefixRedirect': self.request.get(u'prefixRedirect'),
|
|
u'redirectResponseCode': self.request.get(u'redirectResponseCode'),
|
|
u'stripQuery': self.request.get(u'stripQuery'),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapDefaulturlredirect(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'hostRedirect': self.request.get('host_redirect'),
|
|
u'httpsRedirect': self.request.get('https_redirect'),
|
|
u'pathRedirect': self.request.get('path_redirect'),
|
|
u'prefixRedirect': self.request.get('prefix_redirect'),
|
|
u'redirectResponseCode': self.request.get('redirect_response_code'),
|
|
u'stripQuery': self.request.get('strip_query'),
|
|
}
|
|
)
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'hostRedirect': self.request.get(u'hostRedirect'),
|
|
u'httpsRedirect': self.request.get(u'httpsRedirect'),
|
|
u'pathRedirect': self.request.get(u'pathRedirect'),
|
|
u'prefixRedirect': self.request.get(u'prefixRedirect'),
|
|
u'redirectResponseCode': self.request.get(u'redirectResponseCode'),
|
|
u'stripQuery': self.request.get(u'stripQuery'),
|
|
}
|
|
)
|
|
|
|
|
|
class RegionUrlMapTestsArray(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = []
|
|
|
|
def to_request(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._request_for_item(item))
|
|
return items
|
|
|
|
def from_response(self):
|
|
items = []
|
|
for item in self.request:
|
|
items.append(self._response_from_item(item))
|
|
return items
|
|
|
|
def _request_for_item(self, item):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'description': item.get('description'),
|
|
u'host': item.get('host'),
|
|
u'path': item.get('path'),
|
|
u'service': replace_resource_dict(item.get(u'service', {}), 'selfLink'),
|
|
}
|
|
)
|
|
|
|
def _response_from_item(self, item):
|
|
return remove_nones_from_dict(
|
|
{u'description': item.get(u'description'), u'host': item.get(u'host'), u'path': item.get(u'path'), u'service': item.get(u'service')}
|
|
)
|
|
|
|
|
|
class RegionUrlMapDefaulturlredirect(object):
|
|
def __init__(self, request, module):
|
|
self.module = module
|
|
if request:
|
|
self.request = request
|
|
else:
|
|
self.request = {}
|
|
|
|
def to_request(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'hostRedirect': self.request.get('host_redirect'),
|
|
u'httpsRedirect': self.request.get('https_redirect'),
|
|
u'pathRedirect': self.request.get('path_redirect'),
|
|
u'prefixRedirect': self.request.get('prefix_redirect'),
|
|
u'redirectResponseCode': self.request.get('redirect_response_code'),
|
|
u'stripQuery': self.request.get('strip_query'),
|
|
}
|
|
)
|
|
|
|
def from_response(self):
|
|
return remove_nones_from_dict(
|
|
{
|
|
u'hostRedirect': self.request.get(u'hostRedirect'),
|
|
u'httpsRedirect': self.request.get(u'httpsRedirect'),
|
|
u'pathRedirect': self.request.get(u'pathRedirect'),
|
|
u'prefixRedirect': self.request.get(u'prefixRedirect'),
|
|
u'redirectResponseCode': self.request.get(u'redirectResponseCode'),
|
|
u'stripQuery': self.request.get(u'stripQuery'),
|
|
}
|
|
)
|
|
|
|
|
|
if __name__ == '__main__':
|
|
main()
|