google-cloud-tasks-v2beta3 0.3.1 → 0.6.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -6,6 +6,10 @@ require 'google/protobuf'
6
6
  require 'google/api/annotations_pb'
7
7
  Google::Protobuf::DescriptorPool.generated_pool.build do
8
8
  add_file("google/cloud/tasks/v2beta3/target.proto", :syntax => :proto3) do
9
+ add_message "google.cloud.tasks.v2beta3.PullMessage" do
10
+ optional :payload, :bytes, 1
11
+ optional :tag, :string, 2
12
+ end
9
13
  add_message "google.cloud.tasks.v2beta3.HttpRequest" do
10
14
  optional :url, :string, 1
11
15
  optional :http_method, :enum, 2, "google.cloud.tasks.v2beta3.HttpMethod"
@@ -57,6 +61,7 @@ module Google
57
61
  module Cloud
58
62
  module Tasks
59
63
  module V2beta3
64
+ PullMessage = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("google.cloud.tasks.v2beta3.PullMessage").msgclass
60
65
  HttpRequest = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("google.cloud.tasks.v2beta3.HttpRequest").msgclass
61
66
  AppEngineHttpQueue = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("google.cloud.tasks.v2beta3.AppEngineHttpQueue").msgclass
62
67
  AppEngineHttpRequest = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("google.cloud.tasks.v2beta3.AppEngineHttpRequest").msgclass
@@ -24,6 +24,7 @@ Google::Protobuf::DescriptorPool.generated_pool.build do
24
24
  oneof :payload_type do
25
25
  optional :app_engine_http_request, :message, 3, "google.cloud.tasks.v2beta3.AppEngineHttpRequest"
26
26
  optional :http_request, :message, 11, "google.cloud.tasks.v2beta3.HttpRequest"
27
+ optional :pull_message, :message, 13, "google.cloud.tasks.v2beta3.PullMessage"
27
28
  end
28
29
  end
29
30
  add_enum "google.cloud.tasks.v2beta3.Task.View" do
@@ -21,7 +21,7 @@ module Google
21
21
  module Cloud
22
22
  module Tasks
23
23
  module V2beta3
24
- VERSION = "0.3.1"
24
+ VERSION = "0.6.0"
25
25
  end
26
26
  end
27
27
  end
@@ -54,6 +54,12 @@ module Google
54
54
  # This indicates that the field may be set once in a request to create a
55
55
  # resource, but may not be changed thereafter.
56
56
  IMMUTABLE = 5
57
+
58
+ # Denotes that a (repeated) field is an unordered list.
59
+ # This indicates that the service may provide the elements of the list
60
+ # in any arbitrary order, rather than the order the user originally
61
+ # provided. Additionally, the list's order may or may not be stable.
62
+ UNORDERED_LIST = 6
57
63
  end
58
64
  end
59
65
  end
@@ -43,12 +43,12 @@ module Google
43
43
  #
44
44
  # The ResourceDescriptor Yaml config will look like:
45
45
  #
46
- # resources:
47
- # - type: "pubsub.googleapis.com/Topic"
48
- # name_descriptor:
49
- # - pattern: "projects/\\{project}/topics/\\{topic}"
50
- # parent_type: "cloudresourcemanager.googleapis.com/Project"
51
- # parent_name_extractor: "projects/\\{project}"
46
+ # resources:
47
+ # - type: "pubsub.googleapis.com/Topic"
48
+ # name_descriptor:
49
+ # - pattern: "projects/{project}/topics/{topic}"
50
+ # parent_type: "cloudresourcemanager.googleapis.com/Project"
51
+ # parent_name_extractor: "projects/{project}"
52
52
  #
53
53
  # Sometimes, resources have multiple patterns, typically because they can
54
54
  # live under multiple parents.
@@ -183,15 +183,24 @@ module Google
183
183
  # }
184
184
  # @!attribute [rw] plural
185
185
  # @return [::String]
186
- # The plural name used in the resource name, such as 'projects' for
187
- # the name of 'projects/\\{project}'. It is the same concept of the `plural`
188
- # field in k8s CRD spec
186
+ # The plural name used in the resource name and permission names, such as
187
+ # 'projects' for the resource name of 'projects/\\{project}' and the permission
188
+ # name of 'cloudresourcemanager.googleapis.com/projects.get'. It is the same
189
+ # concept of the `plural` field in k8s CRD spec
189
190
  # https://kubernetes.io/docs/tasks/access-kubernetes-api/custom-resources/custom-resource-definitions/
191
+ #
192
+ # Note: The plural form is required even for singleton resources. See
193
+ # https://aip.dev/156
190
194
  # @!attribute [rw] singular
191
195
  # @return [::String]
192
196
  # The same concept of the `singular` field in k8s CRD spec
193
197
  # https://kubernetes.io/docs/tasks/access-kubernetes-api/custom-resources/custom-resource-definitions/
194
198
  # Such as "project" for the `resourcemanager.googleapis.com/Project` type.
199
+ # @!attribute [rw] style
200
+ # @return [::Array<::Google::Api::ResourceDescriptor::Style>]
201
+ # Style flag(s) for this resource.
202
+ # These indicate that a resource is expected to conform to a given
203
+ # style. See the specific style flags for additional information.
195
204
  class ResourceDescriptor
196
205
  include ::Google::Protobuf::MessageExts
197
206
  extend ::Google::Protobuf::MessageExts::ClassMethods
@@ -211,6 +220,22 @@ module Google
211
220
  # that from being necessary once there are multiple patterns.)
212
221
  FUTURE_MULTI_PATTERN = 2
213
222
  end
223
+
224
+ # A flag representing a specific style that a resource claims to conform to.
225
+ module Style
226
+ # The unspecified value. Do not use.
227
+ STYLE_UNSPECIFIED = 0
228
+
229
+ # This resource is intended to be "declarative-friendly".
230
+ #
231
+ # Declarative-friendly resources must be more strictly consistent, and
232
+ # setting this to true communicates to tools that this resource should
233
+ # adhere to declarative-friendly expectations.
234
+ #
235
+ # Note: This is used by the API linter (linter.aip.dev) to enable
236
+ # additional checks.
237
+ DECLARATIVE_FRIENDLY = 1
238
+ end
214
239
  end
215
240
 
216
241
  # Defines a proto annotation that describes a string field that refers to
@@ -226,6 +251,17 @@ module Google
226
251
  # type: "pubsub.googleapis.com/Topic"
227
252
  # }];
228
253
  # }
254
+ #
255
+ # Occasionally, a field may reference an arbitrary resource. In this case,
256
+ # APIs use the special value * in their resource reference.
257
+ #
258
+ # Example:
259
+ #
260
+ # message GetIamPolicyRequest {
261
+ # string resource = 2 [(google.api.resource_reference) = {
262
+ # type: "*"
263
+ # }];
264
+ # }
229
265
  # @!attribute [rw] child_type
230
266
  # @return [::String]
231
267
  # The resource type of a child collection that the annotated field
@@ -234,11 +270,11 @@ module Google
234
270
  #
235
271
  # Example:
236
272
  #
237
- # message ListLogEntriesRequest {
238
- # string parent = 1 [(google.api.resource_reference) = {
239
- # child_type: "logging.googleapis.com/LogEntry"
240
- # };
241
- # }
273
+ # message ListLogEntriesRequest {
274
+ # string parent = 1 [(google.api.resource_reference) = {
275
+ # child_type: "logging.googleapis.com/LogEntry"
276
+ # };
277
+ # }
242
278
  class ResourceReference
243
279
  include ::Google::Protobuf::MessageExts
244
280
  extend ::Google::Protobuf::MessageExts::ClassMethods
@@ -58,6 +58,12 @@ module Google
58
58
  # from the previous call to {::Google::Cloud::Tasks::V2beta3::CloudTasks::Client#list_queues ListQueues}
59
59
  # method. It is an error to switch the value of the
60
60
  # {::Google::Cloud::Tasks::V2beta3::ListQueuesRequest#filter filter} while iterating through pages.
61
+ # @!attribute [rw] read_mask
62
+ # @return [::Google::Protobuf::FieldMask]
63
+ # Optional. Read mask is used for a more granular control over what the API returns.
64
+ # If the mask is not present all fields will be returned except
65
+ # [Queue.stats]. [Queue.stats] will be returned only if it was explicitly
66
+ # specified in the mask.
61
67
  class ListQueuesRequest
62
68
  include ::Google::Protobuf::MessageExts
63
69
  extend ::Google::Protobuf::MessageExts::ClassMethods
@@ -88,6 +94,12 @@ module Google
88
94
  # @return [::String]
89
95
  # Required. The resource name of the queue. For example:
90
96
  # `projects/PROJECT_ID/locations/LOCATION_ID/queues/QUEUE_ID`
97
+ # @!attribute [rw] read_mask
98
+ # @return [::Google::Protobuf::FieldMask]
99
+ # Optional. Read mask is used for a more granular control over what the API returns.
100
+ # If the mask is not present all fields will be returned except
101
+ # [Queue.stats]. [Queue.stats] will be returned only if it was explicitly
102
+ # specified in the mask.
91
103
  class GetQueueRequest
92
104
  include ::Google::Protobuf::MessageExts
93
105
  extend ::Google::Protobuf::MessageExts::ClassMethods
@@ -110,6 +110,32 @@ module Google
110
110
  #
111
111
  # Purge time will be truncated to the nearest microsecond. Purge
112
112
  # time will be unset if the queue has never been purged.
113
+ # @!attribute [rw] task_ttl
114
+ # @return [::Google::Protobuf::Duration]
115
+ # The maximum amount of time that a task will be retained in
116
+ # this queue.
117
+ #
118
+ # Queues created by Cloud Tasks have a default `task_ttl` of 31 days.
119
+ # After a task has lived for `task_ttl`, the task will be deleted
120
+ # regardless of whether it was dispatched or not.
121
+ #
122
+ # The `task_ttl` for queues created via queue.yaml/xml is equal to the
123
+ # maximum duration because there is a
124
+ # [storage quota](https://cloud.google.com/appengine/quotas#Task_Queue) for
125
+ # these queues. To view the maximum valid duration, see the documentation for
126
+ # {::Google::Protobuf::Duration Duration}.
127
+ # @!attribute [rw] tombstone_ttl
128
+ # @return [::Google::Protobuf::Duration]
129
+ # The task tombstone time to live (TTL).
130
+ #
131
+ # After a task is deleted or executed, the task's tombstone is
132
+ # retained for the length of time specified by `tombstone_ttl`.
133
+ # The tombstone is used by task de-duplication; another task with the same
134
+ # name can't be created until the tombstone has expired. For more information
135
+ # about task de-duplication, see the documentation for
136
+ # {::Google::Cloud::Tasks::V2beta3::CreateTaskRequest#task CreateTaskRequest}.
137
+ #
138
+ # Queues created by Cloud Tasks have a default `tombstone_ttl` of 1 hour.
113
139
  # @!attribute [rw] stackdriver_logging_config
114
140
  # @return [::Google::Cloud::Tasks::V2beta3::StackdriverLoggingConfig]
115
141
  # Configuration options for writing logs to
@@ -122,6 +148,11 @@ module Google
122
148
  # `Queue.type` is an immutable property of the queue that is set at the queue
123
149
  # creation time. When left unspecified, the default value of `PUSH` is
124
150
  # selected.
151
+ # @!attribute [r] stats
152
+ # @return [::Google::Cloud::Tasks::V2beta3::QueueStats]
153
+ # Output only. The realtime, informational statistics for a queue. In order
154
+ # to receive the statistics the caller should include this field in the
155
+ # FieldMask.
125
156
  class Queue
126
157
  include ::Google::Protobuf::MessageExts
127
158
  extend ::Google::Protobuf::MessageExts::ClassMethods
@@ -199,7 +230,7 @@ module Google
199
230
  # queue.yaml/xml](https://cloud.google.com/appengine/docs/standard/python/config/queueref#rate).
200
231
  # @!attribute [rw] max_burst_size
201
232
  # @return [::Integer]
202
- # Output only. The max burst size.
233
+ # The max burst size.
203
234
  #
204
235
  # Max burst size limits how fast tasks in queue are processed when
205
236
  # many tasks are in the queue and the rate is high. This field
@@ -216,21 +247,21 @@ module Google
216
247
  # continuously refilled with new tokens based on
217
248
  # {::Google::Cloud::Tasks::V2beta3::RateLimits#max_dispatches_per_second max_dispatches_per_second}.
218
249
  #
219
- # Cloud Tasks will pick the value of `max_burst_size` based on the
220
- # value of
250
+ # The default value of `max_burst_size` is picked by Cloud Tasks
251
+ # based on the value of
221
252
  # {::Google::Cloud::Tasks::V2beta3::RateLimits#max_dispatches_per_second max_dispatches_per_second}.
222
253
  #
254
+ # The maximum value of `max_burst_size` is 500.
255
+ #
223
256
  # For App Engine queues that were created or updated using
224
257
  # `queue.yaml/xml`, `max_burst_size` is equal to
225
258
  # [bucket_size](https://cloud.google.com/appengine/docs/standard/python/config/queueref#bucket_size).
226
- # Since `max_burst_size` is output only, if
227
- # {::Google::Cloud::Tasks::V2beta3::CloudTasks::Client#update_queue UpdateQueue} is called on a queue
228
- # created by `queue.yaml/xml`, `max_burst_size` will be reset based
229
- # on the value of
230
- # {::Google::Cloud::Tasks::V2beta3::RateLimits#max_dispatches_per_second max_dispatches_per_second},
231
- # regardless of whether
232
- # {::Google::Cloud::Tasks::V2beta3::RateLimits#max_dispatches_per_second max_dispatches_per_second}
233
- # is updated.
259
+ # If
260
+ # {::Google::Cloud::Tasks::V2beta3::CloudTasks::Client#update_queue UpdateQueue} is called on a queue without
261
+ # explicitly setting a value for `max_burst_size`,
262
+ # `max_burst_size` value will get updated if
263
+ # {::Google::Cloud::Tasks::V2beta3::CloudTasks::Client#update_queue UpdateQueue} is updating
264
+ # {::Google::Cloud::Tasks::V2beta3::RateLimits#max_dispatches_per_second max_dispatches_per_second}.
234
265
  # @!attribute [rw] max_concurrent_dispatches
235
266
  # @return [::Integer]
236
267
  # The maximum number of concurrent tasks that Cloud Tasks allows
@@ -371,6 +402,37 @@ module Google
371
402
  include ::Google::Protobuf::MessageExts
372
403
  extend ::Google::Protobuf::MessageExts::ClassMethods
373
404
  end
405
+
406
+ # Statistics for a queue.
407
+ # @!attribute [r] tasks_count
408
+ # @return [::Integer]
409
+ # Output only. An estimation of the number of tasks in the queue, that is, the tasks in
410
+ # the queue that haven't been executed, the tasks in the queue which the
411
+ # queue has dispatched but has not yet received a reply for, and the failed
412
+ # tasks that the queue is retrying.
413
+ # @!attribute [r] oldest_estimated_arrival_time
414
+ # @return [::Google::Protobuf::Timestamp]
415
+ # Output only. An estimation of the nearest time in the future where a task in the queue
416
+ # is scheduled to be executed.
417
+ # @!attribute [r] executed_last_minute_count
418
+ # @return [::Integer]
419
+ # Output only. The number of tasks that the queue has dispatched and received a reply for
420
+ # during the last minute. This variable counts both successful and
421
+ # non-successful executions.
422
+ # @!attribute [r] concurrent_dispatches_count
423
+ # @return [::Integer]
424
+ # Output only. The number of requests that the queue has dispatched but has not received
425
+ # a reply for yet.
426
+ # @!attribute [r] effective_execution_rate
427
+ # @return [::Float]
428
+ # Output only. The current maximum number of tasks per second executed by the queue.
429
+ # The maximum value of this variable is controlled by the RateLimits of the
430
+ # Queue. However, this value could be less to avoid overloading the endpoints
431
+ # tasks in the queue are targeting.
432
+ class QueueStats
433
+ include ::Google::Protobuf::MessageExts
434
+ extend ::Google::Protobuf::MessageExts::ClassMethods
435
+ end
374
436
  end
375
437
  end
376
438
  end
@@ -21,6 +21,33 @@ module Google
21
21
  module Cloud
22
22
  module Tasks
23
23
  module V2beta3
24
+ # Pull Message.
25
+ #
26
+ # This proto can only be used for tasks in a queue which has
27
+ # {::Google::Cloud::Tasks::V2beta3::Queue#type PULL} type. It currently exists for backwards compatibility with
28
+ # the App Engine Task Queue SDK. This message type maybe returned with methods
29
+ # [list][google.cloud.tasks.v2beta3.CloudTask.ListTasks] and
30
+ # [get][google.cloud.tasks.v2beta3.CloudTask.ListTasks], when the response view
31
+ # is [FULL][google.cloud.tasks.v2beta3.Task.View.Full].
32
+ # @!attribute [rw] payload
33
+ # @return [::String]
34
+ # A data payload consumed by the worker to execute the task.
35
+ # @!attribute [rw] tag
36
+ # @return [::String]
37
+ # The tasks's tag.
38
+ #
39
+ # The tag is less than 500 characters.
40
+ #
41
+ # SDK compatibility: Although the SDK allows tags to be either
42
+ # string or
43
+ # [bytes](https://cloud.google.com/appengine/docs/standard/java/javadoc/com/google/appengine/api/taskqueue/TaskOptions.html#tag-byte:A-),
44
+ # only UTF-8 encoded tags can be used in Cloud Tasks. If a tag isn't UTF-8
45
+ # encoded, the tag will be empty when the task is returned by Cloud Tasks.
46
+ class PullMessage
47
+ include ::Google::Protobuf::MessageExts
48
+ extend ::Google::Protobuf::MessageExts::ClassMethods
49
+ end
50
+
24
51
  # HTTP request.
25
52
  #
26
53
  # The task will be pushed to the worker as an HTTP request. If the worker
@@ -54,6 +54,15 @@ module Google
54
54
  # HTTP request that is sent to the task's target.
55
55
  #
56
56
  # An HTTP task is a task that has {::Google::Cloud::Tasks::V2beta3::HttpRequest HttpRequest} set.
57
+ # @!attribute [rw] pull_message
58
+ # @return [::Google::Cloud::Tasks::V2beta3::PullMessage]
59
+ # Pull Message contained in a task in a {::Google::Cloud::Tasks::V2beta3::Queue#type PULL} queue type. This
60
+ # payload type cannot be explicitly set through Cloud Tasks API. Its
61
+ # purpose, currently is to provide backward compatibility with App Engine
62
+ # Task Queue
63
+ # [pull](https://cloud.google.com/appengine/docs/standard/java/taskqueue/pull/)
64
+ # queues to provide a way to inspect contents of pull tasks through the
65
+ # {::Google::Cloud::Tasks::V2beta3::CloudTasks::Client#get_task CloudTasks.GetTask}.
57
66
  # @!attribute [rw] schedule_time
58
67
  # @return [::Google::Protobuf::Timestamp]
59
68
  # The time when the task is scheduled to be attempted.
@@ -57,10 +57,13 @@ module Google
57
57
  # Example 4: Pack and unpack a message in Go
58
58
  #
59
59
  # foo := &pb.Foo{...}
60
- # any, err := ptypes.MarshalAny(foo)
60
+ # any, err := anypb.New(foo)
61
+ # if err != nil {
62
+ # ...
63
+ # }
61
64
  # ...
62
65
  # foo := &pb.Foo{}
63
- # if err := ptypes.UnmarshalAny(any, foo); err != nil {
66
+ # if err := any.UnmarshalTo(foo); err != nil {
64
67
  # ...
65
68
  # }
66
69
  #
@@ -70,7 +70,16 @@ module Google
70
70
  # .setNanos((int) ((millis % 1000) * 1000000)).build();
71
71
  #
72
72
  #
73
- # Example 5: Compute Timestamp from current time in Python.
73
+ # Example 5: Compute Timestamp from Java `Instant.now()`.
74
+ #
75
+ # Instant now = Instant.now();
76
+ #
77
+ # Timestamp timestamp =
78
+ # Timestamp.newBuilder().setSeconds(now.getEpochSecond())
79
+ # .setNanos(now.getNano()).build();
80
+ #
81
+ #
82
+ # Example 6: Compute Timestamp from current time in Python.
74
83
  #
75
84
  # timestamp = Timestamp()
76
85
  # timestamp.GetCurrentTime()
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: google-cloud-tasks-v2beta3
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.3.1
4
+ version: 0.6.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Google LLC
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2020-08-07 00:00:00.000000000 Z
11
+ date: 2021-03-09 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: gapic-common
@@ -64,14 +64,14 @@ dependencies:
64
64
  requirements:
65
65
  - - "~>"
66
66
  - !ruby/object:Gem::Version
67
- version: 1.24.0
67
+ version: 1.25.1
68
68
  type: :development
69
69
  prerelease: false
70
70
  version_requirements: !ruby/object:Gem::Requirement
71
71
  requirements:
72
72
  - - "~>"
73
73
  - !ruby/object:Gem::Version
74
- version: 1.24.0
74
+ version: 1.25.1
75
75
  - !ruby/object:Gem::Dependency
76
76
  name: minitest
77
77
  requirement: !ruby/object:Gem::Requirement
@@ -173,7 +173,9 @@ dependencies:
173
173
  description: Cloud Tasks is a fully managed service that allows you to manage the
174
174
  execution, dispatch and delivery of a large number of distributed tasks. You can
175
175
  asynchronously perform work outside of a user request. Your tasks can be executed
176
- on App Engine or any arbitrary HTTP endpoint.
176
+ on App Engine or any arbitrary HTTP endpoint. Note that google-cloud-tasks-v2beta3
177
+ is a version-specific client library. For most uses, we recommend installing the
178
+ main client library google-cloud-tasks instead. See the readme for more details.
177
179
  email: googleapis-packages@google.com
178
180
  executables: []
179
181
  extensions: []
@@ -224,14 +226,14 @@ required_ruby_version: !ruby/object:Gem::Requirement
224
226
  requirements:
225
227
  - - ">="
226
228
  - !ruby/object:Gem::Version
227
- version: '2.4'
229
+ version: '2.5'
228
230
  required_rubygems_version: !ruby/object:Gem::Requirement
229
231
  requirements:
230
232
  - - ">="
231
233
  - !ruby/object:Gem::Version
232
234
  version: '0'
233
235
  requirements: []
234
- rubygems_version: 3.1.3
236
+ rubygems_version: 3.2.13
235
237
  signing_key:
236
238
  specification_version: 4
237
239
  summary: API Client library for the Cloud Tasks V2beta3 API