2012-03-10 18:08:39 +01:00
|
|
|
require 'ezcrypto'
|
|
|
|
|
|
|
|
class User < ActiveRecord::Base
|
|
|
|
|
|
|
|
#acts_as_notes_owner
|
|
|
|
|
2012-03-24 13:23:34 +01:00
|
|
|
validates_presence_of :first_name,:last_name,:login
|
2012-03-10 18:08:39 +01:00
|
|
|
validates_uniqueness_of :login
|
|
|
|
has_many :servers, :dependent => :destroy
|
|
|
|
has_one :prefs, :dependent => :destroy
|
|
|
|
has_many :folders, :dependent => :destroy
|
|
|
|
has_many :messages, :dependent => :destroy
|
|
|
|
has_many :contacts, :dependent => :destroy
|
|
|
|
has_many :links, :dependent => :destroy
|
|
|
|
|
|
|
|
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
|
|
|
|
|
|
|
|
def name
|
|
|
|
first_name + " " + last_name
|
|
|
|
end
|
|
|
|
|
|
|
|
def full_id
|
|
|
|
(name + " <" + email + ">") if email
|
|
|
|
end
|
|
|
|
|
|
|
|
def email
|
|
|
|
if login =~ /\@/
|
|
|
|
login
|
|
|
|
else
|
|
|
|
(login + "@" + domain) if domain.presence
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def username
|
|
|
|
login.gsub(/\@/,"_").gsub(/\./,"_")
|
|
|
|
end
|
|
|
|
|
|
|
|
def has_domain?
|
|
|
|
return domain if domain.presence
|
|
|
|
if login =~ /\@/
|
|
|
|
login.split(/\@/)[1]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|