Module: Redmine::POP3

Defined in:
lib/redmine/pop3.rb

Class Method Summary (collapse)

Class Method Details

+ (Object) check(pop_options = {}, options = {})



23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
# File 'lib/redmine/pop3.rb', line 23

def check(pop_options={}, options={})
  host = pop_options[:host] || '127.0.0.1'
  port = pop_options[:port] || '110'
  apop = (pop_options[:apop].to_s == '1')
  delete_unprocessed = (pop_options[:delete_unprocessed].to_s == '1')

  pop = Net::POP3.APOP(apop).new(host,port)
  logger.debug "Connecting to #{host}..." if logger && logger.debug?
  pop.start(pop_options[:username], pop_options[:password]) do |pop_session|
    if pop_session.mails.empty?
      logger.debug "No email to process" if logger && logger.debug?
    else
      logger.debug "#{pop_session.mails.size} email(s) to process..." if logger && logger.debug?
      pop_session.each_mail do |msg|
        message = msg.pop
        message_id = (message =~ /^Message-ID: (.*)/ ? $1 : '').strip
        if MailHandler.receive(message, options)
          msg.delete
          logger.debug "--> Message #{message_id} processed and deleted from the server" if logger && logger.debug?
        else
          if delete_unprocessed
            msg.delete
            logger.debug "--> Message #{message_id} NOT processed and deleted from the server" if logger && logger.debug?
          else
            logger.debug "--> Message #{message_id} NOT processed and left on the server" if logger && logger.debug?
          end
        end
      end
    end
  end
end