google-cloud-iot-v1 0.9.2 → 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (36) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +3 -143
  3. data/lib/google/cloud/iot/v1/version.rb +3 -8
  4. metadata +15 -203
  5. data/.yardopts +0 -12
  6. data/AUTHENTICATION.md +0 -122
  7. data/lib/google/cloud/iot/v1/device_manager/client.rb +0 -2316
  8. data/lib/google/cloud/iot/v1/device_manager/credentials.rb +0 -52
  9. data/lib/google/cloud/iot/v1/device_manager/paths.rb +0 -90
  10. data/lib/google/cloud/iot/v1/device_manager/rest/client.rb +0 -2157
  11. data/lib/google/cloud/iot/v1/device_manager/rest/service_stub.rb +0 -1293
  12. data/lib/google/cloud/iot/v1/device_manager/rest.rb +0 -52
  13. data/lib/google/cloud/iot/v1/device_manager.rb +0 -55
  14. data/lib/google/cloud/iot/v1/device_manager_pb.rb +0 -77
  15. data/lib/google/cloud/iot/v1/device_manager_services_pb.rb +0 -102
  16. data/lib/google/cloud/iot/v1/resources_pb.rb +0 -68
  17. data/lib/google/cloud/iot/v1/rest.rb +0 -37
  18. data/lib/google/cloud/iot/v1.rb +0 -45
  19. data/lib/google-cloud-iot-v1.rb +0 -21
  20. data/proto_docs/README.md +0 -4
  21. data/proto_docs/google/api/client.rb +0 -395
  22. data/proto_docs/google/api/field_behavior.rb +0 -85
  23. data/proto_docs/google/api/launch_stage.rb +0 -71
  24. data/proto_docs/google/api/resource.rb +0 -222
  25. data/proto_docs/google/cloud/iot/v1/device_manager.rb +0 -399
  26. data/proto_docs/google/cloud/iot/v1/resources.rb +0 -517
  27. data/proto_docs/google/iam/v1/iam_policy.rb +0 -87
  28. data/proto_docs/google/iam/v1/options.rb +0 -50
  29. data/proto_docs/google/iam/v1/policy.rb +0 -426
  30. data/proto_docs/google/protobuf/any.rb +0 -145
  31. data/proto_docs/google/protobuf/duration.rb +0 -98
  32. data/proto_docs/google/protobuf/empty.rb +0 -34
  33. data/proto_docs/google/protobuf/field_mask.rb +0 -229
  34. data/proto_docs/google/protobuf/timestamp.rb +0 -127
  35. data/proto_docs/google/rpc/status.rb +0 -48
  36. data/proto_docs/google/type/expr.rb +0 -75
@@ -1,426 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- # Copyright 2020 Google LLC
4
- #
5
- # Licensed under the Apache License, Version 2.0 (the "License");
6
- # you may not use this file except in compliance with the License.
7
- # You may obtain a copy of the License at
8
- #
9
- # https://www.apache.org/licenses/LICENSE-2.0
10
- #
11
- # Unless required by applicable law or agreed to in writing, software
12
- # distributed under the License is distributed on an "AS IS" BASIS,
13
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
- # See the License for the specific language governing permissions and
15
- # limitations under the License.
16
-
17
- # Auto-generated by gapic-generator-ruby. DO NOT EDIT!
18
-
19
-
20
- module Google
21
- module Iam
22
- module V1
23
- # An Identity and Access Management (IAM) policy, which specifies access
24
- # controls for Google Cloud resources.
25
- #
26
- #
27
- # A `Policy` is a collection of `bindings`. A `binding` binds one or more
28
- # `members`, or principals, to a single `role`. Principals can be user
29
- # accounts, service accounts, Google groups, and domains (such as G Suite). A
30
- # `role` is a named list of permissions; each `role` can be an IAM predefined
31
- # role or a user-created custom role.
32
- #
33
- # For some types of Google Cloud resources, a `binding` can also specify a
34
- # `condition`, which is a logical expression that allows access to a resource
35
- # only if the expression evaluates to `true`. A condition can add constraints
36
- # based on attributes of the request, the resource, or both. To learn which
37
- # resources support conditions in their IAM policies, see the
38
- # [IAM
39
- # documentation](https://cloud.google.com/iam/help/conditions/resource-policies).
40
- #
41
- # **JSON example:**
42
- #
43
- # ```
44
- # {
45
- # "bindings": [
46
- # {
47
- # "role": "roles/resourcemanager.organizationAdmin",
48
- # "members": [
49
- # "user:mike@example.com",
50
- # "group:admins@example.com",
51
- # "domain:google.com",
52
- # "serviceAccount:my-project-id@appspot.gserviceaccount.com"
53
- # ]
54
- # },
55
- # {
56
- # "role": "roles/resourcemanager.organizationViewer",
57
- # "members": [
58
- # "user:eve@example.com"
59
- # ],
60
- # "condition": {
61
- # "title": "expirable access",
62
- # "description": "Does not grant access after Sep 2020",
63
- # "expression": "request.time <
64
- # timestamp('2020-10-01T00:00:00.000Z')",
65
- # }
66
- # }
67
- # ],
68
- # "etag": "BwWWja0YfJA=",
69
- # "version": 3
70
- # }
71
- # ```
72
- #
73
- # **YAML example:**
74
- #
75
- # ```
76
- # bindings:
77
- # - members:
78
- # - user:mike@example.com
79
- # - group:admins@example.com
80
- # - domain:google.com
81
- # - serviceAccount:my-project-id@appspot.gserviceaccount.com
82
- # role: roles/resourcemanager.organizationAdmin
83
- # - members:
84
- # - user:eve@example.com
85
- # role: roles/resourcemanager.organizationViewer
86
- # condition:
87
- # title: expirable access
88
- # description: Does not grant access after Sep 2020
89
- # expression: request.time < timestamp('2020-10-01T00:00:00.000Z')
90
- # etag: BwWWja0YfJA=
91
- # version: 3
92
- # ```
93
- #
94
- # For a description of IAM and its features, see the
95
- # [IAM documentation](https://cloud.google.com/iam/docs/).
96
- # @!attribute [rw] version
97
- # @return [::Integer]
98
- # Specifies the format of the policy.
99
- #
100
- # Valid values are `0`, `1`, and `3`. Requests that specify an invalid value
101
- # are rejected.
102
- #
103
- # Any operation that affects conditional role bindings must specify version
104
- # `3`. This requirement applies to the following operations:
105
- #
106
- # * Getting a policy that includes a conditional role binding
107
- # * Adding a conditional role binding to a policy
108
- # * Changing a conditional role binding in a policy
109
- # * Removing any role binding, with or without a condition, from a policy
110
- # that includes conditions
111
- #
112
- # **Important:** If you use IAM Conditions, you must include the `etag` field
113
- # whenever you call `setIamPolicy`. If you omit this field, then IAM allows
114
- # you to overwrite a version `3` policy with a version `1` policy, and all of
115
- # the conditions in the version `3` policy are lost.
116
- #
117
- # If a policy does not include any conditions, operations on that policy may
118
- # specify any valid version or leave the field unset.
119
- #
120
- # To learn which resources support conditions in their IAM policies, see the
121
- # [IAM
122
- # documentation](https://cloud.google.com/iam/help/conditions/resource-policies).
123
- # @!attribute [rw] bindings
124
- # @return [::Array<::Google::Iam::V1::Binding>]
125
- # Associates a list of `members`, or principals, with a `role`. Optionally,
126
- # may specify a `condition` that determines how and when the `bindings` are
127
- # applied. Each of the `bindings` must contain at least one principal.
128
- #
129
- # The `bindings` in a `Policy` can refer to up to 1,500 principals; up to 250
130
- # of these principals can be Google groups. Each occurrence of a principal
131
- # counts towards these limits. For example, if the `bindings` grant 50
132
- # different roles to `user:alice@example.com`, and not to any other
133
- # principal, then you can add another 1,450 principals to the `bindings` in
134
- # the `Policy`.
135
- # @!attribute [rw] audit_configs
136
- # @return [::Array<::Google::Iam::V1::AuditConfig>]
137
- # Specifies cloud audit logging configuration for this policy.
138
- # @!attribute [rw] etag
139
- # @return [::String]
140
- # `etag` is used for optimistic concurrency control as a way to help
141
- # prevent simultaneous updates of a policy from overwriting each other.
142
- # It is strongly suggested that systems make use of the `etag` in the
143
- # read-modify-write cycle to perform policy updates in order to avoid race
144
- # conditions: An `etag` is returned in the response to `getIamPolicy`, and
145
- # systems are expected to put that etag in the request to `setIamPolicy` to
146
- # ensure that their change will be applied to the same version of the policy.
147
- #
148
- # **Important:** If you use IAM Conditions, you must include the `etag` field
149
- # whenever you call `setIamPolicy`. If you omit this field, then IAM allows
150
- # you to overwrite a version `3` policy with a version `1` policy, and all of
151
- # the conditions in the version `3` policy are lost.
152
- class Policy
153
- include ::Google::Protobuf::MessageExts
154
- extend ::Google::Protobuf::MessageExts::ClassMethods
155
- end
156
-
157
- # Associates `members`, or principals, with a `role`.
158
- # @!attribute [rw] role
159
- # @return [::String]
160
- # Role that is assigned to the list of `members`, or principals.
161
- # For example, `roles/viewer`, `roles/editor`, or `roles/owner`.
162
- # @!attribute [rw] members
163
- # @return [::Array<::String>]
164
- # Specifies the principals requesting access for a Google Cloud resource.
165
- # `members` can have the following values:
166
- #
167
- # * `allUsers`: A special identifier that represents anyone who is
168
- # on the internet; with or without a Google account.
169
- #
170
- # * `allAuthenticatedUsers`: A special identifier that represents anyone
171
- # who is authenticated with a Google account or a service account.
172
- #
173
- # * `user:{emailid}`: An email address that represents a specific Google
174
- # account. For example, `alice@example.com` .
175
- #
176
- #
177
- # * `serviceAccount:{emailid}`: An email address that represents a service
178
- # account. For example, `my-other-app@appspot.gserviceaccount.com`.
179
- #
180
- # * `group:{emailid}`: An email address that represents a Google group.
181
- # For example, `admins@example.com`.
182
- #
183
- # * `deleted:user:{emailid}?uid={uniqueid}`: An email address (plus unique
184
- # identifier) representing a user that has been recently deleted. For
185
- # example, `alice@example.com?uid=123456789012345678901`. If the user is
186
- # recovered, this value reverts to `user:{emailid}` and the recovered user
187
- # retains the role in the binding.
188
- #
189
- # * `deleted:serviceAccount:{emailid}?uid={uniqueid}`: An email address (plus
190
- # unique identifier) representing a service account that has been recently
191
- # deleted. For example,
192
- # `my-other-app@appspot.gserviceaccount.com?uid=123456789012345678901`.
193
- # If the service account is undeleted, this value reverts to
194
- # `serviceAccount:{emailid}` and the undeleted service account retains the
195
- # role in the binding.
196
- #
197
- # * `deleted:group:{emailid}?uid={uniqueid}`: An email address (plus unique
198
- # identifier) representing a Google group that has been recently
199
- # deleted. For example, `admins@example.com?uid=123456789012345678901`. If
200
- # the group is recovered, this value reverts to `group:{emailid}` and the
201
- # recovered group retains the role in the binding.
202
- #
203
- #
204
- # * `domain:{domain}`: The G Suite domain (primary) that represents all the
205
- # users of that domain. For example, `google.com` or `example.com`.
206
- # @!attribute [rw] condition
207
- # @return [::Google::Type::Expr]
208
- # The condition that is associated with this binding.
209
- #
210
- # If the condition evaluates to `true`, then this binding applies to the
211
- # current request.
212
- #
213
- # If the condition evaluates to `false`, then this binding does not apply to
214
- # the current request. However, a different role binding might grant the same
215
- # role to one or more of the principals in this binding.
216
- #
217
- # To learn which resources support conditions in their IAM policies, see the
218
- # [IAM
219
- # documentation](https://cloud.google.com/iam/help/conditions/resource-policies).
220
- class Binding
221
- include ::Google::Protobuf::MessageExts
222
- extend ::Google::Protobuf::MessageExts::ClassMethods
223
- end
224
-
225
- # Specifies the audit configuration for a service.
226
- # The configuration determines which permission types are logged, and what
227
- # identities, if any, are exempted from logging.
228
- # An AuditConfig must have one or more AuditLogConfigs.
229
- #
230
- # If there are AuditConfigs for both `allServices` and a specific service,
231
- # the union of the two AuditConfigs is used for that service: the log_types
232
- # specified in each AuditConfig are enabled, and the exempted_members in each
233
- # AuditLogConfig are exempted.
234
- #
235
- # Example Policy with multiple AuditConfigs:
236
- #
237
- # {
238
- # "audit_configs": [
239
- # {
240
- # "service": "allServices",
241
- # "audit_log_configs": [
242
- # {
243
- # "log_type": "DATA_READ",
244
- # "exempted_members": [
245
- # "user:jose@example.com"
246
- # ]
247
- # },
248
- # {
249
- # "log_type": "DATA_WRITE"
250
- # },
251
- # {
252
- # "log_type": "ADMIN_READ"
253
- # }
254
- # ]
255
- # },
256
- # {
257
- # "service": "sampleservice.googleapis.com",
258
- # "audit_log_configs": [
259
- # {
260
- # "log_type": "DATA_READ"
261
- # },
262
- # {
263
- # "log_type": "DATA_WRITE",
264
- # "exempted_members": [
265
- # "user:aliya@example.com"
266
- # ]
267
- # }
268
- # ]
269
- # }
270
- # ]
271
- # }
272
- #
273
- # For sampleservice, this policy enables DATA_READ, DATA_WRITE and ADMIN_READ
274
- # logging. It also exempts `jose@example.com` from DATA_READ logging, and
275
- # `aliya@example.com` from DATA_WRITE logging.
276
- # @!attribute [rw] service
277
- # @return [::String]
278
- # Specifies a service that will be enabled for audit logging.
279
- # For example, `storage.googleapis.com`, `cloudsql.googleapis.com`.
280
- # `allServices` is a special value that covers all services.
281
- # @!attribute [rw] audit_log_configs
282
- # @return [::Array<::Google::Iam::V1::AuditLogConfig>]
283
- # The configuration for logging of each type of permission.
284
- class AuditConfig
285
- include ::Google::Protobuf::MessageExts
286
- extend ::Google::Protobuf::MessageExts::ClassMethods
287
- end
288
-
289
- # Provides the configuration for logging a type of permissions.
290
- # Example:
291
- #
292
- # {
293
- # "audit_log_configs": [
294
- # {
295
- # "log_type": "DATA_READ",
296
- # "exempted_members": [
297
- # "user:jose@example.com"
298
- # ]
299
- # },
300
- # {
301
- # "log_type": "DATA_WRITE"
302
- # }
303
- # ]
304
- # }
305
- #
306
- # This enables 'DATA_READ' and 'DATA_WRITE' logging, while exempting
307
- # jose@example.com from DATA_READ logging.
308
- # @!attribute [rw] log_type
309
- # @return [::Google::Iam::V1::AuditLogConfig::LogType]
310
- # The log type that this config enables.
311
- # @!attribute [rw] exempted_members
312
- # @return [::Array<::String>]
313
- # Specifies the identities that do not cause logging for this type of
314
- # permission.
315
- # Follows the same format of
316
- # {::Google::Iam::V1::Binding#members Binding.members}.
317
- class AuditLogConfig
318
- include ::Google::Protobuf::MessageExts
319
- extend ::Google::Protobuf::MessageExts::ClassMethods
320
-
321
- # The list of valid permission types for which logging can be configured.
322
- # Admin writes are always logged, and are not configurable.
323
- module LogType
324
- # Default case. Should never be this.
325
- LOG_TYPE_UNSPECIFIED = 0
326
-
327
- # Admin reads. Example: CloudIAM getIamPolicy
328
- ADMIN_READ = 1
329
-
330
- # Data writes. Example: CloudSQL Users create
331
- DATA_WRITE = 2
332
-
333
- # Data reads. Example: CloudSQL Users list
334
- DATA_READ = 3
335
- end
336
- end
337
-
338
- # The difference delta between two policies.
339
- # @!attribute [rw] binding_deltas
340
- # @return [::Array<::Google::Iam::V1::BindingDelta>]
341
- # The delta for Bindings between two policies.
342
- # @!attribute [rw] audit_config_deltas
343
- # @return [::Array<::Google::Iam::V1::AuditConfigDelta>]
344
- # The delta for AuditConfigs between two policies.
345
- class PolicyDelta
346
- include ::Google::Protobuf::MessageExts
347
- extend ::Google::Protobuf::MessageExts::ClassMethods
348
- end
349
-
350
- # One delta entry for Binding. Each individual change (only one member in each
351
- # entry) to a binding will be a separate entry.
352
- # @!attribute [rw] action
353
- # @return [::Google::Iam::V1::BindingDelta::Action]
354
- # The action that was performed on a Binding.
355
- # Required
356
- # @!attribute [rw] role
357
- # @return [::String]
358
- # Role that is assigned to `members`.
359
- # For example, `roles/viewer`, `roles/editor`, or `roles/owner`.
360
- # Required
361
- # @!attribute [rw] member
362
- # @return [::String]
363
- # A single identity requesting access for a Google Cloud resource.
364
- # Follows the same format of Binding.members.
365
- # Required
366
- # @!attribute [rw] condition
367
- # @return [::Google::Type::Expr]
368
- # The condition that is associated with this binding.
369
- class BindingDelta
370
- include ::Google::Protobuf::MessageExts
371
- extend ::Google::Protobuf::MessageExts::ClassMethods
372
-
373
- # The type of action performed on a Binding in a policy.
374
- module Action
375
- # Unspecified.
376
- ACTION_UNSPECIFIED = 0
377
-
378
- # Addition of a Binding.
379
- ADD = 1
380
-
381
- # Removal of a Binding.
382
- REMOVE = 2
383
- end
384
- end
385
-
386
- # One delta entry for AuditConfig. Each individual change (only one
387
- # exempted_member in each entry) to a AuditConfig will be a separate entry.
388
- # @!attribute [rw] action
389
- # @return [::Google::Iam::V1::AuditConfigDelta::Action]
390
- # The action that was performed on an audit configuration in a policy.
391
- # Required
392
- # @!attribute [rw] service
393
- # @return [::String]
394
- # Specifies a service that was configured for Cloud Audit Logging.
395
- # For example, `storage.googleapis.com`, `cloudsql.googleapis.com`.
396
- # `allServices` is a special value that covers all services.
397
- # Required
398
- # @!attribute [rw] exempted_member
399
- # @return [::String]
400
- # A single identity that is exempted from "data access" audit
401
- # logging for the `service` specified above.
402
- # Follows the same format of Binding.members.
403
- # @!attribute [rw] log_type
404
- # @return [::String]
405
- # Specifies the log_type that was be enabled. ADMIN_ACTIVITY is always
406
- # enabled, and cannot be configured.
407
- # Required
408
- class AuditConfigDelta
409
- include ::Google::Protobuf::MessageExts
410
- extend ::Google::Protobuf::MessageExts::ClassMethods
411
-
412
- # The type of action performed on an audit configuration in a policy.
413
- module Action
414
- # Unspecified.
415
- ACTION_UNSPECIFIED = 0
416
-
417
- # Addition of an audit configuration.
418
- ADD = 1
419
-
420
- # Removal of an audit configuration.
421
- REMOVE = 2
422
- end
423
- end
424
- end
425
- end
426
- end
@@ -1,145 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- # Copyright 2020 Google LLC
4
- #
5
- # Licensed under the Apache License, Version 2.0 (the "License");
6
- # you may not use this file except in compliance with the License.
7
- # You may obtain a copy of the License at
8
- #
9
- # https://www.apache.org/licenses/LICENSE-2.0
10
- #
11
- # Unless required by applicable law or agreed to in writing, software
12
- # distributed under the License is distributed on an "AS IS" BASIS,
13
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
- # See the License for the specific language governing permissions and
15
- # limitations under the License.
16
-
17
- # Auto-generated by gapic-generator-ruby. DO NOT EDIT!
18
-
19
-
20
- module Google
21
- module Protobuf
22
- # `Any` contains an arbitrary serialized protocol buffer message along with a
23
- # URL that describes the type of the serialized message.
24
- #
25
- # Protobuf library provides support to pack/unpack Any values in the form
26
- # of utility functions or additional generated methods of the Any type.
27
- #
28
- # Example 1: Pack and unpack a message in C++.
29
- #
30
- # Foo foo = ...;
31
- # Any any;
32
- # any.PackFrom(foo);
33
- # ...
34
- # if (any.UnpackTo(&foo)) {
35
- # ...
36
- # }
37
- #
38
- # Example 2: Pack and unpack a message in Java.
39
- #
40
- # Foo foo = ...;
41
- # Any any = Any.pack(foo);
42
- # ...
43
- # if (any.is(Foo.class)) {
44
- # foo = any.unpack(Foo.class);
45
- # }
46
- # // or ...
47
- # if (any.isSameTypeAs(Foo.getDefaultInstance())) {
48
- # foo = any.unpack(Foo.getDefaultInstance());
49
- # }
50
- #
51
- # Example 3: Pack and unpack a message in Python.
52
- #
53
- # foo = Foo(...)
54
- # any = Any()
55
- # any.Pack(foo)
56
- # ...
57
- # if any.Is(Foo.DESCRIPTOR):
58
- # any.Unpack(foo)
59
- # ...
60
- #
61
- # Example 4: Pack and unpack a message in Go
62
- #
63
- # foo := &pb.Foo{...}
64
- # any, err := anypb.New(foo)
65
- # if err != nil {
66
- # ...
67
- # }
68
- # ...
69
- # foo := &pb.Foo{}
70
- # if err := any.UnmarshalTo(foo); err != nil {
71
- # ...
72
- # }
73
- #
74
- # The pack methods provided by protobuf library will by default use
75
- # 'type.googleapis.com/full.type.name' as the type URL and the unpack
76
- # methods only use the fully qualified type name after the last '/'
77
- # in the type URL, for example "foo.bar.com/x/y.z" will yield type
78
- # name "y.z".
79
- #
80
- # JSON
81
- # ====
82
- # The JSON representation of an `Any` value uses the regular
83
- # representation of the deserialized, embedded message, with an
84
- # additional field `@type` which contains the type URL. Example:
85
- #
86
- # package google.profile;
87
- # message Person {
88
- # string first_name = 1;
89
- # string last_name = 2;
90
- # }
91
- #
92
- # {
93
- # "@type": "type.googleapis.com/google.profile.Person",
94
- # "firstName": <string>,
95
- # "lastName": <string>
96
- # }
97
- #
98
- # If the embedded message type is well-known and has a custom JSON
99
- # representation, that representation will be embedded adding a field
100
- # `value` which holds the custom JSON in addition to the `@type`
101
- # field. Example (for message [google.protobuf.Duration][]):
102
- #
103
- # {
104
- # "@type": "type.googleapis.com/google.protobuf.Duration",
105
- # "value": "1.212s"
106
- # }
107
- # @!attribute [rw] type_url
108
- # @return [::String]
109
- # A URL/resource name that uniquely identifies the type of the serialized
110
- # protocol buffer message. This string must contain at least
111
- # one "/" character. The last segment of the URL's path must represent
112
- # the fully qualified name of the type (as in
113
- # `path/google.protobuf.Duration`). The name should be in a canonical form
114
- # (e.g., leading "." is not accepted).
115
- #
116
- # In practice, teams usually precompile into the binary all types that they
117
- # expect it to use in the context of Any. However, for URLs which use the
118
- # scheme `http`, `https`, or no scheme, one can optionally set up a type
119
- # server that maps type URLs to message definitions as follows:
120
- #
121
- # * If no scheme is provided, `https` is assumed.
122
- # * An HTTP GET on the URL must yield a [google.protobuf.Type][]
123
- # value in binary format, or produce an error.
124
- # * Applications are allowed to cache lookup results based on the
125
- # URL, or have them precompiled into a binary to avoid any
126
- # lookup. Therefore, binary compatibility needs to be preserved
127
- # on changes to types. (Use versioned type names to manage
128
- # breaking changes.)
129
- #
130
- # Note: this functionality is not currently available in the official
131
- # protobuf release, and it is not used for type URLs beginning with
132
- # type.googleapis.com. As of May 2023, there are no widely used type server
133
- # implementations and no plans to implement one.
134
- #
135
- # Schemes other than `http`, `https` (or the empty scheme) might be
136
- # used with implementation specific semantics.
137
- # @!attribute [rw] value
138
- # @return [::String]
139
- # Must be a valid serialized protocol buffer of the above specified type.
140
- class Any
141
- include ::Google::Protobuf::MessageExts
142
- extend ::Google::Protobuf::MessageExts::ClassMethods
143
- end
144
- end
145
- end
@@ -1,98 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- # Copyright 2022 Google LLC
4
- #
5
- # Licensed under the Apache License, Version 2.0 (the "License");
6
- # you may not use this file except in compliance with the License.
7
- # You may obtain a copy of the License at
8
- #
9
- # https://www.apache.org/licenses/LICENSE-2.0
10
- #
11
- # Unless required by applicable law or agreed to in writing, software
12
- # distributed under the License is distributed on an "AS IS" BASIS,
13
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
- # See the License for the specific language governing permissions and
15
- # limitations under the License.
16
-
17
- # Auto-generated by gapic-generator-ruby. DO NOT EDIT!
18
-
19
-
20
- module Google
21
- module Protobuf
22
- # A Duration represents a signed, fixed-length span of time represented
23
- # as a count of seconds and fractions of seconds at nanosecond
24
- # resolution. It is independent of any calendar and concepts like "day"
25
- # or "month". It is related to Timestamp in that the difference between
26
- # two Timestamp values is a Duration and it can be added or subtracted
27
- # from a Timestamp. Range is approximately +-10,000 years.
28
- #
29
- # # Examples
30
- #
31
- # Example 1: Compute Duration from two Timestamps in pseudo code.
32
- #
33
- # Timestamp start = ...;
34
- # Timestamp end = ...;
35
- # Duration duration = ...;
36
- #
37
- # duration.seconds = end.seconds - start.seconds;
38
- # duration.nanos = end.nanos - start.nanos;
39
- #
40
- # if (duration.seconds < 0 && duration.nanos > 0) {
41
- # duration.seconds += 1;
42
- # duration.nanos -= 1000000000;
43
- # } else if (duration.seconds > 0 && duration.nanos < 0) {
44
- # duration.seconds -= 1;
45
- # duration.nanos += 1000000000;
46
- # }
47
- #
48
- # Example 2: Compute Timestamp from Timestamp + Duration in pseudo code.
49
- #
50
- # Timestamp start = ...;
51
- # Duration duration = ...;
52
- # Timestamp end = ...;
53
- #
54
- # end.seconds = start.seconds + duration.seconds;
55
- # end.nanos = start.nanos + duration.nanos;
56
- #
57
- # if (end.nanos < 0) {
58
- # end.seconds -= 1;
59
- # end.nanos += 1000000000;
60
- # } else if (end.nanos >= 1000000000) {
61
- # end.seconds += 1;
62
- # end.nanos -= 1000000000;
63
- # }
64
- #
65
- # Example 3: Compute Duration from datetime.timedelta in Python.
66
- #
67
- # td = datetime.timedelta(days=3, minutes=10)
68
- # duration = Duration()
69
- # duration.FromTimedelta(td)
70
- #
71
- # # JSON Mapping
72
- #
73
- # In JSON format, the Duration type is encoded as a string rather than an
74
- # object, where the string ends in the suffix "s" (indicating seconds) and
75
- # is preceded by the number of seconds, with nanoseconds expressed as
76
- # fractional seconds. For example, 3 seconds with 0 nanoseconds should be
77
- # encoded in JSON format as "3s", while 3 seconds and 1 nanosecond should
78
- # be expressed in JSON format as "3.000000001s", and 3 seconds and 1
79
- # microsecond should be expressed in JSON format as "3.000001s".
80
- # @!attribute [rw] seconds
81
- # @return [::Integer]
82
- # Signed seconds of the span of time. Must be from -315,576,000,000
83
- # to +315,576,000,000 inclusive. Note: these bounds are computed from:
84
- # 60 sec/min * 60 min/hr * 24 hr/day * 365.25 days/year * 10000 years
85
- # @!attribute [rw] nanos
86
- # @return [::Integer]
87
- # Signed fractions of a second at nanosecond resolution of the span
88
- # of time. Durations less than one second are represented with a 0
89
- # `seconds` field and a positive or negative `nanos` field. For durations
90
- # of one second or more, a non-zero value for the `nanos` field must be
91
- # of the same sign as the `seconds` field. Must be from -999,999,999
92
- # to +999,999,999 inclusive.
93
- class Duration
94
- include ::Google::Protobuf::MessageExts
95
- extend ::Google::Protobuf::MessageExts::ClassMethods
96
- end
97
- end
98
- end