|
@@ -11,37 +11,39 @@ module Ticket::Article::AddsMetadataEmail
|
|
|
private
|
|
|
|
|
|
def ticket_article_add_metadata_email
|
|
|
+ return if !neither_importing_nor_postmaster?
|
|
|
+ return if !sender_needs_metadata?
|
|
|
+ return if !type_needs_metadata?
|
|
|
+
|
|
|
+ metadata_email_process_subject
|
|
|
+ metadata_email_process_message_id
|
|
|
+ metadata_email_process_email_address
|
|
|
+ metadata_email_process_from
|
|
|
+ end
|
|
|
|
|
|
- # return if we run import mode
|
|
|
- return true if Setting.get('import_mode')
|
|
|
-
|
|
|
- # only do fill of email from if article got created via application_server (e. g. not
|
|
|
- # if article and sender type is set via *.postmaster)
|
|
|
- return if ApplicationHandleInfo.postmaster?
|
|
|
-
|
|
|
- # if sender is customer, do not change anything
|
|
|
- return true if !sender_id
|
|
|
+ def sender_needs_metadata?
|
|
|
+ return if !sender_id
|
|
|
|
|
|
sender = Ticket::Article::Sender.lookup(id: sender_id)
|
|
|
- return true if sender.nil?
|
|
|
- return true if sender.name == 'Customer'
|
|
|
+ return if sender&.name == 'Customer'
|
|
|
+
|
|
|
+ true
|
|
|
+ end
|
|
|
|
|
|
- # set email attributes
|
|
|
- return true if !type_id
|
|
|
+ def type_needs_metadata?
|
|
|
+ return if !type_id
|
|
|
|
|
|
type = Ticket::Article::Type.lookup(id: type_id)
|
|
|
- return true if type.nil?
|
|
|
- return true if type.name != 'email'
|
|
|
+ return if type&.name != 'email'
|
|
|
|
|
|
- # set subject if empty
|
|
|
- ticket = self.ticket
|
|
|
- if !subject || subject == ''
|
|
|
- self.subject = ticket.title
|
|
|
- end
|
|
|
+ true
|
|
|
+ end
|
|
|
|
|
|
- # clean subject
|
|
|
- self.subject = ticket.subject_clean(subject)
|
|
|
+ def metadata_email_process_subject
|
|
|
+ self.subject = ticket.subject_clean subject.presence || ticket.title
|
|
|
+ end
|
|
|
|
|
|
+ def metadata_email_process_message_id
|
|
|
# generate message id, force it in production, in test allow to set it for testing reasons
|
|
|
if !message_id || Rails.env.production?
|
|
|
fqdn = Setting.get('fqdn')
|
|
@@ -50,33 +52,37 @@ module Ticket::Article::AddsMetadataEmail
|
|
|
|
|
|
# generate message_id_md5
|
|
|
check_message_id_md5
|
|
|
+ end
|
|
|
|
|
|
+ def metadata_email_process_email_address
|
|
|
# set sender
|
|
|
email_address = ticket.group.email_address
|
|
|
+
|
|
|
if !email_address
|
|
|
raise "No email address found for group '#{ticket.group.name}' (#{ticket.group_id})"
|
|
|
end
|
|
|
|
|
|
# remember email address for background job
|
|
|
preferences['email_address_id'] = email_address.id
|
|
|
+ end
|
|
|
|
|
|
- # fill from
|
|
|
- if created_by_id != 1 && Setting.get('ticket_define_email_from') == 'AgentNameSystemAddressName'
|
|
|
- separator = Setting.get('ticket_define_email_from_separator')
|
|
|
- sender = User.find(created_by_id)
|
|
|
- realname = "#{sender.firstname} #{sender.lastname} #{separator} #{email_address.realname}"
|
|
|
- self.from = Channel::EmailBuild.recipient_line(realname, email_address.email)
|
|
|
- elsif Setting.get('ticket_define_email_from') == 'AgentName'
|
|
|
- sender = User.find(created_by_id)
|
|
|
- realname = "#{sender.firstname} #{sender.lastname}"
|
|
|
-
|
|
|
- # avoid "-" as realname, see https://github.com/zammad/zammad/issues/3890
|
|
|
- realname = email_address.realname if sender.id == 1
|
|
|
-
|
|
|
- self.from = Channel::EmailBuild.recipient_line(realname, email_address.email)
|
|
|
- else
|
|
|
- self.from = Channel::EmailBuild.recipient_line(email_address.realname, email_address.email)
|
|
|
+ def recipient_name(email_address)
|
|
|
+ if created_by_id != 1
|
|
|
+ case Setting.get('ticket_define_email_from')
|
|
|
+ when 'AgentNameSystemAddressName'
|
|
|
+ separator = Setting.get('ticket_define_email_from_separator')
|
|
|
+ return "#{created_by.firstname} #{created_by.lastname} #{separator} #{email_address.realname}"
|
|
|
+ when 'AgentName'
|
|
|
+ return "#{created_by.firstname} #{created_by.lastname}"
|
|
|
+ end
|
|
|
end
|
|
|
- true
|
|
|
+
|
|
|
+ email_address.realname
|
|
|
+ end
|
|
|
+
|
|
|
+ def metadata_email_process_from
|
|
|
+ email_address = ticket.group.email_address
|
|
|
+
|
|
|
+ self.from = Channel::EmailBuild.recipient_line(recipient_name(email_address), email_address.email)
|
|
|
end
|
|
|
end
|