sorcery 0.7.0 → 0.7.1

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of sorcery might be problematic. Click here for more details.

Files changed (164) hide show
  1. data/Gemfile +2 -1
  2. data/Gemfile.lock +58 -51
  3. data/README.rdoc +19 -57
  4. data/Rakefile +27 -1
  5. data/VERSION +1 -1
  6. data/lib/generators/sorcery/USAGE +22 -0
  7. data/lib/generators/sorcery/install_generator.rb +71 -0
  8. data/lib/{sorcery/initializers → generators/sorcery/templates}/initializer.rb +4 -4
  9. data/lib/generators/sorcery/templates/migration/activity_logging.rb +17 -0
  10. data/lib/generators/sorcery/templates/migration/brute_force_protection.rb +11 -0
  11. data/lib/generators/{sorcery_migration/templates → sorcery/templates/migration}/core.rb +2 -2
  12. data/lib/generators/{sorcery_migration/templates → sorcery/templates/migration}/external.rb +1 -1
  13. data/lib/generators/sorcery/templates/migration/remember_me.rb +15 -0
  14. data/lib/generators/sorcery/templates/migration/reset_password.rb +17 -0
  15. data/lib/generators/sorcery/templates/migration/user_activation.rb +17 -0
  16. data/lib/sorcery.rb +5 -7
  17. data/lib/sorcery/controller.rb +40 -39
  18. data/lib/sorcery/controller/submodules/activity_logging.rb +7 -10
  19. data/lib/sorcery/controller/submodules/external/protocols/oauth2.rb +23 -8
  20. data/lib/sorcery/controller/submodules/remember_me.rb +3 -2
  21. data/lib/sorcery/model.rb +21 -4
  22. data/lib/sorcery/model/adapters/mongo_mapper.rb +49 -0
  23. data/lib/sorcery/model/adapters/mongoid.rb +1 -1
  24. data/lib/sorcery/model/submodules/brute_force_protection.rb +8 -0
  25. data/lib/sorcery/model/submodules/remember_me.rb +8 -1
  26. data/lib/sorcery/model/submodules/reset_password.rb +10 -0
  27. data/lib/sorcery/model/submodules/user_activation.rb +12 -0
  28. data/sorcery.gemspec +86 -210
  29. data/spec/Gemfile +1 -1
  30. data/spec/Gemfile.lock +28 -15
  31. data/spec/README.md +6 -1
  32. data/spec/rails3/Gemfile +2 -2
  33. data/spec/rails3/Gemfile.lock +45 -50
  34. data/spec/rails3/spec/controller_oauth2_spec.rb +5 -3
  35. data/spec/rails3/spec/spec_helper.rb +1 -3
  36. data/spec/rails3_mongo_mapper/.gitignore +4 -0
  37. data/spec/rails3_mongo_mapper/.rspec +1 -0
  38. data/spec/{sinatra_modular → rails3_mongo_mapper}/Gemfile +5 -5
  39. data/spec/rails3_mongo_mapper/Gemfile.lock +159 -0
  40. data/spec/{sinatra → rails3_mongo_mapper}/Rakefile +3 -3
  41. data/spec/rails3_mongo_mapper/app/controllers/application_controller.rb +108 -0
  42. data/spec/rails3_mongo_mapper/app/helpers/application_helper.rb +2 -0
  43. data/spec/{sinatra → rails3_mongo_mapper/app/mailers}/sorcery_mailer.rb +0 -0
  44. data/spec/rails3_mongo_mapper/app/models/authentication.rb +6 -0
  45. data/spec/rails3_mongo_mapper/app/models/user.rb +5 -0
  46. data/spec/rails3_mongo_mapper/app/views/layouts/application.html.erb +14 -0
  47. data/spec/rails3_mongo_mapper/app/views/sorcery_mailer/activation_email.html.erb +17 -0
  48. data/spec/rails3_mongo_mapper/app/views/sorcery_mailer/activation_email.text.erb +9 -0
  49. data/spec/rails3_mongo_mapper/app/views/sorcery_mailer/activation_success_email.html.erb +17 -0
  50. data/spec/rails3_mongo_mapper/app/views/sorcery_mailer/activation_success_email.text.erb +9 -0
  51. data/spec/rails3_mongo_mapper/app/views/sorcery_mailer/reset_password_email.html.erb +16 -0
  52. data/spec/rails3_mongo_mapper/app/views/sorcery_mailer/reset_password_email.text.erb +8 -0
  53. data/spec/rails3_mongo_mapper/config.ru +4 -0
  54. data/spec/rails3_mongo_mapper/config/application.rb +51 -0
  55. data/spec/rails3_mongo_mapper/config/boot.rb +13 -0
  56. data/spec/rails3_mongo_mapper/config/environment.rb +5 -0
  57. data/spec/rails3_mongo_mapper/config/environments/development.rb +30 -0
  58. data/spec/rails3_mongo_mapper/config/environments/in_memory.rb +0 -0
  59. data/spec/rails3_mongo_mapper/config/environments/production.rb +49 -0
  60. data/spec/rails3_mongo_mapper/config/environments/test.rb +35 -0
  61. data/spec/rails3_mongo_mapper/config/initializers/backtrace_silencers.rb +7 -0
  62. data/spec/rails3_mongo_mapper/config/initializers/inflections.rb +10 -0
  63. data/spec/rails3_mongo_mapper/config/initializers/mime_types.rb +5 -0
  64. data/spec/rails3_mongo_mapper/config/initializers/mongo.rb +2 -0
  65. data/spec/rails3_mongo_mapper/config/initializers/secret_token.rb +7 -0
  66. data/spec/rails3_mongo_mapper/config/initializers/session_store.rb +8 -0
  67. data/spec/rails3_mongo_mapper/config/locales/en.yml +5 -0
  68. data/spec/rails3_mongo_mapper/config/routes.rb +59 -0
  69. data/spec/rails3_mongo_mapper/db/schema.rb +23 -0
  70. data/spec/rails3_mongo_mapper/db/seeds.rb +7 -0
  71. data/spec/rails3_mongo_mapper/lib/tasks/.gitkeep +0 -0
  72. data/spec/rails3_mongo_mapper/public/404.html +26 -0
  73. data/spec/rails3_mongo_mapper/public/422.html +26 -0
  74. data/spec/rails3_mongo_mapper/public/500.html +26 -0
  75. data/spec/rails3_mongo_mapper/public/favicon.ico +0 -0
  76. data/spec/rails3_mongo_mapper/public/images/rails.png +0 -0
  77. data/spec/rails3_mongo_mapper/public/javascripts/application.js +2 -0
  78. data/spec/rails3_mongo_mapper/public/javascripts/controls.js +965 -0
  79. data/spec/rails3_mongo_mapper/public/javascripts/dragdrop.js +974 -0
  80. data/spec/rails3_mongo_mapper/public/javascripts/effects.js +1123 -0
  81. data/spec/rails3_mongo_mapper/public/javascripts/prototype.js +6001 -0
  82. data/spec/rails3_mongo_mapper/public/javascripts/rails.js +175 -0
  83. data/spec/rails3_mongo_mapper/public/robots.txt +5 -0
  84. data/spec/rails3_mongo_mapper/public/stylesheets/.gitkeep +0 -0
  85. data/spec/rails3_mongo_mapper/script/rails +6 -0
  86. data/spec/{sinatra → rails3_mongo_mapper}/spec/controller_spec.rb +45 -42
  87. data/spec/{sinatra → rails3_mongo_mapper}/spec/spec.opts +0 -0
  88. data/spec/rails3_mongo_mapper/spec/spec_helper.orig.rb +27 -0
  89. data/spec/rails3_mongo_mapper/spec/spec_helper.rb +55 -0
  90. data/spec/rails3_mongo_mapper/spec/user_activation_spec.rb +9 -0
  91. data/spec/rails3_mongo_mapper/spec/user_activity_logging_spec.rb +8 -0
  92. data/spec/rails3_mongo_mapper/spec/user_brute_force_protection_spec.rb +8 -0
  93. data/spec/rails3_mongo_mapper/spec/user_oauth_spec.rb +8 -0
  94. data/spec/rails3_mongo_mapper/spec/user_remember_me_spec.rb +8 -0
  95. data/spec/rails3_mongo_mapper/spec/user_reset_password_spec.rb +8 -0
  96. data/spec/rails3_mongo_mapper/spec/user_spec.rb +37 -0
  97. data/spec/rails3_mongo_mapper/vendor/plugins/.gitkeep +0 -0
  98. data/spec/rails3_mongoid/Gemfile +1 -1
  99. data/spec/rails3_mongoid/Gemfile.lock +44 -35
  100. data/spec/rails3_mongoid/spec/controller_activity_logging_spec.rb +98 -0
  101. data/spec/rails3_mongoid/spec/user_spec.rb +1 -0
  102. data/spec/shared_examples/user_shared_examples.rb +29 -1
  103. metadata +124 -237
  104. data/lib/generators/sorcery_migration/sorcery_migration_generator.rb +0 -24
  105. data/lib/generators/sorcery_migration/templates/activity_logging.rb +0 -17
  106. data/lib/generators/sorcery_migration/templates/brute_force_protection.rb +0 -11
  107. data/lib/generators/sorcery_migration/templates/remember_me.rb +0 -15
  108. data/lib/generators/sorcery_migration/templates/reset_password.rb +0 -17
  109. data/lib/generators/sorcery_migration/templates/user_activation.rb +0 -17
  110. data/lib/sorcery/controller/adapters/sinatra.rb +0 -115
  111. data/lib/sorcery/sinatra.rb +0 -4
  112. data/lib/sorcery/test_helpers/internal/sinatra.rb +0 -74
  113. data/lib/sorcery/test_helpers/internal/sinatra_modular.rb +0 -74
  114. data/lib/sorcery/test_helpers/sinatra.rb +0 -88
  115. data/spec/rails3/Rakefile.unused +0 -7
  116. data/spec/sinatra/Gemfile +0 -15
  117. data/spec/sinatra/Gemfile.lock +0 -115
  118. data/spec/sinatra/authentication.rb +0 -3
  119. data/spec/sinatra/db/migrate/activation/20101224223622_add_activation_to_users.rb +0 -17
  120. data/spec/sinatra/db/migrate/activity_logging/20101224223624_add_activity_logging_to_users.rb +0 -17
  121. data/spec/sinatra/db/migrate/brute_force_protection/20101224223626_add_brute_force_protection_to_users.rb +0 -11
  122. data/spec/sinatra/db/migrate/core/20101224223620_create_users.rb +0 -16
  123. data/spec/sinatra/db/migrate/external/20101224223628_create_authentications.rb +0 -14
  124. data/spec/sinatra/db/migrate/remember_me/20101224223623_add_remember_me_token_to_users.rb +0 -15
  125. data/spec/sinatra/db/migrate/reset_password/20101224223622_add_reset_password_to_users.rb +0 -13
  126. data/spec/sinatra/filters.rb +0 -27
  127. data/spec/sinatra/modular.rb +0 -157
  128. data/spec/sinatra/myapp.rb +0 -133
  129. data/spec/sinatra/spec/controller_activity_logging_spec.rb +0 -85
  130. data/spec/sinatra/spec/controller_brute_force_protection_spec.rb +0 -70
  131. data/spec/sinatra/spec/controller_http_basic_auth_spec.rb +0 -53
  132. data/spec/sinatra/spec/controller_oauth2_spec.rb +0 -96
  133. data/spec/sinatra/spec/controller_oauth_spec.rb +0 -100
  134. data/spec/sinatra/spec/controller_remember_me_spec.rb +0 -64
  135. data/spec/sinatra/spec/controller_session_timeout_spec.rb +0 -57
  136. data/spec/sinatra/spec/spec_helper.rb +0 -45
  137. data/spec/sinatra/user.rb +0 -6
  138. data/spec/sinatra/views/test_login.erb +0 -4
  139. data/spec/sinatra_modular/Gemfile.lock +0 -115
  140. data/spec/sinatra_modular/Rakefile +0 -11
  141. data/spec/sinatra_modular/authentication.rb +0 -3
  142. data/spec/sinatra_modular/db/migrate/activation/20101224223622_add_activation_to_users.rb +0 -17
  143. data/spec/sinatra_modular/db/migrate/activity_logging/20101224223624_add_activity_logging_to_users.rb +0 -17
  144. data/spec/sinatra_modular/db/migrate/brute_force_protection/20101224223626_add_brute_force_protection_to_users.rb +0 -11
  145. data/spec/sinatra_modular/db/migrate/core/20101224223620_create_users.rb +0 -16
  146. data/spec/sinatra_modular/db/migrate/external/20101224223628_create_authentications.rb +0 -14
  147. data/spec/sinatra_modular/db/migrate/remember_me/20101224223623_add_remember_me_token_to_users.rb +0 -15
  148. data/spec/sinatra_modular/db/migrate/reset_password/20101224223622_add_reset_password_to_users.rb +0 -13
  149. data/spec/sinatra_modular/filters.rb +0 -27
  150. data/spec/sinatra_modular/modular.rb +0 -157
  151. data/spec/sinatra_modular/myapp.rb +0 -133
  152. data/spec/sinatra_modular/sorcery_mailer.rb +0 -25
  153. data/spec/sinatra_modular/spec_modular/controller_activity_logging_spec.rb +0 -85
  154. data/spec/sinatra_modular/spec_modular/controller_brute_force_protection_spec.rb +0 -70
  155. data/spec/sinatra_modular/spec_modular/controller_http_basic_auth_spec.rb +0 -53
  156. data/spec/sinatra_modular/spec_modular/controller_oauth2_spec.rb +0 -96
  157. data/spec/sinatra_modular/spec_modular/controller_oauth_spec.rb +0 -100
  158. data/spec/sinatra_modular/spec_modular/controller_remember_me_spec.rb +0 -64
  159. data/spec/sinatra_modular/spec_modular/controller_session_timeout_spec.rb +0 -57
  160. data/spec/sinatra_modular/spec_modular/controller_spec.rb +0 -116
  161. data/spec/sinatra_modular/spec_modular/spec.opts +0 -2
  162. data/spec/sinatra_modular/spec_modular/spec_helper.rb +0 -51
  163. data/spec/sinatra_modular/user.rb +0 -6
  164. data/spec/sinatra_modular/views/test_login.erb +0 -4
@@ -1,157 +0,0 @@
1
- require 'sinatra/base'
2
- #enable :sessions
3
-
4
- require 'sqlite3'
5
- require 'active_record'
6
-
7
- # establish connection
8
- ActiveRecord::Base.establish_connection(
9
- :adapter => "sqlite3",
10
- :database => ":memory:",
11
- :verbosity => "quiet"
12
- )
13
-
14
- require 'action_mailer'
15
- ActionMailer::Base.delivery_method = :test
16
- require File.join(File.dirname(__FILE__), 'sorcery_mailer')
17
-
18
- # models
19
- require File.join(File.dirname(__FILE__), 'user')
20
- require 'sorcery'
21
-
22
- APP_ROOT = File.dirname(__FILE__)
23
-
24
- class Modular < Sinatra::Base
25
- set :sessions, true
26
-
27
- # ['/test_logout', '/some_action', '/test_should_be_logged_in'].each do |patt|
28
- # before patt do
29
- # require_login
30
- # end
31
- # end
32
- #
33
- # before '/test_http_basic_auth' do
34
- # require_login_from_http_basic
35
- # end
36
- #
37
- ## ----- test filters
38
- #
39
- # before do
40
- # self.class.sorcery_vars = {}
41
- # end
42
- #
43
- # after do
44
- # save_instance_vars
45
- # end
46
-
47
- get '/' do
48
-
49
- end
50
-
51
- get '/test_login' do
52
- @user = login(params[:username], params[:password])
53
- @current_user = current_user
54
- @logged_in = logged_in?
55
- erb :test_login
56
- end
57
-
58
- get '/test_logout' do
59
- session[:user_id] = User.first.id
60
- logout
61
- @current_user = current_user
62
- @logged_in = logged_in?
63
- end
64
-
65
- get '/test_current_user' do
66
- session[:user_id] = params[:id]
67
- current_user
68
- end
69
-
70
- get '/some_action' do
71
- erb ''
72
- end
73
-
74
- post '/test_return_to' do
75
- session[:return_to_url] = params[:return_to_url] if params[:return_to_url]
76
- @user = login(params[:username], params[:password])
77
- redirect_back_or_to(:some_action)
78
- end
79
-
80
- get '/test_should_be_logged_in' do
81
- erb ''
82
- end
83
-
84
- def test_not_authenticated_action
85
- halt "test_not_authenticated_action"
86
- end
87
-
88
- def not_authenticated2
89
- @session = session
90
- save_instance_vars
91
- redirect '/'
92
- end
93
-
94
- # remember me
95
-
96
- post '/test_login_with_remember' do
97
- @user = login(params[:username], params[:password])
98
- remember_me!
99
- erb ''
100
- end
101
-
102
- post '/test_login_with_remember_in_login' do
103
- @user = login(params[:username], params[:password], params[:remember])
104
- erb ''
105
- end
106
-
107
- get '/test_login_from_cookie' do
108
- @user = current_user
109
- erb ''
110
- end
111
-
112
- # http_basic
113
-
114
- get '/test_http_basic_auth' do
115
- erb "HTTP Basic Auth"
116
- end
117
-
118
- # oauth
119
-
120
- get '/login_at_test' do
121
- login_at(:twitter)
122
- end
123
-
124
- get '/test_login_from' do
125
- if @user = login_from(:twitter)
126
- erb "Success!"
127
- else
128
- erb "Failed!"
129
- end
130
- end
131
-
132
- # oauth2
133
-
134
- get '/login_at_test2' do
135
- login_at(:facebook)
136
- end
137
-
138
- get '/test_login_from2' do
139
- if @user = login_from(:facebook)
140
- erb "Success!"
141
- else
142
- erb "Failed!"
143
- end
144
- end
145
-
146
- get '/test_create_from_provider' do
147
- provider = params[:provider]
148
- login_from(provider)
149
- if @user = create_from(provider)
150
- erb "Success!"
151
- else
152
- erb "Failed!"
153
- end
154
- end
155
-
156
- #run! if app_file == $2
157
- end
@@ -1,133 +0,0 @@
1
- require 'sinatra'
2
- enable :sessions
3
-
4
- require 'sqlite3'
5
- require 'active_record'
6
-
7
- # establish connection
8
- ActiveRecord::Base.establish_connection(
9
- :adapter => "sqlite3",
10
- :database => ":memory:",
11
- :verbosity => "quiet"
12
- )
13
-
14
- require 'action_mailer'
15
- ActionMailer::Base.delivery_method = :test
16
- require File.join(File.dirname(__FILE__),'sorcery_mailer')
17
-
18
- # models
19
- require File.join(File.dirname(__FILE__),'user')
20
- require 'sorcery'
21
-
22
- APP_ROOT = File.dirname(__FILE__)
23
-
24
- require File.join(File.dirname(__FILE__),'filters')
25
-
26
- get '/' do
27
-
28
- end
29
-
30
- get '/test_login' do
31
- @user = login(params[:username],params[:password])
32
- @current_user = current_user
33
- @logged_in = logged_in?
34
- erb :test_login
35
- end
36
-
37
- get '/test_logout' do
38
- session[:user_id] = User.first.id
39
- logout
40
- @current_user = current_user
41
- @logged_in = logged_in?
42
- end
43
-
44
- get '/test_current_user' do
45
- session[:user_id] = params[:id]
46
- current_user
47
- end
48
-
49
- get '/some_action' do
50
- erb ''
51
- end
52
-
53
- post '/test_return_to' do
54
- session[:return_to_url] = params[:return_to_url] if params[:return_to_url]
55
- @user = login(params[:username], params[:password])
56
- redirect_back_or_to(:some_action)
57
- end
58
-
59
- get '/test_should_be_logged_in' do
60
- erb ''
61
- end
62
-
63
- def test_not_authenticated_action
64
- halt "test_not_authenticated_action"
65
- end
66
-
67
- def not_authenticated2
68
- @session = session
69
- save_instance_vars
70
- redirect '/'
71
- end
72
-
73
- # remember me
74
-
75
- post '/test_login_with_remember' do
76
- @user = login(params[:username], params[:password])
77
- remember_me!
78
- erb ''
79
- end
80
-
81
- post '/test_login_with_remember_in_login' do
82
- @user = login(params[:username], params[:password], params[:remember])
83
- erb ''
84
- end
85
-
86
- get '/test_login_from_cookie' do
87
- @user = current_user
88
- erb ''
89
- end
90
-
91
- # http_basic
92
-
93
- get '/test_http_basic_auth' do
94
- erb "HTTP Basic Auth"
95
- end
96
-
97
- # oauth
98
-
99
- get '/login_at_test' do
100
- login_at(:twitter)
101
- end
102
-
103
- get '/test_login_from' do
104
- if @user = login_from(:twitter)
105
- erb "Success!"
106
- else
107
- erb "Failed!"
108
- end
109
- end
110
-
111
- # oauth2
112
-
113
- get '/login_at_test2' do
114
- login_at(:facebook)
115
- end
116
-
117
- get '/test_login_from2' do
118
- if @user = login_from(:facebook)
119
- erb "Success!"
120
- else
121
- erb "Failed!"
122
- end
123
- end
124
-
125
- get '/test_create_from_provider' do
126
- provider = params[:provider]
127
- login_from(provider)
128
- if @user = create_from(provider)
129
- erb "Success!"
130
- else
131
- erb "Failed!"
132
- end
133
- end
@@ -1,25 +0,0 @@
1
- class SorceryMailer < ActionMailer::Base
2
-
3
- default :from => "notifications@example.com"
4
-
5
- def activation_needed_email(user)
6
- @user = user
7
- @url = "http://example.com/login"
8
- mail(:to => user.email,
9
- :subject => "Welcome to My Awesome Site")
10
- end
11
-
12
- def activation_success_email(user)
13
- @user = user
14
- @url = "http://example.com/login"
15
- mail(:to => user.email,
16
- :subject => "Your account is now activated")
17
- end
18
-
19
- def reset_password_email(user)
20
- @user = user
21
- @url = "http://example.com/login"
22
- mail(:to => user.email,
23
- :subject => "Your password has been reset")
24
- end
25
- end
@@ -1,85 +0,0 @@
1
- require File.expand_path(File.dirname(__FILE__) + '/spec_helper')
2
-
3
- describe Modular do
4
- before(:all) do
5
- ActiveRecord::Migrator.migrate("#{APP_ROOT}/db/migrate/activity_logging")
6
- end
7
-
8
- after(:all) do
9
- ActiveRecord::Migrator.rollback("#{APP_ROOT}/db/migrate/activity_logging")
10
- end
11
-
12
- # ----------------- ACTIVITY LOGGING -----------------------
13
- describe Modular, "with activity logging features" do
14
- before(:all) do
15
- sorcery_reload!([:activity_logging])
16
- clear_cookies
17
- end
18
-
19
- before(:each) do
20
- create_new_user
21
- end
22
-
23
- after(:each) do
24
- User.delete_all
25
- end
26
-
27
- it "should respond to 'current_users'" do
28
- get_sinatra_app(subject).should respond_to(:current_users)
29
- end
30
-
31
- it "'current_users' should be empty when no users are logged in" do
32
- get_sinatra_app(subject).current_users.size.should == 0
33
- end
34
-
35
- it "should log login time on login" do
36
- now = Time.now.utc
37
- get "/test_login", :username => 'gizmo', :password => 'secret'
38
- User.first.last_login_at.should_not be_nil
39
- User.first.last_login_at.to_s(:db).should >= now.to_s(:db)
40
- User.first.last_login_at.to_s(:db).should <= (now+2).to_s(:db)
41
- end
42
-
43
- it "should log logout time on logout" do
44
- get "/test_login", :username => 'gizmo', :password => 'secret'
45
- now = Time.now.utc
46
- get "/test_logout"
47
- User.first.last_logout_at.should_not be_nil
48
- User.first.last_logout_at.to_s(:db).should >= now.to_s(:db)
49
- User.first.last_logout_at.to_s(:db).should <= (now+2).to_s(:db)
50
- end
51
-
52
- it "should log last activity time when logged in" do
53
- get "/test_login", :username => 'gizmo', :password => 'secret'
54
- now = Time.now.utc
55
- get "/some_action"
56
- User.first.last_activity_at.to_s.should >= now.to_s(:db)
57
- User.first.last_activity_at.to_s.should <= (now+2).to_s(:db)
58
- end
59
-
60
- it "'current_users' should hold the user object when 1 user is logged in" do
61
- get "/test_login", :username => 'gizmo', :password => 'secret'
62
- get "/some_action"
63
- get_sinatra_app(subject).current_users.size.should == 1
64
- get_sinatra_app(subject).current_users[0].should == @user
65
- end
66
-
67
- it "'current_users' should show all current_users, whether they have logged out before or not." do
68
- user1 = create_new_user({:username => 'gizmo1', :email => "bla1@bla.com", :password => 'secret1'})
69
- get "/test_login", :username => 'gizmo1', :password => 'secret1'
70
- get "/some_action"
71
- clear_user_without_logout
72
- user2 = create_new_user({:username => 'gizmo2', :email => "bla2@bla.com", :password => 'secret2'})
73
- get "/test_login", :username => 'gizmo2', :password => 'secret2'
74
- get "/some_action"
75
- clear_user_without_logout
76
- user3 = create_new_user({:username => 'gizmo3', :email => "bla3@bla.com", :password => 'secret3'})
77
- get "/test_login", :username => 'gizmo3', :password => 'secret3'
78
- get "/some_action"
79
- get_sinatra_app(subject).current_users.size.should == 3
80
- get_sinatra_app(subject).current_users[0].should == user1
81
- get_sinatra_app(subject).current_users[1].should == user2
82
- get_sinatra_app(subject).current_users[2].should == user3
83
- end
84
- end
85
- end
@@ -1,70 +0,0 @@
1
- require File.expand_path(File.dirname(__FILE__) + '/spec_helper')
2
-
3
- describe Modular do
4
- before(:all) do
5
- ActiveRecord::Migrator.migrate("#{APP_ROOT}/db/migrate/brute_force_protection")
6
- end
7
-
8
- after(:all) do
9
- ActiveRecord::Migrator.rollback("#{APP_ROOT}/db/migrate/brute_force_protection")
10
- end
11
-
12
- # ----------------- SESSION TIMEOUT -----------------------
13
- describe Modular, "with brute force protection features" do
14
- before(:all) do
15
- sorcery_reload!([:brute_force_protection])
16
- end
17
-
18
- before(:each) do
19
- create_new_user
20
- end
21
-
22
- after(:each) do
23
- Sorcery::Controller::Config.reset!
24
- sorcery_controller_property_set(:user_class, User)
25
- User.delete_all
26
- Timecop.return
27
- end
28
-
29
- it "should count login retries" do
30
- 3.times {get "/test_login", :username => 'gizmo', :password => 'blabla'}
31
- User.find_by_username('gizmo').failed_logins_count.should == 3
32
- end
33
-
34
- it "should reset the counter on a good login" do
35
- sorcery_model_property_set(:consecutive_login_retries_amount_limit, 5)
36
- 3.times {get "/test_login", :username => 'gizmo', :password => 'blabla'}
37
- get "/test_login", :username => 'gizmo', :password => 'secret'
38
- User.find_by_username('gizmo').failed_logins_count.should == 0
39
- end
40
-
41
- it "should lock user when number of retries reached the limit" do
42
- User.find_by_username('gizmo').lock_expires_at.should be_nil
43
- sorcery_model_property_set(:consecutive_login_retries_amount_limit, 1)
44
- get "/test_login", :username => 'gizmo', :password => 'blabla'
45
- User.find_by_username('gizmo').lock_expires_at.should_not be_nil
46
- end
47
-
48
- it "should unlock after lock time period passes" do
49
- sorcery_model_property_set(:consecutive_login_retries_amount_limit, 2)
50
- sorcery_model_property_set(:login_lock_time_period, 0.2)
51
- get "/test_login", :username => 'gizmo', :password => 'blabla'
52
- get "/test_login", :username => 'gizmo', :password => 'blabla'
53
- User.find_by_username('gizmo').lock_expires_at.should_not be_nil
54
- Timecop.travel(Time.now+0.3)
55
- get "/test_login", :username => 'gizmo', :password => 'blabla'
56
- User.find_by_username('gizmo').lock_expires_at.should be_nil
57
- end
58
-
59
- it "should not unlock if time period is 0 (permanent lock)" do
60
- sorcery_model_property_set(:consecutive_login_retries_amount_limit, 2)
61
- sorcery_model_property_set(:login_lock_time_period, 0)
62
- get "/test_login", :username => 'gizmo', :password => 'blabla'
63
- get "/test_login", :username => 'gizmo', :password => 'blabla'
64
- unlock_date = User.find_by_username('gizmo').lock_expires_at
65
- Timecop.travel(Time.now+1)
66
- get "/test_login", :username => 'gizmo', :password => 'blabla'
67
- User.find_by_username('gizmo').lock_expires_at.to_s.should == unlock_date.to_s
68
- end
69
- end
70
- end