ramon-devise 0.4.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (92) hide show
  1. data/CHANGELOG.rdoc +109 -0
  2. data/MIT-LICENSE +20 -0
  3. data/README.rdoc +243 -0
  4. data/Rakefile +45 -0
  5. data/TODO +8 -0
  6. data/app/controllers/confirmations_controller.rb +33 -0
  7. data/app/controllers/passwords_controller.rb +41 -0
  8. data/app/controllers/sessions_controller.rb +33 -0
  9. data/app/models/devise_mailer.rb +53 -0
  10. data/app/views/confirmations/new.html.erb +16 -0
  11. data/app/views/devise_mailer/confirmation_instructions.html.erb +5 -0
  12. data/app/views/devise_mailer/reset_password_instructions.html.erb +8 -0
  13. data/app/views/passwords/edit.html.erb +20 -0
  14. data/app/views/passwords/new.html.erb +16 -0
  15. data/app/views/sessions/new.html.erb +23 -0
  16. data/generators/devise/USAGE +5 -0
  17. data/generators/devise/devise_generator.rb +25 -0
  18. data/generators/devise/lib/route_devise.rb +32 -0
  19. data/generators/devise/templates/README +22 -0
  20. data/generators/devise/templates/migration.rb +20 -0
  21. data/generators/devise/templates/model.rb +5 -0
  22. data/generators/devise_install/USAGE +3 -0
  23. data/generators/devise_install/devise_install_generator.rb +9 -0
  24. data/generators/devise_install/templates/devise.rb +40 -0
  25. data/generators/devise_views/USAGE +3 -0
  26. data/generators/devise_views/devise_views_generator.rb +24 -0
  27. data/init.rb +2 -0
  28. data/lib/devise.rb +79 -0
  29. data/lib/devise/controllers/filters.rb +111 -0
  30. data/lib/devise/controllers/helpers.rb +130 -0
  31. data/lib/devise/controllers/url_helpers.rb +49 -0
  32. data/lib/devise/failure.rb +38 -0
  33. data/lib/devise/hooks/confirmable.rb +11 -0
  34. data/lib/devise/hooks/rememberable.rb +27 -0
  35. data/lib/devise/locales/en.yml +18 -0
  36. data/lib/devise/mapping.rb +120 -0
  37. data/lib/devise/migrations.rb +51 -0
  38. data/lib/devise/models.rb +105 -0
  39. data/lib/devise/models/authenticatable.rb +97 -0
  40. data/lib/devise/models/confirmable.rb +156 -0
  41. data/lib/devise/models/recoverable.rb +88 -0
  42. data/lib/devise/models/rememberable.rb +95 -0
  43. data/lib/devise/models/validatable.rb +36 -0
  44. data/lib/devise/rails.rb +17 -0
  45. data/lib/devise/rails/routes.rb +109 -0
  46. data/lib/devise/rails/warden_compat.rb +26 -0
  47. data/lib/devise/strategies/authenticatable.rb +46 -0
  48. data/lib/devise/strategies/base.rb +24 -0
  49. data/lib/devise/strategies/rememberable.rb +35 -0
  50. data/lib/devise/version.rb +3 -0
  51. data/lib/devise/warden.rb +24 -0
  52. data/test/controllers/filters_test.rb +103 -0
  53. data/test/controllers/helpers_test.rb +55 -0
  54. data/test/controllers/url_helpers_test.rb +47 -0
  55. data/test/devise_test.rb +72 -0
  56. data/test/failure_test.rb +34 -0
  57. data/test/integration/authenticatable_test.rb +187 -0
  58. data/test/integration/confirmable_test.rb +89 -0
  59. data/test/integration/recoverable_test.rb +131 -0
  60. data/test/integration/rememberable_test.rb +65 -0
  61. data/test/mailers/confirmation_instructions_test.rb +59 -0
  62. data/test/mailers/reset_password_instructions_test.rb +62 -0
  63. data/test/mapping_test.rb +101 -0
  64. data/test/models/authenticatable_test.rb +118 -0
  65. data/test/models/confirmable_test.rb +237 -0
  66. data/test/models/recoverable_test.rb +141 -0
  67. data/test/models/rememberable_test.rb +130 -0
  68. data/test/models/validatable_test.rb +99 -0
  69. data/test/models_test.rb +111 -0
  70. data/test/rails_app/app/controllers/admins_controller.rb +6 -0
  71. data/test/rails_app/app/controllers/application_controller.rb +10 -0
  72. data/test/rails_app/app/controllers/home_controller.rb +4 -0
  73. data/test/rails_app/app/controllers/users_controller.rb +7 -0
  74. data/test/rails_app/app/helpers/application_helper.rb +3 -0
  75. data/test/rails_app/app/models/account.rb +3 -0
  76. data/test/rails_app/app/models/admin.rb +3 -0
  77. data/test/rails_app/app/models/organizer.rb +3 -0
  78. data/test/rails_app/app/models/user.rb +3 -0
  79. data/test/rails_app/config/boot.rb +110 -0
  80. data/test/rails_app/config/environment.rb +41 -0
  81. data/test/rails_app/config/environments/development.rb +17 -0
  82. data/test/rails_app/config/environments/production.rb +28 -0
  83. data/test/rails_app/config/environments/test.rb +28 -0
  84. data/test/rails_app/config/initializers/new_rails_defaults.rb +21 -0
  85. data/test/rails_app/config/initializers/session_store.rb +15 -0
  86. data/test/rails_app/config/routes.rb +18 -0
  87. data/test/routes_test.rb +79 -0
  88. data/test/support/assertions_helper.rb +22 -0
  89. data/test/support/integration_tests_helper.rb +66 -0
  90. data/test/support/model_tests_helper.rb +51 -0
  91. data/test/test_helper.rb +40 -0
  92. metadata +154 -0
@@ -0,0 +1,41 @@
1
+ class PasswordsController < ApplicationController
2
+ include Devise::Controllers::Helpers
3
+
4
+ before_filter :require_no_authentication
5
+
6
+ # GET /resource/password/new
7
+ def new
8
+ build_resource
9
+ end
10
+
11
+ # POST /resource/password
12
+ def create
13
+ self.resource = resource_class.send_reset_password_instructions(params[resource_name])
14
+
15
+ if resource.errors.empty?
16
+ set_flash_message :success, :send_instructions
17
+ redirect_to new_session_path(resource_name)
18
+ else
19
+ render :new
20
+ end
21
+ end
22
+
23
+ # GET /resource/password/edit?perishable_token=abcdef
24
+ def edit
25
+ self.resource = resource_class.new
26
+ resource.reset_password_token = params[:reset_password_token]
27
+ end
28
+
29
+ # PUT /resource/password
30
+ def update
31
+ self.resource = resource_class.reset_password!(params[resource_name])
32
+
33
+ if resource.errors.empty?
34
+ sign_in(resource_name, resource)
35
+ set_flash_message :success, :updated
36
+ redirect_to home_or_root_path
37
+ else
38
+ render :edit
39
+ end
40
+ end
41
+ end
@@ -0,0 +1,33 @@
1
+ class SessionsController < ApplicationController
2
+ include Devise::Controllers::Helpers
3
+
4
+ before_filter :require_no_authentication, :only => [ :new, :create ]
5
+
6
+ # GET /resource/sign_in
7
+ def new
8
+ Devise::FLASH_MESSAGES.each do |message, type|
9
+ set_now_flash_message type, message if params.key?(message)
10
+ end
11
+ build_resource
12
+ end
13
+
14
+ # POST /resource/sign_in
15
+ def create
16
+ if authenticate(resource_name)
17
+ set_flash_message :success, :signed_in
18
+ redirect_back_or_to home_or_root_path
19
+ else
20
+ set_now_flash_message :failure, :invalid
21
+ build_resource
22
+ render :new
23
+ end
24
+ end
25
+
26
+ # GET /resource/sign_out
27
+ def destroy
28
+ set_flash_message :success, :signed_out if signed_in?(resource_name)
29
+ sign_out(resource_name)
30
+ redirect_to root_path
31
+ end
32
+
33
+ end
@@ -0,0 +1,53 @@
1
+ class DeviseMailer < ::ActionMailer::Base
2
+
3
+ # Sets who is sending the e-mail
4
+ def self.sender=(value)
5
+ @@sender = value
6
+ end
7
+
8
+ # Reads who is sending the e-mail
9
+ def self.sender
10
+ @@sender
11
+ end
12
+ self.sender = nil
13
+
14
+ # Deliver confirmation instructions when the user is created or its email is
15
+ # updated, and also when confirmation is manually requested
16
+ def confirmation_instructions(record)
17
+ setup_mail(record, :confirmation_instructions)
18
+ end
19
+
20
+ # Deliver reset password instructions when manually requested
21
+ def reset_password_instructions(record)
22
+ setup_mail(record, :reset_password_instructions)
23
+ end
24
+
25
+ private
26
+
27
+ # Configure default email options
28
+ def setup_mail(record, key)
29
+ mapping = Devise.mappings.values.find { |m| m.to == record.class }
30
+ raise "Invalid devise resource #{record}" unless mapping
31
+
32
+ subject translate(mapping, key)
33
+ from self.class.sender
34
+ recipients record.email
35
+ sent_on Time.now
36
+ content_type 'text/html'
37
+ body mapping.name => record, :resource => record
38
+ end
39
+
40
+ # Setup subject namespaced by model. It means you're able to setup your
41
+ # messages using specific resource scope, or provide a default one.
42
+ # Example (i18n locale file):
43
+ #
44
+ # en:
45
+ # devise:
46
+ # mailer:
47
+ # confirmation_instructions: '...'
48
+ # user:
49
+ # confirmation_instructions: '...'
50
+ def translate(mapping, key)
51
+ I18n.t(:"#{mapping.name}.#{key}", :scope => [:devise, :mailer], :default => key)
52
+ end
53
+ end
@@ -0,0 +1,16 @@
1
+ <h2>Resend confirmation instructions</h2>
2
+
3
+ <% form_for resource_name, resource, :url => confirmation_path(resource_name) do |f| %>
4
+ <%= f.error_messages %>
5
+
6
+ <p><%= f.label :email %></p>
7
+ <p><%= f.text_field :email %></p>
8
+
9
+ <p><%= f.submit "Resend confirmation instructions" %></p>
10
+ <% end %>
11
+
12
+ <%= link_to "Sign in", new_session_path(resource_name) %><br />
13
+
14
+ <%- if devise_mapping.recoverable? %>
15
+ <%= link_to "Forgot password?", new_password_path(resource_name) %><br />
16
+ <% end -%>
@@ -0,0 +1,5 @@
1
+ Welcome <%= @resource.email %>!
2
+
3
+ You can confirm your account through the link below:
4
+
5
+ <%= link_to 'Confirm my account', confirmation_url(@resource, :confirmation_token => @resource.confirmation_token) %>
@@ -0,0 +1,8 @@
1
+ Hello <%= @resource.email %>!
2
+
3
+ Someone has requested a link to change your password, and you can do this through the link below.
4
+
5
+ <%= link_to 'Change my password', edit_password_url(@resource, :reset_password_token => @resource.reset_password_token) %>
6
+
7
+ If you didn't request this, please ignore this email.
8
+ Your password won't change until you access the link above and create a new one.
@@ -0,0 +1,20 @@
1
+ <h2>Change your password</h2>
2
+
3
+ <% form_for resource_name, resource, :url => password_path(resource_name), :html => { :method => :put } do |f| %>
4
+ <%= f.error_messages %>
5
+ <%= f.hidden_field :reset_password_token %>
6
+
7
+ <p><%= f.label :password %></p>
8
+ <p><%= f.password_field :password %></p>
9
+
10
+ <p><%= f.label :password_confirmation %></p>
11
+ <p><%= f.password_field :password_confirmation %></p>
12
+
13
+ <p><%= f.submit "Change my password" %></p>
14
+ <% end %>
15
+
16
+ <%= link_to "Sign in", new_session_path(resource_name) %><br />
17
+
18
+ <%- if devise_mapping.confirmable? %>
19
+ <%= link_to "Didn't receive confirmation instructions?", new_confirmation_path(resource_name) %><br />
20
+ <% end -%>
@@ -0,0 +1,16 @@
1
+ <h2>Forgot your password?</h2>
2
+
3
+ <% form_for resource_name, resource, :url => password_path(resource_name) do |f| %>
4
+ <%= f.error_messages %>
5
+
6
+ <p><%= f.label :email %></p>
7
+ <p><%= f.text_field :email %></p>
8
+
9
+ <p><%= f.submit "Send me reset password instructions" %></p>
10
+ <% end %>
11
+
12
+ <%= link_to "Sign in", new_session_path(resource_name) %><br />
13
+
14
+ <%- if devise_mapping.confirmable? %>
15
+ <%= link_to "Didn't receive confirmation instructions?", new_confirmation_path(resource_name) %><br />
16
+ <% end -%>
@@ -0,0 +1,23 @@
1
+ <h2>Sign in</h2>
2
+
3
+ <% form_for resource_name, resource, :url => session_path(resource_name) do |f| -%>
4
+ <p><%= f.label :email %></p>
5
+ <p><%= f.text_field :email %></p>
6
+
7
+ <p><%= f.label :password %></p>
8
+ <p><%= f.password_field :password %></p>
9
+
10
+ <% if devise_mapping.rememberable? -%>
11
+ <p><%= f.check_box :remember_me %> <%= f.label :remember_me %></p>
12
+ <% end -%>
13
+
14
+ <p><%= f.submit "Sign in" %></p>
15
+ <% end -%>
16
+
17
+ <%- if devise_mapping.recoverable? %>
18
+ <%= link_to "Forgot password?", new_password_path(resource_name) %><br />
19
+ <% end -%>
20
+
21
+ <%- if devise_mapping.confirmable? %>
22
+ <%= link_to "Didn't receive confirmation instructions?", new_confirmation_path(resource_name) %><br />
23
+ <% end -%>
@@ -0,0 +1,5 @@
1
+ To create a devise resource user:
2
+
3
+ script/generate devise User
4
+
5
+ This will generate a model named User, a route map for devise called :users, and a migration file for table :users with all devise modules.
@@ -0,0 +1,25 @@
1
+ require File.expand_path(File.dirname(__FILE__) + "/lib/route_devise.rb")
2
+
3
+ class DeviseGenerator < Rails::Generator::NamedBase
4
+
5
+ def manifest
6
+ record do |m|
7
+ # Check for class naming collisions.
8
+ m.class_collisions(class_name)
9
+
10
+ # Model
11
+ m.directory(File.join('app', 'models', class_path))
12
+ m.template 'model.rb', File.join('app', 'models', "#{file_path}.rb")
13
+
14
+ # Migration
15
+ m.migration_template 'migration.rb', 'db/migrate', :migration_file_name => "devise_create_#{table_name}"
16
+
17
+ # Routing
18
+ m.route_devise table_name
19
+
20
+ # Readme
21
+ m.readme "README"
22
+ end
23
+ end
24
+
25
+ end
@@ -0,0 +1,32 @@
1
+ module Rails
2
+ module Generator
3
+ module Commands
4
+ class Create < Base
5
+
6
+ # Create devise route. Based on route_resources
7
+ def route_devise(*resources)
8
+ resource_list = resources.map { |r| r.to_sym.inspect }.join(', ')
9
+ sentinel = 'ActionController::Routing::Routes.draw do |map|'
10
+
11
+ logger.route "map.devise_for #{resource_list}"
12
+ unless options[:pretend]
13
+ gsub_file 'config/routes.rb', /(#{Regexp.escape(sentinel)})/mi do |match|
14
+ "#{match}\n map.devise_for #{resource_list}\n"
15
+ end
16
+ end
17
+ end
18
+ end
19
+
20
+ class Destroy < RewindBase
21
+
22
+ # Destroy devise route. Based on route_resources
23
+ def route_devise(*resources)
24
+ resource_list = resources.map { |r| r.to_sym.inspect }.join(', ')
25
+ look_for = "\n map.devise_for #{resource_list}\n"
26
+ logger.route "map.devise_for #{resource_list}"
27
+ gsub_file 'config/routes.rb', /(#{look_for})/mi, ''
28
+ end
29
+ end
30
+ end
31
+ end
32
+ end
@@ -0,0 +1,22 @@
1
+
2
+ ================================================================================
3
+
4
+ Some setup you must do manually if you haven't yet:
5
+
6
+ 1. Setup defaut url options for your specific environment. Here is an example of development environment:
7
+
8
+ config.action_mailer.default_url_options = { :host => 'localhost:3000' }
9
+
10
+ It's a Rails required configuration. In production it must be the actual host your application is deployed to.
11
+
12
+ 2. Setup default sender for mails. In config/environment.rb:
13
+
14
+ DeviseMailer.sender = "test@example.com"
15
+
16
+ You can also configure this value by running script/generate devise_install and setting config.mailer_sender,
17
+
18
+ 3. Ensure you have defined root_url to *something* in your config/routes.rb:
19
+
20
+ map.root :controller => 'home'
21
+
22
+ ================================================================================
@@ -0,0 +1,20 @@
1
+ class DeviseCreate<%= table_name.camelize %> < ActiveRecord::Migration
2
+ def self.up
3
+ create_table(:<%= table_name %>) do |t|
4
+ t.authenticatable
5
+ t.confirmable
6
+ t.recoverable
7
+ t.rememberable
8
+
9
+ t.timestamps
10
+ end
11
+
12
+ add_index :<%= table_name %>, :email, :unique => true
13
+ add_index :<%= table_name %>, :confirmation_token, :unique => true
14
+ add_index :<%= table_name %>, :reset_password_token, :unique => true
15
+ end
16
+
17
+ def self.down
18
+ drop_table :<%= table_name %>
19
+ end
20
+ end
@@ -0,0 +1,5 @@
1
+ class <%= class_name %> < ActiveRecord::Base
2
+ devise :all
3
+ # Setup accessible (or protected) attributes for your model
4
+ attr_accessible :email, :password, :password_confirmation
5
+ end
@@ -0,0 +1,3 @@
1
+ To copy a Devise initializer to your Rails App, with some configuration values, just do:
2
+
3
+ script/generate devise_install
@@ -0,0 +1,9 @@
1
+ class DeviseInstallGenerator < Rails::Generator::Base
2
+
3
+ def manifest
4
+ record do |m|
5
+ m.file "devise.rb", "config/initializers/devise.rb"
6
+ end
7
+ end
8
+
9
+ end
@@ -0,0 +1,40 @@
1
+ # Use this hook to configure devise mailer, warden hooks and so forth. The first
2
+ # four configuration values can also be set straight in your models.
3
+ Devise.setup do |config|
4
+ # Invoke `rake secret` and use the printed value to setup a pepper to generate
5
+ # the encrypted password. By default no pepper is used.
6
+ # config.pepper = "rake secret output"
7
+
8
+ # Configure how many times you want the password is reencrypted. Default is 10.
9
+ # config.stretches = 10
10
+
11
+ # The time you want give to your user to confirm his account. During this time
12
+ # he will be able to access your application without confirming. Default is nil.
13
+ # config.confirm_within = 2.days
14
+
15
+ # The time the user will be remembered without asking for credentials again.
16
+ # config.remember_for = 2.weeks
17
+
18
+ # Configure the e-mail address which will be shown in DeviseMailer.
19
+ # config.mailer_sender = "foo.bar@yourapp.com"
20
+
21
+ # If you want to use other strategies, that are not (yet) supported by Devise,
22
+ # you can configure them inside the config.warden block. The example below
23
+ # allows you to setup OAuth, using http://github.com/roman/warden_oauth
24
+ #
25
+ # config.warden do |manager|
26
+ # manager.oauth(:twitter) do |twitter|
27
+ # twitter.consumer_secret = <YOUR CONSUMER SECRET>
28
+ # twitter.consumer_key = <YOUR CONSUMER KEY>
29
+ # twitter.options :site => 'http://twitter.com'
30
+ # end
31
+ # manager.default_strategies.unshift :twitter_oauth
32
+ # end
33
+
34
+ # Configure default_url_options if you are using dynamic segments in :path_prefix
35
+ # for devise_for.
36
+ #
37
+ # config.default_url_options do
38
+ # { :locale => I18n.locale }
39
+ # end
40
+ end
@@ -0,0 +1,3 @@
1
+ To copy all session, password, confirmation and mailer views from devise to your app just run the following command:
2
+
3
+ script/generate devise_views
@@ -0,0 +1,24 @@
1
+ class DeviseViewsGenerator < Rails::Generator::Base
2
+
3
+ def initialize(*args)
4
+ super
5
+ @source_root = options[:source] || File.join(spec.path, '..', '..')
6
+ end
7
+
8
+ def manifest
9
+ record do |m|
10
+ m.directory "app/views"
11
+
12
+ Dir[File.join(@source_root, "app", "views", "**/*.erb")].each do |file|
13
+ file = file.gsub(@source_root, "")[1..-1]
14
+
15
+ m.directory File.dirname(file)
16
+ m.file file, file
17
+ end
18
+
19
+ m.directory "config/locales"
20
+ m.file "lib/devise/locales/en.yml", "config/locales/devise.en.yml"
21
+ end
22
+ end
23
+
24
+ end
data/init.rb ADDED
@@ -0,0 +1,2 @@
1
+ # We need to load devise here to ensure routes extensions are loaded.
2
+ require 'devise'
@@ -0,0 +1,79 @@
1
+ module Devise
2
+ ALL = [:authenticatable, :confirmable, :recoverable, :rememberable, :validatable].freeze
3
+
4
+ # Maps controller names to devise modules
5
+ CONTROLLERS = {
6
+ :sessions => :authenticatable,
7
+ :passwords => :recoverable,
8
+ :confirmations => :confirmable
9
+ }.freeze
10
+
11
+ STRATEGIES = [:rememberable, :authenticatable].freeze
12
+ TRUE_VALUES = [true, 1, '1', 't', 'T', 'true', 'TRUE'].freeze
13
+
14
+ # Maps the messages types that comes from warden to a flash type.
15
+ FLASH_MESSAGES = {
16
+ :unauthenticated => :success,
17
+ :unconfirmed => :failure
18
+ }
19
+
20
+ # Models configuration
21
+ mattr_accessor :pepper, :stretches, :remember_for, :confirm_within
22
+
23
+ # Mappings
24
+ mattr_accessor :mappings
25
+ self.mappings = {}
26
+
27
+ class << self
28
+ # Default way to setup Devise. Run script/generate devise_install to create
29
+ # a fresh initializer with all configuration values.
30
+ def setup
31
+ yield self
32
+ end
33
+
34
+ def mail_sender=(value) #:nodoc:
35
+ ActiveSupport::Deprecation.warn "Devise.mail_sender= is deprecated, use Devise.mailer_sender instead"
36
+ DeviseMailer.sender = value
37
+ end
38
+
39
+ # Sets the sender in DeviseMailer.
40
+ def mailer_sender=(value)
41
+ DeviseMailer.sender = value
42
+ end
43
+ alias :sender= :mailer_sender=
44
+
45
+ # Sets warden configuration using a block that will be invoked on warden
46
+ # initialization.
47
+ #
48
+ # Devise.initialize do |config|
49
+ # config.confirm_within = 2.days
50
+ #
51
+ # config.warden do |manager|
52
+ # # Configure warden to use other strategies, like oauth.
53
+ # manager.oauth(:twitter)
54
+ # end
55
+ # end
56
+ def warden(&block)
57
+ @warden_config = block
58
+ end
59
+
60
+ # Configure default url options to be used within Devise and ActionController.
61
+ def default_url_options(&block)
62
+ Devise::Mapping.metaclass.send :define_method, :default_url_options, &block
63
+ end
64
+
65
+ # A method used internally to setup warden manager from the Rails initialize
66
+ # block.
67
+ def configure_warden_manager(manager) #:nodoc:
68
+ manager.default_strategies *Devise::STRATEGIES
69
+ manager.failure_app = Devise::Failure
70
+ manager.silence_missing_strategies!
71
+
72
+ # If the user provided a warden hook, call it now.
73
+ @warden_config.try :call, manager
74
+ end
75
+ end
76
+ end
77
+
78
+ require 'devise/warden'
79
+ require 'devise/rails'