brainsome_devise 3.3.0
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 +7 -0
- data/.gitignore +10 -0
- data/.travis.yml +35 -0
- data/.yardopts +9 -0
- data/CHANGELOG.md +1086 -0
- data/CONTRIBUTING.md +14 -0
- data/Gemfile +29 -0
- data/Gemfile.lock +166 -0
- data/MIT-LICENSE +20 -0
- data/README.md +506 -0
- data/Rakefile +35 -0
- data/app/controllers/devise/confirmations_controller.rb +47 -0
- data/app/controllers/devise/omniauth_callbacks_controller.rb +30 -0
- data/app/controllers/devise/passwords_controller.rb +70 -0
- data/app/controllers/devise/registrations_controller.rb +148 -0
- data/app/controllers/devise/sessions_controller.rb +76 -0
- data/app/controllers/devise/unlocks_controller.rb +46 -0
- data/app/controllers/devise_controller.rb +176 -0
- data/app/helpers/devise_helper.rb +25 -0
- data/app/mailers/devise/mailer.rb +20 -0
- data/app/views/devise/confirmations/new.html.erb +12 -0
- data/app/views/devise/mailer/confirmation_instructions.html.erb +5 -0
- data/app/views/devise/mailer/reset_password_instructions.html.erb +8 -0
- data/app/views/devise/mailer/unlock_instructions.html.erb +7 -0
- data/app/views/devise/passwords/edit.html.erb +16 -0
- data/app/views/devise/passwords/new.html.erb +12 -0
- data/app/views/devise/registrations/edit.html.erb +29 -0
- data/app/views/devise/registrations/new.html.erb +18 -0
- data/app/views/devise/sessions/new.html.erb +17 -0
- data/app/views/devise/shared/_links.html.erb +25 -0
- data/app/views/devise/unlocks/new.html.erb +12 -0
- data/config/locales/en.yml +60 -0
- data/devise.gemspec +27 -0
- data/devise.png +0 -0
- data/gemfiles/Gemfile.rails-3.2-stable +29 -0
- data/gemfiles/Gemfile.rails-3.2-stable.lock +166 -0
- data/gemfiles/Gemfile.rails-4.0-stable +29 -0
- data/gemfiles/Gemfile.rails-4.0-stable.lock +162 -0
- data/gemfiles/Gemfile.rails-head +32 -0
- data/gemfiles/Gemfile.rails-head.lock +206 -0
- data/lib/devise.rb +495 -0
- data/lib/devise/controllers/helpers.rb +284 -0
- data/lib/devise/controllers/rememberable.rb +47 -0
- data/lib/devise/controllers/scoped_views.rb +17 -0
- data/lib/devise/controllers/sign_in_out.rb +102 -0
- data/lib/devise/controllers/store_location.rb +56 -0
- data/lib/devise/controllers/url_helpers.rb +69 -0
- data/lib/devise/delegator.rb +16 -0
- data/lib/devise/failure_app.rb +205 -0
- data/lib/devise/hooks/activatable.rb +10 -0
- data/lib/devise/hooks/csrf_cleaner.rb +7 -0
- data/lib/devise/hooks/forgetable.rb +9 -0
- data/lib/devise/hooks/lockable.rb +7 -0
- data/lib/devise/hooks/proxy.rb +21 -0
- data/lib/devise/hooks/rememberable.rb +7 -0
- data/lib/devise/hooks/timeoutable.rb +35 -0
- data/lib/devise/hooks/trackable.rb +9 -0
- data/lib/devise/mailers/helpers.rb +90 -0
- data/lib/devise/mapping.rb +175 -0
- data/lib/devise/models.rb +119 -0
- data/lib/devise/models/authenticatable.rb +284 -0
- data/lib/devise/models/confirmable.rb +295 -0
- data/lib/devise/models/database_authenticatable.rb +164 -0
- data/lib/devise/models/lockable.rb +196 -0
- data/lib/devise/models/omniauthable.rb +27 -0
- data/lib/devise/models/recoverable.rb +147 -0
- data/lib/devise/models/registerable.rb +25 -0
- data/lib/devise/models/rememberable.rb +129 -0
- data/lib/devise/models/timeoutable.rb +49 -0
- data/lib/devise/models/trackable.rb +38 -0
- data/lib/devise/models/validatable.rb +66 -0
- data/lib/devise/modules.rb +28 -0
- data/lib/devise/omniauth.rb +28 -0
- data/lib/devise/omniauth/config.rb +45 -0
- data/lib/devise/omniauth/url_helpers.rb +18 -0
- data/lib/devise/orm/active_record.rb +3 -0
- data/lib/devise/orm/mongoid.rb +3 -0
- data/lib/devise/parameter_filter.rb +40 -0
- data/lib/devise/parameter_sanitizer.rb +99 -0
- data/lib/devise/rails.rb +56 -0
- data/lib/devise/rails/routes.rb +498 -0
- data/lib/devise/rails/warden_compat.rb +22 -0
- data/lib/devise/strategies/authenticatable.rb +174 -0
- data/lib/devise/strategies/base.rb +20 -0
- data/lib/devise/strategies/database_authenticatable.rb +23 -0
- data/lib/devise/strategies/rememberable.rb +55 -0
- data/lib/devise/test_helpers.rb +132 -0
- data/lib/devise/time_inflector.rb +14 -0
- data/lib/devise/token_generator.rb +70 -0
- data/lib/devise/version.rb +3 -0
- data/lib/generators/active_record/devise_generator.rb +91 -0
- data/lib/generators/active_record/templates/migration.rb +18 -0
- data/lib/generators/active_record/templates/migration_existing.rb +25 -0
- data/lib/generators/devise/devise_generator.rb +26 -0
- data/lib/generators/devise/install_generator.rb +29 -0
- data/lib/generators/devise/orm_helpers.rb +51 -0
- data/lib/generators/devise/views_generator.rb +135 -0
- data/lib/generators/mongoid/devise_generator.rb +55 -0
- data/lib/generators/templates/README +35 -0
- data/lib/generators/templates/devise.rb +263 -0
- data/lib/generators/templates/markerb/confirmation_instructions.markerb +5 -0
- data/lib/generators/templates/markerb/reset_password_instructions.markerb +8 -0
- data/lib/generators/templates/markerb/unlock_instructions.markerb +7 -0
- data/lib/generators/templates/simple_form_for/confirmations/new.html.erb +16 -0
- data/lib/generators/templates/simple_form_for/passwords/edit.html.erb +19 -0
- data/lib/generators/templates/simple_form_for/passwords/new.html.erb +15 -0
- data/lib/generators/templates/simple_form_for/registrations/edit.html.erb +27 -0
- data/lib/generators/templates/simple_form_for/registrations/new.html.erb +17 -0
- data/lib/generators/templates/simple_form_for/sessions/new.html.erb +15 -0
- data/lib/generators/templates/simple_form_for/unlocks/new.html.erb +16 -0
- data/script/cached-bundle +49 -0
- data/script/s3-put +71 -0
- data/test/controllers/custom_registrations_controller_test.rb +35 -0
- data/test/controllers/custom_strategy_test.rb +62 -0
- data/test/controllers/helpers_test.rb +311 -0
- data/test/controllers/internal_helpers_test.rb +123 -0
- data/test/controllers/passwords_controller_test.rb +31 -0
- data/test/controllers/sessions_controller_test.rb +103 -0
- data/test/controllers/url_helpers_test.rb +59 -0
- data/test/delegator_test.rb +19 -0
- data/test/devise_test.rb +107 -0
- data/test/failure_app_test.rb +268 -0
- data/test/generators/active_record_generator_test.rb +109 -0
- data/test/generators/devise_generator_test.rb +39 -0
- data/test/generators/install_generator_test.rb +13 -0
- data/test/generators/mongoid_generator_test.rb +23 -0
- data/test/generators/views_generator_test.rb +96 -0
- data/test/helpers/devise_helper_test.rb +52 -0
- data/test/integration/authenticatable_test.rb +729 -0
- data/test/integration/confirmable_test.rb +324 -0
- data/test/integration/database_authenticatable_test.rb +84 -0
- data/test/integration/http_authenticatable_test.rb +105 -0
- data/test/integration/lockable_test.rb +239 -0
- data/test/integration/omniauthable_test.rb +133 -0
- data/test/integration/recoverable_test.rb +334 -0
- data/test/integration/registerable_test.rb +359 -0
- data/test/integration/rememberable_test.rb +167 -0
- data/test/integration/timeoutable_test.rb +189 -0
- data/test/integration/trackable_test.rb +92 -0
- data/test/mailers/confirmation_instructions_test.rb +115 -0
- data/test/mailers/reset_password_instructions_test.rb +96 -0
- data/test/mailers/unlock_instructions_test.rb +91 -0
- data/test/mapping_test.rb +127 -0
- data/test/models/authenticatable_test.rb +13 -0
- data/test/models/confirmable_test.rb +454 -0
- data/test/models/database_authenticatable_test.rb +249 -0
- data/test/models/lockable_test.rb +322 -0
- data/test/models/omniauthable_test.rb +7 -0
- data/test/models/recoverable_test.rb +196 -0
- data/test/models/registerable_test.rb +7 -0
- data/test/models/rememberable_test.rb +198 -0
- data/test/models/serializable_test.rb +49 -0
- data/test/models/timeoutable_test.rb +51 -0
- data/test/models/trackable_test.rb +41 -0
- data/test/models/validatable_test.rb +127 -0
- data/test/models_test.rb +144 -0
- data/test/omniauth/config_test.rb +57 -0
- data/test/omniauth/url_helpers_test.rb +54 -0
- data/test/orm/active_record.rb +10 -0
- data/test/orm/mongoid.rb +13 -0
- data/test/parameter_sanitizer_test.rb +81 -0
- data/test/rails_app/Rakefile +6 -0
- data/test/rails_app/app/active_record/admin.rb +6 -0
- data/test/rails_app/app/active_record/shim.rb +2 -0
- data/test/rails_app/app/active_record/user.rb +6 -0
- data/test/rails_app/app/active_record/user_on_engine.rb +7 -0
- data/test/rails_app/app/active_record/user_on_main_app.rb +7 -0
- data/test/rails_app/app/controllers/admins/sessions_controller.rb +6 -0
- data/test/rails_app/app/controllers/admins_controller.rb +11 -0
- data/test/rails_app/app/controllers/application_controller.rb +12 -0
- data/test/rails_app/app/controllers/application_with_fake_engine.rb +30 -0
- data/test/rails_app/app/controllers/custom/registrations_controller.rb +21 -0
- data/test/rails_app/app/controllers/home_controller.rb +25 -0
- data/test/rails_app/app/controllers/publisher/registrations_controller.rb +2 -0
- data/test/rails_app/app/controllers/publisher/sessions_controller.rb +2 -0
- data/test/rails_app/app/controllers/users/omniauth_callbacks_controller.rb +14 -0
- data/test/rails_app/app/controllers/users_controller.rb +31 -0
- data/test/rails_app/app/helpers/application_helper.rb +3 -0
- data/test/rails_app/app/mailers/users/mailer.rb +12 -0
- data/test/rails_app/app/mongoid/admin.rb +29 -0
- data/test/rails_app/app/mongoid/shim.rb +23 -0
- data/test/rails_app/app/mongoid/user.rb +39 -0
- data/test/rails_app/app/mongoid/user_on_engine.rb +39 -0
- data/test/rails_app/app/mongoid/user_on_main_app.rb +39 -0
- data/test/rails_app/app/views/admins/index.html.erb +1 -0
- data/test/rails_app/app/views/admins/sessions/new.html.erb +2 -0
- data/test/rails_app/app/views/home/admin_dashboard.html.erb +1 -0
- data/test/rails_app/app/views/home/index.html.erb +1 -0
- data/test/rails_app/app/views/home/join.html.erb +1 -0
- data/test/rails_app/app/views/home/private.html.erb +1 -0
- data/test/rails_app/app/views/home/user_dashboard.html.erb +1 -0
- data/test/rails_app/app/views/layouts/application.html.erb +24 -0
- data/test/rails_app/app/views/users/edit_form.html.erb +1 -0
- data/test/rails_app/app/views/users/index.html.erb +1 -0
- data/test/rails_app/app/views/users/mailer/confirmation_instructions.erb +1 -0
- data/test/rails_app/app/views/users/sessions/new.html.erb +1 -0
- data/test/rails_app/bin/bundle +3 -0
- data/test/rails_app/bin/rails +4 -0
- data/test/rails_app/bin/rake +4 -0
- data/test/rails_app/config.ru +4 -0
- data/test/rails_app/config/application.rb +40 -0
- data/test/rails_app/config/boot.rb +14 -0
- data/test/rails_app/config/database.yml +18 -0
- data/test/rails_app/config/environment.rb +5 -0
- data/test/rails_app/config/environments/development.rb +30 -0
- data/test/rails_app/config/environments/production.rb +80 -0
- data/test/rails_app/config/environments/test.rb +36 -0
- data/test/rails_app/config/initializers/backtrace_silencers.rb +7 -0
- data/test/rails_app/config/initializers/devise.rb +183 -0
- data/test/rails_app/config/initializers/inflections.rb +2 -0
- data/test/rails_app/config/initializers/secret_token.rb +8 -0
- data/test/rails_app/config/initializers/session_store.rb +1 -0
- data/test/rails_app/config/routes.rb +122 -0
- data/test/rails_app/db/migrate/20100401102949_create_tables.rb +71 -0
- data/test/rails_app/db/schema.rb +55 -0
- data/test/rails_app/lib/shared_admin.rb +17 -0
- data/test/rails_app/lib/shared_user.rb +29 -0
- data/test/rails_app/lib/shared_user_without_omniauth.rb +13 -0
- data/test/rails_app/public/404.html +26 -0
- data/test/rails_app/public/422.html +26 -0
- data/test/rails_app/public/500.html +26 -0
- data/test/rails_app/public/favicon.ico +0 -0
- data/test/routes_test.rb +264 -0
- data/test/support/action_controller/record_identifier.rb +10 -0
- data/test/support/assertions.rb +39 -0
- data/test/support/helpers.rb +70 -0
- data/test/support/integration.rb +92 -0
- data/test/support/locale/en.yml +8 -0
- data/test/support/mongoid.yml +6 -0
- data/test/support/webrat/integrations/rails.rb +24 -0
- data/test/test_helper.rb +29 -0
- data/test/test_helpers_test.rb +163 -0
- data/test/test_models.rb +33 -0
- metadata +474 -0
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
# All Devise controllers are inherited from here.
|
|
2
|
+
class DeviseController < Devise.parent_controller.constantize
|
|
3
|
+
include Devise::Controllers::ScopedViews
|
|
4
|
+
|
|
5
|
+
helper DeviseHelper
|
|
6
|
+
|
|
7
|
+
helpers = %w(resource scope_name resource_name signed_in_resource
|
|
8
|
+
resource_class resource_params devise_mapping)
|
|
9
|
+
hide_action(*helpers)
|
|
10
|
+
helper_method(*helpers)
|
|
11
|
+
|
|
12
|
+
prepend_before_filter :assert_is_devise_resource!
|
|
13
|
+
respond_to :html if mimes_for_respond_to.empty?
|
|
14
|
+
|
|
15
|
+
# Gets the actual resource stored in the instance variable
|
|
16
|
+
def resource
|
|
17
|
+
instance_variable_get(:"@#{resource_name}")
|
|
18
|
+
end
|
|
19
|
+
|
|
20
|
+
# Proxy to devise map name
|
|
21
|
+
def resource_name
|
|
22
|
+
devise_mapping.name
|
|
23
|
+
end
|
|
24
|
+
alias :scope_name :resource_name
|
|
25
|
+
|
|
26
|
+
# Proxy to devise map class
|
|
27
|
+
def resource_class
|
|
28
|
+
devise_mapping.to
|
|
29
|
+
end
|
|
30
|
+
|
|
31
|
+
# Returns a signed in resource from session (if one exists)
|
|
32
|
+
def signed_in_resource
|
|
33
|
+
warden.authenticate(scope: resource_name)
|
|
34
|
+
end
|
|
35
|
+
|
|
36
|
+
# Attempt to find the mapped route for devise based on request path
|
|
37
|
+
def devise_mapping
|
|
38
|
+
@devise_mapping ||= request.env["devise.mapping"]
|
|
39
|
+
end
|
|
40
|
+
|
|
41
|
+
# Override prefixes to consider the scoped view.
|
|
42
|
+
# Notice we need to check for the request due to a bug in
|
|
43
|
+
# Action Controller tests that forces _prefixes to be
|
|
44
|
+
# loaded before even having a request object.
|
|
45
|
+
def _prefixes #:nodoc:
|
|
46
|
+
@_prefixes ||= if self.class.scoped_views? && request && devise_mapping
|
|
47
|
+
["#{devise_mapping.scoped_path}/#{controller_name}"] + super
|
|
48
|
+
else
|
|
49
|
+
super
|
|
50
|
+
end
|
|
51
|
+
end
|
|
52
|
+
|
|
53
|
+
hide_action :_prefixes
|
|
54
|
+
|
|
55
|
+
protected
|
|
56
|
+
|
|
57
|
+
# Checks whether it's a devise mapped resource or not.
|
|
58
|
+
def assert_is_devise_resource! #:nodoc:
|
|
59
|
+
unknown_action! <<-MESSAGE unless devise_mapping
|
|
60
|
+
Could not find devise mapping for path #{request.fullpath.inspect}.
|
|
61
|
+
This may happen for two reasons:
|
|
62
|
+
|
|
63
|
+
1) You forgot to wrap your route inside the scope block. For example:
|
|
64
|
+
|
|
65
|
+
devise_scope :user do
|
|
66
|
+
get "/some/route" => "some_devise_controller"
|
|
67
|
+
end
|
|
68
|
+
|
|
69
|
+
2) You are testing a Devise controller bypassing the router.
|
|
70
|
+
If so, you can explicitly tell Devise which mapping to use:
|
|
71
|
+
|
|
72
|
+
@request.env["devise.mapping"] = Devise.mappings[:user]
|
|
73
|
+
|
|
74
|
+
MESSAGE
|
|
75
|
+
end
|
|
76
|
+
|
|
77
|
+
# Returns real navigational formats which are supported by Rails
|
|
78
|
+
def navigational_formats
|
|
79
|
+
@navigational_formats ||= Devise.navigational_formats.select { |format| Mime::EXTENSION_LOOKUP[format.to_s] }
|
|
80
|
+
end
|
|
81
|
+
|
|
82
|
+
def unknown_action!(msg)
|
|
83
|
+
logger.debug "[Devise] #{msg}" if logger
|
|
84
|
+
raise AbstractController::ActionNotFound, msg
|
|
85
|
+
end
|
|
86
|
+
|
|
87
|
+
# Sets the resource creating an instance variable
|
|
88
|
+
def resource=(new_resource)
|
|
89
|
+
instance_variable_set(:"@#{resource_name}", new_resource)
|
|
90
|
+
end
|
|
91
|
+
|
|
92
|
+
# Helper for use in before_filters where no authentication is required.
|
|
93
|
+
#
|
|
94
|
+
# Example:
|
|
95
|
+
# before_filter :require_no_authentication, only: :new
|
|
96
|
+
def require_no_authentication
|
|
97
|
+
assert_is_devise_resource!
|
|
98
|
+
return unless is_navigational_format?
|
|
99
|
+
no_input = devise_mapping.no_input_strategies
|
|
100
|
+
|
|
101
|
+
authenticated = if no_input.present?
|
|
102
|
+
args = no_input.dup.push scope: resource_name
|
|
103
|
+
warden.authenticate?(*args)
|
|
104
|
+
else
|
|
105
|
+
warden.authenticated?(resource_name)
|
|
106
|
+
end
|
|
107
|
+
|
|
108
|
+
if authenticated && resource = warden.user(resource_name)
|
|
109
|
+
flash[:alert] = I18n.t("devise.failure.already_authenticated")
|
|
110
|
+
redirect_to after_sign_in_path_for(resource)
|
|
111
|
+
end
|
|
112
|
+
end
|
|
113
|
+
|
|
114
|
+
# Helper for use after calling send_*_instructions methods on a resource.
|
|
115
|
+
# If we are in paranoid mode, we always act as if the resource was valid
|
|
116
|
+
# and instructions were sent.
|
|
117
|
+
def successfully_sent?(resource)
|
|
118
|
+
notice = if Devise.paranoid
|
|
119
|
+
resource.errors.clear
|
|
120
|
+
:send_paranoid_instructions
|
|
121
|
+
elsif resource.errors.empty?
|
|
122
|
+
:send_instructions
|
|
123
|
+
end
|
|
124
|
+
|
|
125
|
+
if notice
|
|
126
|
+
set_flash_message :notice, notice if is_flashing_format?
|
|
127
|
+
true
|
|
128
|
+
end
|
|
129
|
+
end
|
|
130
|
+
|
|
131
|
+
# Sets the flash message with :key, using I18n. By default you are able
|
|
132
|
+
# to setup your messages using specific resource scope, and if no one is
|
|
133
|
+
# found we look to default scope.
|
|
134
|
+
# Example (i18n locale file):
|
|
135
|
+
#
|
|
136
|
+
# en:
|
|
137
|
+
# devise:
|
|
138
|
+
# passwords:
|
|
139
|
+
# #default_scope_messages - only if resource_scope is not found
|
|
140
|
+
# user:
|
|
141
|
+
# #resource_scope_messages
|
|
142
|
+
#
|
|
143
|
+
# Please refer to README or en.yml locale file to check what messages are
|
|
144
|
+
# available.
|
|
145
|
+
def set_flash_message(key, kind, options = {})
|
|
146
|
+
message = find_message(kind, options)
|
|
147
|
+
flash[key] = message if message.present?
|
|
148
|
+
end
|
|
149
|
+
|
|
150
|
+
def devise_i18n_options(options)
|
|
151
|
+
options
|
|
152
|
+
end
|
|
153
|
+
|
|
154
|
+
# Get message for given
|
|
155
|
+
def find_message(kind, options = {})
|
|
156
|
+
options[:scope] = "devise.#{controller_name}"
|
|
157
|
+
options[:default] = Array(options[:default]).unshift(kind.to_sym)
|
|
158
|
+
options[:resource_name] = resource_name
|
|
159
|
+
options = devise_i18n_options(options)
|
|
160
|
+
I18n.t("#{options[:resource_name]}.#{kind}", options)
|
|
161
|
+
end
|
|
162
|
+
|
|
163
|
+
def clean_up_passwords(object)
|
|
164
|
+
object.clean_up_passwords if object.respond_to?(:clean_up_passwords)
|
|
165
|
+
end
|
|
166
|
+
|
|
167
|
+
def respond_with_navigational(*args, &block)
|
|
168
|
+
respond_with(*args) do |format|
|
|
169
|
+
format.any(*navigational_formats, &block)
|
|
170
|
+
end
|
|
171
|
+
end
|
|
172
|
+
|
|
173
|
+
def resource_params
|
|
174
|
+
params.fetch(resource_name, {})
|
|
175
|
+
end
|
|
176
|
+
end
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
module DeviseHelper
|
|
2
|
+
# A simple way to show error messages for the current devise resource. If you need
|
|
3
|
+
# to customize this method, you can either overwrite it in your application helpers or
|
|
4
|
+
# copy the views to your application.
|
|
5
|
+
#
|
|
6
|
+
# This method is intended to stay simple and it is unlikely that we are going to change
|
|
7
|
+
# it to add more behavior or options.
|
|
8
|
+
def devise_error_messages!
|
|
9
|
+
return "" if resource.errors.empty?
|
|
10
|
+
|
|
11
|
+
messages = resource.errors.full_messages.map { |msg| content_tag(:li, msg) }.join
|
|
12
|
+
sentence = I18n.t("errors.messages.not_saved",
|
|
13
|
+
count: resource.errors.count,
|
|
14
|
+
resource: resource.class.model_name.human.downcase)
|
|
15
|
+
|
|
16
|
+
html = <<-HTML
|
|
17
|
+
<div id="error_explanation">
|
|
18
|
+
<h2>#{sentence}</h2>
|
|
19
|
+
<ul>#{messages}</ul>
|
|
20
|
+
</div>
|
|
21
|
+
HTML
|
|
22
|
+
|
|
23
|
+
html.html_safe
|
|
24
|
+
end
|
|
25
|
+
end
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
if defined?(ActionMailer)
|
|
2
|
+
class Devise::Mailer < Devise.parent_mailer.constantize
|
|
3
|
+
include Devise::Mailers::Helpers
|
|
4
|
+
|
|
5
|
+
def confirmation_instructions(record, token, opts={})
|
|
6
|
+
@token = token
|
|
7
|
+
devise_mail(record, :confirmation_instructions, opts)
|
|
8
|
+
end
|
|
9
|
+
|
|
10
|
+
def reset_password_instructions(record, token, opts={})
|
|
11
|
+
@token = token
|
|
12
|
+
devise_mail(record, :reset_password_instructions, opts)
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
def unlock_instructions(record, token, opts={})
|
|
16
|
+
@token = token
|
|
17
|
+
devise_mail(record, :unlock_instructions, opts)
|
|
18
|
+
end
|
|
19
|
+
end
|
|
20
|
+
end
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
<h2>Resend confirmation instructions</h2>
|
|
2
|
+
|
|
3
|
+
<%= form_for(resource, as: resource_name, url: confirmation_path(resource_name), html: { method: :post }) do |f| %>
|
|
4
|
+
<%= devise_error_messages! %>
|
|
5
|
+
|
|
6
|
+
<div><%= f.label :email %><br />
|
|
7
|
+
<%= f.email_field :email, autofocus: true %></div>
|
|
8
|
+
|
|
9
|
+
<div><%= f.submit "Resend confirmation instructions" %></div>
|
|
10
|
+
<% end %>
|
|
11
|
+
|
|
12
|
+
<%= render "devise/shared/links" %>
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
<p>Hello <%= @resource.email %>!</p>
|
|
2
|
+
|
|
3
|
+
<p>Someone has requested a link to change your password. You can do this through the link below.</p>
|
|
4
|
+
|
|
5
|
+
<p><%= link_to 'Change my password', edit_password_url(@resource, reset_password_token: @token) %></p>
|
|
6
|
+
|
|
7
|
+
<p>If you didn't request this, please ignore this email.</p>
|
|
8
|
+
<p>Your password won't change until you access the link above and create a new one.</p>
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
<p>Hello <%= @resource.email %>!</p>
|
|
2
|
+
|
|
3
|
+
<p>Your account has been locked due to an excessive number of unsuccessful sign in attempts.</p>
|
|
4
|
+
|
|
5
|
+
<p>Click the link below to unlock your account:</p>
|
|
6
|
+
|
|
7
|
+
<p><%= link_to 'Unlock my account', unlock_url(@resource, unlock_token: @token) %></p>
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
<h2>Change your password</h2>
|
|
2
|
+
|
|
3
|
+
<%= form_for(resource, as: resource_name, url: password_path(resource_name), html: { method: :put }) do |f| %>
|
|
4
|
+
<%= devise_error_messages! %>
|
|
5
|
+
<%= f.hidden_field :reset_password_token %>
|
|
6
|
+
|
|
7
|
+
<div><%= f.label :password, "New password" %><br />
|
|
8
|
+
<%= f.password_field :password, autofocus: true, autocomplete: "off" %></div>
|
|
9
|
+
|
|
10
|
+
<div><%= f.label :password_confirmation, "Confirm new password" %><br />
|
|
11
|
+
<%= f.password_field :password_confirmation, autocomplete: "off" %></div>
|
|
12
|
+
|
|
13
|
+
<div><%= f.submit "Change my password" %></div>
|
|
14
|
+
<% end %>
|
|
15
|
+
|
|
16
|
+
<%= render "devise/shared/links" %>
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
<h2>Forgot your password?</h2>
|
|
2
|
+
|
|
3
|
+
<%= form_for(resource, as: resource_name, url: password_path(resource_name), html: { method: :post }) do |f| %>
|
|
4
|
+
<%= devise_error_messages! %>
|
|
5
|
+
|
|
6
|
+
<div><%= f.label :email %><br />
|
|
7
|
+
<%= f.email_field :email, autofocus: true %></div>
|
|
8
|
+
|
|
9
|
+
<div><%= f.submit "Send me reset password instructions" %></div>
|
|
10
|
+
<% end %>
|
|
11
|
+
|
|
12
|
+
<%= render "devise/shared/links" %>
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
<h2>Edit <%= resource_name.to_s.humanize %></h2>
|
|
2
|
+
|
|
3
|
+
<%= form_for(resource, as: resource_name, url: registration_path(resource_name), html: { method: :put }) do |f| %>
|
|
4
|
+
<%= devise_error_messages! %>
|
|
5
|
+
|
|
6
|
+
<div><%= f.label :email %><br />
|
|
7
|
+
<%= f.email_field :email, autofocus: true %></div>
|
|
8
|
+
|
|
9
|
+
<% if devise_mapping.confirmable? && resource.pending_reconfirmation? %>
|
|
10
|
+
<div>Currently waiting confirmation for: <%= resource.unconfirmed_email %></div>
|
|
11
|
+
<% end %>
|
|
12
|
+
|
|
13
|
+
<div><%= f.label :password %> <i>(leave blank if you don't want to change it)</i><br />
|
|
14
|
+
<%= f.password_field :password, autocomplete: "off" %></div>
|
|
15
|
+
|
|
16
|
+
<div><%= f.label :password_confirmation %><br />
|
|
17
|
+
<%= f.password_field :password_confirmation, autocomplete: "off" %></div>
|
|
18
|
+
|
|
19
|
+
<div><%= f.label :current_password %> <i>(we need your current password to confirm your changes)</i><br />
|
|
20
|
+
<%= f.password_field :current_password, autocomplete: "off" %></div>
|
|
21
|
+
|
|
22
|
+
<div><%= f.submit "Update" %></div>
|
|
23
|
+
<% end %>
|
|
24
|
+
|
|
25
|
+
<h3>Cancel my account</h3>
|
|
26
|
+
|
|
27
|
+
<p>Unhappy? <%= button_to "Cancel my account", registration_path(resource_name), data: { confirm: "Are you sure?" }, method: :delete %></p>
|
|
28
|
+
|
|
29
|
+
<%= link_to "Back", :back %>
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
<h2>Sign up</h2>
|
|
2
|
+
|
|
3
|
+
<%= form_for(resource, as: resource_name, url: registration_path(resource_name)) do |f| %>
|
|
4
|
+
<%= devise_error_messages! %>
|
|
5
|
+
|
|
6
|
+
<div><%= f.label :email %><br />
|
|
7
|
+
<%= f.email_field :email, autofocus: true %></div>
|
|
8
|
+
|
|
9
|
+
<div><%= f.label :password %> <% if @validatable %><i>(<%= @minimum_password_length %> characters minimum)</i><% end %><br />
|
|
10
|
+
<%= f.password_field :password, autocomplete: "off" %></div>
|
|
11
|
+
|
|
12
|
+
<div><%= f.label :password_confirmation %><br />
|
|
13
|
+
<%= f.password_field :password_confirmation, autocomplete: "off" %></div>
|
|
14
|
+
|
|
15
|
+
<div><%= f.submit "Sign up" %></div>
|
|
16
|
+
<% end %>
|
|
17
|
+
|
|
18
|
+
<%= render "devise/shared/links" %>
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
<h2>Log in</h2>
|
|
2
|
+
|
|
3
|
+
<%= form_for(resource, as: resource_name, url: session_path(resource_name)) do |f| %>
|
|
4
|
+
<div><%= f.label :email %><br />
|
|
5
|
+
<%= f.email_field :email, autofocus: true %></div>
|
|
6
|
+
|
|
7
|
+
<div><%= f.label :password %><br />
|
|
8
|
+
<%= f.password_field :password, autocomplete: "off" %></div>
|
|
9
|
+
|
|
10
|
+
<% if devise_mapping.rememberable? -%>
|
|
11
|
+
<div><%= f.check_box :remember_me %> <%= f.label :remember_me %></div>
|
|
12
|
+
<% end -%>
|
|
13
|
+
|
|
14
|
+
<div><%= f.submit "Log in" %></div>
|
|
15
|
+
<% end %>
|
|
16
|
+
|
|
17
|
+
<%= render "devise/shared/links" %>
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
<%- if controller_name != 'sessions' %>
|
|
2
|
+
<%= link_to "Log in", new_session_path(resource_name) %><br />
|
|
3
|
+
<% end -%>
|
|
4
|
+
|
|
5
|
+
<%- if devise_mapping.registerable? && controller_name != 'registrations' %>
|
|
6
|
+
<%= link_to "Sign up", new_registration_path(resource_name) %><br />
|
|
7
|
+
<% end -%>
|
|
8
|
+
|
|
9
|
+
<%- if devise_mapping.recoverable? && controller_name != 'passwords' && controller_name != 'registrations' %>
|
|
10
|
+
<%= link_to "Forgot your password?", new_password_path(resource_name) %><br />
|
|
11
|
+
<% end -%>
|
|
12
|
+
|
|
13
|
+
<%- if devise_mapping.confirmable? && controller_name != 'confirmations' %>
|
|
14
|
+
<%= link_to "Didn't receive confirmation instructions?", new_confirmation_path(resource_name) %><br />
|
|
15
|
+
<% end -%>
|
|
16
|
+
|
|
17
|
+
<%- if devise_mapping.lockable? && resource_class.unlock_strategy_enabled?(:email) && controller_name != 'unlocks' %>
|
|
18
|
+
<%= link_to "Didn't receive unlock instructions?", new_unlock_path(resource_name) %><br />
|
|
19
|
+
<% end -%>
|
|
20
|
+
|
|
21
|
+
<%- if devise_mapping.omniauthable? %>
|
|
22
|
+
<%- resource_class.omniauth_providers.each do |provider| %>
|
|
23
|
+
<%= link_to "Sign in with #{provider.to_s.titleize}", omniauth_authorize_path(resource_name, provider) %><br />
|
|
24
|
+
<% end -%>
|
|
25
|
+
<% end -%>
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
<h2>Resend unlock instructions</h2>
|
|
2
|
+
|
|
3
|
+
<%= form_for(resource, as: resource_name, url: unlock_path(resource_name), html: { method: :post }) do |f| %>
|
|
4
|
+
<%= devise_error_messages! %>
|
|
5
|
+
|
|
6
|
+
<div><%= f.label :email %><br />
|
|
7
|
+
<%= f.email_field :email, autofocus: true %></div>
|
|
8
|
+
|
|
9
|
+
<div><%= f.submit "Resend unlock instructions" %></div>
|
|
10
|
+
<% end %>
|
|
11
|
+
|
|
12
|
+
<%= render "devise/shared/links" %>
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
# Additional translations at https://github.com/plataformatec/devise/wiki/I18n
|
|
2
|
+
|
|
3
|
+
en:
|
|
4
|
+
devise:
|
|
5
|
+
confirmations:
|
|
6
|
+
confirmed: "Your email address has been successfully confirmed."
|
|
7
|
+
send_instructions: "You will receive an email with instructions for how to confirm your email address in a few minutes."
|
|
8
|
+
send_paranoid_instructions: "If your email address exists in our database, you will receive an email with instructions for how to confirm your email address in a few minutes."
|
|
9
|
+
failure:
|
|
10
|
+
already_authenticated: "You are already signed in."
|
|
11
|
+
inactive: "Your account is not activated yet."
|
|
12
|
+
invalid: "Invalid email or password."
|
|
13
|
+
locked: "Your account is locked."
|
|
14
|
+
last_attempt: "You have one more attempt before your account is locked."
|
|
15
|
+
not_found_in_database: "Invalid email address or password."
|
|
16
|
+
timeout: "Your session expired. Please sign in again to continue."
|
|
17
|
+
unauthenticated: "You need to sign in or sign up before continuing."
|
|
18
|
+
unconfirmed: "You have to confirm your email address before continuing."
|
|
19
|
+
mailer:
|
|
20
|
+
confirmation_instructions:
|
|
21
|
+
subject: "Confirmation instructions"
|
|
22
|
+
reset_password_instructions:
|
|
23
|
+
subject: "Reset password instructions"
|
|
24
|
+
unlock_instructions:
|
|
25
|
+
subject: "Unlock instructions"
|
|
26
|
+
omniauth_callbacks:
|
|
27
|
+
failure: "Could not authenticate you from %{kind} because \"%{reason}\"."
|
|
28
|
+
success: "Successfully authenticated from %{kind} account."
|
|
29
|
+
passwords:
|
|
30
|
+
no_token: "You can't access this page without coming from a password reset email. If you do come from a password reset email, please make sure you used the full URL provided."
|
|
31
|
+
send_instructions: "You will receive an email with instructions on how to reset your password in a few minutes."
|
|
32
|
+
send_paranoid_instructions: "If your email address exists in our database, you will receive a password recovery link at your email address in a few minutes."
|
|
33
|
+
updated: "Your password has been changed successfully. You are now signed in."
|
|
34
|
+
updated_not_active: "Your password has been changed successfully."
|
|
35
|
+
registrations:
|
|
36
|
+
destroyed: "Bye! Your account has been successfully cancelled. We hope to see you again soon."
|
|
37
|
+
signed_up: "Welcome! You have signed up successfully."
|
|
38
|
+
signed_up_but_inactive: "You have signed up successfully. However, we could not sign you in because your account is not yet activated."
|
|
39
|
+
signed_up_but_locked: "You have signed up successfully. However, we could not sign you in because your account is locked."
|
|
40
|
+
signed_up_but_unconfirmed: "A message with a confirmation link has been sent to your email address. Please follow the link to activate your account."
|
|
41
|
+
update_needs_confirmation: "You updated your account successfully, but we need to verify your new email address. Please check your email and follow the confirm link to confirm your new email address."
|
|
42
|
+
updated: "Your account has been updated successfully."
|
|
43
|
+
sessions:
|
|
44
|
+
signed_in: "Signed in successfully."
|
|
45
|
+
signed_out: "Signed out successfully."
|
|
46
|
+
already_signed_out: "Signed out successfully."
|
|
47
|
+
unlocks:
|
|
48
|
+
send_instructions: "You will receive an email with instructions for how to unlock your account in a few minutes."
|
|
49
|
+
send_paranoid_instructions: "If your account exists, you will receive an email with instructions for how to unlock it in a few minutes."
|
|
50
|
+
unlocked: "Your account has been unlocked successfully. Please sign in to continue."
|
|
51
|
+
errors:
|
|
52
|
+
messages:
|
|
53
|
+
already_confirmed: "was already confirmed, please try signing in"
|
|
54
|
+
confirmation_period_expired: "needs to be confirmed within %{period}, please request a new one"
|
|
55
|
+
expired: "has expired, please request a new one"
|
|
56
|
+
not_found: "not found"
|
|
57
|
+
not_locked: "was not locked"
|
|
58
|
+
not_saved:
|
|
59
|
+
one: "1 error prohibited this %{resource} from being saved:"
|
|
60
|
+
other: "%{count} errors prohibited this %{resource} from being saved:"
|