add slightly more logs when skipping email notifications

This commit is contained in:
Régis Hanol 2016-02-15 17:53:07 +01:00
parent 2af587005b
commit 4ad5660615
2 changed files with 23 additions and 23 deletions

View File

@ -6,19 +6,20 @@ module Jobs
class UserEmail < Jobs::Base class UserEmail < Jobs::Base
def execute(args) def execute(args)
notification, post = nil
raise Discourse::InvalidParameters.new(:user_id) unless args[:user_id].present? raise Discourse::InvalidParameters.new(:user_id) unless args[:user_id].present?
raise Discourse::InvalidParameters.new(:type) unless args[:type].present? raise Discourse::InvalidParameters.new(:type) unless args[:type].present?
post = nil
notification = nil
type = args[:type] type = args[:type]
user = User.find_by(id: args[:user_id]) user = User.find_by(id: args[:user_id])
to_address = args[:to_address].presence || user.try(:email).presence || "no_email_found"
set_skip_context(type, args[:user_id], to_address)
set_skip_context(type, args[:user_id], args[:to_address].presence || user.try(:email).presence || "no_email_found")
return skip(I18n.t("email_log.no_user", user_id: args[:user_id])) unless user return skip(I18n.t("email_log.no_user", user_id: args[:user_id])) unless user
if args[:post_id] if args[:post_id].present?
post = Post.find_by(id: args[:post_id]) post = Post.find_by(id: args[:post_id])
return skip(I18n.t('email_log.post_not_found', post_id: args[:post_id])) unless post.present? return skip(I18n.t('email_log.post_not_found', post_id: args[:post_id])) unless post.present?
end end
@ -27,18 +28,17 @@ module Jobs
notification = Notification.find_by(id: args[:notification_id]) notification = Notification.find_by(id: args[:notification_id])
end end
message, skip_reason = message_for_email( user, message, skip_reason = message_for_email(user,
post, post,
type, type,
notification, notification,
args[:notification_type], args[:notification_type],
args[:notification_data_hash], args[:notification_data_hash],
args[:email_token], args[:email_token],
args[:to_address] ) args[:to_address])
if message if message
Email::Sender.new(message, args[:type], user).send Email::Sender.new(message, type, user).send
else else
skip_reason skip_reason
end end
@ -51,8 +51,8 @@ module Jobs
NOTIFICATIONS_SENT_BY_MAILING_LIST ||= Set.new %w{posted replied mentioned group_mentioned quoted} NOTIFICATIONS_SENT_BY_MAILING_LIST ||= Set.new %w{posted replied mentioned group_mentioned quoted}
def message_for_email(user, post, type, notification, def message_for_email(user, post, type, notification,
notification_type=nil, notification_data_hash=nil, notification_type=nil, notification_data_hash=nil,
email_token=nil, to_address=nil) email_token=nil, to_address=nil)
set_skip_context(type, user.id, to_address || user.email) set_skip_context(type, user.id, to_address || user.email)
@ -75,7 +75,7 @@ module Jobs
end end
if notification || notification_type if notification || notification_type
email_args[:notification_type] ||= notification_type || notification.try(:notification_type) email_args[:notification_type] ||= notification_type || notification.try(:notification_type)
email_args[:notification_data_hash] ||= notification_data_hash || notification.try(:data_hash) email_args[:notification_data_hash] ||= notification_data_hash || notification.try(:data_hash)
unless String === email_args[:notification_type] unless String === email_args[:notification_type]
@ -113,7 +113,7 @@ module Jobs
# Update the to address if we have a custom one # Update the to address if we have a custom one
if message && to_address.present? if message && to_address.present?
message.to = [to_address] message.to = to_address
end end
[message, nil] [message, nil]
@ -143,7 +143,7 @@ module Jobs
to_address: @skip_context[:to_address], to_address: @skip_context[:to_address],
user_id: @skip_context[:user_id], user_id: @skip_context[:user_id],
skipped: true, skipped: true,
skipped_reason: reason, skipped_reason: "[UserEmail] #{reason}",
) )
end end

View File

@ -23,7 +23,7 @@ module Email
def send def send
return if SiteSetting.disable_emails return if SiteSetting.disable_emails
return skip(I18n.t('email_log.message_blank')) if @message.blank? return skip(I18n.t('email_log.message_blank')) if @message.blank?
return skip(I18n.t('email_log.message_to_blank')) if @message.to.blank? return skip(I18n.t('email_log.message_to_blank')) if @message.to.blank?
if @message.text_part if @message.text_part
@ -135,7 +135,7 @@ module Email
def to_address def to_address
@to_address ||= begin @to_address ||= begin
to = @message ? @message.to : nil to = @message.try(:to)
to = to.first if Array === to to = to.first if Array === to
to.presence || "no_email_found" to.presence || "no_email_found"
end end
@ -167,7 +167,7 @@ module Email
to_address: to_address, to_address: to_address,
user_id: @user.try(:id), user_id: @user.try(:id),
skipped: true, skipped: true,
skipped_reason: reason skipped_reason: "[Sender] #{reason}"
) )
end end