omniauth-google-oauth2 0.8.0 → 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: a035e3c9635a9e588b756e9b2dfe2004ea1b83c49f9860d68e8250e7d93e4459
4
- data.tar.gz: 20e8ba4d7f4b9fb20b139c8d4b9c51d8d1d598de1cada5d989640f01eee0df3a
3
+ metadata.gz: 278efb11e955abf864c2d163e1f1631a271ba34660fa166a4f65b56691ccab0d
4
+ data.tar.gz: 574e6d6b5f3dacfa271ba24a8999e104c74db64482860b6ba095938a6dc7c1b0
5
5
  SHA512:
6
- metadata.gz: 5b06e6a3ffd03ff81fe6e04bbc94c9154e26c59dc17a7c834361bf2fdd80197661434679e8174196f4dd8ed13e4b2b81ff4b223fb366238f48648ea452fcf1ce
7
- data.tar.gz: 4734f0d6f92b57cebfccbbd0b833a7da9674d04e9058b76ef43d96cd94520a48bd540f57c9f804f6b16f2bad76483aefb3ef7357a99186acfc4dcb1603fa3a28
6
+ metadata.gz: 22006de20bc8355329cdca2c9e41a15959e192dcd4c970d1ca6acc8dd149f0fb1eedc313351cc39072e51ea5b219ebb6968b2e178995397d14f58b5117b18c53
7
+ data.tar.gz: b54fe6ca226e39f05705837eb8a390247df3a4fc615c7aab798009b63fd830ad7c21df7536ffa9fefffc4ff6c3586c6067ba5d15ac4d192b88892b3080c753f6
data/.rubocop.yml CHANGED
@@ -1,11 +1,9 @@
1
- ClassLength:
2
- Enabled: false
3
- Layout/IndentHeredoc:
1
+ Metrics/ClassLength:
4
2
  Enabled: false
5
3
  Metrics/AbcSize:
6
4
  Enabled: false
7
5
  Metrics/BlockLength:
8
- ExcludedMethods: ['describe', 'context']
6
+ ExcludedMethods: ['describe', 'context', 'shared_examples']
9
7
  Metrics/CyclomaticComplexity:
10
8
  Enabled: false
11
9
  Metrics/LineLength:
@@ -20,4 +18,3 @@ Style/MutableConstant:
20
18
  Enabled: false
21
19
  Gemspec/RequiredRubyVersion:
22
20
  Enabled: false
23
-
data/.travis.yml CHANGED
@@ -1,6 +1,6 @@
1
1
  language: ruby
2
+ cache: bundler
2
3
  rvm:
3
- - '2.2.7'
4
4
  - '2.3.4'
5
5
  - '2.4.1'
6
6
  - '2.5.0'
data/CHANGELOG.md CHANGED
@@ -1,6 +1,49 @@
1
1
  # Changelog
2
2
  All notable changes to this project will be documented in this file.
3
3
 
4
+ ## 1.0.0 - 2021-03-14
5
+
6
+ ### Added
7
+ - Support for Omniauth 2.x!
8
+
9
+ ### Deprecated
10
+ - Nothing.
11
+
12
+ ### Removed
13
+ - Support for Omniauth 1.x
14
+
15
+ ### Fixed
16
+ - Nothing.
17
+
18
+ ## 0.8.2 - 2021-03-14
19
+
20
+ ### Added
21
+ - Constrains the version to Omniauth 1.x.
22
+
23
+ ### Deprecated
24
+ - Nothing.
25
+
26
+ ### Removed
27
+ - Nothing.
28
+
29
+ ### Fixed
30
+ - Nothing.
31
+
32
+ ## 0.8.1 - 2020-12-12
33
+
34
+ ### Added
35
+ - Support reading the access token from a json request body.
36
+
37
+ ### Deprecated
38
+ - Nothing.
39
+
40
+ ### Removed
41
+ - No longer verify the iat claim for JWT.
42
+
43
+ ### Fixed
44
+ - A few minor issues with .rubocop.yml.
45
+ - Issues with image resizing code when the image came with size information from Google.
46
+
4
47
  ## 0.8.0 - 2019-08-21
5
48
 
6
49
  ### Added
data/README.md CHANGED
@@ -81,7 +81,9 @@ You can configure several options, which you pass in to the `provider` method vi
81
81
 
82
82
  * `include_granted_scopes`: If this is provided with the value true, and the authorization request is granted, the authorization will include any previous authorizations granted to this user/application combination for other scopes. See Google's [Incremental Authorization](https://developers.google.com/accounts/docs/OAuth2WebServer#incrementalAuth) for additional details.
83
83
 
84
- * `openid_realm`: Set the OpenID realm value, to allow upgrading from OpenID based authentication to OAuth 2 based authentication. When this is set correctly an `openid_id` value will be set in `[:extra][:id_info]` in the authentication hash with the value of the user's OpenID ID URL.
84
+ * `openid_realm`: Set the OpenID realm value, to allow upgrading from OpenID based authentication to OAuth 2 based authentication. When this is set correctly an `openid_id` value will be set in `['extra']['id_info']` in the authentication hash with the value of the user's OpenID ID URL.
85
+
86
+ * `provider_ignores_state`: You will need to set this to `true` when using the `One-time Code Flow` below. In this flow there is no server side redirect that would set the state.
85
87
 
86
88
  Here's an example of a possible configuration where the strategy name is changed, the user is asked for extra permissions, the user is always prompted to select their account when logging in and the user's profile picture is returned as a thumbnail:
87
89
 
@@ -176,6 +178,8 @@ devise :omniauthable, omniauth_providers: [:google_oauth2]
176
178
  Then make sure your callbacks controller is setup.
177
179
 
178
180
  ```ruby
181
+ # app/controllers/users/omniauth_callbacks_controller.rb:
182
+
179
183
  class Users::OmniauthCallbacksController < Devise::OmniauthCallbacksController
180
184
  def google_oauth2
181
185
  # You need to implement the method below in your model (e.g. app/models/user.rb)
@@ -185,7 +189,7 @@ class Users::OmniauthCallbacksController < Devise::OmniauthCallbacksController
185
189
  flash[:notice] = I18n.t 'devise.omniauth_callbacks.success', kind: 'Google'
186
190
  sign_in_and_redirect @user, event: :authentication
187
191
  else
188
- session['devise.google_data'] = request.env['omniauth.auth'].except(:extra) # Removing extra as it can overflow some session stores
192
+ session['devise.google_data'] = request.env['omniauth.auth'].except('extra') # Removing extra as it can overflow some session stores
189
193
  redirect_to new_user_registration_url, alert: @user.errors.full_messages.join("\n")
190
194
  end
191
195
  end
@@ -223,7 +227,7 @@ An overview is available at https://github.com/plataformatec/devise/wiki/OmniAut
223
227
 
224
228
  ### One-time Code Flow (Hybrid Authentication)
225
229
 
226
- Google describes the One-time Code Flow [here](https://developers.google.com/+/web/signin/server-side-flow). This hybrid authentication flow has significant functional and security advantages over a pure server-side or pure client-side flow. The following steps occur in this flow:
230
+ Google describes the One-time Code Flow [here](https://developers.google.com/identity/sign-in/web/server-side-flow). This hybrid authentication flow has significant functional and security advantages over a pure server-side or pure client-side flow. The following steps occur in this flow:
227
231
 
228
232
  1. The client (web browser) authenticates the user directly via Google's JS API. During this process assorted modals may be rendered by Google.
229
233
  2. On successful authentication, Google returns a one-time use code, which requires the Google client secret (which is only available server-side).
@@ -232,7 +236,7 @@ Google describes the One-time Code Flow [here](https://developers.google.com/+/w
232
236
 
233
237
  This flow is immune to replay attacks, and conveys no useful information to a man in the middle.
234
238
 
235
- The omniauth-google-oauth2 gem supports this mode of operation out of the box. Implementors simply need to add the appropriate JavaScript to their web page, and they can take advantage of this flow. An example JavaScript snippet follows.
239
+ The omniauth-google-oauth2 gem supports this mode of operation when `provider_ignores_state` is set to `true`. Implementors simply need to add the appropriate JavaScript to their web page, and they can take advantage of this flow. An example JavaScript snippet follows.
236
240
 
237
241
  ```javascript
238
242
  // Basic hybrid auth example following the pattern at:
@@ -247,7 +251,7 @@ function init() {
247
251
  // Ready.
248
252
  $('.google-login-button').click(function(e) {
249
253
  e.preventDefault();
250
-
254
+
251
255
  gapi.auth2.authorize({
252
256
  client_id: 'YOUR_CLIENT_ID',
253
257
  cookie_policy: 'single_host_origin',
@@ -260,7 +264,7 @@ function init() {
260
264
  success: function(data) {
261
265
  // response from server
262
266
  }
263
- });
267
+ });
264
268
  } else {
265
269
  // google authentication failed
266
270
  }
@@ -280,6 +284,66 @@ In that case, ensure to send an additional parameter `redirect_uri=` (empty stri
280
284
 
281
285
  If you're making POST requests to `/auth/google_oauth2/callback` from another domain, then you need to make sure `'X-Requested-With': 'XMLHttpRequest'` header is included with your request, otherwise your server might respond with `OAuth2::Error, : Invalid Value` error.
282
286
 
287
+ #### Getting around the `redirect_uri_mismatch` error (See [Issue #365](https://github.com/zquestz/omniauth-google-oauth2/issues/365))
288
+
289
+ If you are struggling with a persistent `redirect_uri_mismatch`, you can instead pass the `access_token` from [`getAuthResponse`](https://developers.google.com/identity/sign-in/web/reference#googleusergetauthresponseincludeauthorizationdata) directly to the `auth/google_oauth2/callback` endpoint, like so:
290
+
291
+ ```javascript
292
+ // Initialize the GoogleAuth object
293
+ let googleAuth;
294
+ gapi.load('client:auth2', async () => {
295
+ await gapi.client.init({ scope: '...', client_id: '...' });
296
+ googleAuth = gapi.auth2.getAuthInstance();
297
+ });
298
+
299
+ // Call this when the Google Sign In button is clicked
300
+ async function signInGoogle() {
301
+ const googleUser = await googleAuth.signIn(); // wait for the user to authorize through the modal
302
+ const { access_token } = googleUser.getAuthResponse();
303
+
304
+ const data = new FormData();
305
+ data.append('access_token', access_token);
306
+
307
+ const response = await api.post('/auth/google_oauth2/callback', data)
308
+ console.log(response);
309
+ }
310
+ ```
311
+
312
+ #### Using Axios
313
+ If you're making a GET resquests from another domain using `access_token`.
314
+ ```
315
+ axios
316
+ .get(
317
+ 'url(path to your callback}',
318
+ { params: { access_token: 'token' } },
319
+ headers....
320
+ )
321
+ ```
322
+
323
+ If you're making a POST resquests from another domain using `access_token`.
324
+ ```
325
+ axios
326
+ .post(
327
+ 'url(path to your callback}',
328
+ { access_token: 'token' },
329
+ headers....
330
+ )
331
+
332
+ --OR--
333
+
334
+ axios
335
+ .post(
336
+ 'url(path to your callback}',
337
+ null,
338
+ {
339
+ params: {
340
+ access_token: 'token'
341
+ },
342
+ headers....
343
+ }
344
+ )
345
+ ```
346
+
283
347
  ## Fixing Protocol Mismatch for `redirect_uri` in Rails
284
348
 
285
349
  Just set the `full_host` in OmniAuth based on the Rails.env.
data/examples/Gemfile CHANGED
@@ -2,6 +2,6 @@
2
2
 
3
3
  source 'https://rubygems.org'
4
4
 
5
- gem 'omniauth-google-oauth2', '~> 0.8.0'
5
+ gem 'omniauth-google-oauth2', '~> 0.8.1'
6
6
  gem 'rubocop'
7
7
  gem 'sinatra', '~> 1.4'
@@ -10,6 +10,10 @@ Rails.application.config.middleware.use OmniAuth::Builder do
10
10
  #
11
11
  provider :google_oauth2, ENV['GOOGLE_KEY'], ENV['GOOGLE_SECRET'], scope: 'email,profile'
12
12
 
13
+ # Custom redirect_uri
14
+ #
15
+ # provider :google_oauth2, ENV['GOOGLE_KEY'], ENV['GOOGLE_SECRET'], scope: 'email,profile', redirect_uri: 'https://localhost:3000/redirect'
16
+
13
17
  # Manual setup for offline access with a refresh token.
14
18
  #
15
19
  # provider :google_oauth2, ENV['GOOGLE_KEY'], ENV['GOOGLE_SECRET'], access_type: 'offline'
@@ -2,6 +2,6 @@
2
2
 
3
3
  module OmniAuth
4
4
  module GoogleOauth2
5
- VERSION = '0.8.0'
5
+ VERSION = '1.0.0'
6
6
  end
7
7
  end
@@ -1,6 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  require 'jwt'
4
+ require 'oauth2'
4
5
  require 'omniauth/strategies/oauth2'
5
6
  require 'uri'
6
7
 
@@ -13,6 +14,7 @@ module OmniAuth
13
14
  BASE_SCOPES = %w[profile email openid].freeze
14
15
  DEFAULT_SCOPE = 'email,profile'
15
16
  USER_INFO_URL = 'https://www.googleapis.com/oauth2/v3/userinfo'
17
+ IMAGE_SIZE_REGEXP = /(s\d+(-c)?)|(w\d+-h\d+(-c)?)|(w\d+(-c)?)|(h\d+(-c)?)|c/
16
18
 
17
19
  option :name, 'google_oauth2'
18
20
  option :skip_friends, true
@@ -74,7 +76,7 @@ module OmniAuth
74
76
  verify_sub: false,
75
77
  verify_expiration: true,
76
78
  verify_not_before: true,
77
- verify_iat: true,
79
+ verify_iat: false,
78
80
  verify_jti: false,
79
81
  leeway: options[:jwt_leeway])
80
82
 
@@ -100,24 +102,30 @@ module OmniAuth
100
102
  private
101
103
 
102
104
  def callback_url
103
- options[:redirect_uri] || (full_host + script_name + callback_path)
105
+ options[:redirect_uri] || (full_host + callback_path)
104
106
  end
105
107
 
106
108
  def get_access_token(request)
107
109
  verifier = request.params['code']
108
110
  redirect_uri = request.params['redirect_uri']
111
+ access_token = request.params['access_token']
109
112
  if verifier && request.xhr?
110
113
  client_get_token(verifier, redirect_uri || 'postmessage')
111
114
  elsif verifier
112
115
  client_get_token(verifier, redirect_uri || callback_url)
113
- elsif verify_token(request.params['access_token'])
116
+ elsif access_token && verify_token(access_token)
114
117
  ::OAuth2::AccessToken.from_hash(client, request.params.dup)
115
118
  elsif request.content_type =~ /json/i
116
119
  begin
117
120
  body = JSON.parse(request.body.read)
118
121
  request.body.rewind # rewind request body for downstream middlewares
119
122
  verifier = body && body['code']
120
- client_get_token(verifier, 'postmessage') if verifier
123
+ access_token = body && body['access_token']
124
+ if verifier
125
+ client_get_token(verifier, 'postmessage')
126
+ elsif verify_token(access_token)
127
+ ::OAuth2::AccessToken.from_hash(client, body.dup)
128
+ end
121
129
  rescue JSON::ParserError => e
122
130
  warn "[omniauth google-oauth2] JSON parse error=#{e}"
123
131
  end
@@ -164,6 +172,10 @@ module OmniAuth
164
172
  if path_index && image_size_opts_passed?
165
173
  u.path.insert(path_index, image_params)
166
174
  u.path = u.path.gsub('//', '/')
175
+
176
+ # Check if the image is already sized!
177
+ split_path = u.path.split('/')
178
+ u.path = u.path.sub("/#{split_path[-3]}", '') if split_path[-3] =~ IMAGE_SIZE_REGEXP
167
179
  end
168
180
 
169
181
  u.query = strip_unnecessary_query_parameters(u.query)
@@ -21,8 +21,9 @@ Gem::Specification.new do |gem|
21
21
  gem.required_ruby_version = '>= 2.2'
22
22
 
23
23
  gem.add_runtime_dependency 'jwt', '>= 2.0'
24
- gem.add_runtime_dependency 'omniauth', '>= 1.1.1'
25
- gem.add_runtime_dependency 'omniauth-oauth2', '>= 1.6'
24
+ gem.add_runtime_dependency 'oauth2', '~> 1.1'
25
+ gem.add_runtime_dependency 'omniauth', '~> 2.0'
26
+ gem.add_runtime_dependency 'omniauth-oauth2', '~> 1.7.1'
26
27
 
27
28
  gem.add_development_dependency 'rake', '~> 12.0'
28
29
  gem.add_development_dependency 'rspec', '~> 3.6'
@@ -289,14 +289,26 @@ describe OmniAuth::Strategies::GoogleOauth2 do
289
289
  end
290
290
  end
291
291
 
292
- describe '#callback_path' do
292
+ describe '#callback_url' do
293
+ let(:base_url) { 'https://example.com' }
294
+
293
295
  it 'has the correct default callback path' do
294
- expect(subject.callback_path).to eq('/auth/google_oauth2/callback')
296
+ allow(subject).to receive(:full_host) { base_url }
297
+ allow(subject).to receive(:script_name) { '' }
298
+ expect(subject.send(:callback_url)).to eq(base_url + '/auth/google_oauth2/callback')
299
+ end
300
+
301
+ it 'should set the callback path with script_name if present' do
302
+ allow(subject).to receive(:full_host) { base_url }
303
+ allow(subject).to receive(:script_name) { '/v1' }
304
+ expect(subject.send(:callback_url)).to eq(base_url + '/v1/auth/google_oauth2/callback')
295
305
  end
296
306
 
297
307
  it 'should set the callback_path parameter if present' do
298
308
  @options = { callback_path: '/auth/foo/callback' }
299
- expect(subject.callback_path).to eq('/auth/foo/callback')
309
+ allow(subject).to receive(:full_host) { base_url }
310
+ allow(subject).to receive(:script_name) { '' }
311
+ expect(subject.send(:callback_url)).to eq(base_url + '/auth/foo/callback')
300
312
  end
301
313
  end
302
314
 
@@ -349,7 +361,7 @@ describe OmniAuth::Strategies::GoogleOauth2 do
349
361
  before { allow(subject).to receive(:access_token).and_return(access_token) }
350
362
 
351
363
  describe 'id_token' do
352
- shared_examples 'id_token issued by valid issuer' do |issuer| # rubocop:disable Metrics/BlockLength
364
+ shared_examples 'id_token issued by valid issuer' do |issuer|
353
365
  context 'when the id_token is passed into the access token' do
354
366
  let(:token_info) do
355
367
  {
@@ -462,6 +474,12 @@ describe OmniAuth::Strategies::GoogleOauth2 do
462
474
  expect(subject.info[:image]).to eq('https://lh3.googleusercontent.com/url/s50/photo.jpg')
463
475
  end
464
476
 
477
+ it 'should return the image with size specified in the `image_size` option when sizing is in the picture' do
478
+ @options = { image_size: 50 }
479
+ allow(subject).to receive(:raw_info) { { 'picture' => 'https://lh4.googleusercontent.com/url/s96-c/photo.jpg' } }
480
+ expect(subject.info[:image]).to eq('https://lh4.googleusercontent.com/url/s50/photo.jpg')
481
+ end
482
+
465
483
  it 'should handle a picture with too many slashes correctly' do
466
484
  @options = { image_size: 50 }
467
485
  allow(subject).to receive(:raw_info) { { 'picture' => 'https://lh3.googleusercontent.com/url//photo.jpg' } }
@@ -492,24 +510,48 @@ describe OmniAuth::Strategies::GoogleOauth2 do
492
510
  expect(subject.info[:image]).to eq('https://lh3.googleusercontent.com/url/w50-h40/photo.jpg')
493
511
  end
494
512
 
513
+ it 'should return the image with width and height specified in the `image_size` option when sizing is in the picture' do
514
+ @options = { image_size: { width: 50, height: 40 } }
515
+ allow(subject).to receive(:raw_info) { { 'picture' => 'https://lh3.googleusercontent.com/url/w100-h80-c/photo.jpg' } }
516
+ expect(subject.info[:image]).to eq('https://lh3.googleusercontent.com/url/w50-h40/photo.jpg')
517
+ end
518
+
495
519
  it 'should return square image when `image_aspect_ratio` is specified' do
496
520
  @options = { image_aspect_ratio: 'square' }
497
521
  allow(subject).to receive(:raw_info) { { 'picture' => 'https://lh3.googleusercontent.com/url/photo.jpg' } }
498
522
  expect(subject.info[:image]).to eq('https://lh3.googleusercontent.com/url/c/photo.jpg')
499
523
  end
500
524
 
525
+ it 'should return square image when `image_aspect_ratio` is specified and sizing is in the picture' do
526
+ @options = { image_aspect_ratio: 'square' }
527
+ allow(subject).to receive(:raw_info) { { 'picture' => 'https://lh3.googleusercontent.com/url/c/photo.jpg' } }
528
+ expect(subject.info[:image]).to eq('https://lh3.googleusercontent.com/url/c/photo.jpg')
529
+ end
530
+
501
531
  it 'should return square sized image when `image_aspect_ratio` and `image_size` is set' do
502
532
  @options = { image_aspect_ratio: 'square', image_size: 50 }
503
533
  allow(subject).to receive(:raw_info) { { 'picture' => 'https://lh3.googleusercontent.com/url/photo.jpg' } }
504
534
  expect(subject.info[:image]).to eq('https://lh3.googleusercontent.com/url/s50-c/photo.jpg')
505
535
  end
506
536
 
537
+ it 'should return square sized image when `image_aspect_ratio` and `image_size` is set and sizing is in the picture' do
538
+ @options = { image_aspect_ratio: 'square', image_size: 50 }
539
+ allow(subject).to receive(:raw_info) { { 'picture' => 'https://lh3.googleusercontent.com/url/s90/photo.jpg' } }
540
+ expect(subject.info[:image]).to eq('https://lh3.googleusercontent.com/url/s50-c/photo.jpg')
541
+ end
542
+
507
543
  it 'should return square sized image when `image_aspect_ratio` and `image_size` has height and width' do
508
544
  @options = { image_aspect_ratio: 'square', image_size: { width: 50, height: 40 } }
509
545
  allow(subject).to receive(:raw_info) { { 'picture' => 'https://lh3.googleusercontent.com/url/photo.jpg' } }
510
546
  expect(subject.info[:image]).to eq('https://lh3.googleusercontent.com/url/w50-h40-c/photo.jpg')
511
547
  end
512
548
 
549
+ it 'should return square sized image when `image_aspect_ratio` and `image_size` has height and width and sizing is in the picture' do
550
+ @options = { image_aspect_ratio: 'square', image_size: { width: 50, height: 40 } }
551
+ allow(subject).to receive(:raw_info) { { 'picture' => 'https://lh3.googleusercontent.com/url/w100-h80/photo.jpg' } }
552
+ expect(subject.info[:image]).to eq('https://lh3.googleusercontent.com/url/w50-h40-c/photo.jpg')
553
+ end
554
+
513
555
  it 'should return original image if image url does not end in `photo.jpg`' do
514
556
  @options = { image_size: 50 }
515
557
  allow(subject).to receive(:raw_info) { { 'picture' => 'https://lh3.googleusercontent.com/url/photograph.jpg' } }
@@ -599,6 +641,22 @@ describe OmniAuth::Strategies::GoogleOauth2 do
599
641
  subject.build_access_token
600
642
  end
601
643
 
644
+ it 'reads the access token from a json request body' do
645
+ body = StringIO.new(%({"access_token":"valid_access_token"}))
646
+
647
+ allow(request).to receive(:xhr?).and_return(false)
648
+ allow(request).to receive(:content_type).and_return('application/json')
649
+ allow(request).to receive(:body).and_return(body)
650
+ expect(subject).to receive(:client).and_return(:client)
651
+
652
+ expect(subject).to receive(:verify_token).with('valid_access_token').and_return true
653
+
654
+ token = subject.build_access_token
655
+ expect(token).to be_instance_of(::OAuth2::AccessToken)
656
+ expect(token.token).to eq('valid_access_token')
657
+ expect(token.client).to eq(:client)
658
+ end
659
+
602
660
  it 'should use callback_url without query_string if this is not an AJAX request' do
603
661
  allow(request).to receive(:xhr?).and_return(false)
604
662
  allow(request).to receive(:params).and_return('code' => 'valid_code')
metadata CHANGED
@@ -1,15 +1,15 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: omniauth-google-oauth2
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.8.0
4
+ version: 1.0.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Josh Ellithorpe
8
8
  - Yury Korolev
9
- autorequire:
9
+ autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2019-08-22 00:00:00.000000000 Z
12
+ date: 2021-03-15 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: jwt
@@ -25,34 +25,48 @@ dependencies:
25
25
  - - ">="
26
26
  - !ruby/object:Gem::Version
27
27
  version: '2.0'
28
+ - !ruby/object:Gem::Dependency
29
+ name: oauth2
30
+ requirement: !ruby/object:Gem::Requirement
31
+ requirements:
32
+ - - "~>"
33
+ - !ruby/object:Gem::Version
34
+ version: '1.1'
35
+ type: :runtime
36
+ prerelease: false
37
+ version_requirements: !ruby/object:Gem::Requirement
38
+ requirements:
39
+ - - "~>"
40
+ - !ruby/object:Gem::Version
41
+ version: '1.1'
28
42
  - !ruby/object:Gem::Dependency
29
43
  name: omniauth
30
44
  requirement: !ruby/object:Gem::Requirement
31
45
  requirements:
32
- - - ">="
46
+ - - "~>"
33
47
  - !ruby/object:Gem::Version
34
- version: 1.1.1
48
+ version: '2.0'
35
49
  type: :runtime
36
50
  prerelease: false
37
51
  version_requirements: !ruby/object:Gem::Requirement
38
52
  requirements:
39
- - - ">="
53
+ - - "~>"
40
54
  - !ruby/object:Gem::Version
41
- version: 1.1.1
55
+ version: '2.0'
42
56
  - !ruby/object:Gem::Dependency
43
57
  name: omniauth-oauth2
44
58
  requirement: !ruby/object:Gem::Requirement
45
59
  requirements:
46
- - - ">="
60
+ - - "~>"
47
61
  - !ruby/object:Gem::Version
48
- version: '1.6'
62
+ version: 1.7.1
49
63
  type: :runtime
50
64
  prerelease: false
51
65
  version_requirements: !ruby/object:Gem::Requirement
52
66
  requirements:
53
- - - ">="
67
+ - - "~>"
54
68
  - !ruby/object:Gem::Version
55
- version: '1.6'
69
+ version: 1.7.1
56
70
  - !ruby/object:Gem::Dependency
57
71
  name: rake
58
72
  requirement: !ruby/object:Gem::Requirement
@@ -125,7 +139,7 @@ homepage: https://github.com/zquestz/omniauth-google-oauth2
125
139
  licenses:
126
140
  - MIT
127
141
  metadata: {}
128
- post_install_message:
142
+ post_install_message:
129
143
  rdoc_options: []
130
144
  require_paths:
131
145
  - lib
@@ -140,9 +154,9 @@ required_rubygems_version: !ruby/object:Gem::Requirement
140
154
  - !ruby/object:Gem::Version
141
155
  version: '0'
142
156
  requirements: []
143
- rubyforge_project:
157
+ rubyforge_project:
144
158
  rubygems_version: 2.7.9
145
- signing_key:
159
+ signing_key:
146
160
  specification_version: 4
147
161
  summary: A Google OAuth2 strategy for OmniAuth 1.x
148
162
  test_files: []