trabajo-afectivo/app/models/user.rb

584 lines
13 KiB
Ruby
Raw Normal View History

2014-02-03 19:23:00 +00:00
# Copyright (C) 2012-2014 Zammad Foundation, http://zammad-foundation.org/
require 'digest/md5'
2014-12-18 14:58:47 +00:00
# @model User
#
# @property id(required) [Integer] The identifier for the User.
# @property login(required) [String] The login of the User used for authentication.
# @property firstname [String] The firstname of the User.
# @property lastname [String] The lastname of the User.
# @property email [String] The email of the User.
# @property image [String] The Image used as the User avatar (TODO: Image model?).
# @property web [String] The website/URL of the User.
# @property password [String] The password of the User.
# @property phone [String] The phone number of the User.
# @property fax [String] The fax number of the User.
# @property mobile [String] The mobile number of the User.
# @property department [String] The department the User is working at.
# @property street [String] The street the User lives in.
# @property zip [Integer] The zip postal code of the User city.
# @property city [String] The city the User lives in.
# @property country [String] The country the User lives in.
# @property verified [Boolean] The flag that shows the verified state of the User.
# @property active [Boolean] The flag that shows the active state of the User.
# @property note [String] The note or comment stored to the User.
2012-04-16 08:04:49 +00:00
class User < ApplicationModel
include User::Permission
load 'user/assets.rb'
include User::Assets
extend User::Search
2014-12-01 07:32:35 +00:00
before_create :check_name, :check_email, :check_login, :check_password
2015-01-07 20:42:12 +00:00
before_update :check_password, :check_email, :check_login
2015-07-06 18:33:37 +00:00
after_create :avatar_for_email_check
after_update :avatar_for_email_check
after_destroy :avatar_destroy
notify_clients_support
2012-04-10 14:06:46 +00:00
has_and_belongs_to_many :groups, after_add: :cache_update, after_remove: :cache_update
has_and_belongs_to_many :roles, after_add: :cache_update, after_remove: :cache_update
has_and_belongs_to_many :organizations, after_add: :cache_update, after_remove: :cache_update
has_many :tokens, after_add: :cache_update, after_remove: :cache_update
has_many :authorizations, after_add: :cache_update, after_remove: :cache_update
belongs_to :organization, class_name: 'Organization'
2012-04-16 08:04:49 +00:00
store :preferences
2013-10-05 14:44:50 +00:00
activity_stream_support(
role: Z_ROLENAME_ADMIN,
ignore_attributes: {
last_login: true,
image: true,
image_source: true,
preferences: true,
2013-11-02 22:18:39 +00:00
}
2013-10-05 14:44:50 +00:00
)
2013-10-22 06:43:49 +00:00
history_support(
ignore_attributes: {
password: true,
image: true,
image_source: true,
preferences: true,
2013-10-22 06:43:49 +00:00
}
)
search_index_support(
ignore_attributes: {
password: true,
image: true,
image_source: true,
source: true,
login_failed: true,
preferences: true,
}
)
2013-09-28 00:07:11 +00:00
2013-08-17 22:10:02 +00:00
=begin
fullname of user
user = User.find(123)
result = user.fulename
returns
result = "Bob Smith"
=end
2012-07-10 08:09:58 +00:00
def fullname
fullname = ''
if firstname && !firstname.empty?
fullname = fullname + firstname
2012-07-10 08:09:58 +00:00
end
if lastname && !lastname.empty?
2012-07-10 08:09:58 +00:00
if fullname != ''
fullname = fullname + ' '
end
fullname = fullname + lastname
2012-07-10 08:09:58 +00:00
end
if fullname == '' && email
fullname = email
2015-01-07 20:42:12 +00:00
end
2013-09-28 00:07:11 +00:00
fullname
2012-07-10 08:09:58 +00:00
end
2013-08-17 22:10:02 +00:00
=begin
check if user is in role
user = User.find(123)
result = user.role?('Customer')
2013-08-17 22:10:02 +00:00
2015-09-11 08:22:15 +00:00
result = user.role?(['Agent', 'Admin'])
2013-08-17 22:10:02 +00:00
returns
result = true|false
=end
def role?( role_name )
result = false
roles.each { |role|
2015-09-11 08:22:15 +00:00
if role_name.class == Array
next if !role_name.include?(role.name)
else
next if role.name != role_name
end
result = true
break
2012-09-04 21:28:49 +00:00
}
result
2012-09-04 21:28:49 +00:00
end
2013-08-17 22:10:02 +00:00
=begin
2013-09-28 00:07:11 +00:00
get users activity stream
user = User.find(123)
result = user.activity_stream( 20 )
returns
result = [
{
:id => 2,
:o_id => 2,
2013-09-28 00:07:11 +00:00
:created_by_id => 3,
:created_at => '2013-09-28 00:57:21',
:object => "User",
:type => "created",
},
{
:id => 2,
:o_id => 2,
2013-09-28 00:07:11 +00:00
:created_by_id => 3,
:created_at => '2013-09-28 00:59:21',
:object => "User",
:type => "updated",
},
]
=end
def activity_stream( limit, fulldata = false )
activity_stream = ActivityStream.list( self, limit )
return activity_stream if !fulldata
# get related objects
assets = ApplicationModel.assets_of_object_list(activity_stream)
{
activity_stream: activity_stream,
assets: assets,
2013-09-28 00:07:11 +00:00
}
end
=begin
2013-08-17 22:10:02 +00:00
authenticate user
result = User.authenticate(username, password)
returns
result = user_model # user model if authentication was successfully
=end
def self.authenticate( username, password )
2012-07-29 15:27:01 +00:00
# do not authenticate with nothing
return if !username || username == ''
return if !password || password == ''
2012-07-29 15:27:01 +00:00
# try to find user based on login
user = User.find_by( login: username.downcase, active: true )
2012-07-29 15:27:01 +00:00
# try second lookup with email
if !user
user = User.find_by( email: username.downcase, active: true )
end
2012-07-29 15:27:01 +00:00
2013-02-07 21:24:03 +00:00
# check failed logins
2015-02-11 23:04:13 +00:00
max_login_failed = Setting.get('password_max_login_failed').to_i || 10
2013-02-12 22:49:52 +00:00
if user && user.login_failed > max_login_failed
2015-05-05 05:55:06 +00:00
logger.info "Max login faild reached for user #{user.login}."
2013-02-12 22:49:52 +00:00
return false
2013-02-07 21:24:03 +00:00
end
2012-07-29 15:27:01 +00:00
2013-08-17 21:48:01 +00:00
user_auth = Auth.check( username, password, user )
2013-02-07 21:24:03 +00:00
# set login failed +1
2013-02-12 23:21:56 +00:00
if !user_auth && user
2013-08-17 21:48:01 +00:00
sleep 1
2013-02-12 23:21:56 +00:00
user.login_failed = user.login_failed + 1
user.save
end
2013-02-07 21:24:03 +00:00
2013-08-17 21:48:01 +00:00
# auth ok
user_auth
2012-04-10 14:06:46 +00:00
end
2013-08-17 22:10:02 +00:00
=begin
authenticate user agains sso
result = User.sso(sso_params)
returns
result = user_model # user model if authentication was successfully
=end
2013-02-17 18:28:32 +00:00
def self.sso(params)
# try to login against configure auth backends
2013-08-19 08:22:31 +00:00
user_auth = Sso.check( params )
2013-08-17 21:48:01 +00:00
return if !user_auth
2013-02-17 18:28:32 +00:00
user_auth
2013-02-17 18:28:32 +00:00
end
2013-08-17 22:10:02 +00:00
=begin
create user from from omni auth hash
result = User.create_from_hash!(hash)
returns
result = user_model # user model if create was successfully
=end
2012-04-10 14:06:46 +00:00
def self.create_from_hash!(hash)
2015-07-06 18:33:37 +00:00
roles = Role.where( name: 'Customer' )
2012-04-10 14:06:46 +00:00
url = ''
if hash['info']['urls']
2015-07-06 18:33:37 +00:00
hash['info']['urls'].each {|_name, local_url|
next if !local_url
next if local_url.empty?
url = local_url
}
2012-04-10 14:06:46 +00:00
end
create(
login: hash['info']['nickname'] || hash['uid'],
firstname: hash['info']['name'],
email: hash['info']['email'],
2015-07-06 18:33:37 +00:00
image_source: hash['info']['image'],
web: url,
address: hash['info']['location'],
note: hash['info']['description'],
source: hash['provider'],
roles: roles,
updated_by_id: 1,
created_by_id: 1,
2012-04-10 14:06:46 +00:00
)
end
2012-04-23 06:55:16 +00:00
2013-08-17 22:10:02 +00:00
=begin
send reset password email with token to user
result = User.password_reset_send(username)
returns
result = token
2013-08-17 22:10:02 +00:00
=end
2012-04-23 06:55:16 +00:00
def self.password_reset_send(username)
return if !username || username == ''
# try to find user based on login
user = User.find_by( login: username.downcase, active: true )
2012-10-18 08:10:12 +00:00
2012-04-23 06:55:16 +00:00
# try second lookup with email
if !user
user = User.find_by( email: username.downcase, active: true )
2012-04-23 06:55:16 +00:00
end
# check if email address exists
return if !user
2012-04-23 06:55:16 +00:00
return if !user.email
# generate token
token = Token.create( action: 'PasswordReset', user_id: user.id )
2012-04-23 06:55:16 +00:00
# send mail
data = {}
data[:subject] = 'Reset your #{config.product_name} password'
data[:body] = 'Forgot your password?
2015-01-07 12:11:30 +00:00
We received a request to reset the password for your #{config.product_name} account (#{user.login}).
2012-04-23 06:55:16 +00:00
2015-01-07 12:11:30 +00:00
If you want to reset your password, click on the link below (or copy and paste the URL into your browser):
2012-04-23 06:55:16 +00:00
2015-01-07 12:11:30 +00:00
#{config.http_type}://#{config.fqdn}/#password_reset_verify/#{token.name}
2012-04-23 06:55:16 +00:00
2015-01-07 12:11:30 +00:00
This link takes you to a page where you can change your password.
2012-04-23 06:55:16 +00:00
2015-01-07 12:11:30 +00:00
If you don\'t want to reset your password, please ignore this message. Your password will not be reset.
2012-04-23 06:55:16 +00:00
2015-01-07 12:11:30 +00:00
Your #{config.product_name} Team'
2012-04-23 06:55:16 +00:00
# prepare subject & body
[:subject, :body].each { |key|
data[key.to_sym] = NotificationFactory.build(
locale: user.preferences[:locale],
string: data[key.to_sym],
objects: {
token: token,
user: user,
2012-04-23 06:55:16 +00:00
}
)
}
# send notification
NotificationFactory.send(
recipient: user,
subject: data[:subject],
body: data[:body]
2012-04-23 06:55:16 +00:00
)
token
2012-04-23 06:55:16 +00:00
end
2013-08-17 22:10:02 +00:00
=begin
check reset password token
result = User.password_reset_check(token)
returns
result = user_model # user_model if token was verified
=end
2012-04-23 06:55:16 +00:00
def self.password_reset_check(token)
user = Token.check( action: 'PasswordReset', name: token )
# reset login failed if token is valid
if user
user.login_failed = 0
user.save
end
user
2012-04-23 06:55:16 +00:00
end
2013-08-17 22:10:02 +00:00
=begin
reset reset password with token and set new password
result = User.password_reset_via_token(token,password)
returns
result = user_model # user_model if token was verified
=end
2015-04-27 14:53:29 +00:00
def self.password_reset_via_token(token, password)
2012-07-23 22:22:23 +00:00
2012-04-23 06:55:16 +00:00
# check token
user = Token.check( action: 'PasswordReset', name: token )
2013-01-03 12:00:55 +00:00
return if !user
2012-07-23 22:22:23 +00:00
2012-04-23 06:55:16 +00:00
# reset password
user.update_attributes( password: password )
2012-07-23 22:22:23 +00:00
2012-04-23 06:55:16 +00:00
# delete token
Token.find_by( action: 'PasswordReset', name: token ).destroy
user
2012-04-23 06:55:16 +00:00
end
2013-08-17 22:10:02 +00:00
=begin
2013-10-22 06:43:49 +00:00
update last login date and reset login_failed (is automatically done by auth and sso backend)
2013-08-17 22:10:02 +00:00
user = User.find(123)
result = user.update_last_login
returns
result = new_user_model
=end
2012-10-18 08:10:12 +00:00
def update_last_login
self.last_login = Time.zone.now
2013-10-22 06:43:49 +00:00
# reset login failed
self.login_failed = 0
# set updated by user
self.updated_by_id = id
2013-10-22 06:43:49 +00:00
save
2012-10-18 08:10:12 +00:00
end
=begin
list of active users in role
result = User.of_role('Agent')
returns
result = [user1, user2]
=end
def self.of_role(role)
User.where(active: true).joins(:roles).where( 'roles.name' => role, 'roles.active' => true ).uniq()
end
2012-04-10 14:06:46 +00:00
private
def cache_delete
super
# delete asset caches
key = "User::authorizations::#{id}"
Cache.delete(key)
key = "User::role_ids::#{id}"
Cache.delete(key)
key = "User::group_ids::#{id}"
Cache.delete(key)
key = "User::organization_ids::#{id}"
Cache.delete(key)
end
def check_name
if ( firstname && !firstname.empty? ) && ( !lastname || lastname.empty? )
# Lastname, Firstname
scan = firstname.scan(/, /)
if scan[0]
name = firstname.split(', ', 2)
if !name[0].nil?
self.lastname = name[0]
end
if !name[1].nil?
self.firstname = name[1]
end
return
end
# Firstname Lastname
name = firstname.split(' ', 2)
if !name[0].nil?
self.firstname = name[0]
end
if !name[1].nil?
self.lastname = name[1]
end
return
# -no name- firstname.lastname@example.com
elsif ( !firstname || firstname.empty? ) && ( !lastname || lastname.empty? ) && ( email && !email.empty? )
scan = email.scan(/^(.+?)\.(.+?)\@.+?$/)
if scan[0]
if !scan[0][0].nil?
self.firstname = scan[0][0].capitalize
end
if !scan[0][1].nil?
self.lastname = scan[0][1].capitalize
end
2012-04-10 14:06:46 +00:00
end
end
end
2012-04-29 20:47:35 +00:00
def check_email
return if !email
self.email = email.downcase
end
2012-04-29 20:47:35 +00:00
def check_login
2015-01-07 20:42:12 +00:00
# use email as login if not given
if !login && email
self.login = email
2014-09-25 06:20:20 +00:00
end
2015-01-07 20:42:12 +00:00
# if email has changed, login is old email, change also login
if changes && changes['email']
if changes['email'][0] == login
self.login = email
2015-01-07 20:42:12 +00:00
end
end
# check if login already exists
return if !login
self.login = login.downcase
check = true
while check
exists = User.find_by( login: login )
if exists && exists.id != id
self.login = login + rand(999).to_s
else
check = false
2013-02-19 19:04:35 +00:00
end
end
end
2013-02-19 19:04:35 +00:00
2015-07-06 18:33:37 +00:00
def avatar_for_email_check
2012-04-29 20:47:35 +00:00
return if !email
return if email.empty?
2015-10-23 11:02:11 +00:00
return if email !~ /@/
2014-12-01 07:32:35 +00:00
# save/update avatar
avatar = Avatar.auto_detection(
object: 'User',
o_id: id,
url: email,
source: 'app',
updated_by_id: updated_by_id,
created_by_id: updated_by_id,
2014-12-01 07:32:35 +00:00
)
2014-12-01 07:32:35 +00:00
# update user link
return if !avatar
update_column( :image, avatar.store_hash )
cache_delete
2014-12-01 07:32:35 +00:00
end
def avatar_destroy
Avatar.remove( 'User', id )
end
def check_password
2012-10-18 11:42:05 +00:00
# set old password again if not given
if password == '' || !password
# get current record
if id
2014-12-01 07:32:35 +00:00
#current = User.find(self.id)
#self.password = current.password
self.password = password_was
end
2014-12-01 07:32:35 +00:00
end
# crypt password if not already crypted
return if !password
return if password =~ /^\{sha2\}/
crypted = Digest::SHA2.hexdigest( password )
self.password = "{sha2}#{crypted}"
end
end