52 lines
1.7 KiB
Ruby
52 lines
1.7 KiB
Ruby
require 'net/imap'
|
|
|
|
class Inboxes::FetchImapEmailsJob < ApplicationJob
|
|
queue_as :low
|
|
|
|
def perform(channel)
|
|
return unless should_fetch_email?(channel)
|
|
|
|
fetch_mail_for_channel(channel)
|
|
# clearing old failures like timeouts since the mail is now successfully processed
|
|
channel.reauthorized!
|
|
rescue Errno::ECONNREFUSED, Net::OpenTimeout, Net::IMAP::NoResponseError
|
|
channel.authorization_error!
|
|
rescue StandardError => e
|
|
ChatwootExceptionTracker.new(e, account: channel.account).capture_exception
|
|
end
|
|
|
|
private
|
|
|
|
def should_fetch_email?(channel)
|
|
channel.imap_enabled? && !channel.reauthorization_required?
|
|
end
|
|
|
|
def fetch_mail_for_channel(channel)
|
|
# TODO: rather than setting this as default method for all mail objects, lets if can do new mail object
|
|
# using Mail.retriever_method.new(params)
|
|
Mail.defaults do
|
|
retriever_method :imap, address: channel.imap_address,
|
|
port: channel.imap_port,
|
|
user_name: channel.imap_login,
|
|
password: channel.imap_password,
|
|
enable_ssl: channel.imap_enable_ssl
|
|
end
|
|
|
|
new_mails = false
|
|
|
|
Mail.find(what: :last, count: 10, order: :desc).each do |inbound_mail|
|
|
next unless inbound_mail.date.utc >= channel.imap_inbox_synced_at
|
|
|
|
process_mail(inbound_mail, channel)
|
|
new_mails = true
|
|
end
|
|
|
|
channel.update(imap_inbox_synced_at: Time.now.utc) if new_mails
|
|
end
|
|
|
|
def process_mail(inbound_mail, channel)
|
|
Imap::ImapMailbox.new.process(inbound_mail, channel)
|
|
rescue StandardError => e
|
|
ChatwootExceptionTracker.new(e, account: channel.account).capture_exception
|
|
end
|
|
end
|