google-cloud-trace-v2 1.0.1 → 1.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 68bce1d416284c789f45778ee12d9ffc8bff9622fc203b1a421fbc08675b31fe
4
- data.tar.gz: 9691cd8ef3585901f3f1ecd672eafe2e13fcd41c7fd3ffa8f5da4c4e3a43efbf
3
+ metadata.gz: e2c34daf0a28094b3628ec5c2ec41556b99f965f244c42dfc398b231ada5530e
4
+ data.tar.gz: aa80338b4218686687a38a5b52a45e6456554f72233e932b5f7fe4a9ee76cc32
5
5
  SHA512:
6
- metadata.gz: f6820a786f6a0ec252ea6ebd916ee3c2870a3003c5ce6517467bdb08a815affbfd8d9784b31ba005dcc717c1275899ca23f9d3f09609cb58850a02f701a56b50
7
- data.tar.gz: 2c9d99afd73b4d496156acd8663866ec65b8d21138f72cd1e46bb696ce7dd12599ed9dfbf703860ecc1fa9e453b5d6eb19017f078dabe4cae4583be249ade061
6
+ metadata.gz: edb9dd099870e8673a1196da5fb438e8456dba5306a8e6f4ad2e4eed894a3fa485c26b263ac008d3ab69659bcf58c4267c4c4fec2c86a3250b4f0e9e4716bb76
7
+ data.tar.gz: 7fe265c708d27c5f6800aa67371343c0186dc23886b62a0d01e309bcc44943c69a931b55abbdf402732de1785aaf40b0fb00a18fcdc7792d1c5452d812723b8e
data/README.md CHANGED
@@ -43,40 +43,50 @@ for class and method documentation.
43
43
  See also the [Product Documentation](https://cloud.google.com/trace)
44
44
  for general usage information.
45
45
 
46
- ## Enabling Logging
47
-
48
- To enable logging for this library, set the logger for the underlying [gRPC](https://github.com/grpc/grpc/tree/master/src/ruby) library.
49
- The logger that you set may be a Ruby stdlib [`Logger`](https://ruby-doc.org/current/stdlibs/logger/Logger.html) as shown below,
50
- or a [`Google::Cloud::Logging::Logger`](https://cloud.google.com/ruby/docs/reference/google-cloud-logging/latest)
51
- that will write logs to [Cloud Logging](https://cloud.google.com/logging/). See [grpc/logconfig.rb](https://github.com/grpc/grpc/blob/master/src/ruby/lib/grpc/logconfig.rb)
52
- and the gRPC [spec_helper.rb](https://github.com/grpc/grpc/blob/master/src/ruby/spec/spec_helper.rb) for additional information.
53
-
54
- Configuring a Ruby stdlib logger:
46
+ ## Debug Logging
47
+
48
+ This library comes with opt-in Debug Logging that can help you troubleshoot
49
+ your application's integration with the API. When logging is activated, key
50
+ events such as requests and responses, along with data payloads and metadata
51
+ such as headers and client configuration, are logged to the standard error
52
+ stream.
53
+
54
+ **WARNING:** Client Library Debug Logging includes your data payloads in
55
+ plaintext, which could include sensitive data such as PII for yourself or your
56
+ customers, private keys, or other security data that could be compromising if
57
+ leaked. Always practice good data hygiene with your application logs, and follow
58
+ the principle of least access. Google also recommends that Client Library Debug
59
+ Logging be enabled only temporarily during active debugging, and not used
60
+ permanently in production.
61
+
62
+ To enable logging, set the environment variable `GOOGLE_SDK_RUBY_LOGGING_GEMS`
63
+ to the value `all`. Alternatively, you can set the value to a comma-delimited
64
+ list of client library gem names. This will select the default logging behavior,
65
+ which writes logs to the standard error stream. On a local workstation, this may
66
+ result in logs appearing on the console. When running on a Google Cloud hosting
67
+ service such as [Google Cloud Run](https://cloud.google.com/run), this generally
68
+ results in logs appearing alongside your application logs in the
69
+ [Google Cloud Logging](https://cloud.google.com/logging/) service.
70
+
71
+ You can customize logging by modifying the `logger` configuration when
72
+ constructing a client object. For example:
55
73
 
56
74
  ```ruby
75
+ require "google/cloud/trace/v2"
57
76
  require "logger"
58
77
 
59
- module MyLogger
60
- LOGGER = Logger.new $stderr, level: Logger::WARN
61
- def logger
62
- LOGGER
63
- end
64
- end
65
-
66
- # Define a gRPC module-level logger method before grpc/logconfig.rb loads.
67
- module GRPC
68
- extend MyLogger
78
+ client = ::Google::Cloud::Trace::V2::TraceService::Client.new do |config|
79
+ config.logger = Logger.new "my-app.log"
69
80
  end
70
81
  ```
71
82
 
72
-
73
83
  ## Google Cloud Samples
74
84
 
75
85
  To browse ready to use code samples check [Google Cloud Samples](https://cloud.google.com/docs/samples).
76
86
 
77
87
  ## Supported Ruby Versions
78
88
 
79
- This library is supported on Ruby 2.7+.
89
+ This library is supported on Ruby 3.0+.
80
90
 
81
91
  Google provides official support for Ruby versions that are actively supported
82
92
  by Ruby Core—that is, Ruby versions that are either in normal maintenance or
@@ -173,8 +173,28 @@ module Google
173
173
  universe_domain: @config.universe_domain,
174
174
  channel_args: @config.channel_args,
175
175
  interceptors: @config.interceptors,
176
- channel_pool_config: @config.channel_pool
176
+ channel_pool_config: @config.channel_pool,
177
+ logger: @config.logger
177
178
  )
179
+
180
+ @trace_service_stub.stub_logger&.info do |entry|
181
+ entry.set_system_name
182
+ entry.set_service
183
+ entry.message = "Created client for #{entry.service}"
184
+ entry.set_credentials_fields credentials
185
+ entry.set "customEndpoint", @config.endpoint if @config.endpoint
186
+ entry.set "defaultTimeout", @config.timeout if @config.timeout
187
+ entry.set "quotaProject", @quota_project_id if @quota_project_id
188
+ end
189
+ end
190
+
191
+ ##
192
+ # The logger used for request/response debug logging.
193
+ #
194
+ # @return [Logger]
195
+ #
196
+ def logger
197
+ @trace_service_stub.logger
178
198
  end
179
199
 
180
200
  # Service calls
@@ -264,7 +284,6 @@ module Google
264
284
 
265
285
  @trace_service_stub.call_rpc :batch_write_spans, request, options: options do |response, operation|
266
286
  yield response, operation if block_given?
267
- return response
268
287
  end
269
288
  rescue ::GRPC::BadStatus => e
270
289
  raise ::Google::Cloud::Error.from_error(e)
@@ -406,7 +425,6 @@ module Google
406
425
 
407
426
  @trace_service_stub.call_rpc :create_span, request, options: options do |response, operation|
408
427
  yield response, operation if block_given?
409
- return response
410
428
  end
411
429
  rescue ::GRPC::BadStatus => e
412
430
  raise ::Google::Cloud::Error.from_error(e)
@@ -456,6 +474,13 @@ module Google
456
474
  # * (`GRPC::Core::Channel`) a gRPC channel with included credentials
457
475
  # * (`GRPC::Core::ChannelCredentials`) a gRPC credentails object
458
476
  # * (`nil`) indicating no credentials
477
+ #
478
+ # Warning: If you accept a credential configuration (JSON file or Hash) from an
479
+ # external source for authentication to Google Cloud, you must validate it before
480
+ # providing it to a Google API client library. Providing an unvalidated credential
481
+ # configuration to Google APIs can compromise the security of your systems and data.
482
+ # For more information, refer to [Validate credential configurations from external
483
+ # sources](https://cloud.google.com/docs/authentication/external/externally-sourced-credentials).
459
484
  # @return [::Object]
460
485
  # @!attribute [rw] scope
461
486
  # The OAuth scopes
@@ -495,6 +520,11 @@ module Google
495
520
  # default endpoint URL. The default value of nil uses the environment
496
521
  # universe (usually the default "googleapis.com" universe).
497
522
  # @return [::String,nil]
523
+ # @!attribute [rw] logger
524
+ # A custom logger to use for request/response debug logging, or the value
525
+ # `:default` (the default) to construct a default logger, or `nil` to
526
+ # explicitly disable logging.
527
+ # @return [::Logger,:default,nil]
498
528
  #
499
529
  class Configuration
500
530
  extend ::Gapic::Config
@@ -519,6 +549,7 @@ module Google
519
549
  config_attr :retry_policy, nil, ::Hash, ::Proc, nil
520
550
  config_attr :quota_project, nil, ::String, nil
521
551
  config_attr :universe_domain, nil, ::String, nil
552
+ config_attr :logger, :default, ::Logger, nil, :default
522
553
 
523
554
  # @private
524
555
  def initialize parent_config = nil
@@ -166,8 +166,28 @@ module Google
166
166
  endpoint: @config.endpoint,
167
167
  endpoint_template: DEFAULT_ENDPOINT_TEMPLATE,
168
168
  universe_domain: @config.universe_domain,
169
- credentials: credentials
169
+ credentials: credentials,
170
+ logger: @config.logger
170
171
  )
172
+
173
+ @trace_service_stub.logger(stub: true)&.info do |entry|
174
+ entry.set_system_name
175
+ entry.set_service
176
+ entry.message = "Created client for #{entry.service}"
177
+ entry.set_credentials_fields credentials
178
+ entry.set "customEndpoint", @config.endpoint if @config.endpoint
179
+ entry.set "defaultTimeout", @config.timeout if @config.timeout
180
+ entry.set "quotaProject", @quota_project_id if @quota_project_id
181
+ end
182
+ end
183
+
184
+ ##
185
+ # The logger used for request/response debug logging.
186
+ #
187
+ # @return [Logger]
188
+ #
189
+ def logger
190
+ @trace_service_stub.logger
171
191
  end
172
192
 
173
193
  # Service calls
@@ -250,7 +270,6 @@ module Google
250
270
 
251
271
  @trace_service_stub.batch_write_spans request, options do |result, operation|
252
272
  yield result, operation if block_given?
253
- return result
254
273
  end
255
274
  rescue ::Gapic::Rest::Error => e
256
275
  raise ::Google::Cloud::Error.from_error(e)
@@ -385,7 +404,6 @@ module Google
385
404
 
386
405
  @trace_service_stub.create_span request, options do |result, operation|
387
406
  yield result, operation if block_given?
388
- return result
389
407
  end
390
408
  rescue ::Gapic::Rest::Error => e
391
409
  raise ::Google::Cloud::Error.from_error(e)
@@ -433,6 +451,13 @@ module Google
433
451
  # * (`Signet::OAuth2::Client`) A signet oauth2 client object
434
452
  # (see the [signet docs](https://rubydoc.info/gems/signet/Signet/OAuth2/Client))
435
453
  # * (`nil`) indicating no credentials
454
+ #
455
+ # Warning: If you accept a credential configuration (JSON file or Hash) from an
456
+ # external source for authentication to Google Cloud, you must validate it before
457
+ # providing it to a Google API client library. Providing an unvalidated credential
458
+ # configuration to Google APIs can compromise the security of your systems and data.
459
+ # For more information, refer to [Validate credential configurations from external
460
+ # sources](https://cloud.google.com/docs/authentication/external/externally-sourced-credentials).
436
461
  # @return [::Object]
437
462
  # @!attribute [rw] scope
438
463
  # The OAuth scopes
@@ -465,6 +490,11 @@ module Google
465
490
  # default endpoint URL. The default value of nil uses the environment
466
491
  # universe (usually the default "googleapis.com" universe).
467
492
  # @return [::String,nil]
493
+ # @!attribute [rw] logger
494
+ # A custom logger to use for request/response debug logging, or the value
495
+ # `:default` (the default) to construct a default logger, or `nil` to
496
+ # explicitly disable logging.
497
+ # @return [::Logger,:default,nil]
468
498
  #
469
499
  class Configuration
470
500
  extend ::Gapic::Config
@@ -486,6 +516,7 @@ module Google
486
516
  config_attr :retry_policy, nil, ::Hash, ::Proc, nil
487
517
  config_attr :quota_project, nil, ::String, nil
488
518
  config_attr :universe_domain, nil, ::String, nil
519
+ config_attr :logger, :default, ::Logger, nil, :default
489
520
 
490
521
  # @private
491
522
  def initialize parent_config = nil
@@ -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 batch_write_spans 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: "batch_write_spans",
93
106
  options: options
94
107
  )
95
108
  operation = ::Gapic::Rest::TransportOperation.new response
96
109
  result = ::Google::Protobuf::Empty.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: "create_span",
131
146
  options: options
132
147
  )
133
148
  operation = ::Gapic::Rest::TransportOperation.new response
134
149
  result = ::Google::Cloud::Trace::V2::Span.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
  ##
@@ -21,7 +21,7 @@ module Google
21
21
  module Cloud
22
22
  module Trace
23
23
  module V2
24
- VERSION = "1.0.1"
24
+ VERSION = "1.2.0"
25
25
  end
26
26
  end
27
27
  end
@@ -28,6 +28,9 @@ module Google
28
28
  # @!attribute [rw] destinations
29
29
  # @return [::Array<::Google::Api::ClientLibraryDestination>]
30
30
  # The destination where API teams want this client library to be published.
31
+ # @!attribute [rw] selective_gapic_generation
32
+ # @return [::Google::Api::SelectiveGapicGeneration]
33
+ # Configuration for which RPCs should be generated in the GAPIC client.
31
34
  class CommonLanguageSettings
32
35
  include ::Google::Protobuf::MessageExts
33
36
  extend ::Google::Protobuf::MessageExts::ClassMethods
@@ -212,6 +215,12 @@ module Google
212
215
  # enabled. By default, asynchronous REST clients will not be generated.
213
216
  # This feature will be enabled by default 1 month after launching the
214
217
  # feature in preview packages.
218
+ # @!attribute [rw] protobuf_pythonic_types_enabled
219
+ # @return [::Boolean]
220
+ # Enables generation of protobuf code using new types that are more
221
+ # Pythonic which are included in `protobuf>=5.29.x`. This feature will be
222
+ # enabled by default 1 month after launching the feature in preview
223
+ # packages.
215
224
  class ExperimentalFeatures
216
225
  include ::Google::Protobuf::MessageExts
217
226
  extend ::Google::Protobuf::MessageExts::ClassMethods
@@ -297,9 +306,28 @@ module Google
297
306
  # @!attribute [rw] common
298
307
  # @return [::Google::Api::CommonLanguageSettings]
299
308
  # Some settings.
309
+ # @!attribute [rw] renamed_services
310
+ # @return [::Google::Protobuf::Map{::String => ::String}]
311
+ # Map of service names to renamed services. Keys are the package relative
312
+ # service names and values are the name to be used for the service client
313
+ # and call options.
314
+ #
315
+ # publishing:
316
+ # go_settings:
317
+ # renamed_services:
318
+ # Publisher: TopicAdmin
300
319
  class GoSettings
301
320
  include ::Google::Protobuf::MessageExts
302
321
  extend ::Google::Protobuf::MessageExts::ClassMethods
322
+
323
+ # @!attribute [rw] key
324
+ # @return [::String]
325
+ # @!attribute [rw] value
326
+ # @return [::String]
327
+ class RenamedServicesEntry
328
+ include ::Google::Protobuf::MessageExts
329
+ extend ::Google::Protobuf::MessageExts::ClassMethods
330
+ end
303
331
  end
304
332
 
305
333
  # Describes the generator configuration for a method.
@@ -375,6 +403,17 @@ module Google
375
403
  end
376
404
  end
377
405
 
406
+ # This message is used to configure the generation of a subset of the RPCs in
407
+ # a service for client libraries.
408
+ # @!attribute [rw] methods
409
+ # @return [::Array<::String>]
410
+ # An allowlist of the fully qualified names of RPCs that should be included
411
+ # on public client surfaces.
412
+ class SelectiveGapicGeneration
413
+ include ::Google::Protobuf::MessageExts
414
+ extend ::Google::Protobuf::MessageExts::ClassMethods
415
+ end
416
+
378
417
  # The organization for which the client libraries are being published.
379
418
  # Affects the url where generated docs are published, etc.
380
419
  module ClientLibraryOrganization
@@ -141,9 +141,13 @@ module Google
141
141
  # @!attribute [rw] annotation
142
142
  # @return [::Google::Cloud::Trace::V2::Span::TimeEvent::Annotation]
143
143
  # Text annotation with a set of attributes.
144
+ #
145
+ # Note: The following fields are mutually exclusive: `annotation`, `message_event`. If a field in that set is populated, all other fields in the set will automatically be cleared.
144
146
  # @!attribute [rw] message_event
145
147
  # @return [::Google::Cloud::Trace::V2::Span::TimeEvent::MessageEvent]
146
148
  # An event describing a message sent/received between Spans.
149
+ #
150
+ # Note: The following fields are mutually exclusive: `message_event`, `annotation`. If a field in that set is populated, all other fields in the set will automatically be cleared.
147
151
  class TimeEvent
148
152
  include ::Google::Protobuf::MessageExts
149
153
  extend ::Google::Protobuf::MessageExts::ClassMethods
@@ -301,12 +305,18 @@ module Google
301
305
  # @!attribute [rw] string_value
302
306
  # @return [::Google::Cloud::Trace::V2::TruncatableString]
303
307
  # A string up to 256 bytes long.
308
+ #
309
+ # Note: The following fields are mutually exclusive: `string_value`, `int_value`, `bool_value`. If a field in that set is populated, all other fields in the set will automatically be cleared.
304
310
  # @!attribute [rw] int_value
305
311
  # @return [::Integer]
306
312
  # A 64-bit signed integer.
313
+ #
314
+ # Note: The following fields are mutually exclusive: `int_value`, `string_value`, `bool_value`. If a field in that set is populated, all other fields in the set will automatically be cleared.
307
315
  # @!attribute [rw] bool_value
308
316
  # @return [::Boolean]
309
317
  # A Boolean value represented by `true` or `false`.
318
+ #
319
+ # Note: The following fields are mutually exclusive: `bool_value`, `string_value`, `int_value`. If a field in that set is populated, all other fields in the set will automatically be cleared.
310
320
  class AttributeValue
311
321
  include ::Google::Protobuf::MessageExts
312
322
  extend ::Google::Protobuf::MessageExts::ClassMethods
metadata CHANGED
@@ -1,14 +1,13 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: google-cloud-trace-v2
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.0.1
4
+ version: 1.2.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Google LLC
8
- autorequire:
9
8
  bindir: bin
10
9
  cert_chain: []
11
- date: 2024-08-30 00:00:00.000000000 Z
10
+ date: 2025-01-29 00:00:00.000000000 Z
12
11
  dependencies:
13
12
  - !ruby/object:Gem::Dependency
14
13
  name: gapic-common
@@ -16,7 +15,7 @@ dependencies:
16
15
  requirements:
17
16
  - - ">="
18
17
  - !ruby/object:Gem::Version
19
- version: 0.21.1
18
+ version: 0.25.0
20
19
  - - "<"
21
20
  - !ruby/object:Gem::Version
22
21
  version: 2.a
@@ -26,7 +25,7 @@ dependencies:
26
25
  requirements:
27
26
  - - ">="
28
27
  - !ruby/object:Gem::Version
29
- version: 0.21.1
28
+ version: 0.25.0
30
29
  - - "<"
31
30
  - !ruby/object:Gem::Version
32
31
  version: 2.a
@@ -91,7 +90,6 @@ homepage: https://github.com/googleapis/google-cloud-ruby
91
90
  licenses:
92
91
  - Apache-2.0
93
92
  metadata: {}
94
- post_install_message:
95
93
  rdoc_options: []
96
94
  require_paths:
97
95
  - lib
@@ -99,15 +97,14 @@ required_ruby_version: !ruby/object:Gem::Requirement
99
97
  requirements:
100
98
  - - ">="
101
99
  - !ruby/object:Gem::Version
102
- version: '2.7'
100
+ version: '3.0'
103
101
  required_rubygems_version: !ruby/object:Gem::Requirement
104
102
  requirements:
105
103
  - - ">="
106
104
  - !ruby/object:Gem::Version
107
105
  version: '0'
108
106
  requirements: []
109
- rubygems_version: 3.5.6
110
- signing_key:
107
+ rubygems_version: 3.6.2
111
108
  specification_version: 4
112
109
  summary: Sends application trace data to Stackdriver Trace for viewing. Trace data
113
110
  is collected for all App Engine applications by default. Trace data from other applications