2016-04-15 21:56:10 +00:00
|
|
|
# Copyright (C) 2012-2014 Zammad Foundation, http://zammad-foundation.org/
|
2015-01-03 22:53:07 +00:00
|
|
|
|
2016-04-15 21:56:10 +00:00
|
|
|
class Transaction::Notification
|
2016-02-22 07:58:33 +00:00
|
|
|
|
|
|
|
=begin
|
2016-04-15 21:56:10 +00:00
|
|
|
{
|
|
|
|
object: 'Ticket',
|
2016-02-27 11:48:44 +00:00
|
|
|
type: 'update',
|
2016-04-22 06:55:10 +00:00
|
|
|
object_id: 123,
|
2016-04-15 21:56:10 +00:00
|
|
|
via_web: true,
|
2016-02-27 11:48:44 +00:00
|
|
|
changes: {
|
2016-04-15 21:56:10 +00:00
|
|
|
'attribute1' => [before, now],
|
|
|
|
'attribute2' => [before, now],
|
2016-02-22 07:58:33 +00:00
|
|
|
}
|
2016-04-27 07:31:11 +00:00
|
|
|
user_id: 123,
|
2016-04-15 21:56:10 +00:00
|
|
|
},
|
2016-02-22 07:58:33 +00:00
|
|
|
=end
|
2016-04-15 21:56:10 +00:00
|
|
|
|
|
|
|
def initialize(item, params = {})
|
|
|
|
@item = item
|
|
|
|
@params = params
|
2014-08-25 23:58:04 +00:00
|
|
|
end
|
2015-05-07 10:27:12 +00:00
|
|
|
|
2014-08-25 23:58:04 +00:00
|
|
|
def perform
|
2016-04-22 06:55:10 +00:00
|
|
|
|
|
|
|
# return if we run import mode
|
|
|
|
return if Setting.get('import_mode')
|
|
|
|
|
|
|
|
return if @item[:object] != 'Ticket'
|
|
|
|
|
2016-04-16 09:13:12 +00:00
|
|
|
return if @params[:disable_notification]
|
|
|
|
|
2016-04-22 06:55:10 +00:00
|
|
|
ticket = Ticket.find(@item[:object_id])
|
2016-04-15 21:56:10 +00:00
|
|
|
if @item[:article_id]
|
|
|
|
article = Ticket::Article.find(@item[:article_id])
|
2015-01-03 22:53:07 +00:00
|
|
|
end
|
2014-08-25 23:58:04 +00:00
|
|
|
|
|
|
|
# find recipients
|
2016-02-07 13:00:29 +00:00
|
|
|
recipients_and_channels = []
|
2014-08-25 23:58:04 +00:00
|
|
|
|
2015-01-03 22:53:07 +00:00
|
|
|
=begin
|
2014-08-25 23:58:04 +00:00
|
|
|
# group of agents to work on
|
|
|
|
if data[:recipient] == 'group'
|
|
|
|
recipients = ticket.agent_of_group()
|
|
|
|
|
2015-01-02 15:50:31 +00:00
|
|
|
# owner
|
2014-08-25 23:58:04 +00:00
|
|
|
elsif data[:recipient] == 'owner'
|
|
|
|
if ticket.owner_id != 1
|
|
|
|
recipients.push ticket.owner
|
|
|
|
end
|
|
|
|
|
2015-01-02 15:50:31 +00:00
|
|
|
# customer
|
2014-08-25 23:58:04 +00:00
|
|
|
elsif data[:recipient] == 'customer'
|
|
|
|
if ticket.customer_id != 1
|
|
|
|
# temporarily disabled
|
|
|
|
# recipients.push ticket.customer
|
|
|
|
end
|
|
|
|
|
2015-01-02 15:50:31 +00:00
|
|
|
# owner or group of agents to work on
|
2014-08-25 23:58:04 +00:00
|
|
|
elsif data[:recipient] == 'to_work_on'
|
|
|
|
if ticket.owner_id != 1
|
|
|
|
recipients.push ticket.owner
|
|
|
|
else
|
|
|
|
recipients = ticket.agent_of_group()
|
|
|
|
end
|
|
|
|
end
|
2015-01-03 22:53:07 +00:00
|
|
|
=end
|
|
|
|
|
2016-02-07 13:00:29 +00:00
|
|
|
# loop through all users
|
|
|
|
possible_recipients = ticket.agent_of_group
|
|
|
|
if ticket.owner_id == 1
|
|
|
|
possible_recipients.push ticket.owner
|
2015-01-03 22:53:07 +00:00
|
|
|
end
|
2016-02-07 13:00:29 +00:00
|
|
|
already_checked_recipient_ids = {}
|
|
|
|
possible_recipients.each {|user|
|
2016-04-15 21:56:10 +00:00
|
|
|
result = NotificationFactory::Mailer.notification_settings(user, ticket, @item[:type])
|
2016-02-27 11:48:44 +00:00
|
|
|
next if !result
|
|
|
|
next if already_checked_recipient_ids[result[:user].id]
|
|
|
|
already_checked_recipient_ids[result[:user].id] = true
|
|
|
|
recipients_and_channels.push result
|
2016-02-07 13:00:29 +00:00
|
|
|
}
|
2014-08-25 23:58:04 +00:00
|
|
|
|
|
|
|
# send notifications
|
2015-01-03 22:53:07 +00:00
|
|
|
recipient_list = ''
|
2016-02-07 13:00:29 +00:00
|
|
|
recipients_and_channels.each do |item|
|
|
|
|
user = item[:user]
|
|
|
|
channels = item[:channels]
|
2015-01-02 15:50:31 +00:00
|
|
|
|
2016-02-03 07:58:51 +00:00
|
|
|
# ignore user who changed it by him self via web
|
2016-04-15 21:56:10 +00:00
|
|
|
if @params[:via_web]
|
2016-02-03 07:58:51 +00:00
|
|
|
next if article && article.updated_by_id == user.id
|
2016-04-27 07:31:11 +00:00
|
|
|
next if !article && @item[:user_id] == user.id
|
2016-02-03 07:58:51 +00:00
|
|
|
end
|
2015-01-09 19:44:04 +00:00
|
|
|
|
|
|
|
# ignore inactive users
|
2015-01-02 15:53:59 +00:00
|
|
|
next if !user.active
|
2015-01-02 15:50:31 +00:00
|
|
|
|
2016-02-07 13:00:29 +00:00
|
|
|
# ignore if no changes has been done
|
|
|
|
changes = human_changes(user, ticket)
|
2016-04-15 21:56:10 +00:00
|
|
|
next if @item[:type] == 'update' && !article && (!changes || changes.empty?)
|
2014-08-25 23:58:04 +00:00
|
|
|
|
2016-02-22 10:05:33 +00:00
|
|
|
# check if today already notified
|
2016-04-15 21:56:10 +00:00
|
|
|
if @item[:type] == 'reminder_reached' || @item[:type] == 'escalation' || @item[:type] == 'escalation_warning'
|
2016-02-20 10:12:15 +00:00
|
|
|
identifier = user.email
|
|
|
|
if !identifier || identifier == ''
|
|
|
|
identifier = user.login
|
|
|
|
end
|
|
|
|
already_notified = false
|
|
|
|
History.list('Ticket', ticket.id).each {|history|
|
|
|
|
next if history['type'] != 'notification'
|
2016-04-15 21:56:10 +00:00
|
|
|
next if history['value_to'] !~ /\(#{Regexp.escape(@item[:type])}:/
|
2016-02-20 10:12:15 +00:00
|
|
|
next if history['value_to'] !~ /#{Regexp.escape(identifier)}\(/
|
2016-02-22 12:54:28 +00:00
|
|
|
next if !history['created_at'].today?
|
2016-02-20 10:12:15 +00:00
|
|
|
already_notified = true
|
|
|
|
}
|
|
|
|
next if already_notified
|
|
|
|
end
|
|
|
|
|
2016-02-07 13:00:29 +00:00
|
|
|
# create online notification
|
|
|
|
used_channels = []
|
|
|
|
if channels['online']
|
|
|
|
used_channels.push 'online'
|
2016-02-20 10:12:15 +00:00
|
|
|
|
2016-04-27 07:31:11 +00:00
|
|
|
created_by_id = @item[:user_id] || 1
|
2016-02-22 19:58:23 +00:00
|
|
|
|
2016-02-20 10:12:15 +00:00
|
|
|
# delete old notifications
|
2016-04-15 21:56:10 +00:00
|
|
|
if @item[:type] == 'reminder_reached'
|
2016-02-20 13:09:56 +00:00
|
|
|
seen = false
|
2016-02-22 19:58:23 +00:00
|
|
|
created_by_id = 1
|
2016-04-15 21:56:10 +00:00
|
|
|
OnlineNotification.remove_by_type('Ticket', ticket.id, @item[:type], user)
|
2016-02-22 07:58:33 +00:00
|
|
|
|
2016-04-15 21:56:10 +00:00
|
|
|
elsif @item[:type] == 'escalation' || @item[:type] == 'escalation_warning'
|
2016-02-22 23:28:13 +00:00
|
|
|
seen = false
|
|
|
|
created_by_id = 1
|
|
|
|
OnlineNotification.remove_by_type('Ticket', ticket.id, 'escalation', user)
|
|
|
|
OnlineNotification.remove_by_type('Ticket', ticket.id, 'escalation_warning', user)
|
|
|
|
|
2016-02-22 07:58:33 +00:00
|
|
|
# on updates without state changes create unseen messages
|
2016-04-15 21:56:10 +00:00
|
|
|
elsif @item[:type] != 'create' && (!@item[:changes] || @item[:changes].empty? || !@item[:changes]['state_id'])
|
2016-02-22 07:58:33 +00:00
|
|
|
seen = false
|
|
|
|
else
|
|
|
|
seen = ticket.online_notification_seen_state(user.id)
|
2016-02-20 10:12:15 +00:00
|
|
|
end
|
2016-02-22 07:58:33 +00:00
|
|
|
|
2016-02-07 13:00:29 +00:00
|
|
|
OnlineNotification.add(
|
2016-04-15 21:56:10 +00:00
|
|
|
type: @item[:type],
|
2016-02-07 13:00:29 +00:00
|
|
|
object: 'Ticket',
|
|
|
|
o_id: ticket.id,
|
|
|
|
seen: seen,
|
2016-02-22 19:58:23 +00:00
|
|
|
created_by_id: created_by_id,
|
2016-02-07 13:00:29 +00:00
|
|
|
user_id: user.id,
|
|
|
|
)
|
2016-04-15 21:56:10 +00:00
|
|
|
Rails.logger.debug "sent ticket online notifiaction to agent (#{@item[:type]}/#{ticket.id}/#{user.email})"
|
2014-08-25 23:58:04 +00:00
|
|
|
end
|
|
|
|
|
2016-02-07 13:00:29 +00:00
|
|
|
# ignore email channel notificaiton and empty emails
|
2016-02-08 11:01:32 +00:00
|
|
|
if !channels['email'] || !user.email || user.email == ''
|
2016-04-15 21:56:10 +00:00
|
|
|
add_recipient_list(ticket, user, used_channels, @item[:type])
|
2015-01-09 19:44:04 +00:00
|
|
|
next
|
|
|
|
end
|
2015-01-04 12:52:14 +00:00
|
|
|
|
2016-02-07 13:00:29 +00:00
|
|
|
used_channels.push 'email'
|
2016-04-15 21:56:10 +00:00
|
|
|
add_recipient_list(ticket, user, used_channels, @item[:type])
|
2016-02-07 13:00:29 +00:00
|
|
|
|
2015-01-03 22:53:07 +00:00
|
|
|
# get user based notification template
|
|
|
|
# if create, send create message / block update messages
|
2016-02-19 21:05:36 +00:00
|
|
|
template = nil
|
2016-04-15 21:56:10 +00:00
|
|
|
if @item[:type] == 'create'
|
2016-02-19 21:05:36 +00:00
|
|
|
template = 'ticket_create'
|
2016-04-15 21:56:10 +00:00
|
|
|
elsif @item[:type] == 'update'
|
2016-02-19 21:05:36 +00:00
|
|
|
template = 'ticket_update'
|
2016-04-15 21:56:10 +00:00
|
|
|
elsif @item[:type] == 'reminder_reached'
|
2016-02-20 10:12:15 +00:00
|
|
|
template = 'ticket_reminder_reached'
|
2016-04-15 21:56:10 +00:00
|
|
|
elsif @item[:type] == 'escalation'
|
2016-02-20 10:12:15 +00:00
|
|
|
template = 'ticket_escalation'
|
2016-04-15 21:56:10 +00:00
|
|
|
elsif @item[:type] == 'escalation_warning'
|
2016-02-22 23:28:13 +00:00
|
|
|
template = 'ticket_escalation_warning'
|
2015-01-03 22:53:07 +00:00
|
|
|
else
|
2016-04-15 21:56:10 +00:00
|
|
|
raise "unknown type for notification #{@item[:type]}"
|
2015-01-03 22:53:07 +00:00
|
|
|
end
|
|
|
|
|
2016-04-27 07:31:11 +00:00
|
|
|
current_user = User.lookup(id: @item[:user_id] || 1)
|
|
|
|
if !current_user
|
|
|
|
current_user = User.lookup(id: 1)
|
|
|
|
end
|
|
|
|
|
2016-04-13 23:40:37 +00:00
|
|
|
NotificationFactory::Mailer.notification(
|
2016-02-19 21:05:36 +00:00
|
|
|
template: template,
|
|
|
|
user: user,
|
|
|
|
objects: {
|
|
|
|
ticket: ticket,
|
|
|
|
article: article,
|
|
|
|
recipient: user,
|
2016-04-27 07:31:11 +00:00
|
|
|
current_user: current_user,
|
2016-02-19 21:05:36 +00:00
|
|
|
changes: changes,
|
2016-02-20 07:14:51 +00:00
|
|
|
},
|
|
|
|
references: ticket.get_references,
|
|
|
|
main_object: ticket,
|
2014-08-25 23:58:04 +00:00
|
|
|
)
|
2016-04-15 21:56:10 +00:00
|
|
|
Rails.logger.debug "sent ticket email notifiaction to agent (#{@item[:type]}/#{ticket.id}/#{user.email})"
|
2014-08-25 23:58:04 +00:00
|
|
|
end
|
|
|
|
|
2016-02-07 15:53:21 +00:00
|
|
|
end
|
2015-04-30 15:25:04 +00:00
|
|
|
|
2016-02-20 10:12:15 +00:00
|
|
|
def add_recipient_list(ticket, user, channels, type)
|
2016-02-07 15:53:21 +00:00
|
|
|
return if channels.empty?
|
2016-02-07 16:17:27 +00:00
|
|
|
identifier = user.email
|
2016-02-08 05:58:28 +00:00
|
|
|
if !identifier || identifier == ''
|
2016-02-07 16:17:27 +00:00
|
|
|
identifier = user.login
|
|
|
|
end
|
2016-02-20 10:12:15 +00:00
|
|
|
recipient_list = "#{identifier}(#{type}:#{channels.join(',')})"
|
2015-04-30 15:25:04 +00:00
|
|
|
History.add(
|
|
|
|
o_id: ticket.id,
|
|
|
|
history_type: 'notification',
|
|
|
|
history_object: 'Ticket',
|
|
|
|
value_to: recipient_list,
|
2016-04-27 07:31:11 +00:00
|
|
|
created_by_id: @item[:user_id] || 1
|
2015-04-30 15:25:04 +00:00
|
|
|
)
|
2014-08-25 23:58:04 +00:00
|
|
|
end
|
2015-01-03 22:53:07 +00:00
|
|
|
|
2015-01-04 12:52:14 +00:00
|
|
|
def human_changes(user, record)
|
|
|
|
|
2016-04-15 21:56:10 +00:00
|
|
|
return {} if !@item[:changes]
|
2016-02-19 21:05:36 +00:00
|
|
|
locale = user.preferences[:locale] || 'en-us'
|
2015-01-04 12:52:14 +00:00
|
|
|
|
|
|
|
# only show allowed attributes
|
|
|
|
attribute_list = ObjectManager::Attribute.by_object_as_hash('Ticket', user)
|
2015-01-04 15:39:57 +00:00
|
|
|
#puts "AL #{attribute_list.inspect}"
|
2015-01-04 12:52:14 +00:00
|
|
|
user_related_changes = {}
|
2016-04-15 21:56:10 +00:00
|
|
|
@item[:changes].each {|key, value|
|
2015-01-04 15:39:57 +00:00
|
|
|
|
|
|
|
# if no config exists, use all attributes
|
|
|
|
if !attribute_list || attribute_list.empty?
|
|
|
|
user_related_changes[key] = value
|
|
|
|
|
|
|
|
# if config exists, just use existing attributes for user
|
|
|
|
elsif attribute_list[key.to_s]
|
2015-01-04 12:52:14 +00:00
|
|
|
user_related_changes[key] = value
|
|
|
|
end
|
|
|
|
}
|
|
|
|
|
|
|
|
changes = {}
|
|
|
|
user_related_changes.each {|key, value|
|
|
|
|
|
|
|
|
# get attribute name
|
|
|
|
attribute_name = key.to_s
|
|
|
|
object_manager_attribute = attribute_list[attribute_name]
|
2015-04-27 14:53:29 +00:00
|
|
|
if attribute_name[-3, 3] == '_id'
|
2015-04-27 14:41:03 +00:00
|
|
|
attribute_name = attribute_name[ 0, attribute_name.length - 3 ].to_s
|
2015-01-04 12:52:14 +00:00
|
|
|
end
|
2015-02-10 22:48:14 +00:00
|
|
|
|
|
|
|
# add item to changes hash
|
|
|
|
if key.to_s == attribute_name
|
|
|
|
changes[attribute_name] = value
|
2015-01-04 12:52:14 +00:00
|
|
|
end
|
|
|
|
|
2015-02-10 22:48:14 +00:00
|
|
|
# if changed item is an _id field/reference, do an lookup for the realy values
|
|
|
|
value_id = []
|
2015-01-04 12:52:14 +00:00
|
|
|
value_str = [ value[0], value[1] ]
|
2015-04-27 14:53:29 +00:00
|
|
|
if key.to_s[-3, 3] == '_id'
|
2015-01-04 12:52:14 +00:00
|
|
|
value_id[0] = value[0]
|
|
|
|
value_id[1] = value[1]
|
|
|
|
|
2016-03-08 06:32:58 +00:00
|
|
|
if record.respond_to?(attribute_name) && record.send(attribute_name)
|
2015-01-04 12:52:14 +00:00
|
|
|
relation_class = record.send(attribute_name).class
|
|
|
|
if relation_class && value_id[0]
|
2016-03-08 06:32:58 +00:00
|
|
|
relation_model = relation_class.lookup(id: value_id[0])
|
2015-01-04 12:52:14 +00:00
|
|
|
if relation_model
|
|
|
|
if relation_model['name']
|
|
|
|
value_str[0] = relation_model['name']
|
|
|
|
elsif relation_model.respond_to?('fullname')
|
|
|
|
value_str[0] = relation_model.send('fullname')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
if relation_class && value_id[1]
|
2016-03-08 06:32:58 +00:00
|
|
|
relation_model = relation_class.lookup(id: value_id[1])
|
2015-01-04 12:52:14 +00:00
|
|
|
if relation_model
|
|
|
|
if relation_model['name']
|
|
|
|
value_str[1] = relation_model['name']
|
|
|
|
elsif relation_model.respond_to?('fullname')
|
|
|
|
value_str[1] = relation_model.send('fullname')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2015-02-10 22:48:14 +00:00
|
|
|
|
|
|
|
# check if we have an dedcated display name for it
|
2015-01-04 12:52:14 +00:00
|
|
|
display = attribute_name
|
|
|
|
if object_manager_attribute && object_manager_attribute[:display]
|
2015-02-10 22:48:14 +00:00
|
|
|
|
|
|
|
# delete old key
|
2016-03-08 06:32:58 +00:00
|
|
|
changes.delete(display)
|
2015-02-10 22:48:14 +00:00
|
|
|
|
|
|
|
# set new key
|
|
|
|
display = object_manager_attribute[:display].to_s
|
2015-01-04 12:52:14 +00:00
|
|
|
end
|
2016-01-15 17:22:57 +00:00
|
|
|
changes[display] = if object_manager_attribute && object_manager_attribute[:translate]
|
2016-02-19 21:05:36 +00:00
|
|
|
from = Translation.translate(locale, value_str[0])
|
|
|
|
to = Translation.translate(locale, value_str[1])
|
|
|
|
[from, to]
|
2016-01-15 17:22:57 +00:00
|
|
|
else
|
|
|
|
[value_str[0].to_s, value_str[1].to_s]
|
|
|
|
end
|
2015-01-04 12:52:14 +00:00
|
|
|
}
|
|
|
|
changes
|
|
|
|
end
|
|
|
|
|
2015-04-27 14:15:29 +00:00
|
|
|
end
|