class User < ActiveRecord::Base
has_many :traces
- def passwd=(str)
+ validates_confirmation_of :pass_crypt, :message => 'Password must match the confirmation password'
+ validates_uniqueness_of :display_name
+ validates_uniqueness_of :email
+ validates_length_of :pass_crypt, :minimum => 8
+ validates_length_of :display_name, :minimum => 3
+ validates_format_of :email, :with => /^([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})$/i
+
+ def set_defaults
+ self.creation_time = Time.now
+ self.timeout = Time.now
+ self.token = User.make_token()
+ end
+
+ def pass_crypt=(str)
write_attribute("pass_crypt", Digest::MD5.hexdigest(str))
end
- def passwd
- return self.pass_crypt
+ def pass_crypt_confirmation=(str)
+ write_attribute("pass_crypt_confirm", Digest::MD5.hexdigest(str))
+ end
+
+ def self.authenticate(email, passwd)
+ find_first([ "email = ? AND pass_crypt =?", email, Digest::MD5.hexdigest(passwd) ])
end
- def self.authenticate(username, passwd)
- find_first([ "display_name = ? AND pass_crypt =?",
- username,
- Digest::MD5.hexdigest(passwd) ])
+ def self.authenticate_token(token)
+ find_first([ "token = ? ", token])
end
+
+ def self.make_token(length=30)
+ chars = 'abcdefghijklmnopqrtuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789'
+ confirmstring = ''
+
+ length.times do
+ confirmstring += chars[(rand * chars.length).to_i].chr
+ end
+
+ return confirmstring
+ end
+
end