-
Notifications
You must be signed in to change notification settings - Fork 0
/
account.rb
59 lines (51 loc) · 1.94 KB
/
account.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
require 'digest/sha1'
class Account
include MongoMapper::Document
attr_accessor :password
# Keys
key :first_name, String
key :last_name, String
key :username, String
key :email, String
key :crypted_password, String
key :salt, String
key :role, String
# Validations
validates_presence_of :email, :role, :username
validates_presence_of :password, :if => :password_required
validates_presence_of :password_confirmation, :if => :password_required
validates_length_of :password, :within => 4..40, :if => :password_required
validates_confirmation_of :password, :if => :password_required
validates_length_of :email, :within => 3..40
validates_length_of :username, :within => 3..40
validates_length_of :first_name, :within => 3..40
validates_length_of :last_name, :within => 3..40
validates_uniqueness_of :email, :case_sensitive => false
validates_uniqueness_of :username, :case_sensitive => false
validates_format_of :email, :with => /\A([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})\Z/i
validates_format_of :role, :with => /[A-Za-z]/
# Callbacks
before_save :generate_password
##
# This method is for authentication purpose
#
def self.authenticate(email, password)
account = first(:email => email) if email.present?
account && account.password_clean == password ? account : nil
end
##
# This method is used to retrieve the original password.
#
def password_clean
crypted_password.decrypt(salt)
end
private
def generate_password
return if password.blank?
self.salt = Digest::SHA1.hexdigest("--#{Time.now.to_s}--#{email}--") if new_record?
self.crypted_password = password.encrypt(self.salt)
end
def password_required
crypted_password.blank? || !password.blank?
end
end