##// END OF EJS Templates
Fixed STARTTLS option key (#19232)....
Jean-Philippe Lang -
r13665:2800598832d2
parent child
Show More
@@ -1,66 +1,66
1 # Redmine - project management software
1 # Redmine - project management software
2 # Copyright (C) 2006-2015 Jean-Philippe Lang
2 # Copyright (C) 2006-2015 Jean-Philippe Lang
3 #
3 #
4 # This program is free software; you can redistribute it and/or
4 # This program is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU General Public License
5 # modify it under the terms of the GNU General Public License
6 # as published by the Free Software Foundation; either version 2
6 # as published by the Free Software Foundation; either version 2
7 # of the License, or (at your option) any later version.
7 # of the License, or (at your option) any later version.
8 #
8 #
9 # This program is distributed in the hope that it will be useful,
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU General Public License for more details.
12 # GNU General Public License for more details.
13 #
13 #
14 # You should have received a copy of the GNU General Public License
14 # You should have received a copy of the GNU General Public License
15 # along with this program; if not, write to the Free Software
15 # along with this program; if not, write to the Free Software
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17
17
18 require 'net/imap'
18 require 'net/imap'
19
19
20 module Redmine
20 module Redmine
21 module IMAP
21 module IMAP
22 class << self
22 class << self
23 def check(imap_options={}, options={})
23 def check(imap_options={}, options={})
24 host = imap_options[:host] || '127.0.0.1'
24 host = imap_options[:host] || '127.0.0.1'
25 port = imap_options[:port] || '143'
25 port = imap_options[:port] || '143'
26 ssl = !imap_options[:ssl].nil?
26 ssl = !imap_options[:ssl].nil?
27 starttls = !imap_options[:tls].nil?
27 starttls = !imap_options[:starttls].nil?
28 folder = imap_options[:folder] || 'INBOX'
28 folder = imap_options[:folder] || 'INBOX'
29
29
30 imap = Net::IMAP.new(host, port, ssl)
30 imap = Net::IMAP.new(host, port, ssl)
31 if starttls
31 if starttls
32 imap.starttls
32 imap.starttls
33 end
33 end
34 imap.login(imap_options[:username], imap_options[:password]) unless imap_options[:username].nil?
34 imap.login(imap_options[:username], imap_options[:password]) unless imap_options[:username].nil?
35 imap.select(folder)
35 imap.select(folder)
36 imap.uid_search(['NOT', 'SEEN']).each do |uid|
36 imap.uid_search(['NOT', 'SEEN']).each do |uid|
37 msg = imap.uid_fetch(uid,'RFC822')[0].attr['RFC822']
37 msg = imap.uid_fetch(uid,'RFC822')[0].attr['RFC822']
38 logger.debug "Receiving message #{uid}" if logger && logger.debug?
38 logger.debug "Receiving message #{uid}" if logger && logger.debug?
39 if MailHandler.safe_receive(msg, options)
39 if MailHandler.safe_receive(msg, options)
40 logger.debug "Message #{uid} successfully received" if logger && logger.debug?
40 logger.debug "Message #{uid} successfully received" if logger && logger.debug?
41 if imap_options[:move_on_success]
41 if imap_options[:move_on_success]
42 imap.uid_copy(uid, imap_options[:move_on_success])
42 imap.uid_copy(uid, imap_options[:move_on_success])
43 end
43 end
44 imap.uid_store(uid, "+FLAGS", [:Seen, :Deleted])
44 imap.uid_store(uid, "+FLAGS", [:Seen, :Deleted])
45 else
45 else
46 logger.debug "Message #{uid} can not be processed" if logger && logger.debug?
46 logger.debug "Message #{uid} can not be processed" if logger && logger.debug?
47 imap.uid_store(uid, "+FLAGS", [:Seen])
47 imap.uid_store(uid, "+FLAGS", [:Seen])
48 if imap_options[:move_on_failure]
48 if imap_options[:move_on_failure]
49 imap.uid_copy(uid, imap_options[:move_on_failure])
49 imap.uid_copy(uid, imap_options[:move_on_failure])
50 imap.uid_store(uid, "+FLAGS", [:Deleted])
50 imap.uid_store(uid, "+FLAGS", [:Deleted])
51 end
51 end
52 end
52 end
53 end
53 end
54 imap.expunge
54 imap.expunge
55 imap.logout
55 imap.logout
56 imap.disconnect
56 imap.disconnect
57 end
57 end
58
58
59 private
59 private
60
60
61 def logger
61 def logger
62 ::Rails.logger
62 ::Rails.logger
63 end
63 end
64 end
64 end
65 end
65 end
66 end
66 end
General Comments 0
You need to be logged in to leave comments. Login now