2018-06-27 07:23:28 +00:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2015-08-18 22:46:36 +00:00
|
|
|
class EmailReceiverWorker
|
2017-11-28 16:08:30 +00:00
|
|
|
include ApplicationWorker
|
2015-08-18 22:46:36 +00:00
|
|
|
|
|
|
|
def perform(raw)
|
2015-09-21 07:46:47 +00:00
|
|
|
return unless Gitlab::IncomingEmail.enabled?
|
2015-08-18 22:46:36 +00:00
|
|
|
|
2015-08-19 18:10:21 +00:00
|
|
|
begin
|
2015-08-20 18:05:06 +00:00
|
|
|
Gitlab::Email::Receiver.new(raw).execute
|
2015-08-19 18:10:21 +00:00
|
|
|
rescue => e
|
|
|
|
handle_failure(raw, e)
|
|
|
|
end
|
2015-08-18 22:46:36 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
2018-07-04 14:02:01 +00:00
|
|
|
def handle_failure(raw, error)
|
2019-07-10 19:26:47 +00:00
|
|
|
Rails.logger.warn("Email can not be processed: #{error}\n\n#{raw}") # rubocop:disable Gitlab/RailsLogger
|
2015-08-19 18:10:21 +00:00
|
|
|
|
2015-08-24 17:57:35 +00:00
|
|
|
return unless raw.present?
|
|
|
|
|
2015-08-19 18:10:21 +00:00
|
|
|
can_retry = false
|
2016-05-24 07:16:16 +00:00
|
|
|
reason =
|
2018-07-04 14:02:01 +00:00
|
|
|
case error
|
2016-05-24 07:16:16 +00:00
|
|
|
when Gitlab::Email::UnknownIncomingEmail
|
2019-04-10 13:30:09 +00:00
|
|
|
s_("EmailError|We couldn't figure out what the email is for. Please create your issue or comment through the web interface.")
|
2016-05-24 07:16:16 +00:00
|
|
|
when Gitlab::Email::SentNotificationNotFoundError
|
2019-04-10 13:30:09 +00:00
|
|
|
s_("EmailError|We couldn't figure out what the email is in reply to. Please create your comment through the web interface.")
|
2016-05-24 07:16:16 +00:00
|
|
|
when Gitlab::Email::ProjectNotFound
|
2019-04-10 13:30:09 +00:00
|
|
|
s_("EmailError|We couldn't find the project. Please check if there's any typo.")
|
2016-05-24 07:16:16 +00:00
|
|
|
when Gitlab::Email::EmptyEmailError
|
|
|
|
can_retry = true
|
2019-04-10 13:30:09 +00:00
|
|
|
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-05-24 07:16:16 +00:00
|
|
|
when Gitlab::Email::UserNotFoundError
|
2019-04-10 13:30:09 +00:00
|
|
|
s_("EmailError|We couldn't figure out what user corresponds to the email. Please create your comment through the web interface.")
|
2016-05-24 07:16:16 +00:00
|
|
|
when Gitlab::Email::UserBlockedError
|
2019-04-10 13:30:09 +00:00
|
|
|
s_("EmailError|Your account has been blocked. If you believe this is in error, contact a staff member.")
|
2016-05-24 07:16:16 +00:00
|
|
|
when Gitlab::Email::UserNotAuthorizedError
|
2019-04-10 13:30:09 +00:00
|
|
|
s_("EmailError|You are not allowed to perform this action. If you believe this is in error, contact a staff member.")
|
2016-05-24 07:16:16 +00:00
|
|
|
when Gitlab::Email::NoteableNotFoundError
|
2019-04-10 13:30:09 +00:00
|
|
|
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-10-24 16:01:44 +00:00
|
|
|
when Gitlab::Email::InvalidAttachment
|
|
|
|
error.message
|
2017-08-24 06:20:36 +00:00
|
|
|
when Gitlab::Email::InvalidRecordError
|
2016-05-24 07:16:16 +00:00
|
|
|
can_retry = true
|
2018-07-04 14:02:01 +00:00
|
|
|
error.message
|
2016-05-24 07:16:16 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
if reason
|
|
|
|
EmailRejectionMailer.rejection(reason, raw, can_retry).deliver_later
|
2015-08-19 18:10:21 +00:00
|
|
|
end
|
2015-08-18 22:46:36 +00:00
|
|
|
end
|
|
|
|
end
|