33267 lines
		
	
	
		
			1.3 MiB
		
	
	
	
	
	
			
		
		
	
	
			33267 lines
		
	
	
		
			1.3 MiB
		
	
	
	
	
	
| # Copyright 2015 Google Inc.
 | |
| #
 | |
| # Licensed under the Apache License, Version 2.0 (the "License");
 | |
| # you may not use this file except in compliance with the License.
 | |
| # You may obtain a copy of the License at
 | |
| #
 | |
| #      http://www.apache.org/licenses/LICENSE-2.0
 | |
| #
 | |
| # Unless required by applicable law or agreed to in writing, software
 | |
| # distributed under the License is distributed on an "AS IS" BASIS,
 | |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| # See the License for the specific language governing permissions and
 | |
| # limitations under the License.
 | |
| 
 | |
| require 'date'
 | |
| require 'google/apis/core/base_service'
 | |
| require 'google/apis/core/json_representation'
 | |
| require 'google/apis/core/hashable'
 | |
| require 'google/apis/errors'
 | |
| 
 | |
| module Google
 | |
|   module Apis
 | |
|     module ComputeAlpha
 | |
|       
 | |
|       # A specification of the type and number of accelerator cards attached to the
 | |
|       # instance.
 | |
|       class AcceleratorConfig
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The number of the guest accelerator cards exposed to this instance.
 | |
|         # Corresponds to the JSON property `acceleratorCount`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :accelerator_count
 | |
|       
 | |
|         # Full or partial URL of the accelerator type resource to attach to this
 | |
|         # instance. For example: projects/my-project/zones/us-central1-c/
 | |
|         # acceleratorTypes/nvidia-tesla-p100 If you are creating an instance template,
 | |
|         # specify only the accelerator name. See GPUs on Compute Engine for a full list
 | |
|         # of accelerator types.
 | |
|         # Corresponds to the JSON property `acceleratorType`
 | |
|         # @return [String]
 | |
|         attr_accessor :accelerator_type
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @accelerator_count = args[:accelerator_count] if args.key?(:accelerator_count)
 | |
|           @accelerator_type = args[:accelerator_type] if args.key?(:accelerator_type)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # An Accelerator Type resource. (== resource_for beta.acceleratorTypes ==) (==
 | |
|       # resource_for v1.acceleratorTypes ==)
 | |
|       class AcceleratorType
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # Deprecation status for a public resource.
 | |
|         # Corresponds to the JSON property `deprecated`
 | |
|         # @return [Google::Apis::ComputeAlpha::DeprecationStatus]
 | |
|         attr_accessor :deprecated
 | |
|       
 | |
|         # [Output Only] An optional textual description of the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] The type of the resource. Always compute#acceleratorType for
 | |
|         # accelerator types.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] Maximum accelerator cards allowed per instance.
 | |
|         # Corresponds to the JSON property `maximumCardsPerInstance`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :maximum_cards_per_instance
 | |
|       
 | |
|         # [Output Only] Name of the resource.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # [Output Only] Server-defined fully-qualified URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource's resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # [Output Only] The name of the zone where the accelerator type resides, such as
 | |
|         # us-central1-a. You must specify this field as part of the HTTP request URL. It
 | |
|         # is not settable as a field in the request body.
 | |
|         # Corresponds to the JSON property `zone`
 | |
|         # @return [String]
 | |
|         attr_accessor :zone
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @deprecated = args[:deprecated] if args.key?(:deprecated)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @maximum_cards_per_instance = args[:maximum_cards_per_instance] if args.key?(:maximum_cards_per_instance)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @zone = args[:zone] if args.key?(:zone)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class AcceleratorTypeAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of AcceleratorTypesScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::AcceleratorTypesScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#acceleratorTypeAggregatedList
 | |
|         # for aggregated lists of accelerator types.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::AcceleratorTypeAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::AcceleratorTypeAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of accelerator types.
 | |
|       class AcceleratorTypeList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of AcceleratorType resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::AcceleratorType>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#acceleratorTypeList for lists
 | |
|         # of accelerator types.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::AcceleratorTypeList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::AcceleratorTypeList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class AcceleratorTypesScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] A list of accelerator types contained in this scope.
 | |
|         # Corresponds to the JSON property `acceleratorTypes`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::AcceleratorType>]
 | |
|         attr_accessor :accelerator_types
 | |
|       
 | |
|         # [Output Only] An informational warning that appears when the accelerator types
 | |
|         # list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::AcceleratorTypesScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @accelerator_types = args[:accelerator_types] if args.key?(:accelerator_types)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] An informational warning that appears when the accelerator types
 | |
|         # list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::AcceleratorTypesScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # An access configuration attached to an instance's network interface. Only one
 | |
|       # access config per instance is supported.
 | |
|       class AccessConfig
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#accessConfig for access
 | |
|         # configs.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # The name of this access configuration. The default and recommended name is
 | |
|         # External NAT but you can use any arbitrary string you would like. For example,
 | |
|         # My external IP or Network Access.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # An external IP address associated with this instance. Specify an unused static
 | |
|         # external IP address available to the project or leave this field undefined to
 | |
|         # use an IP from a shared ephemeral IP address pool. If you specify a static
 | |
|         # external IP address, it must live in the same region as the zone of the
 | |
|         # instance.
 | |
|         # Corresponds to the JSON property `natIP`
 | |
|         # @return [String]
 | |
|         attr_accessor :nat_ip
 | |
|       
 | |
|         # This signifies the networking tier used for configuring this access
 | |
|         # configuration and can only take the following values: PREMIUM, STANDARD.
 | |
|         # If an AccessConfig is specified without a valid external IP address, an
 | |
|         # ephemeral IP will be created with this networkTier.
 | |
|         # If an AccessConfig with a valid external IP address is specified, it must
 | |
|         # match that of the networkTier associated with the Address resource owning that
 | |
|         # IP.
 | |
|         # Corresponds to the JSON property `networkTier`
 | |
|         # @return [String]
 | |
|         attr_accessor :network_tier
 | |
|       
 | |
|         # [Output Only] The public DNS domain name for the instance.
 | |
|         # Corresponds to the JSON property `publicDnsName`
 | |
|         # @return [String]
 | |
|         attr_accessor :public_dns_name
 | |
|       
 | |
|         # The DNS domain name for the public PTR record. This field can only be set when
 | |
|         # the set_public_ptr field is enabled.
 | |
|         # Corresponds to the JSON property `publicPtrDomainName`
 | |
|         # @return [String]
 | |
|         attr_accessor :public_ptr_domain_name
 | |
|       
 | |
|         # Specifies whether a public DNS ?A? record should be created for the external
 | |
|         # IP address of this access configuration.
 | |
|         # Corresponds to the JSON property `setPublicDns`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :set_public_dns
 | |
|         alias_method :set_public_dns?, :set_public_dns
 | |
|       
 | |
|         # Specifies whether a public DNS ?PTR? record should be created to map the
 | |
|         # external IP address of the instance to a DNS domain name.
 | |
|         # Corresponds to the JSON property `setPublicPtr`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :set_public_ptr
 | |
|         alias_method :set_public_ptr?, :set_public_ptr
 | |
|       
 | |
|         # The type of configuration. The default and only option is ONE_TO_ONE_NAT.
 | |
|         # Corresponds to the JSON property `type`
 | |
|         # @return [String]
 | |
|         attr_accessor :type
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @nat_ip = args[:nat_ip] if args.key?(:nat_ip)
 | |
|           @network_tier = args[:network_tier] if args.key?(:network_tier)
 | |
|           @public_dns_name = args[:public_dns_name] if args.key?(:public_dns_name)
 | |
|           @public_ptr_domain_name = args[:public_ptr_domain_name] if args.key?(:public_ptr_domain_name)
 | |
|           @set_public_dns = args[:set_public_dns] if args.key?(:set_public_dns)
 | |
|           @set_public_ptr = args[:set_public_ptr] if args.key?(:set_public_ptr)
 | |
|           @type = args[:type] if args.key?(:type)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A reserved address resource. (== resource_for beta.addresses ==) (==
 | |
|       # resource_for v1.addresses ==) (== resource_for beta.globalAddresses ==) (==
 | |
|       # resource_for v1.globalAddresses ==)
 | |
|       class Address
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The static IP address represented by this resource.
 | |
|         # Corresponds to the JSON property `address`
 | |
|         # @return [String]
 | |
|         attr_accessor :address
 | |
|       
 | |
|         # The type of address to reserve, either INTERNAL or EXTERNAL. If unspecified,
 | |
|         # defaults to EXTERNAL.
 | |
|         # Corresponds to the JSON property `addressType`
 | |
|         # @return [String]
 | |
|         attr_accessor :address_type
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # The IP Version that will be used by this address. Valid options are IPV4 or
 | |
|         # IPV6. This can only be specified for a global address.
 | |
|         # Corresponds to the JSON property `ipVersion`
 | |
|         # @return [String]
 | |
|         attr_accessor :ip_version
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#address for addresses.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # A fingerprint for the labels being applied to this Address, which is
 | |
|         # essentially a hash of the labels set used for optimistic locking. The
 | |
|         # fingerprint is initially generated by Compute Engine and changes after every
 | |
|         # request to modify or update labels. You must always provide an up-to-date
 | |
|         # fingerprint hash in order to update or change labels, otherwise the request
 | |
|         # will fail with error 412 conditionNotMet.
 | |
|         # To see the latest fingerprint, make a get() request to retrieve an Address.
 | |
|         # Corresponds to the JSON property `labelFingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :label_fingerprint
 | |
|       
 | |
|         # Labels to apply to this Address resource. These can be later modified by the
 | |
|         # setLabels method. Each label key/value must comply with RFC1035. Label values
 | |
|         # may be empty.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # The URL of the network in which to reserve the address. This field can only be
 | |
|         # used with INTERNAL type with VPC_PEERING purpose.
 | |
|         # Corresponds to the JSON property `network`
 | |
|         # @return [String]
 | |
|         attr_accessor :network
 | |
|       
 | |
|         # This signifies the networking tier used for configuring this Address and can
 | |
|         # only take the following values: PREMIUM, STANDARD. Global forwarding rules can
 | |
|         # only be Premium Tier. Regional forwarding rules can be either Premium or
 | |
|         # Standard Tier. Standard Tier addresses applied to regional forwarding rules
 | |
|         # can be used with any external load balancer. Regional forwarding rules in
 | |
|         # Premium Tier can only be used with a Network load balancer.
 | |
|         # If this field is not specified, it is assumed to be PREMIUM.
 | |
|         # Corresponds to the JSON property `networkTier`
 | |
|         # @return [String]
 | |
|         attr_accessor :network_tier
 | |
|       
 | |
|         # The prefix length if the resource reprensents an IP range.
 | |
|         # Corresponds to the JSON property `prefixLength`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :prefix_length
 | |
|       
 | |
|         # The purpose of resource, only used with INTERNAL type.
 | |
|         # Corresponds to the JSON property `purpose`
 | |
|         # @return [String]
 | |
|         attr_accessor :purpose
 | |
|       
 | |
|         # [Output Only] URL of the region where the regional address resides. This field
 | |
|         # is not applicable to global addresses. You must specify this field as part of
 | |
|         # the HTTP request URL. You cannot set this field in the request body.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # [Output Only] The status of the address, which can be one of RESERVING,
 | |
|         # RESERVED, or IN_USE. An address that is RESERVING is currently in the process
 | |
|         # of being reserved. A RESERVED address is currently reserved and available to
 | |
|         # use. An IN_USE address is currently being used by another resource and is not
 | |
|         # available.
 | |
|         # Corresponds to the JSON property `status`
 | |
|         # @return [String]
 | |
|         attr_accessor :status
 | |
|       
 | |
|         # The URL of the subnetwork in which to reserve the address. If an IP address is
 | |
|         # specified, it must be within the subnetwork's IP range. This field can only be
 | |
|         # used with INTERNAL type with GCE_ENDPOINT/DNS_RESOLVER purposes.
 | |
|         # Corresponds to the JSON property `subnetwork`
 | |
|         # @return [String]
 | |
|         attr_accessor :subnetwork
 | |
|       
 | |
|         # [Output Only] The URLs of the resources that are using this address.
 | |
|         # Corresponds to the JSON property `users`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :users
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @address = args[:address] if args.key?(:address)
 | |
|           @address_type = args[:address_type] if args.key?(:address_type)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @ip_version = args[:ip_version] if args.key?(:ip_version)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @network = args[:network] if args.key?(:network)
 | |
|           @network_tier = args[:network_tier] if args.key?(:network_tier)
 | |
|           @prefix_length = args[:prefix_length] if args.key?(:prefix_length)
 | |
|           @purpose = args[:purpose] if args.key?(:purpose)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @status = args[:status] if args.key?(:status)
 | |
|           @subnetwork = args[:subnetwork] if args.key?(:subnetwork)
 | |
|           @users = args[:users] if args.key?(:users)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class AddressAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of AddressesScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::AddressesScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#addressAggregatedList for
 | |
|         # aggregated lists of addresses.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::AddressAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::AddressAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of addresses.
 | |
|       class AddressList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of Address resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Address>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#addressList for lists of
 | |
|         # addresses.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::AddressList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::AddressList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class AddressesScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] A list of addresses contained in this scope.
 | |
|         # Corresponds to the JSON property `addresses`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Address>]
 | |
|         attr_accessor :addresses
 | |
|       
 | |
|         # [Output Only] Informational warning which replaces the list of addresses when
 | |
|         # the list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::AddressesScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @addresses = args[:addresses] if args.key?(:addresses)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning which replaces the list of addresses when
 | |
|         # the list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::AddressesScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # An alias IP range attached to an instance's network interface.
 | |
|       class AliasIpRange
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The IP CIDR range represented by this alias IP range. This IP CIDR range must
 | |
|         # belong to the specified subnetwork and cannot contain IP addresses reserved by
 | |
|         # system or used by other network interfaces. This range may be a single IP
 | |
|         # address (e.g. 10.2.3.4), a netmask (e.g. /24) or a CIDR format string (e.g. 10.
 | |
|         # 1.2.0/24).
 | |
|         # Corresponds to the JSON property `ipCidrRange`
 | |
|         # @return [String]
 | |
|         attr_accessor :ip_cidr_range
 | |
|       
 | |
|         # Optional subnetwork secondary range name specifying the secondary range from
 | |
|         # which to allocate the IP CIDR range for this alias IP range. If left
 | |
|         # unspecified, the primary range of the subnetwork will be used.
 | |
|         # Corresponds to the JSON property `subnetworkRangeName`
 | |
|         # @return [String]
 | |
|         attr_accessor :subnetwork_range_name
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @ip_cidr_range = args[:ip_cidr_range] if args.key?(:ip_cidr_range)
 | |
|           @subnetwork_range_name = args[:subnetwork_range_name] if args.key?(:subnetwork_range_name)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Allocation resource
 | |
|       class Allocation
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Full or partial url for commitment in which this allocation is to be created.
 | |
|         # This field is ignored when allocations are created during committment creation.
 | |
|         # Corresponds to the JSON property `commitment`
 | |
|         # @return [String]
 | |
|         attr_accessor :commitment
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#allocations for allocations.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # The name of the resource, provided by the client when initially creating the
 | |
|         # resource. The resource 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # [Output Only] Server-defined fully-qualified URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # This allocation type allows to pre allocate specific instance configuration.
 | |
|         # Corresponds to the JSON property `specificAllocation`
 | |
|         # @return [Google::Apis::ComputeAlpha::AllocationSpecificSkuAllocation]
 | |
|         attr_accessor :specific_allocation
 | |
|       
 | |
|         # Indicates whether the allocation can be consumed by VMs with "any allocation"
 | |
|         # defined. If the field is set, then only VMs that target the allocation by name
 | |
|         # using --allocation-affinity can consume this allocation.
 | |
|         # Corresponds to the JSON property `specificAllocationRequired`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :specific_allocation_required
 | |
|         alias_method :specific_allocation_required?, :specific_allocation_required
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `zone`
 | |
|         # @return [String]
 | |
|         attr_accessor :zone
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @commitment = args[:commitment] if args.key?(:commitment)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @specific_allocation = args[:specific_allocation] if args.key?(:specific_allocation)
 | |
|           @specific_allocation_required = args[:specific_allocation_required] if args.key?(:specific_allocation_required)
 | |
|           @zone = args[:zone] if args.key?(:zone)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # AllocationAffinity is the configuration of desired allocation which this
 | |
|       # instance could take capacity from.
 | |
|       class AllocationAffinity
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `consumeAllocationType`
 | |
|         # @return [String]
 | |
|         attr_accessor :consume_allocation_type
 | |
|       
 | |
|         # Corresponds to the label key of allocation resource.
 | |
|         # Corresponds to the JSON property `key`
 | |
|         # @return [String]
 | |
|         attr_accessor :key
 | |
|       
 | |
|         # Corresponds to the label values of allocation resource.
 | |
|         # Corresponds to the JSON property `values`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :values
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @consume_allocation_type = args[:consume_allocation_type] if args.key?(:consume_allocation_type)
 | |
|           @key = args[:key] if args.key?(:key)
 | |
|           @values = args[:values] if args.key?(:values)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of allocations.
 | |
|       class AllocationAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of Allocation resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::AllocationsScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::AllocationAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::AllocationAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class AllocationList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] A list of Allocation resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Allocation>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource.Always compute#allocationsList for listsof
 | |
|         # allocations
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::AllocationList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::AllocationList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # This allocation type allows to pre allocate specific instance configuration.
 | |
|       class AllocationSpecificSkuAllocation
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Specifies number of resources that are allocated.
 | |
|         # Corresponds to the JSON property `count`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :count
 | |
|       
 | |
|         # [OutputOnly] Indicates how many resource are in use.
 | |
|         # Corresponds to the JSON property `inUseCount`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :in_use_count
 | |
|       
 | |
|         # Properties of the SKU instances being reserved.
 | |
|         # Corresponds to the JSON property `instanceProperties`
 | |
|         # @return [Google::Apis::ComputeAlpha::AllocationSpecificSkuAllocationAllocatedInstanceProperties]
 | |
|         attr_accessor :instance_properties
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @count = args[:count] if args.key?(:count)
 | |
|           @in_use_count = args[:in_use_count] if args.key?(:in_use_count)
 | |
|           @instance_properties = args[:instance_properties] if args.key?(:instance_properties)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Properties of the SKU instances being reserved.
 | |
|       class AllocationSpecificSkuAllocationAllocatedInstanceProperties
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Specifies accelerator type and count.
 | |
|         # Corresponds to the JSON property `guestAccelerators`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::AcceleratorConfig>]
 | |
|         attr_accessor :guest_accelerators
 | |
|       
 | |
|         # Specifies amount of local ssd to reserve with each instance. The type of disk
 | |
|         # is local-ssd.
 | |
|         # Corresponds to the JSON property `localSsds`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::AllocationSpecificSkuAllocationAllocatedInstancePropertiesAllocatedDisk>]
 | |
|         attr_accessor :local_ssds
 | |
|       
 | |
|         # Specifies type of machine (name only) which has fixed number of vCPUs and
 | |
|         # fixed amount of memory. This also includes specifying custom machine type
 | |
|         # following custom-NUMBER_OF_CPUS-AMOUNT_OF_MEMORY pattern.
 | |
|         # Corresponds to the JSON property `machineType`
 | |
|         # @return [String]
 | |
|         attr_accessor :machine_type
 | |
|       
 | |
|         # Minimum cpu platform the allocation.
 | |
|         # Corresponds to the JSON property `minCpuPlatform`
 | |
|         # @return [String]
 | |
|         attr_accessor :min_cpu_platform
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @guest_accelerators = args[:guest_accelerators] if args.key?(:guest_accelerators)
 | |
|           @local_ssds = args[:local_ssds] if args.key?(:local_ssds)
 | |
|           @machine_type = args[:machine_type] if args.key?(:machine_type)
 | |
|           @min_cpu_platform = args[:min_cpu_platform] if args.key?(:min_cpu_platform)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class AllocationSpecificSkuAllocationAllocatedInstancePropertiesAllocatedDisk
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Specifies the size of the disk in base-2 GB.
 | |
|         # Corresponds to the JSON property `diskSizeGb`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :disk_size_gb
 | |
|       
 | |
|         # Specifies the disk interface to use for attaching this disk, which is either
 | |
|         # SCSI or NVME. The default is SCSI. For performance characteristics of SCSI
 | |
|         # over NVMe, see Local SSD performance.
 | |
|         # Corresponds to the JSON property `interface`
 | |
|         # @return [String]
 | |
|         attr_accessor :interface
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @disk_size_gb = args[:disk_size_gb] if args.key?(:disk_size_gb)
 | |
|           @interface = args[:interface] if args.key?(:interface)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class AllocationsScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of allocations contained in this scope.
 | |
|         # Corresponds to the JSON property `allocations`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Allocation>]
 | |
|         attr_accessor :allocations
 | |
|       
 | |
|         # Informational warning which replaces the list of allocations when the list is
 | |
|         # empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::AllocationsScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @allocations = args[:allocations] if args.key?(:allocations)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # Informational warning which replaces the list of allocations when the list is
 | |
|         # empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::AllocationsScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class AllocationsUpdateResourceShapeRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Number of allocated resources which are to be updated with minimum = 1 and
 | |
|         # maximum = 100.
 | |
|         # Corresponds to the JSON property `count`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :count
 | |
|       
 | |
|         # The name of destination allocation where the modified machines are added. If
 | |
|         # existing, its machine spec must match the modified machine spec. If non
 | |
|         # existing, new allocation with this name and modified machine spec is created
 | |
|         # automatically.
 | |
|         # Corresponds to the JSON property `destinationAllocation`
 | |
|         # @return [String]
 | |
|         attr_accessor :destination_allocation
 | |
|       
 | |
|         # Properties of the SKU instances being reserved.
 | |
|         # Corresponds to the JSON property `updatedResourceProperties`
 | |
|         # @return [Google::Apis::ComputeAlpha::AllocationSpecificSkuAllocationAllocatedInstanceProperties]
 | |
|         attr_accessor :updated_resource_properties
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @count = args[:count] if args.key?(:count)
 | |
|           @destination_allocation = args[:destination_allocation] if args.key?(:destination_allocation)
 | |
|           @updated_resource_properties = args[:updated_resource_properties] if args.key?(:updated_resource_properties)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # An instance-attached disk resource.
 | |
|       class AttachedDisk
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Specifies whether the disk will be auto-deleted when the instance is deleted (
 | |
|         # but not when the disk is detached from the instance).
 | |
|         # Corresponds to the JSON property `autoDelete`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :auto_delete
 | |
|         alias_method :auto_delete?, :auto_delete
 | |
|       
 | |
|         # Indicates that this is a boot disk. The virtual machine will use the first
 | |
|         # partition of the disk for its root filesystem.
 | |
|         # Corresponds to the JSON property `boot`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :boot
 | |
|         alias_method :boot?, :boot
 | |
|       
 | |
|         # Specifies a unique device name of your choice that is reflected into the /dev/
 | |
|         # disk/by-id/google-* tree of a Linux operating system running within the
 | |
|         # instance. This name can be used to reference the device for mounting, resizing,
 | |
|         # and so on, from within the instance.
 | |
|         # If not specified, the server chooses a default device name to apply to this
 | |
|         # disk, in the form persistent-disk-x, where x is a number assigned by Google
 | |
|         # Compute Engine. This field is only applicable for persistent disks.
 | |
|         # Corresponds to the JSON property `deviceName`
 | |
|         # @return [String]
 | |
|         attr_accessor :device_name
 | |
|       
 | |
|         # Represents a customer-supplied encryption key
 | |
|         # Corresponds to the JSON property `diskEncryptionKey`
 | |
|         # @return [Google::Apis::ComputeAlpha::CustomerEncryptionKey]
 | |
|         attr_accessor :disk_encryption_key
 | |
|       
 | |
|         # The size of the disk in base-2 GB. This supersedes disk_size_gb in
 | |
|         # InitializeParams.
 | |
|         # Corresponds to the JSON property `diskSizeGb`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :disk_size_gb
 | |
|       
 | |
|         # A list of features to enable on the guest operating system. Applicable only
 | |
|         # for bootable images. Read  Enabling guest operating system features to see a
 | |
|         # list of available options.
 | |
|         # Corresponds to the JSON property `guestOsFeatures`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::GuestOsFeature>]
 | |
|         attr_accessor :guest_os_features
 | |
|       
 | |
|         # [Output Only] A zero-based index to this disk, where 0 is reserved for the
 | |
|         # boot disk. If you have many disks attached to an instance, each disk would
 | |
|         # have a unique index number.
 | |
|         # Corresponds to the JSON property `index`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :index
 | |
|       
 | |
|         # [Input Only] Specifies the parameters for a new disk that will be created
 | |
|         # alongside the new instance. Use initialization parameters to create boot disks
 | |
|         # or local SSDs attached to the new instance.
 | |
|         # This property is mutually exclusive with the source property; you can only
 | |
|         # define one or the other, but not both.
 | |
|         # Corresponds to the JSON property `initializeParams`
 | |
|         # @return [Google::Apis::ComputeAlpha::AttachedDiskInitializeParams]
 | |
|         attr_accessor :initialize_params
 | |
|       
 | |
|         # Specifies the disk interface to use for attaching this disk, which is either
 | |
|         # SCSI or NVME. The default is SCSI. Persistent disks must always use SCSI and
 | |
|         # the request will fail if you attempt to attach a persistent disk in any other
 | |
|         # format than SCSI. Local SSDs can use either NVME or SCSI. For performance
 | |
|         # characteristics of SCSI over NVMe, see Local SSD performance.
 | |
|         # Corresponds to the JSON property `interface`
 | |
|         # @return [String]
 | |
|         attr_accessor :interface
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#attachedDisk for attached
 | |
|         # disks.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] Any valid publicly visible licenses.
 | |
|         # Corresponds to the JSON property `licenses`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :licenses
 | |
|       
 | |
|         # The mode in which to attach this disk, either READ_WRITE or READ_ONLY. If not
 | |
|         # specified, the default is to attach the disk in READ_WRITE mode.
 | |
|         # Corresponds to the JSON property `mode`
 | |
|         # @return [String]
 | |
|         attr_accessor :mode
 | |
|       
 | |
|         # For LocalSSD disks on VM Instances in STOPPED or SUSPENDED state, this field
 | |
|         # is set to PRESERVED if the LocalSSD data has been saved to a persistent
 | |
|         # location by customer request. (see the discard_local_ssd option on Stop/
 | |
|         # Suspend). Read-only in the api.
 | |
|         # Corresponds to the JSON property `savedState`
 | |
|         # @return [String]
 | |
|         attr_accessor :saved_state
 | |
|       
 | |
|         # Specifies a valid partial or full URL to an existing Persistent Disk resource.
 | |
|         # When creating a new instance, one of initializeParams.sourceImage or disks.
 | |
|         # source is required except for local SSD.
 | |
|         # If desired, you can also attach existing non-root persistent disks using this
 | |
|         # property. This field is only applicable for persistent disks.
 | |
|         # Note that for InstanceTemplate, specify the disk name, not the URL for the
 | |
|         # disk.
 | |
|         # Corresponds to the JSON property `source`
 | |
|         # @return [String]
 | |
|         attr_accessor :source
 | |
|       
 | |
|         # Specifies the type of the disk, either SCRATCH or PERSISTENT. If not specified,
 | |
|         # the default is PERSISTENT.
 | |
|         # Corresponds to the JSON property `type`
 | |
|         # @return [String]
 | |
|         attr_accessor :type
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @auto_delete = args[:auto_delete] if args.key?(:auto_delete)
 | |
|           @boot = args[:boot] if args.key?(:boot)
 | |
|           @device_name = args[:device_name] if args.key?(:device_name)
 | |
|           @disk_encryption_key = args[:disk_encryption_key] if args.key?(:disk_encryption_key)
 | |
|           @disk_size_gb = args[:disk_size_gb] if args.key?(:disk_size_gb)
 | |
|           @guest_os_features = args[:guest_os_features] if args.key?(:guest_os_features)
 | |
|           @index = args[:index] if args.key?(:index)
 | |
|           @initialize_params = args[:initialize_params] if args.key?(:initialize_params)
 | |
|           @interface = args[:interface] if args.key?(:interface)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @licenses = args[:licenses] if args.key?(:licenses)
 | |
|           @mode = args[:mode] if args.key?(:mode)
 | |
|           @saved_state = args[:saved_state] if args.key?(:saved_state)
 | |
|           @source = args[:source] if args.key?(:source)
 | |
|           @type = args[:type] if args.key?(:type)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # [Input Only] Specifies the parameters for a new disk that will be created
 | |
|       # alongside the new instance. Use initialization parameters to create boot disks
 | |
|       # or local SSDs attached to the new instance.
 | |
|       # This property is mutually exclusive with the source property; you can only
 | |
|       # define one or the other, but not both.
 | |
|       class AttachedDiskInitializeParams
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # An optional description. Provide this property when creating the disk.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # Specifies the disk name. If not specified, the default is to use the name of
 | |
|         # the instance. If the disk with the instance name exists already in the given
 | |
|         # zone/region, a new name will be automatically generated.
 | |
|         # Corresponds to the JSON property `diskName`
 | |
|         # @return [String]
 | |
|         attr_accessor :disk_name
 | |
|       
 | |
|         # Specifies the size of the disk in base-2 GB.
 | |
|         # Corresponds to the JSON property `diskSizeGb`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :disk_size_gb
 | |
|       
 | |
|         # Specifies the disk type to use to create the instance. If not specified, the
 | |
|         # default is pd-standard, specified using the full URL. For example:
 | |
|         # https://www.googleapis.com/compute/v1/projects/project/zones/zone/diskTypes/pd-
 | |
|         # standard
 | |
|         # Other values include pd-ssd and local-ssd. If you define this field, you can
 | |
|         # provide either the full or partial URL. For example, the following are valid
 | |
|         # values:
 | |
|         # - https://www.googleapis.com/compute/v1/projects/project/zones/zone/diskTypes/
 | |
|         # diskType
 | |
|         # - projects/project/zones/zone/diskTypes/diskType
 | |
|         # - zones/zone/diskTypes/diskType  Note that for InstanceTemplate, this is the
 | |
|         # name of the disk type, not URL.
 | |
|         # Corresponds to the JSON property `diskType`
 | |
|         # @return [String]
 | |
|         attr_accessor :disk_type
 | |
|       
 | |
|         # Labels to apply to this disk. These can be later modified by the disks.
 | |
|         # setLabels method. This field is only applicable for persistent disks.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         # The source image to create this disk. When creating a new instance, one of
 | |
|         # initializeParams.sourceImage or disks.source is required except for local SSD.
 | |
|         # To create a disk with one of the public operating system images, specify the
 | |
|         # image by its family name. For example, specify family/debian-9 to use the
 | |
|         # latest Debian 9 image:
 | |
|         # projects/debian-cloud/global/images/family/debian-9
 | |
|         # Alternatively, use a specific version of a public operating system image:
 | |
|         # projects/debian-cloud/global/images/debian-9-stretch-vYYYYMMDD
 | |
|         # To create a disk with a custom image that you created, specify the image name
 | |
|         # in the following format:
 | |
|         # global/images/my-custom-image
 | |
|         # You can also specify a custom image by its image family, which returns the
 | |
|         # latest version of the image in that family. Replace the image name with family/
 | |
|         # family-name:
 | |
|         # global/images/family/my-image-family
 | |
|         # If the source image is deleted later, this field will not be set.
 | |
|         # Corresponds to the JSON property `sourceImage`
 | |
|         # @return [String]
 | |
|         attr_accessor :source_image
 | |
|       
 | |
|         # Represents a customer-supplied encryption key
 | |
|         # Corresponds to the JSON property `sourceImageEncryptionKey`
 | |
|         # @return [Google::Apis::ComputeAlpha::CustomerEncryptionKey]
 | |
|         attr_accessor :source_image_encryption_key
 | |
|       
 | |
|         # The source snapshot to create this disk. When creating a new instance, one of
 | |
|         # initializeParams.sourceSnapshot or disks.source is required except for local
 | |
|         # SSD.
 | |
|         # To create a disk with a snapshot that you created, specify the snapshot name
 | |
|         # in the following format:
 | |
|         # global/snapshots/my-backup
 | |
|         # If the source snapshot is deleted later, this field will not be set.
 | |
|         # Corresponds to the JSON property `sourceSnapshot`
 | |
|         # @return [String]
 | |
|         attr_accessor :source_snapshot
 | |
|       
 | |
|         # Represents a customer-supplied encryption key
 | |
|         # Corresponds to the JSON property `sourceSnapshotEncryptionKey`
 | |
|         # @return [Google::Apis::ComputeAlpha::CustomerEncryptionKey]
 | |
|         attr_accessor :source_snapshot_encryption_key
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @disk_name = args[:disk_name] if args.key?(:disk_name)
 | |
|           @disk_size_gb = args[:disk_size_gb] if args.key?(:disk_size_gb)
 | |
|           @disk_type = args[:disk_type] if args.key?(:disk_type)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|           @source_image = args[:source_image] if args.key?(:source_image)
 | |
|           @source_image_encryption_key = args[:source_image_encryption_key] if args.key?(:source_image_encryption_key)
 | |
|           @source_snapshot = args[:source_snapshot] if args.key?(:source_snapshot)
 | |
|           @source_snapshot_encryption_key = args[:source_snapshot_encryption_key] if args.key?(:source_snapshot_encryption_key)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Specifies the audit configuration for a service. The configuration determines
 | |
|       # which permission types are logged, and what identities, if any, are exempted
 | |
|       # from logging. An AuditConfig must have one or more AuditLogConfigs.
 | |
|       # If there are AuditConfigs for both `allServices` and a specific service, the
 | |
|       # union of the two AuditConfigs is used for that service: the log_types
 | |
|       # specified in each AuditConfig are enabled, and the exempted_members in each
 | |
|       # AuditLogConfig are exempted.
 | |
|       # Example Policy with multiple AuditConfigs:
 | |
|       # ` "audit_configs": [ ` "service": "allServices" "audit_log_configs": [ ` "
 | |
|       # log_type": "DATA_READ", "exempted_members": [ "user:foo@gmail.com" ] `, ` "
 | |
|       # log_type": "DATA_WRITE", `, ` "log_type": "ADMIN_READ", ` ] `, ` "service": "
 | |
|       # fooservice.googleapis.com" "audit_log_configs": [ ` "log_type": "DATA_READ", `,
 | |
|       # ` "log_type": "DATA_WRITE", "exempted_members": [ "user:bar@gmail.com" ] ` ] `
 | |
|       # ] `
 | |
|       # For fooservice, this policy enables DATA_READ, DATA_WRITE and ADMIN_READ
 | |
|       # logging. It also exempts foo@gmail.com from DATA_READ logging, and bar@gmail.
 | |
|       # com from DATA_WRITE logging.
 | |
|       class AuditConfig
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The configuration for logging of each type of permission.
 | |
|         # Corresponds to the JSON property `auditLogConfigs`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::AuditLogConfig>]
 | |
|         attr_accessor :audit_log_configs
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `exemptedMembers`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :exempted_members
 | |
|       
 | |
|         # Specifies a service that will be enabled for audit logging. For example, `
 | |
|         # storage.googleapis.com`, `cloudsql.googleapis.com`. `allServices` is a special
 | |
|         # value that covers all services.
 | |
|         # Corresponds to the JSON property `service`
 | |
|         # @return [String]
 | |
|         attr_accessor :service
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @audit_log_configs = args[:audit_log_configs] if args.key?(:audit_log_configs)
 | |
|           @exempted_members = args[:exempted_members] if args.key?(:exempted_members)
 | |
|           @service = args[:service] if args.key?(:service)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Provides the configuration for logging a type of permissions. Example:
 | |
|       # ` "audit_log_configs": [ ` "log_type": "DATA_READ", "exempted_members": [ "
 | |
|       # user:foo@gmail.com" ] `, ` "log_type": "DATA_WRITE", ` ] `
 | |
|       # This enables 'DATA_READ' and 'DATA_WRITE' logging, while exempting foo@gmail.
 | |
|       # com from DATA_READ logging.
 | |
|       class AuditLogConfig
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Specifies the identities that do not cause logging for this type of permission.
 | |
|         # Follows the same format of [Binding.members][].
 | |
|         # Corresponds to the JSON property `exemptedMembers`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :exempted_members
 | |
|       
 | |
|         # The log type that this config enables.
 | |
|         # Corresponds to the JSON property `logType`
 | |
|         # @return [String]
 | |
|         attr_accessor :log_type
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @exempted_members = args[:exempted_members] if args.key?(:exempted_members)
 | |
|           @log_type = args[:log_type] if args.key?(:log_type)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Authorization-related information used by Cloud Audit Logging.
 | |
|       class AuthorizationLoggingOptions
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The type of the permission that was checked.
 | |
|         # Corresponds to the JSON property `permissionType`
 | |
|         # @return [String]
 | |
|         attr_accessor :permission_type
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @permission_type = args[:permission_type] if args.key?(:permission_type)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Represents an Autoscaler resource. Autoscalers allow you to automatically
 | |
|       # scale virtual machine instances in managed instance groups according to an
 | |
|       # autoscaling policy that you define. For more information, read Autoscaling
 | |
|       # Groups of Instances. (== resource_for beta.autoscalers ==) (== resource_for v1.
 | |
|       # autoscalers ==) (== resource_for beta.regionAutoscalers ==) (== resource_for
 | |
|       # v1.regionAutoscalers ==)
 | |
|       class Autoscaler
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Cloud Autoscaler policy.
 | |
|         # Corresponds to the JSON property `autoscalingPolicy`
 | |
|         # @return [Google::Apis::ComputeAlpha::AutoscalingPolicy]
 | |
|         attr_accessor :autoscaling_policy
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#autoscaler for autoscalers.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # [Output Only] Target recommended MIG size (number of instances) computed by
 | |
|         # autoscaler. Autoscaler calculates recommended MIG size even when autoscaling
 | |
|         # policy mode is different from ON. This field is empty when autoscaler is not
 | |
|         # connected to the existing managed instance group or autoscaler did not
 | |
|         # generate its prediction.
 | |
|         # Corresponds to the JSON property `recommendedSize`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :recommended_size
 | |
|       
 | |
|         # [Output Only] URL of the region where the instance group resides (for
 | |
|         # autoscalers living in regional scope).
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # [Output Only] The status of the autoscaler configuration.
 | |
|         # Corresponds to the JSON property `status`
 | |
|         # @return [String]
 | |
|         attr_accessor :status
 | |
|       
 | |
|         # [Output Only] Human-readable details about the current state of the autoscaler.
 | |
|         # Read the documentation for Commonly returned status messages for examples of
 | |
|         # status messages you might encounter.
 | |
|         # Corresponds to the JSON property `statusDetails`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::AutoscalerStatusDetails>]
 | |
|         attr_accessor :status_details
 | |
|       
 | |
|         # URL of the managed instance group that this autoscaler will scale.
 | |
|         # Corresponds to the JSON property `target`
 | |
|         # @return [String]
 | |
|         attr_accessor :target
 | |
|       
 | |
|         # [Output Only] URL of the zone where the instance group resides (for
 | |
|         # autoscalers living in zonal scope).
 | |
|         # Corresponds to the JSON property `zone`
 | |
|         # @return [String]
 | |
|         attr_accessor :zone
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @autoscaling_policy = args[:autoscaling_policy] if args.key?(:autoscaling_policy)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @recommended_size = args[:recommended_size] if args.key?(:recommended_size)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @status = args[:status] if args.key?(:status)
 | |
|           @status_details = args[:status_details] if args.key?(:status_details)
 | |
|           @target = args[:target] if args.key?(:target)
 | |
|           @zone = args[:zone] if args.key?(:zone)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class AutoscalerAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of AutoscalersScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::AutoscalersScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#autoscalerAggregatedList for
 | |
|         # aggregated lists of autoscalers.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::AutoscalerAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::AutoscalerAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of Autoscaler resources.
 | |
|       class AutoscalerList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of Autoscaler resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Autoscaler>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#autoscalerList for lists of
 | |
|         # autoscalers.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::AutoscalerList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::AutoscalerList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class AutoscalerStatusDetails
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The status message.
 | |
|         # Corresponds to the JSON property `message`
 | |
|         # @return [String]
 | |
|         attr_accessor :message
 | |
|       
 | |
|         # The type of error returned.
 | |
|         # Corresponds to the JSON property `type`
 | |
|         # @return [String]
 | |
|         attr_accessor :type
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @message = args[:message] if args.key?(:message)
 | |
|           @type = args[:type] if args.key?(:type)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class AutoscalersScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] A list of autoscalers contained in this scope.
 | |
|         # Corresponds to the JSON property `autoscalers`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Autoscaler>]
 | |
|         attr_accessor :autoscalers
 | |
|       
 | |
|         # [Output Only] Informational warning which replaces the list of autoscalers
 | |
|         # when the list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::AutoscalersScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @autoscalers = args[:autoscalers] if args.key?(:autoscalers)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning which replaces the list of autoscalers
 | |
|         # when the list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::AutoscalersScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Cloud Autoscaler policy.
 | |
|       class AutoscalingPolicy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The number of seconds that the autoscaler should wait before it starts
 | |
|         # collecting information from a new instance. This prevents the autoscaler from
 | |
|         # collecting information when the instance is initializing, during which the
 | |
|         # collected usage would not be reliable. The default time autoscaler waits is 60
 | |
|         # seconds.
 | |
|         # Virtual machine initialization times might vary because of numerous factors.
 | |
|         # We recommend that you test how long an instance may take to initialize. To do
 | |
|         # this, create an instance and time the startup process.
 | |
|         # Corresponds to the JSON property `coolDownPeriodSec`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :cool_down_period_sec
 | |
|       
 | |
|         # CPU utilization policy.
 | |
|         # Corresponds to the JSON property `cpuUtilization`
 | |
|         # @return [Google::Apis::ComputeAlpha::AutoscalingPolicyCpuUtilization]
 | |
|         attr_accessor :cpu_utilization
 | |
|       
 | |
|         # Configuration parameters of autoscaling based on a custom metric.
 | |
|         # Corresponds to the JSON property `customMetricUtilizations`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::AutoscalingPolicyCustomMetricUtilization>]
 | |
|         attr_accessor :custom_metric_utilizations
 | |
|       
 | |
|         # Configuration parameters of autoscaling based on load balancing.
 | |
|         # Corresponds to the JSON property `loadBalancingUtilization`
 | |
|         # @return [Google::Apis::ComputeAlpha::AutoscalingPolicyLoadBalancingUtilization]
 | |
|         attr_accessor :load_balancing_utilization
 | |
|       
 | |
|         # The maximum number of instances that the autoscaler can scale up to. This is
 | |
|         # required when creating or updating an autoscaler. The maximum number of
 | |
|         # replicas should not be lower than minimal number of replicas.
 | |
|         # Corresponds to the JSON property `maxNumReplicas`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :max_num_replicas
 | |
|       
 | |
|         # The minimum number of replicas that the autoscaler can scale down to. This
 | |
|         # cannot be less than 0. If not provided, autoscaler will choose a default value
 | |
|         # depending on maximum number of instances allowed.
 | |
|         # Corresponds to the JSON property `minNumReplicas`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :min_num_replicas
 | |
|       
 | |
|         # Defines operating mode for this policy.
 | |
|         # Corresponds to the JSON property `mode`
 | |
|         # @return [String]
 | |
|         attr_accessor :mode
 | |
|       
 | |
|         # Configuration parameters of autoscaling based on queuing system.
 | |
|         # Corresponds to the JSON property `queueBasedScaling`
 | |
|         # @return [Google::Apis::ComputeAlpha::AutoscalingPolicyQueueBasedScaling]
 | |
|         attr_accessor :queue_based_scaling
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @cool_down_period_sec = args[:cool_down_period_sec] if args.key?(:cool_down_period_sec)
 | |
|           @cpu_utilization = args[:cpu_utilization] if args.key?(:cpu_utilization)
 | |
|           @custom_metric_utilizations = args[:custom_metric_utilizations] if args.key?(:custom_metric_utilizations)
 | |
|           @load_balancing_utilization = args[:load_balancing_utilization] if args.key?(:load_balancing_utilization)
 | |
|           @max_num_replicas = args[:max_num_replicas] if args.key?(:max_num_replicas)
 | |
|           @min_num_replicas = args[:min_num_replicas] if args.key?(:min_num_replicas)
 | |
|           @mode = args[:mode] if args.key?(:mode)
 | |
|           @queue_based_scaling = args[:queue_based_scaling] if args.key?(:queue_based_scaling)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # CPU utilization policy.
 | |
|       class AutoscalingPolicyCpuUtilization
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The target CPU utilization that the autoscaler should maintain. Must be a
 | |
|         # float value in the range (0, 1]. If not specified, the default is 0.6.
 | |
|         # If the CPU level is below the target utilization, the autoscaler scales down
 | |
|         # the number of instances until it reaches the minimum number of instances you
 | |
|         # specified or until the average CPU of your instances reaches the target
 | |
|         # utilization.
 | |
|         # If the average CPU is above the target utilization, the autoscaler scales up
 | |
|         # until it reaches the maximum number of instances you specified or until the
 | |
|         # average utilization reaches the target utilization.
 | |
|         # Corresponds to the JSON property `utilizationTarget`
 | |
|         # @return [Float]
 | |
|         attr_accessor :utilization_target
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @utilization_target = args[:utilization_target] if args.key?(:utilization_target)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Custom utilization metric policy.
 | |
|       class AutoscalingPolicyCustomMetricUtilization
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A filter string, compatible with a Stackdriver Monitoring filter string for
 | |
|         # TimeSeries.list API call. This filter is used to select a specific TimeSeries
 | |
|         # for the purpose of autoscaling and to determine whether the metric is
 | |
|         # exporting per-instance or per-group data.
 | |
|         # For the filter to be valid for autoscaling purposes, the following rules apply:
 | |
|         # 
 | |
|         # - You can only use the AND operator for joining selectors.
 | |
|         # - You can only use direct equality comparison operator (=) without any
 | |
|         # functions for each selector.
 | |
|         # - You can specify the metric in both the filter string and in the metric field.
 | |
|         # However, if specified in both places, the metric must be identical.
 | |
|         # - The monitored resource type determines what kind of values are expected for
 | |
|         # the metric. If it is a gce_instance, the autoscaler expects the metric to
 | |
|         # include a separate TimeSeries for each instance in a group. In such a case,
 | |
|         # you cannot filter on resource labels.
 | |
|         # If the resource type is any other value, the autoscaler expects this metric to
 | |
|         # contain values that apply to the entire autoscaled instance group and resource
 | |
|         # label filtering can be performed to point autoscaler at the correct TimeSeries
 | |
|         # to scale upon. This is called a per-group metric for the purpose of
 | |
|         # autoscaling.
 | |
|         # If not specified, the type defaults to gce_instance.
 | |
|         # You should provide a filter that is selective enough to pick just one
 | |
|         # TimeSeries for the autoscaled group or for each of the instances (if you are
 | |
|         # using gce_instance resource type). If multiple TimeSeries are returned upon
 | |
|         # the query execution, the autoscaler will sum their respective values to obtain
 | |
|         # its scaling value.
 | |
|         # Corresponds to the JSON property `filter`
 | |
|         # @return [String]
 | |
|         attr_accessor :filter
 | |
|       
 | |
|         # The identifier (type) of the Stackdriver Monitoring metric. The metric cannot
 | |
|         # have negative values.
 | |
|         # The metric must have a value type of INT64 or DOUBLE.
 | |
|         # Corresponds to the JSON property `metric`
 | |
|         # @return [String]
 | |
|         attr_accessor :metric
 | |
|       
 | |
|         # If scaling is based on a per-group metric value that represents the total
 | |
|         # amount of work to be done or resource usage, set this value to an amount
 | |
|         # assigned for a single instance of the scaled group. Autoscaler will keep the
 | |
|         # number of instances proportional to the value of this metric, the metric
 | |
|         # itself should not change value due to group resizing.
 | |
|         # A good metric to use with the target is for example pubsub.googleapis.com/
 | |
|         # subscription/num_undelivered_messages or a custom metric exporting the total
 | |
|         # number of requests coming to your instances.
 | |
|         # A bad example would be a metric exporting an average or median latency, since
 | |
|         # this value can't include a chunk assignable to a single instance, it could be
 | |
|         # better used with utilization_target instead.
 | |
|         # Corresponds to the JSON property `singleInstanceAssignment`
 | |
|         # @return [Float]
 | |
|         attr_accessor :single_instance_assignment
 | |
|       
 | |
|         # The target value of the metric that autoscaler should maintain. This must be a
 | |
|         # positive value. A utilization metric scales number of virtual machines
 | |
|         # handling requests to increase or decrease proportionally to the metric.
 | |
|         # For example, a good metric to use as a utilization_target is compute.
 | |
|         # googleapis.com/instance/network/received_bytes_count. The autoscaler will work
 | |
|         # to keep this value constant for each of the instances.
 | |
|         # Corresponds to the JSON property `utilizationTarget`
 | |
|         # @return [Float]
 | |
|         attr_accessor :utilization_target
 | |
|       
 | |
|         # Defines how target utilization value is expressed for a Stackdriver Monitoring
 | |
|         # metric. Either GAUGE, DELTA_PER_SECOND, or DELTA_PER_MINUTE.
 | |
|         # Corresponds to the JSON property `utilizationTargetType`
 | |
|         # @return [String]
 | |
|         attr_accessor :utilization_target_type
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @filter = args[:filter] if args.key?(:filter)
 | |
|           @metric = args[:metric] if args.key?(:metric)
 | |
|           @single_instance_assignment = args[:single_instance_assignment] if args.key?(:single_instance_assignment)
 | |
|           @utilization_target = args[:utilization_target] if args.key?(:utilization_target)
 | |
|           @utilization_target_type = args[:utilization_target_type] if args.key?(:utilization_target_type)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Configuration parameters of autoscaling based on load balancing.
 | |
|       class AutoscalingPolicyLoadBalancingUtilization
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Fraction of backend capacity utilization (set in HTTP(S) load balancing
 | |
|         # configuration) that autoscaler should maintain. Must be a positive float value.
 | |
|         # If not defined, the default is 0.8.
 | |
|         # Corresponds to the JSON property `utilizationTarget`
 | |
|         # @return [Float]
 | |
|         attr_accessor :utilization_target
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @utilization_target = args[:utilization_target] if args.key?(:utilization_target)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Configuration parameters of autoscaling based on queuing system.
 | |
|       class AutoscalingPolicyQueueBasedScaling
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Scaling based on the average number of tasks in the queue per each active
 | |
|         # instance. The autoscaler keeps the average number of tasks per instance below
 | |
|         # this number, based on data collected in the last couple of minutes. The
 | |
|         # autoscaler will also take into account incoming tasks when calculating when to
 | |
|         # scale.
 | |
|         # Corresponds to the JSON property `acceptableBacklogPerInstance`
 | |
|         # @return [Float]
 | |
|         attr_accessor :acceptable_backlog_per_instance
 | |
|       
 | |
|         # Configuration parameters for scaling based on Cloud Pub/Sub subscription queue.
 | |
|         # Corresponds to the JSON property `cloudPubSub`
 | |
|         # @return [Google::Apis::ComputeAlpha::AutoscalingPolicyQueueBasedScalingCloudPubSub]
 | |
|         attr_accessor :cloud_pub_sub
 | |
|       
 | |
|         # The scaling algorithm will also calculate throughput estimates on its own; if
 | |
|         # you explicitly provide this value, the autoscaler will take into account your
 | |
|         # value as well as automatic estimates when deciding how to scale.
 | |
|         # Corresponds to the JSON property `singleWorkerThroughputPerSec`
 | |
|         # @return [Float]
 | |
|         attr_accessor :single_worker_throughput_per_sec
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @acceptable_backlog_per_instance = args[:acceptable_backlog_per_instance] if args.key?(:acceptable_backlog_per_instance)
 | |
|           @cloud_pub_sub = args[:cloud_pub_sub] if args.key?(:cloud_pub_sub)
 | |
|           @single_worker_throughput_per_sec = args[:single_worker_throughput_per_sec] if args.key?(:single_worker_throughput_per_sec)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Configuration parameters for scaling based on Cloud Pub/Sub subscription queue.
 | |
|       class AutoscalingPolicyQueueBasedScalingCloudPubSub
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Cloud Pub/Sub subscription used for scaling. Provide the partial URL (starting
 | |
|         # with projects/) or just the subscription name. The subscription must be
 | |
|         # assigned to the topic specified in topicName and must be in a pull
 | |
|         # configuration. The subscription must belong to the same project as the
 | |
|         # Autoscaler.
 | |
|         # Corresponds to the JSON property `subscription`
 | |
|         # @return [String]
 | |
|         attr_accessor :subscription
 | |
|       
 | |
|         # Cloud Pub/Sub topic used for scaling. Provide the partial URL or partial URL (
 | |
|         # starting with projects/) or just the topic name. The topic must belong to the
 | |
|         # same project as the Autoscaler resource.
 | |
|         # Corresponds to the JSON property `topic`
 | |
|         # @return [String]
 | |
|         attr_accessor :topic
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @subscription = args[:subscription] if args.key?(:subscription)
 | |
|           @topic = args[:topic] if args.key?(:topic)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Message containing information of one individual backend.
 | |
|       class Backend
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Specifies the balancing mode for this backend. For global HTTP(S) or TCP/SSL
 | |
|         # load balancing, the default is UTILIZATION. Valid values are UTILIZATION, RATE
 | |
|         # (for HTTP(S)) and CONNECTION (for TCP/SSL).
 | |
|         # For Internal Load Balancing, the default and only supported mode is CONNECTION.
 | |
|         # Corresponds to the JSON property `balancingMode`
 | |
|         # @return [String]
 | |
|         attr_accessor :balancing_mode
 | |
|       
 | |
|         # A multiplier applied to the group's maximum servicing capacity (based on
 | |
|         # UTILIZATION, RATE or CONNECTION). Default value is 1, which means the group
 | |
|         # will serve up to 100% of its configured capacity (depending on balancingMode).
 | |
|         # A setting of 0 means the group is completely drained, offering 0% of its
 | |
|         # available Capacity. Valid range is [0.0,1.0].
 | |
|         # This cannot be used for internal load balancing.
 | |
|         # Corresponds to the JSON property `capacityScaler`
 | |
|         # @return [Float]
 | |
|         attr_accessor :capacity_scaler
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # This field designates whether this is a failover backend. More than one
 | |
|         # failover backend can be configured for a given BackendService.
 | |
|         # Corresponds to the JSON property `failover`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :failover
 | |
|         alias_method :failover?, :failover
 | |
|       
 | |
|         # The fully-qualified URL of an Instance Group or Network Endpoint Group
 | |
|         # resource. In case of instance group this defines the list of instances that
 | |
|         # serve traffic. Member virtual machine instances from each instance group must
 | |
|         # live in the same zone as the instance group itself. No two backends in a
 | |
|         # backend service are allowed to use same Instance Group resource.
 | |
|         # For Network Endpoint Groups this defines list of endpoints. All endpoints of
 | |
|         # Network Endpoint Group must be hosted on instances located in the same zone as
 | |
|         # the Network Endpoint Group.
 | |
|         # Backend service can not contain mix of Instance Group and Network Endpoint
 | |
|         # Group backends.
 | |
|         # Note that you must specify an Instance Group or Network Endpoint Group
 | |
|         # resource using the fully-qualified URL, rather than a partial URL.
 | |
|         # When the BackendService has load balancing scheme INTERNAL, the instance group
 | |
|         # must be within the same region as the BackendService. Network Endpoint Groups
 | |
|         # are not supported for INTERNAL load balancing scheme.
 | |
|         # Corresponds to the JSON property `group`
 | |
|         # @return [String]
 | |
|         attr_accessor :group
 | |
|       
 | |
|         # The max number of simultaneous connections for the group. Can be used with
 | |
|         # either CONNECTION or UTILIZATION balancing modes. For CONNECTION mode, either
 | |
|         # maxConnections or maxConnectionsPerInstance must be set.
 | |
|         # This cannot be used for internal load balancing.
 | |
|         # Corresponds to the JSON property `maxConnections`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :max_connections
 | |
|       
 | |
|         # The max number of simultaneous connections that a single backend network
 | |
|         # endpoint can handle. This is used to calculate the capacity of the group. Can
 | |
|         # be used in either CONNECTION or UTILIZATION balancing modes. For CONNECTION
 | |
|         # mode, either maxConnections or maxConnectionsPerEndpoint must be set.
 | |
|         # This cannot be used for internal load balancing.
 | |
|         # Corresponds to the JSON property `maxConnectionsPerEndpoint`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :max_connections_per_endpoint
 | |
|       
 | |
|         # The max number of simultaneous connections that a single backend instance can
 | |
|         # handle. This is used to calculate the capacity of the group. Can be used in
 | |
|         # either CONNECTION or UTILIZATION balancing modes. For CONNECTION mode, either
 | |
|         # maxConnections or maxConnectionsPerInstance must be set.
 | |
|         # This cannot be used for internal load balancing.
 | |
|         # Corresponds to the JSON property `maxConnectionsPerInstance`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :max_connections_per_instance
 | |
|       
 | |
|         # The max requests per second (RPS) of the group. Can be used with either RATE
 | |
|         # or UTILIZATION balancing modes, but required if RATE mode. For RATE mode,
 | |
|         # either maxRate or maxRatePerInstance must be set.
 | |
|         # This cannot be used for internal load balancing.
 | |
|         # Corresponds to the JSON property `maxRate`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :max_rate
 | |
|       
 | |
|         # The max requests per second (RPS) that a single backend network endpoint can
 | |
|         # handle. This is used to calculate the capacity of the group. Can be used in
 | |
|         # either balancing mode. For RATE mode, either maxRate or maxRatePerEndpoint
 | |
|         # must be set.
 | |
|         # This cannot be used for internal load balancing.
 | |
|         # Corresponds to the JSON property `maxRatePerEndpoint`
 | |
|         # @return [Float]
 | |
|         attr_accessor :max_rate_per_endpoint
 | |
|       
 | |
|         # The max requests per second (RPS) that a single backend instance can handle.
 | |
|         # This is used to calculate the capacity of the group. Can be used in either
 | |
|         # balancing mode. For RATE mode, either maxRate or maxRatePerInstance must be
 | |
|         # set.
 | |
|         # This cannot be used for internal load balancing.
 | |
|         # Corresponds to the JSON property `maxRatePerInstance`
 | |
|         # @return [Float]
 | |
|         attr_accessor :max_rate_per_instance
 | |
|       
 | |
|         # Used when balancingMode is UTILIZATION. This ratio defines the CPU utilization
 | |
|         # target for the group. The default is 0.8. Valid range is [0.0, 1.0].
 | |
|         # This cannot be used for internal load balancing.
 | |
|         # Corresponds to the JSON property `maxUtilization`
 | |
|         # @return [Float]
 | |
|         attr_accessor :max_utilization
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @balancing_mode = args[:balancing_mode] if args.key?(:balancing_mode)
 | |
|           @capacity_scaler = args[:capacity_scaler] if args.key?(:capacity_scaler)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @failover = args[:failover] if args.key?(:failover)
 | |
|           @group = args[:group] if args.key?(:group)
 | |
|           @max_connections = args[:max_connections] if args.key?(:max_connections)
 | |
|           @max_connections_per_endpoint = args[:max_connections_per_endpoint] if args.key?(:max_connections_per_endpoint)
 | |
|           @max_connections_per_instance = args[:max_connections_per_instance] if args.key?(:max_connections_per_instance)
 | |
|           @max_rate = args[:max_rate] if args.key?(:max_rate)
 | |
|           @max_rate_per_endpoint = args[:max_rate_per_endpoint] if args.key?(:max_rate_per_endpoint)
 | |
|           @max_rate_per_instance = args[:max_rate_per_instance] if args.key?(:max_rate_per_instance)
 | |
|           @max_utilization = args[:max_utilization] if args.key?(:max_utilization)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A BackendBucket resource. This resource defines a Cloud Storage bucket.
 | |
|       class BackendBucket
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Cloud Storage bucket name.
 | |
|         # Corresponds to the JSON property `bucketName`
 | |
|         # @return [String]
 | |
|         attr_accessor :bucket_name
 | |
|       
 | |
|         # Message containing Cloud CDN configuration for a backend bucket.
 | |
|         # Corresponds to the JSON property `cdnPolicy`
 | |
|         # @return [Google::Apis::ComputeAlpha::BackendBucketCdnPolicy]
 | |
|         attr_accessor :cdn_policy
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional textual description of the resource; provided by the client when
 | |
|         # the resource is created.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # If true, enable Cloud CDN for this BackendBucket.
 | |
|         # Corresponds to the JSON property `enableCdn`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :enable_cdn
 | |
|         alias_method :enable_cdn?, :enable_cdn
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # Type of the resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @bucket_name = args[:bucket_name] if args.key?(:bucket_name)
 | |
|           @cdn_policy = args[:cdn_policy] if args.key?(:cdn_policy)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @enable_cdn = args[:enable_cdn] if args.key?(:enable_cdn)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Message containing Cloud CDN configuration for a backend bucket.
 | |
|       class BackendBucketCdnPolicy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Maximum number of seconds the response to a signed URL request will be
 | |
|         # considered fresh. After this time period, the response will be revalidated
 | |
|         # before being served. Defaults to 1hr (3600s). When serving responses to signed
 | |
|         # URL requests, Cloud CDN will internally behave as though all responses from
 | |
|         # this backend had a "Cache-Control: public, max-age=[TTL]" header, regardless
 | |
|         # of any existing Cache-Control header. The actual headers served in responses
 | |
|         # will not be altered.
 | |
|         # Corresponds to the JSON property `signedUrlCacheMaxAgeSec`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :signed_url_cache_max_age_sec
 | |
|       
 | |
|         # [Output Only] Names of the keys for signing request URLs.
 | |
|         # Corresponds to the JSON property `signedUrlKeyNames`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :signed_url_key_names
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @signed_url_cache_max_age_sec = args[:signed_url_cache_max_age_sec] if args.key?(:signed_url_cache_max_age_sec)
 | |
|           @signed_url_key_names = args[:signed_url_key_names] if args.key?(:signed_url_key_names)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of BackendBucket resources.
 | |
|       class BackendBucketList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of BackendBucket resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::BackendBucket>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::BackendBucketList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::BackendBucketList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A BackendService resource. This resource defines a group of backend virtual
 | |
|       # machines and their serving capacity. (== resource_for v1.backendService ==) (==
 | |
|       # resource_for beta.backendService ==)
 | |
|       class BackendService
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Lifetime of cookies in seconds if session_affinity is GENERATED_COOKIE. If set
 | |
|         # to 0, the cookie is non-persistent and lasts only until the end of the browser
 | |
|         # session (or equivalent). The maximum allowed value for TTL is one day.
 | |
|         # When the load balancing scheme is INTERNAL, this field is not used.
 | |
|         # Corresponds to the JSON property `affinityCookieTtlSec`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :affinity_cookie_ttl_sec
 | |
|       
 | |
|         # Configuration of a App Engine backend.
 | |
|         # Corresponds to the JSON property `appEngineBackend`
 | |
|         # @return [Google::Apis::ComputeAlpha::BackendServiceAppEngineBackend]
 | |
|         attr_accessor :app_engine_backend
 | |
|       
 | |
|         # The list of backends that serve this BackendService.
 | |
|         # Corresponds to the JSON property `backends`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Backend>]
 | |
|         attr_accessor :backends
 | |
|       
 | |
|         # Message containing Cloud CDN configuration for a backend service.
 | |
|         # Corresponds to the JSON property `cdnPolicy`
 | |
|         # @return [Google::Apis::ComputeAlpha::BackendServiceCdnPolicy]
 | |
|         attr_accessor :cdn_policy
 | |
|       
 | |
|         # Configuration of a Cloud Function backend.
 | |
|         # Corresponds to the JSON property `cloudFunctionBackend`
 | |
|         # @return [Google::Apis::ComputeAlpha::BackendServiceCloudFunctionBackend]
 | |
|         attr_accessor :cloud_function_backend
 | |
|       
 | |
|         # Message containing connection draining configuration.
 | |
|         # Corresponds to the JSON property `connectionDraining`
 | |
|         # @return [Google::Apis::ComputeAlpha::ConnectionDraining]
 | |
|         attr_accessor :connection_draining
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # Headers that the HTTP/S load balancer should add to proxied requests.
 | |
|         # Corresponds to the JSON property `customRequestHeaders`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :custom_request_headers
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # If true, enable Cloud CDN for this BackendService.
 | |
|         # When the load balancing scheme is INTERNAL, this field is not used.
 | |
|         # Corresponds to the JSON property `enableCDN`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :enable_cdn
 | |
|         alias_method :enable_cdn?, :enable_cdn
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `failoverPolicy`
 | |
|         # @return [Google::Apis::ComputeAlpha::BackendServiceFailoverPolicy]
 | |
|         attr_accessor :failover_policy
 | |
|       
 | |
|         # Fingerprint of this resource. A hash of the contents stored in this object.
 | |
|         # This field is used in optimistic locking. This field will be ignored when
 | |
|         # inserting a BackendService. An up-to-date fingerprint must be provided in
 | |
|         # order to update the BackendService, otherwise the request will fail with error
 | |
|         # 412 conditionNotMet.
 | |
|         # To see the latest fingerprint, make a get() request to retrieve a
 | |
|         # BackendService.
 | |
|         # Corresponds to the JSON property `fingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :fingerprint
 | |
|       
 | |
|         # The list of URLs to the HttpHealthCheck or HttpsHealthCheck resource for
 | |
|         # health checking this BackendService. Currently at most one health check can be
 | |
|         # specified, and a health check is required for Compute Engine backend services.
 | |
|         # A health check must not be specified for App Engine backend and Cloud Function
 | |
|         # backend.
 | |
|         # For internal load balancing, a URL to a HealthCheck resource must be specified
 | |
|         # instead.
 | |
|         # Corresponds to the JSON property `healthChecks`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :health_checks
 | |
|       
 | |
|         # Identity-Aware Proxy
 | |
|         # Corresponds to the JSON property `iap`
 | |
|         # @return [Google::Apis::ComputeAlpha::BackendServiceIap]
 | |
|         attr_accessor :iap
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#backendService for backend
 | |
|         # services.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # Indicates whether the backend service will be used with internal or external
 | |
|         # load balancing. A backend service created for one type of load balancing
 | |
|         # cannot be used with the other. Possible values are INTERNAL and EXTERNAL.
 | |
|         # Corresponds to the JSON property `loadBalancingScheme`
 | |
|         # @return [String]
 | |
|         attr_accessor :load_balancing_scheme
 | |
|       
 | |
|         # The available logging options for the load balancer traffic served by this
 | |
|         # backend service.
 | |
|         # Corresponds to the JSON property `logConfig`
 | |
|         # @return [Google::Apis::ComputeAlpha::BackendServiceLogConfig]
 | |
|         attr_accessor :log_config
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # Deprecated in favor of portName. The TCP port to connect on the backend. The
 | |
|         # default value is 80.
 | |
|         # This cannot be used for internal load balancing.
 | |
|         # Corresponds to the JSON property `port`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :port
 | |
|       
 | |
|         # Name of backend port. The same name should appear in the instance groups
 | |
|         # referenced by this service. Required when the load balancing scheme is
 | |
|         # EXTERNAL.
 | |
|         # When the load balancing scheme is INTERNAL, this field is not used.
 | |
|         # Corresponds to the JSON property `portName`
 | |
|         # @return [String]
 | |
|         attr_accessor :port_name
 | |
|       
 | |
|         # The protocol this BackendService uses to communicate with backends.
 | |
|         # Possible values are HTTP, HTTPS, TCP, and SSL. The default is HTTP.
 | |
|         # For internal load balancing, the possible values are TCP and UDP, and the
 | |
|         # default is TCP.
 | |
|         # Corresponds to the JSON property `protocol`
 | |
|         # @return [String]
 | |
|         attr_accessor :protocol
 | |
|       
 | |
|         # [Output Only] URL of the region where the regional backend service resides.
 | |
|         # This field is not applicable to global backend services. You must specify this
 | |
|         # field as part of the HTTP request URL. It is not settable as a field in the
 | |
|         # request body.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # [Output Only] The resource URL for the security policy associated with this
 | |
|         # backend service.
 | |
|         # Corresponds to the JSON property `securityPolicy`
 | |
|         # @return [String]
 | |
|         attr_accessor :security_policy
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # Type of session affinity to use. The default is NONE.
 | |
|         # When the load balancing scheme is EXTERNAL, can be NONE, CLIENT_IP, or
 | |
|         # GENERATED_COOKIE.
 | |
|         # When the load balancing scheme is INTERNAL, can be NONE, CLIENT_IP,
 | |
|         # CLIENT_IP_PROTO, or CLIENT_IP_PORT_PROTO.
 | |
|         # When the protocol is UDP, this field is not used.
 | |
|         # Corresponds to the JSON property `sessionAffinity`
 | |
|         # @return [String]
 | |
|         attr_accessor :session_affinity
 | |
|       
 | |
|         # How many seconds to wait for the backend before considering it a failed
 | |
|         # request. Default is 30 seconds.
 | |
|         # Corresponds to the JSON property `timeoutSec`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :timeout_sec
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @affinity_cookie_ttl_sec = args[:affinity_cookie_ttl_sec] if args.key?(:affinity_cookie_ttl_sec)
 | |
|           @app_engine_backend = args[:app_engine_backend] if args.key?(:app_engine_backend)
 | |
|           @backends = args[:backends] if args.key?(:backends)
 | |
|           @cdn_policy = args[:cdn_policy] if args.key?(:cdn_policy)
 | |
|           @cloud_function_backend = args[:cloud_function_backend] if args.key?(:cloud_function_backend)
 | |
|           @connection_draining = args[:connection_draining] if args.key?(:connection_draining)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @custom_request_headers = args[:custom_request_headers] if args.key?(:custom_request_headers)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @enable_cdn = args[:enable_cdn] if args.key?(:enable_cdn)
 | |
|           @failover_policy = args[:failover_policy] if args.key?(:failover_policy)
 | |
|           @fingerprint = args[:fingerprint] if args.key?(:fingerprint)
 | |
|           @health_checks = args[:health_checks] if args.key?(:health_checks)
 | |
|           @iap = args[:iap] if args.key?(:iap)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @load_balancing_scheme = args[:load_balancing_scheme] if args.key?(:load_balancing_scheme)
 | |
|           @log_config = args[:log_config] if args.key?(:log_config)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @port = args[:port] if args.key?(:port)
 | |
|           @port_name = args[:port_name] if args.key?(:port_name)
 | |
|           @protocol = args[:protocol] if args.key?(:protocol)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @security_policy = args[:security_policy] if args.key?(:security_policy)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @session_affinity = args[:session_affinity] if args.key?(:session_affinity)
 | |
|           @timeout_sec = args[:timeout_sec] if args.key?(:timeout_sec)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of BackendServicesScopedList.
 | |
|       class BackendServiceAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of BackendServicesScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::BackendServicesScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::BackendServiceAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::BackendServiceAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Configuration of a App Engine backend.
 | |
|       class BackendServiceAppEngineBackend
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Optional. App Engine app service name.
 | |
|         # Corresponds to the JSON property `appEngineService`
 | |
|         # @return [String]
 | |
|         attr_accessor :app_engine_service
 | |
|       
 | |
|         # Required. Project ID of the project hosting the app. This is the project ID of
 | |
|         # this project. Reference to another project is not allowed.
 | |
|         # Corresponds to the JSON property `targetProject`
 | |
|         # @return [String]
 | |
|         attr_accessor :target_project
 | |
|       
 | |
|         # Optional. Version of App Engine app service. When empty, App Engine will do
 | |
|         # its normal traffic split.
 | |
|         # Corresponds to the JSON property `version`
 | |
|         # @return [String]
 | |
|         attr_accessor :version
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @app_engine_service = args[:app_engine_service] if args.key?(:app_engine_service)
 | |
|           @target_project = args[:target_project] if args.key?(:target_project)
 | |
|           @version = args[:version] if args.key?(:version)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Message containing Cloud CDN configuration for a backend service.
 | |
|       class BackendServiceCdnPolicy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Message containing what to include in the cache key for a request for Cloud
 | |
|         # CDN.
 | |
|         # Corresponds to the JSON property `cacheKeyPolicy`
 | |
|         # @return [Google::Apis::ComputeAlpha::CacheKeyPolicy]
 | |
|         attr_accessor :cache_key_policy
 | |
|       
 | |
|         # Maximum number of seconds the response to a signed URL request will be
 | |
|         # considered fresh. After this time period, the response will be revalidated
 | |
|         # before being served. Defaults to 1hr (3600s). When serving responses to signed
 | |
|         # URL requests, Cloud CDN will internally behave as though all responses from
 | |
|         # this backend had a "Cache-Control: public, max-age=[TTL]" header, regardless
 | |
|         # of any existing Cache-Control header. The actual headers served in responses
 | |
|         # will not be altered.
 | |
|         # Corresponds to the JSON property `signedUrlCacheMaxAgeSec`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :signed_url_cache_max_age_sec
 | |
|       
 | |
|         # [Output Only] Names of the keys for signing request URLs.
 | |
|         # Corresponds to the JSON property `signedUrlKeyNames`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :signed_url_key_names
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @cache_key_policy = args[:cache_key_policy] if args.key?(:cache_key_policy)
 | |
|           @signed_url_cache_max_age_sec = args[:signed_url_cache_max_age_sec] if args.key?(:signed_url_cache_max_age_sec)
 | |
|           @signed_url_key_names = args[:signed_url_key_names] if args.key?(:signed_url_key_names)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Configuration of a Cloud Function backend.
 | |
|       class BackendServiceCloudFunctionBackend
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Required. A cloud function name. Special value ?*? represents all cloud
 | |
|         # functions in the project.
 | |
|         # Corresponds to the JSON property `functionName`
 | |
|         # @return [String]
 | |
|         attr_accessor :function_name
 | |
|       
 | |
|         # Required. Project ID of the project hosting the cloud function.
 | |
|         # Corresponds to the JSON property `targetProject`
 | |
|         # @return [String]
 | |
|         attr_accessor :target_project
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @function_name = args[:function_name] if args.key?(:function_name)
 | |
|           @target_project = args[:target_project] if args.key?(:target_project)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class BackendServiceFailoverPolicy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # On failover or failback, this field indicates whether connection drain will be
 | |
|         # honored. Setting this to true has the following effect: connections to the old
 | |
|         # active pool are not drained. Connections to the new active pool use the
 | |
|         # timeout of 10 min (currently fixed). Setting to false has the following effect:
 | |
|         # both old and new connections will have a drain timeout of 10 min.
 | |
|         # This can be set to true only if the protocol is TCP.
 | |
|         # The default is false.
 | |
|         # Corresponds to the JSON property `disableConnectionDrainOnFailover`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :disable_connection_drain_on_failover
 | |
|         alias_method :disable_connection_drain_on_failover?, :disable_connection_drain_on_failover
 | |
|       
 | |
|         # This option is used only when no healthy VMs are detected in the primary and
 | |
|         # backup instance groups. When set to true, traffic is dropped. When set to
 | |
|         # false, new connections are sent across all VMs in the primary group.
 | |
|         # The default is false.
 | |
|         # Corresponds to the JSON property `dropTrafficIfUnhealthy`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :drop_traffic_if_unhealthy
 | |
|         alias_method :drop_traffic_if_unhealthy?, :drop_traffic_if_unhealthy
 | |
|       
 | |
|         # The value of the field must be in [0, 1]. If the ratio of the healthy VMs in
 | |
|         # the primary backend is at or below this number, traffic arriving at the load-
 | |
|         # balanced IP will be directed to the failover backend.
 | |
|         # In case where 'failoverRatio' is not set or all the VMs in the backup backend
 | |
|         # are unhealthy, the traffic will be directed back to the primary backend in the
 | |
|         # "force" mode, where traffic will be spread to the healthy VMs with the best
 | |
|         # effort, or to all VMs when no VM is healthy.
 | |
|         # This field is only used with l4 load balancing.
 | |
|         # Corresponds to the JSON property `failoverRatio`
 | |
|         # @return [Float]
 | |
|         attr_accessor :failover_ratio
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @disable_connection_drain_on_failover = args[:disable_connection_drain_on_failover] if args.key?(:disable_connection_drain_on_failover)
 | |
|           @drop_traffic_if_unhealthy = args[:drop_traffic_if_unhealthy] if args.key?(:drop_traffic_if_unhealthy)
 | |
|           @failover_ratio = args[:failover_ratio] if args.key?(:failover_ratio)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class BackendServiceGroupHealth
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Metadata defined as annotations on the network endpoint group.
 | |
|         # Corresponds to the JSON property `annotations`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :annotations
 | |
|       
 | |
|         # Health state of the backend instances or endpoints in requested instance or
 | |
|         # network endpoint group, determined based on configured health checks.
 | |
|         # Corresponds to the JSON property `healthStatus`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::HealthStatus>]
 | |
|         attr_accessor :health_status
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#backendServiceGroupHealth for
 | |
|         # the health of backend services.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @annotations = args[:annotations] if args.key?(:annotations)
 | |
|           @health_status = args[:health_status] if args.key?(:health_status)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Identity-Aware Proxy
 | |
|       class BackendServiceIap
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `enabled`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :enabled
 | |
|         alias_method :enabled?, :enabled
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `oauth2ClientId`
 | |
|         # @return [String]
 | |
|         attr_accessor :oauth2_client_id
 | |
|       
 | |
|         # [Input Only] OAuth client info required to generate client id to be used for
 | |
|         # IAP.
 | |
|         # Corresponds to the JSON property `oauth2ClientInfo`
 | |
|         # @return [Google::Apis::ComputeAlpha::BackendServiceIapoAuth2ClientInfo]
 | |
|         attr_accessor :oauth2_client_info
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `oauth2ClientSecret`
 | |
|         # @return [String]
 | |
|         attr_accessor :oauth2_client_secret
 | |
|       
 | |
|         # [Output Only] SHA256 hash value for the field oauth2_client_secret above.
 | |
|         # Corresponds to the JSON property `oauth2ClientSecretSha256`
 | |
|         # @return [String]
 | |
|         attr_accessor :oauth2_client_secret_sha256
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @enabled = args[:enabled] if args.key?(:enabled)
 | |
|           @oauth2_client_id = args[:oauth2_client_id] if args.key?(:oauth2_client_id)
 | |
|           @oauth2_client_info = args[:oauth2_client_info] if args.key?(:oauth2_client_info)
 | |
|           @oauth2_client_secret = args[:oauth2_client_secret] if args.key?(:oauth2_client_secret)
 | |
|           @oauth2_client_secret_sha256 = args[:oauth2_client_secret_sha256] if args.key?(:oauth2_client_secret_sha256)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class BackendServiceIapoAuth2ClientInfo
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Application name to be used in OAuth consent screen.
 | |
|         # Corresponds to the JSON property `applicationName`
 | |
|         # @return [String]
 | |
|         attr_accessor :application_name
 | |
|       
 | |
|         # Name of the client to be generated. Optional - If not provided, the name will
 | |
|         # be autogenerated by the backend.
 | |
|         # Corresponds to the JSON property `clientName`
 | |
|         # @return [String]
 | |
|         attr_accessor :client_name
 | |
|       
 | |
|         # Developer's information to be used in OAuth consent screen.
 | |
|         # Corresponds to the JSON property `developerEmailAddress`
 | |
|         # @return [String]
 | |
|         attr_accessor :developer_email_address
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @application_name = args[:application_name] if args.key?(:application_name)
 | |
|           @client_name = args[:client_name] if args.key?(:client_name)
 | |
|           @developer_email_address = args[:developer_email_address] if args.key?(:developer_email_address)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of BackendService resources.
 | |
|       class BackendServiceList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of BackendService resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::BackendService>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#backendServiceList for lists of
 | |
|         # backend services.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::BackendServiceList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::BackendServiceList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The available logging options for the load balancer traffic served by this
 | |
|       # backend service.
 | |
|       class BackendServiceLogConfig
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # This field denotes whether to enable logging for the load balancer traffic
 | |
|         # served by this backend service.
 | |
|         # Corresponds to the JSON property `enable`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :enable
 | |
|         alias_method :enable?, :enable
 | |
|       
 | |
|         # This field can only be specified if logging is enabled for this backend
 | |
|         # service. The value of the field must be in [0, 1]. This configures the
 | |
|         # sampling rate of requests to the load balancer where 1.0 means all logged
 | |
|         # requests are reported and 0.0 means no logged requests are reported. The
 | |
|         # default value is 1.0.
 | |
|         # Corresponds to the JSON property `sampleRate`
 | |
|         # @return [Float]
 | |
|         attr_accessor :sample_rate
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @enable = args[:enable] if args.key?(:enable)
 | |
|           @sample_rate = args[:sample_rate] if args.key?(:sample_rate)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class BackendServiceReference
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `backendService`
 | |
|         # @return [String]
 | |
|         attr_accessor :backend_service
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @backend_service = args[:backend_service] if args.key?(:backend_service)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class BackendServicesScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of BackendServices contained in this scope.
 | |
|         # Corresponds to the JSON property `backendServices`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::BackendService>]
 | |
|         attr_accessor :backend_services
 | |
|       
 | |
|         # Informational warning which replaces the list of backend services when the
 | |
|         # list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::BackendServicesScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @backend_services = args[:backend_services] if args.key?(:backend_services)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # Informational warning which replaces the list of backend services when the
 | |
|         # list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::BackendServicesScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Associates `members` with a `role`.
 | |
|       class Binding
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Represents an expression text. Example:
 | |
|         # title: "User account presence" description: "Determines whether the request
 | |
|         # has a user account" expression: "size(request.user) > 0"
 | |
|         # Corresponds to the JSON property `condition`
 | |
|         # @return [Google::Apis::ComputeAlpha::Expr]
 | |
|         attr_accessor :condition
 | |
|       
 | |
|         # Specifies the identities requesting access for a Cloud Platform resource. `
 | |
|         # members` can have the following values:
 | |
|         # * `allUsers`: A special identifier that represents anyone who is on the
 | |
|         # internet; with or without a Google account.
 | |
|         # * `allAuthenticatedUsers`: A special identifier that represents anyone who is
 | |
|         # authenticated with a Google account or a service account.
 | |
|         # * `user:`emailid``: An email address that represents a specific Google account.
 | |
|         # For example, `alice@gmail.com` .
 | |
|         # * `serviceAccount:`emailid``: An email address that represents a service
 | |
|         # account. For example, `my-other-app@appspot.gserviceaccount.com`.
 | |
|         # * `group:`emailid``: An email address that represents a Google group. For
 | |
|         # example, `admins@example.com`.
 | |
|         # * `domain:`domain``: A Google Apps domain name that represents all the users
 | |
|         # of that domain. For example, `google.com` or `example.com`.
 | |
|         # Corresponds to the JSON property `members`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :members
 | |
|       
 | |
|         # Role that is assigned to `members`. For example, `roles/viewer`, `roles/editor`
 | |
|         # , or `roles/owner`.
 | |
|         # Corresponds to the JSON property `role`
 | |
|         # @return [String]
 | |
|         attr_accessor :role
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @condition = args[:condition] if args.key?(:condition)
 | |
|           @members = args[:members] if args.key?(:members)
 | |
|           @role = args[:role] if args.key?(:role)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class CacheInvalidationRule
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # If set, this invalidation rule will only apply to requests with a Host header
 | |
|         # matching host.
 | |
|         # Corresponds to the JSON property `host`
 | |
|         # @return [String]
 | |
|         attr_accessor :host
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `path`
 | |
|         # @return [String]
 | |
|         attr_accessor :path
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @host = args[:host] if args.key?(:host)
 | |
|           @path = args[:path] if args.key?(:path)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Message containing what to include in the cache key for a request for Cloud
 | |
|       # CDN.
 | |
|       class CacheKeyPolicy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # If true, requests to different hosts will be cached separately.
 | |
|         # Corresponds to the JSON property `includeHost`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :include_host
 | |
|         alias_method :include_host?, :include_host
 | |
|       
 | |
|         # If true, http and https requests will be cached separately.
 | |
|         # Corresponds to the JSON property `includeProtocol`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :include_protocol
 | |
|         alias_method :include_protocol?, :include_protocol
 | |
|       
 | |
|         # If true, include query string parameters in the cache key according to
 | |
|         # query_string_whitelist and query_string_blacklist. If neither is set, the
 | |
|         # entire query string will be included. If false, the query string will be
 | |
|         # excluded from the cache key entirely.
 | |
|         # Corresponds to the JSON property `includeQueryString`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :include_query_string
 | |
|         alias_method :include_query_string?, :include_query_string
 | |
|       
 | |
|         # Names of query string parameters to exclude in cache keys. All other
 | |
|         # parameters will be included. Either specify query_string_whitelist or
 | |
|         # query_string_blacklist, not both. '&' and '=' will be percent encoded and not
 | |
|         # treated as delimiters.
 | |
|         # Corresponds to the JSON property `queryStringBlacklist`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :query_string_blacklist
 | |
|       
 | |
|         # Names of query string parameters to include in cache keys. All other
 | |
|         # parameters will be excluded. Either specify query_string_whitelist or
 | |
|         # query_string_blacklist, not both. '&' and '=' will be percent encoded and not
 | |
|         # treated as delimiters.
 | |
|         # Corresponds to the JSON property `queryStringWhitelist`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :query_string_whitelist
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @include_host = args[:include_host] if args.key?(:include_host)
 | |
|           @include_protocol = args[:include_protocol] if args.key?(:include_protocol)
 | |
|           @include_query_string = args[:include_query_string] if args.key?(:include_query_string)
 | |
|           @query_string_blacklist = args[:query_string_blacklist] if args.key?(:query_string_blacklist)
 | |
|           @query_string_whitelist = args[:query_string_whitelist] if args.key?(:query_string_whitelist)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Represents a Commitment resource. Creating a Commitment resource means that
 | |
|       # you are purchasing a committed use contract with an explicit start and end
 | |
|       # time. You can create commitments based on vCPUs and memory usage and receive
 | |
|       # discounted rates. For full details, read Signing Up for Committed Use
 | |
|       # Discounts.
 | |
|       # Committed use discounts are subject to Google Cloud Platform's Service
 | |
|       # Specific Terms. By purchasing a committed use discount, you agree to these
 | |
|       # terms. Committed use discounts will not renew, so you must purchase a new
 | |
|       # commitment to continue receiving discounts. (== resource_for beta.commitments =
 | |
|       # =) (== resource_for v1.commitments ==)
 | |
|       class Commitment
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # List of allocations for this commitment.
 | |
|         # Corresponds to the JSON property `allocations`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Allocation>]
 | |
|         attr_accessor :allocations
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] Commitment end time in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `endTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :end_timestamp
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#commitment for commitments.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # The plan for this commitment, which determines duration and discount rate. The
 | |
|         # currently supported plans are TWELVE_MONTH (1 year), and THIRTY_SIX_MONTH (3
 | |
|         # years).
 | |
|         # Corresponds to the JSON property `plan`
 | |
|         # @return [String]
 | |
|         attr_accessor :plan
 | |
|       
 | |
|         # [Output Only] URL of the region where this commitment may be used.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # A list of commitment amounts for particular resources. Note that VCPU and
 | |
|         # MEMORY resource commitments must occur together.
 | |
|         # Corresponds to the JSON property `resources`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::ResourceCommitment>]
 | |
|         attr_accessor :resources
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # [Output Only] Commitment start time in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `startTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :start_timestamp
 | |
|       
 | |
|         # [Output Only] Status of the commitment with regards to eventual expiration (
 | |
|         # each commitment has an end date defined). One of the following values:
 | |
|         # NOT_YET_ACTIVE, ACTIVE, EXPIRED.
 | |
|         # Corresponds to the JSON property `status`
 | |
|         # @return [String]
 | |
|         attr_accessor :status
 | |
|       
 | |
|         # [Output Only] An optional, human-readable explanation of the status.
 | |
|         # Corresponds to the JSON property `statusMessage`
 | |
|         # @return [String]
 | |
|         attr_accessor :status_message
 | |
|       
 | |
|         # The type of commitment, which affects the discount rate and the eligible
 | |
|         # resources. Type MEMORY_OPTIMIZED specifies a commitment that will only apply
 | |
|         # to memory optimized machines.
 | |
|         # Corresponds to the JSON property `type`
 | |
|         # @return [String]
 | |
|         attr_accessor :type
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @allocations = args[:allocations] if args.key?(:allocations)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @end_timestamp = args[:end_timestamp] if args.key?(:end_timestamp)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @plan = args[:plan] if args.key?(:plan)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @resources = args[:resources] if args.key?(:resources)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @start_timestamp = args[:start_timestamp] if args.key?(:start_timestamp)
 | |
|           @status = args[:status] if args.key?(:status)
 | |
|           @status_message = args[:status_message] if args.key?(:status_message)
 | |
|           @type = args[:type] if args.key?(:type)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class CommitmentAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of CommitmentsScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::CommitmentsScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#commitmentAggregatedList for
 | |
|         # aggregated lists of commitments.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::CommitmentAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::CommitmentAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of Commitment resources.
 | |
|       class CommitmentList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of Commitment resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Commitment>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#commitmentList for lists of
 | |
|         # commitments.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::CommitmentList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::CommitmentList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class CommitmentsScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] A list of commitments contained in this scope.
 | |
|         # Corresponds to the JSON property `commitments`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Commitment>]
 | |
|         attr_accessor :commitments
 | |
|       
 | |
|         # [Output Only] Informational warning which replaces the list of commitments
 | |
|         # when the list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::CommitmentsScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @commitments = args[:commitments] if args.key?(:commitments)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning which replaces the list of commitments
 | |
|         # when the list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::CommitmentsScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A condition to be met.
 | |
|       class Condition
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Trusted attributes supplied by the IAM system.
 | |
|         # Corresponds to the JSON property `iam`
 | |
|         # @return [String]
 | |
|         attr_accessor :iam
 | |
|       
 | |
|         # An operator to apply the subject with.
 | |
|         # Corresponds to the JSON property `op`
 | |
|         # @return [String]
 | |
|         attr_accessor :op
 | |
|       
 | |
|         # Trusted attributes discharged by the service.
 | |
|         # Corresponds to the JSON property `svc`
 | |
|         # @return [String]
 | |
|         attr_accessor :svc
 | |
|       
 | |
|         # Trusted attributes supplied by any service that owns resources and uses the
 | |
|         # IAM system for access control.
 | |
|         # Corresponds to the JSON property `sys`
 | |
|         # @return [String]
 | |
|         attr_accessor :sys
 | |
|       
 | |
|         # DEPRECATED. Use 'values' instead.
 | |
|         # Corresponds to the JSON property `value`
 | |
|         # @return [String]
 | |
|         attr_accessor :value
 | |
|       
 | |
|         # The objects of the condition. This is mutually exclusive with 'value'.
 | |
|         # Corresponds to the JSON property `values`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :values
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @iam = args[:iam] if args.key?(:iam)
 | |
|           @op = args[:op] if args.key?(:op)
 | |
|           @svc = args[:svc] if args.key?(:svc)
 | |
|           @sys = args[:sys] if args.key?(:sys)
 | |
|           @value = args[:value] if args.key?(:value)
 | |
|           @values = args[:values] if args.key?(:values)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Message containing connection draining configuration.
 | |
|       class ConnectionDraining
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Time for which instance will be drained (not accept new connections, but still
 | |
|         # work to finish started).
 | |
|         # Corresponds to the JSON property `drainingTimeoutSec`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :draining_timeout_sec
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @draining_timeout_sec = args[:draining_timeout_sec] if args.key?(:draining_timeout_sec)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The specification for allowing client side cross-origin requests. Please see
 | |
|       # W3C Recommendation for Cross Origin Resource Sharing
 | |
|       class CorsPolicy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 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.
 | |
|         # Default is false.
 | |
|         # Corresponds to the JSON property `allowCredentials`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :allow_credentials
 | |
|         alias_method :allow_credentials?, :allow_credentials
 | |
|       
 | |
|         # Specifies the content for the Access-Control-Allow-Headers header.
 | |
|         # Corresponds to the JSON property `allowHeaders`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :allow_headers
 | |
|       
 | |
|         # Specifies the content for the Access-Control-Allow-Methods header.
 | |
|         # Corresponds to the JSON property `allowMethods`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :allow_methods
 | |
|       
 | |
|         # Specifies the regualar 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.
 | |
|         # Corresponds to the JSON property `allowOriginRegexes`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :allow_origin_regexes
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `allowOrigins`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :allow_origins
 | |
|       
 | |
|         # If true, specifies the CORS policy is disabled. The default value of false,
 | |
|         # which indicates that the CORS policy is in effect.
 | |
|         # Corresponds to the JSON property `disabled`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :disabled
 | |
|         alias_method :disabled?, :disabled
 | |
|       
 | |
|         # Specifies the content for the Access-Control-Expose-Headers header.
 | |
|         # Corresponds to the JSON property `exposeHeaders`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :expose_headers
 | |
|       
 | |
|         # Specifies how long the results of a preflight request can be cached. This
 | |
|         # translates to the content for the Access-Control-Max-Age header.
 | |
|         # Corresponds to the JSON property `maxAge`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :max_age
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @allow_credentials = args[:allow_credentials] if args.key?(:allow_credentials)
 | |
|           @allow_headers = args[:allow_headers] if args.key?(:allow_headers)
 | |
|           @allow_methods = args[:allow_methods] if args.key?(:allow_methods)
 | |
|           @allow_origin_regexes = args[:allow_origin_regexes] if args.key?(:allow_origin_regexes)
 | |
|           @allow_origins = args[:allow_origins] if args.key?(:allow_origins)
 | |
|           @disabled = args[:disabled] if args.key?(:disabled)
 | |
|           @expose_headers = args[:expose_headers] if args.key?(:expose_headers)
 | |
|           @max_age = args[:max_age] if args.key?(:max_age)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Represents a customer-supplied encryption key
 | |
|       class CustomerEncryptionKey
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The name of the encryption key that is stored in Google Cloud KMS.
 | |
|         # Corresponds to the JSON property `kmsKeyName`
 | |
|         # @return [String]
 | |
|         attr_accessor :kms_key_name
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `kmsKeyServiceAccount`
 | |
|         # @return [String]
 | |
|         attr_accessor :kms_key_service_account
 | |
|       
 | |
|         # Specifies a 256-bit customer-supplied encryption key, encoded in RFC 4648
 | |
|         # base64 to either encrypt or decrypt this resource.
 | |
|         # Corresponds to the JSON property `rawKey`
 | |
|         # @return [String]
 | |
|         attr_accessor :raw_key
 | |
|       
 | |
|         # Specifies an RFC 4648 base64 encoded, RSA-wrapped 2048-bit customer-supplied
 | |
|         # encryption key to either encrypt or decrypt this resource.
 | |
|         # The key must meet the following requirements before you can provide it to
 | |
|         # Compute Engine:
 | |
|         # - The key is wrapped using a RSA public key certificate provided by Google.
 | |
|         # - After being wrapped, the key must be encoded in RFC 4648 base64 encoding.
 | |
|         # Gets the RSA public key certificate provided by Google at:
 | |
|         # https://cloud-certs.storage.googleapis.com/google-cloud-csek-ingress.pem
 | |
|         # Corresponds to the JSON property `rsaEncryptedKey`
 | |
|         # @return [String]
 | |
|         attr_accessor :rsa_encrypted_key
 | |
|       
 | |
|         # [Output only] The RFC 4648 base64 encoded SHA-256 hash of the customer-
 | |
|         # supplied encryption key that protects this resource.
 | |
|         # Corresponds to the JSON property `sha256`
 | |
|         # @return [String]
 | |
|         attr_accessor :sha256
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @kms_key_name = args[:kms_key_name] if args.key?(:kms_key_name)
 | |
|           @kms_key_service_account = args[:kms_key_service_account] if args.key?(:kms_key_service_account)
 | |
|           @raw_key = args[:raw_key] if args.key?(:raw_key)
 | |
|           @rsa_encrypted_key = args[:rsa_encrypted_key] if args.key?(:rsa_encrypted_key)
 | |
|           @sha256 = args[:sha256] if args.key?(:sha256)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class CustomerEncryptionKeyProtectedDisk
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Represents a customer-supplied encryption key
 | |
|         # Corresponds to the JSON property `diskEncryptionKey`
 | |
|         # @return [Google::Apis::ComputeAlpha::CustomerEncryptionKey]
 | |
|         attr_accessor :disk_encryption_key
 | |
|       
 | |
|         # Specifies a valid partial or full URL to an existing Persistent Disk resource.
 | |
|         # This field is only applicable for persistent disks.
 | |
|         # Corresponds to the JSON property `source`
 | |
|         # @return [String]
 | |
|         attr_accessor :source
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @disk_encryption_key = args[:disk_encryption_key] if args.key?(:disk_encryption_key)
 | |
|           @source = args[:source] if args.key?(:source)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Deprecation status for a public resource.
 | |
|       class DeprecationStatus
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # An optional RFC3339 timestamp on or after which the state of this resource is
 | |
|         # intended to change to DELETED. This is only informational and the status will
 | |
|         # not change unless the client explicitly changes it.
 | |
|         # Corresponds to the JSON property `deleted`
 | |
|         # @return [String]
 | |
|         attr_accessor :deleted
 | |
|       
 | |
|         # An optional RFC3339 timestamp on or after which the state of this resource is
 | |
|         # intended to change to DEPRECATED. This is only informational and the status
 | |
|         # will not change unless the client explicitly changes it.
 | |
|         # Corresponds to the JSON property `deprecated`
 | |
|         # @return [String]
 | |
|         attr_accessor :deprecated
 | |
|       
 | |
|         # An optional RFC3339 timestamp on or after which the state of this resource is
 | |
|         # intended to change to OBSOLETE. This is only informational and the status will
 | |
|         # not change unless the client explicitly changes it.
 | |
|         # Corresponds to the JSON property `obsolete`
 | |
|         # @return [String]
 | |
|         attr_accessor :obsolete
 | |
|       
 | |
|         # The URL of the suggested replacement for a deprecated resource. The suggested
 | |
|         # replacement resource must be the same kind of resource as the deprecated
 | |
|         # resource.
 | |
|         # Corresponds to the JSON property `replacement`
 | |
|         # @return [String]
 | |
|         attr_accessor :replacement
 | |
|       
 | |
|         # The deprecation state of this resource. This can be DEPRECATED, OBSOLETE, or
 | |
|         # DELETED. Operations which create a new resource using a DEPRECATED resource
 | |
|         # will return successfully, but with a warning indicating the deprecated
 | |
|         # resource and recommending its replacement. Operations which use OBSOLETE or
 | |
|         # DELETED resources will be rejected and result in an error.
 | |
|         # Corresponds to the JSON property `state`
 | |
|         # @return [String]
 | |
|         attr_accessor :state
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @deleted = args[:deleted] if args.key?(:deleted)
 | |
|           @deprecated = args[:deprecated] if args.key?(:deprecated)
 | |
|           @obsolete = args[:obsolete] if args.key?(:obsolete)
 | |
|           @replacement = args[:replacement] if args.key?(:replacement)
 | |
|           @state = args[:state] if args.key?(:state)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A Disk resource. (== resource_for beta.disks ==) (== resource_for v1.disks ==)
 | |
|       class Disk
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # Represents a customer-supplied encryption key
 | |
|         # Corresponds to the JSON property `diskEncryptionKey`
 | |
|         # @return [Google::Apis::ComputeAlpha::CustomerEncryptionKey]
 | |
|         attr_accessor :disk_encryption_key
 | |
|       
 | |
|         # A list of features to enable on the guest operating system. Applicable only
 | |
|         # for bootable images. Read  Enabling guest operating system features to see a
 | |
|         # list of available options.
 | |
|         # Corresponds to the JSON property `guestOsFeatures`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::GuestOsFeature>]
 | |
|         attr_accessor :guest_os_features
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#disk for disks.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # A fingerprint for the labels being applied to this disk, which is essentially
 | |
|         # a hash of the labels set used for optimistic locking. The fingerprint is
 | |
|         # initially generated by Compute Engine and changes after every request to
 | |
|         # modify or update labels. You must always provide an up-to-date fingerprint
 | |
|         # hash in order to update or change labels, otherwise the request will fail with
 | |
|         # error 412 conditionNotMet.
 | |
|         # To see the latest fingerprint, make a get() request to retrieve a disk.
 | |
|         # Corresponds to the JSON property `labelFingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :label_fingerprint
 | |
|       
 | |
|         # Labels to apply to this disk. These can be later modified by the setLabels
 | |
|         # method.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         # [Output Only] Last attach timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `lastAttachTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :last_attach_timestamp
 | |
|       
 | |
|         # [Output Only] Last detach timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `lastDetachTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :last_detach_timestamp
 | |
|       
 | |
|         # Integer license codes indicating which licenses are attached to this disk.
 | |
|         # Corresponds to the JSON property `licenseCodes`
 | |
|         # @return [Array<Fixnum>]
 | |
|         attr_accessor :license_codes
 | |
|       
 | |
|         # A list of publicly visible licenses. Reserved for Google's use.
 | |
|         # Corresponds to the JSON property `licenses`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :licenses
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # Internal use only.
 | |
|         # Corresponds to the JSON property `options`
 | |
|         # @return [String]
 | |
|         attr_accessor :options
 | |
|       
 | |
|         # Physical block size of the persistent disk, in bytes. If not present in a
 | |
|         # request, a default value is used. Currently supported sizes are 4096 and 16384,
 | |
|         # other sizes may be added in the future. If an unsupported value is requested,
 | |
|         # the error message will list the supported values for the caller's project.
 | |
|         # Corresponds to the JSON property `physicalBlockSizeBytes`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :physical_block_size_bytes
 | |
|       
 | |
|         # [Output Only] URL of the region where the disk resides. Only applicable for
 | |
|         # regional resources. You must specify this field as part of the HTTP request
 | |
|         # URL. It is not settable as a field in the request body.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # URLs of the zones where the disk should be replicated to. Only applicable for
 | |
|         # regional resources.
 | |
|         # Corresponds to the JSON property `replicaZones`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :replica_zones
 | |
|       
 | |
|         # Resource policies applied to this disk for automatic snapshot creations.
 | |
|         # Corresponds to the JSON property `resourcePolicies`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :resource_policies
 | |
|       
 | |
|         # [Output Only] Server-defined fully-qualified URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # Size of the persistent disk, specified in GB. You can specify this field when
 | |
|         # creating a persistent disk using the sourceImage or sourceSnapshot parameter,
 | |
|         # or specify it alone to create an empty persistent disk.
 | |
|         # If you specify this field along with sourceImage or sourceSnapshot, the value
 | |
|         # of sizeGb must not be less than the size of the sourceImage or the size of the
 | |
|         # snapshot. Acceptable values are 1 to 65536, inclusive.
 | |
|         # Corresponds to the JSON property `sizeGb`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :size_gb
 | |
|       
 | |
|         # The source image used to create this disk. If the source image is deleted,
 | |
|         # this field will not be set.
 | |
|         # To create a disk with one of the public operating system images, specify the
 | |
|         # image by its family name. For example, specify family/debian-9 to use the
 | |
|         # latest Debian 9 image:
 | |
|         # projects/debian-cloud/global/images/family/debian-9
 | |
|         # Alternatively, use a specific version of a public operating system image:
 | |
|         # projects/debian-cloud/global/images/debian-9-stretch-vYYYYMMDD
 | |
|         # To create a disk with a custom image that you created, specify the image name
 | |
|         # in the following format:
 | |
|         # global/images/my-custom-image
 | |
|         # You can also specify a custom image by its image family, which returns the
 | |
|         # latest version of the image in that family. Replace the image name with family/
 | |
|         # family-name:
 | |
|         # global/images/family/my-image-family
 | |
|         # Corresponds to the JSON property `sourceImage`
 | |
|         # @return [String]
 | |
|         attr_accessor :source_image
 | |
|       
 | |
|         # Represents a customer-supplied encryption key
 | |
|         # Corresponds to the JSON property `sourceImageEncryptionKey`
 | |
|         # @return [Google::Apis::ComputeAlpha::CustomerEncryptionKey]
 | |
|         attr_accessor :source_image_encryption_key
 | |
|       
 | |
|         # [Output Only] The ID value of the image used to create this disk. This value
 | |
|         # identifies the exact image that was used to create this persistent disk. For
 | |
|         # example, if you created the persistent disk from an image that was later
 | |
|         # deleted and recreated under the same name, the source image ID would identify
 | |
|         # the exact version of the image that was used.
 | |
|         # Corresponds to the JSON property `sourceImageId`
 | |
|         # @return [String]
 | |
|         attr_accessor :source_image_id
 | |
|       
 | |
|         # The source snapshot used to create this disk. You can provide this as a
 | |
|         # partial or full URL to the resource. For example, the following are valid
 | |
|         # values:
 | |
|         # - https://www.googleapis.com/compute/v1/projects/project/global/snapshots/
 | |
|         # snapshot
 | |
|         # - projects/project/global/snapshots/snapshot
 | |
|         # - global/snapshots/snapshot
 | |
|         # Corresponds to the JSON property `sourceSnapshot`
 | |
|         # @return [String]
 | |
|         attr_accessor :source_snapshot
 | |
|       
 | |
|         # Represents a customer-supplied encryption key
 | |
|         # Corresponds to the JSON property `sourceSnapshotEncryptionKey`
 | |
|         # @return [Google::Apis::ComputeAlpha::CustomerEncryptionKey]
 | |
|         attr_accessor :source_snapshot_encryption_key
 | |
|       
 | |
|         # [Output Only] The unique ID of the snapshot used to create this disk. This
 | |
|         # value identifies the exact snapshot that was used to create this persistent
 | |
|         # disk. For example, if you created the persistent disk from a snapshot that was
 | |
|         # later deleted and recreated under the same name, the source snapshot ID would
 | |
|         # identify the exact version of the snapshot that was used.
 | |
|         # Corresponds to the JSON property `sourceSnapshotId`
 | |
|         # @return [String]
 | |
|         attr_accessor :source_snapshot_id
 | |
|       
 | |
|         # [Output Only] The status of disk creation.
 | |
|         # Corresponds to the JSON property `status`
 | |
|         # @return [String]
 | |
|         attr_accessor :status
 | |
|       
 | |
|         # [Deprecated] Storage type of the persistent disk.
 | |
|         # Corresponds to the JSON property `storageType`
 | |
|         # @return [String]
 | |
|         attr_accessor :storage_type
 | |
|       
 | |
|         # URL of the disk type resource describing which disk type to use to create the
 | |
|         # disk. Provide this when creating the disk. For example: project/zones/zone/
 | |
|         # diskTypes/pd-standard or pd-ssd
 | |
|         # Corresponds to the JSON property `type`
 | |
|         # @return [String]
 | |
|         attr_accessor :type
 | |
|       
 | |
|         # [Output Only] Links to the users of the disk (attached instances) in form:
 | |
|         # project/zones/zone/instances/instance
 | |
|         # Corresponds to the JSON property `users`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :users
 | |
|       
 | |
|         # [Output Only] URL of the zone where the disk resides. You must specify this
 | |
|         # field as part of the HTTP request URL. It is not settable as a field in the
 | |
|         # request body.
 | |
|         # Corresponds to the JSON property `zone`
 | |
|         # @return [String]
 | |
|         attr_accessor :zone
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @disk_encryption_key = args[:disk_encryption_key] if args.key?(:disk_encryption_key)
 | |
|           @guest_os_features = args[:guest_os_features] if args.key?(:guest_os_features)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|           @last_attach_timestamp = args[:last_attach_timestamp] if args.key?(:last_attach_timestamp)
 | |
|           @last_detach_timestamp = args[:last_detach_timestamp] if args.key?(:last_detach_timestamp)
 | |
|           @license_codes = args[:license_codes] if args.key?(:license_codes)
 | |
|           @licenses = args[:licenses] if args.key?(:licenses)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @options = args[:options] if args.key?(:options)
 | |
|           @physical_block_size_bytes = args[:physical_block_size_bytes] if args.key?(:physical_block_size_bytes)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @replica_zones = args[:replica_zones] if args.key?(:replica_zones)
 | |
|           @resource_policies = args[:resource_policies] if args.key?(:resource_policies)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @size_gb = args[:size_gb] if args.key?(:size_gb)
 | |
|           @source_image = args[:source_image] if args.key?(:source_image)
 | |
|           @source_image_encryption_key = args[:source_image_encryption_key] if args.key?(:source_image_encryption_key)
 | |
|           @source_image_id = args[:source_image_id] if args.key?(:source_image_id)
 | |
|           @source_snapshot = args[:source_snapshot] if args.key?(:source_snapshot)
 | |
|           @source_snapshot_encryption_key = args[:source_snapshot_encryption_key] if args.key?(:source_snapshot_encryption_key)
 | |
|           @source_snapshot_id = args[:source_snapshot_id] if args.key?(:source_snapshot_id)
 | |
|           @status = args[:status] if args.key?(:status)
 | |
|           @storage_type = args[:storage_type] if args.key?(:storage_type)
 | |
|           @type = args[:type] if args.key?(:type)
 | |
|           @users = args[:users] if args.key?(:users)
 | |
|           @zone = args[:zone] if args.key?(:zone)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class DiskAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of DisksScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::DisksScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#diskAggregatedList for
 | |
|         # aggregated lists of persistent disks.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::DiskAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::DiskAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A specification of the desired way to instantiate a disk in the instance
 | |
|       # template when its created from a source instance.
 | |
|       class DiskInstantiationConfig
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Specifies whether the disk will be auto-deleted when the instance is deleted (
 | |
|         # but not when the disk is detached from the instance).
 | |
|         # Corresponds to the JSON property `autoDelete`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :auto_delete
 | |
|         alias_method :auto_delete?, :auto_delete
 | |
|       
 | |
|         # The custom source image to be used to restore this disk when instantiating
 | |
|         # this instance template.
 | |
|         # Corresponds to the JSON property `customImage`
 | |
|         # @return [String]
 | |
|         attr_accessor :custom_image
 | |
|       
 | |
|         # Specifies the device name of the disk to which the configurations apply to.
 | |
|         # Corresponds to the JSON property `deviceName`
 | |
|         # @return [String]
 | |
|         attr_accessor :device_name
 | |
|       
 | |
|         # Specifies whether to include the disk and what image to use. Possible values
 | |
|         # are:
 | |
|         # - source-image: to use the same image that was used to create the source
 | |
|         # instance's corresponding disk. Applicable to the boot disk and additional read-
 | |
|         # write disks.
 | |
|         # - source-image-family: to use the same image family that was used to create
 | |
|         # the source instance's corresponding disk. Applicable to the boot disk and
 | |
|         # additional read-write disks.
 | |
|         # - custom-image: to use a user-provided image url for disk creation. Applicable
 | |
|         # to the boot disk and additional read-write disks.
 | |
|         # - attach-read-only: to attach a read-only disk. Applicable to read-only disks.
 | |
|         # - do-not-include: to exclude a disk from the template. Applicable to
 | |
|         # additional read-write disks, local SSDs, and read-only disks.
 | |
|         # Corresponds to the JSON property `instantiateFrom`
 | |
|         # @return [String]
 | |
|         attr_accessor :instantiate_from
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @auto_delete = args[:auto_delete] if args.key?(:auto_delete)
 | |
|           @custom_image = args[:custom_image] if args.key?(:custom_image)
 | |
|           @device_name = args[:device_name] if args.key?(:device_name)
 | |
|           @instantiate_from = args[:instantiate_from] if args.key?(:instantiate_from)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A list of Disk resources.
 | |
|       class DiskList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of Disk resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Disk>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#diskList for lists of disks.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::DiskList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::DiskList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class DiskMoveRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The URL of the destination zone to move the disk. This can be a full or
 | |
|         # partial URL. For example, the following are all valid URLs to a zone:
 | |
|         # - https://www.googleapis.com/compute/v1/projects/project/zones/zone
 | |
|         # - projects/project/zones/zone
 | |
|         # - zones/zone
 | |
|         # Corresponds to the JSON property `destinationZone`
 | |
|         # @return [String]
 | |
|         attr_accessor :destination_zone
 | |
|       
 | |
|         # The URL of the target disk to move. This can be a full or partial URL. For
 | |
|         # example, the following are all valid URLs to a disk:
 | |
|         # - https://www.googleapis.com/compute/v1/projects/project/zones/zone/disks/disk
 | |
|         # - projects/project/zones/zone/disks/disk
 | |
|         # - zones/zone/disks/disk
 | |
|         # Corresponds to the JSON property `targetDisk`
 | |
|         # @return [String]
 | |
|         attr_accessor :target_disk
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @destination_zone = args[:destination_zone] if args.key?(:destination_zone)
 | |
|           @target_disk = args[:target_disk] if args.key?(:target_disk)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A DiskType resource. (== resource_for beta.diskTypes ==) (== resource_for v1.
 | |
|       # diskTypes ==)
 | |
|       class DiskType
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # [Output Only] Server-defined default disk size in GB.
 | |
|         # Corresponds to the JSON property `defaultDiskSizeGb`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :default_disk_size_gb
 | |
|       
 | |
|         # Deprecation status for a public resource.
 | |
|         # Corresponds to the JSON property `deprecated`
 | |
|         # @return [Google::Apis::ComputeAlpha::DeprecationStatus]
 | |
|         attr_accessor :deprecated
 | |
|       
 | |
|         # [Output Only] An optional description of this resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#diskType for disk types.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] Name of the resource.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # [Output Only] URL of the region where the disk type resides. Only applicable
 | |
|         # for regional resources. You must specify this field as part of the HTTP
 | |
|         # request URL. It is not settable as a field in the request body.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # [Output Only] An optional textual description of the valid disk size, such as "
 | |
|         # 10GB-10TB".
 | |
|         # Corresponds to the JSON property `validDiskSize`
 | |
|         # @return [String]
 | |
|         attr_accessor :valid_disk_size
 | |
|       
 | |
|         # [Output Only] URL of the zone where the disk type resides. You must specify
 | |
|         # this field as part of the HTTP request URL. It is not settable as a field in
 | |
|         # the request body.
 | |
|         # Corresponds to the JSON property `zone`
 | |
|         # @return [String]
 | |
|         attr_accessor :zone
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @default_disk_size_gb = args[:default_disk_size_gb] if args.key?(:default_disk_size_gb)
 | |
|           @deprecated = args[:deprecated] if args.key?(:deprecated)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @valid_disk_size = args[:valid_disk_size] if args.key?(:valid_disk_size)
 | |
|           @zone = args[:zone] if args.key?(:zone)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class DiskTypeAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of DiskTypesScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::DiskTypesScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#diskTypeAggregatedList.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::DiskTypeAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::DiskTypeAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of disk types.
 | |
|       class DiskTypeList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of DiskType resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::DiskType>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#diskTypeList for disk types.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::DiskTypeList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::DiskTypeList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class DiskTypesScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] A list of disk types contained in this scope.
 | |
|         # Corresponds to the JSON property `diskTypes`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::DiskType>]
 | |
|         attr_accessor :disk_types
 | |
|       
 | |
|         # [Output Only] Informational warning which replaces the list of disk types when
 | |
|         # the list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::DiskTypesScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @disk_types = args[:disk_types] if args.key?(:disk_types)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning which replaces the list of disk types when
 | |
|         # the list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::DiskTypesScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class DisksAddResourcePoliciesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Resource policies to be added to this disk.
 | |
|         # Corresponds to the JSON property `resourcePolicies`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :resource_policies
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @resource_policies = args[:resource_policies] if args.key?(:resource_policies)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class DisksRemoveResourcePoliciesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Resource policies to be removed from this disk.
 | |
|         # Corresponds to the JSON property `resourcePolicies`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :resource_policies
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @resource_policies = args[:resource_policies] if args.key?(:resource_policies)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class DisksResizeRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The new size of the persistent disk, which is specified in GB.
 | |
|         # Corresponds to the JSON property `sizeGb`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :size_gb
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @size_gb = args[:size_gb] if args.key?(:size_gb)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class DisksScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] A list of disks contained in this scope.
 | |
|         # Corresponds to the JSON property `disks`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Disk>]
 | |
|         attr_accessor :disks
 | |
|       
 | |
|         # [Output Only] Informational warning which replaces the list of disks when the
 | |
|         # list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::DisksScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @disks = args[:disks] if args.key?(:disks)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning which replaces the list of disks when the
 | |
|         # list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::DisksScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A set of Display Device options
 | |
|       class DisplayDevice
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Defines whether the instance has Display enabled.
 | |
|         # Corresponds to the JSON property `enableDisplay`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :enable_display
 | |
|         alias_method :enable_display?, :enable_display
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @enable_display = args[:enable_display] if args.key?(:enable_display)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class DistributionPolicy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Zones where the regional managed instance group will create and manage
 | |
|         # instances.
 | |
|         # Corresponds to the JSON property `zones`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::DistributionPolicyZoneConfiguration>]
 | |
|         attr_accessor :zones
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @zones = args[:zones] if args.key?(:zones)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class DistributionPolicyZoneConfiguration
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The URL of the zone. The zone must exist in the region where the managed
 | |
|         # instance group is located.
 | |
|         # Corresponds to the JSON property `zone`
 | |
|         # @return [String]
 | |
|         attr_accessor :zone
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @zone = args[:zone] if args.key?(:zone)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A Duration represents a fixed-length span of time represented as a count of
 | |
|       # seconds and fractions of seconds at nanosecond resolution. It is independent
 | |
|       # of any calendar and concepts like "day" or "month". Range is approximately 10,
 | |
|       # 000 years.
 | |
|       class Duration
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `nanos`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :nanos
 | |
|       
 | |
|         # Span of time at a resolution of a second. Must be from 0 to 315,576,000,000
 | |
|         # inclusive. Note: these bounds are computed from: 60 sec/min * 60 min/hr * 24
 | |
|         # hr/day * 365.25 days/year * 10000 years
 | |
|         # Corresponds to the JSON property `seconds`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :seconds
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @nanos = args[:nanos] if args.key?(:nanos)
 | |
|           @seconds = args[:seconds] if args.key?(:seconds)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ExchangedPeeringRoute
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The destination range of the route.
 | |
|         # Corresponds to the JSON property `destRange`
 | |
|         # @return [String]
 | |
|         attr_accessor :dest_range
 | |
|       
 | |
|         # If the peering route is imported if there is no confliction.
 | |
|         # Corresponds to the JSON property `imported`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :imported
 | |
|         alias_method :imported?, :imported
 | |
|       
 | |
|         # The region of peering route next hop, only applies to dynamic routes.
 | |
|         # Corresponds to the JSON property `nextHopRegion`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_hop_region
 | |
|       
 | |
|         # The priority of the peering route.
 | |
|         # Corresponds to the JSON property `priority`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :priority
 | |
|       
 | |
|         # The type of the peering route.
 | |
|         # Corresponds to the JSON property `type`
 | |
|         # @return [String]
 | |
|         attr_accessor :type
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @dest_range = args[:dest_range] if args.key?(:dest_range)
 | |
|           @imported = args[:imported] if args.key?(:imported)
 | |
|           @next_hop_region = args[:next_hop_region] if args.key?(:next_hop_region)
 | |
|           @priority = args[:priority] if args.key?(:priority)
 | |
|           @type = args[:type] if args.key?(:type)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ExchangedPeeringRoutesList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of ExchangedPeeringRoute resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::ExchangedPeeringRoute>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#exchangedPeeringRoutesList for
 | |
|         # exchanged peering routes lists.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::ExchangedPeeringRoutesList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::ExchangedPeeringRoutesList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Represents an expression text. Example:
 | |
|       # title: "User account presence" description: "Determines whether the request
 | |
|       # has a user account" expression: "size(request.user) > 0"
 | |
|       class Expr
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # An optional description of the expression. This is a longer text which
 | |
|         # describes the expression, e.g. when hovered over it in a UI.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # Textual representation of an expression in Common Expression Language syntax.
 | |
|         # The application context of the containing message determines which well-known
 | |
|         # feature set of CEL is supported.
 | |
|         # Corresponds to the JSON property `expression`
 | |
|         # @return [String]
 | |
|         attr_accessor :expression
 | |
|       
 | |
|         # An optional string indicating the location of the expression for error
 | |
|         # reporting, e.g. a file name and a position in the file.
 | |
|         # Corresponds to the JSON property `location`
 | |
|         # @return [String]
 | |
|         attr_accessor :location
 | |
|       
 | |
|         # An optional title for the expression, i.e. a short string describing its
 | |
|         # purpose. This can be used e.g. in UIs which allow to enter the expression.
 | |
|         # Corresponds to the JSON property `title`
 | |
|         # @return [String]
 | |
|         attr_accessor :title
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @expression = args[:expression] if args.key?(:expression)
 | |
|           @location = args[:location] if args.key?(:location)
 | |
|           @title = args[:title] if args.key?(:title)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # External VPN gateway is the on-premises VPN gateway(s) or another cloud
 | |
|       # provider?s VPN gateway that connects to your Google Cloud VPN gateway. To
 | |
|       # create a highly available VPN from Google Cloud to your on-premises side or
 | |
|       # another Cloud provider's VPN gateway, you must create a external VPN gateway
 | |
|       # resource in GCP, which provides the information to GCP about your external VPN
 | |
|       # gateway.
 | |
|       class ExternalVpnGateway
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # List of interfaces for this external VPN gateway.
 | |
|         # Corresponds to the JSON property `interfaces`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::ExternalVpnGatewayInterface>]
 | |
|         attr_accessor :interfaces
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#externalVpnGateway for
 | |
|         # externalVpnGateways.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # A fingerprint for the labels being applied to this ExternalVpnGateway, which
 | |
|         # is essentially a hash of the labels set used for optimistic locking. The
 | |
|         # fingerprint is initially generated by Compute Engine and changes after every
 | |
|         # request to modify or update labels. You must always provide an up-to-date
 | |
|         # fingerprint hash in order to update or change labels, otherwise the request
 | |
|         # will fail with error 412 conditionNotMet.
 | |
|         # To see the latest fingerprint, make a get() request to retrieve an
 | |
|         # ExternalVpnGateway.
 | |
|         # Corresponds to the JSON property `labelFingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :label_fingerprint
 | |
|       
 | |
|         # Labels to apply to this ExternalVpnGateway resource. These can be later
 | |
|         # modified by the setLabels method. Each label key/value must comply with
 | |
|         # RFC1035. Label values may be empty.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # Indicates the user-supplied redundancy type of this external VPN gateway.
 | |
|         # Corresponds to the JSON property `redundancyType`
 | |
|         # @return [String]
 | |
|         attr_accessor :redundancy_type
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @interfaces = args[:interfaces] if args.key?(:interfaces)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @redundancy_type = args[:redundancy_type] if args.key?(:redundancy_type)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The interface for the external VPN gateway.
 | |
|       class ExternalVpnGatewayInterface
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The numeric ID of this interface. The allowed input values for this id for
 | |
|         # different redundancy types of external VPN gateway:
 | |
|         # SINGLE_IP_INTERNALLY_REDUNDANT - 0 TWO_IPS_REDUNDANCY - 0, 1
 | |
|         # FOUR_IPS_REDUNDANCY - 0, 1, 2, 3
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # IP address of the interface in the external VPN gateway. Only IPv4 is
 | |
|         # supported. This IP address can be either from your on-premise gateway or
 | |
|         # another Cloud provider?s VPN gateway, it cannot be an IP address from Google
 | |
|         # Compute Engine.
 | |
|         # Corresponds to the JSON property `ipAddress`
 | |
|         # @return [String]
 | |
|         attr_accessor :ip_address
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @ip_address = args[:ip_address] if args.key?(:ip_address)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Response to the list request, and contains a list of externalVpnGateways.
 | |
|       class ExternalVpnGatewayList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `etag`
 | |
|         # @return [String]
 | |
|         attr_accessor :etag
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of ExternalVpnGateway resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::ExternalVpnGateway>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#externalVpnGatewayList  for
 | |
|         # lists of externalVpnGateways.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::ExternalVpnGatewayList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @etag = args[:etag] if args.key?(:etag)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::ExternalVpnGatewayList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Represents a Firewall resource.
 | |
|       class Firewall
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The list of ALLOW rules specified by this firewall. Each rule specifies a
 | |
|         # protocol and port-range tuple that describes a permitted connection.
 | |
|         # Corresponds to the JSON property `allowed`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Firewall::Allowed>]
 | |
|         attr_accessor :allowed
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # The list of DENY rules specified by this firewall. Each rule specifies a
 | |
|         # protocol and port-range tuple that describes a denied connection.
 | |
|         # Corresponds to the JSON property `denied`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Firewall::Denied>]
 | |
|         attr_accessor :denied
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # If destination ranges are specified, the firewall will apply only to traffic
 | |
|         # that has destination IP address in these ranges. These ranges must be
 | |
|         # expressed in CIDR format. Only IPv4 is supported.
 | |
|         # Corresponds to the JSON property `destinationRanges`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :destination_ranges
 | |
|       
 | |
|         # Direction of traffic to which this firewall applies; default is INGRESS. Note:
 | |
|         # For INGRESS traffic, it is NOT supported to specify destinationRanges; For
 | |
|         # EGRESS traffic, it is NOT supported to specify sourceRanges OR sourceTags.
 | |
|         # Corresponds to the JSON property `direction`
 | |
|         # @return [String]
 | |
|         attr_accessor :direction
 | |
|       
 | |
|         # Denotes whether the firewall rule is disabled, i.e not applied to the network
 | |
|         # it is associated with. When set to true, the firewall rule is not enforced and
 | |
|         # the network behaves as if it did not exist. If this is unspecified, the
 | |
|         # firewall rule will be enabled.
 | |
|         # Corresponds to the JSON property `disabled`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :disabled
 | |
|         alias_method :disabled?, :disabled
 | |
|       
 | |
|         # Deprecated in favor of enable in LogConfig. This field denotes whether to
 | |
|         # enable logging for a particular firewall rule. If logging is enabled, logs
 | |
|         # will be exported to Stackdriver.
 | |
|         # Corresponds to the JSON property `enableLogging`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :enable_logging
 | |
|         alias_method :enable_logging?, :enable_logging
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#firewall for firewall rules.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # The available logging options for a firewall rule.
 | |
|         # Corresponds to the JSON property `logConfig`
 | |
|         # @return [Google::Apis::ComputeAlpha::FirewallLogConfig]
 | |
|         attr_accessor :log_config
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # URL of the network resource for this firewall rule. If not specified when
 | |
|         # creating a firewall rule, the default network is used:
 | |
|         # global/networks/default
 | |
|         # If you choose to specify this property, you can specify the network as a full
 | |
|         # or partial URL. For example, the following are all valid URLs:
 | |
|         # - https://www.googleapis.com/compute/v1/projects/myproject/global/networks/my-
 | |
|         # network
 | |
|         # - projects/myproject/global/networks/my-network
 | |
|         # - global/networks/default
 | |
|         # Corresponds to the JSON property `network`
 | |
|         # @return [String]
 | |
|         attr_accessor :network
 | |
|       
 | |
|         # Priority for this rule. This is an integer between 0 and 65535, both inclusive.
 | |
|         # When not specified, the value assumed is 1000. Relative priorities determine
 | |
|         # precedence of conflicting rules. Lower value of priority implies higher
 | |
|         # precedence (eg, a rule with priority 0 has higher precedence than a rule with
 | |
|         # priority 1). DENY rules take precedence over ALLOW rules having equal priority.
 | |
|         # Corresponds to the JSON property `priority`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :priority
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # If source ranges are specified, the firewall will apply only to traffic that
 | |
|         # has source IP address in these ranges. These ranges must be expressed in CIDR
 | |
|         # format. One or both of sourceRanges and sourceTags may be set. If both
 | |
|         # properties are set, the firewall will apply to traffic that has source IP
 | |
|         # address within sourceRanges OR the source IP that belongs to a tag listed in
 | |
|         # the sourceTags property. The connection does not need to match both properties
 | |
|         # for the firewall to apply. Only IPv4 is supported.
 | |
|         # Corresponds to the JSON property `sourceRanges`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :source_ranges
 | |
|       
 | |
|         # If source service accounts are specified, the firewall will apply only to
 | |
|         # traffic originating from an instance with a service account in this list.
 | |
|         # Source service accounts cannot be used to control traffic to an instance's
 | |
|         # external IP address because service accounts are associated with an instance,
 | |
|         # not an IP address. sourceRanges can be set at the same time as
 | |
|         # sourceServiceAccounts. If both are set, the firewall will apply to traffic
 | |
|         # that has source IP address within sourceRanges OR the source IP belongs to an
 | |
|         # instance with service account listed in sourceServiceAccount. The connection
 | |
|         # does not need to match both properties for the firewall to apply.
 | |
|         # sourceServiceAccounts cannot be used at the same time as sourceTags or
 | |
|         # targetTags.
 | |
|         # Corresponds to the JSON property `sourceServiceAccounts`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :source_service_accounts
 | |
|       
 | |
|         # If source tags are specified, the firewall rule applies only to traffic with
 | |
|         # source IPs that match the primary network interfaces of VM instances that have
 | |
|         # the tag and are in the same VPC network. Source tags cannot be used to control
 | |
|         # traffic to an instance's external IP address, it only applies to traffic
 | |
|         # between instances in the same virtual network. Because tags are associated
 | |
|         # with instances, not IP addresses. One or both of sourceRanges and sourceTags
 | |
|         # may be set. If both properties are set, the firewall will apply to traffic
 | |
|         # that has source IP address within sourceRanges OR the source IP that belongs
 | |
|         # to a tag listed in the sourceTags property. The connection does not need to
 | |
|         # match both properties for the firewall to apply.
 | |
|         # Corresponds to the JSON property `sourceTags`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :source_tags
 | |
|       
 | |
|         # A list of service accounts indicating sets of instances located in the network
 | |
|         # that may make network connections as specified in allowed[].
 | |
|         # targetServiceAccounts cannot be used at the same time as targetTags or
 | |
|         # sourceTags. If neither targetServiceAccounts nor targetTags are specified, the
 | |
|         # firewall rule applies to all instances on the specified network.
 | |
|         # Corresponds to the JSON property `targetServiceAccounts`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :target_service_accounts
 | |
|       
 | |
|         # A list of tags that controls which instances the firewall rule applies to. If
 | |
|         # targetTags are specified, then the firewall rule applies only to instances in
 | |
|         # the VPC network that have one of those tags. If no targetTags are specified,
 | |
|         # the firewall rule applies to all instances on the specified network.
 | |
|         # Corresponds to the JSON property `targetTags`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :target_tags
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @allowed = args[:allowed] if args.key?(:allowed)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @denied = args[:denied] if args.key?(:denied)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @destination_ranges = args[:destination_ranges] if args.key?(:destination_ranges)
 | |
|           @direction = args[:direction] if args.key?(:direction)
 | |
|           @disabled = args[:disabled] if args.key?(:disabled)
 | |
|           @enable_logging = args[:enable_logging] if args.key?(:enable_logging)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @log_config = args[:log_config] if args.key?(:log_config)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @network = args[:network] if args.key?(:network)
 | |
|           @priority = args[:priority] if args.key?(:priority)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @source_ranges = args[:source_ranges] if args.key?(:source_ranges)
 | |
|           @source_service_accounts = args[:source_service_accounts] if args.key?(:source_service_accounts)
 | |
|           @source_tags = args[:source_tags] if args.key?(:source_tags)
 | |
|           @target_service_accounts = args[:target_service_accounts] if args.key?(:target_service_accounts)
 | |
|           @target_tags = args[:target_tags] if args.key?(:target_tags)
 | |
|         end
 | |
|         
 | |
|         # 
 | |
|         class Allowed
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # The IP protocol to which this rule applies. The protocol type is required when
 | |
|           # creating a firewall rule. This value can either be one of the following well
 | |
|           # known protocol strings (tcp, udp, icmp, esp, ah, ipip, sctp), or the IP
 | |
|           # protocol number.
 | |
|           # Corresponds to the JSON property `IPProtocol`
 | |
|           # @return [String]
 | |
|           attr_accessor :ip_protocol
 | |
|         
 | |
|           # An optional list of ports to which this rule applies. This field is only
 | |
|           # applicable for UDP or TCP protocol. Each entry must be either an integer or a
 | |
|           # range. If not specified, this rule applies to connections through any port.
 | |
|           # Example inputs include: ["22"], ["80","443"], and ["12345-12349"].
 | |
|           # Corresponds to the JSON property `ports`
 | |
|           # @return [Array<String>]
 | |
|           attr_accessor :ports
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @ip_protocol = args[:ip_protocol] if args.key?(:ip_protocol)
 | |
|             @ports = args[:ports] if args.key?(:ports)
 | |
|           end
 | |
|         end
 | |
|         
 | |
|         # 
 | |
|         class Denied
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # The IP protocol to which this rule applies. The protocol type is required when
 | |
|           # creating a firewall rule. This value can either be one of the following well
 | |
|           # known protocol strings (tcp, udp, icmp, esp, ah, ipip, sctp), or the IP
 | |
|           # protocol number.
 | |
|           # Corresponds to the JSON property `IPProtocol`
 | |
|           # @return [String]
 | |
|           attr_accessor :ip_protocol
 | |
|         
 | |
|           # An optional list of ports to which this rule applies. This field is only
 | |
|           # applicable for UDP or TCP protocol. Each entry must be either an integer or a
 | |
|           # range. If not specified, this rule applies to connections through any port.
 | |
|           # Example inputs include: ["22"], ["80","443"], and ["12345-12349"].
 | |
|           # Corresponds to the JSON property `ports`
 | |
|           # @return [Array<String>]
 | |
|           attr_accessor :ports
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @ip_protocol = args[:ip_protocol] if args.key?(:ip_protocol)
 | |
|             @ports = args[:ports] if args.key?(:ports)
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of firewalls.
 | |
|       class FirewallList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of Firewall resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Firewall>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#firewallList for lists of
 | |
|         # firewalls.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::FirewallList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::FirewallList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The available logging options for a firewall rule.
 | |
|       class FirewallLogConfig
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # This field denotes whether to enable logging for a particular firewall rule.
 | |
|         # Corresponds to the JSON property `enable`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :enable
 | |
|         alias_method :enable?, :enable
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @enable = args[:enable] if args.key?(:enable)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Encapsulates numeric value that can be either absolute or relative.
 | |
|       class FixedOrPercent
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Absolute value of VM instances calculated based on the specific
 | |
|         # mode.
 | |
|         # 
 | |
|         # - If the value is fixed, then the caculated value is equal to the fixed value.
 | |
|         # - If the value is a percent, then the calculated value is percent/100 *
 | |
|         # targetSize. For example, the calculated value of a 80% of a managed instance
 | |
|         # group with 150 instances would be (80/100 * 150) = 120 VM instances. If there
 | |
|         # is a remainder, the number is rounded up.
 | |
|         # Corresponds to the JSON property `calculated`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :calculated
 | |
|       
 | |
|         # Specifies a fixed number of VM instances. This must be a positive integer.
 | |
|         # Corresponds to the JSON property `fixed`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :fixed
 | |
|       
 | |
|         # Specifies a percentage of instances between 0 to 100%, inclusive. For example,
 | |
|         # specify 80 for 80%.
 | |
|         # Corresponds to the JSON property `percent`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :percent
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @calculated = args[:calculated] if args.key?(:calculated)
 | |
|           @fixed = args[:fixed] if args.key?(:fixed)
 | |
|           @percent = args[:percent] if args.key?(:percent)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A ForwardingRule resource. A ForwardingRule resource specifies which pool of
 | |
|       # target virtual machines to forward a packet to if it matches the given [
 | |
|       # IPAddress, IPProtocol, ports] tuple. (== resource_for beta.forwardingRules ==)
 | |
|       # (== resource_for v1.forwardingRules ==) (== resource_for beta.
 | |
|       # globalForwardingRules ==) (== resource_for v1.globalForwardingRules ==) (==
 | |
|       # resource_for beta.regionForwardingRules ==) (== resource_for v1.
 | |
|       # regionForwardingRules ==)
 | |
|       class ForwardingRule
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The IP address that this forwarding rule is serving on behalf of.
 | |
|         # Addresses are restricted based on the forwarding rule's load balancing scheme (
 | |
|         # EXTERNAL or INTERNAL) and scope (global or regional).
 | |
|         # When the load balancing scheme is EXTERNAL, for global forwarding rules, the
 | |
|         # address must be a global IP, and for regional forwarding rules, the address
 | |
|         # must live in the same region as the forwarding rule. If this field is empty,
 | |
|         # an ephemeral IPv4 address from the same scope (global or regional) will be
 | |
|         # assigned. A regional forwarding rule supports IPv4 only. A global forwarding
 | |
|         # rule supports either IPv4 or IPv6.
 | |
|         # When the load balancing scheme is INTERNAL_SELF_MANAGED, this must be a URL
 | |
|         # reference to an existing Address resource ( internal regional static IP
 | |
|         # address), with a purpose of GCE_END_POINT and address_type of INTERNAL.
 | |
|         # When the load balancing scheme is INTERNAL, this can only be an RFC 1918 IP
 | |
|         # address belonging to the network/subnet configured for the forwarding rule. By
 | |
|         # default, if this field is empty, an ephemeral internal IP address will be
 | |
|         # automatically allocated from the IP range of the subnet or network configured
 | |
|         # for this forwarding rule.
 | |
|         # An address can be specified either by a literal IP address or a URL reference
 | |
|         # to an existing Address resource. The following examples are all valid:
 | |
|         # - 100.1.2.3
 | |
|         # - https://www.googleapis.com/compute/v1/projects/project/regions/region/
 | |
|         # addresses/address
 | |
|         # - projects/project/regions/region/addresses/address
 | |
|         # - regions/region/addresses/address
 | |
|         # - global/addresses/address
 | |
|         # - address
 | |
|         # Corresponds to the JSON property `IPAddress`
 | |
|         # @return [String]
 | |
|         attr_accessor :ip_address
 | |
|       
 | |
|         # The IP protocol to which this rule applies. Valid options are TCP, UDP, ESP,
 | |
|         # AH, SCTP or ICMP.
 | |
|         # When the load balancing scheme is INTERNAL, only TCP and UDP are valid. When
 | |
|         # the load balancing scheme is INTERNAL_SELF_MANAGED, only TCPis valid.
 | |
|         # Corresponds to the JSON property `IPProtocol`
 | |
|         # @return [String]
 | |
|         attr_accessor :ip_protocol
 | |
|       
 | |
|         # This field is used along with the backend_service field for internal load
 | |
|         # balancing or with the target field for internal TargetInstance. This field
 | |
|         # cannot be used with port or portRange fields.
 | |
|         # When the load balancing scheme is INTERNAL and protocol is TCP/UDP, specify
 | |
|         # this field to allow packets addressed to any ports will be forwarded to the
 | |
|         # backends configured with this forwarding rule.
 | |
|         # Corresponds to the JSON property `allPorts`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :all_ports
 | |
|         alias_method :all_ports?, :all_ports
 | |
|       
 | |
|         # This field is used along with the backend_service field for internal load
 | |
|         # balancing or with the target field for internal TargetInstance. If the field
 | |
|         # is set to TRUE, clients can access ILB from all regions. Otherwise only allows
 | |
|         # access from clients in the same region as the internal load balancer.
 | |
|         # Corresponds to the JSON property `allowGlobalAccess`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :allow_global_access
 | |
|         alias_method :allow_global_access?, :allow_global_access
 | |
|       
 | |
|         # This field is only used for INTERNAL load balancing.
 | |
|         # For internal load balancing, this field identifies the BackendService resource
 | |
|         # to receive the matched traffic.
 | |
|         # Corresponds to the JSON property `backendService`
 | |
|         # @return [String]
 | |
|         attr_accessor :backend_service
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # Fingerprint of this resource. A hash of the contents stored in this object.
 | |
|         # This field is used in optimistic locking. This field will be ignored when
 | |
|         # inserting a ForwardingRule. Include the fingerprint in patch request to ensure
 | |
|         # that you do not overwrite changes that were applied from another concurrent
 | |
|         # request.
 | |
|         # To see the latest fingerprint, make a get() request to retrieve a
 | |
|         # ForwardingRule.
 | |
|         # Corresponds to the JSON property `fingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :fingerprint
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # The IP Version that will be used by this forwarding rule. Valid options are
 | |
|         # IPV4 or IPV6. This can only be specified for an external global forwarding
 | |
|         # rule.
 | |
|         # Corresponds to the JSON property `ipVersion`
 | |
|         # @return [String]
 | |
|         attr_accessor :ip_version
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#forwardingRule for
 | |
|         # Forwarding Rule resources.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # A fingerprint for the labels being applied to this resource, which is
 | |
|         # essentially a hash of the labels set used for optimistic locking. The
 | |
|         # fingerprint is initially generated by Compute Engine and changes after every
 | |
|         # request to modify or update labels. You must always provide an up-to-date
 | |
|         # fingerprint hash in order to update or change labels, otherwise the request
 | |
|         # will fail with error 412 conditionNotMet.
 | |
|         # To see the latest fingerprint, make a get() request to retrieve a
 | |
|         # ForwardingRule.
 | |
|         # Corresponds to the JSON property `labelFingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :label_fingerprint
 | |
|       
 | |
|         # Labels to apply to this resource. These can be later modified by the setLabels
 | |
|         # method. Each label key/value pair must comply with RFC1035. Label values may
 | |
|         # be empty.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         # This signifies what the ForwardingRule will be used for and can only take the
 | |
|         # following values: INTERNAL, INTERNAL_SELF_MANAGED, EXTERNAL. The value of
 | |
|         # INTERNAL means that this will be used for Internal Network Load Balancing (TCP,
 | |
|         # UDP). The value of INTERNAL_SELF_MANAGED means that this will be used for
 | |
|         # Internal Global HTTP(S) LB. The value of EXTERNAL means that this will be used
 | |
|         # for External Load Balancing (HTTP(S) LB, External TCP/UDP LB, SSL Proxy)
 | |
|         # Corresponds to the JSON property `loadBalancingScheme`
 | |
|         # @return [String]
 | |
|         attr_accessor :load_balancing_scheme
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # This field is not used for external load balancing.
 | |
|         # For INTERNAL and INTERNAL_SELF_MANAGED load balancing, this field identifies
 | |
|         # the network that the load balanced IP should belong to for this Forwarding
 | |
|         # Rule. If this field is not specified, the default network will be used.
 | |
|         # Corresponds to the JSON property `network`
 | |
|         # @return [String]
 | |
|         attr_accessor :network
 | |
|       
 | |
|         # This signifies the networking tier used for configuring this load balancer and
 | |
|         # can only take the following values: PREMIUM , STANDARD.
 | |
|         # For regional ForwardingRule, the valid values are PREMIUM and STANDARD. For
 | |
|         # GlobalForwardingRule, the valid value is PREMIUM.
 | |
|         # If this field is not specified, it is assumed to be PREMIUM. If IPAddress is
 | |
|         # specified, this value must be equal to the networkTier of the Address.
 | |
|         # Corresponds to the JSON property `networkTier`
 | |
|         # @return [String]
 | |
|         attr_accessor :network_tier
 | |
|       
 | |
|         # This field is used along with the target field for TargetHttpProxy,
 | |
|         # TargetHttpsProxy, TargetSslProxy, TargetTcpProxy, TargetVpnGateway, TargetPool,
 | |
|         # TargetInstance.
 | |
|         # Applicable only when IPProtocol is TCP, UDP, or SCTP, only packets addressed
 | |
|         # to ports in the specified range will be forwarded to target. Forwarding rules
 | |
|         # with the same [IPAddress, IPProtocol] pair must have disjoint port ranges.
 | |
|         # Some types of forwarding target have constraints on the acceptable ports:
 | |
|         # - TargetHttpProxy: 80, 8080
 | |
|         # - TargetHttpsProxy: 443
 | |
|         # - TargetTcpProxy: 25, 43, 110, 143, 195, 443, 465, 587, 700, 993, 995, 1688,
 | |
|         # 1883, 5222
 | |
|         # - TargetSslProxy: 25, 43, 110, 143, 195, 443, 465, 587, 700, 993, 995, 1688,
 | |
|         # 1883, 5222
 | |
|         # - TargetVpnGateway: 500, 4500
 | |
|         # Corresponds to the JSON property `portRange`
 | |
|         # @return [String]
 | |
|         attr_accessor :port_range
 | |
|       
 | |
|         # This field is used along with the backend_service field for internal load
 | |
|         # balancing.
 | |
|         # When the load balancing scheme is INTERNAL, a list of ports can be configured,
 | |
|         # for example, ['80'], ['8000','9000'] etc. Only packets addressed to these
 | |
|         # ports will be forwarded to the backends configured with this forwarding rule.
 | |
|         # You may specify a maximum of up to 5 ports.
 | |
|         # Corresponds to the JSON property `ports`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :ports
 | |
|       
 | |
|         # [Output Only] URL of the region where the regional forwarding rule resides.
 | |
|         # This field is not applicable to global forwarding rules. You must specify this
 | |
|         # field as part of the HTTP request URL. It is not settable as a field in the
 | |
|         # request body.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # An optional prefix to the service name for this Forwarding Rule. If specified,
 | |
|         # will be the first label of the fully qualified service name.
 | |
|         # The label must be 1-63 characters long, and comply with RFC1035. Specifically,
 | |
|         # the label 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.
 | |
|         # This field is only used for internal load balancing.
 | |
|         # Corresponds to the JSON property `serviceLabel`
 | |
|         # @return [String]
 | |
|         attr_accessor :service_label
 | |
|       
 | |
|         # [Output Only] The internal fully qualified service name for this Forwarding
 | |
|         # Rule.
 | |
|         # This field is only used for internal load balancing.
 | |
|         # Corresponds to the JSON property `serviceName`
 | |
|         # @return [String]
 | |
|         attr_accessor :service_name
 | |
|       
 | |
|         # This field is only used for INTERNAL load balancing.
 | |
|         # For internal load balancing, this field identifies the subnetwork that the
 | |
|         # load balanced IP should belong to for this Forwarding Rule.
 | |
|         # If the network specified is in auto subnet mode, this field is optional.
 | |
|         # However, if the network is in custom subnet mode, a subnetwork must be
 | |
|         # specified.
 | |
|         # Corresponds to the JSON property `subnetwork`
 | |
|         # @return [String]
 | |
|         attr_accessor :subnetwork
 | |
|       
 | |
|         # The URL of the target resource to receive the matched traffic. For regional
 | |
|         # forwarding rules, this target must live in the same region as the forwarding
 | |
|         # rule. For global forwarding rules, this target must be a global load balancing
 | |
|         # resource. The forwarded traffic must be of a type appropriate to the target
 | |
|         # object. For INTERNAL_SELF_MANAGED" load balancing, only HTTP and HTTPS targets
 | |
|         # are valid.
 | |
|         # Corresponds to the JSON property `target`
 | |
|         # @return [String]
 | |
|         attr_accessor :target
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @ip_address = args[:ip_address] if args.key?(:ip_address)
 | |
|           @ip_protocol = args[:ip_protocol] if args.key?(:ip_protocol)
 | |
|           @all_ports = args[:all_ports] if args.key?(:all_ports)
 | |
|           @allow_global_access = args[:allow_global_access] if args.key?(:allow_global_access)
 | |
|           @backend_service = args[:backend_service] if args.key?(:backend_service)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @fingerprint = args[:fingerprint] if args.key?(:fingerprint)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @ip_version = args[:ip_version] if args.key?(:ip_version)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|           @load_balancing_scheme = args[:load_balancing_scheme] if args.key?(:load_balancing_scheme)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @network = args[:network] if args.key?(:network)
 | |
|           @network_tier = args[:network_tier] if args.key?(:network_tier)
 | |
|           @port_range = args[:port_range] if args.key?(:port_range)
 | |
|           @ports = args[:ports] if args.key?(:ports)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @service_label = args[:service_label] if args.key?(:service_label)
 | |
|           @service_name = args[:service_name] if args.key?(:service_name)
 | |
|           @subnetwork = args[:subnetwork] if args.key?(:subnetwork)
 | |
|           @target = args[:target] if args.key?(:target)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ForwardingRuleAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of ForwardingRulesScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::ForwardingRulesScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#forwardingRuleAggregatedList
 | |
|         # for lists of forwarding rules.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::ForwardingRuleAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::ForwardingRuleAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of ForwardingRule resources.
 | |
|       class ForwardingRuleList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of ForwardingRule resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::ForwardingRule>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::ForwardingRuleList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::ForwardingRuleList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ForwardingRuleReference
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `forwardingRule`
 | |
|         # @return [String]
 | |
|         attr_accessor :forwarding_rule
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @forwarding_rule = args[:forwarding_rule] if args.key?(:forwarding_rule)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ForwardingRulesScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of forwarding rules contained in this scope.
 | |
|         # Corresponds to the JSON property `forwardingRules`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::ForwardingRule>]
 | |
|         attr_accessor :forwarding_rules
 | |
|       
 | |
|         # Informational warning which replaces the list of forwarding rules when the
 | |
|         # list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::ForwardingRulesScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @forwarding_rules = args[:forwarding_rules] if args.key?(:forwarding_rules)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # Informational warning which replaces the list of forwarding rules when the
 | |
|         # list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::ForwardingRulesScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class GlobalSetLabelsRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The fingerprint of the previous set of labels for this resource, used to
 | |
|         # detect conflicts. The fingerprint is initially generated by Compute Engine and
 | |
|         # changes after every request to modify or update labels. You must always
 | |
|         # provide an up-to-date fingerprint hash when updating or changing labels,
 | |
|         # otherwise the request will fail with error 412 conditionNotMet. Make a get()
 | |
|         # request to the resource to get the latest fingerprint.
 | |
|         # Corresponds to the JSON property `labelFingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :label_fingerprint
 | |
|       
 | |
|         # A list of labels to apply for this resource. Each label key & value must
 | |
|         # 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. For example, "webserver-frontend": "images". A label value can also
 | |
|         # be empty (e.g. "my-label": "").
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class GlobalSetPolicyRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Flatten Policy to create a backward compatible wire-format. Deprecated. Use '
 | |
|         # policy' to specify bindings.
 | |
|         # Corresponds to the JSON property `bindings`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Binding>]
 | |
|         attr_accessor :bindings
 | |
|       
 | |
|         # Flatten Policy to create a backward compatible wire-format. Deprecated. Use '
 | |
|         # policy' to specify the etag.
 | |
|         # Corresponds to the JSON property `etag`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :etag
 | |
|       
 | |
|         # Defines an Identity and Access Management (IAM) policy. It is used to specify
 | |
|         # access control policies for Cloud Platform resources.
 | |
|         # A `Policy` consists of a list of `bindings`. A `binding` binds a list of `
 | |
|         # members` to a `role`, where the members can be user accounts, Google groups,
 | |
|         # Google domains, and service accounts. A `role` is a named list of permissions
 | |
|         # defined by IAM.
 | |
|         # **JSON Example**
 | |
|         # ` "bindings": [ ` "role": "roles/owner", "members": [ "user:mike@example.com",
 | |
|         # "group:admins@example.com", "domain:google.com", "serviceAccount:my-other-app@
 | |
|         # appspot.gserviceaccount.com" ] `, ` "role": "roles/viewer", "members": ["user:
 | |
|         # sean@example.com"] ` ] `
 | |
|         # **YAML Example**
 | |
|         # bindings: - members: - user:mike@example.com - group:admins@example.com -
 | |
|         # domain:google.com - serviceAccount:my-other-app@appspot.gserviceaccount.com
 | |
|         # role: roles/owner - members: - user:sean@example.com role: roles/viewer
 | |
|         # For a description of IAM and its features, see the [IAM developer's guide](
 | |
|         # https://cloud.google.com/iam/docs).
 | |
|         # Corresponds to the JSON property `policy`
 | |
|         # @return [Google::Apis::ComputeAlpha::Policy]
 | |
|         attr_accessor :policy
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @bindings = args[:bindings] if args.key?(:bindings)
 | |
|           @etag = args[:etag] if args.key?(:etag)
 | |
|           @policy = args[:policy] if args.key?(:policy)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A guest attributes entry.
 | |
|       class GuestAttributes
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#guestAttributes for guest
 | |
|         # attributes entry.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # The path to be queried. This can be the default namespace ('/') or a nested
 | |
|         # namespace ('//') or a specified key ('//')
 | |
|         # Corresponds to the JSON property `queryPath`
 | |
|         # @return [String]
 | |
|         attr_accessor :query_path
 | |
|       
 | |
|         # Array of guest attribute namespace/key/value tuples.
 | |
|         # Corresponds to the JSON property `queryValue`
 | |
|         # @return [Google::Apis::ComputeAlpha::GuestAttributesValue]
 | |
|         attr_accessor :query_value
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # The key to search for.
 | |
|         # Corresponds to the JSON property `variableKey`
 | |
|         # @return [String]
 | |
|         attr_accessor :variable_key
 | |
|       
 | |
|         # [Output Only] The value found for the requested key.
 | |
|         # Corresponds to the JSON property `variableValue`
 | |
|         # @return [String]
 | |
|         attr_accessor :variable_value
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @query_path = args[:query_path] if args.key?(:query_path)
 | |
|           @query_value = args[:query_value] if args.key?(:query_value)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @variable_key = args[:variable_key] if args.key?(:variable_key)
 | |
|           @variable_value = args[:variable_value] if args.key?(:variable_value)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A guest attributes namespace/key/value entry.
 | |
|       class GuestAttributesEntry
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Key for the guest attribute entry.
 | |
|         # Corresponds to the JSON property `key`
 | |
|         # @return [String]
 | |
|         attr_accessor :key
 | |
|       
 | |
|         # Namespace for the guest attribute entry.
 | |
|         # Corresponds to the JSON property `namespace`
 | |
|         # @return [String]
 | |
|         attr_accessor :namespace
 | |
|       
 | |
|         # Value for the guest attribute entry.
 | |
|         # Corresponds to the JSON property `value`
 | |
|         # @return [String]
 | |
|         attr_accessor :value
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @key = args[:key] if args.key?(:key)
 | |
|           @namespace = args[:namespace] if args.key?(:namespace)
 | |
|           @value = args[:value] if args.key?(:value)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Array of guest attribute namespace/key/value tuples.
 | |
|       class GuestAttributesValue
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::GuestAttributesEntry>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Guest OS features.
 | |
|       class GuestOsFeature
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The ID of a supported feature. Read  Enabling guest operating system features
 | |
|         # to see a list of available options.
 | |
|         # Corresponds to the JSON property `type`
 | |
|         # @return [String]
 | |
|         attr_accessor :type
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @type = args[:type] if args.key?(:type)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class Http2HealthCheck
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The value of the host header in the HTTP/2 health check request. If left empty
 | |
|         # (default value), the IP on behalf of which this health check is performed will
 | |
|         # be used.
 | |
|         # Corresponds to the JSON property `host`
 | |
|         # @return [String]
 | |
|         attr_accessor :host
 | |
|       
 | |
|         # The TCP port number for the health check request. The default value is 443.
 | |
|         # Valid values are 1 through 65535.
 | |
|         # Corresponds to the JSON property `port`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :port
 | |
|       
 | |
|         # Port name as defined in InstanceGroup#NamedPort#name. If both port and
 | |
|         # port_name are defined, port takes precedence.
 | |
|         # Corresponds to the JSON property `portName`
 | |
|         # @return [String]
 | |
|         attr_accessor :port_name
 | |
|       
 | |
|         # Specifies how port is selected for health checking, can be one of following
 | |
|         # values:
 | |
|         # USE_FIXED_PORT: The port number in
 | |
|         # port
 | |
|         # is used for health checking.
 | |
|         # USE_NAMED_PORT: The
 | |
|         # portName
 | |
|         # is used for health checking.
 | |
|         # USE_SERVING_PORT: For NetworkEndpointGroup, the port specified for each
 | |
|         # network endpoint is used for health checking. For other backends, the port or
 | |
|         # named port specified in the Backend Service is used for health checking.
 | |
|         # If not specified, HTTP2 health check follows behavior specified in
 | |
|         # port
 | |
|         # and
 | |
|         # portName
 | |
|         # fields.
 | |
|         # Corresponds to the JSON property `portSpecification`
 | |
|         # @return [String]
 | |
|         attr_accessor :port_specification
 | |
|       
 | |
|         # Specifies the type of proxy header to append before sending data to the
 | |
|         # backend, either NONE or PROXY_V1. The default is NONE.
 | |
|         # Corresponds to the JSON property `proxyHeader`
 | |
|         # @return [String]
 | |
|         attr_accessor :proxy_header
 | |
|       
 | |
|         # The request path of the HTTP/2 health check request. The default value is /.
 | |
|         # Corresponds to the JSON property `requestPath`
 | |
|         # @return [String]
 | |
|         attr_accessor :request_path
 | |
|       
 | |
|         # The string to match anywhere in the first 1024 bytes of the response body. If
 | |
|         # left empty (the default value), the status code determines health. The
 | |
|         # response data can only be ASCII.
 | |
|         # Corresponds to the JSON property `response`
 | |
|         # @return [String]
 | |
|         attr_accessor :response
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @host = args[:host] if args.key?(:host)
 | |
|           @port = args[:port] if args.key?(:port)
 | |
|           @port_name = args[:port_name] if args.key?(:port_name)
 | |
|           @port_specification = args[:port_specification] if args.key?(:port_specification)
 | |
|           @proxy_header = args[:proxy_header] if args.key?(:proxy_header)
 | |
|           @request_path = args[:request_path] if args.key?(:request_path)
 | |
|           @response = args[:response] if args.key?(:response)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class HttpHealthCheck
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The value of the host header in the HTTP health check request. If left empty (
 | |
|         # default value), the IP on behalf of which this health check is performed will
 | |
|         # be used.
 | |
|         # Corresponds to the JSON property `host`
 | |
|         # @return [String]
 | |
|         attr_accessor :host
 | |
|       
 | |
|         # The TCP port number for the health check request. The default value is 80.
 | |
|         # Valid values are 1 through 65535.
 | |
|         # Corresponds to the JSON property `port`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :port
 | |
|       
 | |
|         # Port name as defined in InstanceGroup#NamedPort#name. If both port and
 | |
|         # port_name are defined, port takes precedence.
 | |
|         # Corresponds to the JSON property `portName`
 | |
|         # @return [String]
 | |
|         attr_accessor :port_name
 | |
|       
 | |
|         # Specifies how port is selected for health checking, can be one of following
 | |
|         # values:
 | |
|         # USE_FIXED_PORT: The port number in
 | |
|         # port
 | |
|         # is used for health checking.
 | |
|         # USE_NAMED_PORT: The
 | |
|         # portName
 | |
|         # is used for health checking.
 | |
|         # USE_SERVING_PORT: For NetworkEndpointGroup, the port specified for each
 | |
|         # network endpoint is used for health checking. For other backends, the port or
 | |
|         # named port specified in the Backend Service is used for health checking.
 | |
|         # If not specified, HTTP health check follows behavior specified in
 | |
|         # port
 | |
|         # and
 | |
|         # portName
 | |
|         # fields.
 | |
|         # Corresponds to the JSON property `portSpecification`
 | |
|         # @return [String]
 | |
|         attr_accessor :port_specification
 | |
|       
 | |
|         # Specifies the type of proxy header to append before sending data to the
 | |
|         # backend, either NONE or PROXY_V1. The default is NONE.
 | |
|         # Corresponds to the JSON property `proxyHeader`
 | |
|         # @return [String]
 | |
|         attr_accessor :proxy_header
 | |
|       
 | |
|         # The request path of the HTTP health check request. The default value is /.
 | |
|         # Corresponds to the JSON property `requestPath`
 | |
|         # @return [String]
 | |
|         attr_accessor :request_path
 | |
|       
 | |
|         # The string to match anywhere in the first 1024 bytes of the response body. If
 | |
|         # left empty (the default value), the status code determines health. The
 | |
|         # response data can only be ASCII.
 | |
|         # Corresponds to the JSON property `response`
 | |
|         # @return [String]
 | |
|         attr_accessor :response
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @host = args[:host] if args.key?(:host)
 | |
|           @port = args[:port] if args.key?(:port)
 | |
|           @port_name = args[:port_name] if args.key?(:port_name)
 | |
|           @port_specification = args[:port_specification] if args.key?(:port_specification)
 | |
|           @proxy_header = args[:proxy_header] if args.key?(:proxy_header)
 | |
|           @request_path = args[:request_path] if args.key?(:request_path)
 | |
|           @response = args[:response] if args.key?(:response)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class HttpsHealthCheck
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The value of the host header in the HTTPS health check request. If left empty (
 | |
|         # default value), the IP on behalf of which this health check is performed will
 | |
|         # be used.
 | |
|         # Corresponds to the JSON property `host`
 | |
|         # @return [String]
 | |
|         attr_accessor :host
 | |
|       
 | |
|         # The TCP port number for the health check request. The default value is 443.
 | |
|         # Valid values are 1 through 65535.
 | |
|         # Corresponds to the JSON property `port`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :port
 | |
|       
 | |
|         # Port name as defined in InstanceGroup#NamedPort#name. If both port and
 | |
|         # port_name are defined, port takes precedence.
 | |
|         # Corresponds to the JSON property `portName`
 | |
|         # @return [String]
 | |
|         attr_accessor :port_name
 | |
|       
 | |
|         # Specifies how port is selected for health checking, can be one of following
 | |
|         # values:
 | |
|         # USE_FIXED_PORT: The port number in
 | |
|         # port
 | |
|         # is used for health checking.
 | |
|         # USE_NAMED_PORT: The
 | |
|         # portName
 | |
|         # is used for health checking.
 | |
|         # USE_SERVING_PORT: For NetworkEndpointGroup, the port specified for each
 | |
|         # network endpoint is used for health checking. For other backends, the port or
 | |
|         # named port specified in the Backend Service is used for health checking.
 | |
|         # If not specified, HTTPS health check follows behavior specified in
 | |
|         # port
 | |
|         # and
 | |
|         # portName
 | |
|         # fields.
 | |
|         # Corresponds to the JSON property `portSpecification`
 | |
|         # @return [String]
 | |
|         attr_accessor :port_specification
 | |
|       
 | |
|         # Specifies the type of proxy header to append before sending data to the
 | |
|         # backend, either NONE or PROXY_V1. The default is NONE.
 | |
|         # Corresponds to the JSON property `proxyHeader`
 | |
|         # @return [String]
 | |
|         attr_accessor :proxy_header
 | |
|       
 | |
|         # The request path of the HTTPS health check request. The default value is /.
 | |
|         # Corresponds to the JSON property `requestPath`
 | |
|         # @return [String]
 | |
|         attr_accessor :request_path
 | |
|       
 | |
|         # The string to match anywhere in the first 1024 bytes of the response body. If
 | |
|         # left empty (the default value), the status code determines health. The
 | |
|         # response data can only be ASCII.
 | |
|         # Corresponds to the JSON property `response`
 | |
|         # @return [String]
 | |
|         attr_accessor :response
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @host = args[:host] if args.key?(:host)
 | |
|           @port = args[:port] if args.key?(:port)
 | |
|           @port_name = args[:port_name] if args.key?(:port_name)
 | |
|           @port_specification = args[:port_specification] if args.key?(:port_specification)
 | |
|           @proxy_header = args[:proxy_header] if args.key?(:proxy_header)
 | |
|           @request_path = args[:request_path] if args.key?(:request_path)
 | |
|           @response = args[:response] if args.key?(:response)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # An HealthCheck resource. This resource defines a template for how individual
 | |
|       # virtual machines should be checked for health, via one of the supported
 | |
|       # protocols.
 | |
|       class HealthCheck
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # How often (in seconds) to send a health check. The default value is 5 seconds.
 | |
|         # Corresponds to the JSON property `checkIntervalSec`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :check_interval_sec
 | |
|       
 | |
|         # [Output Only] Creation timestamp in 3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # A so-far unhealthy instance will be marked healthy after this many consecutive
 | |
|         # successes. The default value is 2.
 | |
|         # Corresponds to the JSON property `healthyThreshold`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :healthy_threshold
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `http2HealthCheck`
 | |
|         # @return [Google::Apis::ComputeAlpha::Http2HealthCheck]
 | |
|         attr_accessor :http2_health_check
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `httpHealthCheck`
 | |
|         # @return [Google::Apis::ComputeAlpha::HttpHealthCheck]
 | |
|         attr_accessor :http_health_check
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `httpsHealthCheck`
 | |
|         # @return [Google::Apis::ComputeAlpha::HttpsHealthCheck]
 | |
|         attr_accessor :https_health_check
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # Type of the resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # [Output Only] Region where the health check resides. Not applicable to global
 | |
|         # health checks.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `sslHealthCheck`
 | |
|         # @return [Google::Apis::ComputeAlpha::SslHealthCheck]
 | |
|         attr_accessor :ssl_health_check
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `tcpHealthCheck`
 | |
|         # @return [Google::Apis::ComputeAlpha::TcpHealthCheck]
 | |
|         attr_accessor :tcp_health_check
 | |
|       
 | |
|         # How long (in seconds) to wait before claiming failure. The default value is 5
 | |
|         # seconds. It is invalid for timeoutSec to have greater value than
 | |
|         # checkIntervalSec.
 | |
|         # Corresponds to the JSON property `timeoutSec`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :timeout_sec
 | |
|       
 | |
|         # Specifies the type of the healthCheck, either TCP, SSL, HTTP or HTTPS. If not
 | |
|         # specified, the default is TCP. Exactly one of the protocol-specific health
 | |
|         # check field must be specified, which must match type field.
 | |
|         # Corresponds to the JSON property `type`
 | |
|         # @return [String]
 | |
|         attr_accessor :type
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `udpHealthCheck`
 | |
|         # @return [Google::Apis::ComputeAlpha::UdpHealthCheck]
 | |
|         attr_accessor :udp_health_check
 | |
|       
 | |
|         # A so-far healthy instance will be marked unhealthy after this many consecutive
 | |
|         # failures. The default value is 2.
 | |
|         # Corresponds to the JSON property `unhealthyThreshold`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :unhealthy_threshold
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @check_interval_sec = args[:check_interval_sec] if args.key?(:check_interval_sec)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @healthy_threshold = args[:healthy_threshold] if args.key?(:healthy_threshold)
 | |
|           @http2_health_check = args[:http2_health_check] if args.key?(:http2_health_check)
 | |
|           @http_health_check = args[:http_health_check] if args.key?(:http_health_check)
 | |
|           @https_health_check = args[:https_health_check] if args.key?(:https_health_check)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @ssl_health_check = args[:ssl_health_check] if args.key?(:ssl_health_check)
 | |
|           @tcp_health_check = args[:tcp_health_check] if args.key?(:tcp_health_check)
 | |
|           @timeout_sec = args[:timeout_sec] if args.key?(:timeout_sec)
 | |
|           @type = args[:type] if args.key?(:type)
 | |
|           @udp_health_check = args[:udp_health_check] if args.key?(:udp_health_check)
 | |
|           @unhealthy_threshold = args[:unhealthy_threshold] if args.key?(:unhealthy_threshold)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of HealthCheck resources.
 | |
|       class HealthCheckList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of HealthCheck resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::HealthCheck>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::HealthCheckList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::HealthCheckList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A full or valid partial URL to a health check. For example, the following are
 | |
|       # valid URLs:
 | |
|       # - https://www.googleapis.com/compute/beta/projects/project-id/global/
 | |
|       # httpHealthChecks/health-check
 | |
|       # - projects/project-id/global/httpHealthChecks/health-check
 | |
|       # - global/httpHealthChecks/health-check
 | |
|       class HealthCheckReference
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `healthCheck`
 | |
|         # @return [String]
 | |
|         attr_accessor :health_check
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @health_check = args[:health_check] if args.key?(:health_check)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class HealthChecksAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of HealthChecksScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::HealthChecksScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::HealthChecksAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::HealthChecksAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class HealthChecksScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of HealthChecks contained in this scope.
 | |
|         # Corresponds to the JSON property `healthChecks`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::HealthCheck>]
 | |
|         attr_accessor :health_checks
 | |
|       
 | |
|         # Informational warning which replaces the list of backend services when the
 | |
|         # list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::HealthChecksScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @health_checks = args[:health_checks] if args.key?(:health_checks)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # Informational warning which replaces the list of backend services when the
 | |
|         # list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::HealthChecksScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class HealthStatus
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Metadata defined as annotations for network endpoint.
 | |
|         # Corresponds to the JSON property `annotations`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :annotations
 | |
|       
 | |
|         # Health state of the instance.
 | |
|         # Corresponds to the JSON property `healthState`
 | |
|         # @return [String]
 | |
|         attr_accessor :health_state
 | |
|       
 | |
|         # URL of the instance resource.
 | |
|         # Corresponds to the JSON property `instance`
 | |
|         # @return [String]
 | |
|         attr_accessor :instance
 | |
|       
 | |
|         # The IP address represented by this resource.
 | |
|         # Corresponds to the JSON property `ipAddress`
 | |
|         # @return [String]
 | |
|         attr_accessor :ip_address
 | |
|       
 | |
|         # The port on the instance.
 | |
|         # Corresponds to the JSON property `port`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :port
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @annotations = args[:annotations] if args.key?(:annotations)
 | |
|           @health_state = args[:health_state] if args.key?(:health_state)
 | |
|           @instance = args[:instance] if args.key?(:instance)
 | |
|           @ip_address = args[:ip_address] if args.key?(:ip_address)
 | |
|           @port = args[:port] if args.key?(:port)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class HealthStatusForNetworkEndpoint
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # URL of the backend service associated with the health state of the network
 | |
|         # endpoint.
 | |
|         # Corresponds to the JSON property `backendService`
 | |
|         # @return [Google::Apis::ComputeAlpha::BackendServiceReference]
 | |
|         attr_accessor :backend_service
 | |
|       
 | |
|         # URL of the forwarding rule associated with the health state of the network
 | |
|         # endpoint.
 | |
|         # Corresponds to the JSON property `forwardingRule`
 | |
|         # @return [Google::Apis::ComputeAlpha::ForwardingRuleReference]
 | |
|         attr_accessor :forwarding_rule
 | |
|       
 | |
|         # A full or valid partial URL to a health check. For example, the following are
 | |
|         # valid URLs:
 | |
|         # - https://www.googleapis.com/compute/beta/projects/project-id/global/
 | |
|         # httpHealthChecks/health-check
 | |
|         # - projects/project-id/global/httpHealthChecks/health-check
 | |
|         # - global/httpHealthChecks/health-check
 | |
|         # Corresponds to the JSON property `healthCheck`
 | |
|         # @return [Google::Apis::ComputeAlpha::HealthCheckReference]
 | |
|         attr_accessor :health_check
 | |
|       
 | |
|         # Health state of the network endpoint determined based on the health checks
 | |
|         # configured.
 | |
|         # Corresponds to the JSON property `healthState`
 | |
|         # @return [String]
 | |
|         attr_accessor :health_state
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @backend_service = args[:backend_service] if args.key?(:backend_service)
 | |
|           @forwarding_rule = args[:forwarding_rule] if args.key?(:forwarding_rule)
 | |
|           @health_check = args[:health_check] if args.key?(:health_check)
 | |
|           @health_state = args[:health_state] if args.key?(:health_state)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # UrlMaps A host-matching rule for a URL. If matched, will use the named
 | |
|       # PathMatcher to select the BackendService.
 | |
|       class HostRule
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :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 ..
 | |
|         # Corresponds to the JSON property `hosts`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :hosts
 | |
|       
 | |
|         # The name of the PathMatcher to use to match the path portion of the URL if the
 | |
|         # hostRule matches the URL's host portion.
 | |
|         # Corresponds to the JSON property `pathMatcher`
 | |
|         # @return [String]
 | |
|         attr_accessor :path_matcher
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @hosts = args[:hosts] if args.key?(:hosts)
 | |
|           @path_matcher = args[:path_matcher] if args.key?(:path_matcher)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Specification for how requests are aborted as part of fault injection.
 | |
|       class HttpFaultAbort
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The HTTP status code used to abort the request.
 | |
|         # The value must be between 200 and 599 inclusive.
 | |
|         # Corresponds to the JSON property `httpStatus`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :http_status
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `percentage`
 | |
|         # @return [Float]
 | |
|         attr_accessor :percentage
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @http_status = args[:http_status] if args.key?(:http_status)
 | |
|           @percentage = args[:percentage] if args.key?(:percentage)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Specifies the delay introduced by Loadbalancer before forwarding the request
 | |
|       # to the backend service as part of fault injection.
 | |
|       class HttpFaultDelay
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A Duration represents a fixed-length span of time represented as a count of
 | |
|         # seconds and fractions of seconds at nanosecond resolution. It is independent
 | |
|         # of any calendar and concepts like "day" or "month". Range is approximately 10,
 | |
|         # 000 years.
 | |
|         # Corresponds to the JSON property `fixedDelay`
 | |
|         # @return [Google::Apis::ComputeAlpha::Duration]
 | |
|         attr_accessor :fixed_delay
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `percentage`
 | |
|         # @return [Float]
 | |
|         attr_accessor :percentage
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @fixed_delay = args[:fixed_delay] if args.key?(:fixed_delay)
 | |
|           @percentage = args[:percentage] if args.key?(:percentage)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 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.
 | |
|       class HttpFaultInjection
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Specification for how requests are aborted as part of fault injection.
 | |
|         # Corresponds to the JSON property `abort`
 | |
|         # @return [Google::Apis::ComputeAlpha::HttpFaultAbort]
 | |
|         attr_accessor :abort
 | |
|       
 | |
|         # Specifies the delay introduced by Loadbalancer before forwarding the request
 | |
|         # to the backend service as part of fault injection.
 | |
|         # Corresponds to the JSON property `delay`
 | |
|         # @return [Google::Apis::ComputeAlpha::HttpFaultDelay]
 | |
|         attr_accessor :delay
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @abort = args[:abort] if args.key?(:abort)
 | |
|           @delay = args[:delay] if args.key?(:delay)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The request and response header transformations that take effect before the
 | |
|       # request is passed along to the selected backendService.
 | |
|       class HttpHeaderAction
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Headers to add to a matching request prior to forwarding the request to the
 | |
|         # backendService.
 | |
|         # Corresponds to the JSON property `requestHeadersToAdd`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::HttpHeaderOption>]
 | |
|         attr_accessor :request_headers_to_add
 | |
|       
 | |
|         # A list of header names for headers that need to be removed from the request
 | |
|         # prior to forwarding the request to the backendService.
 | |
|         # Corresponds to the JSON property `requestHeadersToRemove`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :request_headers_to_remove
 | |
|       
 | |
|         # Headers to add the response prior to sending the response back to the client.
 | |
|         # Corresponds to the JSON property `responseHeadersToAdd`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::HttpHeaderOption>]
 | |
|         attr_accessor :response_headers_to_add
 | |
|       
 | |
|         # A list of header names for headers that need to be removed from the response
 | |
|         # prior to sending the response back to the client.
 | |
|         # Corresponds to the JSON property `responseHeadersToRemove`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :response_headers_to_remove
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @request_headers_to_add = args[:request_headers_to_add] if args.key?(:request_headers_to_add)
 | |
|           @request_headers_to_remove = args[:request_headers_to_remove] if args.key?(:request_headers_to_remove)
 | |
|           @response_headers_to_add = args[:response_headers_to_add] if args.key?(:response_headers_to_add)
 | |
|           @response_headers_to_remove = args[:response_headers_to_remove] if args.key?(:response_headers_to_remove)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # matchRule criteria for request header matches.
 | |
|       class HttpHeaderMatch
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The value should exactly match contents of exactMatch.
 | |
|         # Only one of exactMatch, prefixMatch, suffixMatch, regexMatch, presentMatch or
 | |
|         # rangeMatch must be set.
 | |
|         # Corresponds to the JSON property `exactMatch`
 | |
|         # @return [String]
 | |
|         attr_accessor :exact_match
 | |
|       
 | |
|         # 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".
 | |
|         # Corresponds to the JSON property `headerName`
 | |
|         # @return [String]
 | |
|         attr_accessor :header_name
 | |
|       
 | |
|         # If set to false, the headerMatch is considered a match if the match criteria
 | |
|         # above are met. If set to true, the headerMatch is considered a match if the
 | |
|         # match criteria above are NOT met.
 | |
|         # The default setting is false.
 | |
|         # Corresponds to the JSON property `invertMatch`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :invert_match
 | |
|         alias_method :invert_match?, :invert_match
 | |
|       
 | |
|         # The value of the header must start with the contents of prefixMatch.
 | |
|         # Only one of exactMatch, prefixMatch, suffixMatch, regexMatch, presentMatch or
 | |
|         # rangeMatch must be set.
 | |
|         # Corresponds to the JSON property `prefixMatch`
 | |
|         # @return [String]
 | |
|         attr_accessor :prefix_match
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `presentMatch`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :present_match
 | |
|         alias_method :present_match?, :present_match
 | |
|       
 | |
|         # HttpRouteRuleMatch criteria for field values that must stay within the
 | |
|         # specified integer range.
 | |
|         # Corresponds to the JSON property `rangeMatch`
 | |
|         # @return [Google::Apis::ComputeAlpha::Int64RangeMatch]
 | |
|         attr_accessor :range_match
 | |
|       
 | |
|         # The value of the header must match the regualar 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.
 | |
|         # Corresponds to the JSON property `regexMatch`
 | |
|         # @return [String]
 | |
|         attr_accessor :regex_match
 | |
|       
 | |
|         # The value of the header must end with the contents of suffixMatch.
 | |
|         # Only one of exactMatch, prefixMatch, suffixMatch, regexMatch, presentMatch or
 | |
|         # rangeMatch must be set.
 | |
|         # Corresponds to the JSON property `suffixMatch`
 | |
|         # @return [String]
 | |
|         attr_accessor :suffix_match
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @exact_match = args[:exact_match] if args.key?(:exact_match)
 | |
|           @header_name = args[:header_name] if args.key?(:header_name)
 | |
|           @invert_match = args[:invert_match] if args.key?(:invert_match)
 | |
|           @prefix_match = args[:prefix_match] if args.key?(:prefix_match)
 | |
|           @present_match = args[:present_match] if args.key?(:present_match)
 | |
|           @range_match = args[:range_match] if args.key?(:range_match)
 | |
|           @regex_match = args[:regex_match] if args.key?(:regex_match)
 | |
|           @suffix_match = args[:suffix_match] if args.key?(:suffix_match)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Specification determining how headers are added to requests or responses.
 | |
|       class HttpHeaderOption
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The name of the header.
 | |
|         # Corresponds to the JSON property `headerName`
 | |
|         # @return [String]
 | |
|         attr_accessor :header_name
 | |
|       
 | |
|         # The value of the header to add.
 | |
|         # Corresponds to the JSON property `headerValue`
 | |
|         # @return [String]
 | |
|         attr_accessor :header_value
 | |
|       
 | |
|         # 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.
 | |
|         # The default value is false.
 | |
|         # Corresponds to the JSON property `replace`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :replace
 | |
|         alias_method :replace?, :replace
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @header_name = args[:header_name] if args.key?(:header_name)
 | |
|           @header_value = args[:header_value] if args.key?(:header_value)
 | |
|           @replace = args[:replace] if args.key?(:replace)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # An HttpHealthCheck resource. This resource defines a template for how
 | |
|       # individual instances should be checked for health, via HTTP.
 | |
|       class HttpHealthCheck
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # How often (in seconds) to send a health check. The default value is 5 seconds.
 | |
|         # Corresponds to the JSON property `checkIntervalSec`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :check_interval_sec
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # A so-far unhealthy instance will be marked healthy after this many consecutive
 | |
|         # successes. The default value is 2.
 | |
|         # Corresponds to the JSON property `healthyThreshold`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :healthy_threshold
 | |
|       
 | |
|         # The value of the host header in the HTTP health check request. If left empty (
 | |
|         # default value), the public IP on behalf of which this health check is
 | |
|         # performed will be used.
 | |
|         # Corresponds to the JSON property `host`
 | |
|         # @return [String]
 | |
|         attr_accessor :host
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#httpHealthCheck for HTTP
 | |
|         # health checks.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # The TCP port number for the HTTP health check request. The default value is 80.
 | |
|         # Corresponds to the JSON property `port`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :port
 | |
|       
 | |
|         # The request path of the HTTP health check request. The default value is /.
 | |
|         # Corresponds to the JSON property `requestPath`
 | |
|         # @return [String]
 | |
|         attr_accessor :request_path
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # How long (in seconds) to wait before claiming failure. The default value is 5
 | |
|         # seconds. It is invalid for timeoutSec to have greater value than
 | |
|         # checkIntervalSec.
 | |
|         # Corresponds to the JSON property `timeoutSec`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :timeout_sec
 | |
|       
 | |
|         # A so-far healthy instance will be marked unhealthy after this many consecutive
 | |
|         # failures. The default value is 2.
 | |
|         # Corresponds to the JSON property `unhealthyThreshold`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :unhealthy_threshold
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @check_interval_sec = args[:check_interval_sec] if args.key?(:check_interval_sec)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @healthy_threshold = args[:healthy_threshold] if args.key?(:healthy_threshold)
 | |
|           @host = args[:host] if args.key?(:host)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @port = args[:port] if args.key?(:port)
 | |
|           @request_path = args[:request_path] if args.key?(:request_path)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @timeout_sec = args[:timeout_sec] if args.key?(:timeout_sec)
 | |
|           @unhealthy_threshold = args[:unhealthy_threshold] if args.key?(:unhealthy_threshold)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of HttpHealthCheck resources.
 | |
|       class HttpHealthCheckList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of HttpHealthCheck resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::HttpHealthCheck>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::HttpHealthCheckList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::HttpHealthCheckList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # HttpRouteRuleMatch criteria for a request's query parameter.
 | |
|       class HttpQueryParameterMatch
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `exactMatch`
 | |
|         # @return [String]
 | |
|         attr_accessor :exact_match
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `presentMatch`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :present_match
 | |
|         alias_method :present_match?, :present_match
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `regexMatch`
 | |
|         # @return [String]
 | |
|         attr_accessor :regex_match
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @exact_match = args[:exact_match] if args.key?(:exact_match)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @present_match = args[:present_match] if args.key?(:present_match)
 | |
|           @regex_match = args[:regex_match] if args.key?(:regex_match)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Specifies settings for an HTTP redirect.
 | |
|       class HttpRedirectAction
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `hostRedirect`
 | |
|         # @return [String]
 | |
|         attr_accessor :host_redirect
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `httpsRedirect`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :https_redirect
 | |
|         alias_method :https_redirect?, :https_redirect
 | |
|       
 | |
|         # The path that will be used in the redirect response instead of the one that
 | |
|         # was supplied in the request.
 | |
|         # Only one of pathRedirect or prefixRedirect must be specified.
 | |
|         # The value must be between 1 and 1024 characters.
 | |
|         # Corresponds to the JSON property `pathRedirect`
 | |
|         # @return [String]
 | |
|         attr_accessor :path_redirect
 | |
|       
 | |
|         # The prefix that replaces the prefixMatch specified in the HttpRouteRuleMatch,
 | |
|         # retaining the remaining portion of the URL before redirecting the request.
 | |
|         # Corresponds to the JSON property `prefixRedirect`
 | |
|         # @return [String]
 | |
|         attr_accessor :prefix_redirect
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `redirectResponseCode`
 | |
|         # @return [String]
 | |
|         attr_accessor :redirect_response_code
 | |
|       
 | |
|         # 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 is set to false.
 | |
|         # Corresponds to the JSON property `stripQuery`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :strip_query
 | |
|         alias_method :strip_query?, :strip_query
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @host_redirect = args[:host_redirect] if args.key?(:host_redirect)
 | |
|           @https_redirect = args[:https_redirect] if args.key?(:https_redirect)
 | |
|           @path_redirect = args[:path_redirect] if args.key?(:path_redirect)
 | |
|           @prefix_redirect = args[:prefix_redirect] if args.key?(:prefix_redirect)
 | |
|           @redirect_response_code = args[:redirect_response_code] if args.key?(:redirect_response_code)
 | |
|           @strip_query = args[:strip_query] if args.key?(:strip_query)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The retry policy associates with HttpRouteRule
 | |
|       class HttpRetryPolicy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Specifies the allowed number retries. This number must be > 0.
 | |
|         # Corresponds to the JSON property `numRetries`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :num_retries
 | |
|       
 | |
|         # A Duration represents a fixed-length span of time represented as a count of
 | |
|         # seconds and fractions of seconds at nanosecond resolution. It is independent
 | |
|         # of any calendar and concepts like "day" or "month". Range is approximately 10,
 | |
|         # 000 years.
 | |
|         # Corresponds to the JSON property `perTryTimeout`
 | |
|         # @return [Google::Apis::ComputeAlpha::Duration]
 | |
|         attr_accessor :per_try_timeout
 | |
|       
 | |
|         # Specfies 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.
 | |
|         # - cancelledLoadbalancer 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
 | |
|         # Corresponds to the JSON property `retryConditions`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :retry_conditions
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @num_retries = args[:num_retries] if args.key?(:num_retries)
 | |
|           @per_try_timeout = args[:per_try_timeout] if args.key?(:per_try_timeout)
 | |
|           @retry_conditions = args[:retry_conditions] if args.key?(:retry_conditions)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class HttpRouteAction
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The specification for allowing client side cross-origin requests. Please see
 | |
|         # W3C Recommendation for Cross Origin Resource Sharing
 | |
|         # Corresponds to the JSON property `corsPolicy`
 | |
|         # @return [Google::Apis::ComputeAlpha::CorsPolicy]
 | |
|         attr_accessor :cors_policy
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `faultInjectionPolicy`
 | |
|         # @return [Google::Apis::ComputeAlpha::HttpFaultInjection]
 | |
|         attr_accessor :fault_injection_policy
 | |
|       
 | |
|         # A policy that specifies 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.
 | |
|         # Corresponds to the JSON property `requestMirrorPolicy`
 | |
|         # @return [Google::Apis::ComputeAlpha::RequestMirrorPolicy]
 | |
|         attr_accessor :request_mirror_policy
 | |
|       
 | |
|         # The retry policy associates with HttpRouteRule
 | |
|         # Corresponds to the JSON property `retryPolicy`
 | |
|         # @return [Google::Apis::ComputeAlpha::HttpRetryPolicy]
 | |
|         attr_accessor :retry_policy
 | |
|       
 | |
|         # A Duration represents a fixed-length span of time represented as a count of
 | |
|         # seconds and fractions of seconds at nanosecond resolution. It is independent
 | |
|         # of any calendar and concepts like "day" or "month". Range is approximately 10,
 | |
|         # 000 years.
 | |
|         # Corresponds to the JSON property `timeout`
 | |
|         # @return [Google::Apis::ComputeAlpha::Duration]
 | |
|         attr_accessor :timeout
 | |
|       
 | |
|         # The spec for modifying the path before sending the request to the matched
 | |
|         # backend service.
 | |
|         # Corresponds to the JSON property `urlRewrite`
 | |
|         # @return [Google::Apis::ComputeAlpha::UrlRewrite]
 | |
|         attr_accessor :url_rewrite
 | |
|       
 | |
|         # A list of weighted backend services to send traffic to when a route match
 | |
|         # occurs. The weights determine the percentage of traffic that flows to their
 | |
|         # corresponding backend service. The weights must add up to 100. If all traffic
 | |
|         # needs to go to a single backend service, there must be one
 | |
|         # weightedBackendService with weight set to 100.
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `weightedBackendServices`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::WeightedBackendService>]
 | |
|         attr_accessor :weighted_backend_services
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @cors_policy = args[:cors_policy] if args.key?(:cors_policy)
 | |
|           @fault_injection_policy = args[:fault_injection_policy] if args.key?(:fault_injection_policy)
 | |
|           @request_mirror_policy = args[:request_mirror_policy] if args.key?(:request_mirror_policy)
 | |
|           @retry_policy = args[:retry_policy] if args.key?(:retry_policy)
 | |
|           @timeout = args[:timeout] if args.key?(:timeout)
 | |
|           @url_rewrite = args[:url_rewrite] if args.key?(:url_rewrite)
 | |
|           @weighted_backend_services = args[:weighted_backend_services] if args.key?(:weighted_backend_services)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # An HttpRouteRule specifies how to match an HTTP request and the corresponding
 | |
|       # routing action that load balancing proxies will perform.
 | |
|       class HttpRouteRule
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The request and response header transformations that take effect before the
 | |
|         # request is passed along to the selected backendService.
 | |
|         # Corresponds to the JSON property `headerAction`
 | |
|         # @return [Google::Apis::ComputeAlpha::HttpHeaderAction]
 | |
|         attr_accessor :header_action
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `matchRules`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::HttpRouteRuleMatch>]
 | |
|         attr_accessor :match_rules
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `routeAction`
 | |
|         # @return [Google::Apis::ComputeAlpha::HttpRouteAction]
 | |
|         attr_accessor :route_action
 | |
|       
 | |
|         # Specifies settings for an HTTP redirect.
 | |
|         # Corresponds to the JSON property `urlRedirect`
 | |
|         # @return [Google::Apis::ComputeAlpha::HttpRedirectAction]
 | |
|         attr_accessor :url_redirect
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @header_action = args[:header_action] if args.key?(:header_action)
 | |
|           @match_rules = args[:match_rules] if args.key?(:match_rules)
 | |
|           @route_action = args[:route_action] if args.key?(:route_action)
 | |
|           @url_redirect = args[:url_redirect] if args.key?(:url_redirect)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # HttpRouteRuleMatch specifies a set of criteria for matching requests to an
 | |
|       # HttpRouteRule. All specified criteria must be satisfied for a match to occur.
 | |
|       class HttpRouteRuleMatch
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # For satifying 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.
 | |
|         # Corresponds to the JSON property `fullPathMatch`
 | |
|         # @return [String]
 | |
|         attr_accessor :full_path_match
 | |
|       
 | |
|         # Specifies a list of header match criteria, all of which must match
 | |
|         # corresponding headers in the request.
 | |
|         # Corresponds to the JSON property `headerMatches`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::HttpHeaderMatch>]
 | |
|         attr_accessor :header_matches
 | |
|       
 | |
|         # Specifies that prefixMatch and fullPathMatch matches are case sensitive.
 | |
|         # The default value is false.
 | |
|         # caseSensitive must not be used with regexMatch.
 | |
|         # Corresponds to the JSON property `ignoreCase`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :ignore_case
 | |
|         alias_method :ignore_case?, :ignore_case
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `metadataFilters`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::MetadataFilter>]
 | |
|         attr_accessor :metadata_filters
 | |
|       
 | |
|         # For satifying 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.
 | |
|         # Corresponds to the JSON property `prefixMatch`
 | |
|         # @return [String]
 | |
|         attr_accessor :prefix_match
 | |
|       
 | |
|         # Specifies a list of query parameter match criteria, all of which must match
 | |
|         # corresponding query parameters in the request.
 | |
|         # Corresponds to the JSON property `queryParameterMatches`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::HttpQueryParameterMatch>]
 | |
|         attr_accessor :query_parameter_matches
 | |
|       
 | |
|         # For satifying 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.
 | |
|         # Corresponds to the JSON property `regexMatch`
 | |
|         # @return [String]
 | |
|         attr_accessor :regex_match
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @full_path_match = args[:full_path_match] if args.key?(:full_path_match)
 | |
|           @header_matches = args[:header_matches] if args.key?(:header_matches)
 | |
|           @ignore_case = args[:ignore_case] if args.key?(:ignore_case)
 | |
|           @metadata_filters = args[:metadata_filters] if args.key?(:metadata_filters)
 | |
|           @prefix_match = args[:prefix_match] if args.key?(:prefix_match)
 | |
|           @query_parameter_matches = args[:query_parameter_matches] if args.key?(:query_parameter_matches)
 | |
|           @regex_match = args[:regex_match] if args.key?(:regex_match)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # An HttpsHealthCheck resource. This resource defines a template for how
 | |
|       # individual instances should be checked for health, via HTTPS.
 | |
|       class HttpsHealthCheck
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # How often (in seconds) to send a health check. The default value is 5 seconds.
 | |
|         # Corresponds to the JSON property `checkIntervalSec`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :check_interval_sec
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # A so-far unhealthy instance will be marked healthy after this many consecutive
 | |
|         # successes. The default value is 2.
 | |
|         # Corresponds to the JSON property `healthyThreshold`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :healthy_threshold
 | |
|       
 | |
|         # The value of the host header in the HTTPS health check request. If left empty (
 | |
|         # default value), the public IP on behalf of which this health check is
 | |
|         # performed will be used.
 | |
|         # Corresponds to the JSON property `host`
 | |
|         # @return [String]
 | |
|         attr_accessor :host
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # Type of the resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # The TCP port number for the HTTPS health check request. The default value is
 | |
|         # 443.
 | |
|         # Corresponds to the JSON property `port`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :port
 | |
|       
 | |
|         # The request path of the HTTPS health check request. The default value is "/".
 | |
|         # Corresponds to the JSON property `requestPath`
 | |
|         # @return [String]
 | |
|         attr_accessor :request_path
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # How long (in seconds) to wait before claiming failure. The default value is 5
 | |
|         # seconds. It is invalid for timeoutSec to have a greater value than
 | |
|         # checkIntervalSec.
 | |
|         # Corresponds to the JSON property `timeoutSec`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :timeout_sec
 | |
|       
 | |
|         # A so-far healthy instance will be marked unhealthy after this many consecutive
 | |
|         # failures. The default value is 2.
 | |
|         # Corresponds to the JSON property `unhealthyThreshold`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :unhealthy_threshold
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @check_interval_sec = args[:check_interval_sec] if args.key?(:check_interval_sec)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @healthy_threshold = args[:healthy_threshold] if args.key?(:healthy_threshold)
 | |
|           @host = args[:host] if args.key?(:host)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @port = args[:port] if args.key?(:port)
 | |
|           @request_path = args[:request_path] if args.key?(:request_path)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @timeout_sec = args[:timeout_sec] if args.key?(:timeout_sec)
 | |
|           @unhealthy_threshold = args[:unhealthy_threshold] if args.key?(:unhealthy_threshold)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of HttpsHealthCheck resources.
 | |
|       class HttpsHealthCheckList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of HttpsHealthCheck resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::HttpsHealthCheck>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::HttpsHealthCheckList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::HttpsHealthCheckList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # An Image resource. (== resource_for beta.images ==) (== resource_for v1.images
 | |
|       # ==)
 | |
|       class Image
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Size of the image tar.gz archive stored in Google Cloud Storage (in bytes).
 | |
|         # Corresponds to the JSON property `archiveSizeBytes`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :archive_size_bytes
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # Deprecation status for a public resource.
 | |
|         # Corresponds to the JSON property `deprecated`
 | |
|         # @return [Google::Apis::ComputeAlpha::DeprecationStatus]
 | |
|         attr_accessor :deprecated
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # Size of the image when restored onto a persistent disk (in GB).
 | |
|         # Corresponds to the JSON property `diskSizeGb`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :disk_size_gb
 | |
|       
 | |
|         # The name of the image family to which this image belongs. You can create disks
 | |
|         # by specifying an image family instead of a specific image name. The image
 | |
|         # family always returns its latest image that is not deprecated. The name of the
 | |
|         # image family must comply with RFC1035.
 | |
|         # Corresponds to the JSON property `family`
 | |
|         # @return [String]
 | |
|         attr_accessor :family
 | |
|       
 | |
|         # A list of features to enable on the guest operating system. Applicable only
 | |
|         # for bootable images. Read  Enabling guest operating system features to see a
 | |
|         # list of available options.
 | |
|         # Corresponds to the JSON property `guestOsFeatures`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::GuestOsFeature>]
 | |
|         attr_accessor :guest_os_features
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # Represents a customer-supplied encryption key
 | |
|         # Corresponds to the JSON property `imageEncryptionKey`
 | |
|         # @return [Google::Apis::ComputeAlpha::CustomerEncryptionKey]
 | |
|         attr_accessor :image_encryption_key
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#image for images.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # A fingerprint for the labels being applied to this image, which is essentially
 | |
|         # a hash of the labels used for optimistic locking. The fingerprint is initially
 | |
|         # generated by Compute Engine and changes after every request to modify or
 | |
|         # update labels. You must always provide an up-to-date fingerprint hash in order
 | |
|         # to update or change labels, otherwise the request will fail with error 412
 | |
|         # conditionNotMet.
 | |
|         # To see the latest fingerprint, make a get() request to retrieve an image.
 | |
|         # Corresponds to the JSON property `labelFingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :label_fingerprint
 | |
|       
 | |
|         # Labels to apply to this image. These can be later modified by the setLabels
 | |
|         # method.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         # Integer license codes indicating which licenses are attached to this image.
 | |
|         # Corresponds to the JSON property `licenseCodes`
 | |
|         # @return [Array<Fixnum>]
 | |
|         attr_accessor :license_codes
 | |
|       
 | |
|         # Any applicable license URI.
 | |
|         # Corresponds to the JSON property `licenses`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :licenses
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # The parameters of the raw disk image.
 | |
|         # Corresponds to the JSON property `rawDisk`
 | |
|         # @return [Google::Apis::ComputeAlpha::Image::RawDisk]
 | |
|         attr_accessor :raw_disk
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource's resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # URL of the source disk used to create this image. This can be a full or valid
 | |
|         # partial URL. You must provide either this property or the rawDisk.source
 | |
|         # property but not both to create an image. For example, the following are valid
 | |
|         # values:
 | |
|         # - https://www.googleapis.com/compute/v1/projects/project/zones/zone/disks/disk
 | |
|         # - projects/project/zones/zone/disks/disk
 | |
|         # - zones/zone/disks/disk
 | |
|         # Corresponds to the JSON property `sourceDisk`
 | |
|         # @return [String]
 | |
|         attr_accessor :source_disk
 | |
|       
 | |
|         # Represents a customer-supplied encryption key
 | |
|         # Corresponds to the JSON property `sourceDiskEncryptionKey`
 | |
|         # @return [Google::Apis::ComputeAlpha::CustomerEncryptionKey]
 | |
|         attr_accessor :source_disk_encryption_key
 | |
|       
 | |
|         # [Output Only] The ID value of the disk used to create this image. This value
 | |
|         # may be used to determine whether the image was taken from the current or a
 | |
|         # previous instance of a given disk name.
 | |
|         # Corresponds to the JSON property `sourceDiskId`
 | |
|         # @return [String]
 | |
|         attr_accessor :source_disk_id
 | |
|       
 | |
|         # URL of the source image used to create this image. This can be a full or valid
 | |
|         # partial URL. You must provide exactly one of:
 | |
|         # - this property, or
 | |
|         # - the rawDisk.source property, or
 | |
|         # - the sourceDisk property   in order to create an image.
 | |
|         # Corresponds to the JSON property `sourceImage`
 | |
|         # @return [String]
 | |
|         attr_accessor :source_image
 | |
|       
 | |
|         # Represents a customer-supplied encryption key
 | |
|         # Corresponds to the JSON property `sourceImageEncryptionKey`
 | |
|         # @return [Google::Apis::ComputeAlpha::CustomerEncryptionKey]
 | |
|         attr_accessor :source_image_encryption_key
 | |
|       
 | |
|         # [Output Only] The ID value of the image used to create this image. This value
 | |
|         # may be used to determine whether the image was taken from the current or a
 | |
|         # previous instance of a given image name.
 | |
|         # Corresponds to the JSON property `sourceImageId`
 | |
|         # @return [String]
 | |
|         attr_accessor :source_image_id
 | |
|       
 | |
|         # URL of the source snapshot used to create this image. This can be a full or
 | |
|         # valid partial URL. You must provide exactly one of:
 | |
|         # - this property, or
 | |
|         # - the sourceImage property, or
 | |
|         # - the rawDisk.source property, or
 | |
|         # - the sourceDisk property   in order to create an image.
 | |
|         # Corresponds to the JSON property `sourceSnapshot`
 | |
|         # @return [String]
 | |
|         attr_accessor :source_snapshot
 | |
|       
 | |
|         # Represents a customer-supplied encryption key
 | |
|         # Corresponds to the JSON property `sourceSnapshotEncryptionKey`
 | |
|         # @return [Google::Apis::ComputeAlpha::CustomerEncryptionKey]
 | |
|         attr_accessor :source_snapshot_encryption_key
 | |
|       
 | |
|         # [Output Only] The ID value of the snapshot used to create this image. This
 | |
|         # value may be used to determine whether the snapshot was taken from the current
 | |
|         # or a previous instance of a given snapshot name.
 | |
|         # Corresponds to the JSON property `sourceSnapshotId`
 | |
|         # @return [String]
 | |
|         attr_accessor :source_snapshot_id
 | |
|       
 | |
|         # The type of the image used to create this disk. The default and only value is
 | |
|         # RAW
 | |
|         # Corresponds to the JSON property `sourceType`
 | |
|         # @return [String]
 | |
|         attr_accessor :source_type
 | |
|       
 | |
|         # [Output Only] The status of the image. An image can be used to create other
 | |
|         # resources, such as instances, only after the image has been successfully
 | |
|         # created and the status is set to READY. Possible values are FAILED, PENDING,
 | |
|         # or READY.
 | |
|         # Corresponds to the JSON property `status`
 | |
|         # @return [String]
 | |
|         attr_accessor :status
 | |
|       
 | |
|         # GCS bucket storage location of the image (regional or multi-regional).
 | |
|         # Corresponds to the JSON property `storageLocations`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :storage_locations
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @archive_size_bytes = args[:archive_size_bytes] if args.key?(:archive_size_bytes)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @deprecated = args[:deprecated] if args.key?(:deprecated)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @disk_size_gb = args[:disk_size_gb] if args.key?(:disk_size_gb)
 | |
|           @family = args[:family] if args.key?(:family)
 | |
|           @guest_os_features = args[:guest_os_features] if args.key?(:guest_os_features)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @image_encryption_key = args[:image_encryption_key] if args.key?(:image_encryption_key)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|           @license_codes = args[:license_codes] if args.key?(:license_codes)
 | |
|           @licenses = args[:licenses] if args.key?(:licenses)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @raw_disk = args[:raw_disk] if args.key?(:raw_disk)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @source_disk = args[:source_disk] if args.key?(:source_disk)
 | |
|           @source_disk_encryption_key = args[:source_disk_encryption_key] if args.key?(:source_disk_encryption_key)
 | |
|           @source_disk_id = args[:source_disk_id] if args.key?(:source_disk_id)
 | |
|           @source_image = args[:source_image] if args.key?(:source_image)
 | |
|           @source_image_encryption_key = args[:source_image_encryption_key] if args.key?(:source_image_encryption_key)
 | |
|           @source_image_id = args[:source_image_id] if args.key?(:source_image_id)
 | |
|           @source_snapshot = args[:source_snapshot] if args.key?(:source_snapshot)
 | |
|           @source_snapshot_encryption_key = args[:source_snapshot_encryption_key] if args.key?(:source_snapshot_encryption_key)
 | |
|           @source_snapshot_id = args[:source_snapshot_id] if args.key?(:source_snapshot_id)
 | |
|           @source_type = args[:source_type] if args.key?(:source_type)
 | |
|           @status = args[:status] if args.key?(:status)
 | |
|           @storage_locations = args[:storage_locations] if args.key?(:storage_locations)
 | |
|         end
 | |
|         
 | |
|         # The parameters of the raw disk image.
 | |
|         class RawDisk
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # The format used to encode and transmit the block device, which should be TAR.
 | |
|           # This is just a container and transmission format and not a runtime format.
 | |
|           # Provided by the client when the disk image is created.
 | |
|           # Corresponds to the JSON property `containerType`
 | |
|           # @return [String]
 | |
|           attr_accessor :container_type
 | |
|         
 | |
|           # An optional SHA1 checksum of the disk image before unpackaging; provided by
 | |
|           # the client when the disk image is created.
 | |
|           # Corresponds to the JSON property `sha1Checksum`
 | |
|           # @return [String]
 | |
|           attr_accessor :sha1_checksum
 | |
|         
 | |
|           # The full Google Cloud Storage URL where the disk image is stored. You must
 | |
|           # provide either this property or the sourceDisk property but not both.
 | |
|           # Corresponds to the JSON property `source`
 | |
|           # @return [String]
 | |
|           attr_accessor :source
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @container_type = args[:container_type] if args.key?(:container_type)
 | |
|             @sha1_checksum = args[:sha1_checksum] if args.key?(:sha1_checksum)
 | |
|             @source = args[:source] if args.key?(:source)
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of images.
 | |
|       class ImageList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of Image resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Image>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::ImageList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::ImageList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # An Instance resource. (== resource_for beta.instances ==) (== resource_for v1.
 | |
|       # instances ==)
 | |
|       class Instance
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # AllocationAffinity is the configuration of desired allocation which this
 | |
|         # instance could take capacity from.
 | |
|         # Corresponds to the JSON property `allocationAffinity`
 | |
|         # @return [Google::Apis::ComputeAlpha::AllocationAffinity]
 | |
|         attr_accessor :allocation_affinity
 | |
|       
 | |
|         # Allows this instance to send and receive packets with non-matching destination
 | |
|         # or source IPs. This is required if you plan to use this instance to forward
 | |
|         # routes. For more information, see Enabling IP Forwarding.
 | |
|         # Corresponds to the JSON property `canIpForward`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :can_ip_forward
 | |
|         alias_method :can_ip_forward?, :can_ip_forward
 | |
|       
 | |
|         # [Output Only] The CPU platform used by this instance.
 | |
|         # Corresponds to the JSON property `cpuPlatform`
 | |
|         # @return [String]
 | |
|         attr_accessor :cpu_platform
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # Whether the resource should be protected against deletion.
 | |
|         # Corresponds to the JSON property `deletionProtection`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :deletion_protection
 | |
|         alias_method :deletion_protection?, :deletion_protection
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # Array of disks associated with this instance. Persistent disks must be created
 | |
|         # before you can assign them.
 | |
|         # Corresponds to the JSON property `disks`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::AttachedDisk>]
 | |
|         attr_accessor :disks
 | |
|       
 | |
|         # A set of Display Device options
 | |
|         # Corresponds to the JSON property `displayDevice`
 | |
|         # @return [Google::Apis::ComputeAlpha::DisplayDevice]
 | |
|         attr_accessor :display_device
 | |
|       
 | |
|         # A list of the type and count of accelerator cards attached to the instance.
 | |
|         # Corresponds to the JSON property `guestAccelerators`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::AcceleratorConfig>]
 | |
|         attr_accessor :guest_accelerators
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `hostname`
 | |
|         # @return [String]
 | |
|         attr_accessor :hostname
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # Represents a customer-supplied encryption key
 | |
|         # Corresponds to the JSON property `instanceEncryptionKey`
 | |
|         # @return [Google::Apis::ComputeAlpha::CustomerEncryptionKey]
 | |
|         attr_accessor :instance_encryption_key
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#instance for instances.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # A fingerprint for this request, which is essentially a hash of the label's
 | |
|         # contents and used for optimistic locking. The fingerprint is initially
 | |
|         # generated by Compute Engine and changes after every request to modify or
 | |
|         # update labels. You must always provide an up-to-date fingerprint hash in order
 | |
|         # to update or change labels.
 | |
|         # To see the latest fingerprint, make get() request to the instance.
 | |
|         # Corresponds to the JSON property `labelFingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :label_fingerprint
 | |
|       
 | |
|         # Labels to apply to this instance. These can be later modified by the setLabels
 | |
|         # method.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         # Full or partial URL of the machine type resource to use for this instance, in
 | |
|         # the format: zones/zone/machineTypes/machine-type. This is provided by the
 | |
|         # client when the instance is created. For example, the following is a valid
 | |
|         # partial url to a predefined machine type:
 | |
|         # zones/us-central1-f/machineTypes/n1-standard-1
 | |
|         # To create a custom machine type, provide a URL to a machine type in the
 | |
|         # following format, where CPUS is 1 or an even number up to 32 (2, 4, 6, ... 24,
 | |
|         # etc), and MEMORY is the total memory for this instance. Memory must be a
 | |
|         # multiple of 256 MB and must be supplied in MB (e.g. 5 GB of memory is 5120 MB):
 | |
|         # zones/zone/machineTypes/custom-CPUS-MEMORY
 | |
|         # For example: zones/us-central1-f/machineTypes/custom-4-5120
 | |
|         # For a full list of restrictions, read the Specifications for custom machine
 | |
|         # types.
 | |
|         # Corresponds to the JSON property `machineType`
 | |
|         # @return [String]
 | |
|         attr_accessor :machine_type
 | |
|       
 | |
|         # A metadata key/value entry.
 | |
|         # Corresponds to the JSON property `metadata`
 | |
|         # @return [Google::Apis::ComputeAlpha::Metadata]
 | |
|         attr_accessor :metadata
 | |
|       
 | |
|         # Specifies a minimum CPU platform for the VM instance. Applicable values are
 | |
|         # the friendly names of CPU platforms, such as minCpuPlatform: "Intel Haswell"
 | |
|         # or minCpuPlatform: "Intel Sandy Bridge".
 | |
|         # Corresponds to the JSON property `minCpuPlatform`
 | |
|         # @return [String]
 | |
|         attr_accessor :min_cpu_platform
 | |
|       
 | |
|         # The name of the resource, provided by the client when initially creating the
 | |
|         # resource. The resource 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # An array of network configurations for this instance. These specify how
 | |
|         # interfaces are configured to interact with other network services, such as
 | |
|         # connecting to the internet. Multiple interfaces are supported per instance.
 | |
|         # Corresponds to the JSON property `networkInterfaces`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::NetworkInterface>]
 | |
|         attr_accessor :network_interfaces
 | |
|       
 | |
|         # Total amount of preserved state for SUSPENDED instances. Read-only in the api.
 | |
|         # Corresponds to the JSON property `preservedStateSizeGb`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :preserved_state_size_gb
 | |
|       
 | |
|         # Resource policies applied to this instance.
 | |
|         # Corresponds to the JSON property `resourcePolicies`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :resource_policies
 | |
|       
 | |
|         # Sets the scheduling options for an Instance.
 | |
|         # Corresponds to the JSON property `scheduling`
 | |
|         # @return [Google::Apis::ComputeAlpha::Scheduling]
 | |
|         attr_accessor :scheduling
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # A list of service accounts, with their specified scopes, authorized for this
 | |
|         # instance. Only one service account per VM instance is supported.
 | |
|         # Service accounts generate access tokens that can be accessed through the
 | |
|         # metadata server and used to authenticate applications on the instance. See
 | |
|         # Service Accounts for more information.
 | |
|         # Corresponds to the JSON property `serviceAccounts`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::ServiceAccount>]
 | |
|         attr_accessor :service_accounts
 | |
|       
 | |
|         # A set of Shielded VM options.
 | |
|         # Corresponds to the JSON property `shieldedVmConfig`
 | |
|         # @return [Google::Apis::ComputeAlpha::ShieldedVmConfig]
 | |
|         attr_accessor :shielded_vm_config
 | |
|       
 | |
|         # The policy describes the baseline against which VM instance boot integrity is
 | |
|         # measured.
 | |
|         # Corresponds to the JSON property `shieldedVmIntegrityPolicy`
 | |
|         # @return [Google::Apis::ComputeAlpha::ShieldedVmIntegrityPolicy]
 | |
|         attr_accessor :shielded_vm_integrity_policy
 | |
|       
 | |
|         # Source machine image
 | |
|         # Corresponds to the JSON property `sourceMachineImage`
 | |
|         # @return [String]
 | |
|         attr_accessor :source_machine_image
 | |
|       
 | |
|         # Represents a customer-supplied encryption key
 | |
|         # Corresponds to the JSON property `sourceMachineImageEncryptionKey`
 | |
|         # @return [Google::Apis::ComputeAlpha::CustomerEncryptionKey]
 | |
|         attr_accessor :source_machine_image_encryption_key
 | |
|       
 | |
|         # [Output Only] Whether a VM has been restricted for start because Compute
 | |
|         # Engine has detected suspicious activity.
 | |
|         # Corresponds to the JSON property `startRestricted`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :start_restricted
 | |
|         alias_method :start_restricted?, :start_restricted
 | |
|       
 | |
|         # [Output Only] The status of the instance. One of the following values:
 | |
|         # PROVISIONING, STAGING, RUNNING, STOPPING, STOPPED, SUSPENDING, SUSPENDED, and
 | |
|         # TERMINATED.
 | |
|         # Corresponds to the JSON property `status`
 | |
|         # @return [String]
 | |
|         attr_accessor :status
 | |
|       
 | |
|         # [Output Only] An optional, human-readable explanation of the status.
 | |
|         # Corresponds to the JSON property `statusMessage`
 | |
|         # @return [String]
 | |
|         attr_accessor :status_message
 | |
|       
 | |
|         # A set of instance tags.
 | |
|         # Corresponds to the JSON property `tags`
 | |
|         # @return [Google::Apis::ComputeAlpha::Tags]
 | |
|         attr_accessor :tags
 | |
|       
 | |
|         # [Output Only] URL of the zone where the instance resides. You must specify
 | |
|         # this field as part of the HTTP request URL. It is not settable as a field in
 | |
|         # the request body.
 | |
|         # Corresponds to the JSON property `zone`
 | |
|         # @return [String]
 | |
|         attr_accessor :zone
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @allocation_affinity = args[:allocation_affinity] if args.key?(:allocation_affinity)
 | |
|           @can_ip_forward = args[:can_ip_forward] if args.key?(:can_ip_forward)
 | |
|           @cpu_platform = args[:cpu_platform] if args.key?(:cpu_platform)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @deletion_protection = args[:deletion_protection] if args.key?(:deletion_protection)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @disks = args[:disks] if args.key?(:disks)
 | |
|           @display_device = args[:display_device] if args.key?(:display_device)
 | |
|           @guest_accelerators = args[:guest_accelerators] if args.key?(:guest_accelerators)
 | |
|           @hostname = args[:hostname] if args.key?(:hostname)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @instance_encryption_key = args[:instance_encryption_key] if args.key?(:instance_encryption_key)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|           @machine_type = args[:machine_type] if args.key?(:machine_type)
 | |
|           @metadata = args[:metadata] if args.key?(:metadata)
 | |
|           @min_cpu_platform = args[:min_cpu_platform] if args.key?(:min_cpu_platform)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @network_interfaces = args[:network_interfaces] if args.key?(:network_interfaces)
 | |
|           @preserved_state_size_gb = args[:preserved_state_size_gb] if args.key?(:preserved_state_size_gb)
 | |
|           @resource_policies = args[:resource_policies] if args.key?(:resource_policies)
 | |
|           @scheduling = args[:scheduling] if args.key?(:scheduling)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @service_accounts = args[:service_accounts] if args.key?(:service_accounts)
 | |
|           @shielded_vm_config = args[:shielded_vm_config] if args.key?(:shielded_vm_config)
 | |
|           @shielded_vm_integrity_policy = args[:shielded_vm_integrity_policy] if args.key?(:shielded_vm_integrity_policy)
 | |
|           @source_machine_image = args[:source_machine_image] if args.key?(:source_machine_image)
 | |
|           @source_machine_image_encryption_key = args[:source_machine_image_encryption_key] if args.key?(:source_machine_image_encryption_key)
 | |
|           @start_restricted = args[:start_restricted] if args.key?(:start_restricted)
 | |
|           @status = args[:status] if args.key?(:status)
 | |
|           @status_message = args[:status_message] if args.key?(:status_message)
 | |
|           @tags = args[:tags] if args.key?(:tags)
 | |
|           @zone = args[:zone] if args.key?(:zone)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of InstancesScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::InstancesScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#instanceAggregatedList for
 | |
|         # aggregated lists of Instance resources.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::InstanceAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::InstanceAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # InstanceGroups (== resource_for beta.instanceGroups ==) (== resource_for v1.
 | |
|       # instanceGroups ==) (== resource_for beta.regionInstanceGroups ==) (==
 | |
|       # resource_for v1.regionInstanceGroups ==)
 | |
|       class InstanceGroup
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The creation timestamp for this instance group in RFC3339 text
 | |
|         # format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The fingerprint of the named ports. The system uses this
 | |
|         # fingerprint to detect conflicts when multiple users change the named ports
 | |
|         # concurrently.
 | |
|         # Corresponds to the JSON property `fingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :fingerprint
 | |
|       
 | |
|         # [Output Only] A unique identifier for this instance group, generated by the
 | |
|         # server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] The resource type, which is always compute#instanceGroup for
 | |
|         # instance groups.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # The name of the instance group. The name must be 1-63 characters long, and
 | |
|         # comply with RFC1035.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # Assigns a name to a port number. For example: `name: "http", port: 80`
 | |
|         # This allows the system to reference ports by the assigned name instead of a
 | |
|         # port number. Named ports can also contain multiple ports. For example: [`name:
 | |
|         # "http", port: 80`,`name: "http", port: 8080`]
 | |
|         # Named ports apply to all instances in this instance group.
 | |
|         # Corresponds to the JSON property `namedPorts`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::NamedPort>]
 | |
|         attr_accessor :named_ports
 | |
|       
 | |
|         # The URL of the network to which all instances in the instance group belong.
 | |
|         # Corresponds to the JSON property `network`
 | |
|         # @return [String]
 | |
|         attr_accessor :network
 | |
|       
 | |
|         # [Output Only] The URL of the region where the instance group is located (for
 | |
|         # regional resources).
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # [Output Only] The URL for this instance group. The server generates this URL.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # [Output Only] The total number of instances in the instance group.
 | |
|         # Corresponds to the JSON property `size`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :size
 | |
|       
 | |
|         # [Output Only] The URL of the subnetwork to which all instances in the instance
 | |
|         # group belong.
 | |
|         # Corresponds to the JSON property `subnetwork`
 | |
|         # @return [String]
 | |
|         attr_accessor :subnetwork
 | |
|       
 | |
|         # [Output Only] The URL of the zone where the instance group is located (for
 | |
|         # zonal resources).
 | |
|         # Corresponds to the JSON property `zone`
 | |
|         # @return [String]
 | |
|         attr_accessor :zone
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @fingerprint = args[:fingerprint] if args.key?(:fingerprint)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @named_ports = args[:named_ports] if args.key?(:named_ports)
 | |
|           @network = args[:network] if args.key?(:network)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @size = args[:size] if args.key?(:size)
 | |
|           @subnetwork = args[:subnetwork] if args.key?(:subnetwork)
 | |
|           @zone = args[:zone] if args.key?(:zone)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of InstanceGroupsScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::InstanceGroupsScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] The resource type, which is always compute#
 | |
|         # instanceGroupAggregatedList for aggregated lists of instance groups.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::InstanceGroupAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::InstanceGroupAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A list of InstanceGroup resources.
 | |
|       class InstanceGroupList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of InstanceGroup resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InstanceGroup>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] The resource type, which is always compute#instanceGroupList for
 | |
|         # instance group lists.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::InstanceGroupList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::InstanceGroupList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # An Instance Group Manager resource. (== resource_for beta.
 | |
|       # instanceGroupManagers ==) (== resource_for v1.instanceGroupManagers ==) (==
 | |
|       # resource_for beta.regionInstanceGroupManagers ==) (== resource_for v1.
 | |
|       # regionInstanceGroupManagers ==)
 | |
|       class InstanceGroupManager
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The autohealing policy for this managed instance group. You can specify only
 | |
|         # one value.
 | |
|         # Corresponds to the JSON property `autoHealingPolicies`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InstanceGroupManagerAutoHealingPolicy>]
 | |
|         attr_accessor :auto_healing_policies
 | |
|       
 | |
|         # The base instance name to use for instances in this group. The value must be 1-
 | |
|         # 58 characters long. Instances are named by appending a hyphen and a random
 | |
|         # four-character string to the base instance name. The base instance name must
 | |
|         # comply with RFC1035.
 | |
|         # Corresponds to the JSON property `baseInstanceName`
 | |
|         # @return [String]
 | |
|         attr_accessor :base_instance_name
 | |
|       
 | |
|         # [Output Only] The creation timestamp for this managed instance group in
 | |
|         # RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # [Output Only] The list of instance actions and the number of instances in this
 | |
|         # managed instance group that are scheduled for each of those actions.
 | |
|         # Corresponds to the JSON property `currentActions`
 | |
|         # @return [Google::Apis::ComputeAlpha::InstanceGroupManagerActionsSummary]
 | |
|         attr_accessor :current_actions
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # Policy specifying intended distribution of instances in regional managed
 | |
|         # instance group.
 | |
|         # Corresponds to the JSON property `distributionPolicy`
 | |
|         # @return [Google::Apis::ComputeAlpha::DistributionPolicy]
 | |
|         attr_accessor :distribution_policy
 | |
|       
 | |
|         # The action to perform in case of zone failure. Only one value is supported,
 | |
|         # NO_FAILOVER. The default is NO_FAILOVER.
 | |
|         # Corresponds to the JSON property `failoverAction`
 | |
|         # @return [String]
 | |
|         attr_accessor :failover_action
 | |
|       
 | |
|         # Fingerprint of this resource. This field may be used in optimistic locking. It
 | |
|         # will be ignored when inserting an InstanceGroupManager. An up-to-date
 | |
|         # fingerprint must be provided in order to update the InstanceGroupManager,
 | |
|         # otherwise the request will fail with error 412 conditionNotMet.
 | |
|         # To see the latest fingerprint, make a get() request to retrieve an
 | |
|         # InstanceGroupManager.
 | |
|         # Corresponds to the JSON property `fingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :fingerprint
 | |
|       
 | |
|         # [Output Only] A unique identifier for this resource type. The server generates
 | |
|         # this identifier.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] The URL of the Instance Group resource.
 | |
|         # Corresponds to the JSON property `instanceGroup`
 | |
|         # @return [String]
 | |
|         attr_accessor :instance_group
 | |
|       
 | |
|         # The URL of the instance template that is specified for this managed instance
 | |
|         # group. The group uses this template to create all new instances in the managed
 | |
|         # instance group.
 | |
|         # Corresponds to the JSON property `instanceTemplate`
 | |
|         # @return [String]
 | |
|         attr_accessor :instance_template
 | |
|       
 | |
|         # [Output Only] The resource type, which is always compute#instanceGroupManager
 | |
|         # for managed instance groups.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # The name of the managed instance group. The name must be 1-63 characters long,
 | |
|         # and comply with RFC1035.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # Named ports configured for the Instance Groups complementary to this Instance
 | |
|         # Group Manager.
 | |
|         # Corresponds to the JSON property `namedPorts`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::NamedPort>]
 | |
|         attr_accessor :named_ports
 | |
|       
 | |
|         # [Output Only] The list of instance actions and the number of instances in this
 | |
|         # managed instance group that are pending for each of those actions.
 | |
|         # Corresponds to the JSON property `pendingActions`
 | |
|         # @return [Google::Apis::ComputeAlpha::InstanceGroupManagerPendingActionsSummary]
 | |
|         attr_accessor :pending_actions
 | |
|       
 | |
|         # [Output Only] The URL of the region where the managed instance group resides (
 | |
|         # for regional resources).
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # [Output Only] The URL for this managed instance group. The server defines this
 | |
|         # URL.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # The service account to be used as credentials for all operations performed by
 | |
|         # the managed instance group on instances. The service accounts needs all
 | |
|         # permissions required to create and delete instances. By default, the service
 | |
|         # account `projectNumber`@cloudservices.gserviceaccount.com is used.
 | |
|         # Corresponds to the JSON property `serviceAccount`
 | |
|         # @return [String]
 | |
|         attr_accessor :service_account
 | |
|       
 | |
|         # Stateful configuration for this Instanced Group Manager
 | |
|         # Corresponds to the JSON property `statefulPolicy`
 | |
|         # @return [Google::Apis::ComputeAlpha::StatefulPolicy]
 | |
|         attr_accessor :stateful_policy
 | |
|       
 | |
|         # [Output Only] The status of this managed instance group.
 | |
|         # Corresponds to the JSON property `status`
 | |
|         # @return [Google::Apis::ComputeAlpha::InstanceGroupManagerStatus]
 | |
|         attr_accessor :status
 | |
|       
 | |
|         # The URLs for all TargetPool resources to which instances in the instanceGroup
 | |
|         # field are added. The target pools automatically apply to all of the instances
 | |
|         # in the managed instance group.
 | |
|         # Corresponds to the JSON property `targetPools`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :target_pools
 | |
|       
 | |
|         # The target number of running instances for this managed instance group.
 | |
|         # Deleting or abandoning instances reduces this number. Resizing the group
 | |
|         # changes this number.
 | |
|         # Corresponds to the JSON property `targetSize`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :target_size
 | |
|       
 | |
|         # The update policy for this managed instance group.
 | |
|         # Corresponds to the JSON property `updatePolicy`
 | |
|         # @return [Google::Apis::ComputeAlpha::InstanceGroupManagerUpdatePolicy]
 | |
|         attr_accessor :update_policy
 | |
|       
 | |
|         # Specifies the instance templates used by this managed instance group to create
 | |
|         # instances.
 | |
|         # Each version is defined by an instanceTemplate. Every template can appear at
 | |
|         # most once per instance group. This field overrides the top-level
 | |
|         # instanceTemplate field. Read more about the relationships between these fields.
 | |
|         # Exactly one version must leave the targetSize field unset. That version will
 | |
|         # be applied to all remaining instances. For more information, read about canary
 | |
|         # updates.
 | |
|         # Corresponds to the JSON property `versions`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InstanceGroupManagerVersion>]
 | |
|         attr_accessor :versions
 | |
|       
 | |
|         # [Output Only] The URL of the zone where the managed instance group is located (
 | |
|         # for zonal resources).
 | |
|         # Corresponds to the JSON property `zone`
 | |
|         # @return [String]
 | |
|         attr_accessor :zone
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @auto_healing_policies = args[:auto_healing_policies] if args.key?(:auto_healing_policies)
 | |
|           @base_instance_name = args[:base_instance_name] if args.key?(:base_instance_name)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @current_actions = args[:current_actions] if args.key?(:current_actions)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @distribution_policy = args[:distribution_policy] if args.key?(:distribution_policy)
 | |
|           @failover_action = args[:failover_action] if args.key?(:failover_action)
 | |
|           @fingerprint = args[:fingerprint] if args.key?(:fingerprint)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @instance_group = args[:instance_group] if args.key?(:instance_group)
 | |
|           @instance_template = args[:instance_template] if args.key?(:instance_template)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @named_ports = args[:named_ports] if args.key?(:named_ports)
 | |
|           @pending_actions = args[:pending_actions] if args.key?(:pending_actions)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @service_account = args[:service_account] if args.key?(:service_account)
 | |
|           @stateful_policy = args[:stateful_policy] if args.key?(:stateful_policy)
 | |
|           @status = args[:status] if args.key?(:status)
 | |
|           @target_pools = args[:target_pools] if args.key?(:target_pools)
 | |
|           @target_size = args[:target_size] if args.key?(:target_size)
 | |
|           @update_policy = args[:update_policy] if args.key?(:update_policy)
 | |
|           @versions = args[:versions] if args.key?(:versions)
 | |
|           @zone = args[:zone] if args.key?(:zone)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupManagerActionsSummary
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The total number of instances in the managed instance group that
 | |
|         # are scheduled to be abandoned. Abandoning an instance removes it from the
 | |
|         # managed instance group without deleting it.
 | |
|         # Corresponds to the JSON property `abandoning`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :abandoning
 | |
|       
 | |
|         # [Output Only] The number of instances in the managed instance group that are
 | |
|         # scheduled to be created or are currently being created. If the group fails to
 | |
|         # create any of these instances, it tries again until it creates the instance
 | |
|         # successfully.
 | |
|         # If you have disabled creation retries, this field will not be populated;
 | |
|         # instead, the creatingWithoutRetries field will be populated.
 | |
|         # Corresponds to the JSON property `creating`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :creating
 | |
|       
 | |
|         # [Output Only] The number of instances that the managed instance group will
 | |
|         # attempt to create. The group attempts to create each instance only once. If
 | |
|         # the group fails to create any of these instances, it decreases the group's
 | |
|         # targetSize value accordingly.
 | |
|         # Corresponds to the JSON property `creatingWithoutRetries`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :creating_without_retries
 | |
|       
 | |
|         # [Output Only] The number of instances in the managed instance group that are
 | |
|         # scheduled to be deleted or are currently being deleted.
 | |
|         # Corresponds to the JSON property `deleting`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :deleting
 | |
|       
 | |
|         # [Output Only] The number of instances in the managed instance group that are
 | |
|         # running and have no scheduled actions.
 | |
|         # Corresponds to the JSON property `none`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :none
 | |
|       
 | |
|         # [Output Only] The number of instances in the managed instance group that are
 | |
|         # scheduled to be recreated or are currently being being recreated. Recreating
 | |
|         # an instance deletes the existing root persistent disk and creates a new disk
 | |
|         # from the image that is defined in the instance template.
 | |
|         # Corresponds to the JSON property `recreating`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :recreating
 | |
|       
 | |
|         # [Output Only] The number of instances in the managed instance group that are
 | |
|         # being reconfigured with properties that do not require a restart or a recreate
 | |
|         # action. For example, setting or removing target pools for the instance.
 | |
|         # Corresponds to the JSON property `refreshing`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :refreshing
 | |
|       
 | |
|         # [Output Only] The number of instances in the managed instance group that are
 | |
|         # scheduled to be restarted or are currently being restarted.
 | |
|         # Corresponds to the JSON property `restarting`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :restarting
 | |
|       
 | |
|         # [Output Only] The number of instances in the managed instance group that are
 | |
|         # being verified. See the managedInstances[].currentAction property in the
 | |
|         # listManagedInstances method documentation.
 | |
|         # Corresponds to the JSON property `verifying`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :verifying
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @abandoning = args[:abandoning] if args.key?(:abandoning)
 | |
|           @creating = args[:creating] if args.key?(:creating)
 | |
|           @creating_without_retries = args[:creating_without_retries] if args.key?(:creating_without_retries)
 | |
|           @deleting = args[:deleting] if args.key?(:deleting)
 | |
|           @none = args[:none] if args.key?(:none)
 | |
|           @recreating = args[:recreating] if args.key?(:recreating)
 | |
|           @refreshing = args[:refreshing] if args.key?(:refreshing)
 | |
|           @restarting = args[:restarting] if args.key?(:restarting)
 | |
|           @verifying = args[:verifying] if args.key?(:verifying)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupManagerAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of InstanceGroupManagersScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::InstanceGroupManagersScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] The resource type, which is always compute#
 | |
|         # instanceGroupManagerAggregatedList for an aggregated list of managed instance
 | |
|         # groups.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::InstanceGroupManagerAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::InstanceGroupManagerAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupManagerAutoHealingPolicy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The URL for the health check that signals autohealing.
 | |
|         # Corresponds to the JSON property `healthCheck`
 | |
|         # @return [String]
 | |
|         attr_accessor :health_check
 | |
|       
 | |
|         # The number of seconds that the managed instance group waits before it applies
 | |
|         # autohealing policies to new instances or recently recreated instances. This
 | |
|         # initial delay allows instances to initialize and run their startup scripts
 | |
|         # before the instance group determines that they are UNHEALTHY. This prevents
 | |
|         # the managed instance group from recreating its instances prematurely. This
 | |
|         # value must be from range [0, 3600].
 | |
|         # Corresponds to the JSON property `initialDelaySec`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :initial_delay_sec
 | |
|       
 | |
|         # Encapsulates numeric value that can be either absolute or relative.
 | |
|         # Corresponds to the JSON property `maxUnavailable`
 | |
|         # @return [Google::Apis::ComputeAlpha::FixedOrPercent]
 | |
|         attr_accessor :max_unavailable
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @health_check = args[:health_check] if args.key?(:health_check)
 | |
|           @initial_delay_sec = args[:initial_delay_sec] if args.key?(:initial_delay_sec)
 | |
|           @max_unavailable = args[:max_unavailable] if args.key?(:max_unavailable)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # [Output Only] A list of managed instance groups.
 | |
|       class InstanceGroupManagerList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of InstanceGroupManager resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InstanceGroupManager>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] The resource type, which is always compute#
 | |
|         # instanceGroupManagerList for a list of managed instance groups.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::InstanceGroupManagerList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::InstanceGroupManagerList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupManagerPendingActionsSummary
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The number of instances in the managed instance group that are
 | |
|         # pending to be created.
 | |
|         # Corresponds to the JSON property `creating`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :creating
 | |
|       
 | |
|         # [Output Only] The number of instances in the managed instance group that are
 | |
|         # pending to be deleted.
 | |
|         # Corresponds to the JSON property `deleting`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :deleting
 | |
|       
 | |
|         # [Output Only] The number of instances in the managed instance group that are
 | |
|         # pending to be recreated.
 | |
|         # Corresponds to the JSON property `recreating`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :recreating
 | |
|       
 | |
|         # [Output Only] The number of instances in the managed instance group that are
 | |
|         # pending to be restarted.
 | |
|         # Corresponds to the JSON property `restarting`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :restarting
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creating = args[:creating] if args.key?(:creating)
 | |
|           @deleting = args[:deleting] if args.key?(:deleting)
 | |
|           @recreating = args[:recreating] if args.key?(:recreating)
 | |
|           @restarting = args[:restarting] if args.key?(:restarting)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupManagerStatus
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] A bit indicating whether the managed instance group is in a
 | |
|         # stable state. A stable state means that: none of the instances in the managed
 | |
|         # instance group is currently undergoing any type of change (for example,
 | |
|         # creation, restart, or deletion); no future changes are scheduled for instances
 | |
|         # in the managed instance group; and the managed instance group itself is not
 | |
|         # being modified.
 | |
|         # Corresponds to the JSON property `isStable`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :is_stable
 | |
|         alias_method :is_stable?, :is_stable
 | |
|       
 | |
|         # [Output Only] A status of consistency of Instances' versions with their target
 | |
|         # version specified by version field on Instance Group Manager.
 | |
|         # Corresponds to the JSON property `versionTarget`
 | |
|         # @return [Google::Apis::ComputeAlpha::InstanceGroupManagerStatusVersionTarget]
 | |
|         attr_accessor :version_target
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @is_stable = args[:is_stable] if args.key?(:is_stable)
 | |
|           @version_target = args[:version_target] if args.key?(:version_target)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupManagerStatusVersionTarget
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] A bit indicating whether version target has been reached in this
 | |
|         # managed instance group, i.e. all instances are in their target version.
 | |
|         # Instances' target version are specified by version field on Instance Group
 | |
|         # Manager.
 | |
|         # Corresponds to the JSON property `isReached`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :is_reached
 | |
|         alias_method :is_reached?, :is_reached
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @is_reached = args[:is_reached] if args.key?(:is_reached)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupManagerUpdatePolicy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `instanceRedistributionType`
 | |
|         # @return [String]
 | |
|         attr_accessor :instance_redistribution_type
 | |
|       
 | |
|         # Encapsulates numeric value that can be either absolute or relative.
 | |
|         # Corresponds to the JSON property `maxSurge`
 | |
|         # @return [Google::Apis::ComputeAlpha::FixedOrPercent]
 | |
|         attr_accessor :max_surge
 | |
|       
 | |
|         # Encapsulates numeric value that can be either absolute or relative.
 | |
|         # Corresponds to the JSON property `maxUnavailable`
 | |
|         # @return [Google::Apis::ComputeAlpha::FixedOrPercent]
 | |
|         attr_accessor :max_unavailable
 | |
|       
 | |
|         # Minimum number of seconds to wait for after a newly created instance becomes
 | |
|         # available. This value must be from range [0, 3600].
 | |
|         # Corresponds to the JSON property `minReadySec`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :min_ready_sec
 | |
|       
 | |
|         # Minimal action to be taken on an instance. You can specify either RESTART to
 | |
|         # restart existing instances or REPLACE to delete and create new instances from
 | |
|         # the target template. If you specify a RESTART, the Updater will attempt to
 | |
|         # perform that action only. However, if the Updater determines that the minimal
 | |
|         # action you specify is not enough to perform the update, it might perform a
 | |
|         # more disruptive action.
 | |
|         # Corresponds to the JSON property `minimalAction`
 | |
|         # @return [String]
 | |
|         attr_accessor :minimal_action
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `type`
 | |
|         # @return [String]
 | |
|         attr_accessor :type
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instance_redistribution_type = args[:instance_redistribution_type] if args.key?(:instance_redistribution_type)
 | |
|           @max_surge = args[:max_surge] if args.key?(:max_surge)
 | |
|           @max_unavailable = args[:max_unavailable] if args.key?(:max_unavailable)
 | |
|           @min_ready_sec = args[:min_ready_sec] if args.key?(:min_ready_sec)
 | |
|           @minimal_action = args[:minimal_action] if args.key?(:minimal_action)
 | |
|           @type = args[:type] if args.key?(:type)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupManagerVersion
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `instanceTemplate`
 | |
|         # @return [String]
 | |
|         attr_accessor :instance_template
 | |
|       
 | |
|         # Name of the version. Unique among all versions in the scope of this managed
 | |
|         # instance group.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # Tag describing the version. Used to trigger rollout of a target version even
 | |
|         # if instance_template remains unchanged. Deprecated in favor of 'name'.
 | |
|         # Corresponds to the JSON property `tag`
 | |
|         # @return [String]
 | |
|         attr_accessor :tag
 | |
|       
 | |
|         # Encapsulates numeric value that can be either absolute or relative.
 | |
|         # Corresponds to the JSON property `targetSize`
 | |
|         # @return [Google::Apis::ComputeAlpha::FixedOrPercent]
 | |
|         attr_accessor :target_size
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instance_template = args[:instance_template] if args.key?(:instance_template)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @tag = args[:tag] if args.key?(:tag)
 | |
|           @target_size = args[:target_size] if args.key?(:target_size)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupManagersAbandonInstancesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The URLs of one or more instances to abandon. This can be a full URL or a
 | |
|         # partial URL, such as zones/[ZONE]/instances/[INSTANCE_NAME].
 | |
|         # Corresponds to the JSON property `instances`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :instances
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instances = args[:instances] if args.key?(:instances)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # InstanceGroupManagers.applyUpdatesToInstances
 | |
|       class InstanceGroupManagersApplyUpdatesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The list of URLs of one or more instances for which we want to apply updates
 | |
|         # on this managed instance group. This can be a full URL or a partial URL, such
 | |
|         # as zones/[ZONE]/instances/[INSTANCE_NAME].
 | |
|         # Corresponds to the JSON property `instances`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :instances
 | |
|       
 | |
|         # The maximal action that should be performed on the instances. By default
 | |
|         # REPLACE. This field is deprecated, please use most_disruptive_allowed_action.
 | |
|         # Corresponds to the JSON property `maximalAction`
 | |
|         # @return [String]
 | |
|         attr_accessor :maximal_action
 | |
|       
 | |
|         # The minimal action that should be perfomed on the instances. By default NONE.
 | |
|         # Corresponds to the JSON property `minimalAction`
 | |
|         # @return [String]
 | |
|         attr_accessor :minimal_action
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instances = args[:instances] if args.key?(:instances)
 | |
|           @maximal_action = args[:maximal_action] if args.key?(:maximal_action)
 | |
|           @minimal_action = args[:minimal_action] if args.key?(:minimal_action)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # InstanceGroupManagers.createInstances
 | |
|       class InstanceGroupManagersCreateInstancesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Required] List of specifications of per-instance configs.
 | |
|         # Corresponds to the JSON property `instances`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::PerInstanceConfig>]
 | |
|         attr_accessor :instances
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instances = args[:instances] if args.key?(:instances)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupManagersDeleteInstancesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The URLs of one or more instances to delete. This can be a full URL or a
 | |
|         # partial URL, such as zones/[ZONE]/instances/[INSTANCE_NAME].
 | |
|         # Corresponds to the JSON property `instances`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :instances
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instances = args[:instances] if args.key?(:instances)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # InstanceGroupManagers.deletePerInstanceConfigs
 | |
|       class InstanceGroupManagersDeletePerInstanceConfigsReq
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The list of instances for which we want to delete per-instance configs on this
 | |
|         # managed instance group.
 | |
|         # Corresponds to the JSON property `instances`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :instances
 | |
|       
 | |
|         # The list of instance names for which we want to delete per-instance configs on
 | |
|         # this managed instance group.
 | |
|         # Corresponds to the JSON property `names`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :names
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instances = args[:instances] if args.key?(:instances)
 | |
|           @names = args[:names] if args.key?(:names)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupManagersListManagedInstancesResponse
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The list of instances in the managed instance group.
 | |
|         # Corresponds to the JSON property `managedInstances`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::ManagedInstance>]
 | |
|         attr_accessor :managed_instances
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @managed_instances = args[:managed_instances] if args.key?(:managed_instances)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupManagersListPerInstanceConfigsResp
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The list of PerInstanceConfig.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::PerInstanceConfig>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::InstanceGroupManagersListPerInstanceConfigsResp::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::InstanceGroupManagersListPerInstanceConfigsResp::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupManagersRecreateInstancesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The URLs of one or more instances to recreate. This can be a full URL or a
 | |
|         # partial URL, such as zones/[ZONE]/instances/[INSTANCE_NAME].
 | |
|         # Corresponds to the JSON property `instances`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :instances
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instances = args[:instances] if args.key?(:instances)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupManagersResizeAdvancedRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # If this flag is true, the managed instance group attempts to create all
 | |
|         # instances initiated by this resize request only once. If there is an error
 | |
|         # during creation, the managed instance group does not retry create this
 | |
|         # instance, and we will decrease the targetSize of the request instead. If the
 | |
|         # flag is false, the group attempts to recreate each instance continuously until
 | |
|         # it succeeds.
 | |
|         # This flag matters only in the first attempt of creation of an instance. After
 | |
|         # an instance is successfully created while this flag is enabled, the instance
 | |
|         # behaves the same way as all the other instances created with a regular resize
 | |
|         # request. In particular, if a running instance dies unexpectedly at a later
 | |
|         # time and needs to be recreated, this mode does not affect the recreation
 | |
|         # behavior in that scenario.
 | |
|         # This flag is applicable only to the current resize request. It does not
 | |
|         # influence other resize requests in any way.
 | |
|         # You can see which instances is being creating in which mode by calling the get
 | |
|         # or listManagedInstances API.
 | |
|         # Corresponds to the JSON property `noCreationRetries`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :no_creation_retries
 | |
|         alias_method :no_creation_retries?, :no_creation_retries
 | |
|       
 | |
|         # The number of running instances that the managed instance group should
 | |
|         # maintain at any given time. The group automatically adds or removes instances
 | |
|         # to maintain the number of instances specified by this parameter.
 | |
|         # Corresponds to the JSON property `targetSize`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :target_size
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @no_creation_retries = args[:no_creation_retries] if args.key?(:no_creation_retries)
 | |
|           @target_size = args[:target_size] if args.key?(:target_size)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupManagersScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The list of managed instance groups that are contained in the
 | |
|         # specified project and zone.
 | |
|         # Corresponds to the JSON property `instanceGroupManagers`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InstanceGroupManager>]
 | |
|         attr_accessor :instance_group_managers
 | |
|       
 | |
|         # [Output Only] The warning that replaces the list of managed instance groups
 | |
|         # when the list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::InstanceGroupManagersScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instance_group_managers = args[:instance_group_managers] if args.key?(:instance_group_managers)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] The warning that replaces the list of managed instance groups
 | |
|         # when the list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::InstanceGroupManagersScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupManagersSetAutoHealingRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `autoHealingPolicies`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InstanceGroupManagerAutoHealingPolicy>]
 | |
|         attr_accessor :auto_healing_policies
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @auto_healing_policies = args[:auto_healing_policies] if args.key?(:auto_healing_policies)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupManagersSetInstanceTemplateRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The URL of the instance template that is specified for this managed instance
 | |
|         # group. The group uses this template to create all new instances in the managed
 | |
|         # instance group.
 | |
|         # Corresponds to the JSON property `instanceTemplate`
 | |
|         # @return [String]
 | |
|         attr_accessor :instance_template
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instance_template = args[:instance_template] if args.key?(:instance_template)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupManagersSetTargetPoolsRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The fingerprint of the target pools information. Use this optional property to
 | |
|         # prevent conflicts when multiple users change the target pools settings
 | |
|         # concurrently. Obtain the fingerprint with the instanceGroupManagers.get method.
 | |
|         # Then, include the fingerprint in your request to ensure that you do not
 | |
|         # overwrite changes that were applied from another concurrent request.
 | |
|         # Corresponds to the JSON property `fingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :fingerprint
 | |
|       
 | |
|         # The list of target pool URLs that instances in this managed instance group
 | |
|         # belong to. The managed instance group applies these target pools to all of the
 | |
|         # instances in the group. Existing instances and new instances in the group all
 | |
|         # receive these target pool settings.
 | |
|         # Corresponds to the JSON property `targetPools`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :target_pools
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @fingerprint = args[:fingerprint] if args.key?(:fingerprint)
 | |
|           @target_pools = args[:target_pools] if args.key?(:target_pools)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # InstanceGroupManagers.updatePerInstanceConfigs
 | |
|       class InstanceGroupManagersUpdatePerInstanceConfigsReq
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The list of per-instance configs to insert or patch on this managed instance
 | |
|         # group.
 | |
|         # Corresponds to the JSON property `perInstanceConfigs`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::PerInstanceConfig>]
 | |
|         attr_accessor :per_instance_configs
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @per_instance_configs = args[:per_instance_configs] if args.key?(:per_instance_configs)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupsAddInstancesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The list of instances to add to the instance group.
 | |
|         # Corresponds to the JSON property `instances`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InstanceReference>]
 | |
|         attr_accessor :instances
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instances = args[:instances] if args.key?(:instances)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupsListInstances
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of InstanceWithNamedPorts resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InstanceWithNamedPorts>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] The resource type, which is always compute#
 | |
|         # instanceGroupsListInstances for the list of instances in the specified
 | |
|         # instance group.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::InstanceGroupsListInstances::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::InstanceGroupsListInstances::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupsListInstancesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A filter for the state of the instances in the instance group. Valid options
 | |
|         # are ALL or RUNNING. If you do not specify this parameter the list includes all
 | |
|         # instances regardless of their state.
 | |
|         # Corresponds to the JSON property `instanceState`
 | |
|         # @return [String]
 | |
|         attr_accessor :instance_state
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instance_state = args[:instance_state] if args.key?(:instance_state)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupsRemoveInstancesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The list of instances to remove from the instance group.
 | |
|         # Corresponds to the JSON property `instances`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InstanceReference>]
 | |
|         attr_accessor :instances
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instances = args[:instances] if args.key?(:instances)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupsScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The list of instance groups that are contained in this scope.
 | |
|         # Corresponds to the JSON property `instanceGroups`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InstanceGroup>]
 | |
|         attr_accessor :instance_groups
 | |
|       
 | |
|         # [Output Only] An informational warning that replaces the list of instance
 | |
|         # groups when the list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::InstanceGroupsScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instance_groups = args[:instance_groups] if args.key?(:instance_groups)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] An informational warning that replaces the list of instance
 | |
|         # groups when the list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::InstanceGroupsScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceGroupsSetNamedPortsRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The fingerprint of the named ports information for this instance group. Use
 | |
|         # this optional property to prevent conflicts when multiple users change the
 | |
|         # named ports settings concurrently. Obtain the fingerprint with the
 | |
|         # instanceGroups.get method. Then, include the fingerprint in your request to
 | |
|         # ensure that you do not overwrite changes that were applied from another
 | |
|         # concurrent request. A request with an incorrect fingerprint will fail with
 | |
|         # error 412 conditionNotMet.
 | |
|         # Corresponds to the JSON property `fingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :fingerprint
 | |
|       
 | |
|         # The list of named ports to set for this instance group.
 | |
|         # Corresponds to the JSON property `namedPorts`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::NamedPort>]
 | |
|         attr_accessor :named_ports
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @fingerprint = args[:fingerprint] if args.key?(:fingerprint)
 | |
|           @named_ports = args[:named_ports] if args.key?(:named_ports)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of instances.
 | |
|       class InstanceList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of Instance resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Instance>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#instanceList for lists of
 | |
|         # Instance resources.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::InstanceList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::InstanceList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of instance referrers.
 | |
|       class InstanceListReferrers
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of Reference resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Reference>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#instanceListReferrers for lists
 | |
|         # of Instance referrers.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::InstanceListReferrers::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::InstanceListReferrers::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceMoveRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The URL of the destination zone to move the instance. This can be a full or
 | |
|         # partial URL. For example, the following are all valid URLs to a zone:
 | |
|         # - https://www.googleapis.com/compute/v1/projects/project/zones/zone
 | |
|         # - projects/project/zones/zone
 | |
|         # - zones/zone
 | |
|         # Corresponds to the JSON property `destinationZone`
 | |
|         # @return [String]
 | |
|         attr_accessor :destination_zone
 | |
|       
 | |
|         # The URL of the target instance to move. This can be a full or partial URL. For
 | |
|         # example, the following are all valid URLs to an instance:
 | |
|         # - https://www.googleapis.com/compute/v1/projects/project/zones/zone/instances/
 | |
|         # instance
 | |
|         # - projects/project/zones/zone/instances/instance
 | |
|         # - zones/zone/instances/instance
 | |
|         # Corresponds to the JSON property `targetInstance`
 | |
|         # @return [String]
 | |
|         attr_accessor :target_instance
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @destination_zone = args[:destination_zone] if args.key?(:destination_zone)
 | |
|           @target_instance = args[:target_instance] if args.key?(:target_instance)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceProperties
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # AllocationAffinity is the configuration of desired allocation which this
 | |
|         # instance could take capacity from.
 | |
|         # Corresponds to the JSON property `allocationAffinity`
 | |
|         # @return [Google::Apis::ComputeAlpha::AllocationAffinity]
 | |
|         attr_accessor :allocation_affinity
 | |
|       
 | |
|         # Enables instances created based on this template to send packets with source
 | |
|         # IP addresses other than their own and receive packets with destination IP
 | |
|         # addresses other than their own. If these instances will be used as an IP
 | |
|         # gateway or it will be set as the next-hop in a Route resource, specify true.
 | |
|         # If unsure, leave this set to false. See the Enable IP forwarding documentation
 | |
|         # for more information.
 | |
|         # Corresponds to the JSON property `canIpForward`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :can_ip_forward
 | |
|         alias_method :can_ip_forward?, :can_ip_forward
 | |
|       
 | |
|         # An optional text description for the instances that are created from this
 | |
|         # instance template.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # An array of disks that are associated with the instances that are created from
 | |
|         # this template.
 | |
|         # Corresponds to the JSON property `disks`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::AttachedDisk>]
 | |
|         attr_accessor :disks
 | |
|       
 | |
|         # A set of Display Device options
 | |
|         # Corresponds to the JSON property `displayDevice`
 | |
|         # @return [Google::Apis::ComputeAlpha::DisplayDevice]
 | |
|         attr_accessor :display_device
 | |
|       
 | |
|         # A list of guest accelerator cards' type and count to use for instances created
 | |
|         # from the instance template.
 | |
|         # Corresponds to the JSON property `guestAccelerators`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::AcceleratorConfig>]
 | |
|         attr_accessor :guest_accelerators
 | |
|       
 | |
|         # Labels to apply to instances that are created from this template.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         # The machine type to use for instances that are created from this template.
 | |
|         # Corresponds to the JSON property `machineType`
 | |
|         # @return [String]
 | |
|         attr_accessor :machine_type
 | |
|       
 | |
|         # A metadata key/value entry.
 | |
|         # Corresponds to the JSON property `metadata`
 | |
|         # @return [Google::Apis::ComputeAlpha::Metadata]
 | |
|         attr_accessor :metadata
 | |
|       
 | |
|         # Minimum cpu/platform to be used by this instance. The instance may be
 | |
|         # scheduled on the specified or newer cpu/platform. Applicable values are the
 | |
|         # friendly names of CPU platforms, such as minCpuPlatform: "Intel Haswell" or
 | |
|         # minCpuPlatform: "Intel Sandy Bridge". For more information, read Specifying a
 | |
|         # Minimum CPU Platform.
 | |
|         # Corresponds to the JSON property `minCpuPlatform`
 | |
|         # @return [String]
 | |
|         attr_accessor :min_cpu_platform
 | |
|       
 | |
|         # An array of network access configurations for this interface.
 | |
|         # Corresponds to the JSON property `networkInterfaces`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::NetworkInterface>]
 | |
|         attr_accessor :network_interfaces
 | |
|       
 | |
|         # Sets the scheduling options for an Instance.
 | |
|         # Corresponds to the JSON property `scheduling`
 | |
|         # @return [Google::Apis::ComputeAlpha::Scheduling]
 | |
|         attr_accessor :scheduling
 | |
|       
 | |
|         # A list of service accounts with specified scopes. Access tokens for these
 | |
|         # service accounts are available to the instances that are created from this
 | |
|         # template. Use metadata queries to obtain the access tokens for these instances.
 | |
|         # Corresponds to the JSON property `serviceAccounts`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::ServiceAccount>]
 | |
|         attr_accessor :service_accounts
 | |
|       
 | |
|         # A set of Shielded VM options.
 | |
|         # Corresponds to the JSON property `shieldedVmConfig`
 | |
|         # @return [Google::Apis::ComputeAlpha::ShieldedVmConfig]
 | |
|         attr_accessor :shielded_vm_config
 | |
|       
 | |
|         # A set of instance tags.
 | |
|         # Corresponds to the JSON property `tags`
 | |
|         # @return [Google::Apis::ComputeAlpha::Tags]
 | |
|         attr_accessor :tags
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @allocation_affinity = args[:allocation_affinity] if args.key?(:allocation_affinity)
 | |
|           @can_ip_forward = args[:can_ip_forward] if args.key?(:can_ip_forward)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @disks = args[:disks] if args.key?(:disks)
 | |
|           @display_device = args[:display_device] if args.key?(:display_device)
 | |
|           @guest_accelerators = args[:guest_accelerators] if args.key?(:guest_accelerators)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|           @machine_type = args[:machine_type] if args.key?(:machine_type)
 | |
|           @metadata = args[:metadata] if args.key?(:metadata)
 | |
|           @min_cpu_platform = args[:min_cpu_platform] if args.key?(:min_cpu_platform)
 | |
|           @network_interfaces = args[:network_interfaces] if args.key?(:network_interfaces)
 | |
|           @scheduling = args[:scheduling] if args.key?(:scheduling)
 | |
|           @service_accounts = args[:service_accounts] if args.key?(:service_accounts)
 | |
|           @shielded_vm_config = args[:shielded_vm_config] if args.key?(:shielded_vm_config)
 | |
|           @tags = args[:tags] if args.key?(:tags)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceReference
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The URL for a specific instance.
 | |
|         # Corresponds to the JSON property `instance`
 | |
|         # @return [String]
 | |
|         attr_accessor :instance
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instance = args[:instance] if args.key?(:instance)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # An Instance Template resource. (== resource_for beta.instanceTemplates ==) (==
 | |
|       # resource_for v1.instanceTemplates ==)
 | |
|       class InstanceTemplate
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The creation timestamp for this instance template in RFC3339
 | |
|         # text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] A unique identifier for this instance template. The server
 | |
|         # defines this identifier.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] The resource type, which is always compute#instanceTemplate for
 | |
|         # instance templates.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `properties`
 | |
|         # @return [Google::Apis::ComputeAlpha::InstanceProperties]
 | |
|         attr_accessor :properties
 | |
|       
 | |
|         # [Output Only] The URL for this instance template. The server defines this URL.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # The source instance used to create the template. You can provide this as a
 | |
|         # partial or full URL to the resource. For example, the following are valid
 | |
|         # values:
 | |
|         # - https://www.googleapis.com/compute/v1/projects/project/zones/zone/instances/
 | |
|         # instance
 | |
|         # - projects/project/zones/zone/instances/instance
 | |
|         # Corresponds to the JSON property `sourceInstance`
 | |
|         # @return [String]
 | |
|         attr_accessor :source_instance
 | |
|       
 | |
|         # A specification of the parameters to use when creating the instance template
 | |
|         # from a source instance.
 | |
|         # Corresponds to the JSON property `sourceInstanceParams`
 | |
|         # @return [Google::Apis::ComputeAlpha::SourceInstanceParams]
 | |
|         attr_accessor :source_instance_params
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @properties = args[:properties] if args.key?(:properties)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @source_instance = args[:source_instance] if args.key?(:source_instance)
 | |
|           @source_instance_params = args[:source_instance_params] if args.key?(:source_instance_params)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A list of instance templates.
 | |
|       class InstanceTemplateList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of InstanceTemplate resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InstanceTemplate>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] The resource type, which is always compute#
 | |
|         # instanceTemplatesListResponse for instance template lists.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::InstanceTemplateList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::InstanceTemplateList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstanceWithNamedPorts
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The URL of the instance.
 | |
|         # Corresponds to the JSON property `instance`
 | |
|         # @return [String]
 | |
|         attr_accessor :instance
 | |
|       
 | |
|         # [Output Only] The named ports that belong to this instance group.
 | |
|         # Corresponds to the JSON property `namedPorts`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::NamedPort>]
 | |
|         attr_accessor :named_ports
 | |
|       
 | |
|         # [Output Only] The status of the instance.
 | |
|         # Corresponds to the JSON property `status`
 | |
|         # @return [String]
 | |
|         attr_accessor :status
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instance = args[:instance] if args.key?(:instance)
 | |
|           @named_ports = args[:named_ports] if args.key?(:named_ports)
 | |
|           @status = args[:status] if args.key?(:status)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstancesAddResourcePoliciesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Resource policies to be added to this instance.
 | |
|         # Corresponds to the JSON property `resourcePolicies`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :resource_policies
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @resource_policies = args[:resource_policies] if args.key?(:resource_policies)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstancesRemoveResourcePoliciesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Resource policies to be removed from this instance.
 | |
|         # Corresponds to the JSON property `resourcePolicies`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :resource_policies
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @resource_policies = args[:resource_policies] if args.key?(:resource_policies)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstancesResumeRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Array of disks associated with this instance that are protected with a
 | |
|         # customer-supplied encryption key.
 | |
|         # In order to resume the instance, the disk url and its corresponding key must
 | |
|         # be provided.
 | |
|         # If the disk is not protected with a customer-supplied encryption key it should
 | |
|         # not be specified.
 | |
|         # Corresponds to the JSON property `disks`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::CustomerEncryptionKeyProtectedDisk>]
 | |
|         attr_accessor :disks
 | |
|       
 | |
|         # Represents a customer-supplied encryption key
 | |
|         # Corresponds to the JSON property `instanceEncryptionKey`
 | |
|         # @return [Google::Apis::ComputeAlpha::CustomerEncryptionKey]
 | |
|         attr_accessor :instance_encryption_key
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @disks = args[:disks] if args.key?(:disks)
 | |
|           @instance_encryption_key = args[:instance_encryption_key] if args.key?(:instance_encryption_key)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstancesScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] A list of instances contained in this scope.
 | |
|         # Corresponds to the JSON property `instances`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Instance>]
 | |
|         attr_accessor :instances
 | |
|       
 | |
|         # [Output Only] Informational warning which replaces the list of instances when
 | |
|         # the list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::InstancesScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instances = args[:instances] if args.key?(:instances)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning which replaces the list of instances when
 | |
|         # the list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::InstancesScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstancesSetLabelsRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Fingerprint of the previous set of labels for this resource, used to prevent
 | |
|         # conflicts. Provide the latest fingerprint value when making a request to add
 | |
|         # or change labels.
 | |
|         # Corresponds to the JSON property `labelFingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :label_fingerprint
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstancesSetMachineResourcesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of the type and count of accelerator cards attached to the instance.
 | |
|         # Corresponds to the JSON property `guestAccelerators`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::AcceleratorConfig>]
 | |
|         attr_accessor :guest_accelerators
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @guest_accelerators = args[:guest_accelerators] if args.key?(:guest_accelerators)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstancesSetMachineTypeRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Full or partial URL of the machine type resource. See Machine Types for a full
 | |
|         # list of machine types. For example: zones/us-central1-f/machineTypes/n1-
 | |
|         # standard-1
 | |
|         # Corresponds to the JSON property `machineType`
 | |
|         # @return [String]
 | |
|         attr_accessor :machine_type
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @machine_type = args[:machine_type] if args.key?(:machine_type)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstancesSetMinCpuPlatformRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Minimum cpu/platform this instance should be started at.
 | |
|         # Corresponds to the JSON property `minCpuPlatform`
 | |
|         # @return [String]
 | |
|         attr_accessor :min_cpu_platform
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @min_cpu_platform = args[:min_cpu_platform] if args.key?(:min_cpu_platform)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstancesSetServiceAccountRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Email address of the service account.
 | |
|         # Corresponds to the JSON property `email`
 | |
|         # @return [String]
 | |
|         attr_accessor :email
 | |
|       
 | |
|         # The list of scopes to be made available for this service account.
 | |
|         # Corresponds to the JSON property `scopes`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :scopes
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @email = args[:email] if args.key?(:email)
 | |
|           @scopes = args[:scopes] if args.key?(:scopes)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InstancesStartWithEncryptionKeyRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Array of disks associated with this instance that are protected with a
 | |
|         # customer-supplied encryption key.
 | |
|         # In order to start the instance, the disk url and its corresponding key must be
 | |
|         # provided.
 | |
|         # If the disk is not protected with a customer-supplied encryption key it should
 | |
|         # not be specified.
 | |
|         # Corresponds to the JSON property `disks`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::CustomerEncryptionKeyProtectedDisk>]
 | |
|         attr_accessor :disks
 | |
|       
 | |
|         # Represents a customer-supplied encryption key
 | |
|         # Corresponds to the JSON property `instanceEncryptionKey`
 | |
|         # @return [Google::Apis::ComputeAlpha::CustomerEncryptionKey]
 | |
|         attr_accessor :instance_encryption_key
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @disks = args[:disks] if args.key?(:disks)
 | |
|           @instance_encryption_key = args[:instance_encryption_key] if args.key?(:instance_encryption_key)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # HttpRouteRuleMatch criteria for field values that must stay within the
 | |
|       # specified integer range.
 | |
|       class Int64RangeMatch
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The end of the range (exclusive) in signed long integer format.
 | |
|         # Corresponds to the JSON property `rangeEnd`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :range_end
 | |
|       
 | |
|         # The start of the range (inclusive) in signed long integer format.
 | |
|         # Corresponds to the JSON property `rangeStart`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :range_start
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @range_end = args[:range_end] if args.key?(:range_end)
 | |
|           @range_start = args[:range_start] if args.key?(:range_start)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Represents an Interconnects resource. The Interconnects resource is a
 | |
|       # dedicated connection between Google's network and your on-premises network.
 | |
|       # For more information, see the  Dedicated overview page. (== resource_for v1.
 | |
|       # interconnects ==) (== resource_for beta.interconnects ==)
 | |
|       class Interconnect
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Administrative status of the interconnect. When this is set to true, the
 | |
|         # Interconnect is functional and can carry traffic. When set to false, no
 | |
|         # packets can be carried over the interconnect and no BGP routes are exchanged
 | |
|         # over it. By default, the status is set to true.
 | |
|         # Corresponds to the JSON property `adminEnabled`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :admin_enabled
 | |
|         alias_method :admin_enabled?, :admin_enabled
 | |
|       
 | |
|         # [Output Only] A list of CircuitInfo objects, that describe the individual
 | |
|         # circuits in this LAG.
 | |
|         # Corresponds to the JSON property `circuitInfos`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InterconnectCircuitInfo>]
 | |
|         attr_accessor :circuit_infos
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # Customer name, to put in the Letter of Authorization as the party authorized
 | |
|         # to request a crossconnect.
 | |
|         # Corresponds to the JSON property `customerName`
 | |
|         # @return [String]
 | |
|         attr_accessor :customer_name
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] A list of outages expected for this Interconnect.
 | |
|         # Corresponds to the JSON property `expectedOutages`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InterconnectOutageNotification>]
 | |
|         attr_accessor :expected_outages
 | |
|       
 | |
|         # [Output Only] IP address configured on the Google side of the Interconnect
 | |
|         # link. This can be used only for ping tests.
 | |
|         # Corresponds to the JSON property `googleIpAddress`
 | |
|         # @return [String]
 | |
|         attr_accessor :google_ip_address
 | |
|       
 | |
|         # [Output Only] Google reference ID; to be used when raising support tickets
 | |
|         # with Google or otherwise to debug backend connectivity issues.
 | |
|         # Corresponds to the JSON property `googleReferenceId`
 | |
|         # @return [String]
 | |
|         attr_accessor :google_reference_id
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] A list of the URLs of all InterconnectAttachments configured to
 | |
|         # use this Interconnect.
 | |
|         # Corresponds to the JSON property `interconnectAttachments`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :interconnect_attachments
 | |
|       
 | |
|         # Type of interconnect. Note that "IT_PRIVATE" has been deprecated in favor of "
 | |
|         # DEDICATED"
 | |
|         # Corresponds to the JSON property `interconnectType`
 | |
|         # @return [String]
 | |
|         attr_accessor :interconnect_type
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#interconnect for
 | |
|         # interconnects.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # A fingerprint for the labels being applied to this Interconnect, which is
 | |
|         # essentially a hash of the labels set used for optimistic locking. The
 | |
|         # fingerprint is initially generated by Compute Engine and changes after every
 | |
|         # request to modify or update labels. You must always provide an up-to-date
 | |
|         # fingerprint hash in order to update or change labels, otherwise the request
 | |
|         # will fail with error 412 conditionNotMet.
 | |
|         # To see the latest fingerprint, make a get() request to retrieve an
 | |
|         # Interconnect.
 | |
|         # Corresponds to the JSON property `labelFingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :label_fingerprint
 | |
|       
 | |
|         # Labels to apply to this Interconnect resource. These can be later modified by
 | |
|         # the setLabels method. Each label key/value must comply with RFC1035. Label
 | |
|         # values may be empty.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         # Type of link requested. This field indicates speed of each of the links in the
 | |
|         # bundle, not the entire bundle.
 | |
|         # Corresponds to the JSON property `linkType`
 | |
|         # @return [String]
 | |
|         attr_accessor :link_type
 | |
|       
 | |
|         # URL of the InterconnectLocation object that represents where this connection
 | |
|         # is to be provisioned.
 | |
|         # Corresponds to the JSON property `location`
 | |
|         # @return [String]
 | |
|         attr_accessor :location
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # Email address to contact the customer NOC for operations and maintenance
 | |
|         # notifications regarding this Interconnect. If specified, this will be used for
 | |
|         # notifications in addition to all other forms described, such as Stackdriver
 | |
|         # logs alerting and Cloud Notifications.
 | |
|         # Corresponds to the JSON property `nocContactEmail`
 | |
|         # @return [String]
 | |
|         attr_accessor :noc_contact_email
 | |
|       
 | |
|         # [Output Only] The current status of whether or not this Interconnect is
 | |
|         # functional.
 | |
|         # Corresponds to the JSON property `operationalStatus`
 | |
|         # @return [String]
 | |
|         attr_accessor :operational_status
 | |
|       
 | |
|         # [Output Only] IP address configured on the customer side of the Interconnect
 | |
|         # link. The customer should configure this IP address during turnup when
 | |
|         # prompted by Google NOC. This can be used only for ping tests.
 | |
|         # Corresponds to the JSON property `peerIpAddress`
 | |
|         # @return [String]
 | |
|         attr_accessor :peer_ip_address
 | |
|       
 | |
|         # [Output Only] Number of links actually provisioned in this interconnect.
 | |
|         # Corresponds to the JSON property `provisionedLinkCount`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :provisioned_link_count
 | |
|       
 | |
|         # Target number of physical links in the link bundle, as requested by the
 | |
|         # customer.
 | |
|         # Corresponds to the JSON property `requestedLinkCount`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :requested_link_count
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # [Output Only] The current state of whether or not this Interconnect is
 | |
|         # functional.
 | |
|         # Corresponds to the JSON property `state`
 | |
|         # @return [String]
 | |
|         attr_accessor :state
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @admin_enabled = args[:admin_enabled] if args.key?(:admin_enabled)
 | |
|           @circuit_infos = args[:circuit_infos] if args.key?(:circuit_infos)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @customer_name = args[:customer_name] if args.key?(:customer_name)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @expected_outages = args[:expected_outages] if args.key?(:expected_outages)
 | |
|           @google_ip_address = args[:google_ip_address] if args.key?(:google_ip_address)
 | |
|           @google_reference_id = args[:google_reference_id] if args.key?(:google_reference_id)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @interconnect_attachments = args[:interconnect_attachments] if args.key?(:interconnect_attachments)
 | |
|           @interconnect_type = args[:interconnect_type] if args.key?(:interconnect_type)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|           @link_type = args[:link_type] if args.key?(:link_type)
 | |
|           @location = args[:location] if args.key?(:location)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @noc_contact_email = args[:noc_contact_email] if args.key?(:noc_contact_email)
 | |
|           @operational_status = args[:operational_status] if args.key?(:operational_status)
 | |
|           @peer_ip_address = args[:peer_ip_address] if args.key?(:peer_ip_address)
 | |
|           @provisioned_link_count = args[:provisioned_link_count] if args.key?(:provisioned_link_count)
 | |
|           @requested_link_count = args[:requested_link_count] if args.key?(:requested_link_count)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @state = args[:state] if args.key?(:state)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Represents an InterconnectAttachment (VLAN attachment) resource. For more
 | |
|       # information, see  Creating VLAN Attachments. (== resource_for beta.
 | |
|       # interconnectAttachments ==) (== resource_for v1.interconnectAttachments ==)
 | |
|       class InterconnectAttachment
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Determines whether this Attachment will carry packets. Not present for
 | |
|         # PARTNER_PROVIDER.
 | |
|         # Corresponds to the JSON property `adminEnabled`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :admin_enabled
 | |
|         alias_method :admin_enabled?, :admin_enabled
 | |
|       
 | |
|         # Provisioned bandwidth capacity for the interconnectAttachment. Can be set by
 | |
|         # the partner to update the customer's provisioned bandwidth. Output only for
 | |
|         # PARTNER type, mutable for PARTNER_PROVIDER and DEDICATED.
 | |
|         # Corresponds to the JSON property `bandwidth`
 | |
|         # @return [String]
 | |
|         attr_accessor :bandwidth
 | |
|       
 | |
|         # Up to 16 candidate prefixes that can be used to restrict the allocation of
 | |
|         # cloudRouterIpAddress and customerRouterIpAddress for this attachment. All
 | |
|         # prefixes must be within link-local address space (169.254.0.0/16) and must be /
 | |
|         # 29 or shorter (/28, /27, etc). Google will attempt to select an unused /29
 | |
|         # from the supplied candidate prefix(es). The request will fail if all possible /
 | |
|         # 29s are in use on Google?s edge. If not supplied, Google will randomly select
 | |
|         # an unused /29 from all of link-local space.
 | |
|         # Corresponds to the JSON property `candidateSubnets`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :candidate_subnets
 | |
|       
 | |
|         # [Output Only] IPv4 address + prefix length to be configured on Cloud Router
 | |
|         # Interface for this interconnect attachment.
 | |
|         # Corresponds to the JSON property `cloudRouterIpAddress`
 | |
|         # @return [String]
 | |
|         attr_accessor :cloud_router_ip_address
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # [Output Only] IPv4 address + prefix length to be configured on the customer
 | |
|         # router subinterface for this interconnect attachment.
 | |
|         # Corresponds to the JSON property `customerRouterIpAddress`
 | |
|         # @return [String]
 | |
|         attr_accessor :customer_router_ip_address
 | |
|       
 | |
|         # An optional description of this resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # Desired availability domain for the attachment. Only available for type
 | |
|         # PARTNER, at creation time. For improved reliability, customers should
 | |
|         # configure a pair of attachments with one per availability domain. The selected
 | |
|         # availability domain will be provided to the Partner via the pairing key so
 | |
|         # that the provisioned circuit will lie in the specified domain. If not
 | |
|         # specified, the value will default to AVAILABILITY_DOMAIN_ANY.
 | |
|         # Corresponds to the JSON property `edgeAvailabilityDomain`
 | |
|         # @return [String]
 | |
|         attr_accessor :edge_availability_domain
 | |
|       
 | |
|         # [Output Only] Google reference ID, to be used when raising support tickets
 | |
|         # with Google or otherwise to debug backend connectivity issues.
 | |
|         # Corresponds to the JSON property `googleReferenceId`
 | |
|         # @return [String]
 | |
|         attr_accessor :google_reference_id
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # URL of the underlying Interconnect object that this attachment's traffic will
 | |
|         # traverse through.
 | |
|         # Corresponds to the JSON property `interconnect`
 | |
|         # @return [String]
 | |
|         attr_accessor :interconnect
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#interconnectAttachment for
 | |
|         # interconnect attachments.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # A fingerprint for the labels being applied to this InterconnectAttachment,
 | |
|         # which is essentially a hash of the labels set used for optimistic locking. The
 | |
|         # fingerprint is initially generated by Compute Engine and changes after every
 | |
|         # request to modify or update labels. You must always provide an up-to-date
 | |
|         # fingerprint hash in order to update or change labels, otherwise the request
 | |
|         # will fail with error 412 conditionNotMet.
 | |
|         # To see the latest fingerprint, make a get() request to retrieve an
 | |
|         # InterconnectAttachment.
 | |
|         # Corresponds to the JSON property `labelFingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :label_fingerprint
 | |
|       
 | |
|         # Labels to apply to this InterconnectAttachment resource. These can be later
 | |
|         # modified by the setLabels method. Each label key/value must comply with
 | |
|         # RFC1035. Label values may be empty.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # [Output Only] The current status of whether or not this interconnect
 | |
|         # attachment is functional.
 | |
|         # Corresponds to the JSON property `operationalStatus`
 | |
|         # @return [String]
 | |
|         attr_accessor :operational_status
 | |
|       
 | |
|         # [Output only for type PARTNER. Input only for PARTNER_PROVIDER. Not present
 | |
|         # for DEDICATED]. The opaque identifier of an PARTNER attachment used to
 | |
|         # initiate provisioning with a selected partner. Of the form "XXXXX/region/
 | |
|         # domain"
 | |
|         # Corresponds to the JSON property `pairingKey`
 | |
|         # @return [String]
 | |
|         attr_accessor :pairing_key
 | |
|       
 | |
|         # Optional BGP ASN for the router that should be supplied by a layer 3 Partner
 | |
|         # if they configured BGP on behalf of the customer. Output only for PARTNER type,
 | |
|         # input only for PARTNER_PROVIDER, not available for DEDICATED.
 | |
|         # Corresponds to the JSON property `partnerAsn`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :partner_asn
 | |
|       
 | |
|         # Informational metadata about Partner attachments from Partners to display to
 | |
|         # customers. These fields are propagated from PARTNER_PROVIDER attachments to
 | |
|         # their corresponding PARTNER attachments.
 | |
|         # Corresponds to the JSON property `partnerMetadata`
 | |
|         # @return [Google::Apis::ComputeAlpha::InterconnectAttachmentPartnerMetadata]
 | |
|         attr_accessor :partner_metadata
 | |
|       
 | |
|         # Information for an interconnect attachment when this belongs to an
 | |
|         # interconnect of type DEDICATED.
 | |
|         # Corresponds to the JSON property `privateInterconnectInfo`
 | |
|         # @return [Google::Apis::ComputeAlpha::InterconnectAttachmentPrivateInfo]
 | |
|         attr_accessor :private_interconnect_info
 | |
|       
 | |
|         # [Output Only] URL of the region where the regional interconnect attachment
 | |
|         # resides. You must specify this field as part of the HTTP request URL. It is
 | |
|         # not settable as a field in the request body.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # URL of the Cloud Router to be used for dynamic routing. This router must be in
 | |
|         # the same region as this InterconnectAttachment. The InterconnectAttachment
 | |
|         # will automatically connect the Interconnect to the network & region within
 | |
|         # which the Cloud Router is configured.
 | |
|         # Corresponds to the JSON property `router`
 | |
|         # @return [String]
 | |
|         attr_accessor :router
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # [Output Only] The current state of this attachment's functionality.
 | |
|         # Corresponds to the JSON property `state`
 | |
|         # @return [String]
 | |
|         attr_accessor :state
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `type`
 | |
|         # @return [String]
 | |
|         attr_accessor :type
 | |
|       
 | |
|         # The IEEE 802.1Q VLAN tag for this attachment, in the range 2-4094. Only
 | |
|         # specified at creation time.
 | |
|         # Corresponds to the JSON property `vlanTag8021q`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :vlan_tag8021q
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @admin_enabled = args[:admin_enabled] if args.key?(:admin_enabled)
 | |
|           @bandwidth = args[:bandwidth] if args.key?(:bandwidth)
 | |
|           @candidate_subnets = args[:candidate_subnets] if args.key?(:candidate_subnets)
 | |
|           @cloud_router_ip_address = args[:cloud_router_ip_address] if args.key?(:cloud_router_ip_address)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @customer_router_ip_address = args[:customer_router_ip_address] if args.key?(:customer_router_ip_address)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @edge_availability_domain = args[:edge_availability_domain] if args.key?(:edge_availability_domain)
 | |
|           @google_reference_id = args[:google_reference_id] if args.key?(:google_reference_id)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @interconnect = args[:interconnect] if args.key?(:interconnect)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @operational_status = args[:operational_status] if args.key?(:operational_status)
 | |
|           @pairing_key = args[:pairing_key] if args.key?(:pairing_key)
 | |
|           @partner_asn = args[:partner_asn] if args.key?(:partner_asn)
 | |
|           @partner_metadata = args[:partner_metadata] if args.key?(:partner_metadata)
 | |
|           @private_interconnect_info = args[:private_interconnect_info] if args.key?(:private_interconnect_info)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @router = args[:router] if args.key?(:router)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @state = args[:state] if args.key?(:state)
 | |
|           @type = args[:type] if args.key?(:type)
 | |
|           @vlan_tag8021q = args[:vlan_tag8021q] if args.key?(:vlan_tag8021q)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InterconnectAttachmentAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of InterconnectAttachmentsScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::InterconnectAttachmentsScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#
 | |
|         # interconnectAttachmentAggregatedList for aggregated lists of interconnect
 | |
|         # attachments.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::InterconnectAttachmentAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::InterconnectAttachmentAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Response to the list request, and contains a list of interconnect attachments.
 | |
|       class InterconnectAttachmentList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of InterconnectAttachment resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InterconnectAttachment>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#interconnectAttachmentList for
 | |
|         # lists of interconnect attachments.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::InterconnectAttachmentList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::InterconnectAttachmentList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Informational metadata about Partner attachments from Partners to display to
 | |
|       # customers. These fields are propagated from PARTNER_PROVIDER attachments to
 | |
|       # their corresponding PARTNER attachments.
 | |
|       class InterconnectAttachmentPartnerMetadata
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Plain text name of the Interconnect this attachment is connected to, as
 | |
|         # displayed in the Partner?s portal. For instance "Chicago 1". This value may be
 | |
|         # validated to match approved Partner values.
 | |
|         # Corresponds to the JSON property `interconnectName`
 | |
|         # @return [String]
 | |
|         attr_accessor :interconnect_name
 | |
|       
 | |
|         # Plain text name of the Partner providing this attachment. This value may be
 | |
|         # validated to match approved Partner values.
 | |
|         # Corresponds to the JSON property `partnerName`
 | |
|         # @return [String]
 | |
|         attr_accessor :partner_name
 | |
|       
 | |
|         # URL of the Partner?s portal for this Attachment. Partners may customise this
 | |
|         # to be a deep-link to the specific resource on the Partner portal. This value
 | |
|         # may be validated to match approved Partner values.
 | |
|         # Corresponds to the JSON property `portalUrl`
 | |
|         # @return [String]
 | |
|         attr_accessor :portal_url
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @interconnect_name = args[:interconnect_name] if args.key?(:interconnect_name)
 | |
|           @partner_name = args[:partner_name] if args.key?(:partner_name)
 | |
|           @portal_url = args[:portal_url] if args.key?(:portal_url)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Information for an interconnect attachment when this belongs to an
 | |
|       # interconnect of type DEDICATED.
 | |
|       class InterconnectAttachmentPrivateInfo
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] 802.1q encapsulation tag to be used for traffic between Google
 | |
|         # and the customer, going to and from this network and region.
 | |
|         # Corresponds to the JSON property `tag8021q`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :tag8021q
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @tag8021q = args[:tag8021q] if args.key?(:tag8021q)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InterconnectAttachmentsScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of interconnect attachments contained in this scope.
 | |
|         # Corresponds to the JSON property `interconnectAttachments`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InterconnectAttachment>]
 | |
|         attr_accessor :interconnect_attachments
 | |
|       
 | |
|         # Informational warning which replaces the list of addresses when the list is
 | |
|         # empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::InterconnectAttachmentsScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @interconnect_attachments = args[:interconnect_attachments] if args.key?(:interconnect_attachments)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # Informational warning which replaces the list of addresses when the list is
 | |
|         # empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::InterconnectAttachmentsScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Describes a single physical circuit between the Customer and Google.
 | |
|       # CircuitInfo objects are created by Google, so all fields are output only. Next
 | |
|       # id: 4
 | |
|       class InterconnectCircuitInfo
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Customer-side demarc ID for this circuit.
 | |
|         # Corresponds to the JSON property `customerDemarcId`
 | |
|         # @return [String]
 | |
|         attr_accessor :customer_demarc_id
 | |
|       
 | |
|         # Google-assigned unique ID for this circuit. Assigned at circuit turn-up.
 | |
|         # Corresponds to the JSON property `googleCircuitId`
 | |
|         # @return [String]
 | |
|         attr_accessor :google_circuit_id
 | |
|       
 | |
|         # Google-side demarc ID for this circuit. Assigned at circuit turn-up and
 | |
|         # provided by Google to the customer in the LOA.
 | |
|         # Corresponds to the JSON property `googleDemarcId`
 | |
|         # @return [String]
 | |
|         attr_accessor :google_demarc_id
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @customer_demarc_id = args[:customer_demarc_id] if args.key?(:customer_demarc_id)
 | |
|           @google_circuit_id = args[:google_circuit_id] if args.key?(:google_circuit_id)
 | |
|           @google_demarc_id = args[:google_demarc_id] if args.key?(:google_demarc_id)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Diagnostics information about interconnect, contains detailed and current
 | |
|       # technical information about Google?s side of the connection.
 | |
|       class InterconnectDiagnostics
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of InterconnectDiagnostics.ARPEntry objects, describing individual
 | |
|         # neighbors currently seen by the Google router in the ARP cache for the
 | |
|         # Interconnect. This will be empty when the Interconnect is not bundled.
 | |
|         # Corresponds to the JSON property `arpCaches`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InterconnectDiagnosticsArpEntry>]
 | |
|         attr_accessor :arp_caches
 | |
|       
 | |
|         # A list of InterconnectDiagnostics.LinkStatus objects, describing the status
 | |
|         # for each link on the Interconnect.
 | |
|         # Corresponds to the JSON property `links`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InterconnectDiagnosticsLinkStatus>]
 | |
|         attr_accessor :links
 | |
|       
 | |
|         # The MAC address of the Interconnect's bundle interface.
 | |
|         # Corresponds to the JSON property `macAddress`
 | |
|         # @return [String]
 | |
|         attr_accessor :mac_address
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @arp_caches = args[:arp_caches] if args.key?(:arp_caches)
 | |
|           @links = args[:links] if args.key?(:links)
 | |
|           @mac_address = args[:mac_address] if args.key?(:mac_address)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Describing the ARP neighbor entries seen on this link
 | |
|       class InterconnectDiagnosticsArpEntry
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The IP address of this ARP neighbor.
 | |
|         # Corresponds to the JSON property `ipAddress`
 | |
|         # @return [String]
 | |
|         attr_accessor :ip_address
 | |
|       
 | |
|         # The MAC address of this ARP neighbor.
 | |
|         # Corresponds to the JSON property `macAddress`
 | |
|         # @return [String]
 | |
|         attr_accessor :mac_address
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @ip_address = args[:ip_address] if args.key?(:ip_address)
 | |
|           @mac_address = args[:mac_address] if args.key?(:mac_address)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InterconnectDiagnosticsLinkLacpStatus
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # System ID of the port on Google?s side of the LACP exchange.
 | |
|         # Corresponds to the JSON property `googleSystemId`
 | |
|         # @return [String]
 | |
|         attr_accessor :google_system_id
 | |
|       
 | |
|         # System ID of the port on the neighbor?s side of the LACP exchange.
 | |
|         # Corresponds to the JSON property `neighborSystemId`
 | |
|         # @return [String]
 | |
|         attr_accessor :neighbor_system_id
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `state`
 | |
|         # @return [String]
 | |
|         attr_accessor :state
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @google_system_id = args[:google_system_id] if args.key?(:google_system_id)
 | |
|           @neighbor_system_id = args[:neighbor_system_id] if args.key?(:neighbor_system_id)
 | |
|           @state = args[:state] if args.key?(:state)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InterconnectDiagnosticsLinkOpticalPower
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `state`
 | |
|         # @return [String]
 | |
|         attr_accessor :state
 | |
|       
 | |
|         # Value of the current optical power, read in dBm. Take a known good optical
 | |
|         # value, give it a 10% margin and trigger warnings relative to that value. In
 | |
|         # general, a -7dBm warning and a -11dBm alarm are good optical value estimates
 | |
|         # for most links.
 | |
|         # Corresponds to the JSON property `value`
 | |
|         # @return [Float]
 | |
|         attr_accessor :value
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @state = args[:state] if args.key?(:state)
 | |
|           @value = args[:value] if args.key?(:value)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InterconnectDiagnosticsLinkStatus
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of InterconnectDiagnostics.ARPEntry objects, describing the ARP
 | |
|         # neighbor entries seen on this link. This will be empty if the link is bundled
 | |
|         # Corresponds to the JSON property `arpCaches`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InterconnectDiagnosticsArpEntry>]
 | |
|         attr_accessor :arp_caches
 | |
|       
 | |
|         # The unique ID for this link assigned during turn up by Google.
 | |
|         # Corresponds to the JSON property `circuitId`
 | |
|         # @return [String]
 | |
|         attr_accessor :circuit_id
 | |
|       
 | |
|         # The Demarc address assigned by Google and provided in the LoA.
 | |
|         # Corresponds to the JSON property `googleDemarc`
 | |
|         # @return [String]
 | |
|         attr_accessor :google_demarc
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `lacpStatus`
 | |
|         # @return [Google::Apis::ComputeAlpha::InterconnectDiagnosticsLinkLacpStatus]
 | |
|         attr_accessor :lacp_status
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `receivingOpticalPower`
 | |
|         # @return [Google::Apis::ComputeAlpha::InterconnectDiagnosticsLinkOpticalPower]
 | |
|         attr_accessor :receiving_optical_power
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `transmittingOpticalPower`
 | |
|         # @return [Google::Apis::ComputeAlpha::InterconnectDiagnosticsLinkOpticalPower]
 | |
|         attr_accessor :transmitting_optical_power
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @arp_caches = args[:arp_caches] if args.key?(:arp_caches)
 | |
|           @circuit_id = args[:circuit_id] if args.key?(:circuit_id)
 | |
|           @google_demarc = args[:google_demarc] if args.key?(:google_demarc)
 | |
|           @lacp_status = args[:lacp_status] if args.key?(:lacp_status)
 | |
|           @receiving_optical_power = args[:receiving_optical_power] if args.key?(:receiving_optical_power)
 | |
|           @transmitting_optical_power = args[:transmitting_optical_power] if args.key?(:transmitting_optical_power)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Response to the list request, and contains a list of interconnects.
 | |
|       class InterconnectList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of Interconnect resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Interconnect>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#interconnectList for lists of
 | |
|         # interconnects.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::InterconnectList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::InterconnectList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Represents an InterconnectLocations resource. The InterconnectLocations
 | |
|       # resource describes the locations where you can connect to Google's networks.
 | |
|       # For more information, see  Colocation Facilities.
 | |
|       class InterconnectLocation
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The postal address of the Point of Presence, each line in the
 | |
|         # address is separated by a newline character.
 | |
|         # Corresponds to the JSON property `address`
 | |
|         # @return [String]
 | |
|         attr_accessor :address
 | |
|       
 | |
|         # [Output Only] Availability zone for this InterconnectLocation. Within a
 | |
|         # metropolitan area (metro), maintenance will not be simultaneously scheduled in
 | |
|         # more than one availability zone. Example: "zone1" or "zone2".
 | |
|         # Corresponds to the JSON property `availabilityZone`
 | |
|         # @return [String]
 | |
|         attr_accessor :availability_zone
 | |
|       
 | |
|         # [Output Only] Metropolitan area designator that indicates which city an
 | |
|         # interconnect is located. For example: "Chicago, IL", "Amsterdam, Netherlands".
 | |
|         # Corresponds to the JSON property `city`
 | |
|         # @return [String]
 | |
|         attr_accessor :city
 | |
|       
 | |
|         # [Output Only] Continent for this location.
 | |
|         # Corresponds to the JSON property `continent`
 | |
|         # @return [String]
 | |
|         attr_accessor :continent
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # [Output Only] An optional description of the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The name of the provider for this facility (e.g., EQUINIX).
 | |
|         # Corresponds to the JSON property `facilityProvider`
 | |
|         # @return [String]
 | |
|         attr_accessor :facility_provider
 | |
|       
 | |
|         # [Output Only] A provider-assigned Identifier for this facility (e.g., Ashburn-
 | |
|         # DC1).
 | |
|         # Corresponds to the JSON property `facilityProviderFacilityId`
 | |
|         # @return [String]
 | |
|         attr_accessor :facility_provider_facility_id
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#interconnectLocation for
 | |
|         # interconnect locations.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] Name of the resource.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # [Output Only] The peeringdb identifier for this facility (corresponding with a
 | |
|         # netfac type in peeringdb).
 | |
|         # Corresponds to the JSON property `peeringdbFacilityId`
 | |
|         # @return [String]
 | |
|         attr_accessor :peeringdb_facility_id
 | |
|       
 | |
|         # [Output Only] A list of InterconnectLocation.RegionInfo objects, that describe
 | |
|         # parameters pertaining to the relation between this InterconnectLocation and
 | |
|         # various Google Cloud regions.
 | |
|         # Corresponds to the JSON property `regionInfos`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InterconnectLocationRegionInfo>]
 | |
|         attr_accessor :region_infos
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # [Output Only] The status of this InterconnectLocation. If the status is
 | |
|         # AVAILABLE, new Interconnects may be provisioned in this InterconnectLocation.
 | |
|         # Otherwise, no new Interconnects may be provisioned.
 | |
|         # Corresponds to the JSON property `status`
 | |
|         # @return [String]
 | |
|         attr_accessor :status
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @address = args[:address] if args.key?(:address)
 | |
|           @availability_zone = args[:availability_zone] if args.key?(:availability_zone)
 | |
|           @city = args[:city] if args.key?(:city)
 | |
|           @continent = args[:continent] if args.key?(:continent)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @facility_provider = args[:facility_provider] if args.key?(:facility_provider)
 | |
|           @facility_provider_facility_id = args[:facility_provider_facility_id] if args.key?(:facility_provider_facility_id)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @peeringdb_facility_id = args[:peeringdb_facility_id] if args.key?(:peeringdb_facility_id)
 | |
|           @region_infos = args[:region_infos] if args.key?(:region_infos)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @status = args[:status] if args.key?(:status)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Response to the list request, and contains a list of interconnect locations.
 | |
|       class InterconnectLocationList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of InterconnectLocation resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InterconnectLocation>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#interconnectLocationList for
 | |
|         # lists of interconnect locations.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::InterconnectLocationList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::InterconnectLocationList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Information about any potential InterconnectAttachments between an
 | |
|       # Interconnect at a specific InterconnectLocation, and a specific Cloud Region.
 | |
|       class InterconnectLocationRegionInfo
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Expected round-trip time in milliseconds, from this InterconnectLocation to a
 | |
|         # VM in this region.
 | |
|         # Corresponds to the JSON property `expectedRttMs`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :expected_rtt_ms
 | |
|       
 | |
|         # Identifies the network presence of this location.
 | |
|         # Corresponds to the JSON property `locationPresence`
 | |
|         # @return [String]
 | |
|         attr_accessor :location_presence
 | |
|       
 | |
|         # URL for the region of this location.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @expected_rtt_ms = args[:expected_rtt_ms] if args.key?(:expected_rtt_ms)
 | |
|           @location_presence = args[:location_presence] if args.key?(:location_presence)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Description of a planned outage on this Interconnect. Next id: 9
 | |
|       class InterconnectOutageNotification
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # If issue_type is IT_PARTIAL_OUTAGE, a list of the Google-side circuit IDs that
 | |
|         # will be affected.
 | |
|         # Corresponds to the JSON property `affectedCircuits`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :affected_circuits
 | |
|       
 | |
|         # A description about the purpose of the outage.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # Scheduled end time for the outage (milliseconds since Unix epoch).
 | |
|         # Corresponds to the JSON property `endTime`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :end_time
 | |
|       
 | |
|         # Form this outage is expected to take. Note that the "IT_" versions of this
 | |
|         # enum have been deprecated in favor of the unprefixed values.
 | |
|         # Corresponds to the JSON property `issueType`
 | |
|         # @return [String]
 | |
|         attr_accessor :issue_type
 | |
|       
 | |
|         # Unique identifier for this outage notification.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # The party that generated this notification. Note that "NSRC_GOOGLE" has been
 | |
|         # deprecated in favor of "GOOGLE"
 | |
|         # Corresponds to the JSON property `source`
 | |
|         # @return [String]
 | |
|         attr_accessor :source
 | |
|       
 | |
|         # Scheduled start time for the outage (milliseconds since Unix epoch).
 | |
|         # Corresponds to the JSON property `startTime`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :start_time
 | |
|       
 | |
|         # State of this notification. Note that the "NS_" versions of this enum have
 | |
|         # been deprecated in favor of the unprefixed values.
 | |
|         # Corresponds to the JSON property `state`
 | |
|         # @return [String]
 | |
|         attr_accessor :state
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @affected_circuits = args[:affected_circuits] if args.key?(:affected_circuits)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @end_time = args[:end_time] if args.key?(:end_time)
 | |
|           @issue_type = args[:issue_type] if args.key?(:issue_type)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @source = args[:source] if args.key?(:source)
 | |
|           @start_time = args[:start_time] if args.key?(:start_time)
 | |
|           @state = args[:state] if args.key?(:state)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Response for the InterconnectsGetDiagnosticsRequest.
 | |
|       class InterconnectsGetDiagnosticsResponse
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Diagnostics information about interconnect, contains detailed and current
 | |
|         # technical information about Google?s side of the connection.
 | |
|         # Corresponds to the JSON property `result`
 | |
|         # @return [Google::Apis::ComputeAlpha::InterconnectDiagnostics]
 | |
|         attr_accessor :result
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @result = args[:result] if args.key?(:result)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InternalIpAddress
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # IP CIDR address or range.
 | |
|         # Corresponds to the JSON property `cidr`
 | |
|         # @return [String]
 | |
|         attr_accessor :cidr
 | |
|       
 | |
|         # The owner of the internal IP address.
 | |
|         # Corresponds to the JSON property `owner`
 | |
|         # @return [String]
 | |
|         attr_accessor :owner
 | |
|       
 | |
|         # The purpose of the internal IP address if applicable.
 | |
|         # Corresponds to the JSON property `purpose`
 | |
|         # @return [String]
 | |
|         attr_accessor :purpose
 | |
|       
 | |
|         # The region of the internal IP address if applicable.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # The type of the internal IP address.
 | |
|         # Corresponds to the JSON property `type`
 | |
|         # @return [String]
 | |
|         attr_accessor :type
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @cidr = args[:cidr] if args.key?(:cidr)
 | |
|           @owner = args[:owner] if args.key?(:owner)
 | |
|           @purpose = args[:purpose] if args.key?(:purpose)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @type = args[:type] if args.key?(:type)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class InternalIpOwner
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # IP CIDR range being owned.
 | |
|         # Corresponds to the JSON property `ipCidrRange`
 | |
|         # @return [String]
 | |
|         attr_accessor :ip_cidr_range
 | |
|       
 | |
|         # URLs of the IP owners of the IP CIDR range.
 | |
|         # Corresponds to the JSON property `owners`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :owners
 | |
|       
 | |
|         # Whether this IP CIDR range is reserved for system use.
 | |
|         # Corresponds to the JSON property `systemOwned`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :system_owned
 | |
|         alias_method :system_owned?, :system_owned
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @ip_cidr_range = args[:ip_cidr_range] if args.key?(:ip_cidr_range)
 | |
|           @owners = args[:owners] if args.key?(:owners)
 | |
|           @system_owned = args[:system_owned] if args.key?(:system_owned)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class IpAddressesList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of InternalIpAddress resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InternalIpAddress>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#ipAddressesList for IP
 | |
|         # addresses lists.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::IpAddressesList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::IpAddressesList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of IP owners.
 | |
|       class IpOwnerList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of InternalIpOwner resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InternalIpOwner>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#ipOwnerList for lists of IP
 | |
|         # owners.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::IpOwnerList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::IpOwnerList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A license resource.
 | |
|       class License
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Deprecated. This field no longer reflects whether a license
 | |
|         # charges a usage fee.
 | |
|         # Corresponds to the JSON property `chargesUseFee`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :charges_use_fee
 | |
|         alias_method :charges_use_fee?, :charges_use_fee
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional textual description of the resource; provided by the client when
 | |
|         # the resource is created.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#license for licenses.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] The unique code used to attach this license to images, snapshots,
 | |
|         # and disks.
 | |
|         # Corresponds to the JSON property `licenseCode`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :license_code
 | |
|       
 | |
|         # Name of the resource. The name must be 1-63 characters long and comply with
 | |
|         # RFC1035.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `resourceRequirements`
 | |
|         # @return [Google::Apis::ComputeAlpha::LicenseResourceRequirements]
 | |
|         attr_accessor :resource_requirements
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # If false, licenses will not be copied from the source resource when creating
 | |
|         # an image from a disk, disk from snapshot, or snapshot from disk.
 | |
|         # Corresponds to the JSON property `transferable`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :transferable
 | |
|         alias_method :transferable?, :transferable
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @charges_use_fee = args[:charges_use_fee] if args.key?(:charges_use_fee)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @license_code = args[:license_code] if args.key?(:license_code)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @resource_requirements = args[:resource_requirements] if args.key?(:resource_requirements)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @transferable = args[:transferable] if args.key?(:transferable)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class LicenseCode
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # [Output Only] Description of this License Code.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#licenseCode for licenses.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] URL and description aliases of Licenses with the same License
 | |
|         # Code.
 | |
|         # Corresponds to the JSON property `licenseAlias`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::LicenseCodeLicenseAlias>]
 | |
|         attr_accessor :license_alias
 | |
|       
 | |
|         # [Output Only] Name of the resource. The name is 1-20 characters long and must
 | |
|         # be a valid 64 bit integer.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Current state of this License Code.
 | |
|         # Corresponds to the JSON property `state`
 | |
|         # @return [String]
 | |
|         attr_accessor :state
 | |
|       
 | |
|         # [Output Only] If true, the license will remain attached when creating images
 | |
|         # or snapshots from disks. Otherwise, the license is not transferred.
 | |
|         # Corresponds to the JSON property `transferable`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :transferable
 | |
|         alias_method :transferable?, :transferable
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @license_alias = args[:license_alias] if args.key?(:license_alias)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @state = args[:state] if args.key?(:state)
 | |
|           @transferable = args[:transferable] if args.key?(:transferable)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class LicenseCodeLicenseAlias
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Description of this License Code.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] URL of license corresponding to this License Code.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class LicenseResourceRequirements
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Minimum number of guest cpus required to use the Instance. Enforced at
 | |
|         # Instance creation and Instance start.
 | |
|         # Corresponds to the JSON property `minGuestCpuCount`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :min_guest_cpu_count
 | |
|       
 | |
|         # Minimum memory required to use the Instance. Enforced at Instance creation and
 | |
|         # Instance start.
 | |
|         # Corresponds to the JSON property `minMemoryMb`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :min_memory_mb
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @min_guest_cpu_count = args[:min_guest_cpu_count] if args.key?(:min_guest_cpu_count)
 | |
|           @min_memory_mb = args[:min_memory_mb] if args.key?(:min_memory_mb)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class LicensesListResponse
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of License resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::License>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::LicensesListResponse::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::LicensesListResponse::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Specifies what kind of log the caller must write
 | |
|       class LogConfig
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Write a Cloud Audit log
 | |
|         # Corresponds to the JSON property `cloudAudit`
 | |
|         # @return [Google::Apis::ComputeAlpha::LogConfigCloudAuditOptions]
 | |
|         attr_accessor :cloud_audit
 | |
|       
 | |
|         # Increment a streamz counter with the specified metric and field names.
 | |
|         # Metric names should start with a '/', generally be lowercase-only, and end in "
 | |
|         # _count". Field names should not contain an initial slash. The actual exported
 | |
|         # metric names will have "/iam/policy" prepended.
 | |
|         # Field names correspond to IAM request parameters and field values are their
 | |
|         # respective values.
 | |
|         # Supported field names: - "authority", which is "[token]" if IAMContext.token
 | |
|         # is present, otherwise the value of IAMContext.authority_selector if present,
 | |
|         # and otherwise a representation of IAMContext.principal; or - "iam_principal",
 | |
|         # a representation of IAMContext.principal even if a token or authority selector
 | |
|         # is present; or - "" (empty string), resulting in a counter with no fields.
 | |
|         # Examples: counter ` metric: "/debug_access_count" field: "iam_principal" ` ==>
 | |
|         # increment counter /iam/policy/backend_debug_access_count `iam_principal=[value
 | |
|         # of IAMContext.principal]`
 | |
|         # At this time we do not support multiple field names (though this may be
 | |
|         # supported in the future).
 | |
|         # Corresponds to the JSON property `counter`
 | |
|         # @return [Google::Apis::ComputeAlpha::LogConfigCounterOptions]
 | |
|         attr_accessor :counter
 | |
|       
 | |
|         # Write a Data Access (Gin) log
 | |
|         # Corresponds to the JSON property `dataAccess`
 | |
|         # @return [Google::Apis::ComputeAlpha::LogConfigDataAccessOptions]
 | |
|         attr_accessor :data_access
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @cloud_audit = args[:cloud_audit] if args.key?(:cloud_audit)
 | |
|           @counter = args[:counter] if args.key?(:counter)
 | |
|           @data_access = args[:data_access] if args.key?(:data_access)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Write a Cloud Audit log
 | |
|       class LogConfigCloudAuditOptions
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Authorization-related information used by Cloud Audit Logging.
 | |
|         # Corresponds to the JSON property `authorizationLoggingOptions`
 | |
|         # @return [Google::Apis::ComputeAlpha::AuthorizationLoggingOptions]
 | |
|         attr_accessor :authorization_logging_options
 | |
|       
 | |
|         # The log_name to populate in the Cloud Audit Record.
 | |
|         # Corresponds to the JSON property `logName`
 | |
|         # @return [String]
 | |
|         attr_accessor :log_name
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @authorization_logging_options = args[:authorization_logging_options] if args.key?(:authorization_logging_options)
 | |
|           @log_name = args[:log_name] if args.key?(:log_name)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Increment a streamz counter with the specified metric and field names.
 | |
|       # Metric names should start with a '/', generally be lowercase-only, and end in "
 | |
|       # _count". Field names should not contain an initial slash. The actual exported
 | |
|       # metric names will have "/iam/policy" prepended.
 | |
|       # Field names correspond to IAM request parameters and field values are their
 | |
|       # respective values.
 | |
|       # Supported field names: - "authority", which is "[token]" if IAMContext.token
 | |
|       # is present, otherwise the value of IAMContext.authority_selector if present,
 | |
|       # and otherwise a representation of IAMContext.principal; or - "iam_principal",
 | |
|       # a representation of IAMContext.principal even if a token or authority selector
 | |
|       # is present; or - "" (empty string), resulting in a counter with no fields.
 | |
|       # Examples: counter ` metric: "/debug_access_count" field: "iam_principal" ` ==>
 | |
|       # increment counter /iam/policy/backend_debug_access_count `iam_principal=[value
 | |
|       # of IAMContext.principal]`
 | |
|       # At this time we do not support multiple field names (though this may be
 | |
|       # supported in the future).
 | |
|       class LogConfigCounterOptions
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The field value to attribute.
 | |
|         # Corresponds to the JSON property `field`
 | |
|         # @return [String]
 | |
|         attr_accessor :field
 | |
|       
 | |
|         # The metric to update.
 | |
|         # Corresponds to the JSON property `metric`
 | |
|         # @return [String]
 | |
|         attr_accessor :metric
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @field = args[:field] if args.key?(:field)
 | |
|           @metric = args[:metric] if args.key?(:metric)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Write a Data Access (Gin) log
 | |
|       class LogConfigDataAccessOptions
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Whether Gin logging should happen in a fail-closed manner at the caller. This
 | |
|         # is relevant only in the LocalIAM implementation, for now.
 | |
|         # NOTE: Logging to Gin in a fail-closed manner is currently unsupported while
 | |
|         # work is being done to satisfy the requirements of go/345. Currently, setting
 | |
|         # LOG_FAIL_CLOSED mode will have no effect, but still exists because there is
 | |
|         # active work being done to support it (b/115874152).
 | |
|         # Corresponds to the JSON property `logMode`
 | |
|         # @return [String]
 | |
|         attr_accessor :log_mode
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @log_mode = args[:log_mode] if args.key?(:log_mode)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Machine image resource.
 | |
|       class MachineImage
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The creation timestamp for this machine image in RFC3339 text
 | |
|         # format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] A unique identifier for this machine image. The server defines
 | |
|         # this identifier.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] The resource type, which is always compute#machineImage for
 | |
|         # machine image.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # Represents a customer-supplied encryption key
 | |
|         # Corresponds to the JSON property `machineImageEncryptionKey`
 | |
|         # @return [Google::Apis::ComputeAlpha::CustomerEncryptionKey]
 | |
|         attr_accessor :machine_image_encryption_key
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # [Output Only] The URL for this machine image. The server defines this URL.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # The source instance used to create the machine image. You can provide this as
 | |
|         # a partial or full URL to the resource. For example, the following are valid
 | |
|         # values:
 | |
|         # - https://www.googleapis.com/compute/v1/projects/project/zones/zone/instances/
 | |
|         # instance
 | |
|         # - projects/project/zones/zone/instances/instance
 | |
|         # Corresponds to the JSON property `sourceInstance`
 | |
|         # @return [String]
 | |
|         attr_accessor :source_instance
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `sourceInstanceProperties`
 | |
|         # @return [Google::Apis::ComputeAlpha::SourceInstanceProperties]
 | |
|         attr_accessor :source_instance_properties
 | |
|       
 | |
|         # [Output Only] The status of disk creation.
 | |
|         # Corresponds to the JSON property `status`
 | |
|         # @return [String]
 | |
|         attr_accessor :status
 | |
|       
 | |
|         # GCS bucket storage location of the snapshot (regional or multi-regional).
 | |
|         # Corresponds to the JSON property `storageLocations`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :storage_locations
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @machine_image_encryption_key = args[:machine_image_encryption_key] if args.key?(:machine_image_encryption_key)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @source_instance = args[:source_instance] if args.key?(:source_instance)
 | |
|           @source_instance_properties = args[:source_instance_properties] if args.key?(:source_instance_properties)
 | |
|           @status = args[:status] if args.key?(:status)
 | |
|           @storage_locations = args[:storage_locations] if args.key?(:storage_locations)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A list of machine images.
 | |
|       class MachineImageList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `etag`
 | |
|         # @return [String]
 | |
|         attr_accessor :etag
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of MachineImage resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::MachineImage>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] The resource type, which is always compute#
 | |
|         # machineImagesListResponse for machine image lists.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::MachineImageList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @etag = args[:etag] if args.key?(:etag)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::MachineImageList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A Machine Type resource. (== resource_for v1.machineTypes ==) (== resource_for
 | |
|       # beta.machineTypes ==)
 | |
|       class MachineType
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # Deprecation status for a public resource.
 | |
|         # Corresponds to the JSON property `deprecated`
 | |
|         # @return [Google::Apis::ComputeAlpha::DeprecationStatus]
 | |
|         attr_accessor :deprecated
 | |
|       
 | |
|         # [Output Only] An optional textual description of the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The number of virtual CPUs that are available to the instance.
 | |
|         # Corresponds to the JSON property `guestCpus`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :guest_cpus
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Whether this machine type has a shared CPU. See Shared-core
 | |
|         # machine types for more information.
 | |
|         # Corresponds to the JSON property `isSharedCpu`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :is_shared_cpu
 | |
|         alias_method :is_shared_cpu?, :is_shared_cpu
 | |
|       
 | |
|         # [Output Only] The type of the resource. Always compute#machineType for machine
 | |
|         # types.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] Maximum persistent disks allowed.
 | |
|         # Corresponds to the JSON property `maximumPersistentDisks`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :maximum_persistent_disks
 | |
|       
 | |
|         # [Output Only] Maximum total persistent disks size (GB) allowed.
 | |
|         # Corresponds to the JSON property `maximumPersistentDisksSizeGb`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :maximum_persistent_disks_size_gb
 | |
|       
 | |
|         # [Output Only] The amount of physical memory available to the instance, defined
 | |
|         # in MB.
 | |
|         # Corresponds to the JSON property `memoryMb`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :memory_mb
 | |
|       
 | |
|         # [Output Only] Name of the resource.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # [Output Only] The name of the zone where the machine type resides, such as us-
 | |
|         # central1-a.
 | |
|         # Corresponds to the JSON property `zone`
 | |
|         # @return [String]
 | |
|         attr_accessor :zone
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @deprecated = args[:deprecated] if args.key?(:deprecated)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @guest_cpus = args[:guest_cpus] if args.key?(:guest_cpus)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @is_shared_cpu = args[:is_shared_cpu] if args.key?(:is_shared_cpu)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @maximum_persistent_disks = args[:maximum_persistent_disks] if args.key?(:maximum_persistent_disks)
 | |
|           @maximum_persistent_disks_size_gb = args[:maximum_persistent_disks_size_gb] if args.key?(:maximum_persistent_disks_size_gb)
 | |
|           @memory_mb = args[:memory_mb] if args.key?(:memory_mb)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @zone = args[:zone] if args.key?(:zone)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class MachineTypeAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of MachineTypesScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::MachineTypesScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#machineTypeAggregatedList for
 | |
|         # aggregated lists of machine types.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::MachineTypeAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::MachineTypeAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of machine types.
 | |
|       class MachineTypeList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of MachineType resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::MachineType>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#machineTypeList for lists of
 | |
|         # machine types.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::MachineTypeList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::MachineTypeList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class MachineTypesScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] A list of machine types contained in this scope.
 | |
|         # Corresponds to the JSON property `machineTypes`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::MachineType>]
 | |
|         attr_accessor :machine_types
 | |
|       
 | |
|         # [Output Only] An informational warning that appears when the machine types
 | |
|         # list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::MachineTypesScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @machine_types = args[:machine_types] if args.key?(:machine_types)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] An informational warning that appears when the machine types
 | |
|         # list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::MachineTypesScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A Managed Instance resource.
 | |
|       class ManagedInstance
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The current action that the managed instance group has scheduled
 | |
|         # for the instance. Possible values:
 | |
|         # - NONE The instance is running, and the managed instance group does not have
 | |
|         # any scheduled actions for this instance.
 | |
|         # - CREATING The managed instance group is creating this instance. If the group
 | |
|         # fails to create this instance, it will try again until it is successful.
 | |
|         # - CREATING_WITHOUT_RETRIES The managed instance group is attempting to create
 | |
|         # this instance only once. If the group fails to create this instance, it does
 | |
|         # not try again and the group's targetSize value is decreased instead.
 | |
|         # - RECREATING The managed instance group is recreating this instance.
 | |
|         # - DELETING The managed instance group is permanently deleting this instance.
 | |
|         # - ABANDONING The managed instance group is abandoning this instance. The
 | |
|         # instance will be removed from the instance group and from any target pools
 | |
|         # that are associated with this group.
 | |
|         # - RESTARTING The managed instance group is restarting the instance.
 | |
|         # - REFRESHING The managed instance group is applying configuration changes to
 | |
|         # the instance without stopping it. For example, the group can update the target
 | |
|         # pool list for an instance without stopping that instance.
 | |
|         # - VERIFYING The managed instance group has created the instance and it is in
 | |
|         # the process of being verified.
 | |
|         # Corresponds to the JSON property `currentAction`
 | |
|         # @return [String]
 | |
|         attr_accessor :current_action
 | |
|       
 | |
|         # [Output only] The unique identifier for this resource. This field is empty
 | |
|         # when instance does not exist.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] The URL of the instance. The URL can exist even if the instance
 | |
|         # has not yet been created.
 | |
|         # Corresponds to the JSON property `instance`
 | |
|         # @return [String]
 | |
|         attr_accessor :instance
 | |
|       
 | |
|         # [Output Only] Health state of the instance per health-check.
 | |
|         # Corresponds to the JSON property `instanceHealth`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::ManagedInstanceInstanceHealth>]
 | |
|         attr_accessor :instance_health
 | |
|       
 | |
|         # [Output Only] The status of the instance. This field is empty when the
 | |
|         # instance does not exist.
 | |
|         # Corresponds to the JSON property `instanceStatus`
 | |
|         # @return [String]
 | |
|         attr_accessor :instance_status
 | |
|       
 | |
|         # [Output Only] The intended template of the instance. This field is empty when
 | |
|         # current_action is one of ` DELETING, ABANDONING `.
 | |
|         # Corresponds to the JSON property `instanceTemplate`
 | |
|         # @return [String]
 | |
|         attr_accessor :instance_template
 | |
|       
 | |
|         # [Output Only] Information about the last attempt to create or delete the
 | |
|         # instance.
 | |
|         # Corresponds to the JSON property `lastAttempt`
 | |
|         # @return [Google::Apis::ComputeAlpha::ManagedInstanceLastAttempt]
 | |
|         attr_accessor :last_attempt
 | |
|       
 | |
|         # Overrides of stateful properties for a given instance
 | |
|         # Corresponds to the JSON property `override`
 | |
|         # @return [Google::Apis::ComputeAlpha::ManagedInstanceOverride]
 | |
|         attr_accessor :override
 | |
|       
 | |
|         # Preserved state for a given instance.
 | |
|         # Corresponds to the JSON property `preservedStateFromConfig`
 | |
|         # @return [Google::Apis::ComputeAlpha::PreservedState]
 | |
|         attr_accessor :preserved_state_from_config
 | |
|       
 | |
|         # Preserved state for a given instance.
 | |
|         # Corresponds to the JSON property `preservedStateFromPolicy`
 | |
|         # @return [Google::Apis::ComputeAlpha::PreservedState]
 | |
|         attr_accessor :preserved_state_from_policy
 | |
|       
 | |
|         # [Output Only] Tag describing the version.
 | |
|         # Corresponds to the JSON property `tag`
 | |
|         # @return [String]
 | |
|         attr_accessor :tag
 | |
|       
 | |
|         # [Output Only] Intended version of this instance.
 | |
|         # Corresponds to the JSON property `version`
 | |
|         # @return [Google::Apis::ComputeAlpha::ManagedInstanceVersion]
 | |
|         attr_accessor :version
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @current_action = args[:current_action] if args.key?(:current_action)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @instance = args[:instance] if args.key?(:instance)
 | |
|           @instance_health = args[:instance_health] if args.key?(:instance_health)
 | |
|           @instance_status = args[:instance_status] if args.key?(:instance_status)
 | |
|           @instance_template = args[:instance_template] if args.key?(:instance_template)
 | |
|           @last_attempt = args[:last_attempt] if args.key?(:last_attempt)
 | |
|           @override = args[:override] if args.key?(:override)
 | |
|           @preserved_state_from_config = args[:preserved_state_from_config] if args.key?(:preserved_state_from_config)
 | |
|           @preserved_state_from_policy = args[:preserved_state_from_policy] if args.key?(:preserved_state_from_policy)
 | |
|           @tag = args[:tag] if args.key?(:tag)
 | |
|           @version = args[:version] if args.key?(:version)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ManagedInstanceInstanceHealth
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The current detailed instance health state.
 | |
|         # Corresponds to the JSON property `detailedHealthState`
 | |
|         # @return [String]
 | |
|         attr_accessor :detailed_health_state
 | |
|       
 | |
|         # [Output Only] The URL for the health check that verifies whether the instance
 | |
|         # is healthy.
 | |
|         # Corresponds to the JSON property `healthCheck`
 | |
|         # @return [String]
 | |
|         attr_accessor :health_check
 | |
|       
 | |
|         # [Output Only] The current instance health state.
 | |
|         # Corresponds to the JSON property `healthState`
 | |
|         # @return [String]
 | |
|         attr_accessor :health_state
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @detailed_health_state = args[:detailed_health_state] if args.key?(:detailed_health_state)
 | |
|           @health_check = args[:health_check] if args.key?(:health_check)
 | |
|           @health_state = args[:health_state] if args.key?(:health_state)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ManagedInstanceLastAttempt
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Encountered errors during the last attempt to create or delete
 | |
|         # the instance.
 | |
|         # Corresponds to the JSON property `errors`
 | |
|         # @return [Google::Apis::ComputeAlpha::ManagedInstanceLastAttempt::Errors]
 | |
|         attr_accessor :errors
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @errors = args[:errors] if args.key?(:errors)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Encountered errors during the last attempt to create or delete
 | |
|         # the instance.
 | |
|         class Errors
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] The array of errors encountered while processing this operation.
 | |
|           # Corresponds to the JSON property `errors`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::ManagedInstanceLastAttempt::Errors::Error>]
 | |
|           attr_accessor :errors
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @errors = args[:errors] if args.key?(:errors)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Error
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] The error type identifier for this error.
 | |
|             # Corresponds to the JSON property `code`
 | |
|             # @return [String]
 | |
|             attr_accessor :code
 | |
|           
 | |
|             # [Output Only] Indicates the field in the request that caused the error. This
 | |
|             # property is optional.
 | |
|             # Corresponds to the JSON property `location`
 | |
|             # @return [String]
 | |
|             attr_accessor :location
 | |
|           
 | |
|             # [Output Only] An optional, human-readable error message.
 | |
|             # Corresponds to the JSON property `message`
 | |
|             # @return [String]
 | |
|             attr_accessor :message
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @code = args[:code] if args.key?(:code)
 | |
|               @location = args[:location] if args.key?(:location)
 | |
|               @message = args[:message] if args.key?(:message)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Overrides of stateful properties for a given instance
 | |
|       class ManagedInstanceOverride
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Disk overrides defined for this instance. According to documentation the
 | |
|         # maximum number of disks attached to an instance is 128: https://cloud.google.
 | |
|         # com/compute/docs/disks/ However, compute API defines the limit at 140, so this
 | |
|         # is what we check.
 | |
|         # Corresponds to the JSON property `disks`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::ManagedInstanceOverrideDiskOverride>]
 | |
|         attr_accessor :disks
 | |
|       
 | |
|         # Metadata overrides defined for this instance. TODO(b/69785416) validate the
 | |
|         # total length is <9 KB
 | |
|         # Corresponds to the JSON property `metadata`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::ManagedInstanceOverride::Metadatum>]
 | |
|         attr_accessor :metadata
 | |
|       
 | |
|         # [Output Only] Indicates where does the override come from.
 | |
|         # Corresponds to the JSON property `origin`
 | |
|         # @return [String]
 | |
|         attr_accessor :origin
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @disks = args[:disks] if args.key?(:disks)
 | |
|           @metadata = args[:metadata] if args.key?(:metadata)
 | |
|           @origin = args[:origin] if args.key?(:origin)
 | |
|         end
 | |
|         
 | |
|         # 
 | |
|         class Metadatum
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # Key for the metadata entry. Keys must conform to the following regexp: [a-zA-
 | |
|           # Z0-9-_]+, and be less than 128 bytes in length. This is reflected as part of a
 | |
|           # URL in the metadata server. Additionally, to avoid ambiguity, keys must not
 | |
|           # conflict with any other metadata keys for the project.
 | |
|           # Corresponds to the JSON property `key`
 | |
|           # @return [String]
 | |
|           attr_accessor :key
 | |
|         
 | |
|           # Value for the metadata entry. These are free-form strings, and only have
 | |
|           # meaning as interpreted by the image running in the instance. The only
 | |
|           # restriction placed on values is that their size must be less than or equal to
 | |
|           # 262144 bytes (256 KiB).
 | |
|           # Corresponds to the JSON property `value`
 | |
|           # @return [String]
 | |
|           attr_accessor :value
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @key = args[:key] if args.key?(:key)
 | |
|             @value = args[:value] if args.key?(:value)
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ManagedInstanceOverrideDiskOverride
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The name of the device on the VM
 | |
|         # Corresponds to the JSON property `deviceName`
 | |
|         # @return [String]
 | |
|         attr_accessor :device_name
 | |
|       
 | |
|         # The mode in which to attach this disk, either READ_WRITE or READ_ONLY. If not
 | |
|         # specified, the default is to attach the disk in READ_WRITE mode.
 | |
|         # Corresponds to the JSON property `mode`
 | |
|         # @return [String]
 | |
|         attr_accessor :mode
 | |
|       
 | |
|         # The disk that is/will be mounted
 | |
|         # Corresponds to the JSON property `source`
 | |
|         # @return [String]
 | |
|         attr_accessor :source
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @device_name = args[:device_name] if args.key?(:device_name)
 | |
|           @mode = args[:mode] if args.key?(:mode)
 | |
|           @source = args[:source] if args.key?(:source)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ManagedInstanceVersion
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The intended template of the instance. This field is empty when
 | |
|         # current_action is one of ` DELETING, ABANDONING `.
 | |
|         # Corresponds to the JSON property `instanceTemplate`
 | |
|         # @return [String]
 | |
|         attr_accessor :instance_template
 | |
|       
 | |
|         # [Output Only] Name of the version.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instance_template = args[:instance_template] if args.key?(:instance_template)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A metadata key/value entry.
 | |
|       class Metadata
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Specifies a fingerprint for this request, which is essentially a hash of the
 | |
|         # metadata's contents and used for optimistic locking. The fingerprint is
 | |
|         # initially generated by Compute Engine and changes after every request to
 | |
|         # modify or update metadata. You must always provide an up-to-date fingerprint
 | |
|         # hash in order to update or change metadata, otherwise the request will fail
 | |
|         # with error 412 conditionNotMet.
 | |
|         # To see the latest fingerprint, make a get() request to retrieve the resource.
 | |
|         # Corresponds to the JSON property `fingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :fingerprint
 | |
|       
 | |
|         # Array of key/value pairs. The total size of all keys and values must be less
 | |
|         # than 512 KB.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Metadata::Item>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#metadata for metadata.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @fingerprint = args[:fingerprint] if args.key?(:fingerprint)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|         end
 | |
|         
 | |
|         # 
 | |
|         class Item
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # Key for the metadata entry. Keys must conform to the following regexp: [a-zA-
 | |
|           # Z0-9-_]+, and be less than 128 bytes in length. This is reflected as part of a
 | |
|           # URL in the metadata server. Additionally, to avoid ambiguity, keys must not
 | |
|           # conflict with any other metadata keys for the project.
 | |
|           # Corresponds to the JSON property `key`
 | |
|           # @return [String]
 | |
|           attr_accessor :key
 | |
|         
 | |
|           # Value for the metadata entry. These are free-form strings, and only have
 | |
|           # meaning as interpreted by the image running in the instance. The only
 | |
|           # restriction placed on values is that their size must be less than or equal to
 | |
|           # 262144 bytes (256 KiB).
 | |
|           # Corresponds to the JSON property `value`
 | |
|           # @return [String]
 | |
|           attr_accessor :value
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @key = args[:key] if args.key?(:key)
 | |
|             @value = args[:value] if args.key?(:value)
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Opaque filter criteria used by loadbalancers to restrict routing configuration
 | |
|       # to a limited set of loadbalancing proxies. Proxies and sidecars involved in
 | |
|       # loadbalancing would typically present metadata to the loadbalancers which need
 | |
|       # to match criteria specified here. 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.
 | |
|       # An example for using metadataFilters would be: if loadbalancing involves
 | |
|       # Envoys, they will only receive routing configuration when values in
 | |
|       # metadataFilters match values supplied in <a href="https://www.envoyproxy.io/
 | |
|       # docs/envoy/latest/api-v2/api/v2/core/base.proto#envoy-api-msg-core-node" Node
 | |
|       # metadata of their XDS requests to loadbalancers.
 | |
|       class MetadataFilter
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The list of label value pairs that must match labels in the provided metadata
 | |
|         # based on filterMatchCriteria
 | |
|         # This list must not be empty and can have at the most 64 entries.
 | |
|         # Corresponds to the JSON property `filterLabels`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::MetadataFilterLabelMatch>]
 | |
|         attr_accessor :filter_labels
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `filterMatchCriteria`
 | |
|         # @return [String]
 | |
|         attr_accessor :filter_match_criteria
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @filter_labels = args[:filter_labels] if args.key?(:filter_labels)
 | |
|           @filter_match_criteria = args[:filter_match_criteria] if args.key?(:filter_match_criteria)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # MetadataFilter label name value pairs that are expected to match corresponding
 | |
|       # labels presented as metadata to the loadbalancer.
 | |
|       class MetadataFilterLabelMatch
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Name of metadata label.
 | |
|         # The name can have a maximum length of 1024 characters and must be at least 1
 | |
|         # character long.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # The value of the label must match the specified value.
 | |
|         # value can have a maximum length of 1024 characters.
 | |
|         # Corresponds to the JSON property `value`
 | |
|         # @return [String]
 | |
|         attr_accessor :value
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @value = args[:value] if args.key?(:value)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The named port. For example: .
 | |
|       class NamedPort
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The name for this named port. The name must be 1-63 characters long, and
 | |
|         # comply with RFC1035.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # The port number, which can be a value between 1 and 65535.
 | |
|         # Corresponds to the JSON property `port`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :port
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @port = args[:port] if args.key?(:port)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Represents a Network resource. Read Virtual Private Cloud (VPC) Network
 | |
|       # Overview for more information. (== resource_for v1.networks ==) (==
 | |
|       # resource_for beta.networks ==)
 | |
|       class Network
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The range of internal addresses that are legal on this network. This range is
 | |
|         # a CIDR specification, for example: 192.168.0.0/16. Provided by the client when
 | |
|         # the network is created.
 | |
|         # Corresponds to the JSON property `IPv4Range`
 | |
|         # @return [String]
 | |
|         attr_accessor :i_pv4_range
 | |
|       
 | |
|         # When set to true, the VPC network is created in "auto" mode. When set to false,
 | |
|         # the VPC network is created in "custom" mode.
 | |
|         # An auto mode VPC network starts with one subnet per region. Each subnet has a
 | |
|         # predetermined range as described in Auto mode VPC network IP ranges.
 | |
|         # Corresponds to the JSON property `autoCreateSubnetworks`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :auto_create_subnetworks
 | |
|         alias_method :auto_create_subnetworks?, :auto_create_subnetworks
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # [Output Only] Type of VM-to-VM traffic encryption for this network.
 | |
|         # Corresponds to the JSON property `crossVmEncryption`
 | |
|         # @return [String]
 | |
|         attr_accessor :cross_vm_encryption
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The gateway address for default routing out of the network. This
 | |
|         # value is read only and is selected by GCP.
 | |
|         # Corresponds to the JSON property `gatewayIPv4`
 | |
|         # @return [String]
 | |
|         attr_accessor :gateway_i_pv4
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#network for networks.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] Type of LB-to-VM traffic encryption for this network.
 | |
|         # Corresponds to the JSON property `loadBalancerVmEncryption`
 | |
|         # @return [String]
 | |
|         attr_accessor :load_balancer_vm_encryption
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # [Output Only] A list of network peerings for the resource.
 | |
|         # Corresponds to the JSON property `peerings`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::NetworkPeering>]
 | |
|         attr_accessor :peerings
 | |
|       
 | |
|         # A routing configuration attached to a network resource. The message includes
 | |
|         # the list of routers associated with the network, and a flag indicating the
 | |
|         # type of routing behavior to enforce network-wide.
 | |
|         # Corresponds to the JSON property `routingConfig`
 | |
|         # @return [Google::Apis::ComputeAlpha::NetworkRoutingConfig]
 | |
|         attr_accessor :routing_config
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # [Output Only] Server-defined fully-qualified URLs for all subnetworks in this
 | |
|         # VPC network.
 | |
|         # Corresponds to the JSON property `subnetworks`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :subnetworks
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @i_pv4_range = args[:i_pv4_range] if args.key?(:i_pv4_range)
 | |
|           @auto_create_subnetworks = args[:auto_create_subnetworks] if args.key?(:auto_create_subnetworks)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @cross_vm_encryption = args[:cross_vm_encryption] if args.key?(:cross_vm_encryption)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @gateway_i_pv4 = args[:gateway_i_pv4] if args.key?(:gateway_i_pv4)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @load_balancer_vm_encryption = args[:load_balancer_vm_encryption] if args.key?(:load_balancer_vm_encryption)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @peerings = args[:peerings] if args.key?(:peerings)
 | |
|           @routing_config = args[:routing_config] if args.key?(:routing_config)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @subnetworks = args[:subnetworks] if args.key?(:subnetworks)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The network endpoint.
 | |
|       class NetworkEndpoint
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Metadata defined as annotations on the network endpoint.
 | |
|         # Corresponds to the JSON property `annotations`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :annotations
 | |
|       
 | |
|         # The name for a specific VM instance that the IP address belongs to. This is
 | |
|         # required for network endpoints of type GCE_VM_IP_PORT. The instance must be in
 | |
|         # the same zone of network endpoint group.
 | |
|         # The name must be 1-63 characters long, and comply with RFC1035.
 | |
|         # Corresponds to the JSON property `instance`
 | |
|         # @return [String]
 | |
|         attr_accessor :instance
 | |
|       
 | |
|         # Optional IPv4 address of network endpoint. The IP address must belong to a VM
 | |
|         # in GCE (either the primary IP or as part of an aliased IP range). If the IP
 | |
|         # address is not specified, then the primary IP address for the VM instance in
 | |
|         # the network that the network endpoint group belongs to will be used.
 | |
|         # Corresponds to the JSON property `ipAddress`
 | |
|         # @return [String]
 | |
|         attr_accessor :ip_address
 | |
|       
 | |
|         # Optional port number of network endpoint. If not specified and the
 | |
|         # NetworkEndpointGroup.network_endpoint_type is GCE_IP_PORT, the defaultPort for
 | |
|         # the network endpoint group will be used.
 | |
|         # Corresponds to the JSON property `port`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :port
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @annotations = args[:annotations] if args.key?(:annotations)
 | |
|           @instance = args[:instance] if args.key?(:instance)
 | |
|           @ip_address = args[:ip_address] if args.key?(:ip_address)
 | |
|           @port = args[:port] if args.key?(:port)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Represents a collection of network endpoints.
 | |
|       class NetworkEndpointGroup
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Metadata defined as annotations on the network endpoint group.
 | |
|         # Corresponds to the JSON property `annotations`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :annotations
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # The default port used if the port number is not specified in the network
 | |
|         # endpoint.
 | |
|         # Corresponds to the JSON property `defaultPort`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :default_port
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#networkEndpointGroup for
 | |
|         # network endpoint group.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # Load balancing specific fields for network endpoint group.
 | |
|         # Corresponds to the JSON property `loadBalancer`
 | |
|         # @return [Google::Apis::ComputeAlpha::NetworkEndpointGroupLbNetworkEndpointGroup]
 | |
|         attr_accessor :load_balancer
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # The URL of the network to which all network endpoints in the NEG belong. Uses "
 | |
|         # default" project network if unspecified.
 | |
|         # Corresponds to the JSON property `network`
 | |
|         # @return [String]
 | |
|         attr_accessor :network
 | |
|       
 | |
|         # Type of network endpoints in this network endpoint group. Currently the only
 | |
|         # supported value is GCE_VM_IP_PORT.
 | |
|         # Corresponds to the JSON property `networkEndpointType`
 | |
|         # @return [String]
 | |
|         attr_accessor :network_endpoint_type
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # [Output only] Number of network endpoints in the network endpoint group.
 | |
|         # Corresponds to the JSON property `size`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :size
 | |
|       
 | |
|         # Optional URL of the subnetwork to which all network endpoints in the NEG
 | |
|         # belong.
 | |
|         # Corresponds to the JSON property `subnetwork`
 | |
|         # @return [String]
 | |
|         attr_accessor :subnetwork
 | |
|       
 | |
|         # Specify the type of this network endpoint group. Only LOAD_BALANCING is valid
 | |
|         # for now.
 | |
|         # Corresponds to the JSON property `type`
 | |
|         # @return [String]
 | |
|         attr_accessor :type
 | |
|       
 | |
|         # [Output Only] The URL of the zone where the network endpoint group is located.
 | |
|         # Corresponds to the JSON property `zone`
 | |
|         # @return [String]
 | |
|         attr_accessor :zone
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @annotations = args[:annotations] if args.key?(:annotations)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @default_port = args[:default_port] if args.key?(:default_port)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @load_balancer = args[:load_balancer] if args.key?(:load_balancer)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @network = args[:network] if args.key?(:network)
 | |
|           @network_endpoint_type = args[:network_endpoint_type] if args.key?(:network_endpoint_type)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @size = args[:size] if args.key?(:size)
 | |
|           @subnetwork = args[:subnetwork] if args.key?(:subnetwork)
 | |
|           @type = args[:type] if args.key?(:type)
 | |
|           @zone = args[:zone] if args.key?(:zone)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NetworkEndpointGroupAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of NetworkEndpointGroupsScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::NetworkEndpointGroupsScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] The resource type, which is always compute#
 | |
|         # networkEndpointGroupAggregatedList for aggregated lists of network endpoint
 | |
|         # groups.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::NetworkEndpointGroupAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::NetworkEndpointGroupAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Load balancing specific fields for network endpoint group.
 | |
|       class NetworkEndpointGroupLbNetworkEndpointGroup
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The default port used if the port number is not specified in the network
 | |
|         # endpoint. [Deprecated] This field is deprecated.
 | |
|         # Corresponds to the JSON property `defaultPort`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :default_port
 | |
|       
 | |
|         # The URL of the network to which all network endpoints in the NEG belong. Uses "
 | |
|         # default" project network if unspecified. [Deprecated] This field is deprecated.
 | |
|         # Corresponds to the JSON property `network`
 | |
|         # @return [String]
 | |
|         attr_accessor :network
 | |
|       
 | |
|         # Optional URL of the subnetwork to which all network endpoints in the NEG
 | |
|         # belong. [Deprecated] This field is deprecated.
 | |
|         # Corresponds to the JSON property `subnetwork`
 | |
|         # @return [String]
 | |
|         attr_accessor :subnetwork
 | |
|       
 | |
|         # [Output Only] The URL of the zone where the network endpoint group is located.
 | |
|         # [Deprecated] This field is deprecated.
 | |
|         # Corresponds to the JSON property `zone`
 | |
|         # @return [String]
 | |
|         attr_accessor :zone
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @default_port = args[:default_port] if args.key?(:default_port)
 | |
|           @network = args[:network] if args.key?(:network)
 | |
|           @subnetwork = args[:subnetwork] if args.key?(:subnetwork)
 | |
|           @zone = args[:zone] if args.key?(:zone)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NetworkEndpointGroupList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of NetworkEndpointGroup resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::NetworkEndpointGroup>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] The resource type, which is always compute#
 | |
|         # networkEndpointGroupList for network endpoint group lists.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::NetworkEndpointGroupList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::NetworkEndpointGroupList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NetworkEndpointGroupsAttachEndpointsRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The list of network endpoints to be attached.
 | |
|         # Corresponds to the JSON property `networkEndpoints`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::NetworkEndpoint>]
 | |
|         attr_accessor :network_endpoints
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @network_endpoints = args[:network_endpoints] if args.key?(:network_endpoints)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NetworkEndpointGroupsDetachEndpointsRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The list of network endpoints to be detached.
 | |
|         # Corresponds to the JSON property `networkEndpoints`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::NetworkEndpoint>]
 | |
|         attr_accessor :network_endpoints
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @network_endpoints = args[:network_endpoints] if args.key?(:network_endpoints)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NetworkEndpointGroupsListEndpointsRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Optional query parameter for showing the health status of each network
 | |
|         # endpoint. Valid options are SKIP or SHOW. If you don't specifiy this parameter,
 | |
|         # the health status of network endpoints will not be provided.
 | |
|         # Corresponds to the JSON property `healthStatus`
 | |
|         # @return [String]
 | |
|         attr_accessor :health_status
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @health_status = args[:health_status] if args.key?(:health_status)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NetworkEndpointGroupsListNetworkEndpoints
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of NetworkEndpointWithHealthStatus resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::NetworkEndpointWithHealthStatus>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] The resource type, which is always compute#
 | |
|         # networkEndpointGroupsListNetworkEndpoints for the list of network endpoints in
 | |
|         # the specified network endpoint group.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::NetworkEndpointGroupsListNetworkEndpoints::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::NetworkEndpointGroupsListNetworkEndpoints::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NetworkEndpointGroupsScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The list of network endpoint groups that are contained in this
 | |
|         # scope.
 | |
|         # Corresponds to the JSON property `networkEndpointGroups`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::NetworkEndpointGroup>]
 | |
|         attr_accessor :network_endpoint_groups
 | |
|       
 | |
|         # [Output Only] An informational warning that replaces the list of network
 | |
|         # endpoint groups when the list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::NetworkEndpointGroupsScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @network_endpoint_groups = args[:network_endpoint_groups] if args.key?(:network_endpoint_groups)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] An informational warning that replaces the list of network
 | |
|         # endpoint groups when the list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::NetworkEndpointGroupsScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NetworkEndpointWithHealthStatus
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output only] The health status of network endpoint;
 | |
|         # Corresponds to the JSON property `healths`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::HealthStatusForNetworkEndpoint>]
 | |
|         attr_accessor :healths
 | |
|       
 | |
|         # The network endpoint.
 | |
|         # Corresponds to the JSON property `networkEndpoint`
 | |
|         # @return [Google::Apis::ComputeAlpha::NetworkEndpoint]
 | |
|         attr_accessor :network_endpoint
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @healths = args[:healths] if args.key?(:healths)
 | |
|           @network_endpoint = args[:network_endpoint] if args.key?(:network_endpoint)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A network interface resource attached to an instance.
 | |
|       class NetworkInterface
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # An array of configurations for this interface. Currently, only one access
 | |
|         # config, ONE_TO_ONE_NAT, is supported. If there are no accessConfigs specified,
 | |
|         # then this instance will have no external internet access.
 | |
|         # Corresponds to the JSON property `accessConfigs`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::AccessConfig>]
 | |
|         attr_accessor :access_configs
 | |
|       
 | |
|         # An array of alias IP ranges for this network interface. Can only be specified
 | |
|         # for network interfaces on subnet-mode networks.
 | |
|         # Corresponds to the JSON property `aliasIpRanges`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::AliasIpRange>]
 | |
|         attr_accessor :alias_ip_ranges
 | |
|       
 | |
|         # Fingerprint hash of contents stored in this network interface. This field will
 | |
|         # be ignored when inserting an Instance or adding a NetworkInterface. An up-to-
 | |
|         # date fingerprint must be provided in order to update the NetworkInterface,
 | |
|         # otherwise the request will fail with error 412 conditionNotMet.
 | |
|         # Corresponds to the JSON property `fingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :fingerprint
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#networkInterface for
 | |
|         # network interfaces.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] The name of the network interface, generated by the server. For
 | |
|         # network devices, these are eth0, eth1, etc.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # URL of the network resource for this instance. When creating an instance, if
 | |
|         # neither the network nor the subnetwork is specified, the default network
 | |
|         # global/networks/default is used; if the network is not specified but the
 | |
|         # subnetwork is specified, the network is inferred.
 | |
|         # This field is optional when creating a firewall rule. If not specified when
 | |
|         # creating a firewall rule, the default network global/networks/default is used.
 | |
|         # If you specify this property, you can specify the network as a full or partial
 | |
|         # URL. For example, the following are all valid URLs:
 | |
|         # - https://www.googleapis.com/compute/v1/projects/project/global/networks/
 | |
|         # network
 | |
|         # - projects/project/global/networks/network
 | |
|         # - global/networks/default
 | |
|         # Corresponds to the JSON property `network`
 | |
|         # @return [String]
 | |
|         attr_accessor :network
 | |
|       
 | |
|         # An IPv4 internal network address to assign to the instance for this network
 | |
|         # interface. If not specified by the user, an unused internal IP is assigned by
 | |
|         # the system.
 | |
|         # Corresponds to the JSON property `networkIP`
 | |
|         # @return [String]
 | |
|         attr_accessor :network_ip
 | |
|       
 | |
|         # The URL of the Subnetwork resource for this instance. If the network resource
 | |
|         # is in legacy mode, do not provide this property. If the network is in auto
 | |
|         # subnet mode, providing the subnetwork is optional. If the network is in custom
 | |
|         # subnet mode, then this field should be specified. If you specify this property,
 | |
|         # you can specify the subnetwork as a full or partial URL. For example, the
 | |
|         # following are all valid URLs:
 | |
|         # - https://www.googleapis.com/compute/v1/projects/project/regions/region/
 | |
|         # subnetworks/subnetwork
 | |
|         # - regions/region/subnetworks/subnetwork
 | |
|         # Corresponds to the JSON property `subnetwork`
 | |
|         # @return [String]
 | |
|         attr_accessor :subnetwork
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @access_configs = args[:access_configs] if args.key?(:access_configs)
 | |
|           @alias_ip_ranges = args[:alias_ip_ranges] if args.key?(:alias_ip_ranges)
 | |
|           @fingerprint = args[:fingerprint] if args.key?(:fingerprint)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @network = args[:network] if args.key?(:network)
 | |
|           @network_ip = args[:network_ip] if args.key?(:network_ip)
 | |
|           @subnetwork = args[:subnetwork] if args.key?(:subnetwork)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of networks.
 | |
|       class NetworkList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of Network resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Network>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#networkList for lists of
 | |
|         # networks.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::NetworkList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::NetworkList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A network peering attached to a network resource. The message includes the
 | |
|       # peering name, peer network, peering state, and a flag indicating whether
 | |
|       # Google Compute Engine should automatically create routes for the peering.
 | |
|       class NetworkPeering
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Whether Cloud Routers in this network can automatically advertise subnets from
 | |
|         # the peer network.
 | |
|         # Corresponds to the JSON property `advertisePeerSubnetsViaRouters`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :advertise_peer_subnets_via_routers
 | |
|         alias_method :advertise_peer_subnets_via_routers?, :advertise_peer_subnets_via_routers
 | |
|       
 | |
|         # Indicates whether full mesh connectivity is created and managed automatically.
 | |
|         # When it is set to true, Google Compute Engine will automatically create and
 | |
|         # manage the routes between two networks when the state is ACTIVE. Otherwise,
 | |
|         # user needs to create routes manually to route packets to peer network.
 | |
|         # Corresponds to the JSON property `autoCreateRoutes`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :auto_create_routes
 | |
|         alias_method :auto_create_routes?, :auto_create_routes
 | |
|       
 | |
|         # Whether full mesh connectivity is created and managed automatically. When it
 | |
|         # is set to true, Google Compute Engine will automatically create and manage the
 | |
|         # routes between two networks when the peering state is ACTIVE. Otherwise, user
 | |
|         # needs to create routes manually to route packets to peer network.
 | |
|         # Corresponds to the JSON property `exchangeSubnetRoutes`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :exchange_subnet_routes
 | |
|         alias_method :exchange_subnet_routes?, :exchange_subnet_routes
 | |
|       
 | |
|         # Whether to export the custom routes to peer network.
 | |
|         # Corresponds to the JSON property `exportCustomRoutes`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :export_custom_routes
 | |
|         alias_method :export_custom_routes?, :export_custom_routes
 | |
|       
 | |
|         # Whether to import the custom routes from peer network.
 | |
|         # Corresponds to the JSON property `importCustomRoutes`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :import_custom_routes
 | |
|         alias_method :import_custom_routes?, :import_custom_routes
 | |
|       
 | |
|         # Name of this peering. Provided by the client when the peering is created. The
 | |
|         # name must comply with RFC1035. Specifically, the name must be 1-63 characters
 | |
|         # long and match regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the
 | |
|         # first character must be a lowercase letter, and all the following characters
 | |
|         # must be a dash, lowercase letter, or digit, except the last character, which
 | |
|         # cannot be a dash.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # The URL of the peer network. It can be either full URL or partial URL. The
 | |
|         # peer network may belong to a different project. If the partial URL does not
 | |
|         # contain project, it is assumed that the peer network is in the same project as
 | |
|         # the current network.
 | |
|         # Corresponds to the JSON property `network`
 | |
|         # @return [String]
 | |
|         attr_accessor :network
 | |
|       
 | |
|         # [Output Only] State for the peering.
 | |
|         # Corresponds to the JSON property `state`
 | |
|         # @return [String]
 | |
|         attr_accessor :state
 | |
|       
 | |
|         # [Output Only] Details about the current state of the peering.
 | |
|         # Corresponds to the JSON property `stateDetails`
 | |
|         # @return [String]
 | |
|         attr_accessor :state_details
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @advertise_peer_subnets_via_routers = args[:advertise_peer_subnets_via_routers] if args.key?(:advertise_peer_subnets_via_routers)
 | |
|           @auto_create_routes = args[:auto_create_routes] if args.key?(:auto_create_routes)
 | |
|           @exchange_subnet_routes = args[:exchange_subnet_routes] if args.key?(:exchange_subnet_routes)
 | |
|           @export_custom_routes = args[:export_custom_routes] if args.key?(:export_custom_routes)
 | |
|           @import_custom_routes = args[:import_custom_routes] if args.key?(:import_custom_routes)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @network = args[:network] if args.key?(:network)
 | |
|           @state = args[:state] if args.key?(:state)
 | |
|           @state_details = args[:state_details] if args.key?(:state_details)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A routing configuration attached to a network resource. The message includes
 | |
|       # the list of routers associated with the network, and a flag indicating the
 | |
|       # type of routing behavior to enforce network-wide.
 | |
|       class NetworkRoutingConfig
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The network-wide routing mode to use. If set to REGIONAL, this network's cloud
 | |
|         # routers will only advertise routes with subnets of this network in the same
 | |
|         # region as the router. If set to GLOBAL, this network's cloud routers will
 | |
|         # advertise routes with all subnets of this network, across regions.
 | |
|         # Corresponds to the JSON property `routingMode`
 | |
|         # @return [String]
 | |
|         attr_accessor :routing_mode
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @routing_mode = args[:routing_mode] if args.key?(:routing_mode)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NetworksAddPeeringRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Whether Google Compute Engine manages the routes automatically.
 | |
|         # Corresponds to the JSON property `autoCreateRoutes`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :auto_create_routes
 | |
|         alias_method :auto_create_routes?, :auto_create_routes
 | |
|       
 | |
|         # This field will be deprecated soon. Prefer using export_custom_routes in
 | |
|         # network_peering instead. Whether to export the custom routes to peer network.
 | |
|         # Corresponds to the JSON property `exportCustomRoutes`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :export_custom_routes
 | |
|         alias_method :export_custom_routes?, :export_custom_routes
 | |
|       
 | |
|         # This field will be deprecated soon. Prefer using import_custom_routes in
 | |
|         # network_peering instead. Whether to import the custom routes from peer network.
 | |
|         # Corresponds to the JSON property `importCustomRoutes`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :import_custom_routes
 | |
|         alias_method :import_custom_routes?, :import_custom_routes
 | |
|       
 | |
|         # Name of the peering, which should conform to RFC1035.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # A network peering attached to a network resource. The message includes the
 | |
|         # peering name, peer network, peering state, and a flag indicating whether
 | |
|         # Google Compute Engine should automatically create routes for the peering.
 | |
|         # Corresponds to the JSON property `networkPeering`
 | |
|         # @return [Google::Apis::ComputeAlpha::NetworkPeering]
 | |
|         attr_accessor :network_peering
 | |
|       
 | |
|         # URL of the peer network. It can be either full URL or partial URL. The peer
 | |
|         # network may belong to a different project. If the partial URL does not contain
 | |
|         # project, it is assumed that the peer network is in the same project as the
 | |
|         # current network.
 | |
|         # Corresponds to the JSON property `peerNetwork`
 | |
|         # @return [String]
 | |
|         attr_accessor :peer_network
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @auto_create_routes = args[:auto_create_routes] if args.key?(:auto_create_routes)
 | |
|           @export_custom_routes = args[:export_custom_routes] if args.key?(:export_custom_routes)
 | |
|           @import_custom_routes = args[:import_custom_routes] if args.key?(:import_custom_routes)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @network_peering = args[:network_peering] if args.key?(:network_peering)
 | |
|           @peer_network = args[:peer_network] if args.key?(:peer_network)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NetworksRemovePeeringRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Name of the peering, which should conform to RFC1035.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NetworksUpdatePeeringRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A network peering attached to a network resource. The message includes the
 | |
|         # peering name, peer network, peering state, and a flag indicating whether
 | |
|         # Google Compute Engine should automatically create routes for the peering.
 | |
|         # Corresponds to the JSON property `networkPeering`
 | |
|         # @return [Google::Apis::ComputeAlpha::NetworkPeering]
 | |
|         attr_accessor :network_peering
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @network_peering = args[:network_peering] if args.key?(:network_peering)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A NodeGroup resource.
 | |
|       class NodeGroup
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `autoscalingPolicy`
 | |
|         # @return [Google::Apis::ComputeAlpha::NodeGroupAutoscalingPolicy]
 | |
|         attr_accessor :autoscaling_policy
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] The type of the resource. Always compute#nodeGroup for node
 | |
|         # group.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # The name of the resource, provided by the client when initially creating the
 | |
|         # resource. The resource 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # The URL of the node template to which this node group belongs.
 | |
|         # Corresponds to the JSON property `nodeTemplate`
 | |
|         # @return [String]
 | |
|         attr_accessor :node_template
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # [Output Only] The total number of nodes in the node group.
 | |
|         # Corresponds to the JSON property `size`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :size
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `status`
 | |
|         # @return [String]
 | |
|         attr_accessor :status
 | |
|       
 | |
|         # [Output Only] The name of the zone where the node group resides, such as us-
 | |
|         # central1-a.
 | |
|         # Corresponds to the JSON property `zone`
 | |
|         # @return [String]
 | |
|         attr_accessor :zone
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @autoscaling_policy = args[:autoscaling_policy] if args.key?(:autoscaling_policy)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @node_template = args[:node_template] if args.key?(:node_template)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @size = args[:size] if args.key?(:size)
 | |
|           @status = args[:status] if args.key?(:status)
 | |
|           @zone = args[:zone] if args.key?(:zone)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NodeGroupAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of NodeGroupsScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::NodeGroupsScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource.Always compute#nodeGroupAggregatedList for
 | |
|         # aggregated lists of node groups.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::NodeGroupAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::NodeGroupAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NodeGroupAutoscalingPolicy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `maxSize`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :max_size
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `minSize`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :min_size
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @max_size = args[:max_size] if args.key?(:max_size)
 | |
|           @min_size = args[:min_size] if args.key?(:min_size)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of nodeGroups.
 | |
|       class NodeGroupList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of NodeGroup resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::NodeGroup>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource.Always compute#nodeGroupList for lists of node
 | |
|         # groups.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::NodeGroupList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::NodeGroupList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NodeGroupNode
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Instances scheduled on this node.
 | |
|         # Corresponds to the JSON property `instances`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :instances
 | |
|       
 | |
|         # The name of the node.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # The type of this node.
 | |
|         # Corresponds to the JSON property `nodeType`
 | |
|         # @return [String]
 | |
|         attr_accessor :node_type
 | |
|       
 | |
|         # Binding properties for the physical server.
 | |
|         # Corresponds to the JSON property `serverBinding`
 | |
|         # @return [Google::Apis::ComputeAlpha::ServerBinding]
 | |
|         attr_accessor :server_binding
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `status`
 | |
|         # @return [String]
 | |
|         attr_accessor :status
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instances = args[:instances] if args.key?(:instances)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @node_type = args[:node_type] if args.key?(:node_type)
 | |
|           @server_binding = args[:server_binding] if args.key?(:server_binding)
 | |
|           @status = args[:status] if args.key?(:status)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NodeGroupsAddNodesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Count of additional nodes to be added to the node group.
 | |
|         # Corresponds to the JSON property `additionalNodeCount`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :additional_node_count
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @additional_node_count = args[:additional_node_count] if args.key?(:additional_node_count)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NodeGroupsDeleteNodesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `nodes`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :nodes
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @nodes = args[:nodes] if args.key?(:nodes)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NodeGroupsListNodes
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of Node resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::NodeGroupNode>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] The resource type, which is always compute.nodeGroupsListNodes
 | |
|         # for the list of nodes in the specified node group.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::NodeGroupsListNodes::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::NodeGroupsListNodes::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NodeGroupsScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] A list of node groups contained in this scope.
 | |
|         # Corresponds to the JSON property `nodeGroups`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::NodeGroup>]
 | |
|         attr_accessor :node_groups
 | |
|       
 | |
|         # [Output Only] An informational warning that appears when the nodeGroup list is
 | |
|         # empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::NodeGroupsScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @node_groups = args[:node_groups] if args.key?(:node_groups)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] An informational warning that appears when the nodeGroup list is
 | |
|         # empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::NodeGroupsScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NodeGroupsSetAutoscalingPolicyRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `autoscalingPolicy`
 | |
|         # @return [Google::Apis::ComputeAlpha::NodeGroupAutoscalingPolicy]
 | |
|         attr_accessor :autoscaling_policy
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @autoscaling_policy = args[:autoscaling_policy] if args.key?(:autoscaling_policy)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NodeGroupsSetNodeTemplateRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Full or partial URL of the node template resource to be updated for this node
 | |
|         # group.
 | |
|         # Corresponds to the JSON property `nodeTemplate`
 | |
|         # @return [String]
 | |
|         attr_accessor :node_template
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @node_template = args[:node_template] if args.key?(:node_template)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A Node Template resource.
 | |
|       class NodeTemplate
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] The type of the resource. Always compute#nodeTemplate for node
 | |
|         # templates.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # The name of the resource, provided by the client when initially creating the
 | |
|         # resource. The resource 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # Labels to use for node affinity, which will be used in instance scheduling.
 | |
|         # Corresponds to the JSON property `nodeAffinityLabels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :node_affinity_labels
 | |
|       
 | |
|         # The node type to use for nodes group that are created from this template.
 | |
|         # Corresponds to the JSON property `nodeType`
 | |
|         # @return [String]
 | |
|         attr_accessor :node_type
 | |
|       
 | |
|         # The flexible properties of the desired node type. Node groups that use this
 | |
|         # node template will create nodes of a type that matches these properties.
 | |
|         # This field is mutually exclusive with the node_type property; you can only
 | |
|         # define one or the other, but not both.
 | |
|         # Corresponds to the JSON property `nodeTypeFlexibility`
 | |
|         # @return [Google::Apis::ComputeAlpha::NodeTemplateNodeTypeFlexibility]
 | |
|         attr_accessor :node_type_flexibility
 | |
|       
 | |
|         # [Output Only] The name of the region where the node template resides, such as
 | |
|         # us-central1.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # Binding properties for the physical server.
 | |
|         # Corresponds to the JSON property `serverBinding`
 | |
|         # @return [Google::Apis::ComputeAlpha::ServerBinding]
 | |
|         attr_accessor :server_binding
 | |
|       
 | |
|         # [Output Only] The status of the node template. One of the following values:
 | |
|         # CREATING, READY, and DELETING.
 | |
|         # Corresponds to the JSON property `status`
 | |
|         # @return [String]
 | |
|         attr_accessor :status
 | |
|       
 | |
|         # [Output Only] An optional, human-readable explanation of the status.
 | |
|         # Corresponds to the JSON property `statusMessage`
 | |
|         # @return [String]
 | |
|         attr_accessor :status_message
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @node_affinity_labels = args[:node_affinity_labels] if args.key?(:node_affinity_labels)
 | |
|           @node_type = args[:node_type] if args.key?(:node_type)
 | |
|           @node_type_flexibility = args[:node_type_flexibility] if args.key?(:node_type_flexibility)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @server_binding = args[:server_binding] if args.key?(:server_binding)
 | |
|           @status = args[:status] if args.key?(:status)
 | |
|           @status_message = args[:status_message] if args.key?(:status_message)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NodeTemplateAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of NodeTemplatesScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::NodeTemplatesScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource.Always compute#nodeTemplateAggregatedList for
 | |
|         # aggregated lists of node templates.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::NodeTemplateAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::NodeTemplateAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of node templates.
 | |
|       class NodeTemplateList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of NodeTemplate resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::NodeTemplate>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource.Always compute#nodeTemplateList for lists of
 | |
|         # node templates.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::NodeTemplateList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::NodeTemplateList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NodeTemplateNodeTypeFlexibility
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `cpus`
 | |
|         # @return [String]
 | |
|         attr_accessor :cpus
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `localSsd`
 | |
|         # @return [String]
 | |
|         attr_accessor :local_ssd
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `memory`
 | |
|         # @return [String]
 | |
|         attr_accessor :memory
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @cpus = args[:cpus] if args.key?(:cpus)
 | |
|           @local_ssd = args[:local_ssd] if args.key?(:local_ssd)
 | |
|           @memory = args[:memory] if args.key?(:memory)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NodeTemplatesScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] A list of node templates contained in this scope.
 | |
|         # Corresponds to the JSON property `nodeTemplates`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::NodeTemplate>]
 | |
|         attr_accessor :node_templates
 | |
|       
 | |
|         # [Output Only] An informational warning that appears when the node templates
 | |
|         # list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::NodeTemplatesScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @node_templates = args[:node_templates] if args.key?(:node_templates)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] An informational warning that appears when the node templates
 | |
|         # list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::NodeTemplatesScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A Node Type resource.
 | |
|       class NodeType
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The CPU platform used by this node type.
 | |
|         # Corresponds to the JSON property `cpuPlatform`
 | |
|         # @return [String]
 | |
|         attr_accessor :cpu_platform
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # Deprecation status for a public resource.
 | |
|         # Corresponds to the JSON property `deprecated`
 | |
|         # @return [Google::Apis::ComputeAlpha::DeprecationStatus]
 | |
|         attr_accessor :deprecated
 | |
|       
 | |
|         # [Output Only] An optional textual description of the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The number of virtual CPUs that are available to the node type.
 | |
|         # Corresponds to the JSON property `guestCpus`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :guest_cpus
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] The type of the resource. Always compute#nodeType for node types.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] Local SSD available to the node type, defined in GB.
 | |
|         # Corresponds to the JSON property `localSsdGb`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :local_ssd_gb
 | |
|       
 | |
|         # [Output Only] The amount of physical memory available to the node type,
 | |
|         # defined in MB.
 | |
|         # Corresponds to the JSON property `memoryMb`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :memory_mb
 | |
|       
 | |
|         # [Output Only] Name of the resource.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # [Output Only] The name of the zone where the node type resides, such as us-
 | |
|         # central1-a.
 | |
|         # Corresponds to the JSON property `zone`
 | |
|         # @return [String]
 | |
|         attr_accessor :zone
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @cpu_platform = args[:cpu_platform] if args.key?(:cpu_platform)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @deprecated = args[:deprecated] if args.key?(:deprecated)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @guest_cpus = args[:guest_cpus] if args.key?(:guest_cpus)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @local_ssd_gb = args[:local_ssd_gb] if args.key?(:local_ssd_gb)
 | |
|           @memory_mb = args[:memory_mb] if args.key?(:memory_mb)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @zone = args[:zone] if args.key?(:zone)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NodeTypeAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of NodeTypesScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::NodeTypesScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource.Always compute#nodeTypeAggregatedList for
 | |
|         # aggregated lists of node types.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::NodeTypeAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::NodeTypeAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of node types.
 | |
|       class NodeTypeList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of NodeType resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::NodeType>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource.Always compute#nodeTypeList for lists of node
 | |
|         # types.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::NodeTypeList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::NodeTypeList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class NodeTypesScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] A list of node types contained in this scope.
 | |
|         # Corresponds to the JSON property `nodeTypes`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::NodeType>]
 | |
|         attr_accessor :node_types
 | |
|       
 | |
|         # [Output Only] An informational warning that appears when the node types list
 | |
|         # is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::NodeTypesScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @node_types = args[:node_types] if args.key?(:node_types)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] An informational warning that appears when the node types list
 | |
|         # is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::NodeTypesScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # An Operation resource, used to manage asynchronous API requests. (==
 | |
|       # resource_for v1.globalOperations ==) (== resource_for beta.globalOperations ==)
 | |
|       # (== resource_for v1.regionOperations ==) (== resource_for beta.
 | |
|       # regionOperations ==) (== resource_for v1.zoneOperations ==) (== resource_for
 | |
|       # beta.zoneOperations ==)
 | |
|       class Operation
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The value of `requestId` if you provided it in the request. Not
 | |
|         # present otherwise.
 | |
|         # Corresponds to the JSON property `clientOperationId`
 | |
|         # @return [String]
 | |
|         attr_accessor :client_operation_id
 | |
|       
 | |
|         # [Deprecated] This field is deprecated.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # [Output Only] A textual description of the operation, which is set when the
 | |
|         # operation is created.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The time that this operation was completed. This value is in
 | |
|         # RFC3339 text format.
 | |
|         # Corresponds to the JSON property `endTime`
 | |
|         # @return [String]
 | |
|         attr_accessor :end_time
 | |
|       
 | |
|         # [Output Only] If errors are generated during processing of the operation, this
 | |
|         # field will be populated.
 | |
|         # Corresponds to the JSON property `error`
 | |
|         # @return [Google::Apis::ComputeAlpha::Operation::Error]
 | |
|         attr_accessor :error
 | |
|       
 | |
|         # [Output Only] If the operation fails, this field contains the HTTP error
 | |
|         # message that was returned, such as NOT FOUND.
 | |
|         # Corresponds to the JSON property `httpErrorMessage`
 | |
|         # @return [String]
 | |
|         attr_accessor :http_error_message
 | |
|       
 | |
|         # [Output Only] If the operation fails, this field contains the HTTP error
 | |
|         # status code that was returned. For example, a 404 means the resource was not
 | |
|         # found.
 | |
|         # Corresponds to the JSON property `httpErrorStatusCode`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :http_error_status_code
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] The time that this operation was requested. This value is in
 | |
|         # RFC3339 text format.
 | |
|         # Corresponds to the JSON property `insertTime`
 | |
|         # @return [String]
 | |
|         attr_accessor :insert_time
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#operation for Operation
 | |
|         # resources.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] Name of the resource.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # [Output Only] The type of operation, such as insert, update, or delete, and so
 | |
|         # on.
 | |
|         # Corresponds to the JSON property `operationType`
 | |
|         # @return [String]
 | |
|         attr_accessor :operation_type
 | |
|       
 | |
|         # [Output Only] An optional progress indicator that ranges from 0 to 100. There
 | |
|         # is no requirement that this be linear or support any granularity of operations.
 | |
|         # This should not be used to guess when the operation will be complete. This
 | |
|         # number should monotonically increase as the operation progresses.
 | |
|         # Corresponds to the JSON property `progress`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :progress
 | |
|       
 | |
|         # [Output Only] The URL of the region where the operation resides. Only
 | |
|         # available when performing regional operations. You must specify this field as
 | |
|         # part of the HTTP request URL. It is not settable as a field in the request
 | |
|         # body.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # [Output Only] The time that this operation was started by the server. This
 | |
|         # value is in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `startTime`
 | |
|         # @return [String]
 | |
|         attr_accessor :start_time
 | |
|       
 | |
|         # [Output Only] The status of the operation, which can be one of the following:
 | |
|         # PENDING, RUNNING, or DONE.
 | |
|         # Corresponds to the JSON property `status`
 | |
|         # @return [String]
 | |
|         attr_accessor :status
 | |
|       
 | |
|         # [Output Only] An optional textual description of the current status of the
 | |
|         # operation.
 | |
|         # Corresponds to the JSON property `statusMessage`
 | |
|         # @return [String]
 | |
|         attr_accessor :status_message
 | |
|       
 | |
|         # [Output Only] The unique target ID, which identifies a specific incarnation of
 | |
|         # the target resource.
 | |
|         # Corresponds to the JSON property `targetId`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :target_id
 | |
|       
 | |
|         # [Output Only] The URL of the resource that the operation modifies. For
 | |
|         # operations related to creating a snapshot, this points to the persistent disk
 | |
|         # that the snapshot was created from.
 | |
|         # Corresponds to the JSON property `targetLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :target_link
 | |
|       
 | |
|         # [Output Only] User who requested the operation, for example: user@example.com.
 | |
|         # Corresponds to the JSON property `user`
 | |
|         # @return [String]
 | |
|         attr_accessor :user
 | |
|       
 | |
|         # [Output Only] If warning messages are generated during processing of the
 | |
|         # operation, this field will be populated.
 | |
|         # Corresponds to the JSON property `warnings`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Operation::Warning>]
 | |
|         attr_accessor :warnings
 | |
|       
 | |
|         # [Output Only] The URL of the zone where the operation resides. Only available
 | |
|         # when performing per-zone operations. You must specify this field as part of
 | |
|         # the HTTP request URL. It is not settable as a field in the request body.
 | |
|         # Corresponds to the JSON property `zone`
 | |
|         # @return [String]
 | |
|         attr_accessor :zone
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @client_operation_id = args[:client_operation_id] if args.key?(:client_operation_id)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @end_time = args[:end_time] if args.key?(:end_time)
 | |
|           @error = args[:error] if args.key?(:error)
 | |
|           @http_error_message = args[:http_error_message] if args.key?(:http_error_message)
 | |
|           @http_error_status_code = args[:http_error_status_code] if args.key?(:http_error_status_code)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @insert_time = args[:insert_time] if args.key?(:insert_time)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @operation_type = args[:operation_type] if args.key?(:operation_type)
 | |
|           @progress = args[:progress] if args.key?(:progress)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @start_time = args[:start_time] if args.key?(:start_time)
 | |
|           @status = args[:status] if args.key?(:status)
 | |
|           @status_message = args[:status_message] if args.key?(:status_message)
 | |
|           @target_id = args[:target_id] if args.key?(:target_id)
 | |
|           @target_link = args[:target_link] if args.key?(:target_link)
 | |
|           @user = args[:user] if args.key?(:user)
 | |
|           @warnings = args[:warnings] if args.key?(:warnings)
 | |
|           @zone = args[:zone] if args.key?(:zone)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] If errors are generated during processing of the operation, this
 | |
|         # field will be populated.
 | |
|         class Error
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] The array of errors encountered while processing this operation.
 | |
|           # Corresponds to the JSON property `errors`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::Operation::Error::Error>]
 | |
|           attr_accessor :errors
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @errors = args[:errors] if args.key?(:errors)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Error
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] The error type identifier for this error.
 | |
|             # Corresponds to the JSON property `code`
 | |
|             # @return [String]
 | |
|             attr_accessor :code
 | |
|           
 | |
|             # [Output Only] Indicates the field in the request that caused the error. This
 | |
|             # property is optional.
 | |
|             # Corresponds to the JSON property `location`
 | |
|             # @return [String]
 | |
|             attr_accessor :location
 | |
|           
 | |
|             # [Output Only] An optional, human-readable error message.
 | |
|             # Corresponds to the JSON property `message`
 | |
|             # @return [String]
 | |
|             attr_accessor :message
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @code = args[:code] if args.key?(:code)
 | |
|               @location = args[:location] if args.key?(:location)
 | |
|               @message = args[:message] if args.key?(:message)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|         
 | |
|         # 
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::Operation::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class OperationAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] A map of scoped operation lists.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::OperationsScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#operationAggregatedList for
 | |
|         # aggregated lists of operations.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::OperationAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::OperationAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of Operation resources.
 | |
|       class OperationList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] A list of Operation resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Operation>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#operations for Operations
 | |
|         # resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::OperationList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::OperationList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class OperationsScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] A list of operations contained in this scope.
 | |
|         # Corresponds to the JSON property `operations`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Operation>]
 | |
|         attr_accessor :operations
 | |
|       
 | |
|         # [Output Only] Informational warning which replaces the list of operations when
 | |
|         # the list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::OperationsScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @operations = args[:operations] if args.key?(:operations)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning which replaces the list of operations when
 | |
|         # the list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::OperationsScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A matcher for the path portion of the URL. The BackendService from the longest-
 | |
|       # matched rule will serve the URL. If no rule was matched, the default service
 | |
|       # will be used.
 | |
|       class PathMatcher
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # defaultRouteAction takes effect when none of the  pathRules or routeRules
 | |
|         # match. The load balancer performs advanced routing actions like URL rewrites,
 | |
|         # header transformations, etc. prior to forwarding the request to the selected
 | |
|         # backend. If defaultRouteAction specifies any weightedBackendServices,
 | |
|         # defaultService must not be set. Conversely if defaultService is set,
 | |
|         # defaultRouteAction cannot contain any  weightedBackendServices.
 | |
|         # Only one of defaultRouteAction or defaultUrlRedirect must be set.
 | |
|         # Corresponds to the JSON property `defaultRouteAction`
 | |
|         # @return [Google::Apis::ComputeAlpha::HttpRouteAction]
 | |
|         attr_accessor :default_route_action
 | |
|       
 | |
|         # The full or partial URL to the BackendService resource. This will be used if
 | |
|         # none of the pathRules or routeRules defined by this PathMatcher are matched.
 | |
|         # For example, the following are all valid URLs to a BackendService resource:
 | |
|         # - https://www.googleapis.com/compute/v1/projects/project/global/
 | |
|         # backendServices/backendService
 | |
|         # - compute/v1/projects/project/global/backendServices/backendService
 | |
|         # - global/backendServices/backendService  If defaultRouteAction is additionally
 | |
|         # specified, advanced routing actions like URL Rewrites, etc. take effect prior
 | |
|         # to sending the request to the backend. However, if defaultService is specified,
 | |
|         # defaultRouteAction cannot contain any weightedBackendServices. Conversely, if
 | |
|         # defaultRouteAction specifies any weightedBackendServices, defaultService must
 | |
|         # not be specified.
 | |
|         # Only one of defaultService, defaultUrlRedirect  or defaultRouteAction.
 | |
|         # weightedBackendService must be set.
 | |
|         # Authorization requires one or more of the following Google IAM permissions on
 | |
|         # the specified resource default_service:
 | |
|         # - compute.backendBuckets.use
 | |
|         # - compute.backendServices.use
 | |
|         # Corresponds to the JSON property `defaultService`
 | |
|         # @return [String]
 | |
|         attr_accessor :default_service
 | |
|       
 | |
|         # Specifies settings for an HTTP redirect.
 | |
|         # Corresponds to the JSON property `defaultUrlRedirect`
 | |
|         # @return [Google::Apis::ComputeAlpha::HttpRedirectAction]
 | |
|         attr_accessor :default_url_redirect
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # The request and response header transformations that take effect before the
 | |
|         # request is passed along to the selected backendService.
 | |
|         # Corresponds to the JSON property `headerAction`
 | |
|         # @return [Google::Apis::ComputeAlpha::HttpHeaderAction]
 | |
|         attr_accessor :header_action
 | |
|       
 | |
|         # The name to which this PathMatcher is referred by the HostRule.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # 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.
 | |
|         # Only one of pathRules or routeRules must be set.
 | |
|         # Corresponds to the JSON property `pathRules`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::PathRule>]
 | |
|         attr_accessor :path_rules
 | |
|       
 | |
|         # 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.
 | |
|         # Only one of pathRules or routeRules must be set.
 | |
|         # Corresponds to the JSON property `routeRules`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::HttpRouteRule>]
 | |
|         attr_accessor :route_rules
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @default_route_action = args[:default_route_action] if args.key?(:default_route_action)
 | |
|           @default_service = args[:default_service] if args.key?(:default_service)
 | |
|           @default_url_redirect = args[:default_url_redirect] if args.key?(:default_url_redirect)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @header_action = args[:header_action] if args.key?(:header_action)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @path_rules = args[:path_rules] if args.key?(:path_rules)
 | |
|           @route_rules = args[:route_rules] if args.key?(:route_rules)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A path-matching rule for a URL. If matched, will use the specified
 | |
|       # BackendService to handle the traffic arriving at this URL.
 | |
|       class PathRule
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `paths`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :paths
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `routeAction`
 | |
|         # @return [Google::Apis::ComputeAlpha::HttpRouteAction]
 | |
|         attr_accessor :route_action
 | |
|       
 | |
|         # The full or partial URL of the 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.
 | |
|         # Corresponds to the JSON property `service`
 | |
|         # @return [String]
 | |
|         attr_accessor :service
 | |
|       
 | |
|         # Specifies settings for an HTTP redirect.
 | |
|         # Corresponds to the JSON property `urlRedirect`
 | |
|         # @return [Google::Apis::ComputeAlpha::HttpRedirectAction]
 | |
|         attr_accessor :url_redirect
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @paths = args[:paths] if args.key?(:paths)
 | |
|           @route_action = args[:route_action] if args.key?(:route_action)
 | |
|           @service = args[:service] if args.key?(:service)
 | |
|           @url_redirect = args[:url_redirect] if args.key?(:url_redirect)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class PerInstanceConfig
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Fingerprint of this per-instance config. This field may be used in optimistic
 | |
|         # locking. It will be ignored when inserting a per-instance config. An up-to-
 | |
|         # date fingerprint must be provided in order to update an existing per-instance
 | |
|         # config or the field needs to be unset.
 | |
|         # Corresponds to the JSON property `fingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :fingerprint
 | |
|       
 | |
|         # The URL of the instance. Serves as a merge key during UpdatePerInstanceConfigs
 | |
|         # operation, i.e. if per-instance config with the same instance URL exists then
 | |
|         # it will be updated, otherwise a new one will be created.
 | |
|         # Corresponds to the JSON property `instance`
 | |
|         # @return [String]
 | |
|         attr_accessor :instance
 | |
|       
 | |
|         # The name of the per-instance config and the corresponding instance. Serves as
 | |
|         # a merge key during UpdatePerInstanceConfigs operation, i.e. if per-instance
 | |
|         # config with the same name exists then it will be updated, otherwise a new one
 | |
|         # will be created for the VM instance with the same name. An attempt to create a
 | |
|         # per-instance config for a VM instance that either doesn't exist or is not part
 | |
|         # of the group will result in a failure.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # Overrides of stateful properties for a given instance
 | |
|         # Corresponds to the JSON property `override`
 | |
|         # @return [Google::Apis::ComputeAlpha::ManagedInstanceOverride]
 | |
|         attr_accessor :override
 | |
|       
 | |
|         # Preserved state for a given instance.
 | |
|         # Corresponds to the JSON property `preservedState`
 | |
|         # @return [Google::Apis::ComputeAlpha::PreservedState]
 | |
|         attr_accessor :preserved_state
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @fingerprint = args[:fingerprint] if args.key?(:fingerprint)
 | |
|           @instance = args[:instance] if args.key?(:instance)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @override = args[:override] if args.key?(:override)
 | |
|           @preserved_state = args[:preserved_state] if args.key?(:preserved_state)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Defines an Identity and Access Management (IAM) policy. It is used to specify
 | |
|       # access control policies for Cloud Platform resources.
 | |
|       # A `Policy` consists of a list of `bindings`. A `binding` binds a list of `
 | |
|       # members` to a `role`, where the members can be user accounts, Google groups,
 | |
|       # Google domains, and service accounts. A `role` is a named list of permissions
 | |
|       # defined by IAM.
 | |
|       # **JSON Example**
 | |
|       # ` "bindings": [ ` "role": "roles/owner", "members": [ "user:mike@example.com",
 | |
|       # "group:admins@example.com", "domain:google.com", "serviceAccount:my-other-app@
 | |
|       # appspot.gserviceaccount.com" ] `, ` "role": "roles/viewer", "members": ["user:
 | |
|       # sean@example.com"] ` ] `
 | |
|       # **YAML Example**
 | |
|       # bindings: - members: - user:mike@example.com - group:admins@example.com -
 | |
|       # domain:google.com - serviceAccount:my-other-app@appspot.gserviceaccount.com
 | |
|       # role: roles/owner - members: - user:sean@example.com role: roles/viewer
 | |
|       # For a description of IAM and its features, see the [IAM developer's guide](
 | |
|       # https://cloud.google.com/iam/docs).
 | |
|       class Policy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Specifies cloud audit logging configuration for this policy.
 | |
|         # Corresponds to the JSON property `auditConfigs`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::AuditConfig>]
 | |
|         attr_accessor :audit_configs
 | |
|       
 | |
|         # Associates a list of `members` to a `role`. `bindings` with no members will
 | |
|         # result in an error.
 | |
|         # Corresponds to the JSON property `bindings`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Binding>]
 | |
|         attr_accessor :bindings
 | |
|       
 | |
|         # `etag` is used for optimistic concurrency control as a way to help prevent
 | |
|         # simultaneous updates of a policy from overwriting each other. It is strongly
 | |
|         # suggested that systems make use of the `etag` in the read-modify-write cycle
 | |
|         # to perform policy updates in order to avoid race conditions: An `etag` is
 | |
|         # returned in the response to `getIamPolicy`, and systems are expected to put
 | |
|         # that etag in the request to `setIamPolicy` to ensure that their change will be
 | |
|         # applied to the same version of the policy.
 | |
|         # If no `etag` is provided in the call to `setIamPolicy`, then the existing
 | |
|         # policy is overwritten blindly.
 | |
|         # Corresponds to the JSON property `etag`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :etag
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `iamOwned`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :iam_owned
 | |
|         alias_method :iam_owned?, :iam_owned
 | |
|       
 | |
|         # If more than one rule is specified, the rules are applied in the following
 | |
|         # manner: - All matching LOG rules are always applied. - If any DENY/
 | |
|         # DENY_WITH_LOG rule matches, permission is denied. Logging will be applied if
 | |
|         # one or more matching rule requires logging. - Otherwise, if any ALLOW/
 | |
|         # ALLOW_WITH_LOG rule matches, permission is granted. Logging will be applied if
 | |
|         # one or more matching rule requires logging. - Otherwise, if no rule applies,
 | |
|         # permission is denied.
 | |
|         # Corresponds to the JSON property `rules`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Rule>]
 | |
|         attr_accessor :rules
 | |
|       
 | |
|         # Deprecated.
 | |
|         # Corresponds to the JSON property `version`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :version
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @audit_configs = args[:audit_configs] if args.key?(:audit_configs)
 | |
|           @bindings = args[:bindings] if args.key?(:bindings)
 | |
|           @etag = args[:etag] if args.key?(:etag)
 | |
|           @iam_owned = args[:iam_owned] if args.key?(:iam_owned)
 | |
|           @rules = args[:rules] if args.key?(:rules)
 | |
|           @version = args[:version] if args.key?(:version)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class PreconfiguredWafSet
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # List of entities that are currently supported for WAF rules.
 | |
|         # Corresponds to the JSON property `expressionSets`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::WafExpressionSet>]
 | |
|         attr_accessor :expression_sets
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @expression_sets = args[:expression_sets] if args.key?(:expression_sets)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Preserved state for a given instance.
 | |
|       class PreservedState
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Preserved disks defined for this instance. This map is keyed with the device
 | |
|         # names of the disks.
 | |
|         # Corresponds to the JSON property `disks`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::PreservedStatePreservedDisk>]
 | |
|         attr_accessor :disks
 | |
|       
 | |
|         # Preserved metadata defined for this instance.
 | |
|         # Corresponds to the JSON property `metadata`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :metadata
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @disks = args[:disks] if args.key?(:disks)
 | |
|           @metadata = args[:metadata] if args.key?(:metadata)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class PreservedStatePreservedDisk
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # These stateful disks will never be deleted during autohealing, update,
 | |
|         # instance recreate operations. This flag is used to configure if the disk
 | |
|         # should be deleted after it is no longer used by the group, e.g. when the given
 | |
|         # instance or the whole MIG is deleted. Note: disks attached in READ_ONLY mode
 | |
|         # cannot be auto-deleted.
 | |
|         # Corresponds to the JSON property `autoDelete`
 | |
|         # @return [String]
 | |
|         attr_accessor :auto_delete
 | |
|       
 | |
|         # The mode in which to attach this disk, either READ_WRITE or READ_ONLY. If not
 | |
|         # specified, the default is to attach the disk in READ_WRITE mode.
 | |
|         # Corresponds to the JSON property `mode`
 | |
|         # @return [String]
 | |
|         attr_accessor :mode
 | |
|       
 | |
|         # The URL of the disk resource that is stateful and should be attached to the VM
 | |
|         # instance.
 | |
|         # Corresponds to the JSON property `source`
 | |
|         # @return [String]
 | |
|         attr_accessor :source
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @auto_delete = args[:auto_delete] if args.key?(:auto_delete)
 | |
|           @mode = args[:mode] if args.key?(:mode)
 | |
|           @source = args[:source] if args.key?(:source)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A Project resource. For an overview of projects, see  Cloud Platform Resource
 | |
|       # Hierarchy. (== resource_for v1.projects ==) (== resource_for beta.projects ==)
 | |
|       class Project
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A metadata key/value entry.
 | |
|         # Corresponds to the JSON property `commonInstanceMetadata`
 | |
|         # @return [Google::Apis::ComputeAlpha::Metadata]
 | |
|         attr_accessor :common_instance_metadata
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # This signifies the default network tier used for configuring resources of the
 | |
|         # project and can only take the following values: PREMIUM, STANDARD. Initially
 | |
|         # the default network tier is PREMIUM.
 | |
|         # Corresponds to the JSON property `defaultNetworkTier`
 | |
|         # @return [String]
 | |
|         attr_accessor :default_network_tier
 | |
|       
 | |
|         # [Output Only] Default service account used by VMs running in this project.
 | |
|         # Corresponds to the JSON property `defaultServiceAccount`
 | |
|         # @return [String]
 | |
|         attr_accessor :default_service_account
 | |
|       
 | |
|         # An optional textual description of the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # Restricted features enabled for use on this project.
 | |
|         # Corresponds to the JSON property `enabledFeatures`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :enabled_features
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server. This is not the project ID, and is just a unique ID
 | |
|         # used by Compute Engine to identify resources.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#project for projects.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # The project ID. For example: my-example-project. Use the project ID to make
 | |
|         # requests to Compute Engine.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # [Output Only] Quotas assigned to this project.
 | |
|         # Corresponds to the JSON property `quotas`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Quota>]
 | |
|         attr_accessor :quotas
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # The location in Cloud Storage and naming method of the daily usage report.
 | |
|         # Contains bucket_name and report_name prefix.
 | |
|         # Corresponds to the JSON property `usageExportLocation`
 | |
|         # @return [Google::Apis::ComputeAlpha::UsageExportLocation]
 | |
|         attr_accessor :usage_export_location
 | |
|       
 | |
|         # [Output Only] The role this project has in a shared VPC configuration.
 | |
|         # Currently only HOST projects are differentiated.
 | |
|         # Corresponds to the JSON property `xpnProjectStatus`
 | |
|         # @return [String]
 | |
|         attr_accessor :xpn_project_status
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @common_instance_metadata = args[:common_instance_metadata] if args.key?(:common_instance_metadata)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @default_network_tier = args[:default_network_tier] if args.key?(:default_network_tier)
 | |
|           @default_service_account = args[:default_service_account] if args.key?(:default_service_account)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @enabled_features = args[:enabled_features] if args.key?(:enabled_features)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @quotas = args[:quotas] if args.key?(:quotas)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @usage_export_location = args[:usage_export_location] if args.key?(:usage_export_location)
 | |
|           @xpn_project_status = args[:xpn_project_status] if args.key?(:xpn_project_status)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ProjectsDisableXpnResourceRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Service resource (a.k.a service project) ID.
 | |
|         # Corresponds to the JSON property `xpnResource`
 | |
|         # @return [Google::Apis::ComputeAlpha::XpnResourceId]
 | |
|         attr_accessor :xpn_resource
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @xpn_resource = args[:xpn_resource] if args.key?(:xpn_resource)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ProjectsEnableXpnResourceRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Service resource (a.k.a service project) ID.
 | |
|         # Corresponds to the JSON property `xpnResource`
 | |
|         # @return [Google::Apis::ComputeAlpha::XpnResourceId]
 | |
|         attr_accessor :xpn_resource
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @xpn_resource = args[:xpn_resource] if args.key?(:xpn_resource)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ProjectsGetXpnResources
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#projectsGetXpnResources for
 | |
|         # lists of service resources (a.k.a service projects)
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # Service resources (a.k.a service projects) attached to this project as their
 | |
|         # shared VPC host.
 | |
|         # Corresponds to the JSON property `resources`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::XpnResourceId>]
 | |
|         attr_accessor :resources
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @resources = args[:resources] if args.key?(:resources)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ProjectsListXpnHostsRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Optional organization ID managed by Cloud Resource Manager, for which to list
 | |
|         # shared VPC host projects. If not specified, the organization will be inferred
 | |
|         # from the project.
 | |
|         # Corresponds to the JSON property `organization`
 | |
|         # @return [String]
 | |
|         attr_accessor :organization
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @organization = args[:organization] if args.key?(:organization)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ProjectsSetDefaultNetworkTierRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Default network tier to be set.
 | |
|         # Corresponds to the JSON property `networkTier`
 | |
|         # @return [String]
 | |
|         attr_accessor :network_tier
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @network_tier = args[:network_tier] if args.key?(:network_tier)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ProjectsSetDefaultServiceAccountRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Email address of the service account.
 | |
|         # Corresponds to the JSON property `email`
 | |
|         # @return [String]
 | |
|         attr_accessor :email
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @email = args[:email] if args.key?(:email)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A quotas entry.
 | |
|       class Quota
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Quota limit for this metric.
 | |
|         # Corresponds to the JSON property `limit`
 | |
|         # @return [Float]
 | |
|         attr_accessor :limit
 | |
|       
 | |
|         # [Output Only] Name of the quota metric.
 | |
|         # Corresponds to the JSON property `metric`
 | |
|         # @return [String]
 | |
|         attr_accessor :metric
 | |
|       
 | |
|         # [Output Only] Owning resource. This is the resource on which this quota is
 | |
|         # applied.
 | |
|         # Corresponds to the JSON property `owner`
 | |
|         # @return [String]
 | |
|         attr_accessor :owner
 | |
|       
 | |
|         # [Output Only] Current usage of this metric.
 | |
|         # Corresponds to the JSON property `usage`
 | |
|         # @return [Float]
 | |
|         attr_accessor :usage
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @limit = args[:limit] if args.key?(:limit)
 | |
|           @metric = args[:metric] if args.key?(:metric)
 | |
|           @owner = args[:owner] if args.key?(:owner)
 | |
|           @usage = args[:usage] if args.key?(:usage)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Represents a reference to a resource.
 | |
|       class Reference
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#reference for references.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # A description of the reference type with no implied semantics. Possible values
 | |
|         # include:
 | |
|         # - MEMBER_OF
 | |
|         # Corresponds to the JSON property `referenceType`
 | |
|         # @return [String]
 | |
|         attr_accessor :reference_type
 | |
|       
 | |
|         # URL of the resource which refers to the target.
 | |
|         # Corresponds to the JSON property `referrer`
 | |
|         # @return [String]
 | |
|         attr_accessor :referrer
 | |
|       
 | |
|         # URL of the resource to which this reference points.
 | |
|         # Corresponds to the JSON property `target`
 | |
|         # @return [String]
 | |
|         attr_accessor :target
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @reference_type = args[:reference_type] if args.key?(:reference_type)
 | |
|           @referrer = args[:referrer] if args.key?(:referrer)
 | |
|           @target = args[:target] if args.key?(:target)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Region resource. (== resource_for beta.regions ==) (== resource_for v1.regions
 | |
|       # ==)
 | |
|       class Region
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # Deprecation status for a public resource.
 | |
|         # Corresponds to the JSON property `deprecated`
 | |
|         # @return [Google::Apis::ComputeAlpha::DeprecationStatus]
 | |
|         attr_accessor :deprecated
 | |
|       
 | |
|         # [Output Only] Textual description of the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#region for regions.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] Name of the resource.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # [Output Only] Quotas assigned to this region.
 | |
|         # Corresponds to the JSON property `quotas`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Quota>]
 | |
|         attr_accessor :quotas
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # [Output Only] Status of the region, either UP or DOWN.
 | |
|         # Corresponds to the JSON property `status`
 | |
|         # @return [String]
 | |
|         attr_accessor :status
 | |
|       
 | |
|         # [Output Only] A list of zones available in this region, in the form of
 | |
|         # resource URLs.
 | |
|         # Corresponds to the JSON property `zones`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :zones
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @deprecated = args[:deprecated] if args.key?(:deprecated)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @quotas = args[:quotas] if args.key?(:quotas)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @status = args[:status] if args.key?(:status)
 | |
|           @zones = args[:zones] if args.key?(:zones)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of autoscalers.
 | |
|       class RegionAutoscalerList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of Autoscaler resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Autoscaler>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::RegionAutoscalerList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::RegionAutoscalerList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RegionDiskTypeList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of DiskType resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::DiskType>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#regionDiskTypeList for region
 | |
|         # disk types.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::RegionDiskTypeList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::RegionDiskTypeList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RegionDisksAddResourcePoliciesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Resource policies to be added to this disk.
 | |
|         # Corresponds to the JSON property `resourcePolicies`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :resource_policies
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @resource_policies = args[:resource_policies] if args.key?(:resource_policies)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RegionDisksRemoveResourcePoliciesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Resource policies to be removed from this disk.
 | |
|         # Corresponds to the JSON property `resourcePolicies`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :resource_policies
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @resource_policies = args[:resource_policies] if args.key?(:resource_policies)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RegionDisksResizeRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The new size of the regional persistent disk, which is specified in GB.
 | |
|         # Corresponds to the JSON property `sizeGb`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :size_gb
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @size_gb = args[:size_gb] if args.key?(:size_gb)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of InstanceGroup resources.
 | |
|       class RegionInstanceGroupList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of InstanceGroup resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InstanceGroup>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # The resource type.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::RegionInstanceGroupList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::RegionInstanceGroupList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # RegionInstanceGroupManagers.deletePerInstanceConfigs
 | |
|       class RegionInstanceGroupManagerDeleteInstanceConfigReq
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The list of instances for which we want to delete per-instance configs on this
 | |
|         # managed instance group.
 | |
|         # Corresponds to the JSON property `instances`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :instances
 | |
|       
 | |
|         # The list of instance names for which we want to delete per-instance configs on
 | |
|         # this managed instance group.
 | |
|         # Corresponds to the JSON property `names`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :names
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instances = args[:instances] if args.key?(:instances)
 | |
|           @names = args[:names] if args.key?(:names)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of managed instance groups.
 | |
|       class RegionInstanceGroupManagerList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of InstanceGroupManager resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InstanceGroupManager>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] The resource type, which is always compute#
 | |
|         # instanceGroupManagerList for a list of managed instance groups that exist in
 | |
|         # th regional scope.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::RegionInstanceGroupManagerList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::RegionInstanceGroupManagerList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # RegionInstanceGroupManagers.updatePerInstanceConfigs
 | |
|       class RegionInstanceGroupManagerUpdateInstanceConfigReq
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The list of per-instance configs to insert or patch on this managed instance
 | |
|         # group.
 | |
|         # Corresponds to the JSON property `perInstanceConfigs`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::PerInstanceConfig>]
 | |
|         attr_accessor :per_instance_configs
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @per_instance_configs = args[:per_instance_configs] if args.key?(:per_instance_configs)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RegionInstanceGroupManagersAbandonInstancesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The URLs of one or more instances to abandon. This can be a full URL or a
 | |
|         # partial URL, such as zones/[ZONE]/instances/[INSTANCE_NAME].
 | |
|         # Corresponds to the JSON property `instances`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :instances
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instances = args[:instances] if args.key?(:instances)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # InstanceGroupManagers.applyUpdatesToInstances
 | |
|       class RegionInstanceGroupManagersApplyUpdatesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The list of instances for which we want to apply changes on this managed
 | |
|         # instance group.
 | |
|         # Corresponds to the JSON property `instances`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :instances
 | |
|       
 | |
|         # The maximal action that should be performed on the instances. By default
 | |
|         # REPLACE. This field is deprecated, please use most_disruptive_allowed_action.
 | |
|         # Corresponds to the JSON property `maximalAction`
 | |
|         # @return [String]
 | |
|         attr_accessor :maximal_action
 | |
|       
 | |
|         # The minimal action that should be perfomed on the instances. By default NONE.
 | |
|         # Corresponds to the JSON property `minimalAction`
 | |
|         # @return [String]
 | |
|         attr_accessor :minimal_action
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instances = args[:instances] if args.key?(:instances)
 | |
|           @maximal_action = args[:maximal_action] if args.key?(:maximal_action)
 | |
|           @minimal_action = args[:minimal_action] if args.key?(:minimal_action)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # RegionInstanceGroupManagers.createInstances
 | |
|       class RegionInstanceGroupManagersCreateInstancesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Required] List of specifications of per-instance configs.
 | |
|         # Corresponds to the JSON property `instances`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::PerInstanceConfig>]
 | |
|         attr_accessor :instances
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instances = args[:instances] if args.key?(:instances)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RegionInstanceGroupManagersDeleteInstancesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The URLs of one or more instances to delete. This can be a full URL or a
 | |
|         # partial URL, such as zones/[ZONE]/instances/[INSTANCE_NAME].
 | |
|         # Corresponds to the JSON property `instances`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :instances
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instances = args[:instances] if args.key?(:instances)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RegionInstanceGroupManagersListInstanceConfigsResp
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The list of PerInstanceConfig.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::PerInstanceConfig>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::RegionInstanceGroupManagersListInstanceConfigsResp::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::RegionInstanceGroupManagersListInstanceConfigsResp::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RegionInstanceGroupManagersListInstancesResponse
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of managed instances.
 | |
|         # Corresponds to the JSON property `managedInstances`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::ManagedInstance>]
 | |
|         attr_accessor :managed_instances
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @managed_instances = args[:managed_instances] if args.key?(:managed_instances)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RegionInstanceGroupManagersRecreateRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The URLs of one or more instances to recreate. This can be a full URL or a
 | |
|         # partial URL, such as zones/[ZONE]/instances/[INSTANCE_NAME].
 | |
|         # Corresponds to the JSON property `instances`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :instances
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instances = args[:instances] if args.key?(:instances)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RegionInstanceGroupManagersSetAutoHealingRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `autoHealingPolicies`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InstanceGroupManagerAutoHealingPolicy>]
 | |
|         attr_accessor :auto_healing_policies
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @auto_healing_policies = args[:auto_healing_policies] if args.key?(:auto_healing_policies)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RegionInstanceGroupManagersSetTargetPoolsRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Fingerprint of the target pools information, which is a hash of the contents.
 | |
|         # This field is used for optimistic locking when you update the target pool
 | |
|         # entries. This field is optional.
 | |
|         # Corresponds to the JSON property `fingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :fingerprint
 | |
|       
 | |
|         # The URL of all TargetPool resources to which instances in the instanceGroup
 | |
|         # field are added. The target pools automatically apply to all of the instances
 | |
|         # in the managed instance group.
 | |
|         # Corresponds to the JSON property `targetPools`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :target_pools
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @fingerprint = args[:fingerprint] if args.key?(:fingerprint)
 | |
|           @target_pools = args[:target_pools] if args.key?(:target_pools)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RegionInstanceGroupManagersSetTemplateRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # URL of the InstanceTemplate resource from which all new instances will be
 | |
|         # created.
 | |
|         # Corresponds to the JSON property `instanceTemplate`
 | |
|         # @return [String]
 | |
|         attr_accessor :instance_template
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instance_template = args[:instance_template] if args.key?(:instance_template)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RegionInstanceGroupsListInstances
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of InstanceWithNamedPorts resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InstanceWithNamedPorts>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # The resource type.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::RegionInstanceGroupsListInstances::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::RegionInstanceGroupsListInstances::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RegionInstanceGroupsListInstancesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Instances in which state should be returned. Valid options are: 'ALL', '
 | |
|         # RUNNING'. By default, it lists all instances.
 | |
|         # Corresponds to the JSON property `instanceState`
 | |
|         # @return [String]
 | |
|         attr_accessor :instance_state
 | |
|       
 | |
|         # Name of port user is interested in. It is optional. If it is set, only
 | |
|         # information about this ports will be returned. If it is not set, all the named
 | |
|         # ports will be returned. Always lists all instances.
 | |
|         # Corresponds to the JSON property `portName`
 | |
|         # @return [String]
 | |
|         attr_accessor :port_name
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instance_state = args[:instance_state] if args.key?(:instance_state)
 | |
|           @port_name = args[:port_name] if args.key?(:port_name)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RegionInstanceGroupsSetNamedPortsRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The fingerprint of the named ports information for this instance group. Use
 | |
|         # this optional property to prevent conflicts when multiple users change the
 | |
|         # named ports settings concurrently. Obtain the fingerprint with the
 | |
|         # instanceGroups.get method. Then, include the fingerprint in your request to
 | |
|         # ensure that you do not overwrite changes that were applied from another
 | |
|         # concurrent request.
 | |
|         # Corresponds to the JSON property `fingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :fingerprint
 | |
|       
 | |
|         # The list of named ports to set for this instance group.
 | |
|         # Corresponds to the JSON property `namedPorts`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::NamedPort>]
 | |
|         attr_accessor :named_ports
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @fingerprint = args[:fingerprint] if args.key?(:fingerprint)
 | |
|           @named_ports = args[:named_ports] if args.key?(:named_ports)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of region resources.
 | |
|       class RegionList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of Region resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Region>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#regionList for lists of regions.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::RegionList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::RegionList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RegionSetLabelsRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The fingerprint of the previous set of labels for this resource, used to
 | |
|         # detect conflicts. The fingerprint is initially generated by Compute Engine and
 | |
|         # changes after every request to modify or update labels. You must always
 | |
|         # provide an up-to-date fingerprint hash in order to update or change labels.
 | |
|         # Make a get() request to the resource to get the latest fingerprint.
 | |
|         # Corresponds to the JSON property `labelFingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :label_fingerprint
 | |
|       
 | |
|         # The labels to set for this resource.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RegionSetPolicyRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Flatten Policy to create a backwacd compatible wire-format. Deprecated. Use '
 | |
|         # policy' to specify bindings.
 | |
|         # Corresponds to the JSON property `bindings`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Binding>]
 | |
|         attr_accessor :bindings
 | |
|       
 | |
|         # Flatten Policy to create a backward compatible wire-format. Deprecated. Use '
 | |
|         # policy' to specify the etag.
 | |
|         # Corresponds to the JSON property `etag`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :etag
 | |
|       
 | |
|         # Defines an Identity and Access Management (IAM) policy. It is used to specify
 | |
|         # access control policies for Cloud Platform resources.
 | |
|         # A `Policy` consists of a list of `bindings`. A `binding` binds a list of `
 | |
|         # members` to a `role`, where the members can be user accounts, Google groups,
 | |
|         # Google domains, and service accounts. A `role` is a named list of permissions
 | |
|         # defined by IAM.
 | |
|         # **JSON Example**
 | |
|         # ` "bindings": [ ` "role": "roles/owner", "members": [ "user:mike@example.com",
 | |
|         # "group:admins@example.com", "domain:google.com", "serviceAccount:my-other-app@
 | |
|         # appspot.gserviceaccount.com" ] `, ` "role": "roles/viewer", "members": ["user:
 | |
|         # sean@example.com"] ` ] `
 | |
|         # **YAML Example**
 | |
|         # bindings: - members: - user:mike@example.com - group:admins@example.com -
 | |
|         # domain:google.com - serviceAccount:my-other-app@appspot.gserviceaccount.com
 | |
|         # role: roles/owner - members: - user:sean@example.com role: roles/viewer
 | |
|         # For a description of IAM and its features, see the [IAM developer's guide](
 | |
|         # https://cloud.google.com/iam/docs).
 | |
|         # Corresponds to the JSON property `policy`
 | |
|         # @return [Google::Apis::ComputeAlpha::Policy]
 | |
|         attr_accessor :policy
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @bindings = args[:bindings] if args.key?(:bindings)
 | |
|           @etag = args[:etag] if args.key?(:etag)
 | |
|           @policy = args[:policy] if args.key?(:policy)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RegionTargetHttpsProxiesSetSslCertificatesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # New set of SslCertificate resources to associate with this TargetHttpsProxy
 | |
|         # resource. Currently exactly one SslCertificate resource must be specified.
 | |
|         # Corresponds to the JSON property `sslCertificates`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :ssl_certificates
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @ssl_certificates = args[:ssl_certificates] if args.key?(:ssl_certificates)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RegionUrlMapsValidateRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A UrlMap resource. This resource defines the mapping from URL to the
 | |
|         # BackendService resource, based on the "longest-match" of the URL's host and
 | |
|         # path.
 | |
|         # Corresponds to the JSON property `resource`
 | |
|         # @return [Google::Apis::ComputeAlpha::UrlMap]
 | |
|         attr_accessor :resource
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @resource = args[:resource] if args.key?(:resource)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A policy that specifies 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.
 | |
|       class RequestMirrorPolicy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The full or partial URL to the BackendService resource being mirrored to.
 | |
|         # Corresponds to the JSON property `backendService`
 | |
|         # @return [String]
 | |
|         attr_accessor :backend_service
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @backend_service = args[:backend_service] if args.key?(:backend_service)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Commitment for a particular resource (a Commitment is composed of one or more
 | |
|       # of these).
 | |
|       class ResourceCommitment
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Name of the accelerator type resource. Applicable only when the type is
 | |
|         # ACCELERATOR.
 | |
|         # Corresponds to the JSON property `acceleratorType`
 | |
|         # @return [String]
 | |
|         attr_accessor :accelerator_type
 | |
|       
 | |
|         # The amount of the resource purchased (in a type-dependent unit, such as bytes).
 | |
|         # For vCPUs, this can just be an integer. For memory, this must be provided in
 | |
|         # MB. Memory must be a multiple of 256 MB, with up to 6.5GB of memory per every
 | |
|         # vCPU.
 | |
|         # Corresponds to the JSON property `amount`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :amount
 | |
|       
 | |
|         # Type of resource for which this commitment applies. Possible values are VCPU
 | |
|         # and MEMORY
 | |
|         # Corresponds to the JSON property `type`
 | |
|         # @return [String]
 | |
|         attr_accessor :type
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @accelerator_type = args[:accelerator_type] if args.key?(:accelerator_type)
 | |
|           @amount = args[:amount] if args.key?(:amount)
 | |
|           @type = args[:type] if args.key?(:type)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ResourceGroupReference
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A URI referencing one of the instance groups or network endpoint groups listed
 | |
|         # in the backend service.
 | |
|         # Corresponds to the JSON property `group`
 | |
|         # @return [String]
 | |
|         attr_accessor :group
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @group = args[:group] if args.key?(:group)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ResourcePoliciesScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of resourcePolicies contained in this scope.
 | |
|         # Corresponds to the JSON property `resourcePolicies`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::ResourcePolicy>]
 | |
|         attr_accessor :resource_policies
 | |
|       
 | |
|         # Informational warning which replaces the list of resourcePolicies when the
 | |
|         # list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::ResourcePoliciesScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @resource_policies = args[:resource_policies] if args.key?(:resource_policies)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # Informational warning which replaces the list of resourcePolicies when the
 | |
|         # list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::ResourcePoliciesScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ResourcePolicy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#resource_policies for
 | |
|         # resource policies.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # The name of the resource, provided by the client when initially creating the
 | |
|         # resource. The resource 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # [Output Only] Server-defined fully-qualified URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # A snapshot schedule policy specifies when and how frequently snapshots are to
 | |
|         # be created for the target disk. Also specifies how many and how long these
 | |
|         # scheduled snapshots should be retained.
 | |
|         # Corresponds to the JSON property `snapshotSchedulePolicy`
 | |
|         # @return [Google::Apis::ComputeAlpha::ResourcePolicySnapshotSchedulePolicy]
 | |
|         attr_accessor :snapshot_schedule_policy
 | |
|       
 | |
|         # Resource policy applicable to VMs for infrastructure maintenance.
 | |
|         # Corresponds to the JSON property `vmMaintenancePolicy`
 | |
|         # @return [Google::Apis::ComputeAlpha::ResourcePolicyVmMaintenancePolicy]
 | |
|         attr_accessor :vm_maintenance_policy
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @snapshot_schedule_policy = args[:snapshot_schedule_policy] if args.key?(:snapshot_schedule_policy)
 | |
|           @vm_maintenance_policy = args[:vm_maintenance_policy] if args.key?(:vm_maintenance_policy)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of resourcePolicies.
 | |
|       class ResourcePolicyAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `etag`
 | |
|         # @return [String]
 | |
|         attr_accessor :etag
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of ResourcePolicy resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::ResourcePoliciesScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::ResourcePolicyAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @etag = args[:etag] if args.key?(:etag)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::ResourcePolicyAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Time window specified for daily operations.
 | |
|       class ResourcePolicyDailyCycle
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Allows to define schedule that runs every nth day of the month.
 | |
|         # Corresponds to the JSON property `daysInCycle`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :days_in_cycle
 | |
|       
 | |
|         # [Output only] Duration of the time window, automatically chosen to be smallest
 | |
|         # possible in the given scenario.
 | |
|         # Corresponds to the JSON property `duration`
 | |
|         # @return [String]
 | |
|         attr_accessor :duration
 | |
|       
 | |
|         # Time within the window to start the operations. It must be in format "HH:MM",
 | |
|         # where HH : [00-23] and MM : [00-00] GMT.
 | |
|         # Corresponds to the JSON property `startTime`
 | |
|         # @return [String]
 | |
|         attr_accessor :start_time
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @days_in_cycle = args[:days_in_cycle] if args.key?(:days_in_cycle)
 | |
|           @duration = args[:duration] if args.key?(:duration)
 | |
|           @start_time = args[:start_time] if args.key?(:start_time)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Time window specified for hourly operations.
 | |
|       class ResourcePolicyHourlyCycle
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output only] Duration of the time window, automatically chosen to be smallest
 | |
|         # possible in the given scenario.
 | |
|         # Corresponds to the JSON property `duration`
 | |
|         # @return [String]
 | |
|         attr_accessor :duration
 | |
|       
 | |
|         # Allows to define schedule that runs every nth hour.
 | |
|         # Corresponds to the JSON property `hoursInCycle`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :hours_in_cycle
 | |
|       
 | |
|         # Time within the window to start the operations. It must be in format "HH:MM",
 | |
|         # where HH : [00-23] and MM : [00-00] GMT.
 | |
|         # Corresponds to the JSON property `startTime`
 | |
|         # @return [String]
 | |
|         attr_accessor :start_time
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @duration = args[:duration] if args.key?(:duration)
 | |
|           @hours_in_cycle = args[:hours_in_cycle] if args.key?(:hours_in_cycle)
 | |
|           @start_time = args[:start_time] if args.key?(:start_time)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ResourcePolicyList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `etag`
 | |
|         # @return [String]
 | |
|         attr_accessor :etag
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] A list of ResourcePolicy resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::ResourcePolicy>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource.Always compute#resourcePoliciesList for listsof
 | |
|         # resourcePolicies
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::ResourcePolicyList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @etag = args[:etag] if args.key?(:etag)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::ResourcePolicyList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A snapshot schedule policy specifies when and how frequently snapshots are to
 | |
|       # be created for the target disk. Also specifies how many and how long these
 | |
|       # scheduled snapshots should be retained.
 | |
|       class ResourcePolicySnapshotSchedulePolicy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Policy for retention of scheduled snapshots.
 | |
|         # Corresponds to the JSON property `retentionPolicy`
 | |
|         # @return [Google::Apis::ComputeAlpha::ResourcePolicySnapshotSchedulePolicyRetentionPolicy]
 | |
|         attr_accessor :retention_policy
 | |
|       
 | |
|         # A schedule for disks where the schedueled operations are performed.
 | |
|         # Corresponds to the JSON property `schedule`
 | |
|         # @return [Google::Apis::ComputeAlpha::ResourcePolicySnapshotSchedulePolicySchedule]
 | |
|         attr_accessor :schedule
 | |
|       
 | |
|         # Specified snapshot properties for scheduled snapshots created by this policy.
 | |
|         # Corresponds to the JSON property `snapshotProperties`
 | |
|         # @return [Google::Apis::ComputeAlpha::ResourcePolicySnapshotSchedulePolicySnapshotProperties]
 | |
|         attr_accessor :snapshot_properties
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @retention_policy = args[:retention_policy] if args.key?(:retention_policy)
 | |
|           @schedule = args[:schedule] if args.key?(:schedule)
 | |
|           @snapshot_properties = args[:snapshot_properties] if args.key?(:snapshot_properties)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Policy for retention of scheduled snapshots.
 | |
|       class ResourcePolicySnapshotSchedulePolicyRetentionPolicy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Maximum age of the snapshot that is allowed to be kept.
 | |
|         # Corresponds to the JSON property `maxRetentionDays`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :max_retention_days
 | |
|       
 | |
|         # Specifies the behavior to apply to existing, scheduled snapshots snapshots if
 | |
|         # the policy is changed.
 | |
|         # Corresponds to the JSON property `onPolicySwitch`
 | |
|         # @return [String]
 | |
|         attr_accessor :on_policy_switch
 | |
|       
 | |
|         # Specifies the behavior to apply to scheduled snapshots when the source disk is
 | |
|         # deleted.
 | |
|         # Corresponds to the JSON property `onSourceDiskDelete`
 | |
|         # @return [String]
 | |
|         attr_accessor :on_source_disk_delete
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @max_retention_days = args[:max_retention_days] if args.key?(:max_retention_days)
 | |
|           @on_policy_switch = args[:on_policy_switch] if args.key?(:on_policy_switch)
 | |
|           @on_source_disk_delete = args[:on_source_disk_delete] if args.key?(:on_source_disk_delete)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A schedule for disks where the schedueled operations are performed.
 | |
|       class ResourcePolicySnapshotSchedulePolicySchedule
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Time window specified for daily operations.
 | |
|         # Corresponds to the JSON property `dailySchedule`
 | |
|         # @return [Google::Apis::ComputeAlpha::ResourcePolicyDailyCycle]
 | |
|         attr_accessor :daily_schedule
 | |
|       
 | |
|         # Time window specified for hourly operations.
 | |
|         # Corresponds to the JSON property `hourlySchedule`
 | |
|         # @return [Google::Apis::ComputeAlpha::ResourcePolicyHourlyCycle]
 | |
|         attr_accessor :hourly_schedule
 | |
|       
 | |
|         # Time window specified for weekly operations.
 | |
|         # Corresponds to the JSON property `weeklySchedule`
 | |
|         # @return [Google::Apis::ComputeAlpha::ResourcePolicyWeeklyCycle]
 | |
|         attr_accessor :weekly_schedule
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @daily_schedule = args[:daily_schedule] if args.key?(:daily_schedule)
 | |
|           @hourly_schedule = args[:hourly_schedule] if args.key?(:hourly_schedule)
 | |
|           @weekly_schedule = args[:weekly_schedule] if args.key?(:weekly_schedule)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Specified snapshot properties for scheduled snapshots created by this policy.
 | |
|       class ResourcePolicySnapshotSchedulePolicySnapshotProperties
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Indication to perform a ?guest aware? snapshot.
 | |
|         # Corresponds to the JSON property `guestFlush`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :guest_flush
 | |
|         alias_method :guest_flush?, :guest_flush
 | |
|       
 | |
|         # Labels to apply to scheduled snapshots. These can be later modified by the
 | |
|         # setLabels method. Label values may be empty.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         # GCS bucket storage location of the auto snapshot (regional or multi-regional).
 | |
|         # Corresponds to the JSON property `storageLocations`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :storage_locations
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @guest_flush = args[:guest_flush] if args.key?(:guest_flush)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|           @storage_locations = args[:storage_locations] if args.key?(:storage_locations)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ResourcePolicyVmMaintenancePolicy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A maintenance window for VMs. When set, we restrict our maintenance operations
 | |
|         # to this window.
 | |
|         # Corresponds to the JSON property `maintenanceWindow`
 | |
|         # @return [Google::Apis::ComputeAlpha::ResourcePolicyVmMaintenancePolicyMaintenanceWindow]
 | |
|         attr_accessor :maintenance_window
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @maintenance_window = args[:maintenance_window] if args.key?(:maintenance_window)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A maintenance window for VMs. When set, we restrict our maintenance operations
 | |
|       # to this window.
 | |
|       class ResourcePolicyVmMaintenancePolicyMaintenanceWindow
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Time window specified for daily operations.
 | |
|         # Corresponds to the JSON property `dailyMaintenanceWindow`
 | |
|         # @return [Google::Apis::ComputeAlpha::ResourcePolicyDailyCycle]
 | |
|         attr_accessor :daily_maintenance_window
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @daily_maintenance_window = args[:daily_maintenance_window] if args.key?(:daily_maintenance_window)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Time window specified for weekly operations.
 | |
|       class ResourcePolicyWeeklyCycle
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Up to 7 intervals/windows, one for each day of the week.
 | |
|         # Corresponds to the JSON property `dayOfWeeks`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::ResourcePolicyWeeklyCycleDayOfWeek>]
 | |
|         attr_accessor :day_of_weeks
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @day_of_weeks = args[:day_of_weeks] if args.key?(:day_of_weeks)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ResourcePolicyWeeklyCycleDayOfWeek
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Allows to define schedule that runs specified day of the week.
 | |
|         # Corresponds to the JSON property `day`
 | |
|         # @return [String]
 | |
|         attr_accessor :day
 | |
|       
 | |
|         # [Output only] Duration of the time window, automatically chosen to be smallest
 | |
|         # possible in the given scenario.
 | |
|         # Corresponds to the JSON property `duration`
 | |
|         # @return [String]
 | |
|         attr_accessor :duration
 | |
|       
 | |
|         # Time within the window to start the operations. It must be in format "HH:MM",
 | |
|         # where HH : [00-23] and MM : [00-00] GMT.
 | |
|         # Corresponds to the JSON property `startTime`
 | |
|         # @return [String]
 | |
|         attr_accessor :start_time
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @day = args[:day] if args.key?(:day)
 | |
|           @duration = args[:duration] if args.key?(:duration)
 | |
|           @start_time = args[:start_time] if args.key?(:start_time)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Represents a Route resource. A route specifies how certain packets should be
 | |
|       # handled by the network. Routes are associated with instances by tags and the
 | |
|       # set of routes for a particular instance is called its routing table.
 | |
|       # For each packet leaving an instance, the system searches that instance's
 | |
|       # routing table for a single best matching route. Routes match packets by
 | |
|       # destination IP address, preferring smaller or more specific ranges over larger
 | |
|       # ones. If there is a tie, the system selects the route with the smallest
 | |
|       # priority value. If there is still a tie, it uses the layer three and four
 | |
|       # packet headers to select just one of the remaining matching routes. The packet
 | |
|       # is then forwarded as specified by the nextHop field of the winning route -
 | |
|       # either to another instance destination, an instance gateway, or a Google
 | |
|       # Compute Engine-operated gateway.
 | |
|       # Packets that do not match any route in the sending instance's routing table
 | |
|       # are dropped. (== resource_for beta.routes ==) (== resource_for v1.routes ==)
 | |
|       class Route
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # The destination range of outgoing packets that this route applies to. Only
 | |
|         # IPv4 is supported.
 | |
|         # Corresponds to the JSON property `destRange`
 | |
|         # @return [String]
 | |
|         attr_accessor :dest_range
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of this resource. Always compute#routes for Route resources.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # Fully-qualified URL of the network that this route applies to.
 | |
|         # Corresponds to the JSON property `network`
 | |
|         # @return [String]
 | |
|         attr_accessor :network
 | |
|       
 | |
|         # The URL to a gateway that should handle matching packets. You can only specify
 | |
|         # the internet gateway using a full or partial valid URL:  projects/<project-id>/
 | |
|         # global/gateways/default-internet-gateway
 | |
|         # Corresponds to the JSON property `nextHopGateway`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_hop_gateway
 | |
|       
 | |
|         # The URL to a forwarding rule of type loadBalancingScheme=INTERNAL that should
 | |
|         # handle matching packets. You can only specify the forwarding rule as a partial
 | |
|         # or full URL. For example, the following are all valid URLs:
 | |
|         # - https://www.googleapis.com/compute/v1/projects/project/regions/region/
 | |
|         # forwardingRules/forwardingRule
 | |
|         # - regions/region/forwardingRules/forwardingRule  Note that this can only be
 | |
|         # used when the destination_range is a public (non-RFC 1918) IP CIDR range.
 | |
|         # Corresponds to the JSON property `nextHopIlb`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_hop_ilb
 | |
|       
 | |
|         # The URL to an instance that should handle matching packets. You can specify
 | |
|         # this as a full or partial URL. For example:
 | |
|         # https://www.googleapis.com/compute/v1/projects/project/zones/zone/instances/
 | |
|         # Corresponds to the JSON property `nextHopInstance`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_hop_instance
 | |
|       
 | |
|         # The network IP address of an instance that should handle matching packets.
 | |
|         # Only IPv4 is supported.
 | |
|         # Corresponds to the JSON property `nextHopIp`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_hop_ip
 | |
|       
 | |
|         # The URL of the local network if it should handle matching packets.
 | |
|         # Corresponds to the JSON property `nextHopNetwork`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_hop_network
 | |
|       
 | |
|         # [Output Only] The network peering name that should handle matching packets,
 | |
|         # which should conform to RFC1035.
 | |
|         # Corresponds to the JSON property `nextHopPeering`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_hop_peering
 | |
|       
 | |
|         # The URL to a VpnTunnel that should handle matching packets.
 | |
|         # Corresponds to the JSON property `nextHopVpnTunnel`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_hop_vpn_tunnel
 | |
|       
 | |
|         # The priority of this route. Priority is used to break ties in cases where
 | |
|         # there is more than one matching route of equal prefix length. In the case of
 | |
|         # two routes with equal prefix length, the one with the lowest-numbered priority
 | |
|         # value wins. Default value is 1000. Valid range is 0 through 65535.
 | |
|         # Corresponds to the JSON property `priority`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :priority
 | |
|       
 | |
|         # [Output Only] Server-defined fully-qualified URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # A list of instance tags to which this route applies.
 | |
|         # Corresponds to the JSON property `tags`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :tags
 | |
|       
 | |
|         # [Output Only] If potential misconfigurations are detected for this route, this
 | |
|         # field will be populated with warning messages.
 | |
|         # Corresponds to the JSON property `warnings`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Route::Warning>]
 | |
|         attr_accessor :warnings
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @dest_range = args[:dest_range] if args.key?(:dest_range)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @network = args[:network] if args.key?(:network)
 | |
|           @next_hop_gateway = args[:next_hop_gateway] if args.key?(:next_hop_gateway)
 | |
|           @next_hop_ilb = args[:next_hop_ilb] if args.key?(:next_hop_ilb)
 | |
|           @next_hop_instance = args[:next_hop_instance] if args.key?(:next_hop_instance)
 | |
|           @next_hop_ip = args[:next_hop_ip] if args.key?(:next_hop_ip)
 | |
|           @next_hop_network = args[:next_hop_network] if args.key?(:next_hop_network)
 | |
|           @next_hop_peering = args[:next_hop_peering] if args.key?(:next_hop_peering)
 | |
|           @next_hop_vpn_tunnel = args[:next_hop_vpn_tunnel] if args.key?(:next_hop_vpn_tunnel)
 | |
|           @priority = args[:priority] if args.key?(:priority)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @tags = args[:tags] if args.key?(:tags)
 | |
|           @warnings = args[:warnings] if args.key?(:warnings)
 | |
|         end
 | |
|         
 | |
|         # 
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::Route::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of Route resources.
 | |
|       class RouteList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of Route resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Route>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::RouteList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::RouteList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Router resource.
 | |
|       class Router
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # BGP information specific to this router.
 | |
|         # Corresponds to the JSON property `bgp`
 | |
|         # @return [Google::Apis::ComputeAlpha::RouterBgp]
 | |
|         attr_accessor :bgp
 | |
|       
 | |
|         # BGP information that needs to be configured into the routing stack to
 | |
|         # establish the BGP peering. It must specify peer ASN and either interface name,
 | |
|         # IP, or peer IP. Please refer to RFC4273.
 | |
|         # Corresponds to the JSON property `bgpPeers`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::RouterBgpPeer>]
 | |
|         attr_accessor :bgp_peers
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # Router interfaces. Each interface requires either one linked resource (e.g.
 | |
|         # linkedVpnTunnel), or IP address and IP address range (e.g. ipRange), or both.
 | |
|         # Corresponds to the JSON property `interfaces`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::RouterInterface>]
 | |
|         attr_accessor :interfaces
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#router for routers.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # A list of Nat services created in this router.
 | |
|         # Corresponds to the JSON property `nats`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::RouterNat>]
 | |
|         attr_accessor :nats
 | |
|       
 | |
|         # URI of the network to which this router belongs.
 | |
|         # Corresponds to the JSON property `network`
 | |
|         # @return [String]
 | |
|         attr_accessor :network
 | |
|       
 | |
|         # [Output Only] URI of the region where the router resides. You must specify
 | |
|         # this field as part of the HTTP request URL. It is not settable as a field in
 | |
|         # the request body.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @bgp = args[:bgp] if args.key?(:bgp)
 | |
|           @bgp_peers = args[:bgp_peers] if args.key?(:bgp_peers)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @interfaces = args[:interfaces] if args.key?(:interfaces)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @nats = args[:nats] if args.key?(:nats)
 | |
|           @network = args[:network] if args.key?(:network)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Description-tagged IP ranges for the router to advertise.
 | |
|       class RouterAdvertisedIpRange
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # User-specified description for the IP range.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # The IP range to advertise. The value must be a CIDR-formatted string.
 | |
|         # Corresponds to the JSON property `range`
 | |
|         # @return [String]
 | |
|         attr_accessor :range
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @range = args[:range] if args.key?(:range)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of routers.
 | |
|       class RouterAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of Router resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::RoutersScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::RouterAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::RouterAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RouterBgp
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # User-specified flag to indicate which mode to use for advertisement.
 | |
|         # Corresponds to the JSON property `advertiseMode`
 | |
|         # @return [String]
 | |
|         attr_accessor :advertise_mode
 | |
|       
 | |
|         # User-specified list of prefix groups to advertise in custom mode. This field
 | |
|         # can only be populated if advertise_mode is CUSTOM and is advertised to all
 | |
|         # peers of the router. These groups will be advertised in addition to any
 | |
|         # specified prefixes. Leave this field blank to advertise no custom groups.
 | |
|         # Corresponds to the JSON property `advertisedGroups`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :advertised_groups
 | |
|       
 | |
|         # User-specified list of individual IP ranges to advertise in custom mode. This
 | |
|         # field can only be populated if advertise_mode is CUSTOM and is advertised to
 | |
|         # all peers of the router. These IP ranges will be advertised in addition to any
 | |
|         # specified groups. Leave this field blank to advertise no custom IP ranges.
 | |
|         # Corresponds to the JSON property `advertisedIpRanges`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::RouterAdvertisedIpRange>]
 | |
|         attr_accessor :advertised_ip_ranges
 | |
|       
 | |
|         # Local BGP Autonomous System Number (ASN). Must be an RFC6996 private ASN,
 | |
|         # either 16-bit or 32-bit. The value will be fixed for this router resource. All
 | |
|         # VPN tunnels that link to this router will have the same local ASN.
 | |
|         # Corresponds to the JSON property `asn`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :asn
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @advertise_mode = args[:advertise_mode] if args.key?(:advertise_mode)
 | |
|           @advertised_groups = args[:advertised_groups] if args.key?(:advertised_groups)
 | |
|           @advertised_ip_ranges = args[:advertised_ip_ranges] if args.key?(:advertised_ip_ranges)
 | |
|           @asn = args[:asn] if args.key?(:asn)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RouterBgpPeer
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # User-specified flag to indicate which mode to use for advertisement.
 | |
|         # Corresponds to the JSON property `advertiseMode`
 | |
|         # @return [String]
 | |
|         attr_accessor :advertise_mode
 | |
|       
 | |
|         # User-specified list of prefix groups to advertise in custom mode. This field
 | |
|         # can only be populated if advertise_mode is CUSTOM and overrides the list
 | |
|         # defined for the router (in Bgp message). These groups will be advertised in
 | |
|         # addition to any specified prefixes. Leave this field blank to advertise no
 | |
|         # custom groups.
 | |
|         # Corresponds to the JSON property `advertisedGroups`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :advertised_groups
 | |
|       
 | |
|         # User-specified list of individual IP ranges to advertise in custom mode. This
 | |
|         # field can only be populated if advertise_mode is CUSTOM and overrides the list
 | |
|         # defined for the router (in Bgp message). These IP ranges will be advertised in
 | |
|         # addition to any specified groups. Leave this field blank to advertise no
 | |
|         # custom IP ranges.
 | |
|         # Corresponds to the JSON property `advertisedIpRanges`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::RouterAdvertisedIpRange>]
 | |
|         attr_accessor :advertised_ip_ranges
 | |
|       
 | |
|         # The priority of routes advertised to this BGP peer. In the case where there is
 | |
|         # more than one matching route of maximum length, the routes with lowest
 | |
|         # priority value win.
 | |
|         # Corresponds to the JSON property `advertisedRoutePriority`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :advertised_route_priority
 | |
|       
 | |
|         # Name of the interface the BGP peer is associated with.
 | |
|         # Corresponds to the JSON property `interfaceName`
 | |
|         # @return [String]
 | |
|         attr_accessor :interface_name
 | |
|       
 | |
|         # IP address of the interface inside Google Cloud Platform. Only IPv4 is
 | |
|         # supported.
 | |
|         # Corresponds to the JSON property `ipAddress`
 | |
|         # @return [String]
 | |
|         attr_accessor :ip_address
 | |
|       
 | |
|         # [Output Only] The resource that configures and manages this BGP peer.
 | |
|         # MANAGED_BY_USER is the default value and can be managed by you or other users;
 | |
|         # MANAGED_BY_ATTACHMENT is a BGP peer that is configured and managed by Cloud
 | |
|         # Interconnect, specifically by an InterconnectAttachment of type PARTNER.
 | |
|         # Google will automatically create, update, and delete this type of BGP peer
 | |
|         # when the PARTNER InterconnectAttachment is created, updated, or deleted.
 | |
|         # Corresponds to the JSON property `managementType`
 | |
|         # @return [String]
 | |
|         attr_accessor :management_type
 | |
|       
 | |
|         # Name of this BGP peer. The name must be 1-63 characters long and comply with
 | |
|         # RFC1035.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # Peer BGP Autonomous System Number (ASN). For VPN use case, this value can be
 | |
|         # different for every tunnel.
 | |
|         # Corresponds to the JSON property `peerAsn`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :peer_asn
 | |
|       
 | |
|         # IP address of the BGP interface outside Google cloud. Only IPv4 is supported.
 | |
|         # Corresponds to the JSON property `peerIpAddress`
 | |
|         # @return [String]
 | |
|         attr_accessor :peer_ip_address
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @advertise_mode = args[:advertise_mode] if args.key?(:advertise_mode)
 | |
|           @advertised_groups = args[:advertised_groups] if args.key?(:advertised_groups)
 | |
|           @advertised_ip_ranges = args[:advertised_ip_ranges] if args.key?(:advertised_ip_ranges)
 | |
|           @advertised_route_priority = args[:advertised_route_priority] if args.key?(:advertised_route_priority)
 | |
|           @interface_name = args[:interface_name] if args.key?(:interface_name)
 | |
|           @ip_address = args[:ip_address] if args.key?(:ip_address)
 | |
|           @management_type = args[:management_type] if args.key?(:management_type)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @peer_asn = args[:peer_asn] if args.key?(:peer_asn)
 | |
|           @peer_ip_address = args[:peer_ip_address] if args.key?(:peer_ip_address)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RouterInterface
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # IP address and range of the interface. The IP range must be in the RFC3927
 | |
|         # link-local IP space. The value must be a CIDR-formatted string, for example:
 | |
|         # 169.254.0.1/30. NOTE: Do not truncate the address as it represents the IP
 | |
|         # address of the interface.
 | |
|         # Corresponds to the JSON property `ipRange`
 | |
|         # @return [String]
 | |
|         attr_accessor :ip_range
 | |
|       
 | |
|         # URI of the linked interconnect attachment. It must be in the same region as
 | |
|         # the router. Each interface can have at most one linked resource and it could
 | |
|         # either be a VPN Tunnel or an interconnect attachment.
 | |
|         # Corresponds to the JSON property `linkedInterconnectAttachment`
 | |
|         # @return [String]
 | |
|         attr_accessor :linked_interconnect_attachment
 | |
|       
 | |
|         # URI of the linked VPN tunnel. It must be in the same region as the router.
 | |
|         # Each interface can have at most one linked resource and it could either be a
 | |
|         # VPN Tunnel or an interconnect attachment.
 | |
|         # Corresponds to the JSON property `linkedVpnTunnel`
 | |
|         # @return [String]
 | |
|         attr_accessor :linked_vpn_tunnel
 | |
|       
 | |
|         # [Output Only] The resource that configures and manages this interface.
 | |
|         # MANAGED_BY_USER is the default value and can be managed by you or other users;
 | |
|         # MANAGED_BY_ATTACHMENT is an interface that is configured and managed by Cloud
 | |
|         # Interconnect, specifically by an InterconnectAttachment of type PARTNER.
 | |
|         # Google will automatically create, update, and delete this type of interface
 | |
|         # when the PARTNER InterconnectAttachment is created, updated, or deleted.
 | |
|         # Corresponds to the JSON property `managementType`
 | |
|         # @return [String]
 | |
|         attr_accessor :management_type
 | |
|       
 | |
|         # Name of this interface entry. The name must be 1-63 characters long and comply
 | |
|         # with RFC1035.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @ip_range = args[:ip_range] if args.key?(:ip_range)
 | |
|           @linked_interconnect_attachment = args[:linked_interconnect_attachment] if args.key?(:linked_interconnect_attachment)
 | |
|           @linked_vpn_tunnel = args[:linked_vpn_tunnel] if args.key?(:linked_vpn_tunnel)
 | |
|           @management_type = args[:management_type] if args.key?(:management_type)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of Router resources.
 | |
|       class RouterList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of Router resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Router>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#router for routers.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::RouterList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::RouterList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Represents a Nat resource. It enables the VMs within the specified subnetworks
 | |
|       # to access Internet without external IP addresses. It specifies a list of
 | |
|       # subnetworks (and the ranges within) that want to use NAT. Customers can also
 | |
|       # provide the external IPs that would be used for NAT. GCP would auto-allocate
 | |
|       # ephemeral IPs if no external IPs are provided.
 | |
|       class RouterNat
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Timeout (in seconds) for ICMP connections. Defaults to 30s if not set.
 | |
|         # Corresponds to the JSON property `icmpIdleTimeoutSec`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :icmp_idle_timeout_sec
 | |
|       
 | |
|         # Configuration of logging on a NAT.
 | |
|         # Corresponds to the JSON property `logConfig`
 | |
|         # @return [Google::Apis::ComputeAlpha::RouterNatLogConfig]
 | |
|         attr_accessor :log_config
 | |
|       
 | |
|         # Minimum number of ports allocated to a VM from this NAT config. If not set, a
 | |
|         # default number of ports is allocated to a VM. This gets rounded up to the
 | |
|         # nearest power of 2. Eg. if the value of this field is 50, at least 64 ports
 | |
|         # will be allocated to a VM.
 | |
|         # Corresponds to the JSON property `minPortsPerVm`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :min_ports_per_vm
 | |
|       
 | |
|         # Unique name of this Nat service. The name must be 1-63 characters long and
 | |
|         # comply with RFC1035.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # Specify the NatIpAllocateOption. If it is AUTO_ONLY, then nat_ip should be
 | |
|         # empty.
 | |
|         # Corresponds to the JSON property `natIpAllocateOption`
 | |
|         # @return [String]
 | |
|         attr_accessor :nat_ip_allocate_option
 | |
|       
 | |
|         # A list of URLs of the IP resources used for this Nat service. These IPs must
 | |
|         # be valid static external IP addresses assigned to the project. max_length is
 | |
|         # subject to change post alpha.
 | |
|         # Corresponds to the JSON property `natIps`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :nat_ips
 | |
|       
 | |
|         # Specify the Nat option. If this field contains ALL_SUBNETWORKS_ALL_IP_RANGES
 | |
|         # or ALL_SUBNETWORKS_ALL_PRIMARY_IP_RANGES, then there should not be any other
 | |
|         # Router.Nat section in any Router for this network in this region.
 | |
|         # Corresponds to the JSON property `sourceSubnetworkIpRangesToNat`
 | |
|         # @return [String]
 | |
|         attr_accessor :source_subnetwork_ip_ranges_to_nat
 | |
|       
 | |
|         # A list of Subnetwork resources whose traffic should be translated by NAT
 | |
|         # Gateway. It is used only when LIST_OF_SUBNETWORKS is selected for the
 | |
|         # SubnetworkIpRangeToNatOption above.
 | |
|         # Corresponds to the JSON property `subnetworks`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::RouterNatSubnetworkToNat>]
 | |
|         attr_accessor :subnetworks
 | |
|       
 | |
|         # Timeout (in seconds) for TCP established connections. Defaults to 1200s if not
 | |
|         # set.
 | |
|         # Corresponds to the JSON property `tcpEstablishedIdleTimeoutSec`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :tcp_established_idle_timeout_sec
 | |
|       
 | |
|         # Timeout (in seconds) for TCP transitory connections. Defaults to 30s if not
 | |
|         # set.
 | |
|         # Corresponds to the JSON property `tcpTransitoryIdleTimeoutSec`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :tcp_transitory_idle_timeout_sec
 | |
|       
 | |
|         # Timeout (in seconds) for UDP connections. Defaults to 30s if not set.
 | |
|         # Corresponds to the JSON property `udpIdleTimeoutSec`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :udp_idle_timeout_sec
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @icmp_idle_timeout_sec = args[:icmp_idle_timeout_sec] if args.key?(:icmp_idle_timeout_sec)
 | |
|           @log_config = args[:log_config] if args.key?(:log_config)
 | |
|           @min_ports_per_vm = args[:min_ports_per_vm] if args.key?(:min_ports_per_vm)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @nat_ip_allocate_option = args[:nat_ip_allocate_option] if args.key?(:nat_ip_allocate_option)
 | |
|           @nat_ips = args[:nat_ips] if args.key?(:nat_ips)
 | |
|           @source_subnetwork_ip_ranges_to_nat = args[:source_subnetwork_ip_ranges_to_nat] if args.key?(:source_subnetwork_ip_ranges_to_nat)
 | |
|           @subnetworks = args[:subnetworks] if args.key?(:subnetworks)
 | |
|           @tcp_established_idle_timeout_sec = args[:tcp_established_idle_timeout_sec] if args.key?(:tcp_established_idle_timeout_sec)
 | |
|           @tcp_transitory_idle_timeout_sec = args[:tcp_transitory_idle_timeout_sec] if args.key?(:tcp_transitory_idle_timeout_sec)
 | |
|           @udp_idle_timeout_sec = args[:udp_idle_timeout_sec] if args.key?(:udp_idle_timeout_sec)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Configuration of logging on a NAT.
 | |
|       class RouterNatLogConfig
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Indicates whether or not to export logs. This is false by default.
 | |
|         # Corresponds to the JSON property `enable`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :enable
 | |
|         alias_method :enable?, :enable
 | |
|       
 | |
|         # Indicates whether or not to export logs. This is false by default. [Deprecated]
 | |
|         # Use 'enable' instead.
 | |
|         # Corresponds to the JSON property `enabled`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :enabled
 | |
|         alias_method :enabled?, :enabled
 | |
|       
 | |
|         # Specifies the desired filtering of logs on this NAT. If unspecified, logs are
 | |
|         # exported for all connections handled by this NAT.
 | |
|         # Corresponds to the JSON property `filter`
 | |
|         # @return [String]
 | |
|         attr_accessor :filter
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @enable = args[:enable] if args.key?(:enable)
 | |
|           @enabled = args[:enabled] if args.key?(:enabled)
 | |
|           @filter = args[:filter] if args.key?(:filter)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Defines the IP ranges that want to use NAT for a subnetwork.
 | |
|       class RouterNatSubnetworkToNat
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # URL for the subnetwork resource to use NAT.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # A list of the secondary ranges of the Subnetwork that are allowed to use NAT.
 | |
|         # This can be populated only if "LIST_OF_SECONDARY_IP_RANGES" is one of the
 | |
|         # values in source_ip_ranges_to_nat.
 | |
|         # Corresponds to the JSON property `secondaryIpRangeNames`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :secondary_ip_range_names
 | |
|       
 | |
|         # Specify the options for NAT ranges in the Subnetwork. All usages of single
 | |
|         # value are valid except NAT_IP_RANGE_OPTION_UNSPECIFIED. The only valid option
 | |
|         # with multiple values is: ["PRIMARY_IP_RANGE", "LIST_OF_SECONDARY_IP_RANGES"]
 | |
|         # Default: [ALL_IP_RANGES]
 | |
|         # Corresponds to the JSON property `sourceIpRangesToNat`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :source_ip_ranges_to_nat
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @secondary_ip_range_names = args[:secondary_ip_range_names] if args.key?(:secondary_ip_range_names)
 | |
|           @source_ip_ranges_to_nat = args[:source_ip_ranges_to_nat] if args.key?(:source_ip_ranges_to_nat)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RouterStatus
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Best routes for this router's network.
 | |
|         # Corresponds to the JSON property `bestRoutes`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Route>]
 | |
|         attr_accessor :best_routes
 | |
|       
 | |
|         # Best routes learned by this router.
 | |
|         # Corresponds to the JSON property `bestRoutesForRouter`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Route>]
 | |
|         attr_accessor :best_routes_for_router
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `bgpPeerStatus`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::RouterStatusBgpPeerStatus>]
 | |
|         attr_accessor :bgp_peer_status
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `natStatus`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::RouterStatusNatStatus>]
 | |
|         attr_accessor :nat_status
 | |
|       
 | |
|         # URI of the network to which this router belongs.
 | |
|         # Corresponds to the JSON property `network`
 | |
|         # @return [String]
 | |
|         attr_accessor :network
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @best_routes = args[:best_routes] if args.key?(:best_routes)
 | |
|           @best_routes_for_router = args[:best_routes_for_router] if args.key?(:best_routes_for_router)
 | |
|           @bgp_peer_status = args[:bgp_peer_status] if args.key?(:bgp_peer_status)
 | |
|           @nat_status = args[:nat_status] if args.key?(:nat_status)
 | |
|           @network = args[:network] if args.key?(:network)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RouterStatusBgpPeerStatus
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Routes that were advertised to the remote BGP peer
 | |
|         # Corresponds to the JSON property `advertisedRoutes`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Route>]
 | |
|         attr_accessor :advertised_routes
 | |
|       
 | |
|         # IP address of the local BGP interface.
 | |
|         # Corresponds to the JSON property `ipAddress`
 | |
|         # @return [String]
 | |
|         attr_accessor :ip_address
 | |
|       
 | |
|         # URL of the VPN tunnel that this BGP peer controls.
 | |
|         # Corresponds to the JSON property `linkedVpnTunnel`
 | |
|         # @return [String]
 | |
|         attr_accessor :linked_vpn_tunnel
 | |
|       
 | |
|         # Name of this BGP peer. Unique within the Routers resource.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # Number of routes learned from the remote BGP Peer.
 | |
|         # Corresponds to the JSON property `numLearnedRoutes`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :num_learned_routes
 | |
|       
 | |
|         # IP address of the remote BGP interface.
 | |
|         # Corresponds to the JSON property `peerIpAddress`
 | |
|         # @return [String]
 | |
|         attr_accessor :peer_ip_address
 | |
|       
 | |
|         # BGP state as specified in RFC1771.
 | |
|         # Corresponds to the JSON property `state`
 | |
|         # @return [String]
 | |
|         attr_accessor :state
 | |
|       
 | |
|         # Status of the BGP peer: `UP, DOWN`
 | |
|         # Corresponds to the JSON property `status`
 | |
|         # @return [String]
 | |
|         attr_accessor :status
 | |
|       
 | |
|         # Time this session has been up. Format: 14 years, 51 weeks, 6 days, 23 hours,
 | |
|         # 59 minutes, 59 seconds
 | |
|         # Corresponds to the JSON property `uptime`
 | |
|         # @return [String]
 | |
|         attr_accessor :uptime
 | |
|       
 | |
|         # Time this session has been up, in seconds. Format: 145
 | |
|         # Corresponds to the JSON property `uptimeSeconds`
 | |
|         # @return [String]
 | |
|         attr_accessor :uptime_seconds
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @advertised_routes = args[:advertised_routes] if args.key?(:advertised_routes)
 | |
|           @ip_address = args[:ip_address] if args.key?(:ip_address)
 | |
|           @linked_vpn_tunnel = args[:linked_vpn_tunnel] if args.key?(:linked_vpn_tunnel)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @num_learned_routes = args[:num_learned_routes] if args.key?(:num_learned_routes)
 | |
|           @peer_ip_address = args[:peer_ip_address] if args.key?(:peer_ip_address)
 | |
|           @state = args[:state] if args.key?(:state)
 | |
|           @status = args[:status] if args.key?(:status)
 | |
|           @uptime = args[:uptime] if args.key?(:uptime)
 | |
|           @uptime_seconds = args[:uptime_seconds] if args.key?(:uptime_seconds)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Status of a NAT contained in this router.
 | |
|       class RouterStatusNatStatus
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of IPs auto-allocated for NAT. Example: ["1.1.1.1", "129.2.16.89"]
 | |
|         # Corresponds to the JSON property `autoAllocatedNatIps`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :auto_allocated_nat_ips
 | |
|       
 | |
|         # The number of extra IPs to allocate. This will be greater than 0 only if user-
 | |
|         # specified IPs are NOT enough to allow all configured VMs to use NAT. This
 | |
|         # value is meaningful only when auto-allocation of NAT IPs is *not* used.
 | |
|         # Corresponds to the JSON property `minExtraNatIpsNeeded`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :min_extra_nat_ips_needed
 | |
|       
 | |
|         # Unique name of this NAT.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # Number of VM endpoints (i.e., Nics) that can use NAT.
 | |
|         # Corresponds to the JSON property `numVmEndpointsWithNatMappings`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :num_vm_endpoints_with_nat_mappings
 | |
|       
 | |
|         # A list of fully qualified URLs of reserved IP address resources.
 | |
|         # Corresponds to the JSON property `userAllocatedNatIpResources`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :user_allocated_nat_ip_resources
 | |
|       
 | |
|         # A list of IPs user-allocated for NAT. They will be raw IP strings like "179.12.
 | |
|         # 26.133".
 | |
|         # Corresponds to the JSON property `userAllocatedNatIps`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :user_allocated_nat_ips
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @auto_allocated_nat_ips = args[:auto_allocated_nat_ips] if args.key?(:auto_allocated_nat_ips)
 | |
|           @min_extra_nat_ips_needed = args[:min_extra_nat_ips_needed] if args.key?(:min_extra_nat_ips_needed)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @num_vm_endpoints_with_nat_mappings = args[:num_vm_endpoints_with_nat_mappings] if args.key?(:num_vm_endpoints_with_nat_mappings)
 | |
|           @user_allocated_nat_ip_resources = args[:user_allocated_nat_ip_resources] if args.key?(:user_allocated_nat_ip_resources)
 | |
|           @user_allocated_nat_ips = args[:user_allocated_nat_ips] if args.key?(:user_allocated_nat_ips)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RouterStatusResponse
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `result`
 | |
|         # @return [Google::Apis::ComputeAlpha::RouterStatus]
 | |
|         attr_accessor :result
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @result = args[:result] if args.key?(:result)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RoutersPreviewResponse
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Router resource.
 | |
|         # Corresponds to the JSON property `resource`
 | |
|         # @return [Google::Apis::ComputeAlpha::Router]
 | |
|         attr_accessor :resource
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @resource = args[:resource] if args.key?(:resource)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class RoutersScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of routers contained in this scope.
 | |
|         # Corresponds to the JSON property `routers`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Router>]
 | |
|         attr_accessor :routers
 | |
|       
 | |
|         # Informational warning which replaces the list of routers when the list is
 | |
|         # empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::RoutersScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @routers = args[:routers] if args.key?(:routers)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # Informational warning which replaces the list of routers when the list is
 | |
|         # empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::RoutersScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A rule to be applied in a Policy.
 | |
|       class Rule
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Required
 | |
|         # Corresponds to the JSON property `action`
 | |
|         # @return [String]
 | |
|         attr_accessor :action
 | |
|       
 | |
|         # Additional restrictions that must be met. All conditions must pass for the
 | |
|         # rule to match.
 | |
|         # Corresponds to the JSON property `conditions`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Condition>]
 | |
|         attr_accessor :conditions
 | |
|       
 | |
|         # Human-readable description of the rule.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # If one or more 'in' clauses are specified, the rule matches if the PRINCIPAL/
 | |
|         # AUTHORITY_SELECTOR is in at least one of these entries.
 | |
|         # Corresponds to the JSON property `ins`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :ins
 | |
|       
 | |
|         # The config returned to callers of tech.iam.IAM.CheckPolicy for any entries
 | |
|         # that match the LOG action.
 | |
|         # Corresponds to the JSON property `logConfigs`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::LogConfig>]
 | |
|         attr_accessor :log_configs
 | |
|       
 | |
|         # If one or more 'not_in' clauses are specified, the rule matches if the
 | |
|         # PRINCIPAL/AUTHORITY_SELECTOR is in none of the entries.
 | |
|         # Corresponds to the JSON property `notIns`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :not_ins
 | |
|       
 | |
|         # A permission is a string of form '..' (e.g., 'storage.buckets.list'). A value
 | |
|         # of '*' matches all permissions, and a verb part of '*' (e.g., 'storage.buckets.
 | |
|         # *') matches all verbs.
 | |
|         # Corresponds to the JSON property `permissions`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :permissions
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @action = args[:action] if args.key?(:action)
 | |
|           @conditions = args[:conditions] if args.key?(:conditions)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @ins = args[:ins] if args.key?(:ins)
 | |
|           @log_configs = args[:log_configs] if args.key?(:log_configs)
 | |
|           @not_ins = args[:not_ins] if args.key?(:not_ins)
 | |
|           @permissions = args[:permissions] if args.key?(:permissions)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class SslHealthCheck
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The TCP port number for the health check request. The default value is 443.
 | |
|         # Valid values are 1 through 65535.
 | |
|         # Corresponds to the JSON property `port`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :port
 | |
|       
 | |
|         # Port name as defined in InstanceGroup#NamedPort#name. If both port and
 | |
|         # port_name are defined, port takes precedence.
 | |
|         # Corresponds to the JSON property `portName`
 | |
|         # @return [String]
 | |
|         attr_accessor :port_name
 | |
|       
 | |
|         # Specifies how port is selected for health checking, can be one of following
 | |
|         # values:
 | |
|         # USE_FIXED_PORT: The port number in
 | |
|         # port
 | |
|         # is used for health checking.
 | |
|         # USE_NAMED_PORT: The
 | |
|         # portName
 | |
|         # is used for health checking.
 | |
|         # USE_SERVING_PORT: For NetworkEndpointGroup, the port specified for each
 | |
|         # network endpoint is used for health checking. For other backends, the port or
 | |
|         # named port specified in the Backend Service is used for health checking.
 | |
|         # If not specified, SSL health check follows behavior specified in
 | |
|         # port
 | |
|         # and
 | |
|         # portName
 | |
|         # fields.
 | |
|         # Corresponds to the JSON property `portSpecification`
 | |
|         # @return [String]
 | |
|         attr_accessor :port_specification
 | |
|       
 | |
|         # Specifies the type of proxy header to append before sending data to the
 | |
|         # backend, either NONE or PROXY_V1. The default is NONE.
 | |
|         # Corresponds to the JSON property `proxyHeader`
 | |
|         # @return [String]
 | |
|         attr_accessor :proxy_header
 | |
|       
 | |
|         # The application data to send once the SSL connection has been established (
 | |
|         # default value is empty). If both request and response are empty, the
 | |
|         # connection establishment alone will indicate health. The request data can only
 | |
|         # be ASCII.
 | |
|         # Corresponds to the JSON property `request`
 | |
|         # @return [String]
 | |
|         attr_accessor :request
 | |
|       
 | |
|         # The bytes to match against the beginning of the response data. If left empty (
 | |
|         # the default value), any response will indicate health. The response data can
 | |
|         # only be ASCII.
 | |
|         # Corresponds to the JSON property `response`
 | |
|         # @return [String]
 | |
|         attr_accessor :response
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @port = args[:port] if args.key?(:port)
 | |
|           @port_name = args[:port_name] if args.key?(:port_name)
 | |
|           @port_specification = args[:port_specification] if args.key?(:port_specification)
 | |
|           @proxy_header = args[:proxy_header] if args.key?(:proxy_header)
 | |
|           @request = args[:request] if args.key?(:request)
 | |
|           @response = args[:response] if args.key?(:response)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # An instance-attached disk resource.
 | |
|       class SavedAttachedDisk
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Specifies whether the disk will be auto-deleted when the instance is deleted (
 | |
|         # but not when the disk is detached from the instance).
 | |
|         # Corresponds to the JSON property `autoDelete`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :auto_delete
 | |
|         alias_method :auto_delete?, :auto_delete
 | |
|       
 | |
|         # Indicates that this is a boot disk. The virtual machine will use the first
 | |
|         # partition of the disk for its root filesystem.
 | |
|         # Corresponds to the JSON property `boot`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :boot
 | |
|         alias_method :boot?, :boot
 | |
|       
 | |
|         # Specifies a unique device name of your choice that is reflected into the /dev/
 | |
|         # disk/by-id/google-* tree of a Linux operating system running within the
 | |
|         # instance. This name can be used to reference the device for mounting, resizing,
 | |
|         # and so on, from within the instance.
 | |
|         # If not specified, the server chooses a default device name to apply to this
 | |
|         # disk, in the form persistent-disks-x, where x is a number assigned by Google
 | |
|         # Compute Engine. This field is only applicable for persistent disks.
 | |
|         # Corresponds to the JSON property `deviceName`
 | |
|         # @return [String]
 | |
|         attr_accessor :device_name
 | |
|       
 | |
|         # Represents a customer-supplied encryption key
 | |
|         # Corresponds to the JSON property `diskEncryptionKey`
 | |
|         # @return [Google::Apis::ComputeAlpha::CustomerEncryptionKey]
 | |
|         attr_accessor :disk_encryption_key
 | |
|       
 | |
|         # The size of the disk in base-2 GB. This supersedes disk_size_gb in
 | |
|         # InitializeParams.
 | |
|         # Corresponds to the JSON property `diskSizeGb`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :disk_size_gb
 | |
|       
 | |
|         # A list of features to enable on the guest operating system. Applicable only
 | |
|         # for bootable images. Read  Enabling guest operating system features to see a
 | |
|         # list of available options.
 | |
|         # Corresponds to the JSON property `guestOsFeatures`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::GuestOsFeature>]
 | |
|         attr_accessor :guest_os_features
 | |
|       
 | |
|         # [Output Only] A zero-based index to this disk, where 0 is reserved for the
 | |
|         # boot disk. If you have many disks attached to an instance, each disk would
 | |
|         # have a unique index number.
 | |
|         # Corresponds to the JSON property `index`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :index
 | |
|       
 | |
|         # [Input Only] Specifies the parameters for a new disk that will be created
 | |
|         # alongside the new instance. Use initialization parameters to create boot disks
 | |
|         # or local SSDs attached to the new instance.
 | |
|         # This property is mutually exclusive with the source property; you can only
 | |
|         # define one or the other, but not both.
 | |
|         # Corresponds to the JSON property `initializeParams`
 | |
|         # @return [Google::Apis::ComputeAlpha::AttachedDiskInitializeParams]
 | |
|         attr_accessor :initialize_params
 | |
|       
 | |
|         # Specifies the disk interface to use for attaching this disk, which is either
 | |
|         # SCSI or NVME. The default is SCSI. Persistent disks must always use SCSI and
 | |
|         # the request will fail if you attempt to attach a persistent disk in any other
 | |
|         # format than SCSI. Local SSDs can use either NVME or SCSI. For performance
 | |
|         # characteristics of SCSI over NVMe, see Local SSD performance.
 | |
|         # Corresponds to the JSON property `interface`
 | |
|         # @return [String]
 | |
|         attr_accessor :interface
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#attachedDisk for attached
 | |
|         # disks.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] Any valid publicly visible licenses.
 | |
|         # Corresponds to the JSON property `licenses`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :licenses
 | |
|       
 | |
|         # The mode in which to attach this disk, either READ_WRITE or READ_ONLY. If not
 | |
|         # specified, the default is to attach the disk in READ_WRITE mode.
 | |
|         # Corresponds to the JSON property `mode`
 | |
|         # @return [String]
 | |
|         attr_accessor :mode
 | |
|       
 | |
|         # For LocalSSD disks on VM Instances in STOPPED or SUSPENDED state, this field
 | |
|         # is set to PRESERVED if the LocalSSD data has been saved to a persistent
 | |
|         # location by customer request. (see the discard_local_ssd option on Stop/
 | |
|         # Suspend). Read-only in the api.
 | |
|         # Corresponds to the JSON property `savedState`
 | |
|         # @return [String]
 | |
|         attr_accessor :saved_state
 | |
|       
 | |
|         # Specifies a valid partial or full URL to an existing Persistent Disk resource.
 | |
|         # When creating a new instance, one of initializeParams.sourceImage or disks.
 | |
|         # source is required except for local SSD.
 | |
|         # If desired, you can also attach existing non-root persistent disks using this
 | |
|         # property. This field is only applicable for persistent disks.
 | |
|         # Note that for sourceMachineImage, specify the disk name, not the URL for the
 | |
|         # disk.
 | |
|         # Corresponds to the JSON property `source`
 | |
|         # @return [String]
 | |
|         attr_accessor :source
 | |
|       
 | |
|         # [Output Only] A size of the storage used by the disk's snapshot.
 | |
|         # Corresponds to the JSON property `storageBytes`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :storage_bytes
 | |
|       
 | |
|         # [Output Only] An indicator whether storageBytes is in a stable state or it is
 | |
|         # being adjusted as a result of shared storage reallocation. This status can
 | |
|         # either be UPDATING, meaning the size of the snapshot is being updated, or
 | |
|         # UP_TO_DATE, meaning the size of the snapshot is up-to-date.
 | |
|         # Corresponds to the JSON property `storageBytesStatus`
 | |
|         # @return [String]
 | |
|         attr_accessor :storage_bytes_status
 | |
|       
 | |
|         # Specifies the type of the disk, either SCRATCH or PERSISTENT. If not specified,
 | |
|         # the default is PERSISTENT.
 | |
|         # Corresponds to the JSON property `type`
 | |
|         # @return [String]
 | |
|         attr_accessor :type
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @auto_delete = args[:auto_delete] if args.key?(:auto_delete)
 | |
|           @boot = args[:boot] if args.key?(:boot)
 | |
|           @device_name = args[:device_name] if args.key?(:device_name)
 | |
|           @disk_encryption_key = args[:disk_encryption_key] if args.key?(:disk_encryption_key)
 | |
|           @disk_size_gb = args[:disk_size_gb] if args.key?(:disk_size_gb)
 | |
|           @guest_os_features = args[:guest_os_features] if args.key?(:guest_os_features)
 | |
|           @index = args[:index] if args.key?(:index)
 | |
|           @initialize_params = args[:initialize_params] if args.key?(:initialize_params)
 | |
|           @interface = args[:interface] if args.key?(:interface)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @licenses = args[:licenses] if args.key?(:licenses)
 | |
|           @mode = args[:mode] if args.key?(:mode)
 | |
|           @saved_state = args[:saved_state] if args.key?(:saved_state)
 | |
|           @source = args[:source] if args.key?(:source)
 | |
|           @storage_bytes = args[:storage_bytes] if args.key?(:storage_bytes)
 | |
|           @storage_bytes_status = args[:storage_bytes_status] if args.key?(:storage_bytes_status)
 | |
|           @type = args[:type] if args.key?(:type)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Sets the scheduling options for an Instance.
 | |
|       class Scheduling
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Specifies whether the instance should be automatically restarted if it is
 | |
|         # terminated by Compute Engine (not terminated by a user). You can only set the
 | |
|         # automatic restart option for standard instances. Preemptible instances cannot
 | |
|         # be automatically restarted.
 | |
|         # By default, this is set to true so an instance is automatically restarted if
 | |
|         # it is terminated by Compute Engine.
 | |
|         # Corresponds to the JSON property `automaticRestart`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :automatic_restart
 | |
|         alias_method :automatic_restart?, :automatic_restart
 | |
|       
 | |
|         # The minimum number of virtual CPUs this instance will consume when running on
 | |
|         # a sole-tenant node.
 | |
|         # Corresponds to the JSON property `minNodeCpus`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :min_node_cpus
 | |
|       
 | |
|         # A set of node affinity and anti-affinity.
 | |
|         # Corresponds to the JSON property `nodeAffinities`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::SchedulingNodeAffinity>]
 | |
|         attr_accessor :node_affinities
 | |
|       
 | |
|         # Defines the maintenance behavior for this instance. For standard instances,
 | |
|         # the default behavior is MIGRATE. For preemptible instances, the default and
 | |
|         # only possible behavior is TERMINATE. For more information, see Setting
 | |
|         # Instance Scheduling Options.
 | |
|         # Corresponds to the JSON property `onHostMaintenance`
 | |
|         # @return [String]
 | |
|         attr_accessor :on_host_maintenance
 | |
|       
 | |
|         # Defines whether the instance is preemptible. This can only be set during
 | |
|         # instance creation, it cannot be set or changed after the instance has been
 | |
|         # created.
 | |
|         # Corresponds to the JSON property `preemptible`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :preemptible
 | |
|         alias_method :preemptible?, :preemptible
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @automatic_restart = args[:automatic_restart] if args.key?(:automatic_restart)
 | |
|           @min_node_cpus = args[:min_node_cpus] if args.key?(:min_node_cpus)
 | |
|           @node_affinities = args[:node_affinities] if args.key?(:node_affinities)
 | |
|           @on_host_maintenance = args[:on_host_maintenance] if args.key?(:on_host_maintenance)
 | |
|           @preemptible = args[:preemptible] if args.key?(:preemptible)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Node Affinity: the configuration of desired nodes onto which this Instance
 | |
|       # could be scheduled.
 | |
|       class SchedulingNodeAffinity
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Corresponds to the label key of Node resource.
 | |
|         # Corresponds to the JSON property `key`
 | |
|         # @return [String]
 | |
|         attr_accessor :key
 | |
|       
 | |
|         # Defines the operation of node selection.
 | |
|         # Corresponds to the JSON property `operator`
 | |
|         # @return [String]
 | |
|         attr_accessor :operator
 | |
|       
 | |
|         # Corresponds to the label values of Node resource.
 | |
|         # Corresponds to the JSON property `values`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :values
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @key = args[:key] if args.key?(:key)
 | |
|           @operator = args[:operator] if args.key?(:operator)
 | |
|           @values = args[:values] if args.key?(:values)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class SecurityPoliciesListPreconfiguredExpressionSetsResponse
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `preconfiguredExpressionSets`
 | |
|         # @return [Google::Apis::ComputeAlpha::SecurityPoliciesWafConfig]
 | |
|         attr_accessor :preconfigured_expression_sets
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @preconfigured_expression_sets = args[:preconfigured_expression_sets] if args.key?(:preconfigured_expression_sets)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class SecurityPoliciesWafConfig
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `wafRules`
 | |
|         # @return [Google::Apis::ComputeAlpha::PreconfiguredWafSet]
 | |
|         attr_accessor :waf_rules
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @waf_rules = args[:waf_rules] if args.key?(:waf_rules)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A security policy is comprised of one or more rules. It can also be associated
 | |
|       # with one or more 'targets'. (== resource_for v1.securityPolicies ==) (==
 | |
|       # resource_for beta.securityPolicies ==)
 | |
|       class SecurityPolicy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of assocations that belong to this policy.
 | |
|         # Corresponds to the JSON property `associations`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::SecurityPolicyAssociation>]
 | |
|         attr_accessor :associations
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # Specifies a fingerprint for this resource, which is essentially a hash of the
 | |
|         # metadata's contents and used for optimistic locking. The fingerprint is
 | |
|         # initially generated by Compute Engine and changes after every request to
 | |
|         # modify or update metadata. You must always provide an up-to-date fingerprint
 | |
|         # hash in order to update or change metadata, otherwise the request will fail
 | |
|         # with error 412 conditionNotMet.
 | |
|         # To see the latest fingerprint, make get() request to the security policy.
 | |
|         # Corresponds to the JSON property `fingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :fingerprint
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output only] Type of the resource. Always compute#securityPolicyfor security
 | |
|         # policies
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # A fingerprint for the labels being applied to this security policy, which is
 | |
|         # essentially a hash of the labels set used for optimistic locking. The
 | |
|         # fingerprint is initially generated by Compute Engine and changes after every
 | |
|         # request to modify or update labels. You must always provide an up-to-date
 | |
|         # fingerprint hash in order to update or change labels.
 | |
|         # To see the latest fingerprint, make get() request to the security policy.
 | |
|         # Corresponds to the JSON property `labelFingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :label_fingerprint
 | |
|       
 | |
|         # Labels to apply to this security policy resource. These can be later modified
 | |
|         # by the setLabels method. Each label key/value must comply with RFC1035. Label
 | |
|         # values may be empty.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # A list of rules that belong to this policy. There must always be a default
 | |
|         # rule (rule with priority 2147483647 and match "*"). If no rules are provided
 | |
|         # when creating a security policy, a default rule with action "allow" will be
 | |
|         # added.
 | |
|         # Corresponds to the JSON property `rules`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::SecurityPolicyRule>]
 | |
|         attr_accessor :rules
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # The type indicates the intended use of the security policy. CLOUD_ARMOR
 | |
|         # policies apply to backend services. FIREWALL policies apply to organizations.
 | |
|         # Corresponds to the JSON property `type`
 | |
|         # @return [String]
 | |
|         attr_accessor :type
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @associations = args[:associations] if args.key?(:associations)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @fingerprint = args[:fingerprint] if args.key?(:fingerprint)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @rules = args[:rules] if args.key?(:rules)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @type = args[:type] if args.key?(:type)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class SecurityPolicyAssociation
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The resource that the security policy is attached to.
 | |
|         # Corresponds to the JSON property `attachmentId`
 | |
|         # @return [String]
 | |
|         attr_accessor :attachment_id
 | |
|       
 | |
|         # The name for an association.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @attachment_id = args[:attachment_id] if args.key?(:attachment_id)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class SecurityPolicyList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of SecurityPolicy resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::SecurityPolicy>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#securityPolicyList for listsof
 | |
|         # securityPolicies
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::SecurityPolicyList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::SecurityPolicyList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class SecurityPolicyReference
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `securityPolicy`
 | |
|         # @return [String]
 | |
|         attr_accessor :security_policy
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @security_policy = args[:security_policy] if args.key?(:security_policy)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Represents a rule that describes one or more match conditions along with the
 | |
|       # action to be taken when traffic matches this condition (allow or deny).
 | |
|       class SecurityPolicyRule
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The Action to preform when the client connection triggers the rule. Can
 | |
|         # currently be either "allow" or "deny()" where valid values for status are 403,
 | |
|         # 404, and 502.
 | |
|         # Corresponds to the JSON property `action`
 | |
|         # @return [String]
 | |
|         attr_accessor :action
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # The direction in which this rule applies. This field may only be specified
 | |
|         # when versioned_expr is set to FIREWALL.
 | |
|         # Corresponds to the JSON property `direction`
 | |
|         # @return [String]
 | |
|         attr_accessor :direction
 | |
|       
 | |
|         # Denotes whether to enable logging for a particular rule. If logging is enabled,
 | |
|         # logs will be exported to the configured export destination in Stackdriver.
 | |
|         # Logs may be exported to BigQuery or Pub/Sub. Note: you cannot enable logging
 | |
|         # on "goto_next" rules.
 | |
|         # This field may only be specified when the versioned_expr is set to FIREWALL.
 | |
|         # Corresponds to the JSON property `enableLogging`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :enable_logging
 | |
|         alias_method :enable_logging?, :enable_logging
 | |
|       
 | |
|         # [Output only] Type of the resource. Always compute#securityPolicyRule for
 | |
|         # security policy rules
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # Represents a match condition that incoming traffic is evaluated against.
 | |
|         # Exactly one field must be specified.
 | |
|         # Corresponds to the JSON property `match`
 | |
|         # @return [Google::Apis::ComputeAlpha::SecurityPolicyRuleMatcher]
 | |
|         attr_accessor :match
 | |
|       
 | |
|         # If set to true, the specified action is not enforced.
 | |
|         # Corresponds to the JSON property `preview`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :preview
 | |
|         alias_method :preview?, :preview
 | |
|       
 | |
|         # An integer indicating the priority of a rule in the list. The priority must be
 | |
|         # a positive value between 0 and 2147483647. Rules are evaluated from highest to
 | |
|         # lowest priority where 0 is the highest priority and 2147483647 is the lowest
 | |
|         # prority.
 | |
|         # Corresponds to the JSON property `priority`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :priority
 | |
|       
 | |
|         # A list of network resource URLs to which this rule applies. This field allows
 | |
|         # you to control which network?s VMs get this rule. If this field is left blank,
 | |
|         # all VMs within the organization will receive the rule.
 | |
|         # This field may only be specified when versioned_expr is set to FIREWALL.
 | |
|         # Corresponds to the JSON property `targetResources`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :target_resources
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @action = args[:action] if args.key?(:action)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @direction = args[:direction] if args.key?(:direction)
 | |
|           @enable_logging = args[:enable_logging] if args.key?(:enable_logging)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @match = args[:match] if args.key?(:match)
 | |
|           @preview = args[:preview] if args.key?(:preview)
 | |
|           @priority = args[:priority] if args.key?(:priority)
 | |
|           @target_resources = args[:target_resources] if args.key?(:target_resources)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Represents a match condition that incoming traffic is evaluated against.
 | |
|       # Exactly one field must be specified.
 | |
|       class SecurityPolicyRuleMatcher
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The configuration options available when specifying versioned_expr. This field
 | |
|         # must be specified if versioned_expr is specified and cannot be specified if
 | |
|         # versioned_expr is not specified.
 | |
|         # Corresponds to the JSON property `config`
 | |
|         # @return [Google::Apis::ComputeAlpha::SecurityPolicyRuleMatcherConfig]
 | |
|         attr_accessor :config
 | |
|       
 | |
|         # Represents an expression text. Example:
 | |
|         # title: "User account presence" description: "Determines whether the request
 | |
|         # has a user account" expression: "size(request.user) > 0"
 | |
|         # Corresponds to the JSON property `expr`
 | |
|         # @return [Google::Apis::ComputeAlpha::Expr]
 | |
|         attr_accessor :expr
 | |
|       
 | |
|         # Preconfigured versioned expression. If this field is specified, config must
 | |
|         # also be specified. Available preconfigured expressions along with their
 | |
|         # requirements are: SRC_IPS_V1 - must specify the corresponding src_ip_range
 | |
|         # field in config.
 | |
|         # Corresponds to the JSON property `versionedExpr`
 | |
|         # @return [String]
 | |
|         attr_accessor :versioned_expr
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @config = args[:config] if args.key?(:config)
 | |
|           @expr = args[:expr] if args.key?(:expr)
 | |
|           @versioned_expr = args[:versioned_expr] if args.key?(:versioned_expr)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class SecurityPolicyRuleMatcherConfig
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # CIDR IP address range.
 | |
|         # This field may only be specified when versioned_expr is set to FIREWALL.
 | |
|         # Corresponds to the JSON property `destIpRanges`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :dest_ip_ranges
 | |
|       
 | |
|         # Pairs of IP protocols and ports that the rule should match.
 | |
|         # This field may only be specified when versioned_expr is set to FIREWALL.
 | |
|         # Corresponds to the JSON property `destPorts`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::SecurityPolicyRuleMatcherConfigDestinationPort>]
 | |
|         attr_accessor :dest_ports
 | |
|       
 | |
|         # CIDR IP address range.
 | |
|         # Corresponds to the JSON property `srcIpRanges`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :src_ip_ranges
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @dest_ip_ranges = args[:dest_ip_ranges] if args.key?(:dest_ip_ranges)
 | |
|           @dest_ports = args[:dest_ports] if args.key?(:dest_ports)
 | |
|           @src_ip_ranges = args[:src_ip_ranges] if args.key?(:src_ip_ranges)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class SecurityPolicyRuleMatcherConfigDestinationPort
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The IP protocol to which this rule applies. The protocol type is required when
 | |
|         # creating a firewall rule. This value can either be one of the following well
 | |
|         # known protocol strings (tcp, udp, icmp, esp, ah, ipip, sctp), or the IP
 | |
|         # protocol number.
 | |
|         # Corresponds to the JSON property `ipProtocol`
 | |
|         # @return [String]
 | |
|         attr_accessor :ip_protocol
 | |
|       
 | |
|         # An optional list of ports to which this rule applies. This field is only
 | |
|         # applicable for UDP or TCP protocol. Each entry must be either an integer or a
 | |
|         # range. If not specified, this rule applies to connections through any port.
 | |
|         # Example inputs include: ["22"], ["80","443"], and ["12345-12349"].
 | |
|         # This field may only be specified when versioned_expr is set to FIREWALL.
 | |
|         # Corresponds to the JSON property `ports`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :ports
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @ip_protocol = args[:ip_protocol] if args.key?(:ip_protocol)
 | |
|           @ports = args[:ports] if args.key?(:ports)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # An instance's serial console output.
 | |
|       class SerialPortOutput
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The contents of the console output.
 | |
|         # Corresponds to the JSON property `contents`
 | |
|         # @return [String]
 | |
|         attr_accessor :contents
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#serialPortOutput for serial
 | |
|         # port output.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] The position of the next byte of content from the serial console
 | |
|         # output. Use this value in the next request as the start parameter.
 | |
|         # Corresponds to the JSON property `next`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :next
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # The starting byte position of the output that was returned. This should match
 | |
|         # the start parameter sent with the request. If the serial console output
 | |
|         # exceeds the size of the buffer, older output will be overwritten by newer
 | |
|         # content and the start values will be mismatched.
 | |
|         # Corresponds to the JSON property `start`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :start
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @contents = args[:contents] if args.key?(:contents)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next = args[:next] if args.key?(:next)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @start = args[:start] if args.key?(:start)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ServerBinding
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `type`
 | |
|         # @return [String]
 | |
|         attr_accessor :type
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @type = args[:type] if args.key?(:type)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A service account.
 | |
|       class ServiceAccount
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Email address of the service account.
 | |
|         # Corresponds to the JSON property `email`
 | |
|         # @return [String]
 | |
|         attr_accessor :email
 | |
|       
 | |
|         # The list of scopes to be made available for this service account.
 | |
|         # Corresponds to the JSON property `scopes`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :scopes
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @email = args[:email] if args.key?(:email)
 | |
|           @scopes = args[:scopes] if args.key?(:scopes)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A set of Shielded VM options.
 | |
|       class ShieldedVmConfig
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Defines whether the instance has integrity monitoring enabled.
 | |
|         # Corresponds to the JSON property `enableIntegrityMonitoring`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :enable_integrity_monitoring
 | |
|         alias_method :enable_integrity_monitoring?, :enable_integrity_monitoring
 | |
|       
 | |
|         # Defines whether the instance has Secure Boot enabled.
 | |
|         # Corresponds to the JSON property `enableSecureBoot`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :enable_secure_boot
 | |
|         alias_method :enable_secure_boot?, :enable_secure_boot
 | |
|       
 | |
|         # Defines whether the instance has the vTPM enabled.
 | |
|         # Corresponds to the JSON property `enableVtpm`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :enable_vtpm
 | |
|         alias_method :enable_vtpm?, :enable_vtpm
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @enable_integrity_monitoring = args[:enable_integrity_monitoring] if args.key?(:enable_integrity_monitoring)
 | |
|           @enable_secure_boot = args[:enable_secure_boot] if args.key?(:enable_secure_boot)
 | |
|           @enable_vtpm = args[:enable_vtpm] if args.key?(:enable_vtpm)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A shielded VM identity entry.
 | |
|       class ShieldedVmIdentity
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A Shielded Instance Identity Entry.
 | |
|         # Corresponds to the JSON property `encryptionKey`
 | |
|         # @return [Google::Apis::ComputeAlpha::ShieldedVmIdentityEntry]
 | |
|         attr_accessor :encryption_key
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#shieldedVmIdentity for
 | |
|         # shielded VM identity entry.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # A Shielded Instance Identity Entry.
 | |
|         # Corresponds to the JSON property `signingKey`
 | |
|         # @return [Google::Apis::ComputeAlpha::ShieldedVmIdentityEntry]
 | |
|         attr_accessor :signing_key
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @encryption_key = args[:encryption_key] if args.key?(:encryption_key)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @signing_key = args[:signing_key] if args.key?(:signing_key)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A Shielded Instance Identity Entry.
 | |
|       class ShieldedVmIdentityEntry
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A PEM-encoded X.509 certificate. This field can be empty.
 | |
|         # Corresponds to the JSON property `ekCert`
 | |
|         # @return [String]
 | |
|         attr_accessor :ek_cert
 | |
|       
 | |
|         # A PEM-encoded public key.
 | |
|         # Corresponds to the JSON property `ekPub`
 | |
|         # @return [String]
 | |
|         attr_accessor :ek_pub
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @ek_cert = args[:ek_cert] if args.key?(:ek_cert)
 | |
|           @ek_pub = args[:ek_pub] if args.key?(:ek_pub)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The policy describes the baseline against which VM instance boot integrity is
 | |
|       # measured.
 | |
|       class ShieldedVmIntegrityPolicy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Updates the integrity policy baseline using the measurements from the VM
 | |
|         # instance's most recent boot.
 | |
|         # Corresponds to the JSON property `updateAutoLearnPolicy`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :update_auto_learn_policy
 | |
|         alias_method :update_auto_learn_policy?, :update_auto_learn_policy
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @update_auto_learn_policy = args[:update_auto_learn_policy] if args.key?(:update_auto_learn_policy)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Represents a customer-supplied Signing Key used by Cloud CDN Signed URLs
 | |
|       class SignedUrlKey
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Name of the key. 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.
 | |
|         # Corresponds to the JSON property `keyName`
 | |
|         # @return [String]
 | |
|         attr_accessor :key_name
 | |
|       
 | |
|         # 128-bit key value used for signing the URL. The key value must be a valid RFC
 | |
|         # 4648 Section 5 base64url encoded string.
 | |
|         # Corresponds to the JSON property `keyValue`
 | |
|         # @return [String]
 | |
|         attr_accessor :key_value
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @key_name = args[:key_name] if args.key?(:key_name)
 | |
|           @key_value = args[:key_value] if args.key?(:key_value)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A persistent disk snapshot resource. (== resource_for beta.snapshots ==) (==
 | |
|       # resource_for v1.snapshots ==)
 | |
|       class Snapshot
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Set to true if snapshots are automatically by applying resource
 | |
|         # policy on the target disk.
 | |
|         # Corresponds to the JSON property `autoCreated`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :auto_created
 | |
|         alias_method :auto_created?, :auto_created
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] Size of the snapshot, specified in GB.
 | |
|         # Corresponds to the JSON property `diskSizeGb`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :disk_size_gb
 | |
|       
 | |
|         # [Output Only] A list of features to enable on the guest operating system.
 | |
|         # Applicable only for bootable images. Read  Enabling guest operating system
 | |
|         # features to see a list of available options.
 | |
|         # Corresponds to the JSON property `guestOsFeatures`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::GuestOsFeature>]
 | |
|         attr_accessor :guest_os_features
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#snapshot for Snapshot
 | |
|         # resources.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # A fingerprint for the labels being applied to this snapshot, which is
 | |
|         # essentially a hash of the labels set used for optimistic locking. The
 | |
|         # fingerprint is initially generated by Compute Engine and changes after every
 | |
|         # request to modify or update labels. You must always provide an up-to-date
 | |
|         # fingerprint hash in order to update or change labels, otherwise the request
 | |
|         # will fail with error 412 conditionNotMet.
 | |
|         # To see the latest fingerprint, make a get() request to retrieve a snapshot.
 | |
|         # Corresponds to the JSON property `labelFingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :label_fingerprint
 | |
|       
 | |
|         # Labels to apply to this snapshot. These can be later modified by the setLabels
 | |
|         # method. Label values may be empty.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         # [Output Only] Integer license codes indicating which licenses are attached to
 | |
|         # this snapshot.
 | |
|         # Corresponds to the JSON property `licenseCodes`
 | |
|         # @return [Array<Fixnum>]
 | |
|         attr_accessor :license_codes
 | |
|       
 | |
|         # [Output Only] A list of public visible licenses that apply to this snapshot.
 | |
|         # This can be because the original image had licenses attached (such as a
 | |
|         # Windows image).
 | |
|         # Corresponds to the JSON property `licenses`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :licenses
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource's resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # Represents a customer-supplied encryption key
 | |
|         # Corresponds to the JSON property `snapshotEncryptionKey`
 | |
|         # @return [Google::Apis::ComputeAlpha::CustomerEncryptionKey]
 | |
|         attr_accessor :snapshot_encryption_key
 | |
|       
 | |
|         # [Output Only] The source disk used to create this snapshot.
 | |
|         # Corresponds to the JSON property `sourceDisk`
 | |
|         # @return [String]
 | |
|         attr_accessor :source_disk
 | |
|       
 | |
|         # Represents a customer-supplied encryption key
 | |
|         # Corresponds to the JSON property `sourceDiskEncryptionKey`
 | |
|         # @return [Google::Apis::ComputeAlpha::CustomerEncryptionKey]
 | |
|         attr_accessor :source_disk_encryption_key
 | |
|       
 | |
|         # [Output Only] The ID value of the disk used to create this snapshot. This
 | |
|         # value may be used to determine whether the snapshot was taken from the current
 | |
|         # or a previous instance of a given disk name.
 | |
|         # Corresponds to the JSON property `sourceDiskId`
 | |
|         # @return [String]
 | |
|         attr_accessor :source_disk_id
 | |
|       
 | |
|         # [Output Only] The status of the snapshot. This can be CREATING, DELETING,
 | |
|         # FAILED, READY, or UPLOADING.
 | |
|         # Corresponds to the JSON property `status`
 | |
|         # @return [String]
 | |
|         attr_accessor :status
 | |
|       
 | |
|         # [Output Only] A size of the storage used by the snapshot. As snapshots share
 | |
|         # storage, this number is expected to change with snapshot creation/deletion.
 | |
|         # Corresponds to the JSON property `storageBytes`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :storage_bytes
 | |
|       
 | |
|         # [Output Only] An indicator whether storageBytes is in a stable state or it is
 | |
|         # being adjusted as a result of shared storage reallocation. This status can
 | |
|         # either be UPDATING, meaning the size of the snapshot is being updated, or
 | |
|         # UP_TO_DATE, meaning the size of the snapshot is up-to-date.
 | |
|         # Corresponds to the JSON property `storageBytesStatus`
 | |
|         # @return [String]
 | |
|         attr_accessor :storage_bytes_status
 | |
|       
 | |
|         # GCS bucket storage location of the snapshot (regional or multi-regional).
 | |
|         # Corresponds to the JSON property `storageLocations`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :storage_locations
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @auto_created = args[:auto_created] if args.key?(:auto_created)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @disk_size_gb = args[:disk_size_gb] if args.key?(:disk_size_gb)
 | |
|           @guest_os_features = args[:guest_os_features] if args.key?(:guest_os_features)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|           @license_codes = args[:license_codes] if args.key?(:license_codes)
 | |
|           @licenses = args[:licenses] if args.key?(:licenses)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @snapshot_encryption_key = args[:snapshot_encryption_key] if args.key?(:snapshot_encryption_key)
 | |
|           @source_disk = args[:source_disk] if args.key?(:source_disk)
 | |
|           @source_disk_encryption_key = args[:source_disk_encryption_key] if args.key?(:source_disk_encryption_key)
 | |
|           @source_disk_id = args[:source_disk_id] if args.key?(:source_disk_id)
 | |
|           @status = args[:status] if args.key?(:status)
 | |
|           @storage_bytes = args[:storage_bytes] if args.key?(:storage_bytes)
 | |
|           @storage_bytes_status = args[:storage_bytes_status] if args.key?(:storage_bytes_status)
 | |
|           @storage_locations = args[:storage_locations] if args.key?(:storage_locations)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of Snapshot resources.
 | |
|       class SnapshotList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of Snapshot resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Snapshot>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::SnapshotList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::SnapshotList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A specification of the parameters to use when creating the instance template
 | |
|       # from a source instance.
 | |
|       class SourceInstanceParams
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Attached disks configuration. If not provided, defaults are applied: For boot
 | |
|         # disk and any other R/W disks, new custom images will be created from each disk.
 | |
|         # For read-only disks, they will be attached in read-only mode. Local SSD disks
 | |
|         # will be created as blank volumes.
 | |
|         # Corresponds to the JSON property `diskConfigs`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::DiskInstantiationConfig>]
 | |
|         attr_accessor :disk_configs
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @disk_configs = args[:disk_configs] if args.key?(:disk_configs)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class SourceInstanceProperties
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Enables instances created based on this machine image to send packets with
 | |
|         # source IP addresses other than their own and receive packets with destination
 | |
|         # IP addresses other than their own. If these instances will be used as an IP
 | |
|         # gateway or it will be set as the next-hop in a Route resource, specify true.
 | |
|         # If unsure, leave this set to false. See the Enable IP forwarding documentation
 | |
|         # for more information.
 | |
|         # Corresponds to the JSON property `canIpForward`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :can_ip_forward
 | |
|         alias_method :can_ip_forward?, :can_ip_forward
 | |
|       
 | |
|         # Whether the instance created from the machine image should be protected
 | |
|         # against deletion.
 | |
|         # Corresponds to the JSON property `deletionProtection`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :deletion_protection
 | |
|         alias_method :deletion_protection?, :deletion_protection
 | |
|       
 | |
|         # An optional text description for the instances that are created from this
 | |
|         # machine image.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # An array of disks that are associated with the instances that are created from
 | |
|         # this machine image.
 | |
|         # Corresponds to the JSON property `disks`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::SavedAttachedDisk>]
 | |
|         attr_accessor :disks
 | |
|       
 | |
|         # A list of guest accelerator cards' type and count to use for instances created
 | |
|         # from the machine image.
 | |
|         # Corresponds to the JSON property `guestAccelerators`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::AcceleratorConfig>]
 | |
|         attr_accessor :guest_accelerators
 | |
|       
 | |
|         # Labels to apply to instances that are created from this machine image.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         # The machine type to use for instances that are created from this machine image.
 | |
|         # Corresponds to the JSON property `machineType`
 | |
|         # @return [String]
 | |
|         attr_accessor :machine_type
 | |
|       
 | |
|         # A metadata key/value entry.
 | |
|         # Corresponds to the JSON property `metadata`
 | |
|         # @return [Google::Apis::ComputeAlpha::Metadata]
 | |
|         attr_accessor :metadata
 | |
|       
 | |
|         # Minimum cpu/platform to be used by this instance. The instance may be
 | |
|         # scheduled on the specified or newer cpu/platform. Applicable values are the
 | |
|         # friendly names of CPU platforms, such as minCpuPlatform: "Intel Haswell" or
 | |
|         # minCpuPlatform: "Intel Sandy Bridge". For more information, read Specifying a
 | |
|         # Minimum CPU Platform.
 | |
|         # Corresponds to the JSON property `minCpuPlatform`
 | |
|         # @return [String]
 | |
|         attr_accessor :min_cpu_platform
 | |
|       
 | |
|         # An array of network access configurations for this interface.
 | |
|         # Corresponds to the JSON property `networkInterfaces`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::NetworkInterface>]
 | |
|         attr_accessor :network_interfaces
 | |
|       
 | |
|         # Sets the scheduling options for an Instance.
 | |
|         # Corresponds to the JSON property `scheduling`
 | |
|         # @return [Google::Apis::ComputeAlpha::Scheduling]
 | |
|         attr_accessor :scheduling
 | |
|       
 | |
|         # A list of service accounts with specified scopes. Access tokens for these
 | |
|         # service accounts are available to the instances that are created from this
 | |
|         # machine image. Use metadata queries to obtain the access tokens for these
 | |
|         # instances.
 | |
|         # Corresponds to the JSON property `serviceAccounts`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::ServiceAccount>]
 | |
|         attr_accessor :service_accounts
 | |
|       
 | |
|         # A set of instance tags.
 | |
|         # Corresponds to the JSON property `tags`
 | |
|         # @return [Google::Apis::ComputeAlpha::Tags]
 | |
|         attr_accessor :tags
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @can_ip_forward = args[:can_ip_forward] if args.key?(:can_ip_forward)
 | |
|           @deletion_protection = args[:deletion_protection] if args.key?(:deletion_protection)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @disks = args[:disks] if args.key?(:disks)
 | |
|           @guest_accelerators = args[:guest_accelerators] if args.key?(:guest_accelerators)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|           @machine_type = args[:machine_type] if args.key?(:machine_type)
 | |
|           @metadata = args[:metadata] if args.key?(:metadata)
 | |
|           @min_cpu_platform = args[:min_cpu_platform] if args.key?(:min_cpu_platform)
 | |
|           @network_interfaces = args[:network_interfaces] if args.key?(:network_interfaces)
 | |
|           @scheduling = args[:scheduling] if args.key?(:scheduling)
 | |
|           @service_accounts = args[:service_accounts] if args.key?(:service_accounts)
 | |
|           @tags = args[:tags] if args.key?(:tags)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # An SslCertificate resource. This resource provides a mechanism to upload an
 | |
|       # SSL key and certificate to the load balancer to serve secure connections from
 | |
|       # the user. (== resource_for beta.sslCertificates ==) (== resource_for v1.
 | |
|       # sslCertificates ==)
 | |
|       class SslCertificate
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A local certificate file. The certificate must be in PEM format. The
 | |
|         # certificate chain must be no greater than 5 certs long. The chain must include
 | |
|         # at least one intermediate cert.
 | |
|         # Corresponds to the JSON property `certificate`
 | |
|         # @return [String]
 | |
|         attr_accessor :certificate
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] Expire time of the certificate. RFC3339
 | |
|         # Corresponds to the JSON property `expireTime`
 | |
|         # @return [String]
 | |
|         attr_accessor :expire_time
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#sslCertificate for SSL
 | |
|         # certificates.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # Configuration and status of a managed SSL certificate.
 | |
|         # Corresponds to the JSON property `managed`
 | |
|         # @return [Google::Apis::ComputeAlpha::SslCertificateManagedSslCertificate]
 | |
|         attr_accessor :managed
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # A write-only private key in PEM format. Only insert requests will include this
 | |
|         # field.
 | |
|         # Corresponds to the JSON property `privateKey`
 | |
|         # @return [String]
 | |
|         attr_accessor :private_key
 | |
|       
 | |
|         # [Output Only] URL of the region where the regional SSL Certificate resides.
 | |
|         # This field is not applicable to global SSL Certificate.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # [Output only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # Configuration and status of a self-managed SSL certificate.
 | |
|         # Corresponds to the JSON property `selfManaged`
 | |
|         # @return [Google::Apis::ComputeAlpha::SslCertificateSelfManagedSslCertificate]
 | |
|         attr_accessor :self_managed
 | |
|       
 | |
|         # [Output Only] Domains associated with the certificate via Subject Alternative
 | |
|         # Name.
 | |
|         # Corresponds to the JSON property `subjectAlternativeNames`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :subject_alternative_names
 | |
|       
 | |
|         # (Optional) Specifies the type of SSL certificate, either "SELF_MANAGED" or "
 | |
|         # MANAGED". If not specified, the certificate is self-managed and the fields
 | |
|         # certificate and private_key are used.
 | |
|         # Corresponds to the JSON property `type`
 | |
|         # @return [String]
 | |
|         attr_accessor :type
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @certificate = args[:certificate] if args.key?(:certificate)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @expire_time = args[:expire_time] if args.key?(:expire_time)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @managed = args[:managed] if args.key?(:managed)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @private_key = args[:private_key] if args.key?(:private_key)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @self_managed = args[:self_managed] if args.key?(:self_managed)
 | |
|           @subject_alternative_names = args[:subject_alternative_names] if args.key?(:subject_alternative_names)
 | |
|           @type = args[:type] if args.key?(:type)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class SslCertificateAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of SslCertificatesScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::SslCertificatesScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#sslCertificateAggregatedList
 | |
|         # for lists of SSL Certificates.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::SslCertificateAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::SslCertificateAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of SslCertificate resources.
 | |
|       class SslCertificateList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of SslCertificate resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::SslCertificate>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::SslCertificateList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::SslCertificateList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Configuration and status of a managed SSL certificate.
 | |
|       class SslCertificateManagedSslCertificate
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output only] Detailed statuses of the domains specified for managed
 | |
|         # certificate resource.
 | |
|         # Corresponds to the JSON property `domainStatus`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :domain_status
 | |
|       
 | |
|         # The domains for which a managed SSL certificate will be generated. Currently
 | |
|         # only single-domain certs are supported.
 | |
|         # Corresponds to the JSON property `domains`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :domains
 | |
|       
 | |
|         # [Output only] Status of the managed certificate resource.
 | |
|         # Corresponds to the JSON property `status`
 | |
|         # @return [String]
 | |
|         attr_accessor :status
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @domain_status = args[:domain_status] if args.key?(:domain_status)
 | |
|           @domains = args[:domains] if args.key?(:domains)
 | |
|           @status = args[:status] if args.key?(:status)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Configuration and status of a self-managed SSL certificate.
 | |
|       class SslCertificateSelfManagedSslCertificate
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A local certificate file. The certificate must be in PEM format. The
 | |
|         # certificate chain must be no greater than 5 certs long. The chain must include
 | |
|         # at least one intermediate cert.
 | |
|         # Corresponds to the JSON property `certificate`
 | |
|         # @return [String]
 | |
|         attr_accessor :certificate
 | |
|       
 | |
|         # A write-only private key in PEM format. Only insert requests will include this
 | |
|         # field.
 | |
|         # Corresponds to the JSON property `privateKey`
 | |
|         # @return [String]
 | |
|         attr_accessor :private_key
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @certificate = args[:certificate] if args.key?(:certificate)
 | |
|           @private_key = args[:private_key] if args.key?(:private_key)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class SslCertificatesScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # List of SslCertificates contained in this scope.
 | |
|         # Corresponds to the JSON property `sslCertificates`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::SslCertificate>]
 | |
|         attr_accessor :ssl_certificates
 | |
|       
 | |
|         # Informational warning which replaces the list of backend services when the
 | |
|         # list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::SslCertificatesScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @ssl_certificates = args[:ssl_certificates] if args.key?(:ssl_certificates)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # Informational warning which replaces the list of backend services when the
 | |
|         # list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::SslCertificatesScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class SslPoliciesList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of SslPolicy resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::SslPolicy>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#sslPoliciesList for lists
 | |
|         # of sslPolicies.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::SslPoliciesList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::SslPoliciesList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class SslPoliciesListAvailableFeaturesResponse
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `features`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :features
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @features = args[:features] if args.key?(:features)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A SSL policy specifies the server-side support for SSL features. This can be
 | |
|       # attached to a TargetHttpsProxy or a TargetSslProxy. This affects connections
 | |
|       # between clients and the HTTPS or SSL proxy load balancer. They do not affect
 | |
|       # the connection between the load balancers and the backends.
 | |
|       class SslPolicy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # A list of features enabled when the selected profile is CUSTOM. The
 | |
|         # - method returns the set of features that can be specified in this list. This
 | |
|         # field must be empty if the profile is not CUSTOM.
 | |
|         # Corresponds to the JSON property `customFeatures`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :custom_features
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The list of features enabled in the SSL policy.
 | |
|         # Corresponds to the JSON property `enabledFeatures`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :enabled_features
 | |
|       
 | |
|         # Fingerprint of this resource. A hash of the contents stored in this object.
 | |
|         # This field is used in optimistic locking. This field will be ignored when
 | |
|         # inserting a SslPolicy. An up-to-date fingerprint must be provided in order to
 | |
|         # update the SslPolicy, otherwise the request will fail with error 412
 | |
|         # conditionNotMet.
 | |
|         # To see the latest fingerprint, make a get() request to retrieve an SslPolicy.
 | |
|         # Corresponds to the JSON property `fingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :fingerprint
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output only] Type of the resource. Always compute#sslPolicyfor SSL policies.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # The minimum version of SSL protocol that can be used by the clients to
 | |
|         # establish a connection with the load balancer. This can be one of TLS_1_0,
 | |
|         # TLS_1_1, TLS_1_2.
 | |
|         # Corresponds to the JSON property `minTlsVersion`
 | |
|         # @return [String]
 | |
|         attr_accessor :min_tls_version
 | |
|       
 | |
|         # Name of the resource. 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # Profile specifies the set of SSL features that can be used by the load
 | |
|         # balancer when negotiating SSL with clients. This can be one of COMPATIBLE,
 | |
|         # MODERN, RESTRICTED, or CUSTOM. If using CUSTOM, the set of SSL features to
 | |
|         # enable must be specified in the customFeatures field.
 | |
|         # Corresponds to the JSON property `profile`
 | |
|         # @return [String]
 | |
|         attr_accessor :profile
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # [Output Only] If potential misconfigurations are detected for this SSL policy,
 | |
|         # this field will be populated with warning messages.
 | |
|         # Corresponds to the JSON property `warnings`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::SslPolicy::Warning>]
 | |
|         attr_accessor :warnings
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @custom_features = args[:custom_features] if args.key?(:custom_features)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @enabled_features = args[:enabled_features] if args.key?(:enabled_features)
 | |
|           @fingerprint = args[:fingerprint] if args.key?(:fingerprint)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @min_tls_version = args[:min_tls_version] if args.key?(:min_tls_version)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @profile = args[:profile] if args.key?(:profile)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @warnings = args[:warnings] if args.key?(:warnings)
 | |
|         end
 | |
|         
 | |
|         # 
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::SslPolicy::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class SslPolicyReference
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # URL of the SSL policy resource. Set this to empty string to clear any existing
 | |
|         # SSL policy associated with the target proxy resource.
 | |
|         # Corresponds to the JSON property `sslPolicy`
 | |
|         # @return [String]
 | |
|         attr_accessor :ssl_policy
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @ssl_policy = args[:ssl_policy] if args.key?(:ssl_policy)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class StatefulPolicy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Configuration of all preserved resources.
 | |
|         # Corresponds to the JSON property `preservedResources`
 | |
|         # @return [Google::Apis::ComputeAlpha::StatefulPolicyPreservedResources]
 | |
|         attr_accessor :preserved_resources
 | |
|       
 | |
|         # Configuration of preserved resources.
 | |
|         # Corresponds to the JSON property `preservedState`
 | |
|         # @return [Google::Apis::ComputeAlpha::StatefulPolicyPreservedState]
 | |
|         attr_accessor :preserved_state
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @preserved_resources = args[:preserved_resources] if args.key?(:preserved_resources)
 | |
|           @preserved_state = args[:preserved_state] if args.key?(:preserved_state)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class StatefulPolicyPreservedDisk
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Device name of the disk to be preserved
 | |
|         # Corresponds to the JSON property `deviceName`
 | |
|         # @return [String]
 | |
|         attr_accessor :device_name
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @device_name = args[:device_name] if args.key?(:device_name)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Configuration of all preserved resources.
 | |
|       class StatefulPolicyPreservedResources
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Disks created on the instances that will be preserved on instance delete,
 | |
|         # resize down, etc.
 | |
|         # Corresponds to the JSON property `disks`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::StatefulPolicyPreservedDisk>]
 | |
|         attr_accessor :disks
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @disks = args[:disks] if args.key?(:disks)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Configuration of preserved resources.
 | |
|       class StatefulPolicyPreservedState
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Disks created on the instances that will be preserved on instance delete,
 | |
|         # resize down, etc. This map is keyed with the device names of the disks.
 | |
|         # Corresponds to the JSON property `disks`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::StatefulPolicyPreservedStateDiskDevice>]
 | |
|         attr_accessor :disks
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @disks = args[:disks] if args.key?(:disks)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class StatefulPolicyPreservedStateDiskDevice
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # These stateful disks will never be deleted during autohealing, update or VM
 | |
|         # instance recreate operations. This flag is used to configure if the disk
 | |
|         # should be deleted after it is no longer used by the group, e.g. when the given
 | |
|         # instance or the whole group is deleted. Note: disks attached in READ_ONLY mode
 | |
|         # cannot be auto-deleted.
 | |
|         # Corresponds to the JSON property `autoDelete`
 | |
|         # @return [String]
 | |
|         attr_accessor :auto_delete
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @auto_delete = args[:auto_delete] if args.key?(:auto_delete)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A Subnetwork resource. (== resource_for beta.subnetworks ==) (== resource_for
 | |
|       # v1.subnetworks ==)
 | |
|       class Subnetwork
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Can only be specified if VPC flow logging for this subnetwork is enabled.
 | |
|         # Toggles the aggregation interval for collecting flow logs. Increasing the
 | |
|         # interval time will reduce the amount of generated flow logs for long lasting
 | |
|         # connections. Default is an interval of 5 seconds per connection.
 | |
|         # Corresponds to the JSON property `aggregationInterval`
 | |
|         # @return [String]
 | |
|         attr_accessor :aggregation_interval
 | |
|       
 | |
|         # Whether this subnetwork can conflict with static routes. Setting this to true
 | |
|         # allows this subnetwork's primary and secondary ranges to conflict with routes
 | |
|         # that have already been configured on the corresponding network. Static routes
 | |
|         # will take precedence over the subnetwork route if the route prefix length is
 | |
|         # at least as large as the subnetwork prefix length.
 | |
|         # Also, packets destined to IPs within subnetwork may contain private/sensitive
 | |
|         # data and are prevented from leaving the virtual network. Setting this field to
 | |
|         # true will disable this feature.
 | |
|         # The default value is false and applies to all existing subnetworks and
 | |
|         # automatically created subnetworks.
 | |
|         # This field cannot be set to true at resource creation time.
 | |
|         # Corresponds to the JSON property `allowSubnetCidrRoutesOverlap`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :allow_subnet_cidr_routes_overlap
 | |
|         alias_method :allow_subnet_cidr_routes_overlap?, :allow_subnet_cidr_routes_overlap
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource. This field can be set only at resource creation time.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # Whether to enable flow logging for this subnetwork. If this field is not
 | |
|         # explicitly set, it will not appear in get listings. If not set the default
 | |
|         # behavior is to disable flow logging.
 | |
|         # Corresponds to the JSON property `enableFlowLogs`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :enable_flow_logs
 | |
|         alias_method :enable_flow_logs?, :enable_flow_logs
 | |
|       
 | |
|         # Deprecated in favor of enable in PrivateIpv6GoogleAccess. Whether the VMs in
 | |
|         # this subnet can directly access Google services via internal IPv6 addresses.
 | |
|         # This field can be both set at resource creation time and updated using patch.
 | |
|         # Corresponds to the JSON property `enablePrivateV6Access`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :enable_private_v6_access
 | |
|         alias_method :enable_private_v6_access?, :enable_private_v6_access
 | |
|       
 | |
|         # Fingerprint of this resource. A hash of the contents stored in this object.
 | |
|         # This field is used in optimistic locking. This field will be ignored when
 | |
|         # inserting a Subnetwork. An up-to-date fingerprint must be provided in order to
 | |
|         # update the Subnetwork, otherwise the request will fail with error 412
 | |
|         # conditionNotMet.
 | |
|         # To see the latest fingerprint, make a get() request to retrieve a Subnetwork.
 | |
|         # Corresponds to the JSON property `fingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :fingerprint
 | |
|       
 | |
|         # Can only be specified if VPC flow logging for this subnetwork is enabled. The
 | |
|         # value of the field must be in [0, 1]. Set the sampling rate of VPC flow logs
 | |
|         # within the subnetwork where 1.0 means all collected logs are reported and 0.0
 | |
|         # means no logs are reported. Default is 0.5 which means half of all collected
 | |
|         # logs are reported.
 | |
|         # Corresponds to the JSON property `flowSampling`
 | |
|         # @return [Float]
 | |
|         attr_accessor :flow_sampling
 | |
|       
 | |
|         # [Output Only] The gateway address for default routes to reach destination
 | |
|         # addresses outside this subnetwork.
 | |
|         # Corresponds to the JSON property `gatewayAddress`
 | |
|         # @return [String]
 | |
|         attr_accessor :gateway_address
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # The range of internal addresses that are owned by this subnetwork. Provide
 | |
|         # this property when you create the subnetwork. For example, 10.0.0.0/8 or 192.
 | |
|         # 168.0.0/16. Ranges must be unique and non-overlapping within a network. Only
 | |
|         # IPv4 is supported. This field can be set only at resource creation time.
 | |
|         # Corresponds to the JSON property `ipCidrRange`
 | |
|         # @return [String]
 | |
|         attr_accessor :ip_cidr_range
 | |
|       
 | |
|         # [Output Only] The range of internal IPv6 addresses that are owned by this
 | |
|         # subnetwork.
 | |
|         # Corresponds to the JSON property `ipv6CidrRange`
 | |
|         # @return [String]
 | |
|         attr_accessor :ipv6_cidr_range
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#subnetwork for Subnetwork
 | |
|         # resources.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # The available logging options for this subnetwork.
 | |
|         # Corresponds to the JSON property `logConfig`
 | |
|         # @return [Google::Apis::ComputeAlpha::SubnetworkLogConfig]
 | |
|         attr_accessor :log_config
 | |
|       
 | |
|         # Can only be specified if VPC flow logging for this subnetwork is enabled.
 | |
|         # Configures whether metadata fields should be added to the reported VPC flow
 | |
|         # logs. Default is INCLUDE_ALL_METADATA.
 | |
|         # Corresponds to the JSON property `metadata`
 | |
|         # @return [String]
 | |
|         attr_accessor :metadata
 | |
|       
 | |
|         # The name of the resource, provided by the client when initially creating the
 | |
|         # resource. 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # The URL of the network to which this subnetwork belongs, provided by the
 | |
|         # client when initially creating the subnetwork. Only networks that are in the
 | |
|         # distributed mode can have subnetworks. This field can be set only at resource
 | |
|         # creation time.
 | |
|         # Corresponds to the JSON property `network`
 | |
|         # @return [String]
 | |
|         attr_accessor :network
 | |
|       
 | |
|         # Whether the VMs in this subnet can access Google services without assigned
 | |
|         # external IP addresses. This field can be both set at resource creation time
 | |
|         # and updated using setPrivateIpGoogleAccess.
 | |
|         # Corresponds to the JSON property `privateIpGoogleAccess`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :private_ip_google_access
 | |
|         alias_method :private_ip_google_access?, :private_ip_google_access
 | |
|       
 | |
|         # The private IPv6 google access type for the VMs in this subnet. This is an
 | |
|         # expanded field of enablePrivateV6Access. If both fields are set,
 | |
|         # privateIpv6GoogleAccess will take priority.
 | |
|         # This field can be both set at resource creation time and updated using patch.
 | |
|         # Corresponds to the JSON property `privateIpv6GoogleAccess`
 | |
|         # @return [String]
 | |
|         attr_accessor :private_ipv6_google_access
 | |
|       
 | |
|         # The purpose of the resource. This field can be either PRIVATE_RFC_1918 or
 | |
|         # INTERNAL_HTTPS_LOAD_BALANCER. A subnetwork with purpose set to
 | |
|         # INTERNAL_HTTPS_LOAD_BALANCER is a user-created subnetwork that is reserved for
 | |
|         # Internal HTTP(S) Load Balancing. If unspecified, the purpose defaults to
 | |
|         # PRIVATE_RFC_1918.
 | |
|         # Corresponds to the JSON property `purpose`
 | |
|         # @return [String]
 | |
|         attr_accessor :purpose
 | |
|       
 | |
|         # URL of the region where the Subnetwork resides. This field can be set only at
 | |
|         # resource creation time.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # The role of subnetwork. Currenly, this field is only used when purpose =
 | |
|         # INTERNAL_HTTPS_LOAD_BALANCER. The value can be set to ACTIVE or BACKUP. An
 | |
|         # ACTIVE subnetwork is one that is currently being used for Internal HTTP(S)
 | |
|         # Load Balancing. A BACKUP subnetwork is one that is ready to be promoted to
 | |
|         # ACTIVE or is currently draining. This field can be updated with a patch
 | |
|         # request.
 | |
|         # Corresponds to the JSON property `role`
 | |
|         # @return [String]
 | |
|         attr_accessor :role
 | |
|       
 | |
|         # An array of configurations for secondary IP ranges for VM instances contained
 | |
|         # in this subnetwork. The primary IP of such VM must belong to the primary
 | |
|         # ipCidrRange of the subnetwork. The alias IPs may belong to either primary or
 | |
|         # secondary ranges. This field can be updated with a patch request.
 | |
|         # Corresponds to the JSON property `secondaryIpRanges`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::SubnetworkSecondaryRange>]
 | |
|         attr_accessor :secondary_ip_ranges
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # [Output Only] The state of the subnetwork, which can be one of READY or
 | |
|         # DRAINING. A subnetwork that is READY is ready to be used. The state of
 | |
|         # DRAINING is only applicable to subnetworks that have the purpose set to
 | |
|         # INTERNAL_HTTPS_LOAD_BALANCER and indicates that connections to the load
 | |
|         # balancer are being drained. A subnetwork that is draining cannot be used or
 | |
|         # modified until it reaches a status of READY.
 | |
|         # Corresponds to the JSON property `state`
 | |
|         # @return [String]
 | |
|         attr_accessor :state
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @aggregation_interval = args[:aggregation_interval] if args.key?(:aggregation_interval)
 | |
|           @allow_subnet_cidr_routes_overlap = args[:allow_subnet_cidr_routes_overlap] if args.key?(:allow_subnet_cidr_routes_overlap)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @enable_flow_logs = args[:enable_flow_logs] if args.key?(:enable_flow_logs)
 | |
|           @enable_private_v6_access = args[:enable_private_v6_access] if args.key?(:enable_private_v6_access)
 | |
|           @fingerprint = args[:fingerprint] if args.key?(:fingerprint)
 | |
|           @flow_sampling = args[:flow_sampling] if args.key?(:flow_sampling)
 | |
|           @gateway_address = args[:gateway_address] if args.key?(:gateway_address)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @ip_cidr_range = args[:ip_cidr_range] if args.key?(:ip_cidr_range)
 | |
|           @ipv6_cidr_range = args[:ipv6_cidr_range] if args.key?(:ipv6_cidr_range)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @log_config = args[:log_config] if args.key?(:log_config)
 | |
|           @metadata = args[:metadata] if args.key?(:metadata)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @network = args[:network] if args.key?(:network)
 | |
|           @private_ip_google_access = args[:private_ip_google_access] if args.key?(:private_ip_google_access)
 | |
|           @private_ipv6_google_access = args[:private_ipv6_google_access] if args.key?(:private_ipv6_google_access)
 | |
|           @purpose = args[:purpose] if args.key?(:purpose)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @role = args[:role] if args.key?(:role)
 | |
|           @secondary_ip_ranges = args[:secondary_ip_ranges] if args.key?(:secondary_ip_ranges)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @state = args[:state] if args.key?(:state)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class SubnetworkAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of SubnetworksScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::SubnetworksScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#subnetworkAggregatedList for
 | |
|         # aggregated lists of subnetworks.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::SubnetworkAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::SubnetworkAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of Subnetwork resources.
 | |
|       class SubnetworkList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of Subnetwork resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Subnetwork>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#subnetworkList for lists of
 | |
|         # subnetworks.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::SubnetworkList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::SubnetworkList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The available logging options for this subnetwork.
 | |
|       class SubnetworkLogConfig
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Can only be specified if VPC flow logging for this subnetwork is enabled.
 | |
|         # Toggles the aggregation interval for collecting flow logs. Increasing the
 | |
|         # interval time will reduce the amount of generated flow logs for long lasting
 | |
|         # connections. Default is an interval of 5 seconds per connection.
 | |
|         # Corresponds to the JSON property `aggregationInterval`
 | |
|         # @return [String]
 | |
|         attr_accessor :aggregation_interval
 | |
|       
 | |
|         # Whether to enable flow logging for this subnetwork. If this field is not
 | |
|         # explicitly set, it will not appear in get listings. If not set the default
 | |
|         # behavior is to disable flow logging.
 | |
|         # Corresponds to the JSON property `enable`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :enable
 | |
|         alias_method :enable?, :enable
 | |
|       
 | |
|         # Can only be specified if VPC flow logging for this subnetwork is enabled. The
 | |
|         # value of the field must be in [0, 1]. Set the sampling rate of VPC flow logs
 | |
|         # within the subnetwork where 1.0 means all collected logs are reported and 0.0
 | |
|         # means no logs are reported. Default is 0.5 which means half of all collected
 | |
|         # logs are reported.
 | |
|         # Corresponds to the JSON property `flowSampling`
 | |
|         # @return [Float]
 | |
|         attr_accessor :flow_sampling
 | |
|       
 | |
|         # Can only be specified if VPC flow logging for this subnetwork is enabled.
 | |
|         # Configures whether metadata fields should be added to the reported VPC flow
 | |
|         # logs. Default is INCLUDE_ALL_METADATA.
 | |
|         # Corresponds to the JSON property `metadata`
 | |
|         # @return [String]
 | |
|         attr_accessor :metadata
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @aggregation_interval = args[:aggregation_interval] if args.key?(:aggregation_interval)
 | |
|           @enable = args[:enable] if args.key?(:enable)
 | |
|           @flow_sampling = args[:flow_sampling] if args.key?(:flow_sampling)
 | |
|           @metadata = args[:metadata] if args.key?(:metadata)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Represents a secondary IP range of a subnetwork.
 | |
|       class SubnetworkSecondaryRange
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The range of IP addresses belonging to this subnetwork secondary range.
 | |
|         # Provide this property when you create the subnetwork. Ranges must be unique
 | |
|         # and non-overlapping with all primary and secondary IP ranges within a network.
 | |
|         # Only IPv4 is supported.
 | |
|         # Corresponds to the JSON property `ipCidrRange`
 | |
|         # @return [String]
 | |
|         attr_accessor :ip_cidr_range
 | |
|       
 | |
|         # The name associated with this subnetwork secondary range, used when adding an
 | |
|         # alias IP range to a VM instance. The name must be 1-63 characters long, and
 | |
|         # comply with RFC1035. The name must be unique within the subnetwork.
 | |
|         # Corresponds to the JSON property `rangeName`
 | |
|         # @return [String]
 | |
|         attr_accessor :range_name
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @ip_cidr_range = args[:ip_cidr_range] if args.key?(:ip_cidr_range)
 | |
|           @range_name = args[:range_name] if args.key?(:range_name)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class SubnetworksExpandIpCidrRangeRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The IP (in CIDR format or netmask) of internal addresses that are legal on
 | |
|         # this Subnetwork. This range should be disjoint from other subnetworks within
 | |
|         # this network. This range can only be larger than (i.e. a superset of) the
 | |
|         # range previously defined before the update.
 | |
|         # Corresponds to the JSON property `ipCidrRange`
 | |
|         # @return [String]
 | |
|         attr_accessor :ip_cidr_range
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @ip_cidr_range = args[:ip_cidr_range] if args.key?(:ip_cidr_range)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class SubnetworksScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of subnetworks contained in this scope.
 | |
|         # Corresponds to the JSON property `subnetworks`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Subnetwork>]
 | |
|         attr_accessor :subnetworks
 | |
|       
 | |
|         # An informational warning that appears when the list of addresses is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::SubnetworksScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @subnetworks = args[:subnetworks] if args.key?(:subnetworks)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # An informational warning that appears when the list of addresses is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::SubnetworksScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class SubnetworksSetPrivateIpGoogleAccessRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `privateIpGoogleAccess`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :private_ip_google_access
 | |
|         alias_method :private_ip_google_access?, :private_ip_google_access
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @private_ip_google_access = args[:private_ip_google_access] if args.key?(:private_ip_google_access)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TcpHealthCheck
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The TCP port number for the health check request. The default value is 80.
 | |
|         # Valid values are 1 through 65535.
 | |
|         # Corresponds to the JSON property `port`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :port
 | |
|       
 | |
|         # Port name as defined in InstanceGroup#NamedPort#name. If both port and
 | |
|         # port_name are defined, port takes precedence.
 | |
|         # Corresponds to the JSON property `portName`
 | |
|         # @return [String]
 | |
|         attr_accessor :port_name
 | |
|       
 | |
|         # Specifies how port is selected for health checking, can be one of following
 | |
|         # values:
 | |
|         # USE_FIXED_PORT: The port number in
 | |
|         # port
 | |
|         # is used for health checking.
 | |
|         # USE_NAMED_PORT: The
 | |
|         # portName
 | |
|         # is used for health checking.
 | |
|         # USE_SERVING_PORT: For NetworkEndpointGroup, the port specified for each
 | |
|         # network endpoint is used for health checking. For other backends, the port or
 | |
|         # named port specified in the Backend Service is used for health checking.
 | |
|         # If not specified, TCP health check follows behavior specified in
 | |
|         # port
 | |
|         # and
 | |
|         # portName
 | |
|         # fields.
 | |
|         # Corresponds to the JSON property `portSpecification`
 | |
|         # @return [String]
 | |
|         attr_accessor :port_specification
 | |
|       
 | |
|         # Specifies the type of proxy header to append before sending data to the
 | |
|         # backend, either NONE or PROXY_V1. The default is NONE.
 | |
|         # Corresponds to the JSON property `proxyHeader`
 | |
|         # @return [String]
 | |
|         attr_accessor :proxy_header
 | |
|       
 | |
|         # The application data to send once the TCP connection has been established (
 | |
|         # default value is empty). If both request and response are empty, the
 | |
|         # connection establishment alone will indicate health. The request data can only
 | |
|         # be ASCII.
 | |
|         # Corresponds to the JSON property `request`
 | |
|         # @return [String]
 | |
|         attr_accessor :request
 | |
|       
 | |
|         # The bytes to match against the beginning of the response data. If left empty (
 | |
|         # the default value), any response will indicate health. The response data can
 | |
|         # only be ASCII.
 | |
|         # Corresponds to the JSON property `response`
 | |
|         # @return [String]
 | |
|         attr_accessor :response
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @port = args[:port] if args.key?(:port)
 | |
|           @port_name = args[:port_name] if args.key?(:port_name)
 | |
|           @port_specification = args[:port_specification] if args.key?(:port_specification)
 | |
|           @proxy_header = args[:proxy_header] if args.key?(:proxy_header)
 | |
|           @request = args[:request] if args.key?(:request)
 | |
|           @response = args[:response] if args.key?(:response)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A set of instance tags.
 | |
|       class Tags
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Specifies a fingerprint for this request, which is essentially a hash of the
 | |
|         # tags' contents and used for optimistic locking. The fingerprint is initially
 | |
|         # generated by Compute Engine and changes after every request to modify or
 | |
|         # update tags. You must always provide an up-to-date fingerprint hash in order
 | |
|         # to update or change tags.
 | |
|         # To see the latest fingerprint, make get() request to the instance.
 | |
|         # Corresponds to the JSON property `fingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :fingerprint
 | |
|       
 | |
|         # An array of tags. Each tag must be 1-63 characters long, and comply with
 | |
|         # RFC1035.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @fingerprint = args[:fingerprint] if args.key?(:fingerprint)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetHttpProxiesScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of TargetHttpProxies contained in this scope.
 | |
|         # Corresponds to the JSON property `targetHttpProxies`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::TargetHttpProxy>]
 | |
|         attr_accessor :target_http_proxies
 | |
|       
 | |
|         # Informational warning which replaces the list of backend services when the
 | |
|         # list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::TargetHttpProxiesScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @target_http_proxies = args[:target_http_proxies] if args.key?(:target_http_proxies)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # Informational warning which replaces the list of backend services when the
 | |
|         # list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::TargetHttpProxiesScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A TargetHttpProxy resource. This resource defines an HTTP proxy. (==
 | |
|       # resource_for beta.targetHttpProxies ==) (== resource_for v1.targetHttpProxies =
 | |
|       # =)
 | |
|       class TargetHttpProxy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#targetHttpProxy for target HTTP
 | |
|         # proxies.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # [Output Only] URL of the region where the regional Target HTTP Proxy resides.
 | |
|         # This field is not applicable to global Target HTTP Proxies.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # URL to the UrlMap resource that defines the mapping from URL to the
 | |
|         # BackendService.
 | |
|         # Corresponds to the JSON property `urlMap`
 | |
|         # @return [String]
 | |
|         attr_accessor :url_map
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @url_map = args[:url_map] if args.key?(:url_map)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetHttpProxyAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of TargetHttpProxiesScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::TargetHttpProxiesScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#targetHttpProxyAggregatedList
 | |
|         # for lists of Target HTTP Proxies.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::TargetHttpProxyAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::TargetHttpProxyAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A list of TargetHttpProxy resources.
 | |
|       class TargetHttpProxyList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of TargetHttpProxy resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::TargetHttpProxy>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource. Always compute#targetHttpProxyList for lists of target HTTP
 | |
|         # proxies.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::TargetHttpProxyList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::TargetHttpProxyList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetHttpsProxiesScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of TargetHttpsProxies contained in this scope.
 | |
|         # Corresponds to the JSON property `targetHttpsProxies`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::TargetHttpsProxy>]
 | |
|         attr_accessor :target_https_proxies
 | |
|       
 | |
|         # Informational warning which replaces the list of backend services when the
 | |
|         # list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::TargetHttpsProxiesScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @target_https_proxies = args[:target_https_proxies] if args.key?(:target_https_proxies)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # Informational warning which replaces the list of backend services when the
 | |
|         # list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::TargetHttpsProxiesScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetHttpsProxiesSetQuicOverrideRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # QUIC policy for the TargetHttpsProxy resource.
 | |
|         # Corresponds to the JSON property `quicOverride`
 | |
|         # @return [String]
 | |
|         attr_accessor :quic_override
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @quic_override = args[:quic_override] if args.key?(:quic_override)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetHttpsProxiesSetSslCertificatesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # New set of SslCertificate resources to associate with this TargetHttpsProxy
 | |
|         # resource. Currently exactly one SslCertificate resource must be specified.
 | |
|         # Corresponds to the JSON property `sslCertificates`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :ssl_certificates
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @ssl_certificates = args[:ssl_certificates] if args.key?(:ssl_certificates)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A TargetHttpsProxy resource. This resource defines an HTTPS proxy. (==
 | |
|       # resource_for beta.targetHttpsProxies ==) (== resource_for v1.
 | |
|       # targetHttpsProxies ==)
 | |
|       class TargetHttpsProxy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#targetHttpsProxy for target
 | |
|         # HTTPS proxies.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # Specifies the QUIC override policy for this TargetHttpsProxy resource. This
 | |
|         # determines whether the load balancer will attempt to negotiate QUIC with
 | |
|         # clients or not. Can specify one of NONE, ENABLE, or DISABLE. Specify ENABLE to
 | |
|         # always enable QUIC, Enables QUIC when set to ENABLE, and disables QUIC when
 | |
|         # set to DISABLE. If NONE is specified, uses the QUIC policy with no user
 | |
|         # overrides, which is equivalent to DISABLE. Not specifying this field is
 | |
|         # equivalent to specifying NONE.
 | |
|         # Corresponds to the JSON property `quicOverride`
 | |
|         # @return [String]
 | |
|         attr_accessor :quic_override
 | |
|       
 | |
|         # [Output Only] URL of the region where the regional TargetHttpsProxy resides.
 | |
|         # This field is not applicable to global TargetHttpsProxies.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # URLs to SslCertificate resources that are used to authenticate connections
 | |
|         # between users and the load balancer. At least one SSL certificate must be
 | |
|         # specified. Currently, you may specify up to 15 SSL certificates.
 | |
|         # Corresponds to the JSON property `sslCertificates`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :ssl_certificates
 | |
|       
 | |
|         # URL of SslPolicy resource that will be associated with the TargetHttpsProxy
 | |
|         # resource. If not set, the TargetHttpsProxy resource will not have any SSL
 | |
|         # policy configured.
 | |
|         # Corresponds to the JSON property `sslPolicy`
 | |
|         # @return [String]
 | |
|         attr_accessor :ssl_policy
 | |
|       
 | |
|         # A fully-qualified or valid partial URL to the UrlMap resource that defines the
 | |
|         # mapping from URL to the BackendService. For example, the following are all
 | |
|         # valid URLs for specifying a URL map:
 | |
|         # - https://www.googleapis.compute/v1/projects/project/global/urlMaps/url-map
 | |
|         # - projects/project/global/urlMaps/url-map
 | |
|         # - global/urlMaps/url-map
 | |
|         # Corresponds to the JSON property `urlMap`
 | |
|         # @return [String]
 | |
|         attr_accessor :url_map
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @quic_override = args[:quic_override] if args.key?(:quic_override)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @ssl_certificates = args[:ssl_certificates] if args.key?(:ssl_certificates)
 | |
|           @ssl_policy = args[:ssl_policy] if args.key?(:ssl_policy)
 | |
|           @url_map = args[:url_map] if args.key?(:url_map)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetHttpsProxyAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of TargetHttpsProxiesScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::TargetHttpsProxiesScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#targetHttpsProxyAggregatedList
 | |
|         # for lists of Target HTTP Proxies.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::TargetHttpsProxyAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::TargetHttpsProxyAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of TargetHttpsProxy resources.
 | |
|       class TargetHttpsProxyList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of TargetHttpsProxy resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::TargetHttpsProxy>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource. Always compute#targetHttpsProxyList for lists of target
 | |
|         # HTTPS proxies.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::TargetHttpsProxyList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::TargetHttpsProxyList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A TargetInstance resource. This resource defines an endpoint instance that
 | |
|       # terminates traffic of certain protocols. (== resource_for beta.targetInstances
 | |
|       # ==) (== resource_for v1.targetInstances ==)
 | |
|       class TargetInstance
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A URL to the virtual machine instance that handles traffic for this target
 | |
|         # instance. When creating a target instance, you can provide the fully-qualified
 | |
|         # URL or a valid partial URL to the desired virtual machine. For example, the
 | |
|         # following are all valid URLs:
 | |
|         # - https://www.googleapis.com/compute/v1/projects/project/zones/zone/instances/
 | |
|         # instance
 | |
|         # - projects/project/zones/zone/instances/instance
 | |
|         # - zones/zone/instances/instance
 | |
|         # Corresponds to the JSON property `instance`
 | |
|         # @return [String]
 | |
|         attr_accessor :instance
 | |
|       
 | |
|         # [Output Only] The type of the resource. Always compute#targetInstance for
 | |
|         # target instances.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # NAT option controlling how IPs are NAT'ed to the instance. Currently only
 | |
|         # NO_NAT (default value) is supported.
 | |
|         # Corresponds to the JSON property `natPolicy`
 | |
|         # @return [String]
 | |
|         attr_accessor :nat_policy
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # [Output Only] URL of the zone where the target instance resides. You must
 | |
|         # specify this field as part of the HTTP request URL. It is not settable as a
 | |
|         # field in the request body.
 | |
|         # Corresponds to the JSON property `zone`
 | |
|         # @return [String]
 | |
|         attr_accessor :zone
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @instance = args[:instance] if args.key?(:instance)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @nat_policy = args[:nat_policy] if args.key?(:nat_policy)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @zone = args[:zone] if args.key?(:zone)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetInstanceAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of TargetInstance resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::TargetInstancesScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::TargetInstanceAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::TargetInstanceAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of TargetInstance resources.
 | |
|       class TargetInstanceList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of TargetInstance resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::TargetInstance>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::TargetInstanceList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::TargetInstanceList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetInstancesScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of target instances contained in this scope.
 | |
|         # Corresponds to the JSON property `targetInstances`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::TargetInstance>]
 | |
|         attr_accessor :target_instances
 | |
|       
 | |
|         # Informational warning which replaces the list of addresses when the list is
 | |
|         # empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::TargetInstancesScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @target_instances = args[:target_instances] if args.key?(:target_instances)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # Informational warning which replaces the list of addresses when the list is
 | |
|         # empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::TargetInstancesScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A TargetPool resource. This resource defines a pool of instances, an
 | |
|       # associated HttpHealthCheck resource, and the fallback target pool. (==
 | |
|       # resource_for beta.targetPools ==) (== resource_for v1.targetPools ==)
 | |
|       class TargetPool
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # This field is applicable only when the containing target pool is serving a
 | |
|         # forwarding rule as the primary pool, and its failoverRatio field is properly
 | |
|         # set to a value between [0, 1].
 | |
|         # backupPool and failoverRatio together define the fallback behavior of the
 | |
|         # primary target pool: if the ratio of the healthy instances in the primary pool
 | |
|         # is at or below failoverRatio, traffic arriving at the load-balanced IP will be
 | |
|         # directed to the backup pool.
 | |
|         # In case where failoverRatio and backupPool are not set, or all the instances
 | |
|         # in the backup pool are unhealthy, the traffic will be directed back to the
 | |
|         # primary pool in the "force" mode, where traffic will be spread to the healthy
 | |
|         # instances with the best effort, or to all instances when no instance is
 | |
|         # healthy.
 | |
|         # Corresponds to the JSON property `backupPool`
 | |
|         # @return [String]
 | |
|         attr_accessor :backup_pool
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # This field is applicable only when the containing target pool is serving a
 | |
|         # forwarding rule as the primary pool (i.e., not as a backup pool to some other
 | |
|         # target pool). The value of the field must be in [0, 1].
 | |
|         # If set, backupPool must also be set. They together define the fallback
 | |
|         # behavior of the primary target pool: if the ratio of the healthy instances in
 | |
|         # the primary pool is at or below this number, traffic arriving at the load-
 | |
|         # balanced IP will be directed to the backup pool.
 | |
|         # In case where failoverRatio is not set or all the instances in the backup pool
 | |
|         # are unhealthy, the traffic will be directed back to the primary pool in the "
 | |
|         # force" mode, where traffic will be spread to the healthy instances with the
 | |
|         # best effort, or to all instances when no instance is healthy.
 | |
|         # Corresponds to the JSON property `failoverRatio`
 | |
|         # @return [Float]
 | |
|         attr_accessor :failover_ratio
 | |
|       
 | |
|         # The URL of the HttpHealthCheck resource. A member instance in this pool is
 | |
|         # considered healthy if and only if the health checks pass. An empty list means
 | |
|         # all member instances will be considered healthy at all times. Only
 | |
|         # HttpHealthChecks are supported. Only one health check may be specified.
 | |
|         # Corresponds to the JSON property `healthChecks`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :health_checks
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of resource URLs to the virtual machine instances serving this pool.
 | |
|         # They must live in zones contained in the same region as this pool.
 | |
|         # Corresponds to the JSON property `instances`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :instances
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#targetPool for target pools.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # [Output Only] URL of the region where the target pool resides.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource with the resource id.
 | |
|         # Corresponds to the JSON property `selfLinkWithId`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link_with_id
 | |
|       
 | |
|         # Session affinity option, must be one of the following values:
 | |
|         # NONE: Connections from the same client IP may go to any instance in the pool.
 | |
|         # CLIENT_IP: Connections from the same client IP will go to the same instance in
 | |
|         # the pool while that instance remains healthy.
 | |
|         # CLIENT_IP_PROTO: Connections from the same client IP with the same IP protocol
 | |
|         # will go to the same instance in the pool while that instance remains healthy.
 | |
|         # Corresponds to the JSON property `sessionAffinity`
 | |
|         # @return [String]
 | |
|         attr_accessor :session_affinity
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @backup_pool = args[:backup_pool] if args.key?(:backup_pool)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @failover_ratio = args[:failover_ratio] if args.key?(:failover_ratio)
 | |
|           @health_checks = args[:health_checks] if args.key?(:health_checks)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @instances = args[:instances] if args.key?(:instances)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
 | |
|           @session_affinity = args[:session_affinity] if args.key?(:session_affinity)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetPoolAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of TargetPool resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::TargetPoolsScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#targetPoolAggregatedList for
 | |
|         # aggregated lists of target pools.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::TargetPoolAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::TargetPoolAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetPoolInstanceHealth
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `healthStatus`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::HealthStatus>]
 | |
|         attr_accessor :health_status
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#targetPoolInstanceHealth when
 | |
|         # checking the health of an instance.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @health_status = args[:health_status] if args.key?(:health_status)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of TargetPool resources.
 | |
|       class TargetPoolList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of TargetPool resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::TargetPool>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#targetPoolList for lists of
 | |
|         # target pools.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::TargetPoolList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::TargetPoolList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetPoolsAddHealthCheckRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The HttpHealthCheck to add to the target pool.
 | |
|         # Corresponds to the JSON property `healthChecks`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::HealthCheckReference>]
 | |
|         attr_accessor :health_checks
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @health_checks = args[:health_checks] if args.key?(:health_checks)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetPoolsAddInstanceRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A full or partial URL to an instance to add to this target pool. This can be a
 | |
|         # full or partial URL. For example, the following are valid URLs:
 | |
|         # - https://www.googleapis.com/compute/v1/projects/project-id/zones/zone/
 | |
|         # instances/instance-name
 | |
|         # - projects/project-id/zones/zone/instances/instance-name
 | |
|         # - zones/zone/instances/instance-name
 | |
|         # Corresponds to the JSON property `instances`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InstanceReference>]
 | |
|         attr_accessor :instances
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instances = args[:instances] if args.key?(:instances)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetPoolsRemoveHealthCheckRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Health check URL to be removed. This can be a full or valid partial URL. For
 | |
|         # example, the following are valid URLs:
 | |
|         # - https://www.googleapis.com/compute/beta/projects/project/global/
 | |
|         # httpHealthChecks/health-check
 | |
|         # - projects/project/global/httpHealthChecks/health-check
 | |
|         # - global/httpHealthChecks/health-check
 | |
|         # Corresponds to the JSON property `healthChecks`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::HealthCheckReference>]
 | |
|         attr_accessor :health_checks
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @health_checks = args[:health_checks] if args.key?(:health_checks)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetPoolsRemoveInstanceRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # URLs of the instances to be removed from target pool.
 | |
|         # Corresponds to the JSON property `instances`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::InstanceReference>]
 | |
|         attr_accessor :instances
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instances = args[:instances] if args.key?(:instances)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetPoolsScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of target pools contained in this scope.
 | |
|         # Corresponds to the JSON property `targetPools`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::TargetPool>]
 | |
|         attr_accessor :target_pools
 | |
|       
 | |
|         # Informational warning which replaces the list of addresses when the list is
 | |
|         # empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::TargetPoolsScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @target_pools = args[:target_pools] if args.key?(:target_pools)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # Informational warning which replaces the list of addresses when the list is
 | |
|         # empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::TargetPoolsScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetReference
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `target`
 | |
|         # @return [String]
 | |
|         attr_accessor :target
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @target = args[:target] if args.key?(:target)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetSslProxiesSetBackendServiceRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The URL of the new BackendService resource for the targetSslProxy.
 | |
|         # Corresponds to the JSON property `service`
 | |
|         # @return [String]
 | |
|         attr_accessor :service
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @service = args[:service] if args.key?(:service)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetSslProxiesSetProxyHeaderRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The new type of proxy header to append before sending data to the backend.
 | |
|         # NONE or PROXY_V1 are allowed.
 | |
|         # Corresponds to the JSON property `proxyHeader`
 | |
|         # @return [String]
 | |
|         attr_accessor :proxy_header
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @proxy_header = args[:proxy_header] if args.key?(:proxy_header)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetSslProxiesSetSslCertificatesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # New set of URLs to SslCertificate resources to associate with this
 | |
|         # TargetSslProxy. Currently exactly one ssl certificate must be specified.
 | |
|         # Corresponds to the JSON property `sslCertificates`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :ssl_certificates
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @ssl_certificates = args[:ssl_certificates] if args.key?(:ssl_certificates)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A TargetSslProxy resource. This resource defines an SSL proxy. (==
 | |
|       # resource_for beta.targetSslProxies ==) (== resource_for v1.targetSslProxies ==)
 | |
|       class TargetSslProxy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#targetSslProxy for target
 | |
|         # SSL proxies.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # Specifies the type of proxy header to append before sending data to the
 | |
|         # backend, either NONE or PROXY_V1. The default is NONE.
 | |
|         # Corresponds to the JSON property `proxyHeader`
 | |
|         # @return [String]
 | |
|         attr_accessor :proxy_header
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # URL to the BackendService resource.
 | |
|         # Corresponds to the JSON property `service`
 | |
|         # @return [String]
 | |
|         attr_accessor :service
 | |
|       
 | |
|         # URLs to SslCertificate resources that are used to authenticate connections to
 | |
|         # Backends. At least one SSL certificate must be specified. Currently, you may
 | |
|         # specify up to 15 SSL certificates.
 | |
|         # Corresponds to the JSON property `sslCertificates`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :ssl_certificates
 | |
|       
 | |
|         # URL of SslPolicy resource that will be associated with the TargetSslProxy
 | |
|         # resource. If not set, the TargetSslProxy resource will not have any SSL policy
 | |
|         # configured.
 | |
|         # Corresponds to the JSON property `sslPolicy`
 | |
|         # @return [String]
 | |
|         attr_accessor :ssl_policy
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @proxy_header = args[:proxy_header] if args.key?(:proxy_header)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @service = args[:service] if args.key?(:service)
 | |
|           @ssl_certificates = args[:ssl_certificates] if args.key?(:ssl_certificates)
 | |
|           @ssl_policy = args[:ssl_policy] if args.key?(:ssl_policy)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of TargetSslProxy resources.
 | |
|       class TargetSslProxyList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of TargetSslProxy resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::TargetSslProxy>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::TargetSslProxyList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::TargetSslProxyList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetTcpProxiesSetBackendServiceRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The URL of the new BackendService resource for the targetTcpProxy.
 | |
|         # Corresponds to the JSON property `service`
 | |
|         # @return [String]
 | |
|         attr_accessor :service
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @service = args[:service] if args.key?(:service)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetTcpProxiesSetProxyHeaderRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The new type of proxy header to append before sending data to the backend.
 | |
|         # NONE or PROXY_V1 are allowed.
 | |
|         # Corresponds to the JSON property `proxyHeader`
 | |
|         # @return [String]
 | |
|         attr_accessor :proxy_header
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @proxy_header = args[:proxy_header] if args.key?(:proxy_header)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A TargetTcpProxy resource. This resource defines a TCP proxy. (== resource_for
 | |
|       # beta.targetTcpProxies ==) (== resource_for v1.targetTcpProxies ==)
 | |
|       class TargetTcpProxy
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#targetTcpProxy for target
 | |
|         # TCP proxies.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # Specifies the type of proxy header to append before sending data to the
 | |
|         # backend, either NONE or PROXY_V1. The default is NONE.
 | |
|         # Corresponds to the JSON property `proxyHeader`
 | |
|         # @return [String]
 | |
|         attr_accessor :proxy_header
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # URL to the BackendService resource.
 | |
|         # Corresponds to the JSON property `service`
 | |
|         # @return [String]
 | |
|         attr_accessor :service
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @proxy_header = args[:proxy_header] if args.key?(:proxy_header)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @service = args[:service] if args.key?(:service)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of TargetTcpProxy resources.
 | |
|       class TargetTcpProxyList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of TargetTcpProxy resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::TargetTcpProxy>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::TargetTcpProxyList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::TargetTcpProxyList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Represents a Target VPN gateway resource. (== resource_for beta.
 | |
|       # targetVpnGateways ==) (== resource_for v1.targetVpnGateways ==)
 | |
|       class TargetVpnGateway
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] A list of URLs to the ForwardingRule resources. ForwardingRules
 | |
|         # are created using compute.forwardingRules.insert and associated to a VPN
 | |
|         # gateway.
 | |
|         # Corresponds to the JSON property `forwardingRules`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :forwarding_rules
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#targetVpnGateway for target VPN
 | |
|         # gateways.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # A fingerprint for the labels being applied to this TargetVpnGateway, which is
 | |
|         # essentially a hash of the labels set used for optimistic locking. The
 | |
|         # fingerprint is initially generated by Compute Engine and changes after every
 | |
|         # request to modify or update labels. You must always provide an up-to-date
 | |
|         # fingerprint hash in order to update or change labels, otherwise the request
 | |
|         # will fail with error 412 conditionNotMet.
 | |
|         # To see the latest fingerprint, make a get() request to retrieve a
 | |
|         # TargetVpnGateway.
 | |
|         # Corresponds to the JSON property `labelFingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :label_fingerprint
 | |
|       
 | |
|         # Labels to apply to this TargetVpnGateway resource. These can be later modified
 | |
|         # by the setLabels method. Each label key/value must comply with RFC1035. Label
 | |
|         # values may be empty.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # URL of the network to which this VPN gateway is attached. Provided by the
 | |
|         # client when the VPN gateway is created.
 | |
|         # Corresponds to the JSON property `network`
 | |
|         # @return [String]
 | |
|         attr_accessor :network
 | |
|       
 | |
|         # [Output Only] URL of the region where the target VPN gateway resides. You must
 | |
|         # specify this field as part of the HTTP request URL. It is not settable as a
 | |
|         # field in the request body.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] The status of the VPN gateway.
 | |
|         # Corresponds to the JSON property `status`
 | |
|         # @return [String]
 | |
|         attr_accessor :status
 | |
|       
 | |
|         # [Output Only] A list of URLs to VpnTunnel resources. VpnTunnels are created
 | |
|         # using compute.vpntunnels.insert method and associated to a VPN gateway.
 | |
|         # Corresponds to the JSON property `tunnels`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :tunnels
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @forwarding_rules = args[:forwarding_rules] if args.key?(:forwarding_rules)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @network = args[:network] if args.key?(:network)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @status = args[:status] if args.key?(:status)
 | |
|           @tunnels = args[:tunnels] if args.key?(:tunnels)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetVpnGatewayAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of TargetVpnGateway resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::TargetVpnGatewaysScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#targetVpnGateway for target VPN
 | |
|         # gateways.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::TargetVpnGatewayAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::TargetVpnGatewayAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of TargetVpnGateway resources.
 | |
|       class TargetVpnGatewayList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of TargetVpnGateway resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::TargetVpnGateway>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#targetVpnGateway for target VPN
 | |
|         # gateways.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::TargetVpnGatewayList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::TargetVpnGatewayList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TargetVpnGatewaysScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] A list of target vpn gateways contained in this scope.
 | |
|         # Corresponds to the JSON property `targetVpnGateways`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::TargetVpnGateway>]
 | |
|         attr_accessor :target_vpn_gateways
 | |
|       
 | |
|         # [Output Only] Informational warning which replaces the list of addresses when
 | |
|         # the list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::TargetVpnGatewaysScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @target_vpn_gateways = args[:target_vpn_gateways] if args.key?(:target_vpn_gateways)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning which replaces the list of addresses when
 | |
|         # the list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::TargetVpnGatewaysScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TestFailure
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `actualService`
 | |
|         # @return [String]
 | |
|         attr_accessor :actual_service
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `expectedService`
 | |
|         # @return [String]
 | |
|         attr_accessor :expected_service
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `host`
 | |
|         # @return [String]
 | |
|         attr_accessor :host
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `path`
 | |
|         # @return [String]
 | |
|         attr_accessor :path
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @actual_service = args[:actual_service] if args.key?(:actual_service)
 | |
|           @expected_service = args[:expected_service] if args.key?(:expected_service)
 | |
|           @host = args[:host] if args.key?(:host)
 | |
|           @path = args[:path] if args.key?(:path)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TestPermissionsRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The set of permissions to check for the 'resource'. Permissions with wildcards
 | |
|         # (such as '*' or 'storage.*') are not allowed.
 | |
|         # Corresponds to the JSON property `permissions`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :permissions
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @permissions = args[:permissions] if args.key?(:permissions)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class TestPermissionsResponse
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A subset of `TestPermissionsRequest.permissions` that the caller is allowed.
 | |
|         # Corresponds to the JSON property `permissions`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :permissions
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @permissions = args[:permissions] if args.key?(:permissions)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class UdpHealthCheck
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The UDP port number for the health check request. Valid values are 1 through
 | |
|         # 65535.
 | |
|         # Corresponds to the JSON property `port`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :port
 | |
|       
 | |
|         # Port name as defined in InstanceGroup#NamedPort#name. If both port and
 | |
|         # port_name are defined, port takes precedence.
 | |
|         # Corresponds to the JSON property `portName`
 | |
|         # @return [String]
 | |
|         attr_accessor :port_name
 | |
|       
 | |
|         # Raw data of request to send in payload of UDP packet. It is an error if this
 | |
|         # is empty. The request data can only be ASCII.
 | |
|         # Corresponds to the JSON property `request`
 | |
|         # @return [String]
 | |
|         attr_accessor :request
 | |
|       
 | |
|         # The bytes to match against the beginning of the response data. It is an error
 | |
|         # if this is empty. The response data can only be ASCII.
 | |
|         # Corresponds to the JSON property `response`
 | |
|         # @return [String]
 | |
|         attr_accessor :response
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @port = args[:port] if args.key?(:port)
 | |
|           @port_name = args[:port_name] if args.key?(:port_name)
 | |
|           @request = args[:request] if args.key?(:request)
 | |
|           @response = args[:response] if args.key?(:response)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A UrlMap resource. This resource defines the mapping from URL to the
 | |
|       # BackendService resource, based on the "longest-match" of the URL's host and
 | |
|       # path.
 | |
|       class UrlMap
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # defaultRouteAction takes effect when none of the  hostRules match. The load
 | |
|         # balancer performs advanced routing actions like URL rewrites, header
 | |
|         # transformations, etc. prior to forwarding the request to the selected backend.
 | |
|         # If defaultRouteAction specifies any weightedBackendServices, defaultService
 | |
|         # must not be set. Conversely if defaultService is set, defaultRouteAction
 | |
|         # cannot contain any  weightedBackendServices.
 | |
|         # Only one of defaultRouteAction or defaultUrlRedirect must be set.
 | |
|         # Corresponds to the JSON property `defaultRouteAction`
 | |
|         # @return [Google::Apis::ComputeAlpha::HttpRouteAction]
 | |
|         attr_accessor :default_route_action
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `defaultService`
 | |
|         # @return [String]
 | |
|         attr_accessor :default_service
 | |
|       
 | |
|         # Specifies settings for an HTTP redirect.
 | |
|         # Corresponds to the JSON property `defaultUrlRedirect`
 | |
|         # @return [Google::Apis::ComputeAlpha::HttpRedirectAction]
 | |
|         attr_accessor :default_url_redirect
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # Fingerprint of this resource. A hash of the contents stored in this object.
 | |
|         # This field is used in optimistic locking. This field will be ignored when
 | |
|         # inserting a UrlMap. An up-to-date fingerprint must be provided in order to
 | |
|         # update the UrlMap, otherwise the request will fail with error 412
 | |
|         # conditionNotMet.
 | |
|         # To see the latest fingerprint, make a get() request to retrieve a UrlMap.
 | |
|         # Corresponds to the JSON property `fingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :fingerprint
 | |
|       
 | |
|         # The request and response header transformations that take effect before the
 | |
|         # request is passed along to the selected backendService.
 | |
|         # Corresponds to the JSON property `headerAction`
 | |
|         # @return [Google::Apis::ComputeAlpha::HttpHeaderAction]
 | |
|         attr_accessor :header_action
 | |
|       
 | |
|         # The list of HostRules to use against the URL.
 | |
|         # Corresponds to the JSON property `hostRules`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::HostRule>]
 | |
|         attr_accessor :host_rules
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#urlMaps for url maps.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # The list of named PathMatchers to use against the URL.
 | |
|         # Corresponds to the JSON property `pathMatchers`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::PathMatcher>]
 | |
|         attr_accessor :path_matchers
 | |
|       
 | |
|         # [Output Only] URL of the region where the regional URL map resides. This field
 | |
|         # is not applicable to global URL maps. You must specify this field as part of
 | |
|         # the HTTP request URL. It is not settable as a field in the request body.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # The list of expected URL mapping tests. Request to update this UrlMap will
 | |
|         # succeed only if all of the test cases pass. You can specify a maximum of 100
 | |
|         # tests per UrlMap.
 | |
|         # Corresponds to the JSON property `tests`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::UrlMapTest>]
 | |
|         attr_accessor :tests
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @default_route_action = args[:default_route_action] if args.key?(:default_route_action)
 | |
|           @default_service = args[:default_service] if args.key?(:default_service)
 | |
|           @default_url_redirect = args[:default_url_redirect] if args.key?(:default_url_redirect)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @fingerprint = args[:fingerprint] if args.key?(:fingerprint)
 | |
|           @header_action = args[:header_action] if args.key?(:header_action)
 | |
|           @host_rules = args[:host_rules] if args.key?(:host_rules)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @path_matchers = args[:path_matchers] if args.key?(:path_matchers)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @tests = args[:tests] if args.key?(:tests)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of UrlMap resources.
 | |
|       class UrlMapList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of UrlMap resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::UrlMap>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::UrlMapList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::UrlMapList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class UrlMapReference
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `urlMap`
 | |
|         # @return [String]
 | |
|         attr_accessor :url_map
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @url_map = args[:url_map] if args.key?(:url_map)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Message for the expected URL mappings.
 | |
|       class UrlMapTest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The weight to use for the supplied host and path when using advanced routing
 | |
|         # rules that involve traffic splitting.
 | |
|         # Corresponds to the JSON property `backendServiceWeight`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :backend_service_weight
 | |
|       
 | |
|         # Description of this test case.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # The expected URL that should be redirected to for the host and path being
 | |
|         # tested.
 | |
|         # Corresponds to the JSON property `expectedUrlRedirect`
 | |
|         # @return [String]
 | |
|         attr_accessor :expected_url_redirect
 | |
|       
 | |
|         # Host portion of the URL.
 | |
|         # Corresponds to the JSON property `host`
 | |
|         # @return [String]
 | |
|         attr_accessor :host
 | |
|       
 | |
|         # Path portion of the URL.
 | |
|         # Corresponds to the JSON property `path`
 | |
|         # @return [String]
 | |
|         attr_accessor :path
 | |
|       
 | |
|         # Expected BackendService resource the given URL should be mapped to.
 | |
|         # Corresponds to the JSON property `service`
 | |
|         # @return [String]
 | |
|         attr_accessor :service
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @backend_service_weight = args[:backend_service_weight] if args.key?(:backend_service_weight)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @expected_url_redirect = args[:expected_url_redirect] if args.key?(:expected_url_redirect)
 | |
|           @host = args[:host] if args.key?(:host)
 | |
|           @path = args[:path] if args.key?(:path)
 | |
|           @service = args[:service] if args.key?(:service)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Message representing the validation result for a UrlMap.
 | |
|       class UrlMapValidationResult
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `loadErrors`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :load_errors
 | |
|       
 | |
|         # Whether the given UrlMap can be successfully loaded. If false, 'loadErrors'
 | |
|         # indicates the reasons.
 | |
|         # Corresponds to the JSON property `loadSucceeded`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :load_succeeded
 | |
|         alias_method :load_succeeded?, :load_succeeded
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `testFailures`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::TestFailure>]
 | |
|         attr_accessor :test_failures
 | |
|       
 | |
|         # If successfully loaded, this field indicates whether the test passed. If false,
 | |
|         # 'testFailures's indicate the reason of failure.
 | |
|         # Corresponds to the JSON property `testPassed`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :test_passed
 | |
|         alias_method :test_passed?, :test_passed
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @load_errors = args[:load_errors] if args.key?(:load_errors)
 | |
|           @load_succeeded = args[:load_succeeded] if args.key?(:load_succeeded)
 | |
|           @test_failures = args[:test_failures] if args.key?(:test_failures)
 | |
|           @test_passed = args[:test_passed] if args.key?(:test_passed)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class UrlMapsAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of UrlMapsScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::UrlMapsScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::UrlMapsAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::UrlMapsAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class UrlMapsScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of UrlMaps contained in this scope.
 | |
|         # Corresponds to the JSON property `urlMaps`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::UrlMap>]
 | |
|         attr_accessor :url_maps
 | |
|       
 | |
|         # Informational warning which replaces the list of backend services when the
 | |
|         # list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::UrlMapsScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @url_maps = args[:url_maps] if args.key?(:url_maps)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # Informational warning which replaces the list of backend services when the
 | |
|         # list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::UrlMapsScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class UrlMapsValidateRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A UrlMap resource. This resource defines the mapping from URL to the
 | |
|         # BackendService resource, based on the "longest-match" of the URL's host and
 | |
|         # path.
 | |
|         # Corresponds to the JSON property `resource`
 | |
|         # @return [Google::Apis::ComputeAlpha::UrlMap]
 | |
|         attr_accessor :resource
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @resource = args[:resource] if args.key?(:resource)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class UrlMapsValidateResponse
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Message representing the validation result for a UrlMap.
 | |
|         # Corresponds to the JSON property `result`
 | |
|         # @return [Google::Apis::ComputeAlpha::UrlMapValidationResult]
 | |
|         attr_accessor :result
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @result = args[:result] if args.key?(:result)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The spec for modifying the path before sending the request to the matched
 | |
|       # backend service.
 | |
|       class UrlRewrite
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `hostRewrite`
 | |
|         # @return [String]
 | |
|         attr_accessor :host_rewrite
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `pathPrefixRewrite`
 | |
|         # @return [String]
 | |
|         attr_accessor :path_prefix_rewrite
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @host_rewrite = args[:host_rewrite] if args.key?(:host_rewrite)
 | |
|           @path_prefix_rewrite = args[:path_prefix_rewrite] if args.key?(:path_prefix_rewrite)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Subnetwork which the current user has compute.subnetworks.use permission on.
 | |
|       class UsableSubnetwork
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The range of internal addresses that are owned by this subnetwork.
 | |
|         # Corresponds to the JSON property `ipCidrRange`
 | |
|         # @return [String]
 | |
|         attr_accessor :ip_cidr_range
 | |
|       
 | |
|         # Network URL.
 | |
|         # Corresponds to the JSON property `network`
 | |
|         # @return [String]
 | |
|         attr_accessor :network
 | |
|       
 | |
|         # Secondary IP ranges.
 | |
|         # Corresponds to the JSON property `secondaryIpRanges`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::UsableSubnetworkSecondaryRange>]
 | |
|         attr_accessor :secondary_ip_ranges
 | |
|       
 | |
|         # Subnetwork URL.
 | |
|         # Corresponds to the JSON property `subnetwork`
 | |
|         # @return [String]
 | |
|         attr_accessor :subnetwork
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @ip_cidr_range = args[:ip_cidr_range] if args.key?(:ip_cidr_range)
 | |
|           @network = args[:network] if args.key?(:network)
 | |
|           @secondary_ip_ranges = args[:secondary_ip_ranges] if args.key?(:secondary_ip_ranges)
 | |
|           @subnetwork = args[:subnetwork] if args.key?(:subnetwork)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Secondary IP range of a usable subnetwork.
 | |
|       class UsableSubnetworkSecondaryRange
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The range of IP addresses belonging to this subnetwork secondary range.
 | |
|         # Corresponds to the JSON property `ipCidrRange`
 | |
|         # @return [String]
 | |
|         attr_accessor :ip_cidr_range
 | |
|       
 | |
|         # The name associated with this subnetwork secondary range, used when adding an
 | |
|         # alias IP range to a VM instance. The name must be 1-63 characters long, and
 | |
|         # comply with RFC1035. The name must be unique within the subnetwork.
 | |
|         # Corresponds to the JSON property `rangeName`
 | |
|         # @return [String]
 | |
|         attr_accessor :range_name
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @ip_cidr_range = args[:ip_cidr_range] if args.key?(:ip_cidr_range)
 | |
|           @range_name = args[:range_name] if args.key?(:range_name)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class UsableSubnetworksAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output] A list of usable subnetwork URLs.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::UsableSubnetwork>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#usableSubnetworksAggregatedList
 | |
|         # for aggregated lists of usable subnetworks.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::UsableSubnetworksAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::UsableSubnetworksAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The location in Cloud Storage and naming method of the daily usage report.
 | |
|       # Contains bucket_name and report_name prefix.
 | |
|       class UsageExportLocation
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The name of an existing bucket in Cloud Storage where the usage report object
 | |
|         # is stored. The Google Service Account is granted write access to this bucket.
 | |
|         # This can either be the bucket name by itself, such as example-bucket, or the
 | |
|         # bucket name with gs:// or https://storage.googleapis.com/ in front of it, such
 | |
|         # as gs://example-bucket.
 | |
|         # Corresponds to the JSON property `bucketName`
 | |
|         # @return [String]
 | |
|         attr_accessor :bucket_name
 | |
|       
 | |
|         # An optional prefix for the name of the usage report object stored in
 | |
|         # bucketName. If not supplied, defaults to usage. The report is stored as a CSV
 | |
|         # file named report_name_prefix_gce_YYYYMMDD.csv where YYYYMMDD is the day of
 | |
|         # the usage according to Pacific Time. If you supply a prefix, it should conform
 | |
|         # to Cloud Storage object naming conventions.
 | |
|         # Corresponds to the JSON property `reportNamePrefix`
 | |
|         # @return [String]
 | |
|         attr_accessor :report_name_prefix
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @bucket_name = args[:bucket_name] if args.key?(:bucket_name)
 | |
|           @report_name_prefix = args[:report_name_prefix] if args.key?(:report_name_prefix)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contain information of Nat mapping for a VM endpoint (i.e., NIC).
 | |
|       class VmEndpointNatMappings
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Name of the VM instance which the endpoint belongs to
 | |
|         # Corresponds to the JSON property `instanceName`
 | |
|         # @return [String]
 | |
|         attr_accessor :instance_name
 | |
|       
 | |
|         # 
 | |
|         # Corresponds to the JSON property `interfaceNatMappings`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::VmEndpointNatMappingsInterfaceNatMappings>]
 | |
|         attr_accessor :interface_nat_mappings
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @instance_name = args[:instance_name] if args.key?(:instance_name)
 | |
|           @interface_nat_mappings = args[:interface_nat_mappings] if args.key?(:interface_nat_mappings)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contain information of Nat mapping for an interface of this endpoint.
 | |
|       class VmEndpointNatMappingsInterfaceNatMappings
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of all IP:port-range mappings assigned to this interface. These ranges
 | |
|         # are inclusive, that is, both the first and the last ports can be used for NAT.
 | |
|         # Example: ["2.2.2.2:12345-12355", "1.1.1.1:2234-2234"].
 | |
|         # Corresponds to the JSON property `natIpPortRanges`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :nat_ip_port_ranges
 | |
|       
 | |
|         # Total number of ports across all NAT IPs allocated to this interface. It
 | |
|         # equals to the aggregated port number in the field nat_ip_port_ranges.
 | |
|         # Corresponds to the JSON property `numTotalNatPorts`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :num_total_nat_ports
 | |
|       
 | |
|         # Alias IP range for this interface endpoint. It will be a private (RFC 1918) IP
 | |
|         # range. Examples: "10.33.4.55/32", or "192.168.5.0/24".
 | |
|         # Corresponds to the JSON property `sourceAliasIpRange`
 | |
|         # @return [String]
 | |
|         attr_accessor :source_alias_ip_range
 | |
|       
 | |
|         # Primary IP of the VM for this NIC.
 | |
|         # Corresponds to the JSON property `sourceVirtualIp`
 | |
|         # @return [String]
 | |
|         attr_accessor :source_virtual_ip
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @nat_ip_port_ranges = args[:nat_ip_port_ranges] if args.key?(:nat_ip_port_ranges)
 | |
|           @num_total_nat_ports = args[:num_total_nat_ports] if args.key?(:num_total_nat_ports)
 | |
|           @source_alias_ip_range = args[:source_alias_ip_range] if args.key?(:source_alias_ip_range)
 | |
|           @source_virtual_ip = args[:source_virtual_ip] if args.key?(:source_virtual_ip)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of VmEndpointNatMappings.
 | |
|       class VmEndpointNatMappingsList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#vmEndpointNatMappingsList for
 | |
|         # lists of Nat mappings of VM endpoints.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] A list of Nat mapping information of VM endpoints.
 | |
|         # Corresponds to the JSON property `result`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::VmEndpointNatMappings>]
 | |
|         attr_accessor :result
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::VmEndpointNatMappingsList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @result = args[:result] if args.key?(:result)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::VmEndpointNatMappingsList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Represents a VPN gateway resource.
 | |
|       class VpnGateway
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#vpnGateway for VPN gateways.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # A fingerprint for the labels being applied to this VpnGateway, which is
 | |
|         # essentially a hash of the labels set used for optimistic locking. The
 | |
|         # fingerprint is initially generated by Compute Engine and changes after every
 | |
|         # request to modify or update labels. You must always provide an up-to-date
 | |
|         # fingerprint hash in order to update or change labels, otherwise the request
 | |
|         # will fail with error 412 conditionNotMet.
 | |
|         # To see the latest fingerprint, make a get() request to retrieve an VpnGateway.
 | |
|         # Corresponds to the JSON property `labelFingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :label_fingerprint
 | |
|       
 | |
|         # Labels to apply to this VpnGateway resource. These can be later modified by
 | |
|         # the setLabels method. Each label key/value must comply with RFC1035. Label
 | |
|         # values may be empty.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # URL of the network to which this VPN gateway is attached. Provided by the
 | |
|         # client when the VPN gateway is created.
 | |
|         # Corresponds to the JSON property `network`
 | |
|         # @return [String]
 | |
|         attr_accessor :network
 | |
|       
 | |
|         # [Output Only] URL of the region where the VPN gateway resides.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] A list of interfaces on this VPN gateway.
 | |
|         # Corresponds to the JSON property `vpnInterfaces`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::VpnGatewayVpnGatewayInterface>]
 | |
|         attr_accessor :vpn_interfaces
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @network = args[:network] if args.key?(:network)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @vpn_interfaces = args[:vpn_interfaces] if args.key?(:vpn_interfaces)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class VpnGatewayAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of VpnGateway resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::VpnGatewaysScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#vpnGateway for VPN gateways.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::VpnGatewayAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::VpnGatewayAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of VpnGateway resources.
 | |
|       class VpnGatewayList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of VpnGateway resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::VpnGateway>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#vpnGateway for VPN gateways.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::VpnGatewayList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::VpnGatewayList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A VPN gateway interface.
 | |
|       class VpnGatewayVpnGatewayInterface
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The numeric ID of this VPN gateway interface.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # The external IP address for this VPN gateway interface.
 | |
|         # Corresponds to the JSON property `ipAddress`
 | |
|         # @return [String]
 | |
|         attr_accessor :ip_address
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @ip_address = args[:ip_address] if args.key?(:ip_address)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class VpnGatewaysScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] A list of VPN gateways contained in this scope.
 | |
|         # Corresponds to the JSON property `vpnGateways`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::VpnGateway>]
 | |
|         attr_accessor :vpn_gateways
 | |
|       
 | |
|         # [Output Only] Informational warning which replaces the list of addresses when
 | |
|         # the list is empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::VpnGatewaysScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @vpn_gateways = args[:vpn_gateways] if args.key?(:vpn_gateways)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning which replaces the list of addresses when
 | |
|         # the list is empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::VpnGatewaysScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # VPN tunnel resource. (== resource_for beta.vpnTunnels ==) (== resource_for v1.
 | |
|       # vpnTunnels ==)
 | |
|       class VpnTunnel
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # An optional description of this resource. Provide this property when you
 | |
|         # create the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] Detailed status message for the VPN tunnel.
 | |
|         # Corresponds to the JSON property `detailedStatus`
 | |
|         # @return [String]
 | |
|         attr_accessor :detailed_status
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # IKE protocol version to use when establishing the VPN tunnel with peer VPN
 | |
|         # gateway. Acceptable IKE versions are 1 or 2. Default version is 2.
 | |
|         # Corresponds to the JSON property `ikeVersion`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :ike_version
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#vpnTunnel for VPN tunnels.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # A fingerprint for the labels being applied to this VpnTunnel, which is
 | |
|         # essentially a hash of the labels set used for optimistic locking. The
 | |
|         # fingerprint is initially generated by Compute Engine and changes after every
 | |
|         # request to modify or update labels. You must always provide an up-to-date
 | |
|         # fingerprint hash in order to update or change labels, otherwise the request
 | |
|         # will fail with error 412 conditionNotMet.
 | |
|         # To see the latest fingerprint, make a get() request to retrieve a VpnTunnel.
 | |
|         # Corresponds to the JSON property `labelFingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :label_fingerprint
 | |
|       
 | |
|         # Labels to apply to this VpnTunnel. These can be later modified by the
 | |
|         # setLabels method. Each label key/value pair must comply with RFC1035. Label
 | |
|         # values may be empty.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         # Local traffic selector to use when establishing the VPN tunnel with peer VPN
 | |
|         # gateway. The value should be a CIDR formatted string, for example: 192.168.0.0/
 | |
|         # 16. The ranges should be disjoint. Only IPv4 is supported.
 | |
|         # Corresponds to the JSON property `localTrafficSelector`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :local_traffic_selector
 | |
|       
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # IP address of the peer VPN gateway. Only IPv4 is supported.
 | |
|         # Corresponds to the JSON property `peerIp`
 | |
|         # @return [String]
 | |
|         attr_accessor :peer_ip
 | |
|       
 | |
|         # [Output Only] URL of the region where the VPN tunnel resides. You must specify
 | |
|         # this field as part of the HTTP request URL. It is not settable as a field in
 | |
|         # the request body.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # Remote traffic selectors to use when establishing the VPN tunnel with peer VPN
 | |
|         # gateway. The value should be a CIDR formatted string, for example: 192.168.0.0/
 | |
|         # 16. The ranges should be disjoint. Only IPv4 is supported.
 | |
|         # Corresponds to the JSON property `remoteTrafficSelector`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :remote_traffic_selector
 | |
|       
 | |
|         # URL of router resource to be used for dynamic routing.
 | |
|         # Corresponds to the JSON property `router`
 | |
|         # @return [String]
 | |
|         attr_accessor :router
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # Shared secret used to set the secure session between the Cloud VPN gateway and
 | |
|         # the peer VPN gateway.
 | |
|         # Corresponds to the JSON property `sharedSecret`
 | |
|         # @return [String]
 | |
|         attr_accessor :shared_secret
 | |
|       
 | |
|         # Hash of the shared secret.
 | |
|         # Corresponds to the JSON property `sharedSecretHash`
 | |
|         # @return [String]
 | |
|         attr_accessor :shared_secret_hash
 | |
|       
 | |
|         # [Output Only] The status of the VPN tunnel.
 | |
|         # Corresponds to the JSON property `status`
 | |
|         # @return [String]
 | |
|         attr_accessor :status
 | |
|       
 | |
|         # URL of the Target VPN gateway with which this VPN tunnel is associated.
 | |
|         # Provided by the client when the VPN tunnel is created.
 | |
|         # Corresponds to the JSON property `targetVpnGateway`
 | |
|         # @return [String]
 | |
|         attr_accessor :target_vpn_gateway
 | |
|       
 | |
|         # URL of the VPN gateway with which this VPN tunnel is associated. Provided by
 | |
|         # the client when the VPN tunnel is created. This must be used (instead of
 | |
|         # target_vpn_gateway) if a High Availability VPN gateway resource is created.
 | |
|         # Corresponds to the JSON property `vpnGateway`
 | |
|         # @return [String]
 | |
|         attr_accessor :vpn_gateway
 | |
|       
 | |
|         # The interface ID of the VPN gateway with which this VPN tunnel is associated.
 | |
|         # Corresponds to the JSON property `vpnGatewayInterface`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :vpn_gateway_interface
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @detailed_status = args[:detailed_status] if args.key?(:detailed_status)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @ike_version = args[:ike_version] if args.key?(:ike_version)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|           @local_traffic_selector = args[:local_traffic_selector] if args.key?(:local_traffic_selector)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @peer_ip = args[:peer_ip] if args.key?(:peer_ip)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @remote_traffic_selector = args[:remote_traffic_selector] if args.key?(:remote_traffic_selector)
 | |
|           @router = args[:router] if args.key?(:router)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @shared_secret = args[:shared_secret] if args.key?(:shared_secret)
 | |
|           @shared_secret_hash = args[:shared_secret_hash] if args.key?(:shared_secret_hash)
 | |
|           @status = args[:status] if args.key?(:status)
 | |
|           @target_vpn_gateway = args[:target_vpn_gateway] if args.key?(:target_vpn_gateway)
 | |
|           @vpn_gateway = args[:vpn_gateway] if args.key?(:vpn_gateway)
 | |
|           @vpn_gateway_interface = args[:vpn_gateway_interface] if args.key?(:vpn_gateway_interface)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class VpnTunnelAggregatedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of VpnTunnelsScopedList resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Hash<String,Google::Apis::ComputeAlpha::VpnTunnelsScopedList>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#vpnTunnel for VPN tunnels.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::VpnTunnelAggregatedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::VpnTunnelAggregatedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of VpnTunnel resources.
 | |
|       class VpnTunnelList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of VpnTunnel resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::VpnTunnel>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#vpnTunnel for VPN tunnels.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::VpnTunnelList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::VpnTunnelList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class VpnTunnelsScopedList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of vpn tunnels contained in this scope.
 | |
|         # Corresponds to the JSON property `vpnTunnels`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::VpnTunnel>]
 | |
|         attr_accessor :vpn_tunnels
 | |
|       
 | |
|         # Informational warning which replaces the list of addresses when the list is
 | |
|         # empty.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::VpnTunnelsScopedList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @vpn_tunnels = args[:vpn_tunnels] if args.key?(:vpn_tunnels)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # Informational warning which replaces the list of addresses when the list is
 | |
|         # empty.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::VpnTunnelsScopedList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class WafExpressionSet
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of alternate IDs. The format should be: - E.g. XSS-stable Generic
 | |
|         # suffix like "stable" is particularly useful if a policy likes to avail newer
 | |
|         # set of expressions without having to change the policy. A given alias name can'
 | |
|         # t be used for more than one entity set.
 | |
|         # Corresponds to the JSON property `aliases`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :aliases
 | |
|       
 | |
|         # List of available expressions.
 | |
|         # Corresponds to the JSON property `expressions`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::WafExpressionSetExpression>]
 | |
|         attr_accessor :expressions
 | |
|       
 | |
|         # Google specified expression set ID. The format should be: - E.g. XSS-20170329
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @aliases = args[:aliases] if args.key?(:aliases)
 | |
|           @expressions = args[:expressions] if args.key?(:expressions)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class WafExpressionSetExpression
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Expression ID should uniquely identify the origin of the expression. E.g.
 | |
|         # owasp-crs-v020901-id973337 identifies Owasp core rule set version 2.9.1 rule
 | |
|         # id 973337. The ID could be used to determine the individual attack definition
 | |
|         # that has been detected. It could also be used to exclude it from the policy in
 | |
|         # case of false positive.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # In contrast to a single BackendService in  HttpRouteAction to which all
 | |
|       # matching traffic is directed to, WeightedBackendService allows traffic to be
 | |
|       # split across multiple BackendServices. The volume of traffic for each
 | |
|       # BackendService is proportional to the weight specified in each
 | |
|       # WeightedBackendService
 | |
|       class WeightedBackendService
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The full or partial URL to the default BackendService resource. Before
 | |
|         # forwarding the request to backendService, the loadbalancer applies any
 | |
|         # relevant headerActions specified as part of this backendServiceWeight.
 | |
|         # Corresponds to the JSON property `backendService`
 | |
|         # @return [String]
 | |
|         attr_accessor :backend_service
 | |
|       
 | |
|         # The request and response header transformations that take effect before the
 | |
|         # request is passed along to the selected backendService.
 | |
|         # Corresponds to the JSON property `headerAction`
 | |
|         # @return [Google::Apis::ComputeAlpha::HttpHeaderAction]
 | |
|         attr_accessor :header_action
 | |
|       
 | |
|         # Specifies the fraction of traffic sent to backendService. The sum of all
 | |
|         # weights specified in weightedBackendServices within HttpRouteAction must equal
 | |
|         # 100.
 | |
|         # 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.
 | |
|         # Corresponds to the JSON property `weight`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :weight
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @backend_service = args[:backend_service] if args.key?(:backend_service)
 | |
|           @header_action = args[:header_action] if args.key?(:header_action)
 | |
|           @weight = args[:weight] if args.key?(:weight)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class XpnHostList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] A list of shared VPC host project URLs.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Project>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # [Output Only] Type of resource. Always compute#xpnHostList for lists of shared
 | |
|         # VPC hosts.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::XpnHostList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::XpnHostList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Service resource (a.k.a service project) ID.
 | |
|       class XpnResourceId
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The ID of the service resource. In the case of projects, this field supports
 | |
|         # project id (e.g., my-project-123) and project number (e.g. 12345678).
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # The type of the service resource.
 | |
|         # Corresponds to the JSON property `type`
 | |
|         # @return [String]
 | |
|         attr_accessor :type
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @type = args[:type] if args.key?(:type)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A Zone resource. (== resource_for beta.zones ==) (== resource_for v1.zones ==)
 | |
|       class Zone
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Available cpu/platform selections for the zone.
 | |
|         # Corresponds to the JSON property `availableCpuPlatforms`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :available_cpu_platforms
 | |
|       
 | |
|         # [Output Only] Creation timestamp in RFC3339 text format.
 | |
|         # Corresponds to the JSON property `creationTimestamp`
 | |
|         # @return [String]
 | |
|         attr_accessor :creation_timestamp
 | |
|       
 | |
|         # Deprecation status for a public resource.
 | |
|         # Corresponds to the JSON property `deprecated`
 | |
|         # @return [Google::Apis::ComputeAlpha::DeprecationStatus]
 | |
|         attr_accessor :deprecated
 | |
|       
 | |
|         # [Output Only] Textual description of the resource.
 | |
|         # Corresponds to the JSON property `description`
 | |
|         # @return [String]
 | |
|         attr_accessor :description
 | |
|       
 | |
|         # [Output Only] The unique identifier for the resource. This identifier is
 | |
|         # defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # [Output Only] Type of the resource. Always compute#zone for zones.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] Name of the resource.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # [Output Only] Full URL reference to the region which hosts the zone.
 | |
|         # Corresponds to the JSON property `region`
 | |
|         # @return [String]
 | |
|         attr_accessor :region
 | |
|       
 | |
|         # [Output Only] Server-defined URL for the resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Status of the zone, either UP or DOWN.
 | |
|         # Corresponds to the JSON property `status`
 | |
|         # @return [String]
 | |
|         attr_accessor :status
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @available_cpu_platforms = args[:available_cpu_platforms] if args.key?(:available_cpu_platforms)
 | |
|           @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
 | |
|           @deprecated = args[:deprecated] if args.key?(:deprecated)
 | |
|           @description = args[:description] if args.key?(:description)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @region = args[:region] if args.key?(:region)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @status = args[:status] if args.key?(:status)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Contains a list of zone resources.
 | |
|       class ZoneList
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # [Output Only] Unique identifier for the resource; defined by the server.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [String]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # A list of Zone resources.
 | |
|         # Corresponds to the JSON property `items`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Zone>]
 | |
|         attr_accessor :items
 | |
|       
 | |
|         # Type of resource.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # [Output Only] This token allows you to get the next page of results for list
 | |
|         # requests. If the number of results is larger than maxResults, use the
 | |
|         # nextPageToken as a value for the query parameter pageToken in the next list
 | |
|         # request. Subsequent list requests will have their own nextPageToken to
 | |
|         # continue paging through the results.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # [Output Only] Server-defined URL for this resource.
 | |
|         # Corresponds to the JSON property `selfLink`
 | |
|         # @return [String]
 | |
|         attr_accessor :self_link
 | |
|       
 | |
|         # [Output Only] Informational warning message.
 | |
|         # Corresponds to the JSON property `warning`
 | |
|         # @return [Google::Apis::ComputeAlpha::ZoneList::Warning]
 | |
|         attr_accessor :warning
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @items = args[:items] if args.key?(:items)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @self_link = args[:self_link] if args.key?(:self_link)
 | |
|           @warning = args[:warning] if args.key?(:warning)
 | |
|         end
 | |
|         
 | |
|         # [Output Only] Informational warning message.
 | |
|         class Warning
 | |
|           include Google::Apis::Core::Hashable
 | |
|         
 | |
|           # [Output Only] A warning code, if applicable. For example, Compute Engine
 | |
|           # returns NO_RESULTS_ON_PAGE if there are no results in the response.
 | |
|           # Corresponds to the JSON property `code`
 | |
|           # @return [String]
 | |
|           attr_accessor :code
 | |
|         
 | |
|           # [Output Only] Metadata about this warning in key: value format. For example:
 | |
|           # "data": [ ` "key": "scope", "value": "zones/us-east1-d" `
 | |
|           # Corresponds to the JSON property `data`
 | |
|           # @return [Array<Google::Apis::ComputeAlpha::ZoneList::Warning::Datum>]
 | |
|           attr_accessor :data
 | |
|         
 | |
|           # [Output Only] A human-readable description of the warning code.
 | |
|           # Corresponds to the JSON property `message`
 | |
|           # @return [String]
 | |
|           attr_accessor :message
 | |
|         
 | |
|           def initialize(**args)
 | |
|              update!(**args)
 | |
|           end
 | |
|         
 | |
|           # Update properties of this object
 | |
|           def update!(**args)
 | |
|             @code = args[:code] if args.key?(:code)
 | |
|             @data = args[:data] if args.key?(:data)
 | |
|             @message = args[:message] if args.key?(:message)
 | |
|           end
 | |
|           
 | |
|           # 
 | |
|           class Datum
 | |
|             include Google::Apis::Core::Hashable
 | |
|           
 | |
|             # [Output Only] A key that provides more detail on the warning being returned.
 | |
|             # For example, for warnings where there are no results in a list request for a
 | |
|             # particular zone, this key might be scope and the key value might be the zone
 | |
|             # name. Other examples might be a key indicating a deprecated resource and a
 | |
|             # suggested replacement, or a warning about invalid network settings (for
 | |
|             # example, if an instance attempts to perform IP forwarding but is not enabled
 | |
|             # for IP forwarding).
 | |
|             # Corresponds to the JSON property `key`
 | |
|             # @return [String]
 | |
|             attr_accessor :key
 | |
|           
 | |
|             # [Output Only] A warning data value corresponding to the key.
 | |
|             # Corresponds to the JSON property `value`
 | |
|             # @return [String]
 | |
|             attr_accessor :value
 | |
|           
 | |
|             def initialize(**args)
 | |
|                update!(**args)
 | |
|             end
 | |
|           
 | |
|             # Update properties of this object
 | |
|             def update!(**args)
 | |
|               @key = args[:key] if args.key?(:key)
 | |
|               @value = args[:value] if args.key?(:value)
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ZoneSetLabelsRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The fingerprint of the previous set of labels for this resource, used to
 | |
|         # detect conflicts. The fingerprint is initially generated by Compute Engine and
 | |
|         # changes after every request to modify or update labels. You must always
 | |
|         # provide an up-to-date fingerprint hash in order to update or change labels.
 | |
|         # Make a get() request to the resource to get the latest fingerprint.
 | |
|         # Corresponds to the JSON property `labelFingerprint`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :label_fingerprint
 | |
|       
 | |
|         # The labels to set for this resource.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # 
 | |
|       class ZoneSetPolicyRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Flatten Policy to create a backwacd compatible wire-format. Deprecated. Use '
 | |
|         # policy' to specify bindings.
 | |
|         # Corresponds to the JSON property `bindings`
 | |
|         # @return [Array<Google::Apis::ComputeAlpha::Binding>]
 | |
|         attr_accessor :bindings
 | |
|       
 | |
|         # Flatten Policy to create a backward compatible wire-format. Deprecated. Use '
 | |
|         # policy' to specify the etag.
 | |
|         # Corresponds to the JSON property `etag`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :etag
 | |
|       
 | |
|         # Defines an Identity and Access Management (IAM) policy. It is used to specify
 | |
|         # access control policies for Cloud Platform resources.
 | |
|         # A `Policy` consists of a list of `bindings`. A `binding` binds a list of `
 | |
|         # members` to a `role`, where the members can be user accounts, Google groups,
 | |
|         # Google domains, and service accounts. A `role` is a named list of permissions
 | |
|         # defined by IAM.
 | |
|         # **JSON Example**
 | |
|         # ` "bindings": [ ` "role": "roles/owner", "members": [ "user:mike@example.com",
 | |
|         # "group:admins@example.com", "domain:google.com", "serviceAccount:my-other-app@
 | |
|         # appspot.gserviceaccount.com" ] `, ` "role": "roles/viewer", "members": ["user:
 | |
|         # sean@example.com"] ` ] `
 | |
|         # **YAML Example**
 | |
|         # bindings: - members: - user:mike@example.com - group:admins@example.com -
 | |
|         # domain:google.com - serviceAccount:my-other-app@appspot.gserviceaccount.com
 | |
|         # role: roles/owner - members: - user:sean@example.com role: roles/viewer
 | |
|         # For a description of IAM and its features, see the [IAM developer's guide](
 | |
|         # https://cloud.google.com/iam/docs).
 | |
|         # Corresponds to the JSON property `policy`
 | |
|         # @return [Google::Apis::ComputeAlpha::Policy]
 | |
|         attr_accessor :policy
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @bindings = args[:bindings] if args.key?(:bindings)
 | |
|           @etag = args[:etag] if args.key?(:etag)
 | |
|           @policy = args[:policy] if args.key?(:policy)
 | |
|         end
 | |
|       end
 | |
|     end
 | |
|   end
 | |
| end
 |