Sha256: 6adea4cd911e0220cad2e69e479bad53b6619d3b40c74c8b346c3a49c38e7d8d
Contents?: true
Size: 1.52 KB
Versions: 1
Compression:
Stored size: 1.52 KB
Contents
class <%= @model_name %> < Sequel::Model plugin :validation_helpers attr_accessor :password, :password_confirmation def validate validates_presence :email validates_presence :role validates_presence :password if password_required validates_presence :password_confirmation if password_required validates_length_range 4..40, :password unless password.blank? errors.add(:password_confirmation, 'must confirm password') if !password.blank? && password != password_confirmation validates_length_range 3..100, :email unless email.blank? validates_unique :email unless email.blank? validates_format /\A([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})\Z/i, :email unless email.blank? validates_format /[A-Za-z]/, :role unless role.blank? end # Callbacks def before_save encrypt_password end ## # This method is for authentication purpose. # def self.authenticate(email, password) account = filter(Sequel.function(:lower, :email) => Sequel.function(:lower, email)).first account && account.has_password?(password) ? account : nil end ## # Replace ActiveRecord method. # def self.find_by_id(id) self[id] rescue nil end def has_password?(password) ::BCrypt::Password.new(self.crypted_password) == password end private def encrypt_password self.crypted_password = ::BCrypt::Password.create(password) if password.present? end def password_required self.crypted_password.blank? || password.present? end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
padrino-admin-0.11.4 | lib/padrino-admin/generators/templates/account/sequel.rb.tt |