Module: Devise
- Defined in:
- lib/devise.rb,
lib/devise/rails.rb,
lib/devise/models.rb,
lib/devise/schema.rb,
lib/devise/mapping.rb,
lib/devise/version.rb,
lib/devise/omniauth.rb,
lib/devise/delegator.rb,
lib/devise/failure_app.rb,
lib/devise/orm/mongoid.rb,
lib/devise/param_filter.rb,
lib/devise/test_helpers.rb,
lib/devise/encryptors/base.rb,
lib/devise/encryptors/sha1.rb,
lib/devise/mailers/helpers.rb,
lib/devise/models/lockable.rb,
lib/devise/omniauth/config.rb,
lib/devise/strategies/base.rb,
lib/devise/models/trackable.rb,
lib/devise/encryptors/sha512.rb,
lib/devise/orm/active_record.rb,
lib/devise/models/confirmable.rb,
lib/devise/models/encryptable.rb,
lib/devise/models/recoverable.rb,
lib/devise/models/timeoutable.rb,
lib/devise/models/validatable.rb,
lib/devise/controllers/helpers.rb,
lib/devise/models/omniauthable.rb,
lib/devise/models/registerable.rb,
lib/devise/models/rememberable.rb,
lib/devise/omniauth/url_helpers.rb,
lib/devise/models/authenticatable.rb,
lib/generators/devise/orm_helpers.rb,
lib/devise/controllers/url_helpers.rb,
lib/devise/strategies/rememberable.rb,
lib/devise/controllers/rememberable.rb,
lib/devise/controllers/scoped_views.rb,
lib/devise/encryptors/clearance_sha1.rb,
lib/devise/strategies/authenticatable.rb,
lib/generators/devise/views_generator.rb,
lib/devise/encryptors/authlogic_sha512.rb,
lib/generators/devise/devise_generator.rb,
lib/devise/models/token_authenticatable.rb,
lib/generators/devise/install_generator.rb,
lib/devise/models/database_authenticatable.rb,
lib/devise/strategies/token_authenticatable.rb,
lib/devise/strategies/database_authenticatable.rb,
lib/devise/encryptors/restful_authentication_sha1.rb
Defined Under Namespace
Modules: Controllers, Encryptors, Generators, Mailers, Models, OmniAuth, Orm, Schema, Strategies, TestHelpers Classes: ConfirmationsController, Delegator, Engine, FailureApp, Getter, Mailer, Mapping, OmniauthCallbacksController, ParamFilter, PasswordsController, RegistrationsController, SessionsController, UnlocksController
Constant Summary collapse
- ALL =
Constants which holds devise configuration for extensions. Those should not be modified by the “end user” (this is why they are constants).
[]
- CONTROLLERS =
ActiveSupport::OrderedHash.new
- ROUTES =
ActiveSupport::OrderedHash.new
- STRATEGIES =
ActiveSupport::OrderedHash.new
- URL_HELPERS =
ActiveSupport::OrderedHash.new
- NO_INPUT =
Strategies that do not require user input.
[]
- TRUE_VALUES =
True values used to check params
[true, 1, '1', 't', 'T', 'true', 'TRUE']
- ENCRYPTORS_LENGTH =
Declare encryptors length which are used in migrations.
{ :sha1 => 40, :sha512 => 128, :clearance_sha1 => 40, :restful_authentication_sha1 => 40, :authlogic_sha512 => 128 }
- VERSION =
"2.0.5".freeze
- @@rememberable_options =
{}
- @@stretches =
10- @@authentication_keys =
[ :email ]
- @@request_keys =
[]
- @@case_insensitive_keys =
false- @@strip_whitespace_keys =
false- @@http_authenticatable =
false- @@http_authenticatable_on_xhr =
true- @@params_authenticatable =
true- @@http_authentication_realm =
"Application"- @@email_regexp =
/\A[^@]+@([^@\.]+\.)+[^@\.]+\z/- @@password_length =
6..128
- @@remember_for =
2.weeks
- @@extend_remember_period =
false- @@allow_unconfirmed_access_for =
0.days
- @@confirmation_keys =
[ :email ]
- @@reconfirmable =
false- @@timeout_in =
30.minutes
- @@pepper =
nil- @@encryptor =
nil- @@scoped_views =
false- @@lock_strategy =
:failed_attempts- @@unlock_keys =
[ :email ]
- @@unlock_strategy =
:both- @@maximum_attempts =
20- @@unlock_in =
1.hour
- @@reset_password_keys =
[ :email ]
- @@reset_password_within =
nil- @@default_scope =
nil- @@mailer_sender =
nil- @@token_authentication_key =
:auth_token- @@skip_session_storage =
[]
["*/*", :html]
- @@sign_out_all_scopes =
true- @@sign_out_via =
:get- @@parent_controller =
"ApplicationController"- @@router_name =
nil- @@use_salt_as_remember_token =
false- @@apply_schema =
true- @@mappings =
ActiveSupport::OrderedHash.new
- @@omniauth_configs =
ActiveSupport::OrderedHash.new
- @@helpers =
Set.new
- @@warden_config =
nil- @@warden_config_block =
nil- @@paranoid =
false
Class Method Summary collapse
-
.add_mapping(resource, options) ⇒ Object
Small method that adds a mapping to Devise.
-
.add_module(module_name, options = {}) ⇒ Object
Make Devise aware of an 3rd party Devise-module (like invitable).
- .available_router_name ⇒ Object
-
.configure_warden! ⇒ Object
A method used internally to setup warden manager from the Rails initialize block.
- .confirm_within=(value) ⇒ Object
- .cookie_options=(value) ⇒ Object
-
.friendly_token ⇒ Object
Generate a friendly string randomically to be used as token.
-
.include_helpers(scope) ⇒ Object
Include helpers in the given scope to AC and AV.
-
.mailer ⇒ Object
Get the mailer class from the mailer reference object.
-
.mailer=(class_name) ⇒ Object
Set the mailer reference object to access the mailer.
-
.omniauth(provider, *args) ⇒ Object
Specify an omniauth provider.
- .omniauth_providers ⇒ Object
- .ref(arg) ⇒ Object
-
.regenerate_helpers! ⇒ Object
Regenerates url helpers considering Devise.mapping.
- .remember_across_browsers=(value) ⇒ Object
-
.secure_compare(a, b) ⇒ Object
constant-time comparison algorithm to prevent timing attacks.
-
.setup {|_self| ... } ⇒ Object
Default way to setup Devise.
- .stateless_token=(value) ⇒ Object
-
.warden(&block) ⇒ Object
Sets warden configuration using a block that will be invoked on warden initialization.
Class Method Details
.add_mapping(resource, options) ⇒ Object
Small method that adds a mapping to Devise.
326 327 328 329 330 331 332 |
# File 'lib/devise.rb', line 326 def self.add_mapping(resource, ) mapping = Devise::Mapping.new(resource, ) @@mappings[mapping.name] = mapping @@default_scope ||= mapping.name @@helpers.each { |h| h.define_helpers(mapping) } mapping end |
.add_module(module_name, options = {}) ⇒ Object
Make Devise aware of an 3rd party Devise-module (like invitable). For convenience.
Options:
+model+ - String representing the load path to a custom *model* for this module (to autoload.)
+controller+ - Symbol representing the name of an exisiting or custom *controller* for this module.
+route+ - Symbol representing the named *route* helper for this module.
+strategy+ - Symbol representing if this module got a custom *strategy*.
All values, except :model, accept also a boolean and will have the same name as the given module name.
Examples:
Devise.add_module(:party_module)
Devise.add_module(:party_module, :strategy => true, :controller => :sessions)
Devise.add_module(:party_module, :model => 'party_module/model')
352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 |
# File 'lib/devise.rb', line 352 def self.add_module(module_name, = {}) ALL << module_name .assert_valid_keys(:strategy, :model, :controller, :route, :no_input) if strategy = [:strategy] strategy = (strategy == true ? module_name : strategy) STRATEGIES[module_name] = strategy end if controller = [:controller] controller = (controller == true ? module_name : controller) CONTROLLERS[module_name] = controller end NO_INPUT << strategy if [:no_input] if route = [:route] case route when TrueClass key, value = module_name, [] when Symbol key, value = route, [] when Hash key, value = route.keys.first, route.values.flatten else raise ArgumentError, ":route should be true, a Symbol or a Hash" end URL_HELPERS[key] ||= [] URL_HELPERS[key].concat(value) URL_HELPERS[key].uniq! ROUTES[module_name] = key end if [:model] path = ([:model] == true ? "devise/models/#{module_name}" : [:model]) camelized = ActiveSupport::Inflector.camelize(module_name.to_s) Devise::Models.send(:autoload, camelized.to_sym, path) end Devise::Mapping.add_module module_name end |
.available_router_name ⇒ Object
306 307 308 |
# File 'lib/devise.rb', line 306 def self.available_router_name router_name || :main_app end |
.configure_warden! ⇒ Object
A method used internally to setup warden manager from the Rails initialize block.
441 442 443 444 445 446 447 448 449 450 451 452 453 454 |
# File 'lib/devise.rb', line 441 def self.configure_warden! #:nodoc: @@warden_configured ||= begin warden_config.failure_app = Devise::Delegator.new warden_config.default_scope = Devise.default_scope warden_config.intercept_401 = false Devise.mappings.each_value do |mapping| warden_config.scope_defaults mapping.name, :strategies => mapping.strategies end @@warden_config_block.try :call, Devise.warden_config true end end |
.confirm_within=(value) ⇒ Object
241 242 243 244 |
# File 'lib/devise.rb', line 241 def self.confirm_within=(value) warn "\n[DEVISE] Devise.confirm_within= is deprecated. Please set Devise.allow_unconfirmed_access_for= instead.\n" Devise.allow_unconfirmed_access_for = value end |
.cookie_options=(value) ⇒ Object
246 247 248 249 |
# File 'lib/devise.rb', line 246 def self.=(value) warn "\n[DEVISE] Devise.cookie_options= is deprecated. Please set Devise.rememberable_options= instead.\n" Devise. = value end |
.friendly_token ⇒ Object
Generate a friendly string randomically to be used as token.
457 458 459 |
# File 'lib/devise.rb', line 457 def self.friendly_token SecureRandom.base64(15).tr('+/=lIO0', 'pqrsxyz') end |
.include_helpers(scope) ⇒ Object
Include helpers in the given scope to AC and AV.
422 423 424 425 426 427 428 429 430 431 |
# File 'lib/devise.rb', line 422 def self.include_helpers(scope) ActiveSupport.on_load(:action_controller) do include scope::Helpers if defined?(scope::Helpers) include scope::UrlHelpers end ActiveSupport.on_load(:action_view) do include scope::UrlHelpers end end |
.mailer ⇒ Object
Get the mailer class from the mailer reference object.
315 316 317 |
# File 'lib/devise.rb', line 315 def self.mailer @@mailer_ref.get end |
.mailer=(class_name) ⇒ Object
Set the mailer reference object to access the mailer.
320 321 322 |
# File 'lib/devise.rb', line 320 def self.mailer=(class_name) @@mailer_ref = ref(class_name) end |
.omniauth(provider, *args) ⇒ Object
Specify an omniauth provider.
config.omniauth :github, APP_ID, APP_SECRET
415 416 417 418 419 |
# File 'lib/devise.rb', line 415 def self.omniauth(provider, *args) @@helpers << Devise::OmniAuth::UrlHelpers config = Devise::OmniAuth::Config.new(provider, args) @@omniauth_configs[config.strategy_name.to_sym] = config end |
.omniauth_providers ⇒ Object
310 311 312 |
# File 'lib/devise.rb', line 310 def self.omniauth_providers omniauth_configs.keys end |
.ref(arg) ⇒ Object
297 298 299 300 301 302 303 304 |
# File 'lib/devise.rb', line 297 def self.ref(arg) if defined?(ActiveSupport::Dependencies::ClassCache) ActiveSupport::Dependencies::reference(arg) Getter.new(arg) else ActiveSupport::Dependencies.ref(arg) end end |
.regenerate_helpers! ⇒ Object
Regenerates url helpers considering Devise.mapping
434 435 436 437 |
# File 'lib/devise.rb', line 434 def self.regenerate_helpers! Devise::Controllers::UrlHelpers.remove_helpers! Devise::Controllers::UrlHelpers.generate_helpers! end |
.remember_across_browsers=(value) ⇒ Object
237 238 239 |
# File 'lib/devise.rb', line 237 def self.remember_across_browsers=(value) warn "\n[DEVISE] Devise.remember_across_browsers is deprecated and has no effect. Please remove it.\n" end |
.secure_compare(a, b) ⇒ Object
constant-time comparison algorithm to prevent timing attacks
462 463 464 465 466 467 468 469 |
# File 'lib/devise.rb', line 462 def self.secure_compare(a, b) return false if a.blank? || b.blank? || a.bytesize != b.bytesize l = a.unpack "C#{a.bytesize}" res = 0 b.each_byte { |byte| res |= byte ^ l.shift } res == 0 end |
.setup {|_self| ... } ⇒ Object
Default way to setup Devise. Run rails generate devise_install to create a fresh initializer with all configuration values.
283 284 285 |
# File 'lib/devise.rb', line 283 def self.setup yield self end |
.stateless_token=(value) ⇒ Object
251 252 253 254 255 |
# File 'lib/devise.rb', line 251 def self.stateless_token=(value) warn "\n[DEVISE] Devise.stateless_token= is deprecated. Please append :token_auth to Devise.skip_session_storage " \ "instead, for example: Devise.skip_session_storage << :token_auth\n" Devise.skip_session_storage << :token_auth end |
.warden(&block) ⇒ Object
Sets warden configuration using a block that will be invoked on warden initialization.
Devise.initialize do |config|
config.allow_unconfirmed_access_for = 2.days
config.warden do |manager|
# Configure warden to use other strategies, like oauth.
manager.oauth(:twitter)
end
end
407 408 409 |
# File 'lib/devise.rb', line 407 def self.warden(&block) @@warden_config_block = block end |