bq 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 6d6f83be99622d5d83bccd1e4dc7aed515e854f0
4
+ data.tar.gz: 2d883c8b12b36adafdb196456df78a7df327488a
5
+ SHA512:
6
+ metadata.gz: 821fad029d3c6461471deaf4b3664b0fcd262fd9a0bb0094eb7891b43bee9d0c25a323fddaaabda25a8d21ce3802eb22bb681f8304ef2516062f93e81c9495c7
7
+ data.tar.gz: f68e29c7c725b9cce2190b3594208f3ec00032cf2f1585f1a5f2b97709414dafb42274b98d47552e9530ef1e456094af4b141817dab7632016fa23f09253025c
data/.gitignore ADDED
@@ -0,0 +1,22 @@
1
+ *.gem
2
+ *.rbc
3
+ .bundle
4
+ .config
5
+ .yardoc
6
+ Gemfile.lock
7
+ InstalledFiles
8
+ _yardoc
9
+ coverage
10
+ doc/
11
+ lib/bundler/man
12
+ pkg
13
+ rdoc
14
+ spec/reports
15
+ test/tmp
16
+ test/version_tmp
17
+ tmp
18
+ *.bundle
19
+ *.so
20
+ *.o
21
+ *.a
22
+ mkmf.log
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in bq.gemspec
4
+ gemspec
data/LICENSE.txt ADDED
@@ -0,0 +1,22 @@
1
+ Copyright (c) 2014 sasaki takeru
2
+
3
+ MIT License
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining
6
+ a copy of this software and associated documentation files (the
7
+ "Software"), to deal in the Software without restriction, including
8
+ without limitation the rights to use, copy, modify, merge, publish,
9
+ distribute, sublicense, and/or sell copies of the Software, and to
10
+ permit persons to whom the Software is furnished to do so, subject to
11
+ the following conditions:
12
+
13
+ The above copyright notice and this permission notice shall be
14
+ included in all copies or substantial portions of the Software.
15
+
16
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,37 @@
1
+ # Bq
2
+
3
+ Just execute (Big)query.
4
+
5
+ ## Installation
6
+
7
+ Add this line to your application's Gemfile:
8
+
9
+ gem 'bq'
10
+
11
+ And then execute:
12
+
13
+ $ bundle
14
+
15
+ Or install it yourself as:
16
+
17
+ $ gem install bq
18
+
19
+ ## Usage
20
+
21
+ require "bq"
22
+
23
+ bq = Bq::InstalledApp.new
24
+ token = bq.authorize # please locate client_secrets.json in load path.
25
+ # save token into file or db or ...
26
+
27
+ bq2 = Bq::InstalledApp.new(:token=>token, :project_id=>"your-project-id")
28
+ pp bq2.datasets.to_hash
29
+ pp bq2.query("SELECT 12345").to_hash
30
+
31
+ ## Contributing
32
+
33
+ 1. Fork it ( https://github.com/takeru/bq/fork )
34
+ 2. Create your feature branch (`git checkout -b my-new-feature`)
35
+ 3. Commit your changes (`git commit -am 'Add some feature'`)
36
+ 4. Push to the branch (`git push origin my-new-feature`)
37
+ 5. Create a new Pull Request
data/Rakefile ADDED
@@ -0,0 +1,2 @@
1
+ require "bundler/gem_tasks"
2
+
data/bq.gemspec ADDED
@@ -0,0 +1,24 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'bq/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "bq"
8
+ spec.version = Bq::VERSION
9
+ spec.authors = ["sasaki takeru"]
10
+ spec.email = ["sasaki.takeru@gmail.com"]
11
+ spec.summary = %q{Just execute (Big)query.}
12
+ spec.description = %q{}
13
+ spec.homepage = ""
14
+ spec.license = "MIT"
15
+
16
+ spec.files = `git ls-files -z`.split("\x0")
17
+ spec.executables = spec.files.grep(%r{^bin/}) { |f| File.basename(f) }
18
+ spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
19
+ spec.require_paths = ["lib"]
20
+
21
+ spec.add_dependency 'google-api-client'
22
+ spec.add_development_dependency "bundler", "~> 1.6"
23
+ spec.add_development_dependency "rake"
24
+ end
data/lib/bq.rb ADDED
@@ -0,0 +1,128 @@
1
+ require "bq/version"
2
+ require 'google/api_client'
3
+ require 'google/api_client/client_secrets'
4
+ require 'google/api_client/auth/installed_app'
5
+ require 'json'
6
+
7
+ module Bq
8
+ class Base
9
+ attr_reader :token
10
+ attr_accessor :project_id
11
+
12
+ def initialize(opts={})
13
+ @project_id = opts[:project_id]
14
+ application_name = opts[:application_name] || "Bq"
15
+ application_version = opts[:application_version] || "0.0.1"
16
+
17
+ @client = Google::APIClient.new(
18
+ :application_name => application_name,
19
+ :application_version => application_version
20
+ )
21
+ self.token = opts[:token] if opts[:token]
22
+ @bq_client = @client.discovered_api('bigquery', 'v2')
23
+ end
24
+ def token=(token)
25
+ @client.authorization.client_id = token["client_id"]
26
+ @client.authorization.client_secret = token["client_secret"]
27
+ @client.authorization.scope = token["scope"]
28
+ @client.authorization.refresh_token = token["refresh_token"]
29
+ @client.authorization.access_token = token["access_token"]
30
+ end
31
+ end
32
+
33
+ class InstalledApp < Base
34
+ def authorize(client_secrets_json=nil)
35
+ client_secrets_json ||= "client_secrets.json"
36
+ puts "read from #{client_secrets_json}"
37
+ credential = Google::APIClient::ClientSecrets.load(client_secrets_json)
38
+
39
+ flow = Google::APIClient::InstalledAppFlow.new(
40
+ :client_id => credential.client_id,
41
+ :client_secret => credential.client_secret,
42
+ :scope => ['https://www.googleapis.com/auth/bigquery']
43
+ )
44
+ @client.authorization = flow.authorize
45
+ # Here, will be opened authorization web page.
46
+ # Click [Authorize] button, and I see "Error: redirect_uri_mismatch".
47
+ # But it may be succeed, authorize arguments is available.
48
+
49
+ unless @client.authorization
50
+ puts "failed to authorize. Canceled?"
51
+ return nil
52
+ end
53
+
54
+ @token = {
55
+ "scope" => @client.authorization.scope,
56
+ "client_id" => @client.authorization.client_id,
57
+ "client_secret" => @client.authorization.client_secret,
58
+ "access_token" => @client.authorization.access_token,
59
+ "refresh_token" => @client.authorization.refresh_token
60
+ }.freeze
61
+
62
+ return @token
63
+ end
64
+
65
+ def datasets
66
+ result = @client.execute(
67
+ :api_method => @bq_client.datasets.list,
68
+ :parameters => {'projectId' => @project_id}
69
+ )
70
+ return result.data
71
+ end
72
+
73
+ def query(q,timeout=90)
74
+ result = @client.execute(
75
+ :api_method => @bq_client.jobs.query,
76
+ :body_object => {
77
+ "query" => q,
78
+ "timeoutMs" => timeout * 1000
79
+ },
80
+ :parameters => {'projectId' => @project_id}
81
+ )
82
+ return result.data
83
+ end
84
+ end
85
+ end
86
+
87
+ if __FILE__ == $0
88
+ require "optparse"
89
+ require "pp"
90
+
91
+ begin
92
+ token_file = '.bq_secret_token.json'
93
+ opts = ARGV.getopts("",
94
+ "authorize", # authorize and create token file
95
+ "client_secrets_json:", # select client_secret file
96
+ "project_id:", # select project id
97
+ "datasets", # list datasets
98
+ "query:" # execute query
99
+ )
100
+ if opts["authorize"]
101
+ puts "will be open authorization page in web browser..."
102
+ bq = Bq::InstalledApp.new
103
+ bq.authorize(opts["client_secrets_json"])
104
+ open(token_file,'w') do |f|
105
+ JSON.dump(bq.token,f)
106
+ end
107
+ puts "wrote access token to file: .bq_secret_token.json"
108
+ end
109
+
110
+ project_id = opts["project_id"]
111
+ raise "project_id missing." unless project_id
112
+ token = JSON.parse File.read(token_file)
113
+ bq = Bq::InstalledApp.new(:token=>token, :project_id=>project_id)
114
+
115
+ if opts["datasets"]
116
+ pp bq.datasets.to_hash
117
+ end
118
+ if opts["query"]
119
+ pp bq.query(opts["query"]).to_hash
120
+ end
121
+ rescue => e
122
+ p e
123
+ puts "usage:"
124
+ puts " ruby bq.rb --authorize [--client_secrets_json ./client_secrets.json]"
125
+ puts " ruby bq.rb --project_id your-project-id --datasets"
126
+ puts " ruby bq.rb --project_id bq-takeru-test --query \"SELECT 123\""
127
+ end
128
+ end
data/lib/bq/version.rb ADDED
@@ -0,0 +1,3 @@
1
+ module Bq
2
+ VERSION = "0.0.1"
3
+ end
metadata ADDED
@@ -0,0 +1,94 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: bq
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - sasaki takeru
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2014-06-03 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'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ">="
25
+ - !ruby/object:Gem::Version
26
+ version: '0'
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.6'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: '1.6'
41
+ - !ruby/object:Gem::Dependency
42
+ name: rake
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - ">="
46
+ - !ruby/object:Gem::Version
47
+ version: '0'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - ">="
53
+ - !ruby/object:Gem::Version
54
+ version: '0'
55
+ description: ''
56
+ email:
57
+ - sasaki.takeru@gmail.com
58
+ executables: []
59
+ extensions: []
60
+ extra_rdoc_files: []
61
+ files:
62
+ - ".gitignore"
63
+ - Gemfile
64
+ - LICENSE.txt
65
+ - README.md
66
+ - Rakefile
67
+ - bq.gemspec
68
+ - lib/bq.rb
69
+ - lib/bq/version.rb
70
+ homepage: ''
71
+ licenses:
72
+ - MIT
73
+ metadata: {}
74
+ post_install_message:
75
+ rdoc_options: []
76
+ require_paths:
77
+ - lib
78
+ required_ruby_version: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - ">="
81
+ - !ruby/object:Gem::Version
82
+ version: '0'
83
+ required_rubygems_version: !ruby/object:Gem::Requirement
84
+ requirements:
85
+ - - ">="
86
+ - !ruby/object:Gem::Version
87
+ version: '0'
88
+ requirements: []
89
+ rubyforge_project:
90
+ rubygems_version: 2.0.14
91
+ signing_key:
92
+ specification_version: 4
93
+ summary: Just execute (Big)query.
94
+ test_files: []