3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
|
# File 'lib/effective_logging/email_logger.rb', line 3
def self.delivering_email(message)
return if EffectiveLogging.supressed?
return unless message.present?
fields = { from: message.from.join(','), to: message.to, subject: message.subject, cc: message.cc, bcc: message.bcc }
if message.['log'].present?
obj = message.['log'].instance_variable_get(:@unparsed_value)
obj ||= message.['log'].instance_variable_get(:@value)
if obj.kind_of?(ActiveRecord::Base)
fields.merge!(associated: obj)
elsif obj.kind_of?(Hash)
fields.merge!(obj)
else
raise('log expected an ActiveRecord object or Hash')
end
message.['log'] = nil
end
tenant = if message.['tenant'].present?
value = message.['tenant'].to_s.to_sym
message.['tenant'] = nil
value
end || (Tenant.current if defined?(Tenant))
user_klass = "#{tenant.to_s.classify}::User".safe_constantize
body = (message.body.try(:parts) || []).find { |part| part.content_type.to_s.downcase.include?('text/html') }
body ||= message.body
fields[:email] = "#{message.header}<hr>#{body}"
if tenant.present?
Tenant.as(tenant) { log_email(message, fields, user_klass) }
else
log_email(message, fields, user_klass)
end
true
end
|