omniauth-google-oauth2 0.2.10 → 0.3.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 +4 -4
- data/CHANGELOG.md +14 -0
- data/README.md +3 -3
- data/examples/omni_auth.rb +0 -2
- data/lib/omniauth/google_oauth2/version.rb +1 -1
- data/lib/omniauth/strategies/google_oauth2.rb +8 -4
- data/omniauth-google-oauth2.gemspec +1 -1
- data/spec/omniauth/strategies/google_oauth2_spec.rb +25 -13
- metadata +5 -5
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA1:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: c7d06ea95829577b987b0c3f38361bbf0d53ac9c
         | 
| 4 | 
            +
              data.tar.gz: ddade281a6be78eb43318effaee6fe1eb0c748ca
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: 8515c0e13e3eeb43fb96b53ffd989126044dddf06c3f6e510b903eee69edc49cde9915e82d547fe77004124c5dbd6eec1166a3cbe78b1e9795a56228df540c9e
         | 
| 7 | 
            +
              data.tar.gz: 41c8b9757efade6cf94c50f29d564c94286f2debb2bb8ed9983923d964b3a6076debb238a02cb92488cd590d6937a8c8b583305076d88be59aa7146c86f8132f
         | 
    
        data/CHANGELOG.md
    CHANGED
    
    | @@ -1,6 +1,20 @@ | |
| 1 1 | 
             
            # Changelog
         | 
| 2 2 | 
             
            All notable changes to this project will be documented in this file.
         | 
| 3 3 |  | 
| 4 | 
            +
            ## 0.3.0 - 2016-01-09
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            ### Added
         | 
| 7 | 
            +
            - Updated verify_token to use the v3 tokeninfo endpoint.
         | 
| 8 | 
            +
             | 
| 9 | 
            +
            ### Deprecated
         | 
| 10 | 
            +
            - Nothing.
         | 
| 11 | 
            +
             | 
| 12 | 
            +
            ### Removed
         | 
| 13 | 
            +
            - Nothing.
         | 
| 14 | 
            +
             | 
| 15 | 
            +
            ### Fixed
         | 
| 16 | 
            +
            - Compatibility with omniauth-oauth2 1.4.0
         | 
| 17 | 
            +
             | 
| 4 18 | 
             
            ## 0.2.10 - 2015-11-05
         | 
| 5 19 |  | 
| 6 20 | 
             
            ### Added
         | 
    
        data/README.md
    CHANGED
    
    | @@ -67,7 +67,7 @@ You can configure several options, which you pass in to the `provider` method vi | |
| 67 67 |  | 
| 68 68 | 
             
            * `name`: The name of the strategy. The default name is `google_oauth2` but it can be changed to any value, for example `google`. The OmniAuth URL will thus change to `/auth/google` and the `provider` key in the auth hash will then return `google`.
         | 
| 69 69 |  | 
| 70 | 
            -
            * `access_type`: Defaults to `offline`, so a refresh token is sent to be used when the user is not present at the browser. Can be set to `online`.  | 
| 70 | 
            +
            * `access_type`: Defaults to `offline`, so a refresh token is sent to be used when the user is not present at the browser. Can be set to `online`. More about [offline access](https://developers.google.com/identity/protocols/OAuth2WebServer#offline)
         | 
| 71 71 |  | 
| 72 72 | 
             
            * `hd`: (Optional) Limit sign-in to a particular Google Apps hosted domain.  More information at: https://developers.google.com/accounts/docs/OpenIDConnect#hd-param
         | 
| 73 73 |  | 
| @@ -245,8 +245,8 @@ window.gpAsyncInit = function() { | |
| 245 245 | 
             
                }, function(response) {
         | 
| 246 246 | 
             
                  if (response && !response.error) {
         | 
| 247 247 | 
             
                    // google authentication succeed, now post data to server and handle data securely
         | 
| 248 | 
            -
                    jQuery.ajax({type: 'POST', url: "/auth/google_oauth2/callback",  | 
| 249 | 
            -
                      success: function( | 
| 248 | 
            +
                    jQuery.ajax({type: 'POST', url: "/auth/google_oauth2/callback", data: response,
         | 
| 249 | 
            +
                      success: function(data) {
         | 
| 250 250 | 
             
                        // response from server
         | 
| 251 251 | 
             
                      }
         | 
| 252 252 | 
             
                    });
         | 
    
        data/examples/omni_auth.rb
    CHANGED
    
    | @@ -11,11 +11,9 @@ Rails.application.config.middleware.use OmniAuth::Builder do | |
| 11 11 | 
             
              }
         | 
| 12 12 |  | 
| 13 13 | 
             
              # Manual setup for offline access with a refresh token.
         | 
| 14 | 
            -
              # The prompt must be set to 'consent'
         | 
| 15 14 | 
             
              #
         | 
| 16 15 | 
             
              # provider :google_oauth2, ENV['GOOGLE_KEY'], ENV['GOOGLE_SECRET'], {
         | 
| 17 16 | 
             
              #   :access_type => 'offline',
         | 
| 18 | 
            -
              #   :prompt => 'consent'
         | 
| 19 17 | 
             
              # }
         | 
| 20 18 |  | 
| 21 19 | 
             
              # Custom scope supporting youtube. If you are customizing scopes, remember
         | 
| @@ -100,14 +100,18 @@ module OmniAuth | |
| 100 100 | 
             
                    elsif verify_token(request.params['access_token'])
         | 
| 101 101 | 
             
                      ::OAuth2::AccessToken.from_hash(client, request.params.dup)
         | 
| 102 102 | 
             
                    else
         | 
| 103 | 
            -
                       | 
| 103 | 
            +
                      verifier = request.params["code"]
         | 
| 104 | 
            +
                      client.auth_code.get_token(verifier, get_token_options(callback_url), deep_symbolize(options.auth_token_params))
         | 
| 104 105 | 
             
                    end
         | 
| 105 106 | 
             
                  end
         | 
| 106 | 
            -
                  alias_method :orig_build_access_token, :build_access_token
         | 
| 107 107 | 
             
                  alias_method :build_access_token, :custom_build_access_token
         | 
| 108 108 |  | 
| 109 109 | 
             
                  private
         | 
| 110 110 |  | 
| 111 | 
            +
                  def callback_url
         | 
| 112 | 
            +
                    options[:redirect_uri] || (full_host + script_name + callback_path)
         | 
| 113 | 
            +
                  end
         | 
| 114 | 
            +
             | 
| 111 115 | 
             
                  def get_token_options(redirect_uri)
         | 
| 112 116 | 
             
                    { :redirect_uri => redirect_uri }.merge(token_params.to_hash(:symbolize_keys => true))
         | 
| 113 117 | 
             
                  end
         | 
| @@ -171,9 +175,9 @@ module OmniAuth | |
| 171 175 |  | 
| 172 176 | 
             
                  def verify_token(access_token)
         | 
| 173 177 | 
             
                    return false unless access_token
         | 
| 174 | 
            -
                    raw_response = client.request(:get, 'https://www.googleapis.com/oauth2/ | 
| 178 | 
            +
                    raw_response = client.request(:get, 'https://www.googleapis.com/oauth2/v3/tokeninfo',
         | 
| 175 179 | 
             
                                                  params: { access_token: access_token }).parsed
         | 
| 176 | 
            -
                    raw_response[' | 
| 180 | 
            +
                    raw_response['aud'] == options.client_id
         | 
| 177 181 | 
             
                  end
         | 
| 178 182 | 
             
                end
         | 
| 179 183 | 
             
              end
         | 
| @@ -15,7 +15,7 @@ Gem::Specification.new do |gem| | |
| 15 15 | 
             
              gem.require_paths = ["lib"]
         | 
| 16 16 |  | 
| 17 17 | 
             
              gem.add_runtime_dependency 'omniauth', '>= 1.1.1'
         | 
| 18 | 
            -
              gem.add_runtime_dependency 'omniauth-oauth2', ' | 
| 18 | 
            +
              gem.add_runtime_dependency 'omniauth-oauth2', '>= 1.3.1'
         | 
| 19 19 | 
             
              gem.add_runtime_dependency 'jwt', '~> 1.0'
         | 
| 20 20 | 
             
              gem.add_runtime_dependency 'multi_json', '~> 1.3'
         | 
| 21 21 | 
             
              gem.add_runtime_dependency 'addressable', '~> 2.3'
         | 
| @@ -255,9 +255,15 @@ describe OmniAuth::Strategies::GoogleOauth2 do | |
| 255 255 | 
             
              end
         | 
| 256 256 |  | 
| 257 257 | 
             
              describe '#callback_path' do
         | 
| 258 | 
            -
                it 'has the correct callback path' do
         | 
| 258 | 
            +
                it 'has the correct default callback path' do
         | 
| 259 259 | 
             
                  expect(subject.callback_path).to eq('/auth/google_oauth2/callback')
         | 
| 260 260 | 
             
                end
         | 
| 261 | 
            +
             | 
| 262 | 
            +
                it 'should set the callback_path parameter if present' do
         | 
| 263 | 
            +
                  @options = {:callback_path => '/auth/foo/callback'}
         | 
| 264 | 
            +
                  expect(subject.callback_path).to eq('/auth/foo/callback')
         | 
| 265 | 
            +
                end
         | 
| 266 | 
            +
             | 
| 261 267 | 
             
              end
         | 
| 262 268 |  | 
| 263 269 | 
             
              describe '#extra' do
         | 
| @@ -531,10 +537,17 @@ describe OmniAuth::Strategies::GoogleOauth2 do | |
| 531 537 | 
             
                  expect(token.client).to eq(:client)
         | 
| 532 538 | 
             
                end
         | 
| 533 539 |  | 
| 534 | 
            -
                it 'should  | 
| 540 | 
            +
                it 'should use callback_url without query_string if this is not an AJAX request' do
         | 
| 535 541 | 
             
                  allow(request).to receive(:xhr?).and_return(false)
         | 
| 536 542 | 
             
                  allow(request).to receive(:params).and_return('code' => 'valid_code')
         | 
| 537 | 
            -
             | 
| 543 | 
            +
             | 
| 544 | 
            +
                  client = double(:client)
         | 
| 545 | 
            +
                  auth_code = double(:auth_code)
         | 
| 546 | 
            +
                  allow(client).to receive(:auth_code).and_return(auth_code)
         | 
| 547 | 
            +
                  allow(subject).to receive(:callback_url).and_return('redirect_uri_without_query_string')
         | 
| 548 | 
            +
             | 
| 549 | 
            +
                  expect(subject).to receive(:client).and_return(client)
         | 
| 550 | 
            +
                  expect(auth_code).to receive(:get_token).with('valid_code', { :redirect_uri => 'redirect_uri_without_query_string'}, {})
         | 
| 538 551 | 
             
                  subject.build_access_token
         | 
| 539 552 | 
             
                end
         | 
| 540 553 | 
             
              end
         | 
| @@ -544,19 +557,18 @@ describe OmniAuth::Strategies::GoogleOauth2 do | |
| 544 557 | 
             
                  subject.options.client_options[:connection_build] = proc do |builder|
         | 
| 545 558 | 
             
                    builder.request :url_encoded
         | 
| 546 559 | 
             
                    builder.adapter :test do |stub|
         | 
| 547 | 
            -
                      stub.get('/oauth2/ | 
| 560 | 
            +
                      stub.get('/oauth2/v3/tokeninfo?access_token=valid_access_token') do |env|
         | 
| 548 561 | 
             
                        [200, {'Content-Type' => 'application/json; charset=UTF-8'}, MultiJson.encode(
         | 
| 549 | 
            -
                          : | 
| 550 | 
            -
                          : | 
| 551 | 
            -
                          : | 
| 552 | 
            -
                          : | 
| 553 | 
            -
                          : | 
| 554 | 
            -
                          : | 
| 555 | 
            -
                          : | 
| 556 | 
            -
                          :access_type => 'online'
         | 
| 562 | 
            +
                          :aud => "000000000000.apps.googleusercontent.com",
         | 
| 563 | 
            +
                          :sub => "123456789",
         | 
| 564 | 
            +
                          :email_verified => "true",
         | 
| 565 | 
            +
                          :email => "example@example.com",
         | 
| 566 | 
            +
                          :access_type => "offline",
         | 
| 567 | 
            +
                          :scope => "profile email",
         | 
| 568 | 
            +
                          :expires_in => 436
         | 
| 557 569 | 
             
                        )]
         | 
| 558 570 | 
             
                      end
         | 
| 559 | 
            -
                      stub.get('/oauth2/ | 
| 571 | 
            +
                      stub.get('/oauth2/v3/tokeninfo?access_token=invalid_access_token') do |env|
         | 
| 560 572 | 
             
                        [400, {'Content-Type' => 'application/json; charset=UTF-8'}, MultiJson.encode(:error_description => 'Invalid Value')]
         | 
| 561 573 | 
             
                      end
         | 
| 562 574 | 
             
                    end
         | 
    
        metadata
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: omniauth-google-oauth2
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 0. | 
| 4 | 
            +
              version: 0.3.0
         | 
| 5 5 | 
             
            platform: ruby
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - Josh Ellithorpe
         | 
| @@ -9,7 +9,7 @@ authors: | |
| 9 9 | 
             
            autorequire: 
         | 
| 10 10 | 
             
            bindir: bin
         | 
| 11 11 | 
             
            cert_chain: []
         | 
| 12 | 
            -
            date:  | 
| 12 | 
            +
            date: 2016-01-09 00:00:00.000000000 Z
         | 
| 13 13 | 
             
            dependencies:
         | 
| 14 14 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 15 15 | 
             
              name: omniauth
         | 
| @@ -29,14 +29,14 @@ dependencies: | |
| 29 29 | 
             
              name: omniauth-oauth2
         | 
| 30 30 | 
             
              requirement: !ruby/object:Gem::Requirement
         | 
| 31 31 | 
             
                requirements:
         | 
| 32 | 
            -
                - - " | 
| 32 | 
            +
                - - ">="
         | 
| 33 33 | 
             
                  - !ruby/object:Gem::Version
         | 
| 34 34 | 
             
                    version: 1.3.1
         | 
| 35 35 | 
             
              type: :runtime
         | 
| 36 36 | 
             
              prerelease: false
         | 
| 37 37 | 
             
              version_requirements: !ruby/object:Gem::Requirement
         | 
| 38 38 | 
             
                requirements:
         | 
| 39 | 
            -
                - - " | 
| 39 | 
            +
                - - ">="
         | 
| 40 40 | 
             
                  - !ruby/object:Gem::Version
         | 
| 41 41 | 
             
                    version: 1.3.1
         | 
| 42 42 | 
             
            - !ruby/object:Gem::Dependency
         | 
| @@ -152,7 +152,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement | |
| 152 152 | 
             
                  version: '0'
         | 
| 153 153 | 
             
            requirements: []
         | 
| 154 154 | 
             
            rubyforge_project: 
         | 
| 155 | 
            -
            rubygems_version: 2. | 
| 155 | 
            +
            rubygems_version: 2.5.1
         | 
| 156 156 | 
             
            signing_key: 
         | 
| 157 157 | 
             
            specification_version: 4
         | 
| 158 158 | 
             
            summary: A Google OAuth2 strategy for OmniAuth 1.x
         |