google-cloud-dialogflow-v2 1.4.0 → 1.5.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (89) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +30 -20
  3. data/lib/google/cloud/dialogflow/v2/agents/client.rb +33 -10
  4. data/lib/google/cloud/dialogflow/v2/agents/operations.rb +12 -15
  5. data/lib/google/cloud/dialogflow/v2/agents/rest/client.rb +33 -10
  6. data/lib/google/cloud/dialogflow/v2/agents/rest/operations.rb +43 -38
  7. data/lib/google/cloud/dialogflow/v2/agents/rest/service_stub.rb +86 -56
  8. data/lib/google/cloud/dialogflow/v2/answer_records/client.rb +29 -3
  9. data/lib/google/cloud/dialogflow/v2/answer_records/rest/client.rb +29 -3
  10. data/lib/google/cloud/dialogflow/v2/answer_records/rest/service_stub.rb +30 -14
  11. data/lib/google/cloud/dialogflow/v2/contexts/client.rb +29 -7
  12. data/lib/google/cloud/dialogflow/v2/contexts/rest/client.rb +29 -7
  13. data/lib/google/cloud/dialogflow/v2/contexts/rest/service_stub.rb +62 -38
  14. data/lib/google/cloud/dialogflow/v2/conversation_datasets/client.rb +32 -6
  15. data/lib/google/cloud/dialogflow/v2/conversation_datasets/operations.rb +12 -15
  16. data/lib/google/cloud/dialogflow/v2/conversation_datasets/rest/client.rb +32 -6
  17. data/lib/google/cloud/dialogflow/v2/conversation_datasets/rest/operations.rb +43 -38
  18. data/lib/google/cloud/dialogflow/v2/conversation_datasets/rest/service_stub.rb +54 -32
  19. data/lib/google/cloud/dialogflow/v2/conversation_models/client.rb +35 -10
  20. data/lib/google/cloud/dialogflow/v2/conversation_models/operations.rb +12 -15
  21. data/lib/google/cloud/dialogflow/v2/conversation_models/rest/client.rb +35 -10
  22. data/lib/google/cloud/dialogflow/v2/conversation_models/rest/operations.rb +43 -38
  23. data/lib/google/cloud/dialogflow/v2/conversation_models/rest/service_stub.rb +86 -56
  24. data/lib/google/cloud/dialogflow/v2/conversation_profile_services_pb.rb +6 -2
  25. data/lib/google/cloud/dialogflow/v2/conversation_profiles/client.rb +37 -10
  26. data/lib/google/cloud/dialogflow/v2/conversation_profiles/operations.rb +12 -15
  27. data/lib/google/cloud/dialogflow/v2/conversation_profiles/rest/client.rb +37 -10
  28. data/lib/google/cloud/dialogflow/v2/conversation_profiles/rest/operations.rb +43 -38
  29. data/lib/google/cloud/dialogflow/v2/conversation_profiles/rest/service_stub.rb +70 -44
  30. data/lib/google/cloud/dialogflow/v2/conversations/client.rb +30 -10
  31. data/lib/google/cloud/dialogflow/v2/conversations/rest/client.rb +30 -10
  32. data/lib/google/cloud/dialogflow/v2/conversations/rest/service_stub.rb +86 -56
  33. data/lib/google/cloud/dialogflow/v2/documents/client.rb +35 -9
  34. data/lib/google/cloud/dialogflow/v2/documents/operations.rb +12 -15
  35. data/lib/google/cloud/dialogflow/v2/documents/rest/client.rb +35 -9
  36. data/lib/google/cloud/dialogflow/v2/documents/rest/operations.rb +43 -38
  37. data/lib/google/cloud/dialogflow/v2/documents/rest/service_stub.rb +78 -50
  38. data/lib/google/cloud/dialogflow/v2/encryption_spec_service/client.rb +29 -3
  39. data/lib/google/cloud/dialogflow/v2/encryption_spec_service/operations.rb +12 -15
  40. data/lib/google/cloud/dialogflow/v2/encryption_spec_service/rest/client.rb +29 -3
  41. data/lib/google/cloud/dialogflow/v2/encryption_spec_service/rest/operations.rb +43 -38
  42. data/lib/google/cloud/dialogflow/v2/encryption_spec_service/rest/service_stub.rb +30 -14
  43. data/lib/google/cloud/dialogflow/v2/entity_types/client.rb +34 -11
  44. data/lib/google/cloud/dialogflow/v2/entity_types/operations.rb +12 -15
  45. data/lib/google/cloud/dialogflow/v2/entity_types/rest/client.rb +34 -11
  46. data/lib/google/cloud/dialogflow/v2/entity_types/rest/operations.rb +43 -38
  47. data/lib/google/cloud/dialogflow/v2/entity_types/rest/service_stub.rb +94 -62
  48. data/lib/google/cloud/dialogflow/v2/environments/client.rb +30 -7
  49. data/lib/google/cloud/dialogflow/v2/environments/rest/client.rb +30 -7
  50. data/lib/google/cloud/dialogflow/v2/environments/rest/service_stub.rb +62 -38
  51. data/lib/google/cloud/dialogflow/v2/fulfillments/client.rb +28 -3
  52. data/lib/google/cloud/dialogflow/v2/fulfillments/rest/client.rb +28 -3
  53. data/lib/google/cloud/dialogflow/v2/fulfillments/rest/service_stub.rb +30 -14
  54. data/lib/google/cloud/dialogflow/v2/generators/client.rb +29 -6
  55. data/lib/google/cloud/dialogflow/v2/generators/rest/client.rb +29 -6
  56. data/lib/google/cloud/dialogflow/v2/generators/rest/service_stub.rb +54 -32
  57. data/lib/google/cloud/dialogflow/v2/intent_pb.rb +1 -1
  58. data/lib/google/cloud/dialogflow/v2/intents/client.rb +31 -8
  59. data/lib/google/cloud/dialogflow/v2/intents/operations.rb +12 -15
  60. data/lib/google/cloud/dialogflow/v2/intents/rest/client.rb +31 -8
  61. data/lib/google/cloud/dialogflow/v2/intents/rest/operations.rb +43 -38
  62. data/lib/google/cloud/dialogflow/v2/intents/rest/service_stub.rb +70 -44
  63. data/lib/google/cloud/dialogflow/v2/knowledge_bases/client.rb +29 -6
  64. data/lib/google/cloud/dialogflow/v2/knowledge_bases/rest/client.rb +29 -6
  65. data/lib/google/cloud/dialogflow/v2/knowledge_bases/rest/service_stub.rb +54 -32
  66. data/lib/google/cloud/dialogflow/v2/participants/client.rb +29 -11
  67. data/lib/google/cloud/dialogflow/v2/participants/rest/client.rb +29 -10
  68. data/lib/google/cloud/dialogflow/v2/participants/rest/service_stub.rb +86 -56
  69. data/lib/google/cloud/dialogflow/v2/session_entity_types/client.rb +29 -6
  70. data/lib/google/cloud/dialogflow/v2/session_entity_types/rest/client.rb +29 -6
  71. data/lib/google/cloud/dialogflow/v2/session_entity_types/rest/service_stub.rb +54 -32
  72. data/lib/google/cloud/dialogflow/v2/sessions/client.rb +28 -3
  73. data/lib/google/cloud/dialogflow/v2/sessions/rest/client.rb +28 -2
  74. data/lib/google/cloud/dialogflow/v2/sessions/rest/service_stub.rb +22 -8
  75. data/lib/google/cloud/dialogflow/v2/version.rb +1 -1
  76. data/lib/google/cloud/dialogflow/v2/versions/client.rb +29 -6
  77. data/lib/google/cloud/dialogflow/v2/versions/rest/client.rb +29 -6
  78. data/lib/google/cloud/dialogflow/v2/versions/rest/service_stub.rb +54 -32
  79. data/proto_docs/google/api/client.rb +19 -0
  80. data/proto_docs/google/cloud/dialogflow/v2/answer_record.rb +3 -2
  81. data/proto_docs/google/cloud/dialogflow/v2/audio_config.rb +2 -2
  82. data/proto_docs/google/cloud/dialogflow/v2/conversation.rb +10 -6
  83. data/proto_docs/google/cloud/dialogflow/v2/conversation_dataset.rb +2 -2
  84. data/proto_docs/google/cloud/dialogflow/v2/conversation_profile.rb +7 -4
  85. data/proto_docs/google/cloud/dialogflow/v2/intent.rb +1 -1
  86. data/proto_docs/google/cloud/dialogflow/v2/participant.rb +10 -8
  87. data/proto_docs/google/cloud/dialogflow/v2/session.rb +12 -10
  88. data/proto_docs/google/longrunning/operations.rb +19 -14
  89. metadata +5 -5
@@ -30,7 +30,8 @@ module Google
30
30
  # including transcoding, making the REST call, and deserialing the response.
31
31
  #
32
32
  class ServiceStub
33
- def initialize endpoint:, endpoint_template:, universe_domain:, credentials:
33
+ # @private
34
+ def initialize endpoint:, endpoint_template:, universe_domain:, credentials:, logger:
34
35
  # These require statements are intentionally placed here to initialize
35
36
  # the REST modules only when it's required.
36
37
  require "gapic/rest"
@@ -40,7 +41,9 @@ module Google
40
41
  universe_domain: universe_domain,
41
42
  credentials: credentials,
42
43
  numeric_enums: true,
43
- raise_faraday_errors: false
44
+ service_name: self.class,
45
+ raise_faraday_errors: false,
46
+ logger: logger
44
47
  end
45
48
 
46
49
  ##
@@ -61,6 +64,15 @@ module Google
61
64
  @client_stub.endpoint
62
65
  end
63
66
 
67
+ ##
68
+ # The logger used for request/response debug logging.
69
+ #
70
+ # @return [Logger]
71
+ #
72
+ def logger stub: false
73
+ stub ? @client_stub.stub_logger : @client_stub.logger
74
+ end
75
+
64
76
  ##
65
77
  # Baseline implementation for the create_conversation REST call
66
78
  #
@@ -87,16 +99,18 @@ module Google
87
99
 
88
100
  response = @client_stub.make_http_request(
89
101
  verb,
90
- uri: uri,
91
- body: body || "",
92
- params: query_string_params,
102
+ uri: uri,
103
+ body: body || "",
104
+ params: query_string_params,
105
+ method_name: "create_conversation",
93
106
  options: options
94
107
  )
95
108
  operation = ::Gapic::Rest::TransportOperation.new response
96
109
  result = ::Google::Cloud::Dialogflow::V2::Conversation.decode_json response.body, ignore_unknown_fields: true
97
-
98
- yield result, operation if block_given?
99
- result
110
+ catch :response do
111
+ yield result, operation if block_given?
112
+ result
113
+ end
100
114
  end
101
115
 
102
116
  ##
@@ -125,16 +139,18 @@ module Google
125
139
 
126
140
  response = @client_stub.make_http_request(
127
141
  verb,
128
- uri: uri,
129
- body: body || "",
130
- params: query_string_params,
142
+ uri: uri,
143
+ body: body || "",
144
+ params: query_string_params,
145
+ method_name: "list_conversations",
131
146
  options: options
132
147
  )
133
148
  operation = ::Gapic::Rest::TransportOperation.new response
134
149
  result = ::Google::Cloud::Dialogflow::V2::ListConversationsResponse.decode_json response.body, ignore_unknown_fields: true
135
-
136
- yield result, operation if block_given?
137
- result
150
+ catch :response do
151
+ yield result, operation if block_given?
152
+ result
153
+ end
138
154
  end
139
155
 
140
156
  ##
@@ -163,16 +179,18 @@ module Google
163
179
 
164
180
  response = @client_stub.make_http_request(
165
181
  verb,
166
- uri: uri,
167
- body: body || "",
168
- params: query_string_params,
182
+ uri: uri,
183
+ body: body || "",
184
+ params: query_string_params,
185
+ method_name: "get_conversation",
169
186
  options: options
170
187
  )
171
188
  operation = ::Gapic::Rest::TransportOperation.new response
172
189
  result = ::Google::Cloud::Dialogflow::V2::Conversation.decode_json response.body, ignore_unknown_fields: true
173
-
174
- yield result, operation if block_given?
175
- result
190
+ catch :response do
191
+ yield result, operation if block_given?
192
+ result
193
+ end
176
194
  end
177
195
 
178
196
  ##
@@ -201,16 +219,18 @@ module Google
201
219
 
202
220
  response = @client_stub.make_http_request(
203
221
  verb,
204
- uri: uri,
205
- body: body || "",
206
- params: query_string_params,
222
+ uri: uri,
223
+ body: body || "",
224
+ params: query_string_params,
225
+ method_name: "complete_conversation",
207
226
  options: options
208
227
  )
209
228
  operation = ::Gapic::Rest::TransportOperation.new response
210
229
  result = ::Google::Cloud::Dialogflow::V2::Conversation.decode_json response.body, ignore_unknown_fields: true
211
-
212
- yield result, operation if block_given?
213
- result
230
+ catch :response do
231
+ yield result, operation if block_given?
232
+ result
233
+ end
214
234
  end
215
235
 
216
236
  ##
@@ -239,16 +259,18 @@ module Google
239
259
 
240
260
  response = @client_stub.make_http_request(
241
261
  verb,
242
- uri: uri,
243
- body: body || "",
244
- params: query_string_params,
262
+ uri: uri,
263
+ body: body || "",
264
+ params: query_string_params,
265
+ method_name: "list_messages",
245
266
  options: options
246
267
  )
247
268
  operation = ::Gapic::Rest::TransportOperation.new response
248
269
  result = ::Google::Cloud::Dialogflow::V2::ListMessagesResponse.decode_json response.body, ignore_unknown_fields: true
249
-
250
- yield result, operation if block_given?
251
- result
270
+ catch :response do
271
+ yield result, operation if block_given?
272
+ result
273
+ end
252
274
  end
253
275
 
254
276
  ##
@@ -277,16 +299,18 @@ module Google
277
299
 
278
300
  response = @client_stub.make_http_request(
279
301
  verb,
280
- uri: uri,
281
- body: body || "",
282
- params: query_string_params,
302
+ uri: uri,
303
+ body: body || "",
304
+ params: query_string_params,
305
+ method_name: "suggest_conversation_summary",
283
306
  options: options
284
307
  )
285
308
  operation = ::Gapic::Rest::TransportOperation.new response
286
309
  result = ::Google::Cloud::Dialogflow::V2::SuggestConversationSummaryResponse.decode_json response.body, ignore_unknown_fields: true
287
-
288
- yield result, operation if block_given?
289
- result
310
+ catch :response do
311
+ yield result, operation if block_given?
312
+ result
313
+ end
290
314
  end
291
315
 
292
316
  ##
@@ -315,16 +339,18 @@ module Google
315
339
 
316
340
  response = @client_stub.make_http_request(
317
341
  verb,
318
- uri: uri,
319
- body: body || "",
320
- params: query_string_params,
342
+ uri: uri,
343
+ body: body || "",
344
+ params: query_string_params,
345
+ method_name: "generate_stateless_summary",
321
346
  options: options
322
347
  )
323
348
  operation = ::Gapic::Rest::TransportOperation.new response
324
349
  result = ::Google::Cloud::Dialogflow::V2::GenerateStatelessSummaryResponse.decode_json response.body, ignore_unknown_fields: true
325
-
326
- yield result, operation if block_given?
327
- result
350
+ catch :response do
351
+ yield result, operation if block_given?
352
+ result
353
+ end
328
354
  end
329
355
 
330
356
  ##
@@ -353,16 +379,18 @@ module Google
353
379
 
354
380
  response = @client_stub.make_http_request(
355
381
  verb,
356
- uri: uri,
357
- body: body || "",
358
- params: query_string_params,
382
+ uri: uri,
383
+ body: body || "",
384
+ params: query_string_params,
385
+ method_name: "generate_stateless_suggestion",
359
386
  options: options
360
387
  )
361
388
  operation = ::Gapic::Rest::TransportOperation.new response
362
389
  result = ::Google::Cloud::Dialogflow::V2::GenerateStatelessSuggestionResponse.decode_json response.body, ignore_unknown_fields: true
363
-
364
- yield result, operation if block_given?
365
- result
390
+ catch :response do
391
+ yield result, operation if block_given?
392
+ result
393
+ end
366
394
  end
367
395
 
368
396
  ##
@@ -391,16 +419,18 @@ module Google
391
419
 
392
420
  response = @client_stub.make_http_request(
393
421
  verb,
394
- uri: uri,
395
- body: body || "",
396
- params: query_string_params,
422
+ uri: uri,
423
+ body: body || "",
424
+ params: query_string_params,
425
+ method_name: "search_knowledge",
397
426
  options: options
398
427
  )
399
428
  operation = ::Gapic::Rest::TransportOperation.new response
400
429
  result = ::Google::Cloud::Dialogflow::V2::SearchKnowledgeResponse.decode_json response.body, ignore_unknown_fields: true
401
-
402
- yield result, operation if block_given?
403
- result
430
+ catch :response do
431
+ yield result, operation if block_given?
432
+ result
433
+ end
404
434
  end
405
435
 
406
436
  ##
@@ -171,14 +171,26 @@ module Google
171
171
  universe_domain: @config.universe_domain,
172
172
  channel_args: @config.channel_args,
173
173
  interceptors: @config.interceptors,
174
- channel_pool_config: @config.channel_pool
174
+ channel_pool_config: @config.channel_pool,
175
+ logger: @config.logger
175
176
  )
176
177
 
178
+ @documents_stub.stub_logger&.info do |entry|
179
+ entry.set_system_name
180
+ entry.set_service
181
+ entry.message = "Created client for #{entry.service}"
182
+ entry.set_credentials_fields credentials
183
+ entry.set "customEndpoint", @config.endpoint if @config.endpoint
184
+ entry.set "defaultTimeout", @config.timeout if @config.timeout
185
+ entry.set "quotaProject", @quota_project_id if @quota_project_id
186
+ end
187
+
177
188
  @location_client = Google::Cloud::Location::Locations::Client.new do |config|
178
189
  config.credentials = credentials
179
190
  config.quota_project = @quota_project_id
180
191
  config.endpoint = @documents_stub.endpoint
181
192
  config.universe_domain = @documents_stub.universe_domain
193
+ config.logger = @documents_stub.logger if config.respond_to? :logger=
182
194
  end
183
195
  end
184
196
 
@@ -196,6 +208,15 @@ module Google
196
208
  #
197
209
  attr_reader :location_client
198
210
 
211
+ ##
212
+ # The logger used for request/response debug logging.
213
+ #
214
+ # @return [Logger]
215
+ #
216
+ def logger
217
+ @documents_stub.logger
218
+ end
219
+
199
220
  # Service calls
200
221
 
201
222
  ##
@@ -312,7 +333,7 @@ module Google
312
333
  @documents_stub.call_rpc :list_documents, request, options: options do |response, operation|
313
334
  response = ::Gapic::PagedEnumerable.new @documents_stub, :list_documents, request, response, operation, options
314
335
  yield response, operation if block_given?
315
- return response
336
+ throw :response, response
316
337
  end
317
338
  rescue ::GRPC::BadStatus => e
318
339
  raise ::Google::Cloud::Error.from_error(e)
@@ -400,7 +421,6 @@ module Google
400
421
 
401
422
  @documents_stub.call_rpc :get_document, request, options: options do |response, operation|
402
423
  yield response, operation if block_given?
403
- return response
404
424
  end
405
425
  rescue ::GRPC::BadStatus => e
406
426
  raise ::Google::Cloud::Error.from_error(e)
@@ -506,7 +526,7 @@ module Google
506
526
  @documents_stub.call_rpc :create_document, request, options: options do |response, operation|
507
527
  response = ::Gapic::Operation.new response, @operations_client, options: options
508
528
  yield response, operation if block_given?
509
- return response
529
+ throw :response, response
510
530
  end
511
531
  rescue ::GRPC::BadStatus => e
512
532
  raise ::Google::Cloud::Error.from_error(e)
@@ -625,7 +645,7 @@ module Google
625
645
  @documents_stub.call_rpc :import_documents, request, options: options do |response, operation|
626
646
  response = ::Gapic::Operation.new response, @operations_client, options: options
627
647
  yield response, operation if block_given?
628
- return response
648
+ throw :response, response
629
649
  end
630
650
  rescue ::GRPC::BadStatus => e
631
651
  raise ::Google::Cloud::Error.from_error(e)
@@ -730,7 +750,7 @@ module Google
730
750
  @documents_stub.call_rpc :delete_document, request, options: options do |response, operation|
731
751
  response = ::Gapic::Operation.new response, @operations_client, options: options
732
752
  yield response, operation if block_given?
733
- return response
753
+ throw :response, response
734
754
  end
735
755
  rescue ::GRPC::BadStatus => e
736
756
  raise ::Google::Cloud::Error.from_error(e)
@@ -836,7 +856,7 @@ module Google
836
856
  @documents_stub.call_rpc :update_document, request, options: options do |response, operation|
837
857
  response = ::Gapic::Operation.new response, @operations_client, options: options
838
858
  yield response, operation if block_given?
839
- return response
859
+ throw :response, response
840
860
  end
841
861
  rescue ::GRPC::BadStatus => e
842
862
  raise ::Google::Cloud::Error.from_error(e)
@@ -958,7 +978,7 @@ module Google
958
978
  @documents_stub.call_rpc :reload_document, request, options: options do |response, operation|
959
979
  response = ::Gapic::Operation.new response, @operations_client, options: options
960
980
  yield response, operation if block_given?
961
- return response
981
+ throw :response, response
962
982
  end
963
983
  rescue ::GRPC::BadStatus => e
964
984
  raise ::Google::Cloud::Error.from_error(e)
@@ -1071,7 +1091,7 @@ module Google
1071
1091
  @documents_stub.call_rpc :export_document, request, options: options do |response, operation|
1072
1092
  response = ::Gapic::Operation.new response, @operations_client, options: options
1073
1093
  yield response, operation if block_given?
1074
- return response
1094
+ throw :response, response
1075
1095
  end
1076
1096
  rescue ::GRPC::BadStatus => e
1077
1097
  raise ::Google::Cloud::Error.from_error(e)
@@ -1160,6 +1180,11 @@ module Google
1160
1180
  # default endpoint URL. The default value of nil uses the environment
1161
1181
  # universe (usually the default "googleapis.com" universe).
1162
1182
  # @return [::String,nil]
1183
+ # @!attribute [rw] logger
1184
+ # A custom logger to use for request/response debug logging, or the value
1185
+ # `:default` (the default) to construct a default logger, or `nil` to
1186
+ # explicitly disable logging.
1187
+ # @return [::Logger,:default,nil]
1163
1188
  #
1164
1189
  class Configuration
1165
1190
  extend ::Gapic::Config
@@ -1184,6 +1209,7 @@ module Google
1184
1209
  config_attr :retry_policy, nil, ::Hash, ::Proc, nil
1185
1210
  config_attr :quota_project, nil, ::String, nil
1186
1211
  config_attr :universe_domain, nil, ::String, nil
1212
+ config_attr :logger, :default, ::Logger, nil, :default
1187
1213
 
1188
1214
  # @private
1189
1215
  def initialize parent_config = nil
@@ -124,14 +124,6 @@ module Google
124
124
  # Lists operations that match the specified filter in the request. If the
125
125
  # server doesn't support this method, it returns `UNIMPLEMENTED`.
126
126
  #
127
- # NOTE: the `name` binding allows API services to override the binding
128
- # to use different resource name schemes, such as `users/*/operations`. To
129
- # override the binding, API services can add a binding such as
130
- # `"/v1/{name=users/*}/operations"` to their service configuration.
131
- # For backwards compatibility, the default name includes the operations
132
- # collection id, however overriding users must ensure the name binding
133
- # is the parent resource, without the operations collection id.
134
- #
135
127
  # @overload list_operations(request, options = nil)
136
128
  # Pass arguments to `list_operations` via a request object, either of type
137
129
  # {::Google::Longrunning::ListOperationsRequest} or an equivalent Hash.
@@ -221,7 +213,7 @@ module Google
221
213
  wrap_lro_operation = ->(op_response) { ::Gapic::Operation.new op_response, @operations_client }
222
214
  response = ::Gapic::PagedEnumerable.new @operations_stub, :list_operations, request, response, operation, options, format_resource: wrap_lro_operation
223
215
  yield response, operation if block_given?
224
- return response
216
+ throw :response, response
225
217
  end
226
218
  rescue ::GRPC::BadStatus => e
227
219
  raise ::Google::Cloud::Error.from_error(e)
@@ -317,7 +309,7 @@ module Google
317
309
  @operations_stub.call_rpc :get_operation, request, options: options do |response, operation|
318
310
  response = ::Gapic::Operation.new response, @operations_client, options: options
319
311
  yield response, operation if block_given?
320
- return response
312
+ throw :response, response
321
313
  end
322
314
  rescue ::GRPC::BadStatus => e
323
315
  raise ::Google::Cloud::Error.from_error(e)
@@ -406,7 +398,6 @@ module Google
406
398
 
407
399
  @operations_stub.call_rpc :delete_operation, request, options: options do |response, operation|
408
400
  yield response, operation if block_given?
409
- return response
410
401
  end
411
402
  rescue ::GRPC::BadStatus => e
412
403
  raise ::Google::Cloud::Error.from_error(e)
@@ -421,8 +412,9 @@ module Google
421
412
  # other methods to check whether the cancellation succeeded or whether the
422
413
  # operation completed despite cancellation. On successful cancellation,
423
414
  # the operation is not deleted; instead, it becomes an operation with
424
- # an {::Google::Longrunning::Operation#error Operation.error} value with a {::Google::Rpc::Status#code google.rpc.Status.code} of 1,
425
- # corresponding to `Code.CANCELLED`.
415
+ # an {::Google::Longrunning::Operation#error Operation.error} value with a
416
+ # {::Google::Rpc::Status#code google.rpc.Status.code} of `1`, corresponding to
417
+ # `Code.CANCELLED`.
426
418
  #
427
419
  # @overload cancel_operation(request, options = nil)
428
420
  # Pass arguments to `cancel_operation` via a request object, either of type
@@ -501,7 +493,6 @@ module Google
501
493
 
502
494
  @operations_stub.call_rpc :cancel_operation, request, options: options do |response, operation|
503
495
  yield response, operation if block_given?
504
- return response
505
496
  end
506
497
  rescue ::GRPC::BadStatus => e
507
498
  raise ::Google::Cloud::Error.from_error(e)
@@ -599,7 +590,7 @@ module Google
599
590
  @operations_stub.call_rpc :wait_operation, request, options: options do |response, operation|
600
591
  response = ::Gapic::Operation.new response, @operations_client, options: options
601
592
  yield response, operation if block_given?
602
- return response
593
+ throw :response, response
603
594
  end
604
595
  rescue ::GRPC::BadStatus => e
605
596
  raise ::Google::Cloud::Error.from_error(e)
@@ -688,6 +679,11 @@ module Google
688
679
  # default endpoint URL. The default value of nil uses the environment
689
680
  # universe (usually the default "googleapis.com" universe).
690
681
  # @return [::String,nil]
682
+ # @!attribute [rw] logger
683
+ # A custom logger to use for request/response debug logging, or the value
684
+ # `:default` (the default) to construct a default logger, or `nil` to
685
+ # explicitly disable logging.
686
+ # @return [::Logger,:default,nil]
691
687
  #
692
688
  class Configuration
693
689
  extend ::Gapic::Config
@@ -712,6 +708,7 @@ module Google
712
708
  config_attr :retry_policy, nil, ::Hash, ::Proc, nil
713
709
  config_attr :quota_project, nil, ::String, nil
714
710
  config_attr :universe_domain, nil, ::String, nil
711
+ config_attr :logger, :default, ::Logger, nil, :default
715
712
 
716
713
  # @private
717
714
  def initialize parent_config = nil
@@ -164,15 +164,27 @@ module Google
164
164
  endpoint: @config.endpoint,
165
165
  endpoint_template: DEFAULT_ENDPOINT_TEMPLATE,
166
166
  universe_domain: @config.universe_domain,
167
- credentials: credentials
167
+ credentials: credentials,
168
+ logger: @config.logger
168
169
  )
169
170
 
171
+ @documents_stub.logger(stub: true)&.info do |entry|
172
+ entry.set_system_name
173
+ entry.set_service
174
+ entry.message = "Created client for #{entry.service}"
175
+ entry.set_credentials_fields credentials
176
+ entry.set "customEndpoint", @config.endpoint if @config.endpoint
177
+ entry.set "defaultTimeout", @config.timeout if @config.timeout
178
+ entry.set "quotaProject", @quota_project_id if @quota_project_id
179
+ end
180
+
170
181
  @location_client = Google::Cloud::Location::Locations::Rest::Client.new do |config|
171
182
  config.credentials = credentials
172
183
  config.quota_project = @quota_project_id
173
184
  config.endpoint = @documents_stub.endpoint
174
185
  config.universe_domain = @documents_stub.universe_domain
175
186
  config.bindings_override = @config.bindings_override
187
+ config.logger = @documents_stub.logger if config.respond_to? :logger=
176
188
  end
177
189
  end
178
190
 
@@ -190,6 +202,15 @@ module Google
190
202
  #
191
203
  attr_reader :location_client
192
204
 
205
+ ##
206
+ # The logger used for request/response debug logging.
207
+ #
208
+ # @return [Logger]
209
+ #
210
+ def logger
211
+ @documents_stub.logger
212
+ end
213
+
193
214
  # Service calls
194
215
 
195
216
  ##
@@ -299,7 +320,7 @@ module Google
299
320
  @documents_stub.list_documents request, options do |result, operation|
300
321
  result = ::Gapic::Rest::PagedEnumerable.new @documents_stub, :list_documents, "documents", request, result, options
301
322
  yield result, operation if block_given?
302
- return result
323
+ throw :response, result
303
324
  end
304
325
  rescue ::Gapic::Rest::Error => e
305
326
  raise ::Google::Cloud::Error.from_error(e)
@@ -380,7 +401,6 @@ module Google
380
401
 
381
402
  @documents_stub.get_document request, options do |result, operation|
382
403
  yield result, operation if block_given?
383
- return result
384
404
  end
385
405
  rescue ::Gapic::Rest::Error => e
386
406
  raise ::Google::Cloud::Error.from_error(e)
@@ -479,7 +499,7 @@ module Google
479
499
  @documents_stub.create_document request, options do |result, operation|
480
500
  result = ::Gapic::Operation.new result, @operations_client, options: options
481
501
  yield result, operation if block_given?
482
- return result
502
+ throw :response, result
483
503
  end
484
504
  rescue ::Gapic::Rest::Error => e
485
505
  raise ::Google::Cloud::Error.from_error(e)
@@ -591,7 +611,7 @@ module Google
591
611
  @documents_stub.import_documents request, options do |result, operation|
592
612
  result = ::Gapic::Operation.new result, @operations_client, options: options
593
613
  yield result, operation if block_given?
594
- return result
614
+ throw :response, result
595
615
  end
596
616
  rescue ::Gapic::Rest::Error => e
597
617
  raise ::Google::Cloud::Error.from_error(e)
@@ -689,7 +709,7 @@ module Google
689
709
  @documents_stub.delete_document request, options do |result, operation|
690
710
  result = ::Gapic::Operation.new result, @operations_client, options: options
691
711
  yield result, operation if block_given?
692
- return result
712
+ throw :response, result
693
713
  end
694
714
  rescue ::Gapic::Rest::Error => e
695
715
  raise ::Google::Cloud::Error.from_error(e)
@@ -788,7 +808,7 @@ module Google
788
808
  @documents_stub.update_document request, options do |result, operation|
789
809
  result = ::Gapic::Operation.new result, @operations_client, options: options
790
810
  yield result, operation if block_given?
791
- return result
811
+ throw :response, result
792
812
  end
793
813
  rescue ::Gapic::Rest::Error => e
794
814
  raise ::Google::Cloud::Error.from_error(e)
@@ -903,7 +923,7 @@ module Google
903
923
  @documents_stub.reload_document request, options do |result, operation|
904
924
  result = ::Gapic::Operation.new result, @operations_client, options: options
905
925
  yield result, operation if block_given?
906
- return result
926
+ throw :response, result
907
927
  end
908
928
  rescue ::Gapic::Rest::Error => e
909
929
  raise ::Google::Cloud::Error.from_error(e)
@@ -1009,7 +1029,7 @@ module Google
1009
1029
  @documents_stub.export_document request, options do |result, operation|
1010
1030
  result = ::Gapic::Operation.new result, @operations_client, options: options
1011
1031
  yield result, operation if block_given?
1012
- return result
1032
+ throw :response, result
1013
1033
  end
1014
1034
  rescue ::Gapic::Rest::Error => e
1015
1035
  raise ::Google::Cloud::Error.from_error(e)
@@ -1089,6 +1109,11 @@ module Google
1089
1109
  # default endpoint URL. The default value of nil uses the environment
1090
1110
  # universe (usually the default "googleapis.com" universe).
1091
1111
  # @return [::String,nil]
1112
+ # @!attribute [rw] logger
1113
+ # A custom logger to use for request/response debug logging, or the value
1114
+ # `:default` (the default) to construct a default logger, or `nil` to
1115
+ # explicitly disable logging.
1116
+ # @return [::Logger,:default,nil]
1092
1117
  #
1093
1118
  class Configuration
1094
1119
  extend ::Gapic::Config
@@ -1117,6 +1142,7 @@ module Google
1117
1142
  # by the host service.
1118
1143
  # @return [::Hash{::Symbol=>::Array<::Gapic::Rest::GrpcTranscoder::HttpBinding>}]
1119
1144
  config_attr :bindings_override, {}, ::Hash, nil
1145
+ config_attr :logger, :default, ::Logger, nil, :default
1120
1146
 
1121
1147
  # @private
1122
1148
  def initialize parent_config = nil