# frozen_string_literal: true # Copyright 2023 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/firestore/v1/firestore_pb" module Google module Cloud module Firestore module V1 module Firestore module Rest ## # REST service stub for the Firestore service. # Service stub contains baseline method implementations # including transcoding, making the REST call, and deserialing the response. # class ServiceStub # @private def initialize endpoint:, endpoint_template:, universe_domain:, credentials:, logger: # 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, endpoint_template: endpoint_template, universe_domain: universe_domain, credentials: credentials, numeric_enums: true, service_name: self.class, raise_faraday_errors: false, logger: logger end ## # The effective universe domain # # @return [String] # def universe_domain @client_stub.universe_domain end ## # The effective endpoint # # @return [String] # def endpoint @client_stub.endpoint end ## # The logger used for request/response debug logging. # # @return [Logger] # def logger stub: false stub ? @client_stub.stub_logger : @client_stub.logger end ## # Baseline implementation for the get_document REST call # # @param request_pb [::Google::Cloud::Firestore::V1::GetDocumentRequest] # 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, operation] Access the result along with the TransportOperation object # @yieldparam result [::Google::Cloud::Firestore::V1::Document] # @yieldparam operation [::Gapic::Rest::TransportOperation] # # @return [::Google::Cloud::Firestore::V1::Document] # A result object deserialized from the server's reply def get_document request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = ServiceStub.transcode_get_document_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, method_name: "get_document", options: options ) operation = ::Gapic::Rest::TransportOperation.new response result = ::Google::Cloud::Firestore::V1::Document.decode_json response.body, ignore_unknown_fields: true catch :response do yield result, operation if block_given? result end end ## # Baseline implementation for the list_documents REST call # # @param request_pb [::Google::Cloud::Firestore::V1::ListDocumentsRequest] # 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, operation] Access the result along with the TransportOperation object # @yieldparam result [::Google::Cloud::Firestore::V1::ListDocumentsResponse] # @yieldparam operation [::Gapic::Rest::TransportOperation] # # @return [::Google::Cloud::Firestore::V1::ListDocumentsResponse] # A result object deserialized from the server's reply def list_documents request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = ServiceStub.transcode_list_documents_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, method_name: "list_documents", options: options ) operation = ::Gapic::Rest::TransportOperation.new response result = ::Google::Cloud::Firestore::V1::ListDocumentsResponse.decode_json response.body, ignore_unknown_fields: true catch :response do yield result, operation if block_given? result end end ## # Baseline implementation for the update_document REST call # # @param request_pb [::Google::Cloud::Firestore::V1::UpdateDocumentRequest] # 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, operation] Access the result along with the TransportOperation object # @yieldparam result [::Google::Cloud::Firestore::V1::Document] # @yieldparam operation [::Gapic::Rest::TransportOperation] # # @return [::Google::Cloud::Firestore::V1::Document] # A result object deserialized from the server's reply def update_document request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = ServiceStub.transcode_update_document_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, method_name: "update_document", options: options ) operation = ::Gapic::Rest::TransportOperation.new response result = ::Google::Cloud::Firestore::V1::Document.decode_json response.body, ignore_unknown_fields: true catch :response do yield result, operation if block_given? result end end ## # Baseline implementation for the delete_document REST call # # @param request_pb [::Google::Cloud::Firestore::V1::DeleteDocumentRequest] # 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, operation] Access the result along with the TransportOperation object # @yieldparam result [::Google::Protobuf::Empty] # @yieldparam operation [::Gapic::Rest::TransportOperation] # # @return [::Google::Protobuf::Empty] # A result object deserialized from the server's reply def delete_document request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = ServiceStub.transcode_delete_document_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, method_name: "delete_document", options: options ) operation = ::Gapic::Rest::TransportOperation.new response result = ::Google::Protobuf::Empty.decode_json response.body, ignore_unknown_fields: true catch :response do yield result, operation if block_given? result end end ## # Baseline implementation for the batch_get_documents REST call # # @param request_pb [::Google::Cloud::Firestore::V1::BatchGetDocumentsRequest] # 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. # # @yieldparam chunk [::String] The chunk of data received during server streaming. # # @return [::Gapic::Rest::TransportOperation] def batch_get_documents request_pb, options = nil, &block raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = ServiceStub.transcode_batch_get_documents_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, method_name: "batch_get_documents", options: options, is_server_streaming: true, &block ) ::Gapic::Rest::TransportOperation.new response end ## # Baseline implementation for the begin_transaction REST call # # @param request_pb [::Google::Cloud::Firestore::V1::BeginTransactionRequest] # 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, operation] Access the result along with the TransportOperation object # @yieldparam result [::Google::Cloud::Firestore::V1::BeginTransactionResponse] # @yieldparam operation [::Gapic::Rest::TransportOperation] # # @return [::Google::Cloud::Firestore::V1::BeginTransactionResponse] # A result object deserialized from the server's reply def begin_transaction request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = ServiceStub.transcode_begin_transaction_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, method_name: "begin_transaction", options: options ) operation = ::Gapic::Rest::TransportOperation.new response result = ::Google::Cloud::Firestore::V1::BeginTransactionResponse.decode_json response.body, ignore_unknown_fields: true catch :response do yield result, operation if block_given? result end end ## # Baseline implementation for the commit REST call # # @param request_pb [::Google::Cloud::Firestore::V1::CommitRequest] # 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, operation] Access the result along with the TransportOperation object # @yieldparam result [::Google::Cloud::Firestore::V1::CommitResponse] # @yieldparam operation [::Gapic::Rest::TransportOperation] # # @return [::Google::Cloud::Firestore::V1::CommitResponse] # A result object deserialized from the server's reply def commit request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = ServiceStub.transcode_commit_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, method_name: "commit", options: options ) operation = ::Gapic::Rest::TransportOperation.new response result = ::Google::Cloud::Firestore::V1::CommitResponse.decode_json response.body, ignore_unknown_fields: true catch :response do yield result, operation if block_given? result end end ## # Baseline implementation for the rollback REST call # # @param request_pb [::Google::Cloud::Firestore::V1::RollbackRequest] # 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, operation] Access the result along with the TransportOperation object # @yieldparam result [::Google::Protobuf::Empty] # @yieldparam operation [::Gapic::Rest::TransportOperation] # # @return [::Google::Protobuf::Empty] # A result object deserialized from the server's reply def rollback request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = ServiceStub.transcode_rollback_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, method_name: "rollback", options: options ) operation = ::Gapic::Rest::TransportOperation.new response result = ::Google::Protobuf::Empty.decode_json response.body, ignore_unknown_fields: true catch :response do yield result, operation if block_given? result end end ## # Baseline implementation for the run_query REST call # # @param request_pb [::Google::Cloud::Firestore::V1::RunQueryRequest] # 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. # # @yieldparam chunk [::String] The chunk of data received during server streaming. # # @return [::Gapic::Rest::TransportOperation] def run_query request_pb, options = nil, &block raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = ServiceStub.transcode_run_query_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, method_name: "run_query", options: options, is_server_streaming: true, &block ) ::Gapic::Rest::TransportOperation.new response end ## # Baseline implementation for the run_aggregation_query REST call # # @param request_pb [::Google::Cloud::Firestore::V1::RunAggregationQueryRequest] # 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. # # @yieldparam chunk [::String] The chunk of data received during server streaming. # # @return [::Gapic::Rest::TransportOperation] def run_aggregation_query request_pb, options = nil, &block raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = ServiceStub.transcode_run_aggregation_query_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, method_name: "run_aggregation_query", options: options, is_server_streaming: true, &block ) ::Gapic::Rest::TransportOperation.new response end ## # Baseline implementation for the partition_query REST call # # @param request_pb [::Google::Cloud::Firestore::V1::PartitionQueryRequest] # 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, operation] Access the result along with the TransportOperation object # @yieldparam result [::Google::Cloud::Firestore::V1::PartitionQueryResponse] # @yieldparam operation [::Gapic::Rest::TransportOperation] # # @return [::Google::Cloud::Firestore::V1::PartitionQueryResponse] # A result object deserialized from the server's reply def partition_query request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = ServiceStub.transcode_partition_query_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, method_name: "partition_query", options: options ) operation = ::Gapic::Rest::TransportOperation.new response result = ::Google::Cloud::Firestore::V1::PartitionQueryResponse.decode_json response.body, ignore_unknown_fields: true catch :response do yield result, operation if block_given? result end end ## # Baseline implementation for the list_collection_ids REST call # # @param request_pb [::Google::Cloud::Firestore::V1::ListCollectionIdsRequest] # 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, operation] Access the result along with the TransportOperation object # @yieldparam result [::Google::Cloud::Firestore::V1::ListCollectionIdsResponse] # @yieldparam operation [::Gapic::Rest::TransportOperation] # # @return [::Google::Cloud::Firestore::V1::ListCollectionIdsResponse] # A result object deserialized from the server's reply def list_collection_ids request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = ServiceStub.transcode_list_collection_ids_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, method_name: "list_collection_ids", options: options ) operation = ::Gapic::Rest::TransportOperation.new response result = ::Google::Cloud::Firestore::V1::ListCollectionIdsResponse.decode_json response.body, ignore_unknown_fields: true catch :response do yield result, operation if block_given? result end end ## # Baseline implementation for the batch_write REST call # # @param request_pb [::Google::Cloud::Firestore::V1::BatchWriteRequest] # 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, operation] Access the result along with the TransportOperation object # @yieldparam result [::Google::Cloud::Firestore::V1::BatchWriteResponse] # @yieldparam operation [::Gapic::Rest::TransportOperation] # # @return [::Google::Cloud::Firestore::V1::BatchWriteResponse] # A result object deserialized from the server's reply def batch_write request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = ServiceStub.transcode_batch_write_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, method_name: "batch_write", options: options ) operation = ::Gapic::Rest::TransportOperation.new response result = ::Google::Cloud::Firestore::V1::BatchWriteResponse.decode_json response.body, ignore_unknown_fields: true catch :response do yield result, operation if block_given? result end end ## # Baseline implementation for the create_document REST call # # @param request_pb [::Google::Cloud::Firestore::V1::CreateDocumentRequest] # 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, operation] Access the result along with the TransportOperation object # @yieldparam result [::Google::Cloud::Firestore::V1::Document] # @yieldparam operation [::Gapic::Rest::TransportOperation] # # @return [::Google::Cloud::Firestore::V1::Document] # A result object deserialized from the server's reply def create_document request_pb, options = nil raise ::ArgumentError, "request must be provided" if request_pb.nil? verb, uri, query_string_params, body = ServiceStub.transcode_create_document_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, method_name: "create_document", options: options ) operation = ::Gapic::Rest::TransportOperation.new response result = ::Google::Cloud::Firestore::V1::Document.decode_json response.body, ignore_unknown_fields: true catch :response do yield result, operation if block_given? result end end ## # @private # # GRPC transcoding helper method for the get_document REST call # # @param request_pb [::Google::Cloud::Firestore::V1::GetDocumentRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def self.transcode_get_document_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :get, uri_template: "/v1/{name}", matches: [ ["name", %r{^projects/[^/]+/databases/[^/]+/documents/[^/]+(?:/.*)?$}, true] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the list_documents REST call # # @param request_pb [::Google::Cloud::Firestore::V1::ListDocumentsRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def self.transcode_list_documents_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :get, uri_template: "/v1/{parent}/{collection_id}", matches: [ ["parent", %r{^projects/[^/]+/databases/[^/]+/documents/[^/]+(?:/.*)?$}, true], ["collection_id", %r{^[^/]+/?$}, false] ] ) .with_bindings( uri_method: :get, uri_template: "/v1/{parent}/{collection_id}", matches: [ ["parent", %r{^projects/[^/]+/databases/[^/]+/documents/?$}, false], ["collection_id", %r{^[^/]+/?$}, false] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the update_document REST call # # @param request_pb [::Google::Cloud::Firestore::V1::UpdateDocumentRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def self.transcode_update_document_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :patch, uri_template: "/v1/{document.name}", body: "document", matches: [ ["document.name", %r{^projects/[^/]+/databases/[^/]+/documents/[^/]+(?:/.*)?$}, true] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the delete_document REST call # # @param request_pb [::Google::Cloud::Firestore::V1::DeleteDocumentRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def self.transcode_delete_document_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :delete, uri_template: "/v1/{name}", matches: [ ["name", %r{^projects/[^/]+/databases/[^/]+/documents/[^/]+(?:/.*)?$}, true] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the batch_get_documents REST call # # @param request_pb [::Google::Cloud::Firestore::V1::BatchGetDocumentsRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def self.transcode_batch_get_documents_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :post, uri_template: "/v1/{database}/documents:batchGet", body: "*", matches: [ ["database", %r{^projects/[^/]+/databases/[^/]+/?$}, false] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the begin_transaction REST call # # @param request_pb [::Google::Cloud::Firestore::V1::BeginTransactionRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def self.transcode_begin_transaction_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :post, uri_template: "/v1/{database}/documents:beginTransaction", body: "*", matches: [ ["database", %r{^projects/[^/]+/databases/[^/]+/?$}, false] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the commit REST call # # @param request_pb [::Google::Cloud::Firestore::V1::CommitRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def self.transcode_commit_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :post, uri_template: "/v1/{database}/documents:commit", body: "*", matches: [ ["database", %r{^projects/[^/]+/databases/[^/]+/?$}, false] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the rollback REST call # # @param request_pb [::Google::Cloud::Firestore::V1::RollbackRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def self.transcode_rollback_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :post, uri_template: "/v1/{database}/documents:rollback", body: "*", matches: [ ["database", %r{^projects/[^/]+/databases/[^/]+/?$}, false] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the run_query REST call # # @param request_pb [::Google::Cloud::Firestore::V1::RunQueryRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def self.transcode_run_query_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :post, uri_template: "/v1/{parent}:runQuery", body: "*", matches: [ ["parent", %r{^projects/[^/]+/databases/[^/]+/documents/?$}, false] ] ) .with_bindings( uri_method: :post, uri_template: "/v1/{parent}:runQuery", body: "*", matches: [ ["parent", %r{^projects/[^/]+/databases/[^/]+/documents/[^/]+(?:/.*)?$}, true] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the run_aggregation_query REST call # # @param request_pb [::Google::Cloud::Firestore::V1::RunAggregationQueryRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def self.transcode_run_aggregation_query_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :post, uri_template: "/v1/{parent}:runAggregationQuery", body: "*", matches: [ ["parent", %r{^projects/[^/]+/databases/[^/]+/documents/?$}, false] ] ) .with_bindings( uri_method: :post, uri_template: "/v1/{parent}:runAggregationQuery", body: "*", matches: [ ["parent", %r{^projects/[^/]+/databases/[^/]+/documents/[^/]+(?:/.*)?$}, true] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the partition_query REST call # # @param request_pb [::Google::Cloud::Firestore::V1::PartitionQueryRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def self.transcode_partition_query_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :post, uri_template: "/v1/{parent}:partitionQuery", body: "*", matches: [ ["parent", %r{^projects/[^/]+/databases/[^/]+/documents/?$}, false] ] ) .with_bindings( uri_method: :post, uri_template: "/v1/{parent}:partitionQuery", body: "*", matches: [ ["parent", %r{^projects/[^/]+/databases/[^/]+/documents/[^/]+(?:/.*)?$}, true] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the list_collection_ids REST call # # @param request_pb [::Google::Cloud::Firestore::V1::ListCollectionIdsRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def self.transcode_list_collection_ids_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :post, uri_template: "/v1/{parent}:listCollectionIds", body: "*", matches: [ ["parent", %r{^projects/[^/]+/databases/[^/]+/documents/?$}, false] ] ) .with_bindings( uri_method: :post, uri_template: "/v1/{parent}:listCollectionIds", body: "*", matches: [ ["parent", %r{^projects/[^/]+/databases/[^/]+/documents/[^/]+(?:/.*)?$}, true] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the batch_write REST call # # @param request_pb [::Google::Cloud::Firestore::V1::BatchWriteRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def self.transcode_batch_write_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :post, uri_template: "/v1/{database}/documents:batchWrite", body: "*", matches: [ ["database", %r{^projects/[^/]+/databases/[^/]+/?$}, false] ] ) transcoder.transcode request_pb end ## # @private # # GRPC transcoding helper method for the create_document REST call # # @param request_pb [::Google::Cloud::Firestore::V1::CreateDocumentRequest] # A request object representing the call parameters. Required. # @return [Array(String, [String, nil], Hash{String => String})] # Uri, Body, Query string parameters def self.transcode_create_document_request request_pb transcoder = Gapic::Rest::GrpcTranscoder.new .with_bindings( uri_method: :post, uri_template: "/v1/{parent}/{collection_id}", body: "document", matches: [ ["parent", %r{^projects/[^/]+/databases/[^/]+/documents(?:/.*)?$}, true], ["collection_id", %r{^[^/]+/?$}, false] ] ) transcoder.transcode request_pb end end end end end end end end