# frozen_string_literal: true # Copyright 2021 Google LLC # # 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 # # https://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. # Auto-generated by gapic-generator-ruby. DO NOT EDIT! require "google/cloud/compute/v1/compute_pb" module Google module Cloud module Compute module V1 module TargetPools module Rest ## # REST service stub for the TargetPools service. # service stub contains baseline method implementations # including transcoding, making the REST call and deserialing the response # class ServiceStub def initialize endpoint:, credentials: # These require statements are intentionally placed here to initialize # the REST modules only when it's required. require "gapic/rest" @client_stub = ::Gapic::Rest::ClientStub.new endpoint: endpoint, credentials: credentials end ## # Baseline implementation for the add_health_check REST call # # @param request_pb [::Google::Cloud::Compute::V1::AddHealthCheckTargetPoolRequest] # A request object representing the call parameters. Required. # @param options [::Gapic::CallOptions] # Overrides the default settings for this call, e.g, timeout, retries etc. Optional. # # @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] # A result object deserialized from the server's reply def add_health_check request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = transcode_add_health_check_request request_pb query_string_params = if query_string_params.any? query_string_params.to_h { |p| p.split("=", 2) } else {} end response = @client_stub.make_http_request( verb, uri: uri, body: body || "", params: query_string_params, options: options ) result = ::Google::Cloud::Compute::V1::Operation.decode_json response.body, ignore_unknown_fields: true yield result, response if block_given? result end ## # Baseline implementation for the add_instance REST call # # @param request_pb [::Google::Cloud::Compute::V1::AddInstanceTargetPoolRequest] # A request object representing the call parameters. Required. # @param options [::Gapic::CallOptions] # Overrides the default settings for this call, e.g, timeout, retries etc. Optional. # # @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] # A result object deserialized from the server's reply def add_instance request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = transcode_add_instance_request request_pb query_string_params = if query_string_params.any? query_string_params.to_h { |p| p.split("=", 2) } else {} end response = @client_stub.make_http_request( verb, uri: uri, body: body || "", params: query_string_params, options: options ) result = ::Google::Cloud::Compute::V1::Operation.decode_json response.body, ignore_unknown_fields: true yield result, response if block_given? result end ## # Baseline implementation for the aggregated_list REST call # # @param request_pb [::Google::Cloud::Compute::V1::AggregatedListTargetPoolsRequest] # A request object representing the call parameters. Required. # @param options [::Gapic::CallOptions] # Overrides the default settings for this call, e.g, timeout, retries etc. Optional. # # @yield [result, response] Access the result along with the Faraday response object # @yieldparam result [::Google::Cloud::Compute::V1::TargetPoolAggregatedList] # @yieldparam response [::Faraday::Response] # # @return [::Google::Cloud::Compute::V1::TargetPoolAggregatedList] # A result object deserialized from the server's reply def aggregated_list request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = transcode_aggregated_list_request request_pb query_string_params = if query_string_params.any? query_string_params.to_h { |p| p.split("=", 2) } else {} end response = @client_stub.make_http_request( verb, uri: uri, body: body || "", params: query_string_params, options: options ) result = ::Google::Cloud::Compute::V1::TargetPoolAggregatedList.decode_json response.body, ignore_unknown_fields: true yield result, response if block_given? result end ## # Baseline implementation for the delete REST call # # @param request_pb [::Google::Cloud::Compute::V1::DeleteTargetPoolRequest] # A request object representing the call parameters. Required. # @param options [::Gapic::CallOptions] # Overrides the default settings for this call, e.g, timeout, retries etc. Optional. # # @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] # A result object deserialized from the server's reply def delete request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = transcode_delete_request request_pb query_string_params = if query_string_params.any? query_string_params.to_h { |p| p.split("=", 2) } else {} end response = @client_stub.make_http_request( verb, uri: uri, body: body || "", params: query_string_params, options: options ) result = ::Google::Cloud::Compute::V1::Operation.decode_json response.body, ignore_unknown_fields: true yield result, response if block_given? result end ## # Baseline implementation for the get REST call # # @param request_pb [::Google::Cloud::Compute::V1::GetTargetPoolRequest] # A request object representing the call parameters. Required. # @param options [::Gapic::CallOptions] # Overrides the default settings for this call, e.g, timeout, retries etc. Optional. # # @yield [result, response] Access the result along with the Faraday response object # @yieldparam result [::Google::Cloud::Compute::V1::TargetPool] # @yieldparam response [::Faraday::Response] # # @return [::Google::Cloud::Compute::V1::TargetPool] # A result object deserialized from the server's reply def get request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = transcode_get_request request_pb query_string_params = if query_string_params.any? query_string_params.to_h { |p| p.split("=", 2) } else {} end response = @client_stub.make_http_request( verb, uri: uri, body: body || "", params: query_string_params, options: options ) result = ::Google::Cloud::Compute::V1::TargetPool.decode_json response.body, ignore_unknown_fields: true yield result, response if block_given? result end ## # Baseline implementation for the get_health REST call # # @param request_pb [::Google::Cloud::Compute::V1::GetHealthTargetPoolRequest] # A request object representing the call parameters. Required. # @param options [::Gapic::CallOptions] # Overrides the default settings for this call, e.g, timeout, retries etc. Optional. # # @yield [result, response] Access the result along with the Faraday response object # @yieldparam result [::Google::Cloud::Compute::V1::TargetPoolInstanceHealth] # @yieldparam response [::Faraday::Response] # # @return [::Google::Cloud::Compute::V1::TargetPoolInstanceHealth] # A result object deserialized from the server's reply def get_health request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = transcode_get_health_request request_pb query_string_params = if query_string_params.any? query_string_params.to_h { |p| p.split("=", 2) } else {} end response = @client_stub.make_http_request( verb, uri: uri, body: body || "", params: query_string_params, options: options ) result = ::Google::Cloud::Compute::V1::TargetPoolInstanceHealth.decode_json response.body, ignore_unknown_fields: true yield result, response if block_given? result end ## # Baseline implementation for the insert REST call # # @param request_pb [::Google::Cloud::Compute::V1::InsertTargetPoolRequest] # A request object representing the call parameters. Required. # @param options [::Gapic::CallOptions] # Overrides the default settings for this call, e.g, timeout, retries etc. Optional. # # @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] # A result object deserialized from the server's reply def insert request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = transcode_insert_request request_pb query_string_params = if query_string_params.any? query_string_params.to_h { |p| p.split("=", 2) } else {} end response = @client_stub.make_http_request( verb, uri: uri, body: body || "", params: query_string_params, options: options ) result = ::Google::Cloud::Compute::V1::Operation.decode_json response.body, ignore_unknown_fields: true yield result, response if block_given? result end ## # Baseline implementation for the list REST call # # @param request_pb [::Google::Cloud::Compute::V1::ListTargetPoolsRequest] # A request object representing the call parameters. Required. # @param options [::Gapic::CallOptions] # Overrides the default settings for this call, e.g, timeout, retries etc. Optional. # # @yield [result, response] Access the result along with the Faraday response object # @yieldparam result [::Google::Cloud::Compute::V1::TargetPoolList] # @yieldparam response [::Faraday::Response] # # @return [::Google::Cloud::Compute::V1::TargetPoolList] # A result object deserialized from the server's reply def list request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = transcode_list_request request_pb query_string_params = if query_string_params.any? query_string_params.to_h { |p| p.split("=", 2) } else {} end response = @client_stub.make_http_request( verb, uri: uri, body: body || "", params: query_string_params, options: options ) result = ::Google::Cloud::Compute::V1::TargetPoolList.decode_json response.body, ignore_unknown_fields: true yield result, response if block_given? result end ## # Baseline implementation for the remove_health_check REST call # # @param request_pb [::Google::Cloud::Compute::V1::RemoveHealthCheckTargetPoolRequest] # A request object representing the call parameters. Required. # @param options [::Gapic::CallOptions] # Overrides the default settings for this call, e.g, timeout, retries etc. Optional. # # @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] # A result object deserialized from the server's reply def remove_health_check request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = transcode_remove_health_check_request request_pb query_string_params = if query_string_params.any? query_string_params.to_h { |p| p.split("=", 2) } else {} end response = @client_stub.make_http_request( verb, uri: uri, body: body || "", params: query_string_params, options: options ) result = ::Google::Cloud::Compute::V1::Operation.decode_json response.body, ignore_unknown_fields: true yield result, response if block_given? result end ## # Baseline implementation for the remove_instance REST call # # @param request_pb [::Google::Cloud::Compute::V1::RemoveInstanceTargetPoolRequest] # A request object representing the call parameters. Required. # @param options [::Gapic::CallOptions] # Overrides the default settings for this call, e.g, timeout, retries etc. Optional. # # @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] # A result object deserialized from the server's reply def remove_instance request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = transcode_remove_instance_request request_pb query_string_params = if query_string_params.any? query_string_params.to_h { |p| p.split("=", 2) } else {} end response = @client_stub.make_http_request( verb, uri: uri, body: body || "", params: query_string_params, options: options ) result = ::Google::Cloud::Compute::V1::Operation.decode_json response.body, ignore_unknown_fields: true yield result, response if block_given? result end ## # Baseline implementation for the set_backup REST call # # @param request_pb [::Google::Cloud::Compute::V1::SetBackupTargetPoolRequest] # A request object representing the call parameters. Required. # @param options [::Gapic::CallOptions] # Overrides the default settings for this call, e.g, timeout, retries etc. Optional. # # @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] # A result object deserialized from the server's reply def set_backup request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = transcode_set_backup_request request_pb query_string_params = if query_string_params.any? query_string_params.to_h { |p| p.split("=", 2) } else {} end response = @client_stub.make_http_request( verb, uri: uri, body: body || "", params: query_string_params, options: options ) result = ::Google::Cloud::Compute::V1::Operation.decode_json response.body, ignore_unknown_fields: true yield result, response if block_given? result end private ## # @private # # GRPC transcoding helper method for the add_health_check REST call # # @param request_pb [::Google::Cloud::Compute::V1::AddHealthCheckTargetPoolRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def transcode_add_health_check_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :post, uri_template: "/compute/v1/projects/{project}/regions/{region}/targetPools/{target_pool}/addHealthCheck", body: "target_pools_add_health_check_request_resource", matches: [ ["project", %r{[^/]+}, false], ["region", %r{[^/]+}, false], ["target_pool", %r{[^/]+}, false] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the add_instance REST call # # @param request_pb [::Google::Cloud::Compute::V1::AddInstanceTargetPoolRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def transcode_add_instance_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :post, uri_template: "/compute/v1/projects/{project}/regions/{region}/targetPools/{target_pool}/addInstance", body: "target_pools_add_instance_request_resource", matches: [ ["project", %r{[^/]+}, false], ["region", %r{[^/]+}, false], ["target_pool", %r{[^/]+}, false] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the aggregated_list REST call # # @param request_pb [::Google::Cloud::Compute::V1::AggregatedListTargetPoolsRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def transcode_aggregated_list_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :get, uri_template: "/compute/v1/projects/{project}/aggregated/targetPools", matches: [ ["project", %r{[^/]+}, false] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the delete REST call # # @param request_pb [::Google::Cloud::Compute::V1::DeleteTargetPoolRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def transcode_delete_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :delete, uri_template: "/compute/v1/projects/{project}/regions/{region}/targetPools/{target_pool}", matches: [ ["project", %r{[^/]+}, false], ["region", %r{[^/]+}, false], ["target_pool", %r{[^/]+}, false] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the get REST call # # @param request_pb [::Google::Cloud::Compute::V1::GetTargetPoolRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def transcode_get_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :get, uri_template: "/compute/v1/projects/{project}/regions/{region}/targetPools/{target_pool}", matches: [ ["project", %r{[^/]+}, false], ["region", %r{[^/]+}, false], ["target_pool", %r{[^/]+}, false] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the get_health REST call # # @param request_pb [::Google::Cloud::Compute::V1::GetHealthTargetPoolRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def transcode_get_health_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :post, uri_template: "/compute/v1/projects/{project}/regions/{region}/targetPools/{target_pool}/getHealth", body: "instance_reference_resource", matches: [ ["project", %r{[^/]+}, false], ["region", %r{[^/]+}, false], ["target_pool", %r{[^/]+}, false] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the insert REST call # # @param request_pb [::Google::Cloud::Compute::V1::InsertTargetPoolRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def transcode_insert_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :post, uri_template: "/compute/v1/projects/{project}/regions/{region}/targetPools", body: "target_pool_resource", matches: [ ["project", %r{[^/]+}, false], ["region", %r{[^/]+}, false] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the list REST call # # @param request_pb [::Google::Cloud::Compute::V1::ListTargetPoolsRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def transcode_list_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :get, uri_template: "/compute/v1/projects/{project}/regions/{region}/targetPools", matches: [ ["project", %r{[^/]+}, false], ["region", %r{[^/]+}, false] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the remove_health_check REST call # # @param request_pb [::Google::Cloud::Compute::V1::RemoveHealthCheckTargetPoolRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def transcode_remove_health_check_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :post, uri_template: "/compute/v1/projects/{project}/regions/{region}/targetPools/{target_pool}/removeHealthCheck", body: "target_pools_remove_health_check_request_resource", matches: [ ["project", %r{[^/]+}, false], ["region", %r{[^/]+}, false], ["target_pool", %r{[^/]+}, false] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the remove_instance REST call # # @param request_pb [::Google::Cloud::Compute::V1::RemoveInstanceTargetPoolRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def transcode_remove_instance_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :post, uri_template: "/compute/v1/projects/{project}/regions/{region}/targetPools/{target_pool}/removeInstance", body: "target_pools_remove_instance_request_resource", matches: [ ["project", %r{[^/]+}, false], ["region", %r{[^/]+}, false], ["target_pool", %r{[^/]+}, false] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the set_backup REST call # # @param request_pb [::Google::Cloud::Compute::V1::SetBackupTargetPoolRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def transcode_set_backup_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :post, uri_template: "/compute/v1/projects/{project}/regions/{region}/targetPools/{target_pool}/setBackup", body: "target_reference_resource", matches: [ ["project", %r{[^/]+}, false], ["region", %r{[^/]+}, false], ["target_pool", %r{[^/]+}, false] ] ) transcoder.transcode request_pb end end end end end end end end