2015-08-18 18:46:36 -04:00
|
|
|
class EmailReceiverWorker
|
|
|
|
include Sidekiq::Worker
|
|
|
|
|
|
|
|
sidekiq_options queue: :incoming_email
|
|
|
|
|
|
|
|
def perform(raw)
|
2015-09-21 03:46:47 -04:00
|
|
|
return unless Gitlab::IncomingEmail.enabled?
|
2015-08-18 18:46:36 -04:00
|
|
|
|
2015-08-19 14:10:21 -04:00
|
|
|
begin
|
2015-08-20 14:05:06 -04:00
|
|
|
Gitlab::Email::Receiver.new(raw).execute
|
2015-08-19 14:10:21 -04:00
|
|
|
rescue => e
|
|
|
|
handle_failure(raw, e)
|
|
|
|
end
|
2015-08-18 18:46:36 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def handle_failure(raw, e)
|
|
|
|
Rails.logger.warn("Email can not be processed: #{e}\n\n#{raw}")
|
2015-08-19 14:10:21 -04:00
|
|
|
|
2015-08-24 13:57:35 -04:00
|
|
|
return unless raw.present?
|
|
|
|
|
2015-08-19 14:10:21 -04:00
|
|
|
can_retry = false
|
|
|
|
reason = nil
|
|
|
|
|
|
|
|
case e
|
2015-08-20 14:33:18 -04:00
|
|
|
when Gitlab::Email::Receiver::SentNotificationNotFoundError
|
2015-08-19 14:10:21 -04:00
|
|
|
reason = "We couldn't figure out what the email is in reply to. Please create your comment through the web interface."
|
2015-08-20 14:05:06 -04:00
|
|
|
when Gitlab::Email::Receiver::EmptyEmailError
|
2015-08-19 14:10:21 -04:00
|
|
|
can_retry = true
|
|
|
|
reason = "It appears that the email is blank. Make sure your reply is at the top of the email, we can't process inline replies."
|
2015-08-20 14:05:06 -04:00
|
|
|
when Gitlab::Email::Receiver::AutoGeneratedEmailError
|
2015-08-19 14:10:21 -04:00
|
|
|
reason = "The email was marked as 'auto generated', which we can't accept. Please create your comment through the web interface."
|
2015-08-20 14:05:06 -04:00
|
|
|
when Gitlab::Email::Receiver::UserNotFoundError
|
2015-08-19 14:10:21 -04:00
|
|
|
reason = "We couldn't figure out what user corresponds to the email. Please create your comment through the web interface."
|
2015-08-21 13:14:45 -04:00
|
|
|
when Gitlab::Email::Receiver::UserBlockedError
|
|
|
|
reason = "Your account has been blocked. If you believe this is in error, contact a staff member."
|
2015-08-20 14:05:06 -04:00
|
|
|
when Gitlab::Email::Receiver::UserNotAuthorizedError
|
2015-08-19 14:10:21 -04:00
|
|
|
reason = "You are not allowed to respond to the thread you are replying to. If you believe this is in error, contact a staff member."
|
2015-08-20 14:05:06 -04:00
|
|
|
when Gitlab::Email::Receiver::NoteableNotFoundError
|
2015-08-19 14:10:21 -04:00
|
|
|
reason = "The thread you are replying to no longer exists, perhaps it was deleted? If you believe this is in error, contact a staff member."
|
2015-08-20 14:33:18 -04:00
|
|
|
when Gitlab::Email::Receiver::InvalidNoteError
|
2015-08-19 14:10:21 -04:00
|
|
|
can_retry = true
|
|
|
|
reason = e.message
|
|
|
|
else
|
|
|
|
return
|
|
|
|
end
|
|
|
|
|
2015-11-30 09:12:31 -05:00
|
|
|
EmailRejectionMailer.rejection(reason, raw, can_retry).deliver_later
|
2015-08-18 18:46:36 -04:00
|
|
|
end
|
|
|
|
end
|