google-cloud-storage-control 1.0.0 → 1.1.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 816d4db120cc1cb4b3956cf64944e22ccbcb696b84e60807f31c87a5acaee6ef
4
- data.tar.gz: fb0df4317acc1201078b0303a1673e93b9f57a76302cc84518dcc76e1171695f
3
+ metadata.gz: bdb49c8f413d69958485313050592a0361aa3379ef6283c5f49f47750f59ae9a
4
+ data.tar.gz: e6c2965bde14b4db97cc1ff5075d19abcefbc372e90c08de8160bd4256689bf3
5
5
  SHA512:
6
- metadata.gz: 7efc5be2c167fe2fdc09e8c1f60448f4d4540baa6b7eafe509d1716b80914c65c149a8c9b1511df910be8338a7ed7238ccad0691c1fa24f63f2fafc02976a4b3
7
- data.tar.gz: 52c119639004ce72986141ee2f1b11001d0322bfb0c4ebec56483e91da99b22c72a4e282afb907db5bc189ca45d11382e1444f873354e10d409fb998471f8830
6
+ metadata.gz: d8fe9bdfc3e63086e87be7d08e86b73c68481c08b05b8804eaf373552b6bc402ba621fba49ef421f7c91ab1af755f6fea45aaddff91b13d092bd70dae327f6b9
7
+ data.tar.gz: 03bf52e6d79e5be029726ae846335e93be15aa73f8475bfb49a0bbb848803a1abac7c0da73e5d5efec800c1aa17e72e1743a7802db9fb9f85a96f0c08d545d23
data/README.md CHANGED
@@ -34,35 +34,39 @@ In order to use this library, you first need to go through the following steps:
34
34
  1. [Enable the API.](https://console.cloud.google.com/apis/library/storage.googleapis.com)
35
35
  1. {file:AUTHENTICATION.md Set up authentication.}
36
36
 
37
- ## Enabling Logging
38
-
39
- To enable logging for this library, set the logger for the underlying [gRPC](https://github.com/grpc/grpc/tree/master/src/ruby) library.
40
- The logger that you set may be a Ruby stdlib [`Logger`](https://ruby-doc.org/current/stdlibs/logger/Logger.html) as shown below,
41
- or a [`Google::Cloud::Logging::Logger`](https://cloud.google.com/ruby/docs/reference/google-cloud-logging/latest)
42
- 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)
43
- and the gRPC [spec_helper.rb](https://github.com/grpc/grpc/blob/master/src/ruby/spec/spec_helper.rb) for additional information.
44
-
45
- Configuring a Ruby stdlib logger:
46
-
47
- ```ruby
48
- require "logger"
49
-
50
- module MyLogger
51
- LOGGER = Logger.new $stderr, level: Logger::WARN
52
- def logger
53
- LOGGER
54
- end
55
- end
56
-
57
- # Define a gRPC module-level logger method before grpc/logconfig.rb loads.
58
- module GRPC
59
- extend MyLogger
60
- end
61
- ```
37
+ ## Debug Logging
38
+
39
+ This library comes with opt-in Debug Logging that can help you troubleshoot
40
+ your application's integration with the API. When logging is activated, key
41
+ events such as requests and responses, along with data payloads and metadata
42
+ such as headers and client configuration, are logged to the standard error
43
+ stream.
44
+
45
+ **WARNING:** Client Library Debug Logging includes your data payloads in
46
+ plaintext, which could include sensitive data such as PII for yourself or your
47
+ customers, private keys, or other security data that could be compromising if
48
+ leaked. Always practice good data hygiene with your application logs, and follow
49
+ the principle of least access. Google also recommends that Client Library Debug
50
+ Logging be enabled only temporarily during active debugging, and not used
51
+ permanently in production.
52
+
53
+ To enable logging, set the environment variable `GOOGLE_SDK_RUBY_LOGGING_GEMS`
54
+ to the value `all`. Alternatively, you can set the value to a comma-delimited
55
+ list of client library gem names. This will select the default logging behavior,
56
+ which writes logs to the standard error stream. On a local workstation, this may
57
+ result in logs appearing on the console. When running on a Google Cloud hosting
58
+ service such as [Google Cloud Run](https://cloud.google.com/run), this generally
59
+ results in logs appearing alongside your application logs in the
60
+ [Google Cloud Logging](https://cloud.google.com/logging/) service.
61
+
62
+ Debug logging also requires that the versioned clients for this service be
63
+ sufficiently recent, released after about Dec 10, 2024. If logging is not
64
+ working, try updating the versioned clients in your bundle or installed gems:
65
+ [google-cloud-storage-control-v2](https://cloud.google.com/ruby/docs/reference/google-cloud-storage-control-v2/latest).
62
66
 
63
67
  ## Supported Ruby Versions
64
68
 
65
- This library is supported on Ruby 2.7+.
69
+ This library is supported on Ruby 3.0+.
66
70
 
67
71
  Google provides official support for Ruby versions that are actively supported
68
72
  by Ruby Core—that is, Ruby versions that are either in normal maintenance or
@@ -21,7 +21,7 @@ module Google
21
21
  module Cloud
22
22
  module Storage
23
23
  module Control
24
- VERSION = "1.0.0"
24
+ VERSION = "1.1.0"
25
25
  end
26
26
  end
27
27
  end
@@ -57,6 +57,11 @@ module Google
57
57
  # supported by that API version, and the corresponding gem is available, the
58
58
  # appropriate versioned client will be returned.
59
59
  #
60
+ # Raises an exception if the currently installed versioned client gem for the
61
+ # given API version does not support the StorageControl service.
62
+ # You can determine whether the method will succeed by calling
63
+ # {Google::Cloud::Storage::Control.storage_control_available?}.
64
+ #
60
65
  # ## About StorageControl
61
66
  #
62
67
  # StorageControl service includes selected control plane operations.
@@ -76,6 +81,32 @@ module Google
76
81
  service_module.const_get(:Client).new(&block)
77
82
  end
78
83
 
84
+ ##
85
+ # Determines whether the StorageControl service is supported by the current client.
86
+ # If true, you can retrieve a client object by calling {Google::Cloud::Storage::Control.storage_control}.
87
+ # If false, that method will raise an exception. This could happen if the given
88
+ # API version does not exist or does not support the StorageControl service,
89
+ # or if the versioned client gem needs an update to support the StorageControl service.
90
+ #
91
+ # @param version [::String, ::Symbol] The API version to connect to. Optional.
92
+ # Defaults to `:v2`.
93
+ # @return [boolean] Whether the service is available.
94
+ #
95
+ def self.storage_control_available? version: :v2
96
+ require "google/cloud/storage/control/#{version.to_s.downcase}"
97
+ package_name = Google::Cloud::Storage::Control
98
+ .constants
99
+ .select { |sym| sym.to_s.downcase == version.to_s.downcase.tr("_", "") }
100
+ .first
101
+ return false unless package_name
102
+ service_module = Google::Cloud::Storage::Control.const_get package_name
103
+ return false unless service_module.const_defined? :StorageControl
104
+ service_module = service_module.const_get :StorageControl
105
+ service_module.const_defined? :Client
106
+ rescue ::LoadError
107
+ false
108
+ end
109
+
79
110
  ##
80
111
  # Configure the google-cloud-storage-control library.
81
112
  #
metadata CHANGED
@@ -1,14 +1,13 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: google-cloud-storage-control
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.0.0
4
+ version: 1.1.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-06-27 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: google-cloud-core
@@ -67,7 +66,6 @@ homepage: https://github.com/googleapis/google-cloud-ruby
67
66
  licenses:
68
67
  - Apache-2.0
69
68
  metadata: {}
70
- post_install_message:
71
69
  rdoc_options: []
72
70
  require_paths:
73
71
  - lib
@@ -75,15 +73,14 @@ required_ruby_version: !ruby/object:Gem::Requirement
75
73
  requirements:
76
74
  - - ">="
77
75
  - !ruby/object:Gem::Version
78
- version: '2.7'
76
+ version: '3.0'
79
77
  required_rubygems_version: !ruby/object:Gem::Requirement
80
78
  requirements:
81
79
  - - ">="
82
80
  - !ruby/object:Gem::Version
83
81
  version: '0'
84
82
  requirements: []
85
- rubygems_version: 3.5.6
86
- signing_key:
83
+ rubygems_version: 3.6.2
87
84
  specification_version: 4
88
85
  summary: The Storage Control API lets you perform metadata-specific, control plane,
89
86
  and long-running operations. The Storage Control API creates one space to perform