2011-07-24 22:22:13 +02:00
|
|
|
require 'ezcrypto'
|
|
|
|
|
2011-07-23 21:55:26 +02:00
|
|
|
class User < ActiveRecord::Base
|
2011-07-27 20:34:30 +02:00
|
|
|
|
2011-07-23 21:55:26 +02:00
|
|
|
validates_presence_of :first_name,:last_name
|
|
|
|
validates_uniqueness_of :email
|
|
|
|
has_many :servers, :dependent => :destroy
|
2011-07-24 15:56:47 +02:00
|
|
|
has_one :prefs, :dependent => :destroy
|
2011-07-27 20:34:30 +02:00
|
|
|
has_many :folders, :dependent => :destroy
|
2011-08-02 23:12:17 +02:00
|
|
|
has_many :messages, :dependent => :destroy
|
2011-08-16 20:05:58 +02:00
|
|
|
has_many :contacts, :dependent => :destroy
|
2011-07-24 22:22:13 +02:00
|
|
|
|
|
|
|
def set_cached_password(session,password)
|
|
|
|
if $defaults['session_encryption']
|
|
|
|
session[:session_salt] = generate_salt
|
|
|
|
session[:user_password] = EzCrypto::Key.encrypt_with_password($defaults['session_password'], session[:session_salt], password)
|
|
|
|
else
|
|
|
|
session[:user_password] = password
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def get_cached_password(session)
|
|
|
|
if $defaults['session_encryption']
|
|
|
|
EzCrypto::Key.decrypt_with_password($defaults['session_password'], session[:session_salt], session[:user_password])
|
|
|
|
else
|
|
|
|
session[:user_password]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def generate_salt
|
|
|
|
(0...8).map{65.+(rand(25)).chr}.join
|
|
|
|
end
|
|
|
|
|
2011-09-03 13:07:40 +02:00
|
|
|
def full_name
|
|
|
|
first_name + " " + last_name
|
|
|
|
end
|
|
|
|
|
|
|
|
def full_address
|
2011-09-10 20:31:55 +02:00
|
|
|
d = domain.presence || ""
|
2011-09-03 13:07:40 +02:00
|
|
|
if email =~ /\@/
|
|
|
|
email
|
|
|
|
else
|
2011-09-10 20:31:55 +02:00
|
|
|
email + "@" + d
|
2011-09-03 13:07:40 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-09-09 22:10:25 +02:00
|
|
|
def username
|
|
|
|
email.gsub(/\@/,"_").gsub(/\./,"_")
|
|
|
|
end
|
|
|
|
|
2011-07-23 21:55:26 +02:00
|
|
|
end
|