2009-10-18 11:30:32 -04:00
|
|
|
module Devise
|
2009-12-01 13:35:46 -05:00
|
|
|
autoload :FailureApp, 'devise/failure_app'
|
2009-12-12 19:52:48 -05:00
|
|
|
autoload :Schema, 'devise/schema'
|
|
|
|
autoload :TestHelpers, 'devise/test_helpers'
|
|
|
|
|
|
|
|
module Controllers
|
|
|
|
autoload :Helpers, 'devise/controllers/helpers'
|
2010-01-13 12:12:13 -05:00
|
|
|
autoload :InternalHelpers, 'devise/controllers/internal_helpers'
|
2009-12-12 19:52:48 -05:00
|
|
|
autoload :UrlHelpers, 'devise/controllers/url_helpers'
|
|
|
|
end
|
|
|
|
|
|
|
|
module Encryptors
|
2010-01-08 17:19:57 -05:00
|
|
|
autoload :Base, 'devise/encryptors/base'
|
|
|
|
autoload :Bcrypt, 'devise/encryptors/bcrypt'
|
2009-12-12 19:52:48 -05:00
|
|
|
autoload :AuthlogicSha512, 'devise/encryptors/authlogic_sha512'
|
2010-02-12 10:00:58 -05:00
|
|
|
autoload :ClearanceSha1, 'devise/encryptors/clearance_sha1'
|
2009-12-12 19:52:48 -05:00
|
|
|
autoload :RestfulAuthenticationSha1, 'devise/encryptors/restful_authentication_sha1'
|
|
|
|
autoload :Sha512, 'devise/encryptors/sha512'
|
|
|
|
autoload :Sha1, 'devise/encryptors/sha1'
|
|
|
|
end
|
|
|
|
|
|
|
|
module Orm
|
|
|
|
autoload :ActiveRecord, 'devise/orm/active_record'
|
|
|
|
autoload :DataMapper, 'devise/orm/data_mapper'
|
|
|
|
autoload :MongoMapper, 'devise/orm/mongo_mapper'
|
|
|
|
end
|
2009-12-01 13:35:46 -05:00
|
|
|
|
2010-02-05 15:34:05 -05:00
|
|
|
ALL = []
|
|
|
|
|
|
|
|
# Authentication ones first
|
|
|
|
ALL.push :authenticatable, :token_authenticatable, :rememberable
|
|
|
|
|
|
|
|
# Misc after
|
2010-02-06 06:24:00 -05:00
|
|
|
ALL.push :recoverable, :registerable, :validatable
|
2010-02-05 15:34:05 -05:00
|
|
|
|
|
|
|
# The ones which can sign out after
|
|
|
|
ALL.push :activatable, :confirmable, :lockable, :timeoutable
|
|
|
|
|
|
|
|
# Stats for last, so we make sure the user is really signed in
|
|
|
|
ALL.push :trackable
|
2009-10-18 11:30:32 -04:00
|
|
|
|
2010-01-23 19:47:33 -05:00
|
|
|
# Maps controller names to devise modules.
|
2009-10-18 11:30:32 -04:00
|
|
|
CONTROLLERS = {
|
2010-01-23 21:38:52 -05:00
|
|
|
:sessions => [:authenticatable, :token_authenticatable],
|
2009-12-08 17:39:38 -05:00
|
|
|
:passwords => [:recoverable],
|
2009-12-30 12:19:33 -05:00
|
|
|
:confirmations => [:confirmable],
|
2010-01-23 19:26:06 -05:00
|
|
|
:registrations => [:registerable],
|
2009-12-30 12:19:33 -05:00
|
|
|
:unlocks => [:lockable]
|
2009-12-09 05:14:50 -05:00
|
|
|
}
|
2009-10-20 06:44:21 -04:00
|
|
|
|
2010-01-23 19:47:33 -05:00
|
|
|
# Routes for generating url helpers.
|
|
|
|
ROUTES = [:session, :password, :confirmation, :registration, :unlock]
|
|
|
|
|
2010-02-05 19:33:32 -05:00
|
|
|
STRATEGIES = [:rememberable, :http_authenticatable, :token_authenticatable, :authenticatable]
|
2010-01-23 21:38:52 -05:00
|
|
|
|
2009-12-08 15:29:00 -05:00
|
|
|
TRUE_VALUES = [true, 1, '1', 't', 'T', 'true', 'TRUE']
|
2009-10-18 11:30:32 -04:00
|
|
|
|
2009-12-20 07:53:53 -05:00
|
|
|
# Maps the messages types that are used in flash message.
|
2010-01-23 19:47:33 -05:00
|
|
|
FLASH_MESSAGES = [:unauthenticated, :unconfirmed, :invalid, :invalid_token, :timeout, :inactive, :locked]
|
2009-11-06 11:27:27 -05:00
|
|
|
|
2009-11-10 15:55:13 -05:00
|
|
|
# Declare encryptors length which are used in migrations.
|
|
|
|
ENCRYPTORS_LENGTH = {
|
|
|
|
:sha1 => 40,
|
|
|
|
:sha512 => 128,
|
|
|
|
:clearance_sha1 => 40,
|
|
|
|
:restful_authentication_sha1 => 40,
|
2010-01-08 17:19:57 -05:00
|
|
|
:authlogic_sha512 => 128,
|
|
|
|
:bcrypt => 60
|
2009-11-10 15:55:13 -05:00
|
|
|
}
|
|
|
|
|
2010-02-02 07:28:47 -05:00
|
|
|
# Email regex used to validate email formats. Adapted from authlogic.
|
|
|
|
EMAIL_REGEX = /^([\w\.%\+\-]+)@([\w\-]+\.)+([\w]{2,})$/i
|
2009-12-20 07:53:53 -05:00
|
|
|
|
2009-11-18 06:41:42 -05:00
|
|
|
# Used to encrypt password. Please generate one with rake secret.
|
2009-11-09 19:00:44 -05:00
|
|
|
mattr_accessor :pepper
|
|
|
|
@@pepper = nil
|
2009-11-13 17:54:21 -05:00
|
|
|
|
2009-11-09 19:00:44 -05:00
|
|
|
# The number of times to encrypt password.
|
|
|
|
mattr_accessor :stretches
|
|
|
|
@@stretches = 10
|
2009-11-13 17:54:21 -05:00
|
|
|
|
2009-11-15 00:31:13 -05:00
|
|
|
# Keys used when authenticating an user.
|
|
|
|
mattr_accessor :authentication_keys
|
|
|
|
@@authentication_keys = [ :email ]
|
|
|
|
|
2009-11-09 19:00:44 -05:00
|
|
|
# Time interval where the remember me token is valid.
|
|
|
|
mattr_accessor :remember_for
|
|
|
|
@@remember_for = 2.weeks
|
2009-11-13 17:54:21 -05:00
|
|
|
|
2009-11-09 19:00:44 -05:00
|
|
|
# Time interval you can access your account before confirming your account.
|
|
|
|
mattr_accessor :confirm_within
|
|
|
|
@@confirm_within = 0.days
|
2009-11-03 19:34:37 -05:00
|
|
|
|
2009-11-22 19:19:29 -05:00
|
|
|
# Time interval to timeout the user session without activity.
|
2009-11-24 21:11:49 -05:00
|
|
|
mattr_accessor :timeout_in
|
|
|
|
@@timeout_in = 30.minutes
|
2009-11-22 19:19:29 -05:00
|
|
|
|
2009-11-10 15:55:13 -05:00
|
|
|
# Used to define the password encryption algorithm.
|
2009-11-22 19:32:54 -05:00
|
|
|
mattr_accessor :encryptor
|
|
|
|
@@encryptor = :sha1
|
2009-11-10 15:55:13 -05:00
|
|
|
|
2009-11-09 19:00:44 -05:00
|
|
|
# Store scopes mappings.
|
2009-11-06 11:27:27 -05:00
|
|
|
mattr_accessor :mappings
|
2010-01-16 08:32:52 -05:00
|
|
|
@@mappings = ActiveSupport::OrderedHash.new
|
2009-11-06 11:27:27 -05:00
|
|
|
|
2009-11-13 19:33:00 -05:00
|
|
|
# Stores the chosen ORM.
|
2009-11-13 17:54:21 -05:00
|
|
|
mattr_accessor :orm
|
2009-11-13 19:33:00 -05:00
|
|
|
@@orm = :active_record
|
2009-11-13 17:54:21 -05:00
|
|
|
|
2010-01-13 13:45:24 -05:00
|
|
|
# TODO Remove
|
2009-11-18 06:26:47 -05:00
|
|
|
mattr_accessor :all
|
2010-01-13 13:45:24 -05:00
|
|
|
@@all = []
|
2009-11-18 06:26:47 -05:00
|
|
|
|
2009-11-18 06:41:42 -05:00
|
|
|
# Tells if devise should apply the schema in ORMs where devise declaration
|
|
|
|
# and schema belongs to the same class (as Datamapper and MongoMapper).
|
|
|
|
mattr_accessor :apply_schema
|
|
|
|
@@apply_schema = true
|
|
|
|
|
2009-11-21 17:07:37 -05:00
|
|
|
# Scoped views. Since it relies on fallbacks to render default views, it's
|
|
|
|
# turned off by default.
|
|
|
|
mattr_accessor :scoped_views
|
|
|
|
@@scoped_views = false
|
|
|
|
|
2009-12-30 12:19:33 -05:00
|
|
|
# Number of authentication tries before locking an account
|
|
|
|
mattr_accessor :maximum_attempts
|
2010-01-09 08:41:28 -05:00
|
|
|
@@maximum_attempts = 20
|
2009-12-30 12:19:33 -05:00
|
|
|
|
|
|
|
# Defines which strategy can be used to unlock an account.
|
|
|
|
# Values: :email, :time, :both
|
|
|
|
mattr_accessor :unlock_strategy
|
|
|
|
@@unlock_strategy = :both
|
|
|
|
|
|
|
|
# Time interval to unlock the account if :time is defined as unlock_strategy.
|
|
|
|
mattr_accessor :unlock_in
|
|
|
|
@@unlock_in = 1.hour
|
|
|
|
|
2010-01-06 08:31:00 -05:00
|
|
|
# Tell when to use the default scope, if one cannot be found from routes.
|
|
|
|
mattr_accessor :use_default_scope
|
2010-02-08 11:33:22 -05:00
|
|
|
@@use_default_scope = false
|
2010-01-06 08:31:00 -05:00
|
|
|
|
|
|
|
# The default scope which is used by warden.
|
2010-01-05 07:44:13 -05:00
|
|
|
mattr_accessor :default_scope
|
|
|
|
@@default_scope = nil
|
|
|
|
|
2010-01-06 08:31:00 -05:00
|
|
|
# Address which sends Devise e-mails.
|
2010-01-05 10:01:16 -05:00
|
|
|
mattr_accessor :mailer_sender
|
2010-02-08 11:33:22 -05:00
|
|
|
@@mailer_sender = nil
|
2010-01-05 10:01:16 -05:00
|
|
|
|
2010-01-23 21:38:52 -05:00
|
|
|
# Authentication token params key name of choice. E.g. /users/sign_in?some_key=...
|
2010-02-02 07:21:00 -05:00
|
|
|
mattr_accessor :token_authentication_key
|
|
|
|
@@token_authentication_key = :auth_token
|
2010-01-23 21:38:52 -05:00
|
|
|
|
2010-02-05 19:33:32 -05:00
|
|
|
# The realm used in Http Basic Authentication
|
|
|
|
mattr_accessor :http_authentication_realm
|
|
|
|
@@http_authentication_realm = "Application"
|
|
|
|
|
2009-11-03 06:35:11 -05:00
|
|
|
class << self
|
|
|
|
# Default way to setup Devise. Run script/generate devise_install to create
|
|
|
|
# a fresh initializer with all configuration values.
|
|
|
|
def setup
|
|
|
|
yield self
|
|
|
|
end
|
|
|
|
|
|
|
|
# Sets warden configuration using a block that will be invoked on warden
|
|
|
|
# initialization.
|
|
|
|
#
|
|
|
|
# Devise.initialize do |config|
|
|
|
|
# config.confirm_within = 2.days
|
|
|
|
#
|
|
|
|
# config.warden do |manager|
|
|
|
|
# # Configure warden to use other strategies, like oauth.
|
|
|
|
# manager.oauth(:twitter)
|
|
|
|
# end
|
|
|
|
# end
|
|
|
|
def warden(&block)
|
|
|
|
@warden_config = block
|
|
|
|
end
|
|
|
|
|
2009-11-06 17:59:36 -05:00
|
|
|
# Configure default url options to be used within Devise and ActionController.
|
|
|
|
def default_url_options(&block)
|
|
|
|
Devise::Mapping.metaclass.send :define_method, :default_url_options, &block
|
|
|
|
end
|
|
|
|
|
2009-11-03 06:35:11 -05:00
|
|
|
# A method used internally to setup warden manager from the Rails initialize
|
|
|
|
# block.
|
2010-01-05 07:44:13 -05:00
|
|
|
def configure_warden(config) #:nodoc:
|
|
|
|
config.default_strategies *Devise::STRATEGIES
|
|
|
|
config.failure_app = Devise::FailureApp
|
|
|
|
config.silence_missing_strategies!
|
|
|
|
config.default_scope = Devise.default_scope
|
2009-11-03 06:35:11 -05:00
|
|
|
|
|
|
|
# If the user provided a warden hook, call it now.
|
2010-01-05 07:44:13 -05:00
|
|
|
@warden_config.try :call, config
|
2009-11-03 06:35:11 -05:00
|
|
|
end
|
2009-11-13 17:54:21 -05:00
|
|
|
|
2009-11-13 19:33:00 -05:00
|
|
|
# The class of the configured ORM
|
|
|
|
def orm_class
|
|
|
|
Devise::Orm.const_get(@@orm.to_s.camelize.to_sym)
|
2009-11-13 17:54:21 -05:00
|
|
|
end
|
2009-11-18 06:26:47 -05:00
|
|
|
|
|
|
|
# Generate a friendly string randomically to be used as token.
|
|
|
|
def friendly_token
|
|
|
|
ActiveSupport::SecureRandom.base64(15).tr('+/=', '-_ ').strip.delete("\n")
|
|
|
|
end
|
2010-01-20 19:19:36 -05:00
|
|
|
|
|
|
|
# Make Devise aware of an 3rd party Devise-module. For convenience.
|
|
|
|
#
|
|
|
|
# == Options:
|
|
|
|
#
|
|
|
|
# +strategy+ - Boolean value representing if this module got a custom *strategy*.
|
|
|
|
# Default is +false+. Note: Devise will auto-detect this in such case if this is true.
|
|
|
|
# +model+ - String representing a load path to a custom *model* for this module (to autoload).
|
|
|
|
# Default is +nil+ (i.e. +false+).
|
|
|
|
# +controller+ - Symbol representing a name of an exisiting or custom *controller* for this module.
|
|
|
|
# Default is +nil+ (i.e. +false+).
|
|
|
|
#
|
|
|
|
# == Examples:
|
|
|
|
#
|
|
|
|
# Devise.add_module(:party_module)
|
|
|
|
# Devise.add_module(:party_module, :strategy => true, :controller => :sessions)
|
|
|
|
# Devise.add_module(:party_module, :model => 'party_module/model')
|
|
|
|
#
|
|
|
|
def add_module(module_name, options = {})
|
2010-01-21 03:15:07 -05:00
|
|
|
Devise::ALL.unshift module_name unless Devise::ALL.include?(module_name)
|
2010-01-20 19:19:36 -05:00
|
|
|
Devise::STRATEGIES.unshift module_name if options[:strategy] && !Devise::STRATEGIES.include?(module_name)
|
2010-01-21 03:15:07 -05:00
|
|
|
|
|
|
|
if options[:controller]
|
2010-01-20 19:19:36 -05:00
|
|
|
controller = options[:controller].to_sym
|
|
|
|
Devise::CONTROLLERS[controller] ||= []
|
|
|
|
Devise::CONTROLLERS[controller].unshift module_name unless Devise::CONTROLLERS[controller].include?(module_name)
|
|
|
|
end
|
2010-01-21 03:15:07 -05:00
|
|
|
|
|
|
|
if options[:model]
|
2010-01-20 19:19:36 -05:00
|
|
|
Devise::Models.module_eval do
|
|
|
|
autoload :"#{module_name.to_s.classify}", options[:model]
|
|
|
|
end
|
|
|
|
end
|
2010-01-21 03:15:07 -05:00
|
|
|
|
|
|
|
Devise::Mapping.register module_name
|
2010-01-20 19:19:36 -05:00
|
|
|
end
|
2009-11-03 06:35:11 -05:00
|
|
|
end
|
2009-10-11 07:15:48 -04:00
|
|
|
end
|
2009-10-20 22:12:21 -04:00
|
|
|
|
2009-11-14 21:13:43 -05:00
|
|
|
begin
|
|
|
|
require 'warden'
|
|
|
|
rescue
|
|
|
|
gem 'warden'
|
|
|
|
require 'warden'
|
|
|
|
end
|
|
|
|
|
2010-01-21 03:15:07 -05:00
|
|
|
require 'devise/mapping'
|
2010-01-23 19:26:06 -05:00
|
|
|
require 'devise/rails'
|