mirror of
				https://github.com/ansible-collections/google.cloud.git
				synced 2025-10-25 05:24:05 -07:00 
			
		
		
		
	
		
			
				
	
	
		
			4976 lines
		
	
	
	
		
			227 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			4976 lines
		
	
	
	
		
			227 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
 | |
|                     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
 | |
|                 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
 | |
|                     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
 | |
|                     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
 | |
|                 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
 | |
|                 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
 | |
|                     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
 | |
|                 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
 | |
|                 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
 | |
|             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
 | |
|             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
 | |
|         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
 | |
|         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
 | |
|     - accesstoken
 | |
|   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
 | |
|   access_token:
 | |
|     description:
 | |
|     - An OAuth2 access token if credential type is accesstoken.
 | |
|     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()
 |