module Devise # Holds devise schema information. To use it, just include its methods # and overwrite the apply_schema method. module Schema # Creates email, encrypted_password and password_salt. # # == Options # * :null - When true, allow columns to be null. # * :encryptor - The encryptor going to be used, necessary for setting the proper encrypter password length. def authenticatable(options={}) null = options[:null] || false encryptor = options[:encryptor] || (respond_to?(:encryptor) ? self.encryptor : :sha1) apply_schema :email, String, :null => null apply_schema :encrypted_password, String, :null => null, :limit => Devise::ENCRYPTORS_LENGTH[encryptor] apply_schema :password_salt, String, :null => null end # Creates authentication_token. def token_authenticatable apply_schema :authentication_token, String, :limit => 20 end # Creates confirmation_token, confirmed_at and confirmation_sent_at. def confirmable apply_schema :confirmation_token, String, :limit => 20 apply_schema :confirmed_at, DateTime apply_schema :confirmation_sent_at, DateTime end # Creates reset_password_token. def recoverable apply_schema :reset_password_token, String, :limit => 20 end # Creates remember_token and remember_created_at. def rememberable apply_schema :remember_token, String, :limit => 20 apply_schema :remember_created_at, DateTime end # Creates sign_in_count, current_sign_in_at, last_sign_in_at, # current_sign_in_ip, last_sign_in_ip. def trackable apply_schema :sign_in_count, Integer apply_schema :current_sign_in_at, DateTime apply_schema :last_sign_in_at, DateTime apply_schema :current_sign_in_ip, String apply_schema :last_sign_in_ip, String end # Creates failed_attempts, unlock_token and locked_at def lockable apply_schema :failed_attempts, Integer, :default => 0 apply_schema :unlock_token, String, :limit => 20 apply_schema :locked_at, DateTime end # Overwrite with specific modification to create your own schema. def apply_schema(name, type, options={}) raise NotImplementedError end end end