devise 4.4.3 → 4.9.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CHANGELOG.md +159 -3
- data/MIT-LICENSE +2 -1
- data/README.md +128 -64
- data/app/controllers/devise/confirmations_controller.rb +1 -0
- data/app/controllers/devise/passwords_controller.rb +3 -2
- data/app/controllers/devise/registrations_controller.rb +27 -9
- data/app/controllers/devise/sessions_controller.rb +1 -1
- data/app/controllers/devise/unlocks_controller.rb +1 -0
- data/app/controllers/devise_controller.rb +4 -3
- data/app/helpers/devise_helper.rb +21 -18
- data/app/mailers/devise/mailer.rb +5 -5
- data/app/views/devise/confirmations/new.html.erb +1 -1
- data/app/views/devise/passwords/edit.html.erb +3 -3
- data/app/views/devise/passwords/new.html.erb +1 -1
- data/app/views/devise/registrations/edit.html.erb +5 -5
- data/app/views/devise/registrations/new.html.erb +3 -3
- data/app/views/devise/sessions/new.html.erb +3 -3
- data/app/views/devise/shared/_error_messages.html.erb +15 -0
- data/app/views/devise/shared/_links.html.erb +8 -8
- data/app/views/devise/unlocks/new.html.erb +1 -1
- data/config/locales/en.yml +3 -2
- data/lib/devise/controllers/helpers.rb +8 -8
- data/lib/devise/controllers/responder.rb +35 -0
- data/lib/devise/controllers/sign_in_out.rb +8 -3
- data/lib/devise/controllers/url_helpers.rb +1 -1
- data/lib/devise/failure_app.rb +31 -7
- data/lib/devise/hooks/csrf_cleaner.rb +6 -1
- data/lib/devise/hooks/lockable.rb +2 -5
- data/lib/devise/hooks/timeoutable.rb +2 -2
- data/lib/devise/mapping.rb +1 -1
- data/lib/devise/models/authenticatable.rb +51 -48
- data/lib/devise/models/confirmable.rb +34 -40
- data/lib/devise/models/database_authenticatable.rb +54 -35
- data/lib/devise/models/lockable.rb +13 -5
- data/lib/devise/models/omniauthable.rb +2 -2
- data/lib/devise/models/recoverable.rb +8 -19
- data/lib/devise/models/registerable.rb +2 -0
- data/lib/devise/models/rememberable.rb +2 -2
- data/lib/devise/models/timeoutable.rb +1 -1
- data/lib/devise/models/trackable.rb +9 -2
- data/lib/devise/models/validatable.rb +4 -9
- data/lib/devise/models.rb +1 -0
- data/lib/devise/omniauth.rb +2 -5
- data/lib/devise/orm.rb +71 -0
- data/lib/devise/parameter_filter.rb +2 -0
- data/lib/devise/parameter_sanitizer.rb +13 -1
- data/lib/devise/rails/deprecated_constant_accessor.rb +39 -0
- data/lib/devise/rails/routes.rb +6 -6
- data/lib/devise/secret_key_finder.rb +2 -0
- data/lib/devise/strategies/authenticatable.rb +1 -1
- data/lib/devise/strategies/database_authenticatable.rb +6 -1
- data/lib/devise/test/controller_helpers.rb +4 -2
- data/lib/devise/test/integration_helpers.rb +1 -1
- data/lib/devise/version.rb +1 -1
- data/lib/devise.rb +34 -11
- data/lib/generators/active_record/devise_generator.rb +26 -11
- data/lib/generators/devise/controllers_generator.rb +1 -1
- data/lib/generators/devise/devise_generator.rb +1 -1
- data/lib/generators/devise/install_generator.rb +1 -5
- data/lib/generators/devise/orm_helpers.rb +2 -2
- data/lib/generators/devise/views_generator.rb +1 -1
- data/lib/generators/mongoid/devise_generator.rb +5 -5
- data/lib/generators/templates/README +9 -1
- data/lib/generators/templates/controllers/omniauth_callbacks_controller.rb +1 -1
- data/lib/generators/templates/devise.rb +38 -8
- data/lib/generators/templates/simple_form_for/confirmations/new.html.erb +5 -1
- data/lib/generators/templates/simple_form_for/passwords/edit.html.erb +10 -2
- data/lib/generators/templates/simple_form_for/passwords/new.html.erb +4 -1
- data/lib/generators/templates/simple_form_for/registrations/edit.html.erb +12 -4
- data/lib/generators/templates/simple_form_for/registrations/new.html.erb +11 -3
- data/lib/generators/templates/simple_form_for/sessions/new.html.erb +7 -2
- data/lib/generators/templates/simple_form_for/unlocks/new.html.erb +4 -1
- metadata +23 -316
- data/.gitignore +0 -10
- data/.travis.yml +0 -68
- data/.yardopts +0 -9
- data/CODE_OF_CONDUCT.md +0 -22
- data/CONTRIBUTING.md +0 -79
- data/Gemfile +0 -39
- data/Gemfile.lock +0 -193
- data/ISSUE_TEMPLATE.md +0 -19
- data/Rakefile +0 -37
- data/bin/test +0 -13
- data/devise.gemspec +0 -28
- data/devise.png +0 -0
- data/gemfiles/Gemfile.rails-4.1-stable +0 -32
- data/gemfiles/Gemfile.rails-4.1-stable.lock +0 -171
- data/gemfiles/Gemfile.rails-4.2-stable +0 -32
- data/gemfiles/Gemfile.rails-4.2-stable.lock +0 -192
- data/gemfiles/Gemfile.rails-5.0-stable +0 -33
- data/gemfiles/Gemfile.rails-5.0-stable.lock +0 -192
- data/gemfiles/Gemfile.rails-5.2-rc1 +0 -26
- data/gemfiles/Gemfile.rails-5.2-rc1.lock +0 -201
- data/guides/bug_report_templates/integration_test.rb +0 -106
- data/test/controllers/custom_registrations_controller_test.rb +0 -42
- data/test/controllers/custom_strategy_test.rb +0 -66
- data/test/controllers/helper_methods_test.rb +0 -24
- data/test/controllers/helpers_test.rb +0 -318
- data/test/controllers/inherited_controller_i18n_messages_test.rb +0 -53
- data/test/controllers/internal_helpers_test.rb +0 -129
- data/test/controllers/load_hooks_controller_test.rb +0 -21
- data/test/controllers/passwords_controller_test.rb +0 -34
- data/test/controllers/sessions_controller_test.rb +0 -108
- data/test/controllers/url_helpers_test.rb +0 -67
- data/test/delegator_test.rb +0 -21
- data/test/devise_test.rb +0 -109
- data/test/failure_app_test.rb +0 -340
- data/test/generators/active_record_generator_test.rb +0 -130
- data/test/generators/controllers_generator_test.rb +0 -50
- data/test/generators/devise_generator_test.rb +0 -41
- data/test/generators/install_generator_test.rb +0 -26
- data/test/generators/mongoid_generator_test.rb +0 -25
- data/test/generators/views_generator_test.rb +0 -105
- data/test/helpers/devise_helper_test.rb +0 -51
- data/test/integration/authenticatable_test.rb +0 -706
- data/test/integration/confirmable_test.rb +0 -326
- data/test/integration/database_authenticatable_test.rb +0 -97
- data/test/integration/http_authenticatable_test.rb +0 -114
- data/test/integration/lockable_test.rb +0 -242
- data/test/integration/mounted_engine_test.rb +0 -38
- data/test/integration/omniauthable_test.rb +0 -148
- data/test/integration/recoverable_test.rb +0 -349
- data/test/integration/registerable_test.rb +0 -365
- data/test/integration/rememberable_test.rb +0 -219
- data/test/integration/timeoutable_test.rb +0 -186
- data/test/integration/trackable_test.rb +0 -99
- data/test/mailers/confirmation_instructions_test.rb +0 -117
- data/test/mailers/email_changed_test.rb +0 -132
- data/test/mailers/mailer_test.rb +0 -20
- data/test/mailers/reset_password_instructions_test.rb +0 -98
- data/test/mailers/unlock_instructions_test.rb +0 -93
- data/test/mapping_test.rb +0 -136
- data/test/models/authenticatable_test.rb +0 -25
- data/test/models/confirmable_test.rb +0 -549
- data/test/models/database_authenticatable_test.rb +0 -283
- data/test/models/lockable_test.rb +0 -352
- data/test/models/omniauthable_test.rb +0 -9
- data/test/models/recoverable_test.rb +0 -263
- data/test/models/registerable_test.rb +0 -9
- data/test/models/rememberable_test.rb +0 -184
- data/test/models/serializable_test.rb +0 -60
- data/test/models/timeoutable_test.rb +0 -53
- data/test/models/trackable_test.rb +0 -62
- data/test/models/validatable_test.rb +0 -121
- data/test/models_test.rb +0 -155
- data/test/omniauth/config_test.rb +0 -61
- data/test/omniauth/url_helpers_test.rb +0 -53
- data/test/orm/active_record.rb +0 -24
- data/test/orm/mongoid.rb +0 -15
- data/test/parameter_sanitizer_test.rb +0 -77
- data/test/rails_app/Rakefile +0 -6
- data/test/rails_app/app/active_record/admin.rb +0 -8
- data/test/rails_app/app/active_record/shim.rb +0 -4
- data/test/rails_app/app/active_record/user.rb +0 -20
- data/test/rails_app/app/active_record/user_on_engine.rb +0 -9
- data/test/rails_app/app/active_record/user_on_main_app.rb +0 -9
- data/test/rails_app/app/active_record/user_with_validations.rb +0 -12
- data/test/rails_app/app/active_record/user_without_email.rb +0 -10
- data/test/rails_app/app/controllers/admins/sessions_controller.rb +0 -8
- data/test/rails_app/app/controllers/admins_controller.rb +0 -8
- data/test/rails_app/app/controllers/application_controller.rb +0 -13
- data/test/rails_app/app/controllers/application_with_fake_engine.rb +0 -32
- data/test/rails_app/app/controllers/custom/registrations_controller.rb +0 -33
- data/test/rails_app/app/controllers/home_controller.rb +0 -31
- data/test/rails_app/app/controllers/publisher/registrations_controller.rb +0 -4
- data/test/rails_app/app/controllers/publisher/sessions_controller.rb +0 -4
- data/test/rails_app/app/controllers/users/omniauth_callbacks_controller.rb +0 -16
- data/test/rails_app/app/controllers/users_controller.rb +0 -33
- data/test/rails_app/app/helpers/application_helper.rb +0 -5
- data/test/rails_app/app/mailers/users/from_proc_mailer.rb +0 -5
- data/test/rails_app/app/mailers/users/mailer.rb +0 -5
- data/test/rails_app/app/mailers/users/reply_to_mailer.rb +0 -6
- data/test/rails_app/app/mongoid/admin.rb +0 -31
- data/test/rails_app/app/mongoid/shim.rb +0 -25
- data/test/rails_app/app/mongoid/user.rb +0 -50
- data/test/rails_app/app/mongoid/user_on_engine.rb +0 -41
- data/test/rails_app/app/mongoid/user_on_main_app.rb +0 -41
- data/test/rails_app/app/mongoid/user_with_validations.rb +0 -37
- data/test/rails_app/app/mongoid/user_without_email.rb +0 -35
- data/test/rails_app/app/views/admins/index.html.erb +0 -1
- data/test/rails_app/app/views/admins/sessions/new.html.erb +0 -2
- data/test/rails_app/app/views/home/admin_dashboard.html.erb +0 -1
- data/test/rails_app/app/views/home/index.html.erb +0 -1
- data/test/rails_app/app/views/home/join.html.erb +0 -1
- data/test/rails_app/app/views/home/private.html.erb +0 -1
- data/test/rails_app/app/views/home/user_dashboard.html.erb +0 -1
- data/test/rails_app/app/views/layouts/application.html.erb +0 -24
- data/test/rails_app/app/views/users/edit_form.html.erb +0 -1
- data/test/rails_app/app/views/users/index.html.erb +0 -1
- data/test/rails_app/app/views/users/mailer/confirmation_instructions.erb +0 -1
- data/test/rails_app/app/views/users/sessions/new.html.erb +0 -1
- data/test/rails_app/bin/bundle +0 -3
- data/test/rails_app/bin/rails +0 -4
- data/test/rails_app/bin/rake +0 -4
- data/test/rails_app/config/application.rb +0 -48
- data/test/rails_app/config/boot.rb +0 -27
- data/test/rails_app/config/database.yml +0 -18
- data/test/rails_app/config/environment.rb +0 -7
- data/test/rails_app/config/environments/development.rb +0 -32
- data/test/rails_app/config/environments/production.rb +0 -88
- data/test/rails_app/config/environments/test.rb +0 -47
- data/test/rails_app/config/initializers/backtrace_silencers.rb +0 -9
- data/test/rails_app/config/initializers/devise.rb +0 -182
- data/test/rails_app/config/initializers/inflections.rb +0 -4
- data/test/rails_app/config/initializers/secret_token.rb +0 -5
- data/test/rails_app/config/initializers/session_store.rb +0 -3
- data/test/rails_app/config/routes.rb +0 -128
- data/test/rails_app/config.ru +0 -4
- data/test/rails_app/db/migrate/20100401102949_create_tables.rb +0 -77
- data/test/rails_app/db/schema.rb +0 -57
- data/test/rails_app/lib/shared_admin.rb +0 -23
- data/test/rails_app/lib/shared_user.rb +0 -32
- data/test/rails_app/lib/shared_user_without_email.rb +0 -28
- data/test/rails_app/lib/shared_user_without_omniauth.rb +0 -15
- data/test/rails_app/public/404.html +0 -26
- data/test/rails_app/public/422.html +0 -26
- data/test/rails_app/public/500.html +0 -26
- data/test/rails_app/public/favicon.ico +0 -0
- data/test/rails_test.rb +0 -11
- data/test/routes_test.rb +0 -281
- data/test/secret_key_finder_test.rb +0 -97
- data/test/support/action_controller/record_identifier.rb +0 -12
- data/test/support/assertions.rb +0 -30
- data/test/support/helpers.rb +0 -83
- data/test/support/http_method_compatibility.rb +0 -53
- data/test/support/integration.rb +0 -95
- data/test/support/locale/en.yml +0 -8
- data/test/support/mongoid.yml +0 -6
- data/test/support/webrat/integrations/rails.rb +0 -35
- data/test/test/controller_helpers_test.rb +0 -193
- data/test/test/integration_helpers_test.rb +0 -34
- data/test/test_helper.rb +0 -36
- data/test/test_models.rb +0 -35
|
@@ -7,7 +7,7 @@ module Devise
|
|
|
7
7
|
#
|
|
8
8
|
# ==Options
|
|
9
9
|
#
|
|
10
|
-
# Recoverable adds the following options to
|
|
10
|
+
# Recoverable adds the following options to +devise+:
|
|
11
11
|
#
|
|
12
12
|
# * +reset_password_keys+: the keys you want to use when recovering the password for an account
|
|
13
13
|
# * +reset_password_within+: the time period within which the password must be reset or the token expires.
|
|
@@ -99,24 +99,13 @@ module Devise
|
|
|
99
99
|
send_devise_notification(:reset_password_instructions, token, {})
|
|
100
100
|
end
|
|
101
101
|
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
respond_to?("will_save_change_to_#{attribute}?") && send("will_save_change_to_#{attribute}?")
|
|
107
|
-
end
|
|
108
|
-
|
|
109
|
-
authentication_keys_changed || encrypted_password_changed
|
|
102
|
+
def clear_reset_password_token?
|
|
103
|
+
encrypted_password_changed = devise_respond_to_and_will_save_change_to_attribute?(:encrypted_password)
|
|
104
|
+
authentication_keys_changed = self.class.authentication_keys.any? do |attribute|
|
|
105
|
+
devise_respond_to_and_will_save_change_to_attribute?(attribute)
|
|
110
106
|
end
|
|
111
|
-
else
|
|
112
|
-
def clear_reset_password_token?
|
|
113
|
-
encrypted_password_changed = respond_to?(:encrypted_password_changed?) && encrypted_password_changed?
|
|
114
|
-
authentication_keys_changed = self.class.authentication_keys.any? do |attribute|
|
|
115
|
-
respond_to?("#{attribute}_changed?") && send("#{attribute}_changed?")
|
|
116
|
-
end
|
|
117
107
|
|
|
118
|
-
|
|
119
|
-
end
|
|
108
|
+
authentication_keys_changed || encrypted_password_changed
|
|
120
109
|
end
|
|
121
110
|
|
|
122
111
|
module ClassMethods
|
|
@@ -131,7 +120,7 @@ module Devise
|
|
|
131
120
|
# password instructions to it. If user is not found, returns a new user
|
|
132
121
|
# with an email not found error.
|
|
133
122
|
# Attributes must contain the user's email
|
|
134
|
-
def send_reset_password_instructions(attributes={})
|
|
123
|
+
def send_reset_password_instructions(attributes = {})
|
|
135
124
|
recoverable = find_or_initialize_with_errors(reset_password_keys, attributes, :not_found)
|
|
136
125
|
recoverable.send_reset_password_instructions if recoverable.persisted?
|
|
137
126
|
recoverable
|
|
@@ -142,7 +131,7 @@ module Devise
|
|
|
142
131
|
# try saving the record. If not user is found, returns a new user
|
|
143
132
|
# containing an error in reset_password_token attribute.
|
|
144
133
|
# Attributes must contain reset_password_token, password and confirmation
|
|
145
|
-
def reset_password_by_token(attributes={})
|
|
134
|
+
def reset_password_by_token(attributes = {})
|
|
146
135
|
original_token = attributes[:reset_password_token]
|
|
147
136
|
reset_password_token = Devise.token_generator.digest(self, :reset_password_token, original_token)
|
|
148
137
|
|
|
@@ -15,7 +15,7 @@ module Devise
|
|
|
15
15
|
#
|
|
16
16
|
# == Options
|
|
17
17
|
#
|
|
18
|
-
# Rememberable adds the following options
|
|
18
|
+
# Rememberable adds the following options to +devise+:
|
|
19
19
|
#
|
|
20
20
|
# * +remember_for+: the time you want the user will be remembered without
|
|
21
21
|
# asking for credentials. After this time the user will be blocked and
|
|
@@ -102,7 +102,7 @@ module Devise
|
|
|
102
102
|
|
|
103
103
|
def remember_me?(token, generated_at)
|
|
104
104
|
# TODO: Normalize the JSON type coercion along with the Timeoutable hook
|
|
105
|
-
# in a single place https://github.com/
|
|
105
|
+
# in a single place https://github.com/heartcombo/devise/blob/ffe9d6d406e79108cf32a2c6a1d0b3828849c40b/lib/devise/hooks/timeoutable.rb#L14-L18
|
|
106
106
|
if generated_at.is_a?(String)
|
|
107
107
|
generated_at = time_from_json(generated_at)
|
|
108
108
|
end
|
|
@@ -22,7 +22,7 @@ module Devise
|
|
|
22
22
|
self.last_sign_in_at = old_current || new_current
|
|
23
23
|
self.current_sign_in_at = new_current
|
|
24
24
|
|
|
25
|
-
old_current, new_current = self.current_sign_in_ip, request
|
|
25
|
+
old_current, new_current = self.current_sign_in_ip, extract_ip_from(request)
|
|
26
26
|
self.last_sign_in_ip = old_current || new_current
|
|
27
27
|
self.current_sign_in_ip = new_current
|
|
28
28
|
|
|
@@ -33,12 +33,19 @@ module Devise
|
|
|
33
33
|
def update_tracked_fields!(request)
|
|
34
34
|
# We have to check if the user is already persisted before running
|
|
35
35
|
# `save` here because invalid users can be saved if we don't.
|
|
36
|
-
# See https://github.com/
|
|
36
|
+
# See https://github.com/heartcombo/devise/issues/4673 for more details.
|
|
37
37
|
return if new_record?
|
|
38
38
|
|
|
39
39
|
update_tracked_fields(request)
|
|
40
40
|
save(validate: false)
|
|
41
41
|
end
|
|
42
|
+
|
|
43
|
+
protected
|
|
44
|
+
|
|
45
|
+
def extract_ip_from(request)
|
|
46
|
+
request.remote_ip
|
|
47
|
+
end
|
|
48
|
+
|
|
42
49
|
end
|
|
43
50
|
end
|
|
44
51
|
end
|
|
@@ -9,7 +9,7 @@ module Devise
|
|
|
9
9
|
#
|
|
10
10
|
# == Options
|
|
11
11
|
#
|
|
12
|
-
# Validatable adds the following options to
|
|
12
|
+
# Validatable adds the following options to +devise+:
|
|
13
13
|
#
|
|
14
14
|
# * +email_regexp+: the regular expression used to validate e-mails;
|
|
15
15
|
# * +password_length+: a range expressing password length. Defaults to 6..128.
|
|
@@ -29,13 +29,8 @@ module Devise
|
|
|
29
29
|
|
|
30
30
|
base.class_eval do
|
|
31
31
|
validates_presence_of :email, if: :email_required?
|
|
32
|
-
if
|
|
33
|
-
|
|
34
|
-
validates_format_of :email, with: email_regexp, allow_blank: true, if: :will_save_change_to_email?
|
|
35
|
-
else
|
|
36
|
-
validates_uniqueness_of :email, allow_blank: true, if: :email_changed?
|
|
37
|
-
validates_format_of :email, with: email_regexp, allow_blank: true, if: :email_changed?
|
|
38
|
-
end
|
|
32
|
+
validates_uniqueness_of :email, allow_blank: true, case_sensitive: true, if: :devise_will_save_change_to_email?
|
|
33
|
+
validates_format_of :email, with: email_regexp, allow_blank: true, if: :devise_will_save_change_to_email?
|
|
39
34
|
|
|
40
35
|
validates_presence_of :password, if: :password_required?
|
|
41
36
|
validates_confirmation_of :password, if: :password_required?
|
|
@@ -47,7 +42,7 @@ module Devise
|
|
|
47
42
|
unavailable_validations = VALIDATIONS.select { |v| !base.respond_to?(v) }
|
|
48
43
|
|
|
49
44
|
unless unavailable_validations.empty?
|
|
50
|
-
raise "Could not use :validatable module since #{base} does not respond "
|
|
45
|
+
raise "Could not use :validatable module since #{base} does not respond " \
|
|
51
46
|
"to the following methods: #{unavailable_validations.to_sentence}."
|
|
52
47
|
end
|
|
53
48
|
end
|
data/lib/devise/models.rb
CHANGED
data/lib/devise/omniauth.rb
CHANGED
|
@@ -1,17 +1,14 @@
|
|
|
1
1
|
# frozen_string_literal: true
|
|
2
2
|
|
|
3
3
|
begin
|
|
4
|
+
gem "omniauth", ">= 1.0.0"
|
|
5
|
+
|
|
4
6
|
require "omniauth"
|
|
5
|
-
require "omniauth/version"
|
|
6
7
|
rescue LoadError
|
|
7
8
|
warn "Could not load 'omniauth'. Please ensure you have the omniauth gem >= 1.0.0 installed and listed in your Gemfile."
|
|
8
9
|
raise
|
|
9
10
|
end
|
|
10
11
|
|
|
11
|
-
unless OmniAuth::VERSION =~ /^1\./
|
|
12
|
-
raise "You are using an old OmniAuth version, please ensure you have 1.0.0.pr2 version or later installed."
|
|
13
|
-
end
|
|
14
|
-
|
|
15
12
|
# Clean up the default path_prefix. It will be automatically set by Devise.
|
|
16
13
|
OmniAuth.config.path_prefix = nil
|
|
17
14
|
|
data/lib/devise/orm.rb
ADDED
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
module Devise
|
|
2
|
+
module Orm # :nodoc:
|
|
3
|
+
def self.active_record?(model)
|
|
4
|
+
defined?(ActiveRecord) && model < ActiveRecord::Base
|
|
5
|
+
end
|
|
6
|
+
|
|
7
|
+
def self.active_record_51?(model)
|
|
8
|
+
active_record?(model) && ActiveRecord.gem_version >= Gem::Version.new("5.1.x")
|
|
9
|
+
end
|
|
10
|
+
|
|
11
|
+
def self.included(model)
|
|
12
|
+
if Devise::Orm.active_record_51?(model)
|
|
13
|
+
model.include DirtyTrackingNewMethods
|
|
14
|
+
else
|
|
15
|
+
model.include DirtyTrackingOldMethods
|
|
16
|
+
end
|
|
17
|
+
end
|
|
18
|
+
|
|
19
|
+
module DirtyTrackingNewMethods
|
|
20
|
+
def devise_email_before_last_save
|
|
21
|
+
email_before_last_save
|
|
22
|
+
end
|
|
23
|
+
|
|
24
|
+
def devise_email_in_database
|
|
25
|
+
email_in_database
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
def devise_saved_change_to_email?
|
|
29
|
+
saved_change_to_email?
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
def devise_saved_change_to_encrypted_password?
|
|
33
|
+
saved_change_to_encrypted_password?
|
|
34
|
+
end
|
|
35
|
+
|
|
36
|
+
def devise_will_save_change_to_email?
|
|
37
|
+
will_save_change_to_email?
|
|
38
|
+
end
|
|
39
|
+
|
|
40
|
+
def devise_respond_to_and_will_save_change_to_attribute?(attribute)
|
|
41
|
+
respond_to?("will_save_change_to_#{attribute}?") && send("will_save_change_to_#{attribute}?")
|
|
42
|
+
end
|
|
43
|
+
end
|
|
44
|
+
|
|
45
|
+
module DirtyTrackingOldMethods
|
|
46
|
+
def devise_email_before_last_save
|
|
47
|
+
email_was
|
|
48
|
+
end
|
|
49
|
+
|
|
50
|
+
def devise_email_in_database
|
|
51
|
+
email_was
|
|
52
|
+
end
|
|
53
|
+
|
|
54
|
+
def devise_saved_change_to_email?
|
|
55
|
+
email_changed?
|
|
56
|
+
end
|
|
57
|
+
|
|
58
|
+
def devise_saved_change_to_encrypted_password?
|
|
59
|
+
encrypted_password_changed?
|
|
60
|
+
end
|
|
61
|
+
|
|
62
|
+
def devise_will_save_change_to_email?
|
|
63
|
+
email_changed?
|
|
64
|
+
end
|
|
65
|
+
|
|
66
|
+
def devise_respond_to_and_will_save_change_to_attribute?(attribute)
|
|
67
|
+
respond_to?("#{attribute}_changed?") && send("#{attribute}_changed?")
|
|
68
|
+
end
|
|
69
|
+
end
|
|
70
|
+
end
|
|
71
|
+
end
|
|
@@ -18,6 +18,8 @@ module Devise
|
|
|
18
18
|
|
|
19
19
|
def filtered_hash_by_method_for_given_keys(conditions, method, condition_keys)
|
|
20
20
|
condition_keys.each do |k|
|
|
21
|
+
next unless conditions.key?(k)
|
|
22
|
+
|
|
21
23
|
value = conditions[k]
|
|
22
24
|
conditions[k] = value.send(method) if value.respond_to?(method)
|
|
23
25
|
end
|
|
@@ -135,7 +135,19 @@ module Devise
|
|
|
135
135
|
end
|
|
136
136
|
|
|
137
137
|
def default_params
|
|
138
|
-
|
|
138
|
+
if hashable_resource_params?
|
|
139
|
+
@params.fetch(@resource_name)
|
|
140
|
+
else
|
|
141
|
+
empty_params
|
|
142
|
+
end
|
|
143
|
+
end
|
|
144
|
+
|
|
145
|
+
def hashable_resource_params?
|
|
146
|
+
@params[@resource_name].respond_to?(:permit)
|
|
147
|
+
end
|
|
148
|
+
|
|
149
|
+
def empty_params
|
|
150
|
+
ActionController::Parameters.new({})
|
|
139
151
|
end
|
|
140
152
|
|
|
141
153
|
def permit_keys(parameters, keys)
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
begin
|
|
4
|
+
require 'active_support/deprecation/constant_accessor'
|
|
5
|
+
|
|
6
|
+
module Devise
|
|
7
|
+
DeprecatedConstantAccessor = ActiveSupport::Deprecation::DeprecatedConstantAccessor #:nodoc:
|
|
8
|
+
end
|
|
9
|
+
rescue LoadError
|
|
10
|
+
|
|
11
|
+
# Copy of constant deprecation module from Rails / Active Support version 6, so we can use it
|
|
12
|
+
# with Rails <= 5.0 versions. This can be removed once we support only Rails 5.1 or greater.
|
|
13
|
+
module Devise
|
|
14
|
+
module DeprecatedConstantAccessor #:nodoc:
|
|
15
|
+
def self.included(base)
|
|
16
|
+
require "active_support/inflector/methods"
|
|
17
|
+
|
|
18
|
+
extension = Module.new do
|
|
19
|
+
def const_missing(missing_const_name)
|
|
20
|
+
if class_variable_defined?(:@@_deprecated_constants)
|
|
21
|
+
if (replacement = class_variable_get(:@@_deprecated_constants)[missing_const_name.to_s])
|
|
22
|
+
replacement[:deprecator].warn(replacement[:message] || "#{name}::#{missing_const_name} is deprecated! Use #{replacement[:new]} instead.", Rails::VERSION::MAJOR == 4 ? caller : caller_locations)
|
|
23
|
+
return ActiveSupport::Inflector.constantize(replacement[:new].to_s)
|
|
24
|
+
end
|
|
25
|
+
end
|
|
26
|
+
super
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
def deprecate_constant(const_name, new_constant, message: nil, deprecator: ActiveSupport::Deprecation.instance)
|
|
30
|
+
class_variable_set(:@@_deprecated_constants, {}) unless class_variable_defined?(:@@_deprecated_constants)
|
|
31
|
+
class_variable_get(:@@_deprecated_constants)[const_name.to_s] = { new: new_constant, message: message, deprecator: deprecator }
|
|
32
|
+
end
|
|
33
|
+
end
|
|
34
|
+
base.singleton_class.prepend extension
|
|
35
|
+
end
|
|
36
|
+
end
|
|
37
|
+
end
|
|
38
|
+
|
|
39
|
+
end
|
data/lib/devise/rails/routes.rb
CHANGED
|
@@ -135,10 +135,10 @@ module ActionDispatch::Routing
|
|
|
135
135
|
# * failure_app: a rack app which is invoked whenever there is a failure. Strings representing a given
|
|
136
136
|
# are also allowed as parameter.
|
|
137
137
|
#
|
|
138
|
-
# * sign_out_via: the HTTP method(s) accepted for the :sign_out action (default: :
|
|
138
|
+
# * sign_out_via: the HTTP method(s) accepted for the :sign_out action (default: :delete),
|
|
139
139
|
# if you wish to restrict this to accept only :post or :delete requests you should do:
|
|
140
140
|
#
|
|
141
|
-
# devise_for :users, sign_out_via: [:
|
|
141
|
+
# devise_for :users, sign_out_via: [:get, :post]
|
|
142
142
|
#
|
|
143
143
|
# You need to make sure that your sign_out controls trigger a request with a matching HTTP method.
|
|
144
144
|
#
|
|
@@ -287,7 +287,7 @@ module ActionDispatch::Routing
|
|
|
287
287
|
# root to: "admin/dashboard#show", as: :user_root
|
|
288
288
|
# end
|
|
289
289
|
#
|
|
290
|
-
def authenticate(scope=nil, block=nil)
|
|
290
|
+
def authenticate(scope = nil, block = nil)
|
|
291
291
|
constraints_for(:authenticate!, scope, block) do
|
|
292
292
|
yield
|
|
293
293
|
end
|
|
@@ -311,7 +311,7 @@ module ActionDispatch::Routing
|
|
|
311
311
|
#
|
|
312
312
|
# root to: 'landing#show'
|
|
313
313
|
#
|
|
314
|
-
def authenticated(scope=nil, block=nil)
|
|
314
|
+
def authenticated(scope = nil, block = nil)
|
|
315
315
|
constraints_for(:authenticate?, scope, block) do
|
|
316
316
|
yield
|
|
317
317
|
end
|
|
@@ -328,7 +328,7 @@ module ActionDispatch::Routing
|
|
|
328
328
|
#
|
|
329
329
|
# root to: 'dashboard#show'
|
|
330
330
|
#
|
|
331
|
-
def unauthenticated(scope=nil)
|
|
331
|
+
def unauthenticated(scope = nil)
|
|
332
332
|
constraint = lambda do |request|
|
|
333
333
|
not request.env["warden"].authenticate? scope: scope
|
|
334
334
|
end
|
|
@@ -474,7 +474,7 @@ ERROR
|
|
|
474
474
|
@scope = current_scope
|
|
475
475
|
end
|
|
476
476
|
|
|
477
|
-
def constraints_for(method_to_apply, scope=nil, block=nil)
|
|
477
|
+
def constraints_for(method_to_apply, scope = nil, block = nil)
|
|
478
478
|
constraint = lambda do |request|
|
|
479
479
|
request.env['warden'].send(method_to_apply, scope: scope) &&
|
|
480
480
|
(block.nil? || block.call(request.env["warden"].user(scope)))
|
|
@@ -13,6 +13,8 @@ module Devise
|
|
|
13
13
|
@application.secrets.secret_key_base
|
|
14
14
|
elsif @application.config.respond_to?(:secret_key_base) && key_exists?(@application.config)
|
|
15
15
|
@application.config.secret_key_base
|
|
16
|
+
elsif @application.respond_to?(:secret_key_base) && key_exists?(@application)
|
|
17
|
+
@application.secret_key_base
|
|
16
18
|
end
|
|
17
19
|
end
|
|
18
20
|
|
|
@@ -28,7 +28,7 @@ module Devise
|
|
|
28
28
|
private
|
|
29
29
|
|
|
30
30
|
# Receives a resource and check if it is valid by calling valid_for_authentication?
|
|
31
|
-
#
|
|
31
|
+
# A block that will be triggered while validating can be optionally
|
|
32
32
|
# given as parameter. Check Devise::Models::Authenticatable.valid_for_authentication?
|
|
33
33
|
# for more information.
|
|
34
34
|
#
|
|
@@ -16,8 +16,13 @@ module Devise
|
|
|
16
16
|
success!(resource)
|
|
17
17
|
end
|
|
18
18
|
|
|
19
|
+
# In paranoid mode, hash the password even when a resource doesn't exist for the given authentication key.
|
|
20
|
+
# This is necessary to prevent enumeration attacks - e.g. the request is faster when a resource doesn't
|
|
21
|
+
# exist in the database if the password hashing algorithm is not called.
|
|
19
22
|
mapping.to.new.password = password if !hashed && Devise.paranoid
|
|
20
|
-
|
|
23
|
+
unless resource
|
|
24
|
+
Devise.paranoid ? fail(:invalid) : fail(:not_found_in_database)
|
|
25
|
+
end
|
|
21
26
|
end
|
|
22
27
|
end
|
|
23
28
|
end
|
|
@@ -37,6 +37,8 @@ module Devise
|
|
|
37
37
|
@response
|
|
38
38
|
end
|
|
39
39
|
|
|
40
|
+
ruby2_keywords(:process) if respond_to?(:ruby2_keywords, true)
|
|
41
|
+
|
|
40
42
|
# We need to set up the environment variables and the response in the controller.
|
|
41
43
|
def setup_controller_for_warden #:nodoc:
|
|
42
44
|
@request.env['action_controller.instance'] = @controller
|
|
@@ -139,9 +141,9 @@ module Devise
|
|
|
139
141
|
|
|
140
142
|
status, headers, response = Devise.warden_config[:failure_app].call(env).to_a
|
|
141
143
|
@controller.response.headers.merge!(headers)
|
|
142
|
-
@controller.response.content_type = headers["Content-Type"] unless Rails
|
|
144
|
+
@controller.response.content_type = headers["Content-Type"] unless Rails::VERSION::MAJOR >= 5
|
|
143
145
|
@controller.status = status
|
|
144
|
-
@controller.
|
|
146
|
+
@controller.response_body = response.body
|
|
145
147
|
nil # causes process return @response
|
|
146
148
|
end
|
|
147
149
|
|
|
@@ -28,7 +28,7 @@ module Devise
|
|
|
28
28
|
end
|
|
29
29
|
end
|
|
30
30
|
|
|
31
|
-
# Signs in a specific resource, mimicking a
|
|
31
|
+
# Signs in a specific resource, mimicking a successful sign in
|
|
32
32
|
# operation through +Devise::SessionsController#create+.
|
|
33
33
|
#
|
|
34
34
|
# * +resource+ - The resource that should be authenticated
|
data/lib/devise/version.rb
CHANGED
data/lib/devise.rb
CHANGED
|
@@ -13,6 +13,7 @@ module Devise
|
|
|
13
13
|
autoload :Encryptor, 'devise/encryptor'
|
|
14
14
|
autoload :FailureApp, 'devise/failure_app'
|
|
15
15
|
autoload :OmniAuth, 'devise/omniauth'
|
|
16
|
+
autoload :Orm, 'devise/orm'
|
|
16
17
|
autoload :ParameterFilter, 'devise/parameter_filter'
|
|
17
18
|
autoload :ParameterSanitizer, 'devise/parameter_sanitizer'
|
|
18
19
|
autoload :TestHelpers, 'devise/test_helpers'
|
|
@@ -23,6 +24,7 @@ module Devise
|
|
|
23
24
|
module Controllers
|
|
24
25
|
autoload :Helpers, 'devise/controllers/helpers'
|
|
25
26
|
autoload :Rememberable, 'devise/controllers/rememberable'
|
|
27
|
+
autoload :Responder, 'devise/controllers/responder'
|
|
26
28
|
autoload :ScopedViews, 'devise/controllers/scoped_views'
|
|
27
29
|
autoload :SignInOut, 'devise/controllers/sign_in_out'
|
|
28
30
|
autoload :StoreLocation, 'devise/controllers/store_location'
|
|
@@ -71,7 +73,7 @@ module Devise
|
|
|
71
73
|
|
|
72
74
|
# The number of times to hash the password.
|
|
73
75
|
mattr_accessor :stretches
|
|
74
|
-
@@stretches =
|
|
76
|
+
@@stretches = 12
|
|
75
77
|
|
|
76
78
|
# The default key used when authenticating over http auth.
|
|
77
79
|
mattr_accessor :http_authentication_key
|
|
@@ -217,7 +219,16 @@ module Devise
|
|
|
217
219
|
|
|
218
220
|
# Which formats should be treated as navigational.
|
|
219
221
|
mattr_accessor :navigational_formats
|
|
220
|
-
@@navigational_formats = ["*/*", :html]
|
|
222
|
+
@@navigational_formats = ["*/*", :html, :turbo_stream]
|
|
223
|
+
|
|
224
|
+
# The default responder used by Devise, used to customize status codes with:
|
|
225
|
+
#
|
|
226
|
+
# `config.responder.error_status`
|
|
227
|
+
# `config.responder.redirect_status`
|
|
228
|
+
#
|
|
229
|
+
# Can be replaced by a custom application responder.
|
|
230
|
+
mattr_accessor :responder
|
|
231
|
+
@@responder = Devise::Controllers::Responder
|
|
221
232
|
|
|
222
233
|
# When set to true, signing out a user signs out all other scopes.
|
|
223
234
|
mattr_accessor :sign_out_all_scopes
|
|
@@ -293,13 +304,9 @@ module Devise
|
|
|
293
304
|
mattr_accessor :token_generator
|
|
294
305
|
@@token_generator = nil
|
|
295
306
|
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
def self.activerecord51? # :nodoc:
|
|
301
|
-
defined?(ActiveRecord) && ActiveRecord.gem_version >= Gem::Version.new("5.1.x")
|
|
302
|
-
end
|
|
307
|
+
# When set to false, changing a password does not automatically sign in a user
|
|
308
|
+
mattr_accessor :sign_in_after_change_password
|
|
309
|
+
@@sign_in_after_change_password = true
|
|
303
310
|
|
|
304
311
|
# Default way to set up Devise. Run rails generate devise_install to create
|
|
305
312
|
# a fresh initializer with all configuration values.
|
|
@@ -313,12 +320,20 @@ module Devise
|
|
|
313
320
|
end
|
|
314
321
|
|
|
315
322
|
def get
|
|
316
|
-
|
|
323
|
+
# TODO: Remove AS::Dependencies usage when dropping support to Rails < 7.
|
|
324
|
+
if ActiveSupport::Dependencies.respond_to?(:constantize)
|
|
325
|
+
ActiveSupport::Dependencies.constantize(@name)
|
|
326
|
+
else
|
|
327
|
+
@name.constantize
|
|
328
|
+
end
|
|
317
329
|
end
|
|
318
330
|
end
|
|
319
331
|
|
|
320
332
|
def self.ref(arg)
|
|
321
|
-
|
|
333
|
+
# TODO: Remove AS::Dependencies usage when dropping support to Rails < 7.
|
|
334
|
+
if ActiveSupport::Dependencies.respond_to?(:reference)
|
|
335
|
+
ActiveSupport::Dependencies.reference(arg)
|
|
336
|
+
end
|
|
322
337
|
Getter.new(arg)
|
|
323
338
|
end
|
|
324
339
|
|
|
@@ -505,6 +520,14 @@ module Devise
|
|
|
505
520
|
b.each_byte { |byte| res |= byte ^ l.shift }
|
|
506
521
|
res == 0
|
|
507
522
|
end
|
|
523
|
+
|
|
524
|
+
def self.activerecord51? # :nodoc:
|
|
525
|
+
ActiveSupport::Deprecation.warn <<-DEPRECATION.strip_heredoc
|
|
526
|
+
[Devise] `Devise.activerecord51?` is deprecated and will be removed in the next major version.
|
|
527
|
+
It is a non-public method that's no longer used internally, but that other libraries have been relying on.
|
|
528
|
+
DEPRECATION
|
|
529
|
+
defined?(ActiveRecord) && ActiveRecord.gem_version >= Gem::Version.new("5.1.x")
|
|
530
|
+
end
|
|
508
531
|
end
|
|
509
532
|
|
|
510
533
|
require 'warden'
|
|
@@ -54,11 +54,11 @@ module ActiveRecord
|
|
|
54
54
|
t.datetime :remember_created_at
|
|
55
55
|
|
|
56
56
|
## Trackable
|
|
57
|
-
t.integer :sign_in_count, default: 0, null: false
|
|
58
|
-
t.datetime :current_sign_in_at
|
|
59
|
-
t.datetime :last_sign_in_at
|
|
60
|
-
t.#{ip_column} :current_sign_in_ip
|
|
61
|
-
t.#{ip_column} :last_sign_in_ip
|
|
57
|
+
# t.integer :sign_in_count, default: 0, null: false
|
|
58
|
+
# t.datetime :current_sign_in_at
|
|
59
|
+
# t.datetime :last_sign_in_at
|
|
60
|
+
# t.#{ip_column} :current_sign_in_ip
|
|
61
|
+
# t.#{ip_column} :last_sign_in_ip
|
|
62
62
|
|
|
63
63
|
## Confirmable
|
|
64
64
|
# t.string :confirmation_token
|
|
@@ -82,23 +82,38 @@ RUBY
|
|
|
82
82
|
postgresql?
|
|
83
83
|
end
|
|
84
84
|
|
|
85
|
-
def
|
|
86
|
-
Rails
|
|
85
|
+
def rails5_and_up?
|
|
86
|
+
Rails::VERSION::MAJOR >= 5
|
|
87
|
+
end
|
|
88
|
+
|
|
89
|
+
def rails61_and_up?
|
|
90
|
+
Rails::VERSION::MAJOR > 6 || (Rails::VERSION::MAJOR == 6 && Rails::VERSION::MINOR >= 1)
|
|
87
91
|
end
|
|
88
92
|
|
|
89
93
|
def postgresql?
|
|
90
|
-
|
|
91
|
-
|
|
94
|
+
ar_config && ar_config['adapter'] == 'postgresql'
|
|
95
|
+
end
|
|
96
|
+
|
|
97
|
+
def ar_config
|
|
98
|
+
if ActiveRecord::Base.configurations.respond_to?(:configs_for)
|
|
99
|
+
if rails61_and_up?
|
|
100
|
+
ActiveRecord::Base.configurations.configs_for(env_name: Rails.env, name: "primary").configuration_hash
|
|
101
|
+
else
|
|
102
|
+
ActiveRecord::Base.configurations.configs_for(env_name: Rails.env, spec_name: "primary").config
|
|
103
|
+
end
|
|
104
|
+
else
|
|
105
|
+
ActiveRecord::Base.configurations[Rails.env]
|
|
106
|
+
end
|
|
92
107
|
end
|
|
93
108
|
|
|
94
109
|
def migration_version
|
|
95
|
-
if
|
|
110
|
+
if rails5_and_up?
|
|
96
111
|
"[#{Rails::VERSION::MAJOR}.#{Rails::VERSION::MINOR}]"
|
|
97
112
|
end
|
|
98
113
|
end
|
|
99
114
|
|
|
100
115
|
def primary_key_type
|
|
101
|
-
primary_key_string if
|
|
116
|
+
primary_key_string if rails5_and_up?
|
|
102
117
|
end
|
|
103
118
|
|
|
104
119
|
def primary_key_string
|
|
@@ -18,7 +18,7 @@ module Devise
|
|
|
18
18
|
|
|
19
19
|
This will create a controller class at app/controllers/users/sessions_controller.rb like this:
|
|
20
20
|
|
|
21
|
-
class Users::
|
|
21
|
+
class Users::SessionsController < Devise::SessionsController
|
|
22
22
|
content...
|
|
23
23
|
end
|
|
24
24
|
DESC
|
|
@@ -13,7 +13,7 @@ module Devise
|
|
|
13
13
|
desc "Generates a model with the given NAME (if one does not exist) with devise " \
|
|
14
14
|
"configuration plus a migration file and devise routes."
|
|
15
15
|
|
|
16
|
-
hook_for :orm
|
|
16
|
+
hook_for :orm, required: true
|
|
17
17
|
|
|
18
18
|
class_option :routes, desc: "Generate routes", type: :boolean, default: true
|
|
19
19
|
|
|
@@ -11,7 +11,7 @@ module Devise
|
|
|
11
11
|
source_root File.expand_path("../../templates", __FILE__)
|
|
12
12
|
|
|
13
13
|
desc "Creates a Devise initializer and copy locale files to your application."
|
|
14
|
-
class_option :orm
|
|
14
|
+
class_option :orm, required: true
|
|
15
15
|
|
|
16
16
|
def copy_initializer
|
|
17
17
|
unless options[:orm]
|
|
@@ -37,10 +37,6 @@ module Devise
|
|
|
37
37
|
def show_readme
|
|
38
38
|
readme "README" if behavior == :invoke
|
|
39
39
|
end
|
|
40
|
-
|
|
41
|
-
def rails_4?
|
|
42
|
-
Rails::VERSION::MAJOR == 4
|
|
43
|
-
end
|
|
44
40
|
end
|
|
45
41
|
end
|
|
46
42
|
end
|