google-cloud-billing 1.5.1 → 1.6.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: 5a1ea5891f62903fa76c57bab0e7e86edcc485042be2ae27bfa4d72217d45530
4
- data.tar.gz: e77be972012c665ecaad50598c22951b78dbfc98cea0ed1134be2d44dc120fd5
3
+ metadata.gz: 1c54d4d94948ae60b4993c9e88c9410309ab1fa5a2d8ab3df42d2d2c0b7808dd
4
+ data.tar.gz: ef718df3eb5ca84c73c30d9ffdcd24be2d01e4496c083cfcf3f2052aae97e35d
5
5
  SHA512:
6
- metadata.gz: 6db6e5a2a41c8b8f071fac8a06ab38cb959bc0284f882ab9ceea32421a8f128d535734da38dadfeca6bf2c439daa121a9083278463e2f32a06d92b86cdb49163
7
- data.tar.gz: 3a1ba720ad39bb672c6b6c115611d675897eff1fc7baa8976d42b65ae93e52782871ffffa2f3b2b937b60bd6786355eaf0097da0cbba49ba1b2d916cab7d9e63
6
+ metadata.gz: 85bba3789b0a61d84310c2e32bb566fcbefe652c6ac6324da7b42cac31eb928969c379d8f66367892f11d8550ddb8f32412995dff64135e88680e02d82514061
7
+ data.tar.gz: 889bf48d25f3191cffa605c3bf9cd6dd471ba0633b37967027db6ed95e4aefdf88dc02533dbbadd1aff65b91bcf5703e17eb38c2e6f262edc6adec2ad88f55d1
data/README.md CHANGED
@@ -34,9 +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/cloudbilling.googleapis.com)
35
35
  1. {file:AUTHENTICATION.md Set up authentication.}
36
36
 
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-billing-v1](https://cloud.google.com/ruby/docs/reference/google-cloud-billing-v1/latest).
66
+
37
67
  ## Supported Ruby Versions
38
68
 
39
- This library is supported on Ruby 2.7+.
69
+ This library is supported on Ruby 3.0+.
40
70
 
41
71
  Google provides official support for Ruby versions that are actively supported
42
72
  by Ruby Core—that is, Ruby versions that are either in normal maintenance or
@@ -16,7 +16,7 @@
16
16
  module Google
17
17
  module Cloud
18
18
  module Billing
19
- VERSION = "1.5.1".freeze
19
+ VERSION = "1.6.0".freeze
20
20
  end
21
21
  end
22
22
  end
@@ -58,6 +58,11 @@ module Google
58
58
  # You can also specify a different transport by passing `:rest` or `:grpc` in
59
59
  # the `transport` parameter.
60
60
  #
61
+ # Raises an exception if the currently installed versioned client gem for the
62
+ # given API version does not support the given transport of the CloudBilling service.
63
+ # You can determine whether the method will succeed by calling
64
+ # {Google::Cloud::Billing.cloud_billing_service_available?}.
65
+ #
61
66
  # ## About CloudBilling
62
67
  #
63
68
  # Retrieves the Google Cloud Console billing accounts and associates them with
@@ -80,6 +85,37 @@ module Google
80
85
  service_module.const_get(:Client).new(&block)
81
86
  end
82
87
 
88
+ ##
89
+ # Determines whether the CloudBilling service is supported by the current client.
90
+ # If true, you can retrieve a client object by calling {Google::Cloud::Billing.cloud_billing_service}.
91
+ # If false, that method will raise an exception. This could happen if the given
92
+ # API version does not exist or does not support the CloudBilling service,
93
+ # or if the versioned client gem needs an update to support the CloudBilling service.
94
+ #
95
+ # @param version [::String, ::Symbol] The API version to connect to. Optional.
96
+ # Defaults to `:v1`.
97
+ # @param transport [:grpc, :rest] The transport to use. Defaults to `:grpc`.
98
+ # @return [boolean] Whether the service is available.
99
+ #
100
+ def self.cloud_billing_service_available? version: :v1, transport: :grpc
101
+ require "google/cloud/billing/#{version.to_s.downcase}"
102
+ package_name = Google::Cloud::Billing
103
+ .constants
104
+ .select { |sym| sym.to_s.downcase == version.to_s.downcase.tr("_", "") }
105
+ .first
106
+ return false unless package_name
107
+ service_module = Google::Cloud::Billing.const_get package_name
108
+ return false unless service_module.const_defined? :CloudBilling
109
+ service_module = service_module.const_get :CloudBilling
110
+ if transport == :rest
111
+ return false unless service_module.const_defined? :Rest
112
+ service_module = service_module.const_get :Rest
113
+ end
114
+ service_module.const_defined? :Client
115
+ rescue ::LoadError
116
+ false
117
+ end
118
+
83
119
  ##
84
120
  # Create a new client object for CloudCatalog.
85
121
  #
@@ -93,6 +129,11 @@ module Google
93
129
  # You can also specify a different transport by passing `:rest` or `:grpc` in
94
130
  # the `transport` parameter.
95
131
  #
132
+ # Raises an exception if the currently installed versioned client gem for the
133
+ # given API version does not support the given transport of the CloudCatalog service.
134
+ # You can determine whether the method will succeed by calling
135
+ # {Google::Cloud::Billing.cloud_catalog_service_available?}.
136
+ #
96
137
  # ## About CloudCatalog
97
138
  #
98
139
  # A catalog of Google Cloud Platform services and SKUs.
@@ -116,6 +157,37 @@ module Google
116
157
  service_module.const_get(:Client).new(&block)
117
158
  end
118
159
 
160
+ ##
161
+ # Determines whether the CloudCatalog service is supported by the current client.
162
+ # If true, you can retrieve a client object by calling {Google::Cloud::Billing.cloud_catalog_service}.
163
+ # If false, that method will raise an exception. This could happen if the given
164
+ # API version does not exist or does not support the CloudCatalog service,
165
+ # or if the versioned client gem needs an update to support the CloudCatalog service.
166
+ #
167
+ # @param version [::String, ::Symbol] The API version to connect to. Optional.
168
+ # Defaults to `:v1`.
169
+ # @param transport [:grpc, :rest] The transport to use. Defaults to `:grpc`.
170
+ # @return [boolean] Whether the service is available.
171
+ #
172
+ def self.cloud_catalog_service_available? version: :v1, transport: :grpc
173
+ require "google/cloud/billing/#{version.to_s.downcase}"
174
+ package_name = Google::Cloud::Billing
175
+ .constants
176
+ .select { |sym| sym.to_s.downcase == version.to_s.downcase.tr("_", "") }
177
+ .first
178
+ return false unless package_name
179
+ service_module = Google::Cloud::Billing.const_get package_name
180
+ return false unless service_module.const_defined? :CloudCatalog
181
+ service_module = service_module.const_get :CloudCatalog
182
+ if transport == :rest
183
+ return false unless service_module.const_defined? :Rest
184
+ service_module = service_module.const_get :Rest
185
+ end
186
+ service_module.const_defined? :Client
187
+ rescue ::LoadError
188
+ false
189
+ end
190
+
119
191
  ##
120
192
  # Configure the google-cloud-billing library.
121
193
  #
metadata CHANGED
@@ -1,14 +1,13 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: google-cloud-billing
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.5.1
4
+ version: 1.6.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-09 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-billing-v1
@@ -62,7 +61,6 @@ homepage: https://github.com/googleapis/google-cloud-ruby
62
61
  licenses:
63
62
  - Apache-2.0
64
63
  metadata: {}
65
- post_install_message:
66
64
  rdoc_options: []
67
65
  require_paths:
68
66
  - lib
@@ -70,15 +68,14 @@ required_ruby_version: !ruby/object:Gem::Requirement
70
68
  requirements:
71
69
  - - ">="
72
70
  - !ruby/object:Gem::Version
73
- version: '2.7'
71
+ version: '3.0'
74
72
  required_rubygems_version: !ruby/object:Gem::Requirement
75
73
  requirements:
76
74
  - - ">="
77
75
  - !ruby/object:Gem::Version
78
76
  version: '0'
79
77
  requirements: []
80
- rubygems_version: 3.5.6
81
- signing_key:
78
+ rubygems_version: 3.6.2
82
79
  specification_version: 4
83
80
  summary: API Client library for the Billing API
84
81
  test_files: []