sorcery 0.8.4 → 0.8.5

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 (281) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +54 -0
  3. data/.travis.yml +13 -1
  4. data/CHANGELOG.md +234 -0
  5. data/Gemfile +17 -14
  6. data/Gemfile.rails4 +24 -0
  7. data/README.md +300 -0
  8. data/Rakefile +3 -79
  9. data/VERSION +1 -1
  10. data/lib/generators/sorcery/helpers.rb +40 -0
  11. data/lib/generators/sorcery/install_generator.rb +21 -17
  12. data/lib/generators/sorcery/templates/initializer.rb +1 -1
  13. data/lib/generators/sorcery/templates/migration/activity_logging.rb +2 -11
  14. data/lib/generators/sorcery/templates/migration/brute_force_protection.rb +1 -7
  15. data/lib/generators/sorcery/templates/migration/core.rb +5 -8
  16. data/lib/generators/sorcery/templates/migration/external.rb +1 -5
  17. data/lib/generators/sorcery/templates/migration/remember_me.rb +2 -9
  18. data/lib/generators/sorcery/templates/migration/reset_password.rb +2 -10
  19. data/lib/generators/sorcery/templates/migration/user_activation.rb +2 -10
  20. data/lib/sorcery/controller.rb +16 -4
  21. data/lib/sorcery/controller/submodules/external.rb +9 -8
  22. data/lib/sorcery/controller/submodules/external/protocols/oauth2.rb +2 -1
  23. data/lib/sorcery/controller/submodules/external/providers/facebook.rb +2 -1
  24. data/lib/sorcery/controller/submodules/external/providers/github.rb +2 -1
  25. data/lib/sorcery/controller/submodules/external/providers/google.rb +2 -1
  26. data/lib/sorcery/controller/submodules/external/providers/linkedin.rb +2 -1
  27. data/lib/sorcery/controller/submodules/external/providers/liveid.rb +2 -1
  28. data/lib/sorcery/controller/submodules/external/providers/twitter.rb +3 -2
  29. data/lib/sorcery/controller/submodules/external/providers/vk.rb +2 -1
  30. data/lib/sorcery/controller/submodules/external/providers/xing.rb +2 -1
  31. data/lib/sorcery/controller/submodules/remember_me.rb +1 -1
  32. data/lib/sorcery/controller/submodules/session_timeout.rb +1 -1
  33. data/lib/sorcery/model.rb +9 -3
  34. data/lib/sorcery/model/adapters/mongoid.rb +3 -3
  35. data/lib/sorcery/model/submodules/brute_force_protection.rb +6 -8
  36. data/lib/sorcery/model/submodules/reset_password.rb +5 -1
  37. data/lib/sorcery/model/submodules/user_activation.rb +18 -4
  38. data/lib/sorcery/test_helpers/internal.rb +21 -4
  39. data/lib/sorcery/test_helpers/internal/rails.rb +4 -4
  40. data/lib/sorcery/test_helpers/rails.rb +2 -2
  41. data/sorcery.gemspec +25 -363
  42. data/spec/{rails3/spec → active_record}/controller_activity_logging_spec.rb +29 -19
  43. data/spec/active_record/controller_brute_force_protection_spec.rb +136 -0
  44. data/spec/{rails3/spec → active_record}/controller_http_basic_auth_spec.rb +26 -17
  45. data/spec/{rails3/spec → active_record}/controller_oauth2_spec.rb +93 -56
  46. data/spec/{rails3/spec → active_record}/controller_oauth_spec.rb +35 -29
  47. data/spec/{rails3/spec → active_record}/controller_remember_me_spec.rb +28 -28
  48. data/spec/{rails3/spec → active_record}/controller_session_timeout_spec.rb +11 -11
  49. data/spec/{rails3/spec → active_record}/controller_spec.rb +19 -19
  50. data/spec/{rails3/spec → active_record}/integration_spec.rb +2 -2
  51. data/spec/{rails3/spec → active_record}/user_activation_spec.rb +8 -6
  52. data/spec/active_record/user_activity_logging_spec.rb +8 -0
  53. data/spec/{rails3/spec → active_record}/user_brute_force_protection_spec.rb +5 -4
  54. data/spec/{rails3/spec → active_record}/user_oauth_spec.rb +5 -4
  55. data/spec/{rails3/spec → active_record}/user_remember_me_spec.rb +4 -3
  56. data/spec/{rails3/spec → active_record}/user_reset_password_spec.rb +6 -6
  57. data/spec/{rails3/spec → active_record}/user_spec.rb +12 -10
  58. data/spec/{rails3_mongo_mapper/spec → mongo_mapper}/controller_spec.rb +15 -15
  59. data/spec/mongo_mapper/user_activation_spec.rb +10 -0
  60. data/spec/mongo_mapper/user_activity_logging_spec.rb +8 -0
  61. data/spec/mongo_mapper/user_brute_force_protection_spec.rb +8 -0
  62. data/spec/mongo_mapper/user_oauth_spec.rb +8 -0
  63. data/spec/mongo_mapper/user_remember_me_spec.rb +8 -0
  64. data/spec/mongo_mapper/user_reset_password_spec.rb +8 -0
  65. data/spec/{rails3_mongo_mapper/spec → mongo_mapper}/user_spec.rb +9 -8
  66. data/spec/{rails3_mongoid/spec → mongoid}/controller_activity_logging_spec.rb +8 -8
  67. data/spec/{rails3_mongoid/spec → mongoid}/controller_spec.rb +14 -14
  68. data/spec/mongoid/user_activation_spec.rb +10 -0
  69. data/spec/mongoid/user_activity_logging_spec.rb +9 -0
  70. data/spec/mongoid/user_brute_force_protection_spec.rb +9 -0
  71. data/spec/mongoid/user_oauth_spec.rb +9 -0
  72. data/spec/mongoid/user_remember_me_spec.rb +9 -0
  73. data/spec/mongoid/user_reset_password_spec.rb +9 -0
  74. data/spec/{rails3_mongoid/spec → mongoid}/user_spec.rb +10 -9
  75. data/spec/orm/active_record.rb +7 -0
  76. data/spec/orm/mongo_mapper.rb +10 -0
  77. data/spec/orm/mongoid.rb +17 -0
  78. data/spec/{rails3/app/models → rails_app/app/active_record}/authentication.rb +0 -0
  79. data/spec/{rails3/app/models → rails_app/app/active_record}/user.rb +1 -2
  80. data/spec/rails_app/app/active_record/user_provider.rb +3 -0
  81. data/spec/{rails3/app/controllers/application_controller.rb → rails_app/app/controllers/sorcery_controller.rb} +26 -15
  82. data/spec/{rails3 → rails_app}/app/helpers/application_helper.rb +0 -0
  83. data/spec/{rails3 → rails_app}/app/mailers/sorcery_mailer.rb +0 -0
  84. data/spec/{rails3_mongo_mapper/app/models → rails_app/app/mongo_mapper}/authentication.rb +0 -0
  85. data/spec/{rails3_mongo_mapper/app/models → rails_app/app/mongo_mapper}/user.rb +0 -0
  86. data/spec/{rails3_mongoid/app/models → rails_app/app/mongoid}/authentication.rb +0 -0
  87. data/spec/{rails3_mongoid/app/models → rails_app/app/mongoid}/user.rb +2 -0
  88. data/spec/{rails3 → rails_app}/app/views/application/index.html.erb +0 -0
  89. data/spec/{rails3 → rails_app}/app/views/layouts/application.html.erb +0 -0
  90. data/spec/{rails3 → rails_app}/app/views/sorcery_mailer/activation_email.html.erb +0 -0
  91. data/spec/{rails3 → rails_app}/app/views/sorcery_mailer/activation_email.text.erb +0 -0
  92. data/spec/{rails3/app/views/sorcery_mailer/activation_success_email.html.erb → rails_app/app/views/sorcery_mailer/activation_needed_email.html.erb} +0 -0
  93. data/spec/{rails3_mongo_mapper → rails_app}/app/views/sorcery_mailer/activation_success_email.html.erb +0 -0
  94. data/spec/{rails3 → rails_app}/app/views/sorcery_mailer/activation_success_email.text.erb +0 -0
  95. data/spec/{rails3 → rails_app}/app/views/sorcery_mailer/reset_password_email.html.erb +0 -0
  96. data/spec/{rails3 → rails_app}/app/views/sorcery_mailer/reset_password_email.text.erb +0 -0
  97. data/spec/{rails3 → rails_app}/app/views/sorcery_mailer/send_unlock_token_email.text.erb +0 -0
  98. data/spec/{rails3_mongo_mapper → rails_app}/config.ru +1 -1
  99. data/spec/{rails3_mongoid → rails_app}/config/application.rb +13 -8
  100. data/spec/rails_app/config/boot.rb +4 -0
  101. data/spec/rails_app/config/database.yml +22 -0
  102. data/spec/{rails3 → rails_app}/config/environment.rb +0 -0
  103. data/spec/{rails3_mongo_mapper → rails_app}/config/environments/test.rb +2 -0
  104. data/spec/{rails3 → rails_app}/config/initializers/backtrace_silencers.rb +0 -0
  105. data/spec/{rails3 → rails_app}/config/initializers/inflections.rb +0 -0
  106. data/spec/{rails3 → rails_app}/config/initializers/mime_types.rb +0 -0
  107. data/spec/{rails3 → rails_app}/config/initializers/secret_token.rb +0 -0
  108. data/spec/{rails3 → rails_app}/config/initializers/session_store.rb +4 -0
  109. data/spec/{rails3 → rails_app}/config/locales/en.yml +0 -0
  110. data/spec/rails_app/config/routes.rb +37 -0
  111. data/spec/{rails3 → rails_app}/db/migrate/activation/20101224223622_add_activation_to_users.rb +3 -3
  112. data/spec/{rails3 → rails_app}/db/migrate/activity_logging/20101224223624_add_activity_logging_to_users.rb +0 -0
  113. data/spec/{rails3 → rails_app}/db/migrate/brute_force_protection/20101224223626_add_brute_force_protection_to_users.rb +0 -0
  114. data/spec/{rails3 → rails_app}/db/migrate/core/20101224223620_create_users.rb +0 -0
  115. data/spec/rails_app/db/migrate/external/20101224223628_create_authentications_and_user_providers.rb +22 -0
  116. data/spec/{rails3 → rails_app}/db/migrate/remember_me/20101224223623_add_remember_me_token_to_users.rb +0 -0
  117. data/spec/{rails3 → rails_app}/db/migrate/reset_password/20101224223622_add_reset_password_to_users.rb +0 -0
  118. data/spec/{rails3 → rails_app}/db/schema.rb +0 -0
  119. data/spec/{rails3 → rails_app}/db/seeds.rb +0 -0
  120. data/spec/{rails3 → rails_app}/public/404.html +0 -0
  121. data/spec/{rails3 → rails_app}/public/422.html +0 -0
  122. data/spec/{rails3 → rails_app}/public/500.html +0 -0
  123. data/spec/{rails3 → rails_app}/public/favicon.ico +0 -0
  124. data/spec/{rails3 → rails_app}/public/images/rails.png +0 -0
  125. data/spec/{rails3 → rails_app}/public/javascripts/application.js +0 -0
  126. data/spec/{rails3 → rails_app}/public/javascripts/controls.js +0 -0
  127. data/spec/{rails3 → rails_app}/public/javascripts/dragdrop.js +0 -0
  128. data/spec/{rails3 → rails_app}/public/javascripts/effects.js +0 -0
  129. data/spec/{rails3 → rails_app}/public/javascripts/prototype.js +0 -0
  130. data/spec/{rails3 → rails_app}/public/javascripts/rails.js +0 -0
  131. data/spec/{rails3 → rails_app}/public/robots.txt +0 -0
  132. data/spec/{rails3/lib/tasks → rails_app/public/stylesheets}/.gitkeep +0 -0
  133. data/spec/shared_examples/controller_oauth_shared_examples.rb +22 -8
  134. data/spec/shared_examples/user_activation_shared_examples.rb +49 -27
  135. data/spec/shared_examples/user_reset_password_shared_examples.rb +33 -21
  136. data/spec/shared_examples/user_shared_examples.rb +65 -50
  137. data/spec/sorcery_crypto_providers_spec.rb +47 -45
  138. data/spec/spec_helper.rb +38 -4
  139. metadata +117 -254
  140. data/Gemfile.lock +0 -175
  141. data/README.rdoc +0 -261
  142. data/spec/Gemfile +0 -12
  143. data/spec/Gemfile.lock +0 -129
  144. data/spec/README.md +0 -31
  145. data/spec/Rakefile +0 -12
  146. data/spec/rails3/.gitignore +0 -4
  147. data/spec/rails3/.rspec +0 -1
  148. data/spec/rails3/Gemfile +0 -15
  149. data/spec/rails3/Gemfile.lock +0 -162
  150. data/spec/rails3/README +0 -256
  151. data/spec/rails3/Rakefile +0 -11
  152. data/spec/rails3/config.ru +0 -4
  153. data/spec/rails3/config/application.rb +0 -46
  154. data/spec/rails3/config/boot.rb +0 -13
  155. data/spec/rails3/config/database.yml +0 -27
  156. data/spec/rails3/config/environments/development.rb +0 -26
  157. data/spec/rails3/config/environments/in_memory.rb +0 -35
  158. data/spec/rails3/config/environments/production.rb +0 -49
  159. data/spec/rails3/config/environments/test.rb +0 -35
  160. data/spec/rails3/config/routes.rb +0 -59
  161. data/spec/rails3/db/migrate/external/20101224223628_create_authentications.rb +0 -14
  162. data/spec/rails3/public/stylesheets/.gitkeep +0 -0
  163. data/spec/rails3/script/rails +0 -6
  164. data/spec/rails3/spec/controller_brute_force_protection_spec.rb +0 -96
  165. data/spec/rails3/spec/spec.opts +0 -2
  166. data/spec/rails3/spec/spec_helper.orig.rb +0 -27
  167. data/spec/rails3/spec/spec_helper.rb +0 -71
  168. data/spec/rails3/spec/user_activity_logging_spec.rb +0 -8
  169. data/spec/rails3/vendor/plugins/.gitkeep +0 -0
  170. data/spec/rails3_mongo_mapper/.gitignore +0 -4
  171. data/spec/rails3_mongo_mapper/.rspec +0 -1
  172. data/spec/rails3_mongo_mapper/Gemfile +0 -16
  173. data/spec/rails3_mongo_mapper/Gemfile.lock +0 -156
  174. data/spec/rails3_mongo_mapper/Rakefile +0 -11
  175. data/spec/rails3_mongo_mapper/app/controllers/application_controller.rb +0 -122
  176. data/spec/rails3_mongo_mapper/app/helpers/application_helper.rb +0 -2
  177. data/spec/rails3_mongo_mapper/app/mailers/sorcery_mailer.rb +0 -25
  178. data/spec/rails3_mongo_mapper/app/views/layouts/application.html.erb +0 -14
  179. data/spec/rails3_mongo_mapper/app/views/sorcery_mailer/activation_email.html.erb +0 -17
  180. data/spec/rails3_mongo_mapper/app/views/sorcery_mailer/activation_email.text.erb +0 -9
  181. data/spec/rails3_mongo_mapper/app/views/sorcery_mailer/activation_success_email.text.erb +0 -9
  182. data/spec/rails3_mongo_mapper/app/views/sorcery_mailer/reset_password_email.html.erb +0 -16
  183. data/spec/rails3_mongo_mapper/app/views/sorcery_mailer/reset_password_email.text.erb +0 -8
  184. data/spec/rails3_mongo_mapper/config/application.rb +0 -51
  185. data/spec/rails3_mongo_mapper/config/boot.rb +0 -13
  186. data/spec/rails3_mongo_mapper/config/environment.rb +0 -5
  187. data/spec/rails3_mongo_mapper/config/environments/development.rb +0 -30
  188. data/spec/rails3_mongo_mapper/config/environments/in_memory.rb +0 -0
  189. data/spec/rails3_mongo_mapper/config/environments/production.rb +0 -49
  190. data/spec/rails3_mongo_mapper/config/initializers/backtrace_silencers.rb +0 -7
  191. data/spec/rails3_mongo_mapper/config/initializers/inflections.rb +0 -10
  192. data/spec/rails3_mongo_mapper/config/initializers/mime_types.rb +0 -5
  193. data/spec/rails3_mongo_mapper/config/initializers/mongo.rb +0 -2
  194. data/spec/rails3_mongo_mapper/config/initializers/secret_token.rb +0 -7
  195. data/spec/rails3_mongo_mapper/config/initializers/session_store.rb +0 -8
  196. data/spec/rails3_mongo_mapper/config/locales/en.yml +0 -5
  197. data/spec/rails3_mongo_mapper/config/routes.rb +0 -59
  198. data/spec/rails3_mongo_mapper/db/schema.rb +0 -23
  199. data/spec/rails3_mongo_mapper/db/seeds.rb +0 -7
  200. data/spec/rails3_mongo_mapper/lib/tasks/.gitkeep +0 -0
  201. data/spec/rails3_mongo_mapper/public/404.html +0 -26
  202. data/spec/rails3_mongo_mapper/public/422.html +0 -26
  203. data/spec/rails3_mongo_mapper/public/500.html +0 -26
  204. data/spec/rails3_mongo_mapper/public/favicon.ico +0 -0
  205. data/spec/rails3_mongo_mapper/public/images/rails.png +0 -0
  206. data/spec/rails3_mongo_mapper/public/javascripts/application.js +0 -2
  207. data/spec/rails3_mongo_mapper/public/javascripts/controls.js +0 -965
  208. data/spec/rails3_mongo_mapper/public/javascripts/dragdrop.js +0 -974
  209. data/spec/rails3_mongo_mapper/public/javascripts/effects.js +0 -1123
  210. data/spec/rails3_mongo_mapper/public/javascripts/prototype.js +0 -6001
  211. data/spec/rails3_mongo_mapper/public/javascripts/rails.js +0 -175
  212. data/spec/rails3_mongo_mapper/public/robots.txt +0 -5
  213. data/spec/rails3_mongo_mapper/public/stylesheets/.gitkeep +0 -0
  214. data/spec/rails3_mongo_mapper/script/rails +0 -6
  215. data/spec/rails3_mongo_mapper/spec/spec.opts +0 -2
  216. data/spec/rails3_mongo_mapper/spec/spec_helper.orig.rb +0 -27
  217. data/spec/rails3_mongo_mapper/spec/spec_helper.rb +0 -55
  218. data/spec/rails3_mongo_mapper/spec/user_activation_spec.rb +0 -9
  219. data/spec/rails3_mongo_mapper/spec/user_activity_logging_spec.rb +0 -8
  220. data/spec/rails3_mongo_mapper/spec/user_brute_force_protection_spec.rb +0 -8
  221. data/spec/rails3_mongo_mapper/spec/user_oauth_spec.rb +0 -8
  222. data/spec/rails3_mongo_mapper/spec/user_remember_me_spec.rb +0 -8
  223. data/spec/rails3_mongo_mapper/spec/user_reset_password_spec.rb +0 -8
  224. data/spec/rails3_mongo_mapper/vendor/plugins/.gitkeep +0 -0
  225. data/spec/rails3_mongoid/.gitignore +0 -4
  226. data/spec/rails3_mongoid/.rspec +0 -1
  227. data/spec/rails3_mongoid/Gemfile +0 -15
  228. data/spec/rails3_mongoid/Gemfile.lock +0 -146
  229. data/spec/rails3_mongoid/Rakefile +0 -11
  230. data/spec/rails3_mongoid/app/controllers/application_controller.rb +0 -127
  231. data/spec/rails3_mongoid/app/helpers/application_helper.rb +0 -2
  232. data/spec/rails3_mongoid/app/mailers/sorcery_mailer.rb +0 -25
  233. data/spec/rails3_mongoid/app/views/layouts/application.html.erb +0 -14
  234. data/spec/rails3_mongoid/app/views/sorcery_mailer/activation_email.html.erb +0 -17
  235. data/spec/rails3_mongoid/app/views/sorcery_mailer/activation_email.text.erb +0 -9
  236. data/spec/rails3_mongoid/app/views/sorcery_mailer/activation_success_email.html.erb +0 -17
  237. data/spec/rails3_mongoid/app/views/sorcery_mailer/activation_success_email.text.erb +0 -9
  238. data/spec/rails3_mongoid/app/views/sorcery_mailer/reset_password_email.html.erb +0 -16
  239. data/spec/rails3_mongoid/app/views/sorcery_mailer/reset_password_email.text.erb +0 -8
  240. data/spec/rails3_mongoid/config.ru +0 -4
  241. data/spec/rails3_mongoid/config/boot.rb +0 -13
  242. data/spec/rails3_mongoid/config/environment.rb +0 -5
  243. data/spec/rails3_mongoid/config/environments/development.rb +0 -26
  244. data/spec/rails3_mongoid/config/environments/in_memory.rb +0 -0
  245. data/spec/rails3_mongoid/config/environments/production.rb +0 -49
  246. data/spec/rails3_mongoid/config/environments/test.rb +0 -35
  247. data/spec/rails3_mongoid/config/initializers/backtrace_silencers.rb +0 -7
  248. data/spec/rails3_mongoid/config/initializers/inflections.rb +0 -10
  249. data/spec/rails3_mongoid/config/initializers/mime_types.rb +0 -5
  250. data/spec/rails3_mongoid/config/initializers/secret_token.rb +0 -7
  251. data/spec/rails3_mongoid/config/initializers/session_store.rb +0 -8
  252. data/spec/rails3_mongoid/config/locales/en.yml +0 -5
  253. data/spec/rails3_mongoid/config/mongoid.yml +0 -7
  254. data/spec/rails3_mongoid/config/routes.rb +0 -59
  255. data/spec/rails3_mongoid/db/schema.rb +0 -23
  256. data/spec/rails3_mongoid/db/seeds.rb +0 -7
  257. data/spec/rails3_mongoid/lib/tasks/.gitkeep +0 -0
  258. data/spec/rails3_mongoid/public/404.html +0 -26
  259. data/spec/rails3_mongoid/public/422.html +0 -26
  260. data/spec/rails3_mongoid/public/500.html +0 -26
  261. data/spec/rails3_mongoid/public/favicon.ico +0 -0
  262. data/spec/rails3_mongoid/public/images/rails.png +0 -0
  263. data/spec/rails3_mongoid/public/javascripts/application.js +0 -2
  264. data/spec/rails3_mongoid/public/javascripts/controls.js +0 -965
  265. data/spec/rails3_mongoid/public/javascripts/dragdrop.js +0 -974
  266. data/spec/rails3_mongoid/public/javascripts/effects.js +0 -1123
  267. data/spec/rails3_mongoid/public/javascripts/prototype.js +0 -6001
  268. data/spec/rails3_mongoid/public/javascripts/rails.js +0 -175
  269. data/spec/rails3_mongoid/public/robots.txt +0 -5
  270. data/spec/rails3_mongoid/public/stylesheets/.gitkeep +0 -0
  271. data/spec/rails3_mongoid/script/rails +0 -6
  272. data/spec/rails3_mongoid/spec/spec.opts +0 -2
  273. data/spec/rails3_mongoid/spec/spec_helper.orig.rb +0 -27
  274. data/spec/rails3_mongoid/spec/spec_helper.rb +0 -55
  275. data/spec/rails3_mongoid/spec/user_activation_spec.rb +0 -9
  276. data/spec/rails3_mongoid/spec/user_activity_logging_spec.rb +0 -8
  277. data/spec/rails3_mongoid/spec/user_brute_force_protection_spec.rb +0 -8
  278. data/spec/rails3_mongoid/spec/user_oauth_spec.rb +0 -8
  279. data/spec/rails3_mongoid/spec/user_remember_me_spec.rb +0 -8
  280. data/spec/rails3_mongoid/spec/user_reset_password_spec.rb +0 -8
  281. data/spec/rails3_mongoid/vendor/plugins/.gitkeep +0 -0
@@ -1,175 +0,0 @@
1
- GEM
2
- remote: https://rubygems.org/
3
- specs:
4
- abstract (1.0.0)
5
- actionmailer (3.2.2)
6
- actionpack (= 3.2.2)
7
- mail (~> 2.4.0)
8
- actionpack (3.2.2)
9
- activemodel (= 3.2.2)
10
- activesupport (= 3.2.2)
11
- builder (~> 3.0.0)
12
- erubis (~> 2.7.0)
13
- journey (~> 1.0.1)
14
- rack (~> 1.4.0)
15
- rack-cache (~> 1.1)
16
- rack-test (~> 0.6.1)
17
- sprockets (~> 2.1.2)
18
- activemodel (3.2.2)
19
- activesupport (= 3.2.2)
20
- builder (~> 3.0.0)
21
- activerecord (3.2.2)
22
- activemodel (= 3.2.2)
23
- activesupport (= 3.2.2)
24
- arel (~> 3.0.2)
25
- tzinfo (~> 0.3.29)
26
- activeresource (3.2.2)
27
- activemodel (= 3.2.2)
28
- activesupport (= 3.2.2)
29
- activesupport (3.2.2)
30
- i18n (~> 0.6)
31
- multi_json (~> 1.0)
32
- arel (3.0.2)
33
- bcrypt-ruby (3.0.1)
34
- bson (1.6.1)
35
- builder (3.0.0)
36
- capybara (1.1.2)
37
- mime-types (>= 1.16)
38
- nokogiri (>= 1.3.3)
39
- rack (>= 1.0.0)
40
- rack-test (>= 0.5.4)
41
- selenium-webdriver (~> 2.0)
42
- xpath (~> 0.1.4)
43
- childprocess (0.3.1)
44
- ffi (~> 1.0.6)
45
- diff-lcs (1.1.3)
46
- erubis (2.7.0)
47
- faraday (0.8.4)
48
- multipart-post (~> 1.1)
49
- ffi (1.0.11)
50
- git (1.2.5)
51
- hike (1.2.1)
52
- httpauth (0.2.0)
53
- i18n (0.6.0)
54
- jeweler (1.8.3)
55
- bundler (~> 1.0)
56
- git (>= 1.2.5)
57
- rake
58
- rdoc
59
- journey (1.0.3)
60
- json (1.7.7)
61
- jwt (0.1.5)
62
- multi_json (>= 1.0)
63
- mail (2.4.4)
64
- i18n (>= 0.4.0)
65
- mime-types (~> 1.16)
66
- treetop (~> 1.4.8)
67
- mime-types (1.18)
68
- mongo (1.6.1)
69
- bson (~> 1.6.1)
70
- mongo_mapper (0.11.1)
71
- activemodel (~> 3.0)
72
- activesupport (~> 3.0)
73
- plucky (~> 0.4.0)
74
- mongoid (2.4.7)
75
- activemodel (~> 3.1)
76
- mongo (~> 1.3)
77
- tzinfo (~> 0.3.22)
78
- multi_json (1.3.2)
79
- multipart-post (1.1.5)
80
- nokogiri (1.5.2)
81
- oauth (0.4.5)
82
- oauth2 (0.8.0)
83
- faraday (~> 0.8)
84
- httpauth (~> 0.1)
85
- jwt (~> 0.1.4)
86
- multi_json (~> 1.0)
87
- rack (~> 1.2)
88
- plucky (0.4.4)
89
- mongo (~> 1.5)
90
- polyglot (0.3.3)
91
- rack (1.4.1)
92
- rack-cache (1.2)
93
- rack (>= 0.4)
94
- rack-ssl (1.3.2)
95
- rack
96
- rack-test (0.6.1)
97
- rack (>= 1.0)
98
- rails (3.2.2)
99
- actionmailer (= 3.2.2)
100
- actionpack (= 3.2.2)
101
- activerecord (= 3.2.2)
102
- activeresource (= 3.2.2)
103
- activesupport (= 3.2.2)
104
- bundler (~> 1.0)
105
- railties (= 3.2.2)
106
- railties (3.2.2)
107
- actionpack (= 3.2.2)
108
- activesupport (= 3.2.2)
109
- rack-ssl (~> 1.3.2)
110
- rake (>= 0.8.7)
111
- rdoc (~> 3.4)
112
- thor (~> 0.14.6)
113
- rake (0.9.2.2)
114
- rdoc (3.12)
115
- json (~> 1.4)
116
- rspec (2.5.0)
117
- rspec-core (~> 2.5.0)
118
- rspec-expectations (~> 2.5.0)
119
- rspec-mocks (~> 2.5.0)
120
- rspec-core (2.5.2)
121
- rspec-expectations (2.5.0)
122
- diff-lcs (~> 1.1.2)
123
- rspec-mocks (2.5.0)
124
- rspec-rails (2.5.0)
125
- actionpack (~> 3.0)
126
- activesupport (~> 3.0)
127
- railties (~> 3.0)
128
- rspec (~> 2.5.0)
129
- rubyzip (0.9.6.1)
130
- selenium-webdriver (2.20.0)
131
- childprocess (>= 0.2.5)
132
- ffi (~> 1.0)
133
- multi_json (~> 1.0)
134
- rubyzip
135
- simplecov (0.6.1)
136
- multi_json (~> 1.0)
137
- simplecov-html (~> 0.5.3)
138
- simplecov-html (0.5.3)
139
- sprockets (2.1.2)
140
- hike (~> 1.2)
141
- rack (~> 1.0)
142
- tilt (~> 1.1, != 1.3.0)
143
- sqlite3 (1.3.7)
144
- thor (0.14.6)
145
- tilt (1.3.3)
146
- timecop (0.3.5)
147
- treetop (1.4.10)
148
- polyglot
149
- polyglot (>= 0.3.1)
150
- tzinfo (0.3.32)
151
- xpath (0.1.4)
152
- nokogiri (~> 1.3)
153
- yard (0.6.8)
154
-
155
- PLATFORMS
156
- ruby
157
-
158
- DEPENDENCIES
159
- abstract (>= 1.0.0)
160
- bcrypt-ruby (~> 3.0.0)
161
- bundler (>= 1.1.0)
162
- capybara
163
- jeweler (~> 1.8.3)
164
- json (>= 1.7.7)
165
- mongo_mapper
166
- mongoid (~> 2.4.4)
167
- oauth (~> 0.4.4)
168
- oauth2 (~> 0.8.0)
169
- rails (>= 3.0.0)
170
- rspec (~> 2.5.0)
171
- rspec-rails (~> 2.5.0)
172
- simplecov (>= 0.3.8)
173
- sqlite3
174
- timecop
175
- yard (~> 0.6.0)
@@ -1,261 +0,0 @@
1
- {<img src="https://secure.travis-ci.org/NoamB/sorcery.png" />}[http://travis-ci.org/NoamB/sorcery]
2
-
3
- = sorcery
4
- Magical Authentication for Rails 3.
5
- Supports ActiveRecord, Mongoid and MongoMapper.
6
-
7
- Inspired by restful_authentication, Authlogic and Devise.
8
- Crypto code taken almost unchanged from Authlogic.
9
- OAuth code inspired by OmniAuth and Ryan Bates's railscasts about it.
10
-
11
- == Philosophy
12
-
13
-
14
- Sorcery is a stripped-down, bare-bones authentication library, with which you can write your own authentication flow.
15
- It was built with a few goals in mind:
16
-
17
- * Less is more - less than 20 public methods to remember for the entire feature-set make the lib easy to 'get'.
18
- * No built-in or generated code - use the library's methods inside *your own* MVC structures, and don't fight to fix someone else's.
19
- * Magic yes, Voodoo no - the lib should be easy to hack for most developers.
20
- * Configuration over Confusion - Centralized (1 file), Simple & short configuration as possible, not drowning in syntactic sugar.
21
- * Keep MVC cleanly separated - DB is for models, sessions are for controllers. Models stay unaware of sessions.
22
-
23
- Hopefully, I've achieved this. If not, let me know.
24
-
25
-
26
- == Useful Links:
27
-
28
- Railscast: http://railscasts.com/episodes/283-authentication-with-sorcery
29
-
30
- Example Rails 3 app using sorcery: https://github.com/NoamB/sorcery-example-app
31
-
32
- Documentation: http://rubydoc.info/gems/sorcery/0.8.2/frames
33
-
34
- Check out the tutorials in the github wiki!
35
-
36
-
37
- == API Summary
38
-
39
-
40
- Below is a summary of the library methods. Most method names are self explaining and the rest are commented:
41
-
42
- # core
43
- require_login # this is a before filter
44
- login(username,password,remember_me = false)
45
- auto_login(user)# login without credentials
46
- logout
47
- logged_in? # available to view
48
- current_user # available to view
49
- redirect_back_or_to # used when a user tries to access a page while logged out, is asked to login, and we want to return him back to the page he originally wanted.
50
- @user.external? # external users, such as facebook/twitter etc.
51
- User.authenticates_with_sorcery!
52
-
53
- # activity logging
54
- current_users
55
-
56
- # http basic auth
57
- require_login_from_http_basic # this is a before filter
58
-
59
- # external
60
- login_at(provider) # sends the user to an external service (twitter etc.) to authenticate.
61
- login_from(provider) # tries to login from the external provider's callback.
62
- create_from(provider) # create the user in the local app db.
63
-
64
- # remember me
65
- auto_login(user, should_remember=false) # login without credentials, optional remember_me
66
- remember_me!
67
- forget_me!
68
-
69
- # reset password
70
- User.load_from_reset_password_token(token)
71
- @user.deliver_reset_password_instructions!
72
- @user.change_password!(new_password)
73
-
74
- # user activation
75
- User.load_from_activation_token(token)
76
- @user.activate!
77
-
78
- Please see the tutorials in the github wiki for detailed usage information.
79
-
80
-
81
- == Installation:
82
-
83
-
84
- If using bundler, first add 'sorcery' to your Gemfile:
85
-
86
- gem "sorcery"
87
-
88
- And run
89
-
90
- bundle install
91
-
92
- Otherwise simply
93
-
94
- gem install sorcery
95
-
96
-
97
- == Rails 3 Configuration:
98
-
99
- rails generate sorcery:install
100
-
101
- This will generate the core migration file, the initializer file and the 'User' model class.
102
-
103
- rails generate sorcery:install remember_me reset_password
104
-
105
- This will generate the migrations files for remember_me and reset_password submodules
106
- and will create the initializer file (and add submodules to it), and create the 'User' model class.
107
-
108
- rails generate sorcery:install --model Person
109
-
110
- This will generate the core migration file, the initializer and change the model class
111
- (in the initializer and migration files) to the class 'Person' (and its pluralized version, 'people')
112
-
113
- rails generate sorcery:install http_basic_auth external remember_me --migrations
114
-
115
- This will generate only the migration files for the specified submodules and will
116
- add them to the initializer file.
117
-
118
- Inside the initializer, the comments will tell you what each setting does.
119
-
120
-
121
- == DelayedJob Integration
122
-
123
- By default emails are sent synchronously. You can send them asynchronously by using the
124
- [delayed_job gem](https://github.com/collectiveidea/delayed_job).
125
-
126
- After implementing the `delayed_job` into your project add the code below at the end of
127
- the `config/initializers/sorcery.rb` file. After that all emails will be sent asynchronously.
128
-
129
- module Sorcery
130
- module Model
131
- module InstanceMethods
132
- def generic_send_email(method, mailer)
133
- config = sorcery_config
134
- mail = config.send(mailer).delay.send(config.send(method), self)
135
- end
136
- end
137
- end
138
- end
139
-
140
-
141
- == Single Table Inheritance (STI) Support
142
- STI is supported via a single setting in config/initializers/sorcery.rb.
143
-
144
-
145
- == Full Features List by module:
146
-
147
-
148
- Core (see lib/sorcery/model.rb and lib/sorcery/controller.rb):
149
- * login/logout, optional return user to requested url on login, configurable redirect for non-logged-in users.
150
- * password encryption, algorithms: bcrypt(default), md5, sha1, sha256, sha512, aes256, custom(yours!), none. Configurable stretches and salt.
151
- * configurable attribute names for username, password and email.
152
- * allow multiple fields to serve as username.
153
-
154
- User Activation (see lib/sorcery/model/submodules/user_activation.rb):
155
- * User activation by email with optional success email.
156
- * configurable attribute names.
157
- * configurable mailer, method name, and attribute name.
158
- * configurable temporary token expiration.
159
- * Optionally prevent non-active users to login.
160
-
161
- Reset Password (see lib/sorcery/model/submodules/reset_password.rb):
162
- * Reset password with email verification.
163
- * configurable mailer, method name, and attribute name.
164
- * configurable temporary token expiration.
165
- * configurable time between emails (hammering protection).
166
-
167
- Remember Me (see lib/sorcery/model/submodules/remember_me.rb):
168
- * Remember me with configurable expiration.
169
- * configurable attribute names.
170
-
171
- Session Timeout (see lib/sorcery/controller/submodules/session_timeout.rb):
172
- * Configurable session timeout.
173
- * Optionally session timeout will be calculated from last user action.
174
-
175
- Brute Force Protection (see lib/sorcery/model/submodules/brute_force_protection.rb):
176
- * Brute force login hammering protection.
177
- * configurable logins before lock and lock duration.
178
-
179
- Basic HTTP Authentication (see lib/sorcery/controller/submodules/http_basic_auth.rb):
180
- * A before filter for requesting authentication with HTTP Basic.
181
- * automatic login from HTTP Basic.
182
- * automatic login is disabled if session key changed.
183
-
184
- Activity Logging (see lib/sorcery/model/submodules/activity_logging.rb):
185
- * automatic logging of last login, last logout, last activity time and IP address for last login.
186
- * an easy method of collecting the list of currently logged in users.
187
- * configurable timeout by which to decide whether to include a user in the list of logged in users.
188
-
189
- External (see lib/sorcery/controller/submodules/external.rb):
190
- * OAuth1 and OAuth2 support (currently twitter & facebook)
191
- * configurable db field names and authentications table.
192
-
193
-
194
- == Next Planned Features:
195
-
196
-
197
- I've got some thoughts which include (unordered):
198
- * Passing a block to encrypt, allowing the developer to define his own mix of salting and encrypting
199
- * Forgot username, maybe as part of the reset_password module
200
- * Scoping logins (to a subdomain or another arbitrary field)
201
- * Allowing storing the salt and crypted password in the same DB field for extra security
202
- * Other reset password strategies (security questions?)
203
- * Other brute force protection strategies (captcha)
204
-
205
-
206
- Have an idea? Let me know, and it might get into the gem!
207
-
208
-
209
- == Backward compatibility
210
-
211
-
212
- While the lib is young and evolving fast I'm breaking backward compatibility quite often.
213
- I'm constantly finding better ways to do things and throwing away old ways.
214
- To let you know when things are changing in a non-compatible way, I'm bumping the minor version of the gem.
215
- The patch version changes are backward compatible.
216
-
217
- In short, an app that works with x.3.1 should be able to upgrade to x.3.2 with no code changes.
218
- The same cannot be said about upgrading to x.4.0 and above, however.
219
-
220
- == Upgrading
221
-
222
- Important notes while upgrading:
223
-
224
- * If upgrading from <= 0.6.1 to >= 0.7.0 you need to change 'username_attribute_name' to 'username_attribute_names' in initializer.
225
- * If upgrading from <= v0.5.1 to >= v0.5.2 you need to explicitly set your user_class model in the initializer file.
226
-
227
- # This line must come after the 'user config' block.
228
- config.user_class = User
229
-
230
- * Sinatra support existed until v0.7.0 (including), but was dropped later due to being a maintenance nightmare.
231
-
232
-
233
- == Contributing to sorcery
234
-
235
-
236
- Your feedback is very welcome and will make this gem much much better for you, me and everyone else.
237
- Besides feedback on code, features, suggestions and bug reports, you may want to actually make an impact on the code.
238
- For this:
239
-
240
- * Fork it.
241
- * Fix it.
242
- * Test it.
243
- * Commit it.
244
- * Send me a pull request so I'll... Pull it.
245
-
246
- If you feel sorcery has made your life easier, and you would like to express your thanks via a donation, my paypal email is in the contact details.
247
-
248
-
249
- == Contact
250
-
251
-
252
- Feel free to ask questions using these contact details:
253
-
254
- email: nbenari@gmail.com ( also for paypal )
255
- twitter: @nbenari
256
-
257
-
258
- == Copyright
259
-
260
-
261
- Copyright (c) 2010 Noam Ben Ari (nbenari@gmail.com). See LICENSE.txt for further details.
@@ -1,12 +0,0 @@
1
- source 'https://rubygems.org'
2
-
3
- gem "rails", '3.0.3'
4
- gem 'bcrypt-ruby', :require => 'bcrypt'
5
- gem "sorcery", '>= 0.1.0', :path => '../'
6
- gem 'oauth', "~> 0.4.4"
7
- gem 'oauth2', "~> 0.8.0"
8
- group :development do
9
- gem "rspec", "~> 2.5.0"
10
- gem 'ruby-debug19'
11
- gem 'simplecov', '>= 0.3.8', :require => false # Will install simplecov-html as a dependency
12
- end
@@ -1,129 +0,0 @@
1
- PATH
2
- remote: ../
3
- specs:
4
- sorcery (0.8.1)
5
- bcrypt-ruby (~> 3.0.0)
6
- oauth (~> 0.4.4)
7
- oauth2 (~> 0.8.0)
8
-
9
- GEM
10
- remote: http://rubygems.org/
11
- specs:
12
- abstract (1.0.0)
13
- actionmailer (3.0.3)
14
- actionpack (= 3.0.3)
15
- mail (~> 2.2.9)
16
- actionpack (3.0.3)
17
- activemodel (= 3.0.3)
18
- activesupport (= 3.0.3)
19
- builder (~> 2.1.2)
20
- erubis (~> 2.6.6)
21
- i18n (~> 0.4)
22
- rack (~> 1.2.1)
23
- rack-mount (~> 0.6.13)
24
- rack-test (~> 0.5.6)
25
- tzinfo (~> 0.3.23)
26
- activemodel (3.0.3)
27
- activesupport (= 3.0.3)
28
- builder (~> 2.1.2)
29
- i18n (~> 0.4)
30
- activerecord (3.0.3)
31
- activemodel (= 3.0.3)
32
- activesupport (= 3.0.3)
33
- arel (~> 2.0.2)
34
- tzinfo (~> 0.3.23)
35
- activeresource (3.0.3)
36
- activemodel (= 3.0.3)
37
- activesupport (= 3.0.3)
38
- activesupport (3.0.3)
39
- archive-tar-minitar (0.5.2)
40
- arel (2.0.10)
41
- bcrypt-ruby (3.0.1)
42
- builder (2.1.2)
43
- columnize (0.3.6)
44
- diff-lcs (1.1.3)
45
- erubis (2.6.6)
46
- abstract (>= 1.0.0)
47
- faraday (0.8.4)
48
- multipart-post (~> 1.1)
49
- httpauth (0.2.0)
50
- i18n (0.6.0)
51
- jwt (0.1.5)
52
- multi_json (>= 1.0)
53
- linecache19 (0.5.12)
54
- ruby_core_source (>= 0.1.4)
55
- mail (2.2.19)
56
- activesupport (>= 2.3.6)
57
- i18n (>= 0.4.0)
58
- mime-types (~> 1.16)
59
- treetop (~> 1.4.8)
60
- mime-types (1.17.2)
61
- multi_json (1.1.0)
62
- multipart-post (1.1.5)
63
- oauth (0.4.5)
64
- oauth2 (0.8.0)
65
- faraday (~> 0.8)
66
- httpauth (~> 0.1)
67
- jwt (~> 0.1.4)
68
- multi_json (~> 1.0)
69
- rack (~> 1.2)
70
- polyglot (0.3.3)
71
- rack (1.2.5)
72
- rack-mount (0.6.14)
73
- rack (>= 1.0.0)
74
- rack-test (0.5.7)
75
- rack (>= 1.0)
76
- rails (3.0.3)
77
- actionmailer (= 3.0.3)
78
- actionpack (= 3.0.3)
79
- activerecord (= 3.0.3)
80
- activeresource (= 3.0.3)
81
- activesupport (= 3.0.3)
82
- bundler (~> 1.0)
83
- railties (= 3.0.3)
84
- railties (3.0.3)
85
- actionpack (= 3.0.3)
86
- activesupport (= 3.0.3)
87
- rake (>= 0.8.7)
88
- thor (~> 0.14.4)
89
- rake (0.9.2.2)
90
- rspec (2.5.0)
91
- rspec-core (~> 2.5.0)
92
- rspec-expectations (~> 2.5.0)
93
- rspec-mocks (~> 2.5.0)
94
- rspec-core (2.5.2)
95
- rspec-expectations (2.5.0)
96
- diff-lcs (~> 1.1.2)
97
- rspec-mocks (2.5.0)
98
- ruby-debug-base19 (0.11.25)
99
- columnize (>= 0.3.1)
100
- linecache19 (>= 0.5.11)
101
- ruby_core_source (>= 0.1.4)
102
- ruby-debug19 (0.11.6)
103
- columnize (>= 0.3.1)
104
- linecache19 (>= 0.5.11)
105
- ruby-debug-base19 (>= 0.11.19)
106
- ruby_core_source (0.1.5)
107
- archive-tar-minitar (>= 0.5.2)
108
- simplecov (0.6.1)
109
- multi_json (~> 1.0)
110
- simplecov-html (~> 0.5.3)
111
- simplecov-html (0.5.3)
112
- thor (0.14.6)
113
- treetop (1.4.10)
114
- polyglot
115
- polyglot (>= 0.3.1)
116
- tzinfo (0.3.31)
117
-
118
- PLATFORMS
119
- ruby
120
-
121
- DEPENDENCIES
122
- bcrypt-ruby
123
- oauth (~> 0.4.4)
124
- oauth2 (~> 0.8.0)
125
- rails (= 3.0.3)
126
- rspec (~> 2.5.0)
127
- ruby-debug19
128
- simplecov (>= 0.3.8)
129
- sorcery (>= 0.1.0)!