google-cloud-pubsub 2.15.3 → 3.0.2
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 +4 -4
- data/AUTHENTICATION.md +8 -26
- data/CHANGELOG.md +108 -0
- data/OVERVIEW.md +188 -144
- data/lib/google/cloud/pubsub/admin_clients.rb +116 -0
- data/lib/google/cloud/pubsub/async_publisher.rb +9 -9
- data/lib/google/cloud/pubsub/batch_publisher.rb +4 -4
- data/lib/google/cloud/pubsub/convert.rb +1 -1
- data/lib/google/cloud/pubsub/errors.rb +3 -3
- data/lib/google/cloud/pubsub/flow_controller.rb +0 -2
- data/lib/google/cloud/pubsub/message.rb +10 -11
- data/lib/google/cloud/pubsub/{subscriber → message_listener}/enumerator_queue.rb +1 -1
- data/lib/google/cloud/pubsub/{subscriber → message_listener}/inventory.rb +2 -4
- data/lib/google/cloud/pubsub/{subscriber → message_listener}/sequencer.rb +1 -1
- data/lib/google/cloud/pubsub/{subscriber → message_listener}/stream.rb +15 -14
- data/lib/google/cloud/pubsub/{subscriber → message_listener}/timed_unary_buffer.rb +1 -1
- data/lib/google/cloud/pubsub/message_listener.rb +413 -0
- data/lib/google/cloud/pubsub/project.rb +103 -523
- data/lib/google/cloud/pubsub/publisher.rb +373 -0
- data/lib/google/cloud/pubsub/received_message.rb +50 -45
- data/lib/google/cloud/pubsub/service.rb +40 -352
- data/lib/google/cloud/pubsub/subscriber.rb +442 -279
- data/lib/google/cloud/pubsub/version.rb +1 -1
- data/lib/google/cloud/pubsub.rb +24 -28
- data/lib/google-cloud-pubsub.rb +8 -6
- metadata +18 -183
- data/lib/google/cloud/pubsub/policy.rb +0 -188
- data/lib/google/cloud/pubsub/retry_policy.rb +0 -88
- data/lib/google/cloud/pubsub/schema/list.rb +0 -180
- data/lib/google/cloud/pubsub/schema.rb +0 -310
- data/lib/google/cloud/pubsub/snapshot/list.rb +0 -178
- data/lib/google/cloud/pubsub/snapshot.rb +0 -205
- data/lib/google/cloud/pubsub/subscription/list.rb +0 -205
- data/lib/google/cloud/pubsub/subscription/push_config.rb +0 -268
- data/lib/google/cloud/pubsub/subscription.rb +0 -1467
- data/lib/google/cloud/pubsub/topic/list.rb +0 -171
- data/lib/google/cloud/pubsub/topic.rb +0 -1100
|
@@ -1,268 +0,0 @@
|
|
|
1
|
-
# Copyright 2019 Google LLC
|
|
2
|
-
#
|
|
3
|
-
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
4
|
-
# you may not use this file except in compliance with the License.
|
|
5
|
-
# You may obtain a copy of the License at
|
|
6
|
-
#
|
|
7
|
-
# https://www.apache.org/licenses/LICENSE-2.0
|
|
8
|
-
#
|
|
9
|
-
# Unless required by applicable law or agreed to in writing, software
|
|
10
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
11
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
12
|
-
# See the License for the specific language governing permissions and
|
|
13
|
-
# limitations under the License.
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
require "google/pubsub/v1/pubsub_pb"
|
|
17
|
-
|
|
18
|
-
module Google
|
|
19
|
-
module Cloud
|
|
20
|
-
module PubSub
|
|
21
|
-
class Subscription
|
|
22
|
-
##
|
|
23
|
-
# Configuration for a push delivery endpoint.
|
|
24
|
-
#
|
|
25
|
-
# @example Create a push config:
|
|
26
|
-
# require "google/cloud/pubsub"
|
|
27
|
-
#
|
|
28
|
-
# pubsub = Google::Cloud::PubSub.new
|
|
29
|
-
# topic = pubsub.topic "my-topic"
|
|
30
|
-
#
|
|
31
|
-
# push_config = Google::Cloud::PubSub::Subscription::PushConfig.new endpoint: "http://example.net/callback"
|
|
32
|
-
# push_config.set_oidc_token "service-account@example.net", "audience-header-value"
|
|
33
|
-
#
|
|
34
|
-
# sub = topic.subscribe "my-subscription", push_config: push_config
|
|
35
|
-
#
|
|
36
|
-
# @example Read a push config:
|
|
37
|
-
# require "google/cloud/pubsub"
|
|
38
|
-
#
|
|
39
|
-
# pubsub = Google::Cloud::PubSub.new
|
|
40
|
-
#
|
|
41
|
-
# sub = pubsub.subscription "my-topic-sub"
|
|
42
|
-
# sub.push_config.endpoint #=> "http://example.com/callback"
|
|
43
|
-
# sub.push_config.authentication.email #=> "user@example.com"
|
|
44
|
-
# sub.push_config.authentication.audience #=> "client-12345"
|
|
45
|
-
#
|
|
46
|
-
# @example Update a push config:
|
|
47
|
-
# require "google/cloud/pubsub"
|
|
48
|
-
#
|
|
49
|
-
# pubsub = Google::Cloud::PubSub.new
|
|
50
|
-
# sub = pubsub.subscription "my-subscription"
|
|
51
|
-
#
|
|
52
|
-
# sub.push_config do |pc|
|
|
53
|
-
# pc.endpoint = "http://example.net/callback"
|
|
54
|
-
# pc.set_oidc_token "user@example.net", "client-67890"
|
|
55
|
-
# end
|
|
56
|
-
#
|
|
57
|
-
class PushConfig
|
|
58
|
-
##
|
|
59
|
-
# Creates a new push configuration.
|
|
60
|
-
#
|
|
61
|
-
# @param [String] endpoint A URL locating the endpoint to which messages should be pushed. For
|
|
62
|
-
# example, a Webhook endpoint might use `https://example.com/push`.
|
|
63
|
-
# @param [String] email The service account email to be used for generating the OIDC token.
|
|
64
|
-
# The caller must have the `iam.serviceAccounts.actAs` permission for the service account.
|
|
65
|
-
# @param [String] audience The audience to be used when generating OIDC token. The audience claim identifies
|
|
66
|
-
# the recipients that the JWT is intended for. The audience value is a single case-sensitive string. Having
|
|
67
|
-
# multiple values (array) for the audience field is not supported. More info about the OIDC JWT token
|
|
68
|
-
# audience here: https://tools.ietf.org/html/rfc7519#section-4.1.3 Note: if not specified, the `endpoint`
|
|
69
|
-
# URL will be used.
|
|
70
|
-
#
|
|
71
|
-
def initialize endpoint: nil, email: nil, audience: nil
|
|
72
|
-
@grpc = Google::Cloud::PubSub::V1::PushConfig.new
|
|
73
|
-
|
|
74
|
-
self.endpoint = endpoint unless endpoint.nil?
|
|
75
|
-
|
|
76
|
-
raise ArgumentError, "audience provided without email. Authentication is invalid" if audience && !email
|
|
77
|
-
|
|
78
|
-
set_oidc_token email, audience if email
|
|
79
|
-
end
|
|
80
|
-
|
|
81
|
-
##
|
|
82
|
-
# A URL locating the endpoint to which messages should be pushed. For example, a Webhook endpoint might use
|
|
83
|
-
# `https://example.com/push`.
|
|
84
|
-
#
|
|
85
|
-
# @return [String]
|
|
86
|
-
def endpoint
|
|
87
|
-
@grpc.push_endpoint
|
|
88
|
-
end
|
|
89
|
-
|
|
90
|
-
##
|
|
91
|
-
# Sets the URL locating the endpoint to which messages should be pushed. For example, a Webhook endpoint might
|
|
92
|
-
# use `https://example.com/push`.
|
|
93
|
-
#
|
|
94
|
-
# @param [String, nil] new_endpoint New URL value
|
|
95
|
-
def endpoint= new_endpoint
|
|
96
|
-
@grpc.push_endpoint = String new_endpoint
|
|
97
|
-
end
|
|
98
|
-
|
|
99
|
-
##
|
|
100
|
-
# The authentication method used by push endpoints to verify the source of push requests.
|
|
101
|
-
#
|
|
102
|
-
# @return [OidcToken, nil] An OIDC JWT token if specified, `nil`
|
|
103
|
-
# otherwise.
|
|
104
|
-
def authentication
|
|
105
|
-
return nil unless @grpc.authentication_method == :oidc_token
|
|
106
|
-
|
|
107
|
-
OidcToken.from_grpc @grpc.oidc_token
|
|
108
|
-
end
|
|
109
|
-
|
|
110
|
-
##
|
|
111
|
-
# Sets the authentication method used by push endpoints to verify the source of push requests.
|
|
112
|
-
#
|
|
113
|
-
# @param [OidcToken, nil] new_auth An authentication value.
|
|
114
|
-
def authentication= new_auth
|
|
115
|
-
if new_auth.nil?
|
|
116
|
-
@grpc.oidc_token = nil
|
|
117
|
-
else
|
|
118
|
-
raise ArgumentError unless new_auth.is_a? OidcToken
|
|
119
|
-
|
|
120
|
-
@grpc.oidc_token = new_auth.to_grpc
|
|
121
|
-
end
|
|
122
|
-
end
|
|
123
|
-
|
|
124
|
-
##
|
|
125
|
-
# Checks whether authentication is an {OidcToken}.
|
|
126
|
-
#
|
|
127
|
-
# @return [Boolean]
|
|
128
|
-
def oidc_token?
|
|
129
|
-
authentication.is_a? OidcToken
|
|
130
|
-
end
|
|
131
|
-
|
|
132
|
-
##
|
|
133
|
-
# Sets the authentication method to use an {OidcToken}.
|
|
134
|
-
#
|
|
135
|
-
# @param [String] email Service account email.
|
|
136
|
-
# @param [String] audience Audience to be used.
|
|
137
|
-
def set_oidc_token email, audience
|
|
138
|
-
oidc_token = OidcToken.new.tap do |token|
|
|
139
|
-
token.email = email
|
|
140
|
-
token.audience = audience
|
|
141
|
-
end
|
|
142
|
-
self.authentication = oidc_token
|
|
143
|
-
end
|
|
144
|
-
|
|
145
|
-
##
|
|
146
|
-
# The format of the pushed message. This attribute indicates the version of the data expected by the endpoint.
|
|
147
|
-
# This controls the shape of the pushed message (i.e., its fields and metadata). The endpoint version is based
|
|
148
|
-
# on the version of the Pub/Sub API.
|
|
149
|
-
#
|
|
150
|
-
# If not present during the Subscription creation, it will default to the version of the API used to make such
|
|
151
|
-
# call.
|
|
152
|
-
#
|
|
153
|
-
# The possible values for this attribute are:
|
|
154
|
-
#
|
|
155
|
-
# * `v1beta1`: uses the push format defined in the v1beta1 Pub/Sub
|
|
156
|
-
# API.
|
|
157
|
-
# * `v1` or `v1beta2`: uses the push format defined in the v1 Pub/Sub
|
|
158
|
-
# API.
|
|
159
|
-
#
|
|
160
|
-
# @return [String]
|
|
161
|
-
def version
|
|
162
|
-
@grpc.attributes["x-goog-version"]
|
|
163
|
-
end
|
|
164
|
-
|
|
165
|
-
##
|
|
166
|
-
# Sets the format of the pushed message.
|
|
167
|
-
#
|
|
168
|
-
# The possible values for this attribute are:
|
|
169
|
-
#
|
|
170
|
-
# * `v1beta1`: uses the push format defined in the v1beta1 Pub/Sub
|
|
171
|
-
# API.
|
|
172
|
-
# * `v1` or `v1beta2`: uses the push format defined in the v1 Pub/Sub
|
|
173
|
-
# API.
|
|
174
|
-
#
|
|
175
|
-
# @param [String, nil] new_version The new version value.
|
|
176
|
-
def version= new_version
|
|
177
|
-
if new_version.nil?
|
|
178
|
-
@grpc.attributes.delete "x-goog-version"
|
|
179
|
-
else
|
|
180
|
-
@grpc.attributes["x-goog-version"] = new_version
|
|
181
|
-
end
|
|
182
|
-
end
|
|
183
|
-
|
|
184
|
-
##
|
|
185
|
-
# @private
|
|
186
|
-
def to_grpc
|
|
187
|
-
@grpc
|
|
188
|
-
end
|
|
189
|
-
|
|
190
|
-
##
|
|
191
|
-
# @private
|
|
192
|
-
def self.from_grpc grpc
|
|
193
|
-
new.tap do |pc|
|
|
194
|
-
pc.instance_variable_set :@grpc, grpc.dup if grpc
|
|
195
|
-
end
|
|
196
|
-
end
|
|
197
|
-
|
|
198
|
-
##
|
|
199
|
-
# Contains information needed for generating an [OpenID Connect
|
|
200
|
-
# token](https://developers.google.com/identity/protocols/OpenIDConnect).
|
|
201
|
-
class OidcToken
|
|
202
|
-
##
|
|
203
|
-
# @private
|
|
204
|
-
def initialize
|
|
205
|
-
@grpc = Google::Cloud::PubSub::V1::PushConfig::OidcToken.new
|
|
206
|
-
end
|
|
207
|
-
|
|
208
|
-
##
|
|
209
|
-
# The service account email to be used for generating the OIDC token. The caller must have the
|
|
210
|
-
# `iam.serviceAccounts.actAs` permission for the service account.
|
|
211
|
-
#
|
|
212
|
-
# @return [String]
|
|
213
|
-
def email
|
|
214
|
-
@grpc.service_account_email
|
|
215
|
-
end
|
|
216
|
-
|
|
217
|
-
##
|
|
218
|
-
# Sets the service account email to be used for generating the OIDC token. The caller must have the
|
|
219
|
-
# `iam.serviceAccounts.actAs` permission for the service account.
|
|
220
|
-
#
|
|
221
|
-
# @param [String] new_email New service account email value.
|
|
222
|
-
def email= new_email
|
|
223
|
-
@grpc.service_account_email = new_email
|
|
224
|
-
end
|
|
225
|
-
|
|
226
|
-
##
|
|
227
|
-
# The audience to be used when generating OIDC token. The audience claim identifies the recipients that
|
|
228
|
-
# the JWT is intended for. The audience value is a single case-sensitive string. Having multiple values
|
|
229
|
-
# (array) for the audience field is not supported. More info about the OIDC JWT token audience here:
|
|
230
|
-
# https://tools.ietf.org/html/rfc7519#section-4.1.3 Note: if not specified, the `endpoint` URL will be used.
|
|
231
|
-
#
|
|
232
|
-
# @return [String]
|
|
233
|
-
def audience
|
|
234
|
-
@grpc.audience
|
|
235
|
-
end
|
|
236
|
-
|
|
237
|
-
##
|
|
238
|
-
# Sets the audience to be used when generating OIDC token. The audience claim identifies the recipients that
|
|
239
|
-
# the JWT is intended for. The audience value is a single case-sensitive string. Having multiple values
|
|
240
|
-
# (array) for the audience field is not supported. More info about the OIDC JWT token audience here:
|
|
241
|
-
# https://tools.ietf.org/html/rfc7519#section-4.1.3 Note: if not specified, the `endpoint` URL will be used.
|
|
242
|
-
#
|
|
243
|
-
# @param [String] new_audience New audience value.
|
|
244
|
-
def audience= new_audience
|
|
245
|
-
@grpc.audience = new_audience
|
|
246
|
-
end
|
|
247
|
-
|
|
248
|
-
##
|
|
249
|
-
# @private
|
|
250
|
-
def to_grpc
|
|
251
|
-
@grpc
|
|
252
|
-
end
|
|
253
|
-
|
|
254
|
-
##
|
|
255
|
-
# @private
|
|
256
|
-
def self.from_grpc grpc
|
|
257
|
-
grpc ||= Google::Cloud::PubSub::V1::PushConfig::OidcToken.new
|
|
258
|
-
|
|
259
|
-
new.tap do |pc|
|
|
260
|
-
pc.instance_variable_set :@grpc, grpc.dup
|
|
261
|
-
end
|
|
262
|
-
end
|
|
263
|
-
end
|
|
264
|
-
end
|
|
265
|
-
end
|
|
266
|
-
end
|
|
267
|
-
end
|
|
268
|
-
end
|