gapic-common 0.0.1
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 +7 -0
- data/.yardopts +13 -0
- data/CHANGELOG.md +2 -0
- data/CODE_OF_CONDUCT.md +43 -0
- data/CONTRIBUTING.md +28 -0
- data/LICENSE +13 -0
- data/README.md +40 -0
- data/RELEASING.md +76 -0
- data/lib/gapic-common.rb +15 -0
- data/lib/gapic/call_options.rb +68 -0
- data/lib/gapic/call_options/retry_policy.rb +106 -0
- data/lib/gapic/common.rb +32 -0
- data/lib/gapic/common/version.rb +19 -0
- data/lib/gapic/config.rb +104 -0
- data/lib/gapic/config/method.rb +65 -0
- data/lib/gapic/grpc.rb +17 -0
- data/lib/gapic/grpc/service_stub.rb +158 -0
- data/lib/gapic/grpc/service_stub/rpc_call.rb +149 -0
- data/lib/gapic/grpc/status_details.rb +40 -0
- data/lib/gapic/headers.rb +43 -0
- data/lib/gapic/operation.rb +278 -0
- data/lib/gapic/operation/retry_policy.rb +92 -0
- data/lib/gapic/paged_enumerable.rb +260 -0
- data/lib/gapic/protobuf.rb +152 -0
- data/lib/gapic/stream_input.rb +76 -0
- metadata +261 -0
checksums.yaml
ADDED
@@ -0,0 +1,7 @@
|
|
1
|
+
---
|
2
|
+
SHA256:
|
3
|
+
metadata.gz: 9019d4ed6928276ec36fa6e06dd95a3674a30ce24635a087e0ebde6abc43cd91
|
4
|
+
data.tar.gz: abaa4c9666268d28dff68a5e2b4379d11f3f442c4fc2a8034e77d226d6f82365
|
5
|
+
SHA512:
|
6
|
+
metadata.gz: b58787f5b5b86b8b146a5c2fed6e7a23f7d7dc1498f53a1a4d75163e51f498b0ccbab88bbdd84b8a3f669f1a218ba674f419758b88e4c7f3c5405e5669f9962b
|
7
|
+
data.tar.gz: a04f15b0d04aced9ad2d9918fb6a75305dea59f05b10985618590c3d85ff211bbb88c1ab5d2a64853721685dcf6919c53c546e0b11652eb39374a9d8dd17f844
|
data/.yardopts
ADDED
data/CHANGELOG.md
ADDED
data/CODE_OF_CONDUCT.md
ADDED
@@ -0,0 +1,43 @@
|
|
1
|
+
# Contributor Code of Conduct
|
2
|
+
|
3
|
+
As contributors and maintainers of this project,
|
4
|
+
and in the interest of fostering an open and welcoming community,
|
5
|
+
we pledge to respect all people who contribute through reporting issues,
|
6
|
+
posting feature requests, updating documentation,
|
7
|
+
submitting pull requests or patches, and other activities.
|
8
|
+
|
9
|
+
We are committed to making participation in this project
|
10
|
+
a harassment-free experience for everyone,
|
11
|
+
regardless of level of experience, gender, gender identity and expression,
|
12
|
+
sexual orientation, disability, personal appearance,
|
13
|
+
body size, race, ethnicity, age, religion, or nationality.
|
14
|
+
|
15
|
+
Examples of unacceptable behavior by participants include:
|
16
|
+
|
17
|
+
* The use of sexualized language or imagery
|
18
|
+
* Personal attacks
|
19
|
+
* Trolling or insulting/derogatory comments
|
20
|
+
* Public or private harassment
|
21
|
+
* Publishing other's private information,
|
22
|
+
such as physical or electronic
|
23
|
+
addresses, without explicit permission
|
24
|
+
* Other unethical or unprofessional conduct.
|
25
|
+
|
26
|
+
Project maintainers have the right and responsibility to remove, edit, or reject
|
27
|
+
comments, commits, code, wiki edits, issues, and other contributions
|
28
|
+
that are not aligned to this Code of Conduct.
|
29
|
+
By adopting this Code of Conduct,
|
30
|
+
project maintainers commit themselves to fairly and consistently
|
31
|
+
applying these principles to every aspect of managing this project.
|
32
|
+
Project maintainers who do not follow or enforce the Code of Conduct
|
33
|
+
may be permanently removed from the project team.
|
34
|
+
|
35
|
+
This code of conduct applies both within project spaces and in public spaces
|
36
|
+
when an individual is representing the project or its community.
|
37
|
+
|
38
|
+
Instances of abusive, harassing, or otherwise unacceptable behavior
|
39
|
+
may be reported by opening an issue
|
40
|
+
or contacting one or more of the project maintainers.
|
41
|
+
|
42
|
+
This Code of Conduct is adapted from the [Contributor Covenant](http://contributor-covenant.org), version 1.2.0,
|
43
|
+
available at [http://contributor-covenant.org/version/1/2/0/](http://contributor-covenant.org/version/1/2/0/)
|
data/CONTRIBUTING.md
ADDED
@@ -0,0 +1,28 @@
|
|
1
|
+
# How to Contribute
|
2
|
+
|
3
|
+
We'd love to accept your patches and contributions to this project. There are
|
4
|
+
just a few small guidelines you need to follow.
|
5
|
+
|
6
|
+
## Contributor License Agreement
|
7
|
+
|
8
|
+
Contributions to this project must be accompanied by a Contributor License
|
9
|
+
Agreement. You (or your employer) retain the copyright to your contribution;
|
10
|
+
this simply gives us permission to use and redistribute your contributions as
|
11
|
+
part of the project. Head over to <https://cla.developers.google.com/> to see
|
12
|
+
your current agreements on file or to sign a new one.
|
13
|
+
|
14
|
+
You generally only need to submit a CLA once, so if you've already submitted one
|
15
|
+
(even if it was for a different project), you probably don't need to do it
|
16
|
+
again.
|
17
|
+
|
18
|
+
## Code reviews
|
19
|
+
|
20
|
+
All submissions, including submissions by project members, require review. We
|
21
|
+
use GitHub pull requests for this purpose. Consult
|
22
|
+
[GitHub Help](https://help.github.com/articles/about-pull-requests/) for more
|
23
|
+
information on using pull requests.
|
24
|
+
|
25
|
+
## Community Guidelines
|
26
|
+
|
27
|
+
This project follows [Google's Open Source Community
|
28
|
+
Guidelines](https://opensource.google.com/conduct/).
|
data/LICENSE
ADDED
@@ -0,0 +1,13 @@
|
|
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.
|
data/README.md
ADDED
@@ -0,0 +1,40 @@
|
|
1
|
+
Google API Extensions for Ruby
|
2
|
+
================================
|
3
|
+
|
4
|
+
Generated API Client common code (gapic-common) is a set of modules which aids
|
5
|
+
the development of APIs for clients and servers based on [gRPC][] and Google API
|
6
|
+
conventions.
|
7
|
+
|
8
|
+
Application code will rarely need to use most of the classes within this library
|
9
|
+
directly, but code generated automatically from the API definition files in
|
10
|
+
[Google APIs][] can use services such as page streaming to provide a more
|
11
|
+
convenient and idiomatic API surface to callers.
|
12
|
+
|
13
|
+
[gRPC]: http://grpc.io
|
14
|
+
[Google APIs]: https://github.com/googleapis/googleapis/
|
15
|
+
|
16
|
+
## Supported Ruby Versions
|
17
|
+
|
18
|
+
This library is supported on Ruby 2.4+.
|
19
|
+
|
20
|
+
Google provides official support for Ruby versions that are actively supported
|
21
|
+
by Ruby Core—that is, Ruby versions that are either in normal maintenance or in
|
22
|
+
security maintenance, and not end of life. Currently, this means Ruby 2.4 and
|
23
|
+
later. Older versions of Ruby _may_ still work, but are unsupported and not
|
24
|
+
recommended. See https://www.ruby-lang.org/en/downloads/branches/ for details
|
25
|
+
about the Ruby support schedule.
|
26
|
+
|
27
|
+
## Contributing
|
28
|
+
|
29
|
+
Contributions to this library are always welcome and highly encouraged.
|
30
|
+
|
31
|
+
See the [CONTRIBUTING](CONTRIBUTING.md) documentation for more information on how to get started.
|
32
|
+
|
33
|
+
## Versioning
|
34
|
+
|
35
|
+
This library is currently a **preview** with no guarantees of stability or support. Please get
|
36
|
+
involved and let us know if you find it useful and we'll work towards a stable version.
|
37
|
+
|
38
|
+
## Disclaimer
|
39
|
+
|
40
|
+
This is not an official Google product.
|
data/RELEASING.md
ADDED
@@ -0,0 +1,76 @@
|
|
1
|
+
# Releasing gapic-common
|
2
|
+
|
3
|
+
The Google Ruby GAX project uses [semantic versioning](http://semver.org). Replace the `<prev_version>` and `<version>` placeholders shown in the examples below with the appropriate numbers, e.g. `0.1.0` and `0.2.0`.
|
4
|
+
|
5
|
+
After all [pull requests](https://github.com/googleapis/gax-ruby/pulls) for a release have been merged and all [Travis builds](https://travis-ci.org/googleapis/gax-ruby) are green, you may create a release as follows:
|
6
|
+
|
7
|
+
1. If you haven't already, switch to the master branch, ensure that you have no changes, and pull from origin.
|
8
|
+
|
9
|
+
```sh
|
10
|
+
$ git checkout master
|
11
|
+
$ git status
|
12
|
+
$ git pull <remote> master --rebase
|
13
|
+
```
|
14
|
+
|
15
|
+
1. Build the gem locally. (Depending on your environment, you may need to `bundle exec` to rake commands; this will be shown.)
|
16
|
+
|
17
|
+
```sh
|
18
|
+
$ bundle exec rake build
|
19
|
+
```
|
20
|
+
|
21
|
+
1. Install the gem locally.
|
22
|
+
|
23
|
+
```sh
|
24
|
+
$ bundle exec rake install
|
25
|
+
```
|
26
|
+
|
27
|
+
1. Using IRB (not `rake console`!), manually test the gem that you installed in the previous step.
|
28
|
+
|
29
|
+
1. Update the `CHANGELOG.md`. Write bullet-point lists of the major and minor changes. You can also add examples, fixes, thank yous, and anything else helpful or relevant. See google-cloud-node [v0.18.0](https://github.com/GoogleCloudPlatform/google-cloud-node/releases/tag/v0.18.0) for an example with all the bells and whistles.
|
30
|
+
|
31
|
+
1. Edit `lib/gapic/version.rb` file, changing the value of `VERSION` to your new version number. This repo requires a PR for all changes so doing this in a branch is best.
|
32
|
+
|
33
|
+
1. Run the tests, one last time.
|
34
|
+
|
35
|
+
```sh
|
36
|
+
$ bundle update
|
37
|
+
$ bundle exec rake spec
|
38
|
+
```
|
39
|
+
|
40
|
+
1. Commit your changes. Copy and paste the significant points from your `CHANGELOG.md` edit as the description in your commit message.
|
41
|
+
|
42
|
+
```sh
|
43
|
+
$ git commit -am "Release gapic-common <version> ..."
|
44
|
+
```
|
45
|
+
|
46
|
+
1. Tag the version after all changes have been merged.
|
47
|
+
|
48
|
+
```sh
|
49
|
+
$ git tag gapic-common/v<version>
|
50
|
+
```
|
51
|
+
|
52
|
+
1. Push the tag.
|
53
|
+
|
54
|
+
```sh
|
55
|
+
$ git push <remote> gapic-common/v<version>
|
56
|
+
```
|
57
|
+
|
58
|
+
1. Wait until the [Travis build](https://travis-ci.org/googleapis/gax-ruby) has passed for the tag.
|
59
|
+
|
60
|
+
1. Push the gem to [RubyGems.org](https://rubygems.org/gems/google-cloud).
|
61
|
+
|
62
|
+
```sh
|
63
|
+
$ gem push gapic-common-<version>.gem
|
64
|
+
```
|
65
|
+
|
66
|
+
1. On the [gax-ruby releases page](https://github.com/googleapis/gax-ruby/releases), click [Draft a new release](https://github.com/googleapis/gax-ruby/releases/new). Complete the form. Include the bullet-point lists of the major and minor changes from the gem's `CHANGELOG.md`. You can also add examples, fixes, thank yous, and anything else helpful or relevant.
|
67
|
+
|
68
|
+
1. Click `Publish release`.
|
69
|
+
|
70
|
+
1. Wait until the last tag build job has successfully completed on Travis. Then push your commits to the master branch. This will trigger another [Travis](https://travis-ci.org/googleapis/gax-ruby) build on master branch.
|
71
|
+
|
72
|
+
```sh
|
73
|
+
$ git push <remote> master
|
74
|
+
```
|
75
|
+
|
76
|
+
High fives all around!
|
data/lib/gapic-common.rb
ADDED
@@ -0,0 +1,15 @@
|
|
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
|
+
require "gapic/common"
|
@@ -0,0 +1,68 @@
|
|
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
|
+
require "gapic/call_options/retry_policy"
|
16
|
+
|
17
|
+
module Gapic
|
18
|
+
##
|
19
|
+
# Encapsulates the overridable settings for a particular RPC call.
|
20
|
+
#
|
21
|
+
# @!attribute [r] timeout
|
22
|
+
# @return [Numeric, nil]
|
23
|
+
# @!attribute [r] metadata
|
24
|
+
# @return [Hash]
|
25
|
+
# @!attribute [r] retry_policy
|
26
|
+
# @return [RetryPolicy, Object]
|
27
|
+
#
|
28
|
+
class CallOptions
|
29
|
+
attr_reader :timeout, :metadata, :retry_policy
|
30
|
+
|
31
|
+
##
|
32
|
+
# Create a new Options object instance.
|
33
|
+
#
|
34
|
+
# @param timeout [Numeric] The client-side timeout for RPC calls.
|
35
|
+
# @param metadata [Hash] The request header params.
|
36
|
+
# @param retry_policy [Hash, RetryPolicy, Proc] The policy for error retry. A Hash can be provided to
|
37
|
+
# customize the policy object, using keys that match the arguments for {RetryPolicy.new}.
|
38
|
+
#
|
39
|
+
# A Proc object can also be provided. The Proc should accept an error as an argument, and return `true` if the
|
40
|
+
# error should be retried or `false` if not. If the error is to be retried, the Proc object must also block
|
41
|
+
# with an incremental delay before returning `true`.
|
42
|
+
#
|
43
|
+
def initialize timeout: nil, metadata: nil, retry_policy: nil
|
44
|
+
# Converts hash and nil to a policy object
|
45
|
+
retry_policy = RetryPolicy.new retry_policy.to_h if retry_policy.respond_to? :to_h
|
46
|
+
|
47
|
+
@timeout = timeout # allow to be nil so it can be overridden
|
48
|
+
@metadata = metadata.to_h # Ensure always hash, even for nil
|
49
|
+
@retry_policy = retry_policy
|
50
|
+
end
|
51
|
+
|
52
|
+
##
|
53
|
+
# @private
|
54
|
+
# Apply default values to the options object. This does not replace user-provided values, it only overrides
|
55
|
+
# empty values.
|
56
|
+
#
|
57
|
+
# @param timeout [Numeric] The client-side timeout for RPC calls.
|
58
|
+
# @param metadata [Hash] the request header params.
|
59
|
+
# @param retry_policy [Hash] the policy for error retry.
|
60
|
+
# @param retry_policy [Hash] The policy for error retry. keys must match the arguments for
|
61
|
+
# {RetryPolicy.new}.
|
62
|
+
def apply_defaults timeout: nil, metadata: nil, retry_policy: nil
|
63
|
+
@timeout ||= timeout
|
64
|
+
@metadata = metadata.merge @metadata if metadata
|
65
|
+
@retry_policy.apply_defaults retry_policy if @retry_policy.respond_to? :apply_defaults
|
66
|
+
end
|
67
|
+
end
|
68
|
+
end
|
@@ -0,0 +1,106 @@
|
|
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
|
+
module Gapic
|
16
|
+
class CallOptions
|
17
|
+
##
|
18
|
+
# The policy for retrying failed RPC calls using an incremental backoff. A new object instance should be used for
|
19
|
+
# every RpcCall invocation.
|
20
|
+
#
|
21
|
+
# Only errors orginating from GRPC will be retried.
|
22
|
+
#
|
23
|
+
class RetryPolicy
|
24
|
+
##
|
25
|
+
# Create new API Call RetryPolicy.
|
26
|
+
#
|
27
|
+
# @param initial_delay [Numeric] client-side timeout
|
28
|
+
# @param multiplier [Numeric] client-side timeout
|
29
|
+
# @param max_delay [Numeric] client-side timeout
|
30
|
+
#
|
31
|
+
def initialize retry_codes: nil, initial_delay: nil, multiplier: nil, max_delay: nil
|
32
|
+
@retry_codes = retry_codes
|
33
|
+
@initial_delay = initial_delay
|
34
|
+
@multiplier = multiplier
|
35
|
+
@max_delay = max_delay
|
36
|
+
@delay = nil
|
37
|
+
end
|
38
|
+
|
39
|
+
def retry_codes
|
40
|
+
@retry_codes || []
|
41
|
+
end
|
42
|
+
|
43
|
+
def initial_delay
|
44
|
+
@initial_delay || 1
|
45
|
+
end
|
46
|
+
|
47
|
+
def multiplier
|
48
|
+
@multiplier || 1.3
|
49
|
+
end
|
50
|
+
|
51
|
+
def max_delay
|
52
|
+
@max_delay || 15
|
53
|
+
end
|
54
|
+
|
55
|
+
##
|
56
|
+
# The current delay value.
|
57
|
+
def delay
|
58
|
+
@delay || initial_delay
|
59
|
+
end
|
60
|
+
|
61
|
+
def call error
|
62
|
+
return false unless retry? error
|
63
|
+
|
64
|
+
delay!
|
65
|
+
increment_delay!
|
66
|
+
|
67
|
+
true
|
68
|
+
end
|
69
|
+
|
70
|
+
##
|
71
|
+
# @private
|
72
|
+
# Apply default values to the policy object. This does not replace user-provided values, it only overrides empty
|
73
|
+
# values.
|
74
|
+
#
|
75
|
+
# @param retry_policy [Hash] The policy for error retry. keys must match the arguments for
|
76
|
+
# {RpcCall::RetryPolicy.new}.
|
77
|
+
def apply_defaults retry_policy
|
78
|
+
return unless retry_policy.is_a? Hash
|
79
|
+
|
80
|
+
@retry_codes ||= retry_policy[:retry_codes]
|
81
|
+
@initial_delay ||= retry_policy[:initial_delay]
|
82
|
+
@multiplier ||= retry_policy[:multiplier]
|
83
|
+
@max_delay ||= retry_policy[:max_delay]
|
84
|
+
|
85
|
+
self
|
86
|
+
end
|
87
|
+
|
88
|
+
private
|
89
|
+
|
90
|
+
def retry? error
|
91
|
+
error.is_a?(GRPC::BadStatus) && retry_codes.include?(error.code)
|
92
|
+
end
|
93
|
+
|
94
|
+
def delay!
|
95
|
+
# Call Kernel.sleep so we can stub it.
|
96
|
+
Kernel.sleep delay
|
97
|
+
end
|
98
|
+
|
99
|
+
##
|
100
|
+
# Calculate and set the next delay value.
|
101
|
+
def increment_delay!
|
102
|
+
@delay = [delay * multiplier, max_delay].min
|
103
|
+
end
|
104
|
+
end
|
105
|
+
end
|
106
|
+
end
|
data/lib/gapic/common.rb
ADDED
@@ -0,0 +1,32 @@
|
|
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
|
+
require "grpc/errors"
|
16
|
+
require "grpc/core/status_codes"
|
17
|
+
|
18
|
+
require "gapic/call_options"
|
19
|
+
require "gapic/headers"
|
20
|
+
require "gapic/operation"
|
21
|
+
require "gapic/paged_enumerable"
|
22
|
+
require "gapic/protobuf"
|
23
|
+
require "gapic/stream_input"
|
24
|
+
require "gapic/common/version"
|
25
|
+
|
26
|
+
# Gapic is Google's API client generator
|
27
|
+
module Gapic
|
28
|
+
# The gapic-common gem includes various common libraries for clients built
|
29
|
+
# with Gapic.
|
30
|
+
module Common
|
31
|
+
end
|
32
|
+
end
|