2013-06-13 18:11:10 -04:00
|
|
|
#
|
|
|
|
# Connects to a mailbox and checks for replies
|
|
|
|
#
|
|
|
|
require 'net/pop'
|
|
|
|
require_dependency 'email/receiver'
|
2014-02-24 00:01:37 -06:00
|
|
|
require_dependency 'email/sender'
|
|
|
|
require_dependency 'email/message_builder'
|
2013-06-13 18:11:10 -04:00
|
|
|
|
|
|
|
module Jobs
|
2013-08-07 19:25:05 +02:00
|
|
|
class PollMailbox < Jobs::Scheduled
|
2014-06-21 15:57:49 +08:00
|
|
|
every SiteSetting.pop3s_polling_period_mins.minutes
|
2013-06-13 18:11:10 -04:00
|
|
|
sidekiq_options retry: false
|
2014-02-24 00:01:37 -06:00
|
|
|
include Email::BuildEmailHelper
|
2013-06-13 18:11:10 -04:00
|
|
|
|
|
|
|
def execute(args)
|
|
|
|
if SiteSetting.pop3s_polling_enabled?
|
|
|
|
poll_pop3s
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2014-02-28 13:05:09 +01:00
|
|
|
def handle_mail(mail)
|
|
|
|
begin
|
2014-03-07 11:28:55 -05:00
|
|
|
mail_string = mail.pop
|
|
|
|
Email::Receiver.new(mail_string).process
|
2014-06-23 17:16:56 -07:00
|
|
|
rescue => e
|
|
|
|
message_template = nil
|
|
|
|
case e
|
|
|
|
when Email::Receiver::UserNotSufficientTrustLevelError
|
|
|
|
message_template = :email_reject_trust_level
|
|
|
|
when Email::Receiver::UserNotFoundError
|
|
|
|
message_template = :email_reject_no_account
|
|
|
|
when Email::Receiver::EmptyEmailError
|
|
|
|
message_template = :email_reject_empty
|
|
|
|
when Email::Receiver::EmailUnparsableError
|
|
|
|
message_template = :email_reject_parsing
|
2014-06-23 17:46:22 -07:00
|
|
|
when Email::Receiver::EmailLogNotFound
|
|
|
|
message_template = :email_reject_reply_key
|
2014-06-23 17:16:56 -07:00
|
|
|
when ActiveRecord::Rollback
|
|
|
|
message_template = :email_reject_post_error
|
|
|
|
else
|
2014-06-23 17:48:51 -07:00
|
|
|
message_template = nil
|
2014-06-23 17:16:56 -07:00
|
|
|
end
|
2014-06-22 15:04:24 -07:00
|
|
|
|
2014-06-23 17:16:56 -07:00
|
|
|
if message_template
|
2014-06-25 17:01:23 -07:00
|
|
|
# inform the user about the rejection
|
|
|
|
message = Mail::Message.new(mail_string)
|
2014-06-27 12:03:07 -07:00
|
|
|
client_message = RejectionMailer.send_rejection(message.from, message.body, message.to, message_template)
|
2014-06-23 17:16:56 -07:00
|
|
|
Email::Sender.new(client_message, message_template).send
|
|
|
|
else
|
2014-06-30 15:17:05 -07:00
|
|
|
Discourse.handle_exception(e, { code: "unknown error for incoming email", mail: mail_string} )
|
2014-06-23 17:16:56 -07:00
|
|
|
end
|
2014-02-28 13:05:09 +01:00
|
|
|
ensure
|
|
|
|
mail.delete
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-06-13 18:11:10 -04:00
|
|
|
def poll_pop3s
|
2014-06-02 20:59:10 +08:00
|
|
|
if !SiteSetting.pop3s_polling_insecure
|
|
|
|
Net::POP3.enable_ssl(OpenSSL::SSL::VERIFY_NONE)
|
|
|
|
end
|
2013-06-13 18:11:10 -04:00
|
|
|
Net::POP3.start(SiteSetting.pop3s_polling_host,
|
|
|
|
SiteSetting.pop3s_polling_port,
|
|
|
|
SiteSetting.pop3s_polling_username,
|
|
|
|
SiteSetting.pop3s_polling_password) do |pop|
|
|
|
|
unless pop.mails.empty?
|
|
|
|
pop.each do |mail|
|
2014-03-07 11:28:55 -05:00
|
|
|
handle_mail(mail)
|
2013-06-13 18:11:10 -04:00
|
|
|
end
|
|
|
|
end
|
2014-04-14 22:55:57 +02:00
|
|
|
pop.finish
|
2013-06-13 18:11:10 -04:00
|
|
|
end
|
2014-04-09 19:26:19 +02:00
|
|
|
rescue Net::POPAuthenticationError => e
|
2014-06-30 15:17:05 -07:00
|
|
|
Discourse.handle_exception(e, { code: "signing in for incoming email" } )
|
2013-06-13 18:11:10 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
end
|