omniauth-myapps 0.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (44) hide show
  1. data/MIT-LICENSE +20 -0
  2. data/README.rdoc +3 -0
  3. data/Rakefile +32 -0
  4. data/lib/omniauth_myapps/version.rb +3 -0
  5. data/lib/omniauth_myapps.rb +8 -0
  6. data/lib/strategies/oauth2.rb +206 -0
  7. data/lib/tasks/omniauth_myapps_tasks.rake +5 -0
  8. data/test/dummy/README.rdoc +28 -0
  9. data/test/dummy/Rakefile +6 -0
  10. data/test/dummy/app/assets/javascripts/application.js +13 -0
  11. data/test/dummy/app/assets/stylesheets/application.css +15 -0
  12. data/test/dummy/app/controllers/application_controller.rb +5 -0
  13. data/test/dummy/app/helpers/application_helper.rb +2 -0
  14. data/test/dummy/app/views/layouts/application.html.erb +14 -0
  15. data/test/dummy/bin/bundle +3 -0
  16. data/test/dummy/bin/rails +4 -0
  17. data/test/dummy/bin/rake +4 -0
  18. data/test/dummy/config/application.rb +23 -0
  19. data/test/dummy/config/boot.rb +5 -0
  20. data/test/dummy/config/database.yml +25 -0
  21. data/test/dummy/config/environment.rb +5 -0
  22. data/test/dummy/config/environments/development.rb +37 -0
  23. data/test/dummy/config/environments/production.rb +82 -0
  24. data/test/dummy/config/environments/test.rb +39 -0
  25. data/test/dummy/config/initializers/assets.rb +8 -0
  26. data/test/dummy/config/initializers/backtrace_silencers.rb +7 -0
  27. data/test/dummy/config/initializers/cookies_serializer.rb +3 -0
  28. data/test/dummy/config/initializers/filter_parameter_logging.rb +4 -0
  29. data/test/dummy/config/initializers/inflections.rb +16 -0
  30. data/test/dummy/config/initializers/mime_types.rb +4 -0
  31. data/test/dummy/config/initializers/session_store.rb +3 -0
  32. data/test/dummy/config/initializers/wrap_parameters.rb +14 -0
  33. data/test/dummy/config/locales/en.yml +23 -0
  34. data/test/dummy/config/routes.rb +56 -0
  35. data/test/dummy/config/secrets.yml +22 -0
  36. data/test/dummy/config.ru +4 -0
  37. data/test/dummy/public/404.html +67 -0
  38. data/test/dummy/public/422.html +67 -0
  39. data/test/dummy/public/500.html +66 -0
  40. data/test/dummy/public/favicon.ico +0 -0
  41. data/test/omniauth_myapps_test.rb +7 -0
  42. data/test/strategies/oauth2_spec.rb +98 -0
  43. data/test/test_helper.rb +44 -0
  44. metadata +220 -0
@@ -0,0 +1,4 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Add new mime types for use in respond_to blocks:
4
+ # Mime::Type.register "text/richtext", :rtf
@@ -0,0 +1,3 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ Rails.application.config.session_store :cookie_store, key: '_dummy_session'
@@ -0,0 +1,14 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # This file contains settings for ActionController::ParamsWrapper which
4
+ # is enabled by default.
5
+
6
+ # Enable parameter wrapping for JSON. You can disable this by setting :format to an empty array.
7
+ ActiveSupport.on_load(:action_controller) do
8
+ wrap_parameters format: [:json] if respond_to?(:wrap_parameters)
9
+ end
10
+
11
+ # To enable root element in JSON for ActiveRecord objects.
12
+ # ActiveSupport.on_load(:active_record) do
13
+ # self.include_root_in_json = true
14
+ # end
@@ -0,0 +1,23 @@
1
+ # Files in the config/locales directory are used for internationalization
2
+ # and are automatically loaded by Rails. If you want to use locales other
3
+ # than English, add the necessary files in this directory.
4
+ #
5
+ # To use the locales, use `I18n.t`:
6
+ #
7
+ # I18n.t 'hello'
8
+ #
9
+ # In views, this is aliased to just `t`:
10
+ #
11
+ # <%= t('hello') %>
12
+ #
13
+ # To use a different locale, set it with `I18n.locale`:
14
+ #
15
+ # I18n.locale = :es
16
+ #
17
+ # This would use the information in config/locales/es.yml.
18
+ #
19
+ # To learn more, please read the Rails Internationalization guide
20
+ # available at http://guides.rubyonrails.org/i18n.html.
21
+
22
+ en:
23
+ hello: "Hello world"
@@ -0,0 +1,56 @@
1
+ Rails.application.routes.draw do
2
+ # The priority is based upon order of creation: first created -> highest priority.
3
+ # See how all your routes lay out with "rake routes".
4
+
5
+ # You can have the root of your site routed with "root"
6
+ # root 'welcome#index'
7
+
8
+ # Example of regular route:
9
+ # get 'products/:id' => 'catalog#view'
10
+
11
+ # Example of named route that can be invoked with purchase_url(id: product.id)
12
+ # get 'products/:id/purchase' => 'catalog#purchase', as: :purchase
13
+
14
+ # Example resource route (maps HTTP verbs to controller actions automatically):
15
+ # resources :products
16
+
17
+ # Example resource route with options:
18
+ # resources :products do
19
+ # member do
20
+ # get 'short'
21
+ # post 'toggle'
22
+ # end
23
+ #
24
+ # collection do
25
+ # get 'sold'
26
+ # end
27
+ # end
28
+
29
+ # Example resource route with sub-resources:
30
+ # resources :products do
31
+ # resources :comments, :sales
32
+ # resource :seller
33
+ # end
34
+
35
+ # Example resource route with more complex sub-resources:
36
+ # resources :products do
37
+ # resources :comments
38
+ # resources :sales do
39
+ # get 'recent', on: :collection
40
+ # end
41
+ # end
42
+
43
+ # Example resource route with concerns:
44
+ # concern :toggleable do
45
+ # post 'toggle'
46
+ # end
47
+ # resources :posts, concerns: :toggleable
48
+ # resources :photos, concerns: :toggleable
49
+
50
+ # Example resource route within a namespace:
51
+ # namespace :admin do
52
+ # # Directs /admin/products/* to Admin::ProductsController
53
+ # # (app/controllers/admin/products_controller.rb)
54
+ # resources :products
55
+ # end
56
+ end
@@ -0,0 +1,22 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Your secret key is used for verifying the integrity of signed cookies.
4
+ # If you change this key, all old signed cookies will become invalid!
5
+
6
+ # Make sure the secret is at least 30 characters and all random,
7
+ # no regular words or you'll be exposed to dictionary attacks.
8
+ # You can use `rake secret` to generate a secure secret key.
9
+
10
+ # Make sure the secrets in this file are kept private
11
+ # if you're sharing your code publicly.
12
+
13
+ development:
14
+ secret_key_base: 92f8ad6d725d5c6904fb486995fac409bd767e007a99ccfaef09ba59083ededb68aa233a8087b4ff02c0df469c032cd61733309b2f29ecc57e86c7ec0e2caa93
15
+
16
+ test:
17
+ secret_key_base: 9622994d51a4bcf6878f8330400aea55e6ded53118d161a3fd3a23e87bfaca21ade0815e5cadd1f9b414127d55d67f4346e19a385d68ca66570eaaf661e13f84
18
+
19
+ # Do not keep production secrets in the repository,
20
+ # instead read values from the environment.
21
+ production:
22
+ secret_key_base: <%= ENV["SECRET_KEY_BASE"] %>
@@ -0,0 +1,4 @@
1
+ # This file is used by Rack-based servers to start the application.
2
+
3
+ require ::File.expand_path('../config/environment', __FILE__)
4
+ run Rails.application
@@ -0,0 +1,67 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>The page you were looking for doesn't exist (404)</title>
5
+ <meta name="viewport" content="width=device-width,initial-scale=1">
6
+ <style>
7
+ body {
8
+ background-color: #EFEFEF;
9
+ color: #2E2F30;
10
+ text-align: center;
11
+ font-family: arial, sans-serif;
12
+ margin: 0;
13
+ }
14
+
15
+ div.dialog {
16
+ width: 95%;
17
+ max-width: 33em;
18
+ margin: 4em auto 0;
19
+ }
20
+
21
+ div.dialog > div {
22
+ border: 1px solid #CCC;
23
+ border-right-color: #999;
24
+ border-left-color: #999;
25
+ border-bottom-color: #BBB;
26
+ border-top: #B00100 solid 4px;
27
+ border-top-left-radius: 9px;
28
+ border-top-right-radius: 9px;
29
+ background-color: white;
30
+ padding: 7px 12% 0;
31
+ box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
32
+ }
33
+
34
+ h1 {
35
+ font-size: 100%;
36
+ color: #730E15;
37
+ line-height: 1.5em;
38
+ }
39
+
40
+ div.dialog > p {
41
+ margin: 0 0 1em;
42
+ padding: 1em;
43
+ background-color: #F7F7F7;
44
+ border: 1px solid #CCC;
45
+ border-right-color: #999;
46
+ border-left-color: #999;
47
+ border-bottom-color: #999;
48
+ border-bottom-left-radius: 4px;
49
+ border-bottom-right-radius: 4px;
50
+ border-top-color: #DADADA;
51
+ color: #666;
52
+ box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
53
+ }
54
+ </style>
55
+ </head>
56
+
57
+ <body>
58
+ <!-- This file lives in public/404.html -->
59
+ <div class="dialog">
60
+ <div>
61
+ <h1>The page you were looking for doesn't exist.</h1>
62
+ <p>You may have mistyped the address or the page may have moved.</p>
63
+ </div>
64
+ <p>If you are the application owner check the logs for more information.</p>
65
+ </div>
66
+ </body>
67
+ </html>
@@ -0,0 +1,67 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>The change you wanted was rejected (422)</title>
5
+ <meta name="viewport" content="width=device-width,initial-scale=1">
6
+ <style>
7
+ body {
8
+ background-color: #EFEFEF;
9
+ color: #2E2F30;
10
+ text-align: center;
11
+ font-family: arial, sans-serif;
12
+ margin: 0;
13
+ }
14
+
15
+ div.dialog {
16
+ width: 95%;
17
+ max-width: 33em;
18
+ margin: 4em auto 0;
19
+ }
20
+
21
+ div.dialog > div {
22
+ border: 1px solid #CCC;
23
+ border-right-color: #999;
24
+ border-left-color: #999;
25
+ border-bottom-color: #BBB;
26
+ border-top: #B00100 solid 4px;
27
+ border-top-left-radius: 9px;
28
+ border-top-right-radius: 9px;
29
+ background-color: white;
30
+ padding: 7px 12% 0;
31
+ box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
32
+ }
33
+
34
+ h1 {
35
+ font-size: 100%;
36
+ color: #730E15;
37
+ line-height: 1.5em;
38
+ }
39
+
40
+ div.dialog > p {
41
+ margin: 0 0 1em;
42
+ padding: 1em;
43
+ background-color: #F7F7F7;
44
+ border: 1px solid #CCC;
45
+ border-right-color: #999;
46
+ border-left-color: #999;
47
+ border-bottom-color: #999;
48
+ border-bottom-left-radius: 4px;
49
+ border-bottom-right-radius: 4px;
50
+ border-top-color: #DADADA;
51
+ color: #666;
52
+ box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
53
+ }
54
+ </style>
55
+ </head>
56
+
57
+ <body>
58
+ <!-- This file lives in public/422.html -->
59
+ <div class="dialog">
60
+ <div>
61
+ <h1>The change you wanted was rejected.</h1>
62
+ <p>Maybe you tried to change something you didn't have access to.</p>
63
+ </div>
64
+ <p>If you are the application owner check the logs for more information.</p>
65
+ </div>
66
+ </body>
67
+ </html>
@@ -0,0 +1,66 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>We're sorry, but something went wrong (500)</title>
5
+ <meta name="viewport" content="width=device-width,initial-scale=1">
6
+ <style>
7
+ body {
8
+ background-color: #EFEFEF;
9
+ color: #2E2F30;
10
+ text-align: center;
11
+ font-family: arial, sans-serif;
12
+ margin: 0;
13
+ }
14
+
15
+ div.dialog {
16
+ width: 95%;
17
+ max-width: 33em;
18
+ margin: 4em auto 0;
19
+ }
20
+
21
+ div.dialog > div {
22
+ border: 1px solid #CCC;
23
+ border-right-color: #999;
24
+ border-left-color: #999;
25
+ border-bottom-color: #BBB;
26
+ border-top: #B00100 solid 4px;
27
+ border-top-left-radius: 9px;
28
+ border-top-right-radius: 9px;
29
+ background-color: white;
30
+ padding: 7px 12% 0;
31
+ box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
32
+ }
33
+
34
+ h1 {
35
+ font-size: 100%;
36
+ color: #730E15;
37
+ line-height: 1.5em;
38
+ }
39
+
40
+ div.dialog > p {
41
+ margin: 0 0 1em;
42
+ padding: 1em;
43
+ background-color: #F7F7F7;
44
+ border: 1px solid #CCC;
45
+ border-right-color: #999;
46
+ border-left-color: #999;
47
+ border-bottom-color: #999;
48
+ border-bottom-left-radius: 4px;
49
+ border-bottom-right-radius: 4px;
50
+ border-top-color: #DADADA;
51
+ color: #666;
52
+ box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
53
+ }
54
+ </style>
55
+ </head>
56
+
57
+ <body>
58
+ <!-- This file lives in public/500.html -->
59
+ <div class="dialog">
60
+ <div>
61
+ <h1>We're sorry, but something went wrong.</h1>
62
+ </div>
63
+ <p>If you are the application owner check the logs for more information.</p>
64
+ </div>
65
+ </body>
66
+ </html>
File without changes
@@ -0,0 +1,7 @@
1
+ require 'test_helper'
2
+
3
+ class OmniauthMyappsTest < ActiveSupport::TestCase
4
+ test "truth" do
5
+ assert_kind_of Module, OmniauthMyapps
6
+ end
7
+ end
@@ -0,0 +1,98 @@
1
+ require 'helper'
2
+
3
+ describe OmniAuth::Strategies::OAuth2 do
4
+ def app
5
+ lambda do |_env|
6
+ [200, {}, ['Hello.']]
7
+ end
8
+ end
9
+ let(:fresh_strategy) { Class.new(OmniAuth::Strategies::OAuth2) }
10
+
11
+ before do
12
+ OmniAuth.config.test_mode = true
13
+ end
14
+
15
+ after do
16
+ OmniAuth.config.test_mode = false
17
+ end
18
+
19
+ describe '#client' do
20
+ subject { fresh_strategy }
21
+
22
+ it 'is initialized with symbolized client_options' do
23
+ instance = subject.new(app, :client_options => {'authorize_url' => 'https://example.com'})
24
+ expect(instance.client.options[:authorize_url]).to eq('https://example.com')
25
+ end
26
+
27
+ it 'sets ssl options as connection options' do
28
+ instance = subject.new(app, :client_options => {'ssl' => {'ca_path' => 'foo'}})
29
+ expect(instance.client.options[:connection_opts][:ssl]).to eq(:ca_path => 'foo')
30
+ end
31
+ end
32
+
33
+ describe '#authorize_params' do
34
+ subject { fresh_strategy }
35
+
36
+ it 'includes any authorize params passed in the :authorize_params option' do
37
+ instance = subject.new('abc', 'def', :authorize_params => {:foo => 'bar', :baz => 'zip'})
38
+ expect(instance.authorize_params['foo']).to eq('bar')
39
+ expect(instance.authorize_params['baz']).to eq('zip')
40
+ end
41
+
42
+ it 'includes top-level options that are marked as :authorize_options' do
43
+ instance = subject.new('abc', 'def', :authorize_options => [:scope, :foo, :state], :scope => 'bar', :foo => 'baz')
44
+ expect(instance.authorize_params['scope']).to eq('bar')
45
+ expect(instance.authorize_params['foo']).to eq('baz')
46
+ end
47
+
48
+ it 'includes random state in the authorize params' do
49
+ instance = subject.new('abc', 'def')
50
+ expect(instance.authorize_params.keys).to eq(['state'])
51
+ expect(instance.session['omniauth.state']).not_to be_empty
52
+ end
53
+ end
54
+
55
+ describe '#token_params' do
56
+ subject { fresh_strategy }
57
+
58
+ it 'includes any authorize params passed in the :authorize_params option' do
59
+ instance = subject.new('abc', 'def', :token_params => {:foo => 'bar', :baz => 'zip'})
60
+ expect(instance.token_params).to eq('foo' => 'bar', 'baz' => 'zip')
61
+ end
62
+
63
+ it 'includes top-level options that are marked as :authorize_options' do
64
+ instance = subject.new('abc', 'def', :token_options => [:scope, :foo], :scope => 'bar', :foo => 'baz')
65
+ expect(instance.token_params).to eq('scope' => 'bar', 'foo' => 'baz')
66
+ end
67
+ end
68
+
69
+ describe '#callback_phase' do
70
+ subject { fresh_strategy }
71
+ it 'calls fail with the client error received' do
72
+ instance = subject.new('abc', 'def')
73
+ allow(instance).to receive(:request) do
74
+ double('Request', :params => {'error_reason' => 'user_denied', 'error' => 'access_denied'})
75
+ end
76
+
77
+ expect(instance).to receive(:fail!).with('user_denied', anything)
78
+ instance.callback_phase
79
+ end
80
+ end
81
+ end
82
+
83
+ describe OmniAuth::Strategies::OAuth2::CallbackError do
84
+ let(:error) { Class.new(OmniAuth::Strategies::OAuth2::CallbackError) }
85
+ describe '#message' do
86
+ subject { error }
87
+ it 'includes all of the attributes' do
88
+ instance = subject.new('error', 'description', 'uri')
89
+ expect(instance.message).to match(/error/)
90
+ expect(instance.message).to match(/description/)
91
+ expect(instance.message).to match(/uri/)
92
+ end
93
+ it 'includes all of the attributes' do
94
+ instance = subject.new(nil, :symbol)
95
+ expect(instance.message).to eq('symbol')
96
+ end
97
+ end
98
+ end
@@ -0,0 +1,44 @@
1
+ # Configure Rails Environment
2
+ #ENV["RAILS_ENV"] = "test"
3
+
4
+ #require File.expand_path("../dummy/config/environment.rb", __FILE__)
5
+ #require "rails/test_help"
6
+
7
+ #Rails.backtrace_cleaner.remove_silencers!
8
+
9
+ # Load support files
10
+ #Dir["#{File.dirname(__FILE__)}/support/**/*.rb"].each { |f| require f }
11
+
12
+ # Load fixtures from the engine
13
+ #if ActiveSupport::TestCase.method_defined?(:fixture_path=)
14
+ # ActiveSupport::TestCase.fixture_path = File.expand_path("../fixtures", __FILE__)
15
+ #end
16
+
17
+ $LOAD_PATH.unshift File.expand_path('..', __FILE__)
18
+ $LOAD_PATH.unshift File.expand_path('../../lib', __FILE__)
19
+
20
+ if RUBY_VERSION >= '1.9'
21
+ require 'simplecov'
22
+ require 'coveralls'
23
+
24
+ SimpleCov.formatters = [SimpleCov::Formatter::HTMLFormatter, Coveralls::SimpleCov::Formatter]
25
+
26
+ SimpleCov.start do
27
+ minimum_coverage(76)
28
+ end
29
+ end
30
+
31
+ require 'rspec'
32
+ require 'rack/test'
33
+ require 'webmock/rspec'
34
+ require 'omniauth'
35
+ require 'omniauth-oauth2'
36
+
37
+ RSpec.configure do |config|
38
+ config.expect_with :rspec do |c|
39
+ c.syntax = :expect
40
+ end
41
+ config.extend OmniAuth::Test::StrategyMacros, :type => :strategy
42
+ config.include Rack::Test::Methods
43
+ config.include WebMock::API
44
+ end