debian-mirror-gitlab/app/workers/email_receiver_worker.rb

125 lines
3.8 KiB
Ruby
Raw Normal View History

2018-11-08 19:23:39 +05:30
# frozen_string_literal: true
2020-04-08 14:13:33 +05:30
class EmailReceiverWorker # rubocop:disable Scalability/IdempotentWorker
2018-03-17 18:26:18 +05:30
include ApplicationWorker
2015-09-25 12:07:36 +05:30
2021-10-27 15:23:28 +05:30
data_consistency :always
2021-06-08 01:23:25 +05:30
sidekiq_options retry: 3
2019-12-21 20:55:43 +05:30
feature_category :issue_tracking
2020-04-08 14:13:33 +05:30
urgency :high
2020-03-13 15:44:24 +05:30
weight 2
2019-12-21 20:55:43 +05:30
2021-11-11 11:23:49 +05:30
# https://gitlab.com/gitlab-com/gl-infra/scalability/-/issues/1263
2021-10-27 15:23:28 +05:30
tags :needs_own_queue
2021-06-08 01:23:25 +05:30
attr_accessor :raw
2015-09-25 12:07:36 +05:30
def perform(raw)
2021-06-08 01:23:25 +05:30
return unless should_perform?
2015-09-25 12:07:36 +05:30
2021-06-08 01:23:25 +05:30
@raw = raw
execute_receiver
end
def should_perform?
Gitlab::IncomingEmail.enabled?
2015-09-25 12:07:36 +05:30
end
private
2021-06-08 01:23:25 +05:30
def execute_receiver
receiver.execute
log_success
rescue StandardError => e
log_error(e)
handle_failure(e)
end
def receiver
@receiver ||= Gitlab::Email::Receiver.new(raw)
end
def logger
Sidekiq.logger
end
def log_success
logger.info(build_message('Successfully processed message', receiver.mail_metadata))
end
def log_error(error)
payload =
case error
# Unparsable e-mails don't have metadata we can use
when Gitlab::Email::EmailUnparsableError, Gitlab::Email::EmptyEmailError
{}
else
mail_metadata
end
# We don't need the backtrace and more details if the e-mail couldn't be processed
if error.is_a?(Gitlab::Email::ProcessingError)
payload['exception.class'] = error.class.name
else
Gitlab::ExceptionLogFormatter.format!(error, payload)
Gitlab::ErrorTracking.track_exception(error)
end
logger.error(build_message('Error processing message', payload))
end
def build_message(message, params = {})
{
class: self.class.name,
Labkit::Correlation::CorrelationId::LOG_KEY => Labkit::Correlation::CorrelationId.current_id,
message: message
}.merge(params)
end
def mail_metadata
receiver.mail_metadata
rescue StandardError => e
# We should never get here as long as we check EmailUnparsableError, but
# let's be defensive in case we did something wrong.
Gitlab::ErrorTracking.track_exception(e)
{}
end
2015-09-25 12:07:36 +05:30
2021-06-08 01:23:25 +05:30
def handle_failure(error)
2015-09-25 12:07:36 +05:30
return unless raw.present?
can_retry = false
2016-09-13 17:45:13 +05:30
reason =
2018-11-18 11:00:15 +05:30
case error
2016-09-13 17:45:13 +05:30
when Gitlab::Email::UnknownIncomingEmail
2019-07-31 22:56:46 +05:30
s_("EmailError|We couldn't figure out what the email is for. Please create your issue or comment through the web interface.")
2016-09-13 17:45:13 +05:30
when Gitlab::Email::SentNotificationNotFoundError
2019-07-31 22:56:46 +05:30
s_("EmailError|We couldn't figure out what the email is in reply to. Please create your comment through the web interface.")
2016-09-13 17:45:13 +05:30
when Gitlab::Email::ProjectNotFound
2019-07-31 22:56:46 +05:30
s_("EmailError|We couldn't find the project. Please check if there's any typo.")
2016-09-13 17:45:13 +05:30
when Gitlab::Email::EmptyEmailError
can_retry = true
2019-07-31 22:56:46 +05:30
s_("EmailError|It appears that the email is blank. Make sure your reply is at the top of the email, we can't process inline replies.")
2016-09-13 17:45:13 +05:30
when Gitlab::Email::UserNotFoundError
2019-07-31 22:56:46 +05:30
s_("EmailError|We couldn't figure out what user corresponds to the email. Please create your comment through the web interface.")
2016-09-13 17:45:13 +05:30
when Gitlab::Email::UserBlockedError
2019-07-31 22:56:46 +05:30
s_("EmailError|Your account has been blocked. If you believe this is in error, contact a staff member.")
2016-09-13 17:45:13 +05:30
when Gitlab::Email::UserNotAuthorizedError
2019-07-31 22:56:46 +05:30
s_("EmailError|You are not allowed to perform this action. If you believe this is in error, contact a staff member.")
2016-09-13 17:45:13 +05:30
when Gitlab::Email::NoteableNotFoundError
2019-07-31 22:56:46 +05:30
s_("EmailError|The thread you are replying to no longer exists, perhaps it was deleted? If you believe this is in error, contact a staff member.")
2018-12-13 13:39:08 +05:30
when Gitlab::Email::InvalidAttachment
error.message
2018-03-17 18:26:18 +05:30
when Gitlab::Email::InvalidRecordError
2016-09-13 17:45:13 +05:30
can_retry = true
2018-11-18 11:00:15 +05:30
error.message
2016-09-13 17:45:13 +05:30
end
if reason
EmailRejectionMailer.rejection(reason, raw, can_retry).deliver_later
2015-09-25 12:07:36 +05:30
end
end
end