Update depdencies, simplify gem management
This commit is contained in:
parent
95823b0e19
commit
0244bf13b3
27
Gemfile
27
Gemfile
|
@ -2,31 +2,4 @@ source 'https://rubygems.org'
|
||||||
|
|
||||||
gemspec
|
gemspec
|
||||||
|
|
||||||
gem 'signet', '>= 0.5.0'
|
|
||||||
gem 'addressable', '>= 2.3.2'
|
|
||||||
gem 'uuidtools', '>= 2.1.0'
|
|
||||||
gem 'autoparse', '>= 0.3.3'
|
|
||||||
gem 'faraday', '>= 0.9.0'
|
|
||||||
gem 'multi_json', '>= 1.0.0'
|
|
||||||
gem 'extlib', '>= 0.9.15'
|
|
||||||
gem 'jwt', '~> 0.1.5'
|
|
||||||
gem 'retriable', '~> 1.4'
|
|
||||||
gem 'jruby-openssl', :platforms => :jruby
|
gem 'jruby-openssl', :platforms => :jruby
|
||||||
|
|
||||||
group :development do
|
|
||||||
gem 'launchy', '>= 2.1.1'
|
|
||||||
gem 'yard'
|
|
||||||
gem 'kramdown'
|
|
||||||
end
|
|
||||||
|
|
||||||
group :examples do
|
|
||||||
gem 'sinatra'
|
|
||||||
end
|
|
||||||
|
|
||||||
group :test, :development do
|
|
||||||
gem 'json', '~> 1.7.7'
|
|
||||||
gem 'rspec', '~> 3.0'
|
|
||||||
gem 'simplecov', :platforms => [:ruby_19, :ruby_20], :require => false
|
|
||||||
end
|
|
||||||
|
|
||||||
gem 'idn', :platforms => :mri_18
|
|
||||||
|
|
|
@ -1,65 +1,40 @@
|
||||||
# -*- encoding: utf-8 -*-
|
# -*- encoding: utf-8 -*-
|
||||||
|
require File.join(File.dirname(__FILE__), 'lib/google/api_client', 'version')
|
||||||
|
|
||||||
Gem::Specification.new do |s|
|
Gem::Specification.new do |s|
|
||||||
s.name = "google-api-client"
|
s.name = "google-api-client"
|
||||||
s.version = "0.7.1"
|
s.version = Google::APIClient::VERSION::STRING
|
||||||
|
|
||||||
s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
|
s.required_rubygems_version = ">= 1.3.5"
|
||||||
s.authors = ["Bob Aman", "Steve Bazyl"]
|
s.require_paths = ["lib"]
|
||||||
s.date = "2014-01-23"
|
s.authors = ["Bob Aman", "Steven Bazyl"]
|
||||||
s.description = "The Google API Ruby Client makes it trivial to discover and access supported\nAPIs.\n"
|
s.license = "Apache-2.0"
|
||||||
|
s.description = "The Google API Ruby Client makes it trivial to discover and access supported APIs."
|
||||||
s.email = "sbazyl@google.com"
|
s.email = "sbazyl@google.com"
|
||||||
s.extra_rdoc_files = ["README.md"]
|
s.extra_rdoc_files = ["README.md"]
|
||||||
s.files = ["lib/cacerts.pem", "lib/compat", "lib/compat/multi_json.rb", "lib/google", "lib/google/api_client", "lib/google/api_client.rb", "lib/google/api_client/auth", "lib/google/api_client/auth/compute_service_account.rb", "lib/google/api_client/auth/file_storage.rb", "lib/google/api_client/auth/installed_app.rb", "lib/google/api_client/auth/jwt_asserter.rb", "lib/google/api_client/auth/key_utils.rb", "lib/google/api_client/auth/pkcs12.rb", "lib/google/api_client/batch.rb", "lib/google/api_client/client_secrets.rb", "lib/google/api_client/discovery", "lib/google/api_client/discovery.rb", "lib/google/api_client/discovery/api.rb", "lib/google/api_client/discovery/media.rb", "lib/google/api_client/discovery/method.rb", "lib/google/api_client/discovery/resource.rb", "lib/google/api_client/discovery/schema.rb", "lib/google/api_client/environment.rb", "lib/google/api_client/errors.rb", "lib/google/api_client/gzip.rb", "lib/google/api_client/logging.rb", "lib/google/api_client/media.rb", "lib/google/api_client/railtie.rb", "lib/google/api_client/reference.rb", "lib/google/api_client/request.rb", "lib/google/api_client/result.rb", "lib/google/api_client/service", "lib/google/api_client/service.rb", "lib/google/api_client/service/batch.rb", "lib/google/api_client/service/request.rb", "lib/google/api_client/service/resource.rb", "lib/google/api_client/service/result.rb", "lib/google/api_client/service/simple_file_store.rb", "lib/google/api_client/service/stub_generator.rb", "lib/google/api_client/service_account.rb", "lib/google/api_client/version.rb", "lib/google/inflection.rb", "spec/fixtures", "spec/fixtures/files", "spec/fixtures/files/privatekey.p12", "spec/fixtures/files/sample.txt", "spec/fixtures/files/secret.pem", "spec/google", "spec/google/api_client", "spec/google/api_client/batch_spec.rb", "spec/google/api_client/discovery_spec.rb", "spec/google/api_client/gzip_spec.rb", "spec/google/api_client/media_spec.rb", "spec/google/api_client/request_spec.rb", "spec/google/api_client/result_spec.rb", "spec/google/api_client/service_account_spec.rb", "spec/google/api_client/service_spec.rb", "spec/google/api_client/simple_file_store_spec.rb", "spec/google/api_client_spec.rb", "spec/spec_helper.rb", "tasks/gem.rake", "tasks/git.rake", "tasks/metrics.rake", "tasks/spec.rake", "tasks/wiki.rake", "tasks/yard.rake", "CHANGELOG.md", "CONTRIBUTING.md", "Gemfile", "LICENSE", "README.md", "Rakefile"]
|
s.files = %w(google-api-client.gemspec Rakefile LICENSE CHANGELOG.md README.md Gemfile)
|
||||||
s.homepage = "https://github.com/google/google-api-ruby-client"
|
s.files += Dir.glob("lib/**/*.rb")
|
||||||
s.licenses = ["Apache 2.0"]
|
s.files += Dir.glob("spec/**/*.{rb,opts}")
|
||||||
|
s.files += Dir.glob("vendor/**/*.rb")
|
||||||
|
s.files += Dir.glob("tasks/**/*")
|
||||||
|
s.files += Dir.glob("website/**/*")
|
||||||
|
s.homepage = "https://github.com/google/google-api-ruby-client/"
|
||||||
s.rdoc_options = ["--main", "README.md"]
|
s.rdoc_options = ["--main", "README.md"]
|
||||||
s.require_paths = ["lib"]
|
s.summary = "The Google API Ruby Client makes it trivial to discover and access Google's REST APIs."
|
||||||
s.rubygems_version = "2.0.7"
|
|
||||||
s.summary = "Package Summary"
|
|
||||||
|
|
||||||
if s.respond_to? :specification_version then
|
s.add_runtime_dependency 'addressable', '~> 2.3'
|
||||||
s.specification_version = 4
|
s.add_runtime_dependency 'signet', '~> 0.6'
|
||||||
|
s.add_runtime_dependency 'faraday', '~> 0.9'
|
||||||
|
s.add_runtime_dependency 'multi_json', '~> 1.10'
|
||||||
|
s.add_runtime_dependency 'uuidtools', "~> 2.1"
|
||||||
|
s.add_runtime_dependency 'autoparse', "~> 0.3"
|
||||||
|
s.add_runtime_dependency 'extlib', '~> 0.9'
|
||||||
|
s.add_runtime_dependency 'launchy', '~> 2.4'
|
||||||
|
s.add_runtime_dependency 'retriable', '~> 1.4'
|
||||||
|
|
||||||
if Gem::Version.new(Gem::VERSION) >= Gem::Version.new('1.2.0') then
|
s.add_development_dependency 'rake', '~> 10.0'
|
||||||
s.add_runtime_dependency(%q<signet>, [">= 0.5.0"])
|
s.add_development_dependency 'yard', '~> 0.8'
|
||||||
s.add_runtime_dependency(%q<addressable>, [">= 2.3.2"])
|
s.add_development_dependency 'rspec', '~> 3.1'
|
||||||
s.add_runtime_dependency(%q<uuidtools>, [">= 2.1.0"])
|
s.add_development_dependency 'kramdown', '~> 1.5'
|
||||||
s.add_runtime_dependency(%q<autoparse>, [">= 0.3.3"])
|
s.add_development_dependency 'simplecov', '~> 0.9'
|
||||||
s.add_runtime_dependency(%q<faraday>, [">= 0.9.0"])
|
|
||||||
s.add_runtime_dependency(%q<multi_json>, [">= 1.0.0"])
|
|
||||||
s.add_runtime_dependency(%q<extlib>, [">= 0.9.15"])
|
|
||||||
s.add_runtime_dependency(%q<jwt>, [">= 0.1.5"])
|
|
||||||
s.add_runtime_dependency(%q<retriable>, ["~> 1.4"])
|
|
||||||
s.add_runtime_dependency(%q<launchy>, [">= 2.1.1"])
|
|
||||||
s.add_development_dependency(%q<rake>, [">= 0.9.0"])
|
|
||||||
s.add_development_dependency(%q<rspec>, [">= 2.11.0"])
|
|
||||||
else
|
|
||||||
s.add_dependency(%q<signet>, [">= 0.5.0"])
|
|
||||||
s.add_dependency(%q<addressable>, [">= 2.3.2"])
|
|
||||||
s.add_dependency(%q<uuidtools>, [">= 2.1.0"])
|
|
||||||
s.add_dependency(%q<autoparse>, [">= 0.3.3"])
|
|
||||||
s.add_dependency(%q<faraday>, [">= 0.9.0"])
|
|
||||||
s.add_dependency(%q<multi_json>, [">= 1.0.0"])
|
|
||||||
s.add_dependency(%q<extlib>, [">= 0.9.15"])
|
|
||||||
s.add_dependency(%q<jwt>, [">= 0.1.5"])
|
|
||||||
s.add_dependency(%q<retriable>, ["~> 1.4"])
|
|
||||||
s.add_dependency(%q<launchy>, [">= 2.1.1"])
|
|
||||||
s.add_dependency(%q<rake>, [">= 0.9.0"])
|
|
||||||
s.add_dependency(%q<rspec>, [">= 2.11.0"])
|
|
||||||
end
|
|
||||||
else
|
|
||||||
s.add_dependency(%q<signet>, [">= 0.5.0"])
|
|
||||||
s.add_dependency(%q<addressable>, [">= 2.3.2"])
|
|
||||||
s.add_dependency(%q<uuidtools>, [">= 2.1.0"])
|
|
||||||
s.add_dependency(%q<autoparse>, [">= 0.3.3"])
|
|
||||||
s.add_dependency(%q<faraday>, [">= 0.9.0"])
|
|
||||||
s.add_dependency(%q<multi_json>, [">= 1.0.0"])
|
|
||||||
s.add_dependency(%q<extlib>, [">= 0.9.15"])
|
|
||||||
s.add_dependency(%q<jwt>, [">= 0.1.5"])
|
|
||||||
s.add_dependency(%q<retriable>, ["~> 1.4"])
|
|
||||||
s.add_dependency(%q<launchy>, [">= 2.1.1"])
|
|
||||||
s.add_dependency(%q<rake>, [">= 0.9.0"])
|
|
||||||
s.add_dependency(%q<rspec>, [">= 2.11.0"])
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -21,7 +21,7 @@ module Google
|
||||||
def fetch_access_token(options={})
|
def fetch_access_token(options={})
|
||||||
connection = options[:connection] || Faraday.default_connection
|
connection = options[:connection] || Faraday.default_connection
|
||||||
response = connection.get 'http://metadata/computeMetadata/v1beta1/instance/service-accounts/default/token'
|
response = connection.get 'http://metadata/computeMetadata/v1beta1/instance/service-accounts/default/token'
|
||||||
Signet::OAuth2.parse_json_credentials(response.body)
|
Signet::OAuth2.parse_credentials(response.body, response.headers['content-type'])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -0,0 +1,8 @@
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
# Usage: script/gem
|
||||||
|
# Updates the gemspec and builds a new gem in the pkg directory.
|
||||||
|
|
||||||
|
mkdir -p pkg
|
||||||
|
gem build *.gemspec
|
||||||
|
mv *.gem pkg
|
||||||
|
|
|
@ -0,0 +1,14 @@
|
||||||
|
age: script/release
|
||||||
|
# Build the package, tag a commit, push it to origin, and then release the
|
||||||
|
# package publicly.
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
version="$(script/package | grep Version: | awk '{print $2}')"
|
||||||
|
[ -n "$version" ] || exit 1
|
||||||
|
|
||||||
|
git commit --allow-empty -a -m "Release $version"
|
||||||
|
git tag "$version"
|
||||||
|
git push --tags origin
|
||||||
|
gem push pkg/*-${version}.gem
|
||||||
|
|
|
@ -77,7 +77,7 @@ describe Google::APIClient::JWTAsserter do
|
||||||
params = Addressable::URI.form_unencode(env[:body])
|
params = Addressable::URI.form_unencode(env[:body])
|
||||||
JWT.decode(params.assoc("assertion").last, @key.public_key)
|
JWT.decode(params.assoc("assertion").last, @key.public_key)
|
||||||
expect(params.assoc("grant_type")).to eq(['grant_type','urn:ietf:params:oauth:grant-type:jwt-bearer'])
|
expect(params.assoc("grant_type")).to eq(['grant_type','urn:ietf:params:oauth:grant-type:jwt-bearer'])
|
||||||
[200, {}, '{
|
[200, {'content-type' => 'application/json'}, '{
|
||||||
"access_token" : "1/abcdef1234567890",
|
"access_token" : "1/abcdef1234567890",
|
||||||
"token_type" : "Bearer",
|
"token_type" : "Bearer",
|
||||||
"expires_in" : 3600
|
"expires_in" : 3600
|
||||||
|
@ -97,7 +97,7 @@ describe Google::APIClient::JWTAsserter do
|
||||||
params = Addressable::URI.form_unencode(env[:body])
|
params = Addressable::URI.form_unencode(env[:body])
|
||||||
JWT.decode(params.assoc("assertion").last, @key.public_key)
|
JWT.decode(params.assoc("assertion").last, @key.public_key)
|
||||||
expect(params.assoc("grant_type")).to eq(['grant_type','urn:ietf:params:oauth:grant-type:jwt-bearer'])
|
expect(params.assoc("grant_type")).to eq(['grant_type','urn:ietf:params:oauth:grant-type:jwt-bearer'])
|
||||||
[200, {}, '{
|
[200, {'content-type' => 'application/json'}, '{
|
||||||
"access_token" : "1/abcdef1234567890",
|
"access_token" : "1/abcdef1234567890",
|
||||||
"token_type" : "Bearer",
|
"token_type" : "Bearer",
|
||||||
"expires_in" : 3600
|
"expires_in" : 3600
|
||||||
|
@ -117,7 +117,7 @@ describe Google::APIClient::JWTAsserter do
|
||||||
params = Addressable::URI.form_unencode(env[:body])
|
params = Addressable::URI.form_unencode(env[:body])
|
||||||
JWT.decode(params.assoc("assertion").last, @key.public_key)
|
JWT.decode(params.assoc("assertion").last, @key.public_key)
|
||||||
expect(params.assoc("grant_type")).to eq(['grant_type','urn:ietf:params:oauth:grant-type:jwt-bearer'])
|
expect(params.assoc("grant_type")).to eq(['grant_type','urn:ietf:params:oauth:grant-type:jwt-bearer'])
|
||||||
[200, {}, '{
|
[200, {'content-type' => 'application/json'}, '{
|
||||||
"access_token" : "1/abcdef1234567890",
|
"access_token" : "1/abcdef1234567890",
|
||||||
"token_type" : "Bearer",
|
"token_type" : "Bearer",
|
||||||
"expires_in" : 3600
|
"expires_in" : 3600
|
||||||
|
@ -127,7 +127,7 @@ describe Google::APIClient::JWTAsserter do
|
||||||
params = Addressable::URI.form_unencode(env[:body])
|
params = Addressable::URI.form_unencode(env[:body])
|
||||||
JWT.decode(params.assoc("assertion").last, @key.public_key)
|
JWT.decode(params.assoc("assertion").last, @key.public_key)
|
||||||
expect(params.assoc("grant_type")).to eq(['grant_type','urn:ietf:params:oauth:grant-type:jwt-bearer'])
|
expect(params.assoc("grant_type")).to eq(['grant_type','urn:ietf:params:oauth:grant-type:jwt-bearer'])
|
||||||
[200, {}, '{
|
[200, {'content-type' => 'application/json'}, '{
|
||||||
"access_token" : "1/0987654321fedcba",
|
"access_token" : "1/0987654321fedcba",
|
||||||
"token_type" : "Bearer",
|
"token_type" : "Bearer",
|
||||||
"expires_in" : 3600
|
"expires_in" : 3600
|
||||||
|
@ -153,7 +153,7 @@ describe Google::APIClient::ComputeServiceAccount do
|
||||||
conn = stub_connection do |stub|
|
conn = stub_connection do |stub|
|
||||||
stub.get('/computeMetadata/v1beta1/instance/service-accounts/default/token') do |env|
|
stub.get('/computeMetadata/v1beta1/instance/service-accounts/default/token') do |env|
|
||||||
expect(env.url.host).to eq('metadata')
|
expect(env.url.host).to eq('metadata')
|
||||||
[200, {}, '{
|
[200, {'content-type' => 'application/json'}, '{
|
||||||
"access_token" : "1/abcdef1234567890",
|
"access_token" : "1/abcdef1234567890",
|
||||||
"token_type" : "Bearer",
|
"token_type" : "Bearer",
|
||||||
"expires_in" : 3600
|
"expires_in" : 3600
|
||||||
|
|
|
@ -1,81 +1,18 @@
|
||||||
require 'rubygems/package_task'
|
require "rubygems/package_task"
|
||||||
require 'rake/clean'
|
|
||||||
|
|
||||||
CLOBBER.include('pkg')
|
|
||||||
|
|
||||||
namespace :gem do
|
namespace :gem do
|
||||||
GEM_SPEC = Gem::Specification.new do |s|
|
|
||||||
unless s.respond_to?(:add_development_dependency)
|
|
||||||
puts 'The gem spec requires a newer version of RubyGems.'
|
|
||||||
exit(1)
|
|
||||||
end
|
|
||||||
|
|
||||||
s.name = PKG_NAME
|
desc "Build the gem"
|
||||||
s.version = PKG_VERSION
|
task :build do
|
||||||
s.author = PKG_AUTHOR
|
system "gem build signet.gemspec"
|
||||||
s.email = PKG_AUTHOR_EMAIL
|
|
||||||
s.summary = PKG_SUMMARY
|
|
||||||
s.description = PKG_DESCRIPTION
|
|
||||||
s.license = 'Apache 2.0'
|
|
||||||
s.files = PKG_FILES.to_a
|
|
||||||
|
|
||||||
s.extra_rdoc_files = %w( README.md )
|
|
||||||
s.rdoc_options.concat ['--main', 'README.md']
|
|
||||||
|
|
||||||
# Dependencies used in the main library
|
|
||||||
s.add_runtime_dependency('signet', '>= 0.5.0')
|
|
||||||
s.add_runtime_dependency('addressable', '>= 2.3.2')
|
|
||||||
s.add_runtime_dependency('uuidtools', '>= 2.1.0')
|
|
||||||
s.add_runtime_dependency('autoparse', '>= 0.3.3')
|
|
||||||
s.add_runtime_dependency('faraday', '>= 0.9.0')
|
|
||||||
s.add_runtime_dependency('multi_json', '>= 1.0.0')
|
|
||||||
s.add_runtime_dependency('extlib', '>= 0.9.15')
|
|
||||||
s.add_runtime_dependency('jwt', '>= 0.1.5')
|
|
||||||
s.add_runtime_dependency('retriable', '~> 1.4')
|
|
||||||
# Dependencies used in the CLI
|
|
||||||
s.add_runtime_dependency('launchy', '>= 2.1.1')
|
|
||||||
|
|
||||||
# Dependencies used in the examples
|
|
||||||
s.add_development_dependency('rake', '>= 0.9.0')
|
|
||||||
s.add_development_dependency('rspec', '~> 3.0')
|
|
||||||
|
|
||||||
s.require_path = 'lib'
|
|
||||||
|
|
||||||
s.homepage = PKG_HOMEPAGE
|
|
||||||
end
|
end
|
||||||
|
|
||||||
Gem::PackageTask.new(GEM_SPEC) do |p|
|
desc "Install the gem"
|
||||||
p.gem_spec = GEM_SPEC
|
task :install => ["clobber", "gem:package"] do
|
||||||
p.need_tar = true
|
|
||||||
p.need_zip = true
|
|
||||||
end
|
|
||||||
|
|
||||||
desc 'Show information about the gem'
|
|
||||||
task :debug do
|
|
||||||
puts GEM_SPEC.to_ruby
|
|
||||||
end
|
|
||||||
|
|
||||||
desc "Generates .gemspec file"
|
|
||||||
task :gemspec do
|
|
||||||
spec_string = GEM_SPEC.to_ruby
|
|
||||||
|
|
||||||
begin
|
|
||||||
Thread.new { eval("$SAFE = 3\n#{spec_string}", binding) }.join
|
|
||||||
rescue
|
|
||||||
abort "unsafe gemspec: #{$!}"
|
|
||||||
else
|
|
||||||
File.open("#{GEM_SPEC.name}.gemspec", 'w') do |file|
|
|
||||||
file.write spec_string
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
desc 'Install the gem'
|
|
||||||
task :install => ['clobber', 'gem:package'] do
|
|
||||||
sh "#{SUDO} gem install --local pkg/#{GEM_SPEC.full_name}"
|
sh "#{SUDO} gem install --local pkg/#{GEM_SPEC.full_name}"
|
||||||
end
|
end
|
||||||
|
|
||||||
desc 'Uninstall the gem'
|
desc "Uninstall the gem"
|
||||||
task :uninstall do
|
task :uninstall do
|
||||||
installed_list = Gem.source_index.find_name(PKG_NAME)
|
installed_list = Gem.source_index.find_name(PKG_NAME)
|
||||||
if installed_list &&
|
if installed_list &&
|
||||||
|
@ -87,11 +24,11 @@ namespace :gem do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
desc 'Reinstall the gem'
|
desc "Reinstall the gem"
|
||||||
task :reinstall => [:uninstall, :install]
|
task :reinstall => [:uninstall, :install]
|
||||||
end
|
end
|
||||||
|
|
||||||
desc 'Alias to gem:package'
|
desc "Alias to gem:package"
|
||||||
task 'gem' => 'gem:package'
|
task "gem" => "gem:package"
|
||||||
|
|
||||||
task 'gem:release' => 'gem:gemspec'
|
task "clobber" => ["gem:clobber_package"]
|
Loading…
Reference in New Issue