google_spreadsheet_fetcher 0.1.0

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 ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: f64fc0c33bc7dae3976b4524939abbc4fa804d85
4
+ data.tar.gz: 53df8c4ab01d25ca63861af70238c60b8099f9a4
5
+ SHA512:
6
+ metadata.gz: f3e0dad7e17d8beb8f133139a2e8133f3c7c3ce578e4a2cb9aac1942faeed1b0da5706cd23e71d9db6d0edeb1893b8dee15a7a32bb0a71fb1eb27e2f07220692
7
+ data.tar.gz: 71a98ab13281cbf7442a3cbc42d47c2e62eb9851d98c3fb90e4088a0ce58bdef71bd8c722312fa469e2a4d6137ab475e0409d6444b9d53bd7d42a39969304de7
data/.gitignore ADDED
@@ -0,0 +1,12 @@
1
+ /.bundle/
2
+ /.yardoc
3
+ /Gemfile.lock
4
+ /_yardoc/
5
+ /coverage/
6
+ /doc/
7
+ /pkg/
8
+ /spec/reports/
9
+ /tmp/
10
+
11
+ # rspec failure tracking
12
+ .rspec_status
data/.rspec ADDED
@@ -0,0 +1,2 @@
1
+ --format documentation
2
+ --color
data/.travis.yml ADDED
@@ -0,0 +1,5 @@
1
+ sudo: false
2
+ language: ruby
3
+ rvm:
4
+ - 2.4.1
5
+ before_install: gem install bundler -v 1.14.6
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in google_spreadsheet_fetcher.gemspec
4
+ gemspec
data/README.md ADDED
@@ -0,0 +1,36 @@
1
+ # GoogleSpreadsheetFetcher
2
+
3
+ Welcome to your new gem! In this directory, you'll find the files you need to be able to package up your Ruby library into a gem. Put your Ruby code in the file `lib/google_spreadsheet_fetcher`. To experiment with that code, run `bin/console` for an interactive prompt.
4
+
5
+ TODO: Delete this and the text above, and describe your gem
6
+
7
+ ## Installation
8
+
9
+ Add this line to your application's Gemfile:
10
+
11
+ ```ruby
12
+ gem 'google_spreadsheet_fetcher'
13
+ ```
14
+
15
+ And then execute:
16
+
17
+ $ bundle
18
+
19
+ Or install it yourself as:
20
+
21
+ $ gem install google_spreadsheet_fetcher
22
+
23
+ ## Usage
24
+
25
+ TODO: Write usage instructions here
26
+
27
+ ## Development
28
+
29
+ After checking out the repo, run `bin/setup` to install dependencies. Then, run `rake spec` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment.
30
+
31
+ To install this gem onto your local machine, run `bundle exec rake install`. To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, push git commits and tags, and push the `.gem` file to [rubygems.org](https://rubygems.org).
32
+
33
+ ## Contributing
34
+
35
+ Bug reports and pull requests are welcome on GitHub at https://github.com/[USERNAME]/google_spreadsheet_fetcher.
36
+
data/Rakefile ADDED
@@ -0,0 +1,6 @@
1
+ require "bundler/gem_tasks"
2
+ require "rspec/core/rake_task"
3
+
4
+ RSpec::Core::RakeTask.new(:spec)
5
+
6
+ task :default => :spec
data/bin/console ADDED
@@ -0,0 +1,14 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require "bundler/setup"
4
+ require "google_spreadsheet_fetcher"
5
+
6
+ # You can add fixtures and/or initialization code here to make experimenting
7
+ # with your gem easier. You can also use a different console, if you like.
8
+
9
+ # (If you use this, don't forget to add pry to your Gemfile!)
10
+ # require "pry"
11
+ # Pry.start
12
+
13
+ require "irb"
14
+ IRB.start(__FILE__)
data/bin/setup ADDED
@@ -0,0 +1,8 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+ IFS=$'\n\t'
4
+ set -vx
5
+
6
+ bundle install
7
+
8
+ # Do any other automated setup that you need to do here
@@ -0,0 +1,30 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'google_spreadsheet_fetcher/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "google_spreadsheet_fetcher"
8
+ spec.version = GoogleSpreadsheetFetcher::VERSION
9
+ spec.authors = ["Takahiro Ooishi"]
10
+ spec.email = ["taka0125@gmail.com"]
11
+
12
+ spec.summary = %q{Google Spreadsheet fetcher}
13
+ spec.description = %q{Google Spreadsheet fetcher}
14
+ spec.homepage = "https://github.com/taka0125/google_spreadsheet_fetcher"
15
+
16
+ spec.files = `git ls-files -z`.split("\x0").reject do |f|
17
+ f.match(%r{^(test|spec|features)/})
18
+ end
19
+ spec.bindir = "exe"
20
+ spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
21
+ spec.require_paths = ["lib"]
22
+
23
+ spec.required_ruby_version = '>= 2.3.0'
24
+
25
+ spec.add_dependency 'google-api-client', '~> 0.9'
26
+
27
+ spec.add_development_dependency "bundler", "~> 1.14"
28
+ spec.add_development_dependency "rake", "~> 10.0"
29
+ spec.add_development_dependency "rspec", "~> 3.0"
30
+ end
@@ -0,0 +1,13 @@
1
+ require "google_spreadsheet_fetcher/version"
2
+ require "google_spreadsheet_fetcher/config"
3
+ require "google_spreadsheet_fetcher/fetcher"
4
+
5
+ module GoogleSpreadsheetFetcher
6
+ def self.config
7
+ @config ||= Config.new
8
+ end
9
+
10
+ def self.configure
11
+ yield config
12
+ end
13
+ end
@@ -0,0 +1,7 @@
1
+ require 'active_support/configurable'
2
+
3
+ module GoogleSpreadsheetFetcher
4
+ class Config
5
+ attr_accessor :client_secrets_file_path
6
+ end
7
+ end
@@ -0,0 +1,85 @@
1
+ require 'googleauth'
2
+ require 'googleauth/stores/file_token_store'
3
+ require 'google/apis/drive_v2'
4
+ require 'google_drive'
5
+ require 'shellwords'
6
+
7
+ module GoogleSpreadsheetFetcher
8
+ class Fetcher
9
+ OOB_URI = 'urn:ietf:wg:oauth:2.0:oob'
10
+
11
+ def initialize(credential_store_file, user_id, sheet_key)
12
+ @client_secret_file = GoogleSpreadsheetFetcher.config.client_secrets_file_path
13
+ @credential_store_file = credential_store_file
14
+ @user_id = user_id
15
+ @sheet_key = sheet_key
16
+ end
17
+
18
+ def fetch_by_index(index)
19
+ fetch_worksheet_by(index: index)
20
+ end
21
+
22
+ def fetch_by_title(title)
23
+ fetch_worksheet_by(title: title)
24
+ end
25
+
26
+ def fetch_by_gid(gid)
27
+ fetch_worksheet_by(gid: gid)
28
+ end
29
+
30
+ private
31
+
32
+ def fetch_worksheet_by(index: nil, title: nil, gid: nil)
33
+ credentials = fetch_credentials
34
+
35
+ drive = Google::Apis::DriveV2::DriveService.new
36
+ drive.authorization = credentials
37
+ session = GoogleDrive::Session.login_with_oauth(credentials)
38
+
39
+ spreadsheet = session.spreadsheet_by_key(@sheet_key)
40
+
41
+ unless index.nil?
42
+ return spreadsheet.worksheets[index]
43
+ end
44
+
45
+ unless title.nil?
46
+ return spreadsheet.worksheet_by_title(title)
47
+ end
48
+
49
+ unless gid.nil?
50
+ return spreadsheet.worksheet_by_gid(gid)
51
+ end
52
+
53
+ raise
54
+ end
55
+
56
+ def fetch_credentials
57
+ oob_uri = 'urn:ietf:wg:oauth:2.0:oob'
58
+
59
+ client_id = Google::Auth::ClientId.from_file(@client_secret_file)
60
+ token_store = Google::Auth::Stores::FileTokenStore.new(file: @credential_store_file)
61
+ authorizer = Google::Auth::UserAuthorizer.new(client_id, scopes, token_store)
62
+
63
+ credentials = authorizer.get_credentials(@user_id)
64
+
65
+ if credentials.nil?
66
+ url = authorizer.get_authorization_url(base_url: OOB_URI)
67
+ escaped_url = url.shellescape
68
+ system("open #{escaped_url}")
69
+ puts "Open #{url} in your browser and enter the resulting code: "
70
+ code = STDIN.gets
71
+ credentials = authorizer.get_and_store_credentials_from_code(user_id: @user_id, code: code, base_url: oob_uri)
72
+ end
73
+
74
+ credentials
75
+ end
76
+
77
+ def scopes
78
+ %w[
79
+ https://spreadsheets.google.com/feeds/
80
+ https://www.googleapis.com/auth/drive
81
+ https://www.googleapis.com/auth/userinfo.profile
82
+ ]
83
+ end
84
+ end
85
+ end
@@ -0,0 +1,3 @@
1
+ module GoogleSpreadsheetFetcher
2
+ VERSION = "0.1.0"
3
+ end
metadata ADDED
@@ -0,0 +1,112 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: google_spreadsheet_fetcher
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Takahiro Ooishi
8
+ autorequire:
9
+ bindir: exe
10
+ cert_chain: []
11
+ date: 2017-06-23 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: google-api-client
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: '0.9'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '0.9'
27
+ - !ruby/object:Gem::Dependency
28
+ name: bundler
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: '1.14'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: '1.14'
41
+ - !ruby/object:Gem::Dependency
42
+ name: rake
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - "~>"
46
+ - !ruby/object:Gem::Version
47
+ version: '10.0'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - "~>"
53
+ - !ruby/object:Gem::Version
54
+ version: '10.0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: rspec
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - "~>"
60
+ - !ruby/object:Gem::Version
61
+ version: '3.0'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - "~>"
67
+ - !ruby/object:Gem::Version
68
+ version: '3.0'
69
+ description: Google Spreadsheet fetcher
70
+ email:
71
+ - taka0125@gmail.com
72
+ executables: []
73
+ extensions: []
74
+ extra_rdoc_files: []
75
+ files:
76
+ - ".gitignore"
77
+ - ".rspec"
78
+ - ".travis.yml"
79
+ - Gemfile
80
+ - README.md
81
+ - Rakefile
82
+ - bin/console
83
+ - bin/setup
84
+ - google_spreadsheet_fetcher.gemspec
85
+ - lib/google_spreadsheet_fetcher.rb
86
+ - lib/google_spreadsheet_fetcher/config.rb
87
+ - lib/google_spreadsheet_fetcher/fetcher.rb
88
+ - lib/google_spreadsheet_fetcher/version.rb
89
+ homepage: https://github.com/taka0125/google_spreadsheet_fetcher
90
+ licenses: []
91
+ metadata: {}
92
+ post_install_message:
93
+ rdoc_options: []
94
+ require_paths:
95
+ - lib
96
+ required_ruby_version: !ruby/object:Gem::Requirement
97
+ requirements:
98
+ - - ">="
99
+ - !ruby/object:Gem::Version
100
+ version: 2.3.0
101
+ required_rubygems_version: !ruby/object:Gem::Requirement
102
+ requirements:
103
+ - - ">="
104
+ - !ruby/object:Gem::Version
105
+ version: '0'
106
+ requirements: []
107
+ rubyforge_project:
108
+ rubygems_version: 2.6.11
109
+ signing_key:
110
+ specification_version: 4
111
+ summary: Google Spreadsheet fetcher
112
+ test_files: []