lib/google/cloud/compute/v1/region_operations/rest/client.rb in google-cloud-compute-v1-0.2.0 vs lib/google/cloud/compute/v1/region_operations/rest/client.rb in google-cloud-compute-v1-0.3.0
- old
+ new
@@ -16,10 +16,11 @@
# Auto-generated by gapic-generator-ruby. DO NOT EDIT!
require "google/cloud/errors"
require "google/cloud/compute/v1/compute_pb"
+require "google/cloud/compute/v1/region_operations/rest/service_stub"
module Google
module Cloud
module Compute
module V1
@@ -29,29 +30,26 @@
# REST client for the RegionOperations service.
#
# The RegionOperations API.
#
class Client
- include GrpcTranscoding
-
# @private
attr_reader :region_operations_stub
##
# Configure the RegionOperations Client class.
#
# See {::Google::Cloud::Compute::V1::RegionOperations::Rest::Client::Configuration}
# for a description of the configuration fields.
#
- # ## Example
+ # @example
#
- # To modify the configuration for all RegionOperations clients:
+ # # Modify the configuration for all RegionOperations clients
+ # ::Google::Cloud::Compute::V1::RegionOperations::Rest::Client.configure do |config|
+ # config.timeout = 10.0
+ # end
#
- # ::Google::Cloud::Compute::V1::RegionOperations::Rest::Client.configure do |config|
- # config.timeout = 10.0
- # end
- #
# @yield [config] Configure the Client client.
# @yieldparam config [Client::Configuration]
#
# @return [Client::Configuration]
#
@@ -64,10 +62,24 @@
break parent_const.configure if parent_const.respond_to? :configure
namespace.pop
end
default_config = Client::Configuration.new parent_config
+ default_config.rpcs.delete.timeout = 600.0
+
+ default_config.rpcs.get.timeout = 600.0
+ default_config.rpcs.get.retry_policy = {
+ initial_delay: 0.1, max_delay: 60.0, multiplier: 1.3, retry_codes: [4, 14]
+ }
+
+ default_config.rpcs.list.timeout = 600.0
+ default_config.rpcs.list.retry_policy = {
+ initial_delay: 0.1, max_delay: 60.0, multiplier: 1.3, retry_codes: [4, 14]
+ }
+
+ default_config.rpcs.wait.timeout = 600.0
+
default_config
end
yield @configure if block_given?
@configure
end
@@ -93,46 +105,38 @@
end
##
# Create a new RegionOperations REST client object.
#
- # ## Examples
+ # @example
#
- # To create a new RegionOperations REST client with the default
- # configuration:
+ # # Create a client using the default configuration
+ # client = ::Google::Cloud::Compute::V1::RegionOperations::Rest::Client.new
#
- # client = ::Google::Cloud::Compute::V1::RegionOperations::Rest::Client.new
+ # # Create a client using a custom configuration
+ # client = ::Google::Cloud::Compute::V1::RegionOperations::Rest::Client.new do |config|
+ # config.timeout = 10.0
+ # end
#
- # To create a new RegionOperations REST client with a custom
- # configuration:
- #
- # client = ::Google::Cloud::Compute::V1::RegionOperations::Rest::Client.new do |config|
- # config.timeout = 10.0
- # end
- #
# @yield [config] Configure the RegionOperations client.
# @yieldparam config [Client::Configuration]
#
def initialize
- # These require statements are intentionally placed here to initialize
- # the REST modules only when it's required.
- require "gapic/rest"
-
# Create the configuration object
@config = Configuration.new Client.configure
# Yield the configuration if needed
yield @config if block_given?
# Create credentials
credentials = @config.credentials
credentials ||= Credentials.default scope: @config.scope
- if credentials.is_a?(String) || credentials.is_a?(Hash)
+ if credentials.is_a?(::String) || credentials.is_a?(::Hash)
credentials = Credentials.new credentials, scope: @config.scope
end
- @client_stub = ::Gapic::Rest::ClientStub.new endpoint: @config.endpoint, credentials: credentials
+ @region_operations_stub = ::Google::Cloud::Compute::V1::RegionOperations::Rest::ServiceStub.new endpoint: @config.endpoint, credentials: credentials
end
# Service calls
##
@@ -159,11 +163,11 @@
# Name of the Operations resource to delete.
# @param project [::String]
# Project ID for this request.
# @param region [::String]
# Name of the region for this request.
- # @yield [result, env] Access the result along with the Faraday environment object
+ # @yield [result, response] Access the result along with the Faraday response object
# @yieldparam result [::Google::Cloud::Compute::V1::DeleteRegionOperationResponse]
# @yieldparam response [::Faraday::Response]
#
# @return [::Google::Cloud::Compute::V1::DeleteRegionOperationResponse]
#
@@ -175,30 +179,28 @@
# Converts hash and nil to an options object
options = ::Gapic::CallOptions.new(**options.to_h) if options.respond_to? :to_h
# Customize the options with defaults
- call_metadata = {}
+ call_metadata = @config.rpcs.delete.metadata.to_h
# Set x-goog-api-client header
call_metadata[:"x-goog-api-client"] ||= ::Gapic::Headers.x_goog_api_client \
lib_name: @config.lib_name, lib_version: @config.lib_version,
gapic_version: ::Google::Cloud::Compute::V1::VERSION,
transports_version_send: [:rest]
- options.apply_defaults timeout: @config.timeout,
+ options.apply_defaults timeout: @config.rpcs.delete.timeout,
metadata: call_metadata
- uri, _body, _query_string_params = transcode_delete request
- response = @client_stub.make_delete_request(
- uri: uri,
- options: options
- )
- result = ::Google::Cloud::Compute::V1::DeleteRegionOperationResponse.decode_json response.body, ignore_unknown_fields: true
+ options.apply_defaults timeout: @config.timeout,
+ metadata: @config.metadata
- yield result, response if block_given?
- result
+ @region_operations_stub.delete request, options do |result, response|
+ yield result, response if block_given?
+ return result
+ end
rescue ::Faraday::Error => e
gapic_error = ::Gapic::Rest::Error.wrap_faraday_error e
raise ::Google::Cloud::Error.from_error(gapic_error)
end
@@ -226,11 +228,11 @@
# Name of the Operations resource to return.
# @param project [::String]
# Project ID for this request.
# @param region [::String]
# Name of the region for this request.
- # @yield [result, env] Access the result along with the Faraday environment object
+ # @yield [result, response] Access the result along with the Faraday response object
# @yieldparam result [::Google::Cloud::Compute::V1::Operation]
# @yieldparam response [::Faraday::Response]
#
# @return [::Google::Cloud::Compute::V1::Operation]
#
@@ -242,30 +244,28 @@
# Converts hash and nil to an options object
options = ::Gapic::CallOptions.new(**options.to_h) if options.respond_to? :to_h
# Customize the options with defaults
- call_metadata = {}
+ call_metadata = @config.rpcs.get.metadata.to_h
# Set x-goog-api-client header
call_metadata[:"x-goog-api-client"] ||= ::Gapic::Headers.x_goog_api_client \
lib_name: @config.lib_name, lib_version: @config.lib_version,
gapic_version: ::Google::Cloud::Compute::V1::VERSION,
transports_version_send: [:rest]
- options.apply_defaults timeout: @config.timeout,
+ options.apply_defaults timeout: @config.rpcs.get.timeout,
metadata: call_metadata
- uri, _body, _query_string_params = transcode_get request
- response = @client_stub.make_get_request(
- uri: uri,
- options: options
- )
- result = ::Google::Cloud::Compute::V1::Operation.decode_json response.body, ignore_unknown_fields: true
+ options.apply_defaults timeout: @config.timeout,
+ metadata: @config.metadata
- yield result, response if block_given?
- result
+ @region_operations_stub.get request, options do |result, response|
+ yield result, response if block_given?
+ return result
+ end
rescue ::Faraday::Error => e
gapic_error = ::Gapic::Rest::Error.wrap_faraday_error e
raise ::Google::Cloud::Error.from_error(gapic_error)
end
@@ -310,16 +310,16 @@
# @param project [::String]
# Project ID for this request.
# @param region [::String]
# Name of the region for this request.
# @param return_partial_success [::Boolean]
- # Opt-in for partial success behavior which provides partial results in case of failure. The default value is false and the logic is the same as today.
- # @yield [result, env] Access the result along with the Faraday environment object
- # @yieldparam result [::Google::Cloud::Compute::V1::OperationList]
+ # Opt-in for partial success behavior which provides partial results in case of failure. The default value is false.
+ # @yield [result, response] Access the result along with the Faraday response object
+ # @yieldparam result [::Gapic::Rest::PagedEnumerable<::Google::Cloud::Compute::V1::Operation>]
# @yieldparam response [::Faraday::Response]
#
- # @return [::Google::Cloud::Compute::V1::OperationList]
+ # @return [::Gapic::Rest::PagedEnumerable<::Google::Cloud::Compute::V1::Operation>]
#
# @raise [::Google::Cloud::Error] if the REST call is aborted.
def list request, options = nil
raise ::ArgumentError, "request must be provided" if request.nil?
@@ -327,31 +327,29 @@
# Converts hash and nil to an options object
options = ::Gapic::CallOptions.new(**options.to_h) if options.respond_to? :to_h
# Customize the options with defaults
- call_metadata = {}
+ call_metadata = @config.rpcs.list.metadata.to_h
# Set x-goog-api-client header
call_metadata[:"x-goog-api-client"] ||= ::Gapic::Headers.x_goog_api_client \
lib_name: @config.lib_name, lib_version: @config.lib_version,
gapic_version: ::Google::Cloud::Compute::V1::VERSION,
transports_version_send: [:rest]
- options.apply_defaults timeout: @config.timeout,
+ options.apply_defaults timeout: @config.rpcs.list.timeout,
metadata: call_metadata
- uri, _body, query_string_params = transcode_list request
- response = @client_stub.make_get_request(
- uri: uri,
- params: query_string_params,
- options: options
- )
- result = ::Google::Cloud::Compute::V1::OperationList.decode_json response.body, ignore_unknown_fields: true
+ options.apply_defaults timeout: @config.timeout,
+ metadata: @config.metadata
- yield result, response if block_given?
- result
+ @region_operations_stub.list request, options do |result, response|
+ result = ::Gapic::Rest::PagedEnumerable.new @region_operations_stub, :list, "items", request, result, options
+ yield result, response if block_given?
+ return result
+ end
rescue ::Faraday::Error => e
gapic_error = ::Gapic::Rest::Error.wrap_faraday_error e
raise ::Google::Cloud::Error.from_error(gapic_error)
end
@@ -383,11 +381,11 @@
# Name of the Operations resource to return.
# @param project [::String]
# Project ID for this request.
# @param region [::String]
# Name of the region for this request.
- # @yield [result, env] Access the result along with the Faraday environment object
+ # @yield [result, response] Access the result along with the Faraday response object
# @yieldparam result [::Google::Cloud::Compute::V1::Operation]
# @yieldparam response [::Faraday::Response]
#
# @return [::Google::Cloud::Compute::V1::Operation]
#
@@ -399,30 +397,28 @@
# Converts hash and nil to an options object
options = ::Gapic::CallOptions.new(**options.to_h) if options.respond_to? :to_h
# Customize the options with defaults
- call_metadata = {}
+ call_metadata = @config.rpcs.wait.metadata.to_h
# Set x-goog-api-client header
call_metadata[:"x-goog-api-client"] ||= ::Gapic::Headers.x_goog_api_client \
lib_name: @config.lib_name, lib_version: @config.lib_version,
gapic_version: ::Google::Cloud::Compute::V1::VERSION,
transports_version_send: [:rest]
- options.apply_defaults timeout: @config.timeout,
+ options.apply_defaults timeout: @config.rpcs.wait.timeout,
metadata: call_metadata
- uri, _body, _query_string_params = transcode_wait request
- response = @client_stub.make_post_request(
- uri: uri,
- options: options
- )
- result = ::Google::Cloud::Compute::V1::Operation.decode_json response.body, ignore_unknown_fields: true
+ options.apply_defaults timeout: @config.timeout,
+ metadata: @config.metadata
- yield result, response if block_given?
- result
+ @region_operations_stub.wait request, options do |result, response|
+ yield result, response if block_given?
+ return result
+ end
rescue ::Faraday::Error => e
gapic_error = ::Gapic::Rest::Error.wrap_faraday_error e
raise ::Google::Cloud::Error.from_error(gapic_error)
end
@@ -473,10 +469,13 @@
# The library version as recorded in instrumentation and logging
# @return [::String]
# @!attribute [rw] timeout
# The call timeout in seconds.
# @return [::Numeric]
+ # @!attribute [rw] metadata
+ # Additional REST headers to be sent with the call.
+ # @return [::Hash{::Symbol=>::String}]
#
class Configuration
extend ::Gapic::Config
config_attr :endpoint, "compute.googleapis.com", ::String
@@ -486,15 +485,77 @@
end
config_attr :scope, nil, ::String, ::Array, nil
config_attr :lib_name, nil, ::String, nil
config_attr :lib_version, nil, ::String, nil
config_attr :timeout, nil, ::Numeric, nil
+ config_attr :metadata, nil, ::Hash, nil
# @private
def initialize parent_config = nil
@parent_config = parent_config unless parent_config.nil?
yield self if block_given?
+ end
+
+ ##
+ # Configurations for individual RPCs
+ # @return [Rpcs]
+ #
+ def rpcs
+ @rpcs ||= begin
+ parent_rpcs = nil
+ parent_rpcs = @parent_config.rpcs if defined?(@parent_config) && @parent_config.respond_to?(:rpcs)
+ Rpcs.new parent_rpcs
+ end
+ end
+
+ ##
+ # Configuration RPC class for the RegionOperations API.
+ #
+ # Includes fields providing the configuration for each RPC in this service.
+ # Each configuration object is of type `Gapic::Config::Method` and includes
+ # the following configuration fields:
+ #
+ # * `timeout` (*type:* `Numeric`) - The call timeout in seconds
+ #
+ # there is one other field (`retry_policy`) that can be set
+ # but is currently not supported for REST Gapic libraries.
+ #
+ class Rpcs
+ ##
+ # RPC-specific configuration for `delete`
+ # @return [::Gapic::Config::Method]
+ #
+ attr_reader :delete
+ ##
+ # RPC-specific configuration for `get`
+ # @return [::Gapic::Config::Method]
+ #
+ attr_reader :get
+ ##
+ # RPC-specific configuration for `list`
+ # @return [::Gapic::Config::Method]
+ #
+ attr_reader :list
+ ##
+ # RPC-specific configuration for `wait`
+ # @return [::Gapic::Config::Method]
+ #
+ attr_reader :wait
+
+ # @private
+ def initialize parent_rpcs = nil
+ delete_config = parent_rpcs.delete if parent_rpcs.respond_to? :delete
+ @delete = ::Gapic::Config::Method.new delete_config
+ get_config = parent_rpcs.get if parent_rpcs.respond_to? :get
+ @get = ::Gapic::Config::Method.new get_config
+ list_config = parent_rpcs.list if parent_rpcs.respond_to? :list
+ @list = ::Gapic::Config::Method.new list_config
+ wait_config = parent_rpcs.wait if parent_rpcs.respond_to? :wait
+ @wait = ::Gapic::Config::Method.new wait_config
+
+ yield self if block_given?
+ end
end
end
end
end
end