author | jgf <jgf> | 2003-12-18 16:02:47 (UTC) |
---|---|---|
committer | jgf <jgf> | 2003-12-18 16:02:47 (UTC) |
commit | 5b88f5d05b2f3f5d106b58b07bc7018f757cfc03 (patch) (unidiff) | |
tree | 27f8a7ccb9dd659ea8484cb12c0e3dc3c3c99252 | |
parent | 5cb08b0c69ffc7216405b552e17ff0541578bda0 (diff) | |
download | opie-5b88f5d05b2f3f5d106b58b07bc7018f757cfc03.zip opie-5b88f5d05b2f3f5d106b58b07bc7018f757cfc03.tar.gz opie-5b88f5d05b2f3f5d106b58b07bc7018f757cfc03.tar.bz2 |
ask for user/password if field is empty
-rw-r--r-- | noncore/net/mail/imapwrapper.cpp | 19 | ||||
-rw-r--r-- | noncore/net/mail/libmailwrapper/imapwrapper.cpp | 19 | ||||
-rw-r--r-- | noncore/net/mail/libmailwrapper/pop3wrapper.cpp | 20 | ||||
-rw-r--r-- | noncore/net/mail/pop3wrapper.cpp | 20 |
4 files changed, 70 insertions, 8 deletions
diff --git a/noncore/net/mail/imapwrapper.cpp b/noncore/net/mail/imapwrapper.cpp index 838300a..cce3d34 100644 --- a/noncore/net/mail/imapwrapper.cpp +++ b/noncore/net/mail/imapwrapper.cpp | |||
@@ -1,104 +1,119 @@ | |||
1 | 1 | ||
2 | #include <stdlib.h> | 2 | #include <stdlib.h> |
3 | 3 | ||
4 | #include "imapwrapper.h" | 4 | #include "imapwrapper.h" |
5 | #include "mailtypes.h" | 5 | #include "mailtypes.h" |
6 | #include "logindialog.h" | ||
6 | #include <libetpan/mailimap.h> | 7 | #include <libetpan/mailimap.h> |
7 | 8 | ||
8 | IMAPwrapper::IMAPwrapper( IMAPaccount *a ) | 9 | IMAPwrapper::IMAPwrapper( IMAPaccount *a ) |
9 | : AbstractMail() | 10 | : AbstractMail() |
10 | { | 11 | { |
11 | account = a; | 12 | account = a; |
12 | m_imap = 0; | 13 | m_imap = 0; |
13 | } | 14 | } |
14 | 15 | ||
15 | IMAPwrapper::~IMAPwrapper() | 16 | IMAPwrapper::~IMAPwrapper() |
16 | { | 17 | { |
17 | logout(); | 18 | logout(); |
18 | } | 19 | } |
19 | 20 | ||
20 | void IMAPwrapper::imap_progress( size_t current, size_t maximum ) | 21 | void IMAPwrapper::imap_progress( size_t current, size_t maximum ) |
21 | { | 22 | { |
22 | qDebug( "IMAP: %i of %i", current, maximum ); | 23 | qDebug( "IMAP: %i of %i", current, maximum ); |
23 | } | 24 | } |
24 | 25 | ||
25 | void IMAPwrapper::login() | 26 | void IMAPwrapper::login() |
26 | { | 27 | { |
27 | const char *server, *user, *pass; | 28 | const char *server, *user, *pass; |
28 | uint16_t port; | 29 | uint16_t port; |
29 | int err = MAILIMAP_NO_ERROR; | 30 | int err = MAILIMAP_NO_ERROR; |
30 | 31 | ||
31 | /* we are connected this moment */ | 32 | /* we are connected this moment */ |
32 | /* TODO: setup a timer holding the line or if connection closed - delete the value */ | 33 | /* TODO: setup a timer holding the line or if connection closed - delete the value */ |
33 | if (m_imap) { | 34 | if (m_imap) { |
34 | mailstream_flush(m_imap->imap_stream); | 35 | mailstream_flush(m_imap->imap_stream); |
35 | return; | 36 | return; |
36 | } | 37 | } |
37 | server = account->getServer().latin1(); | 38 | server = account->getServer().latin1(); |
38 | port = account->getPort().toUInt(); | 39 | port = account->getPort().toUInt(); |
39 | user = account->getUser().latin1(); | 40 | if ( account->getUser().isEmpty() || account->getPassword().isEmpty() ) { |
40 | pass = account->getPassword().latin1(); | 41 | LoginDialog login( account->getUser(), account->getPassword(), NULL, 0, true ); |
42 | login.show(); | ||
43 | if ( QDialog::Accepted == login.exec() ) { | ||
44 | // ok | ||
45 | user = strdup( login.getUser().latin1() ); | ||
46 | pass = strdup( login.getPassword().latin1() ); | ||
47 | } else { | ||
48 | // cancel | ||
49 | qDebug( "IMAP: Login canceled" ); | ||
50 | return; | ||
51 | } | ||
52 | } else { | ||
53 | user = account->getUser().latin1(); | ||
54 | pass = account->getPassword().latin1(); | ||
55 | } | ||
41 | 56 | ||
42 | m_imap = mailimap_new( 20, &imap_progress ); | 57 | m_imap = mailimap_new( 20, &imap_progress ); |
43 | /* connect */ | 58 | /* connect */ |
44 | if (account->getSSL()) { | 59 | if (account->getSSL()) { |
45 | err = mailimap_ssl_connect( m_imap, (char*)server, port ); | 60 | err = mailimap_ssl_connect( m_imap, (char*)server, port ); |
46 | } else { | 61 | } else { |
47 | err = mailimap_socket_connect( m_imap, (char*)server, port ); | 62 | err = mailimap_socket_connect( m_imap, (char*)server, port ); |
48 | } | 63 | } |
49 | 64 | ||
50 | if ( err != MAILIMAP_NO_ERROR && | 65 | if ( err != MAILIMAP_NO_ERROR && |
51 | err != MAILIMAP_NO_ERROR_AUTHENTICATED && | 66 | err != MAILIMAP_NO_ERROR_AUTHENTICATED && |
52 | err != MAILIMAP_NO_ERROR_NON_AUTHENTICATED ) { | 67 | err != MAILIMAP_NO_ERROR_NON_AUTHENTICATED ) { |
53 | qDebug("error connecting server: %s",m_imap->imap_response); | 68 | qDebug("error connecting server: %s",m_imap->imap_response); |
54 | mailimap_free( m_imap ); | 69 | mailimap_free( m_imap ); |
55 | m_imap = 0; | 70 | m_imap = 0; |
56 | return; | 71 | return; |
57 | } | 72 | } |
58 | 73 | ||
59 | /* login */ | 74 | /* login */ |
60 | err = mailimap_login_simple( m_imap, (char*)user, (char*)pass ); | 75 | err = mailimap_login_simple( m_imap, (char*)user, (char*)pass ); |
61 | if ( err != MAILIMAP_NO_ERROR ) { | 76 | if ( err != MAILIMAP_NO_ERROR ) { |
62 | qDebug("error logging in imap: %s",m_imap->imap_response); | 77 | qDebug("error logging in imap: %s",m_imap->imap_response); |
63 | err = mailimap_close( m_imap ); | 78 | err = mailimap_close( m_imap ); |
64 | mailimap_free( m_imap ); | 79 | mailimap_free( m_imap ); |
65 | m_imap = 0; | 80 | m_imap = 0; |
66 | } | 81 | } |
67 | } | 82 | } |
68 | 83 | ||
69 | void IMAPwrapper::logout() | 84 | void IMAPwrapper::logout() |
70 | { | 85 | { |
71 | int err = MAILIMAP_NO_ERROR; | 86 | int err = MAILIMAP_NO_ERROR; |
72 | if (!m_imap) return; | 87 | if (!m_imap) return; |
73 | err = mailimap_logout( m_imap ); | 88 | err = mailimap_logout( m_imap ); |
74 | err = mailimap_close( m_imap ); | 89 | err = mailimap_close( m_imap ); |
75 | mailimap_free( m_imap ); | 90 | mailimap_free( m_imap ); |
76 | m_imap = 0; | 91 | m_imap = 0; |
77 | } | 92 | } |
78 | 93 | ||
79 | void IMAPwrapper::listMessages(const QString&mailbox,QList<RecMail> &target ) | 94 | void IMAPwrapper::listMessages(const QString&mailbox,QList<RecMail> &target ) |
80 | { | 95 | { |
81 | const char *mb; | 96 | const char *mb; |
82 | int err = MAILIMAP_NO_ERROR; | 97 | int err = MAILIMAP_NO_ERROR; |
83 | clist *result; | 98 | clist *result; |
84 | clistcell *current; | 99 | clistcell *current; |
85 | // mailimap_fetch_att *fetchAtt,*fetchAttFlags,*fetchAttDate,*fetchAttSize; | 100 | // mailimap_fetch_att *fetchAtt,*fetchAttFlags,*fetchAttDate,*fetchAttSize; |
86 | mailimap_fetch_type *fetchType; | 101 | mailimap_fetch_type *fetchType; |
87 | mailimap_set *set; | 102 | mailimap_set *set; |
88 | 103 | ||
89 | mb = mailbox.latin1(); | 104 | mb = mailbox.latin1(); |
90 | login(); | 105 | login(); |
91 | if (!m_imap) { | 106 | if (!m_imap) { |
92 | return; | 107 | return; |
93 | } | 108 | } |
94 | /* select mailbox READONLY for operations */ | 109 | /* select mailbox READONLY for operations */ |
95 | err = mailimap_examine( m_imap, (char*)mb); | 110 | err = mailimap_examine( m_imap, (char*)mb); |
96 | if ( err != MAILIMAP_NO_ERROR ) { | 111 | if ( err != MAILIMAP_NO_ERROR ) { |
97 | qDebug("error selecting mailbox: %s",m_imap->imap_response); | 112 | qDebug("error selecting mailbox: %s",m_imap->imap_response); |
98 | return; | 113 | return; |
99 | } | 114 | } |
100 | 115 | ||
101 | int last = m_imap->imap_selection_info->sel_exists; | 116 | int last = m_imap->imap_selection_info->sel_exists; |
102 | 117 | ||
103 | if (last == 0) { | 118 | if (last == 0) { |
104 | qDebug("mailbox has no mails"); | 119 | qDebug("mailbox has no mails"); |
diff --git a/noncore/net/mail/libmailwrapper/imapwrapper.cpp b/noncore/net/mail/libmailwrapper/imapwrapper.cpp index 838300a..cce3d34 100644 --- a/noncore/net/mail/libmailwrapper/imapwrapper.cpp +++ b/noncore/net/mail/libmailwrapper/imapwrapper.cpp | |||
@@ -1,104 +1,119 @@ | |||
1 | 1 | ||
2 | #include <stdlib.h> | 2 | #include <stdlib.h> |
3 | 3 | ||
4 | #include "imapwrapper.h" | 4 | #include "imapwrapper.h" |
5 | #include "mailtypes.h" | 5 | #include "mailtypes.h" |
6 | #include "logindialog.h" | ||
6 | #include <libetpan/mailimap.h> | 7 | #include <libetpan/mailimap.h> |
7 | 8 | ||
8 | IMAPwrapper::IMAPwrapper( IMAPaccount *a ) | 9 | IMAPwrapper::IMAPwrapper( IMAPaccount *a ) |
9 | : AbstractMail() | 10 | : AbstractMail() |
10 | { | 11 | { |
11 | account = a; | 12 | account = a; |
12 | m_imap = 0; | 13 | m_imap = 0; |
13 | } | 14 | } |
14 | 15 | ||
15 | IMAPwrapper::~IMAPwrapper() | 16 | IMAPwrapper::~IMAPwrapper() |
16 | { | 17 | { |
17 | logout(); | 18 | logout(); |
18 | } | 19 | } |
19 | 20 | ||
20 | void IMAPwrapper::imap_progress( size_t current, size_t maximum ) | 21 | void IMAPwrapper::imap_progress( size_t current, size_t maximum ) |
21 | { | 22 | { |
22 | qDebug( "IMAP: %i of %i", current, maximum ); | 23 | qDebug( "IMAP: %i of %i", current, maximum ); |
23 | } | 24 | } |
24 | 25 | ||
25 | void IMAPwrapper::login() | 26 | void IMAPwrapper::login() |
26 | { | 27 | { |
27 | const char *server, *user, *pass; | 28 | const char *server, *user, *pass; |
28 | uint16_t port; | 29 | uint16_t port; |
29 | int err = MAILIMAP_NO_ERROR; | 30 | int err = MAILIMAP_NO_ERROR; |
30 | 31 | ||
31 | /* we are connected this moment */ | 32 | /* we are connected this moment */ |
32 | /* TODO: setup a timer holding the line or if connection closed - delete the value */ | 33 | /* TODO: setup a timer holding the line or if connection closed - delete the value */ |
33 | if (m_imap) { | 34 | if (m_imap) { |
34 | mailstream_flush(m_imap->imap_stream); | 35 | mailstream_flush(m_imap->imap_stream); |
35 | return; | 36 | return; |
36 | } | 37 | } |
37 | server = account->getServer().latin1(); | 38 | server = account->getServer().latin1(); |
38 | port = account->getPort().toUInt(); | 39 | port = account->getPort().toUInt(); |
39 | user = account->getUser().latin1(); | 40 | if ( account->getUser().isEmpty() || account->getPassword().isEmpty() ) { |
40 | pass = account->getPassword().latin1(); | 41 | LoginDialog login( account->getUser(), account->getPassword(), NULL, 0, true ); |
42 | login.show(); | ||
43 | if ( QDialog::Accepted == login.exec() ) { | ||
44 | // ok | ||
45 | user = strdup( login.getUser().latin1() ); | ||
46 | pass = strdup( login.getPassword().latin1() ); | ||
47 | } else { | ||
48 | // cancel | ||
49 | qDebug( "IMAP: Login canceled" ); | ||
50 | return; | ||
51 | } | ||
52 | } else { | ||
53 | user = account->getUser().latin1(); | ||
54 | pass = account->getPassword().latin1(); | ||
55 | } | ||
41 | 56 | ||
42 | m_imap = mailimap_new( 20, &imap_progress ); | 57 | m_imap = mailimap_new( 20, &imap_progress ); |
43 | /* connect */ | 58 | /* connect */ |
44 | if (account->getSSL()) { | 59 | if (account->getSSL()) { |
45 | err = mailimap_ssl_connect( m_imap, (char*)server, port ); | 60 | err = mailimap_ssl_connect( m_imap, (char*)server, port ); |
46 | } else { | 61 | } else { |
47 | err = mailimap_socket_connect( m_imap, (char*)server, port ); | 62 | err = mailimap_socket_connect( m_imap, (char*)server, port ); |
48 | } | 63 | } |
49 | 64 | ||
50 | if ( err != MAILIMAP_NO_ERROR && | 65 | if ( err != MAILIMAP_NO_ERROR && |
51 | err != MAILIMAP_NO_ERROR_AUTHENTICATED && | 66 | err != MAILIMAP_NO_ERROR_AUTHENTICATED && |
52 | err != MAILIMAP_NO_ERROR_NON_AUTHENTICATED ) { | 67 | err != MAILIMAP_NO_ERROR_NON_AUTHENTICATED ) { |
53 | qDebug("error connecting server: %s",m_imap->imap_response); | 68 | qDebug("error connecting server: %s",m_imap->imap_response); |
54 | mailimap_free( m_imap ); | 69 | mailimap_free( m_imap ); |
55 | m_imap = 0; | 70 | m_imap = 0; |
56 | return; | 71 | return; |
57 | } | 72 | } |
58 | 73 | ||
59 | /* login */ | 74 | /* login */ |
60 | err = mailimap_login_simple( m_imap, (char*)user, (char*)pass ); | 75 | err = mailimap_login_simple( m_imap, (char*)user, (char*)pass ); |
61 | if ( err != MAILIMAP_NO_ERROR ) { | 76 | if ( err != MAILIMAP_NO_ERROR ) { |
62 | qDebug("error logging in imap: %s",m_imap->imap_response); | 77 | qDebug("error logging in imap: %s",m_imap->imap_response); |
63 | err = mailimap_close( m_imap ); | 78 | err = mailimap_close( m_imap ); |
64 | mailimap_free( m_imap ); | 79 | mailimap_free( m_imap ); |
65 | m_imap = 0; | 80 | m_imap = 0; |
66 | } | 81 | } |
67 | } | 82 | } |
68 | 83 | ||
69 | void IMAPwrapper::logout() | 84 | void IMAPwrapper::logout() |
70 | { | 85 | { |
71 | int err = MAILIMAP_NO_ERROR; | 86 | int err = MAILIMAP_NO_ERROR; |
72 | if (!m_imap) return; | 87 | if (!m_imap) return; |
73 | err = mailimap_logout( m_imap ); | 88 | err = mailimap_logout( m_imap ); |
74 | err = mailimap_close( m_imap ); | 89 | err = mailimap_close( m_imap ); |
75 | mailimap_free( m_imap ); | 90 | mailimap_free( m_imap ); |
76 | m_imap = 0; | 91 | m_imap = 0; |
77 | } | 92 | } |
78 | 93 | ||
79 | void IMAPwrapper::listMessages(const QString&mailbox,QList<RecMail> &target ) | 94 | void IMAPwrapper::listMessages(const QString&mailbox,QList<RecMail> &target ) |
80 | { | 95 | { |
81 | const char *mb; | 96 | const char *mb; |
82 | int err = MAILIMAP_NO_ERROR; | 97 | int err = MAILIMAP_NO_ERROR; |
83 | clist *result; | 98 | clist *result; |
84 | clistcell *current; | 99 | clistcell *current; |
85 | // mailimap_fetch_att *fetchAtt,*fetchAttFlags,*fetchAttDate,*fetchAttSize; | 100 | // mailimap_fetch_att *fetchAtt,*fetchAttFlags,*fetchAttDate,*fetchAttSize; |
86 | mailimap_fetch_type *fetchType; | 101 | mailimap_fetch_type *fetchType; |
87 | mailimap_set *set; | 102 | mailimap_set *set; |
88 | 103 | ||
89 | mb = mailbox.latin1(); | 104 | mb = mailbox.latin1(); |
90 | login(); | 105 | login(); |
91 | if (!m_imap) { | 106 | if (!m_imap) { |
92 | return; | 107 | return; |
93 | } | 108 | } |
94 | /* select mailbox READONLY for operations */ | 109 | /* select mailbox READONLY for operations */ |
95 | err = mailimap_examine( m_imap, (char*)mb); | 110 | err = mailimap_examine( m_imap, (char*)mb); |
96 | if ( err != MAILIMAP_NO_ERROR ) { | 111 | if ( err != MAILIMAP_NO_ERROR ) { |
97 | qDebug("error selecting mailbox: %s",m_imap->imap_response); | 112 | qDebug("error selecting mailbox: %s",m_imap->imap_response); |
98 | return; | 113 | return; |
99 | } | 114 | } |
100 | 115 | ||
101 | int last = m_imap->imap_selection_info->sel_exists; | 116 | int last = m_imap->imap_selection_info->sel_exists; |
102 | 117 | ||
103 | if (last == 0) { | 118 | if (last == 0) { |
104 | qDebug("mailbox has no mails"); | 119 | qDebug("mailbox has no mails"); |
diff --git a/noncore/net/mail/libmailwrapper/pop3wrapper.cpp b/noncore/net/mail/libmailwrapper/pop3wrapper.cpp index 22a4c70..b0b985c 100644 --- a/noncore/net/mail/libmailwrapper/pop3wrapper.cpp +++ b/noncore/net/mail/libmailwrapper/pop3wrapper.cpp | |||
@@ -1,67 +1,68 @@ | |||
1 | #include <stdlib.h> | 1 | #include <stdlib.h> |
2 | #include "pop3wrapper.h" | 2 | #include "pop3wrapper.h" |
3 | #include "mailtypes.h" | 3 | #include "mailtypes.h" |
4 | #include "logindialog.h" | ||
4 | #include <libetpan/mailpop3.h> | 5 | #include <libetpan/mailpop3.h> |
5 | #include <libetpan/mailmime.h> | 6 | #include <libetpan/mailmime.h> |
6 | #include <libetpan/data_message_driver.h> | 7 | #include <libetpan/data_message_driver.h> |
7 | #include <qfile.h> | 8 | #include <qfile.h> |
8 | 9 | ||
9 | /* we don't fetch messages larger than 5 MB */ | 10 | /* we don't fetch messages larger than 5 MB */ |
10 | #define HARD_MSG_SIZE_LIMIT 5242880 | 11 | #define HARD_MSG_SIZE_LIMIT 5242880 |
11 | 12 | ||
12 | POP3wrapper::POP3wrapper( POP3account *a ) | 13 | POP3wrapper::POP3wrapper( POP3account *a ) |
13 | { | 14 | { |
14 | account = a; | 15 | account = a; |
15 | m_pop3 = NULL; | 16 | m_pop3 = NULL; |
16 | msgTempName = a->getFileName()+"_msg_cache"; | 17 | msgTempName = a->getFileName()+"_msg_cache"; |
17 | last_msg_id = 0; | 18 | last_msg_id = 0; |
18 | } | 19 | } |
19 | 20 | ||
20 | POP3wrapper::~POP3wrapper() | 21 | POP3wrapper::~POP3wrapper() |
21 | { | 22 | { |
22 | logout(); | 23 | logout(); |
23 | QFile msg_cache(msgTempName); | 24 | QFile msg_cache(msgTempName); |
24 | if (msg_cache.exists()) { | 25 | if (msg_cache.exists()) { |
25 | msg_cache.remove(); | 26 | msg_cache.remove(); |
26 | } | 27 | } |
27 | } | 28 | } |
28 | 29 | ||
29 | void POP3wrapper::pop3_progress( size_t current, size_t maximum ) | 30 | void POP3wrapper::pop3_progress( size_t current, size_t maximum ) |
30 | { | 31 | { |
31 | //qDebug( "POP3: %i of %i", current, maximum ); | 32 | //qDebug( "POP3: %i of %i", current, maximum ); |
32 | } | 33 | } |
33 | 34 | ||
34 | RecBody POP3wrapper::fetchBody( const RecMail &mail ) | 35 | RecBody POP3wrapper::fetchBody( const RecMail &mail ) |
35 | { | 36 | { |
36 | int err = MAILPOP3_NO_ERROR; | 37 | int err = MAILPOP3_NO_ERROR; |
37 | char *message; | 38 | char *message; |
38 | size_t length = 0; | 39 | size_t length = 0; |
39 | 40 | ||
40 | login(); | 41 | login(); |
41 | if ( !m_pop3 ) { | 42 | if ( !m_pop3 ) { |
42 | return RecBody(); | 43 | return RecBody(); |
43 | } | 44 | } |
44 | 45 | ||
45 | RecBody body; | 46 | RecBody body; |
46 | 47 | ||
47 | QFile msg_cache(msgTempName); | 48 | QFile msg_cache(msgTempName); |
48 | 49 | ||
49 | if (mail.Msgsize()>HARD_MSG_SIZE_LIMIT) { | 50 | if (mail.Msgsize()>HARD_MSG_SIZE_LIMIT) { |
50 | qDebug("Message to large: %i",mail.Msgsize()); | 51 | qDebug("Message to large: %i",mail.Msgsize()); |
51 | return body; | 52 | return body; |
52 | } | 53 | } |
53 | if (mail.getNumber()!=last_msg_id) { | 54 | if (mail.getNumber()!=last_msg_id) { |
54 | if (msg_cache.exists()) { | 55 | if (msg_cache.exists()) { |
55 | msg_cache.remove(); | 56 | msg_cache.remove(); |
56 | } | 57 | } |
57 | msg_cache.open(IO_ReadWrite|IO_Truncate); | 58 | msg_cache.open(IO_ReadWrite|IO_Truncate); |
58 | last_msg_id = mail.getNumber(); | 59 | last_msg_id = mail.getNumber(); |
59 | err = mailpop3_retr( m_pop3, mail.getNumber(), &message, &length ); | 60 | err = mailpop3_retr( m_pop3, mail.getNumber(), &message, &length ); |
60 | if ( err != MAILPOP3_NO_ERROR ) { | 61 | if ( err != MAILPOP3_NO_ERROR ) { |
61 | qDebug( "POP3: error retrieving body with index %i", mail.getNumber() ); | 62 | qDebug( "POP3: error retrieving body with index %i", mail.getNumber() ); |
62 | last_msg_id = 0; | 63 | last_msg_id = 0; |
63 | return RecBody(); | 64 | return RecBody(); |
64 | } | 65 | } |
65 | msg_cache.writeBlock(message,length); | 66 | msg_cache.writeBlock(message,length); |
66 | } else { | 67 | } else { |
67 | QString msg=""; | 68 | QString msg=""; |
@@ -296,130 +297,145 @@ QString POP3wrapper::parseAddressList( mailimf_address_list *list ) | |||
296 | 297 | ||
297 | QString POP3wrapper::parseGroup( mailimf_group *group ) | 298 | QString POP3wrapper::parseGroup( mailimf_group *group ) |
298 | { | 299 | { |
299 | QString result( "" ); | 300 | QString result( "" ); |
300 | 301 | ||
301 | result.append( group->grp_display_name ); | 302 | result.append( group->grp_display_name ); |
302 | result.append( ": " ); | 303 | result.append( ": " ); |
303 | 304 | ||
304 | if ( group->grp_mb_list != NULL ) { | 305 | if ( group->grp_mb_list != NULL ) { |
305 | result.append( parseMailboxList( group->grp_mb_list ) ); | 306 | result.append( parseMailboxList( group->grp_mb_list ) ); |
306 | } | 307 | } |
307 | 308 | ||
308 | result.append( ";" ); | 309 | result.append( ";" ); |
309 | 310 | ||
310 | return result; | 311 | return result; |
311 | } | 312 | } |
312 | 313 | ||
313 | QString POP3wrapper::parseMailbox( mailimf_mailbox *box ) | 314 | QString POP3wrapper::parseMailbox( mailimf_mailbox *box ) |
314 | { | 315 | { |
315 | QString result( "" ); | 316 | QString result( "" ); |
316 | 317 | ||
317 | if ( box->mb_display_name == NULL ) { | 318 | if ( box->mb_display_name == NULL ) { |
318 | result.append( box->mb_addr_spec ); | 319 | result.append( box->mb_addr_spec ); |
319 | } else { | 320 | } else { |
320 | result.append( convert_String(box->mb_display_name).latin1() ); | 321 | result.append( convert_String(box->mb_display_name).latin1() ); |
321 | result.append( " <" ); | 322 | result.append( " <" ); |
322 | result.append( box->mb_addr_spec ); | 323 | result.append( box->mb_addr_spec ); |
323 | result.append( ">" ); | 324 | result.append( ">" ); |
324 | } | 325 | } |
325 | 326 | ||
326 | return result; | 327 | return result; |
327 | } | 328 | } |
328 | 329 | ||
329 | QString POP3wrapper::parseMailboxList( mailimf_mailbox_list *list ) | 330 | QString POP3wrapper::parseMailboxList( mailimf_mailbox_list *list ) |
330 | { | 331 | { |
331 | QString result( "" ); | 332 | QString result( "" ); |
332 | 333 | ||
333 | bool first = true; | 334 | bool first = true; |
334 | for ( clistiter *current = clist_begin( list->mb_list ); current != NULL; current = current->next ) { | 335 | for ( clistiter *current = clist_begin( list->mb_list ); current != NULL; current = current->next ) { |
335 | mailimf_mailbox *box = (mailimf_mailbox *) current->data; | 336 | mailimf_mailbox *box = (mailimf_mailbox *) current->data; |
336 | 337 | ||
337 | if ( !first ) { | 338 | if ( !first ) { |
338 | result.append( "," ); | 339 | result.append( "," ); |
339 | } else { | 340 | } else { |
340 | first = false; | 341 | first = false; |
341 | } | 342 | } |
342 | 343 | ||
343 | result.append( parseMailbox( box ) ); | 344 | result.append( parseMailbox( box ) ); |
344 | } | 345 | } |
345 | 346 | ||
346 | return result; | 347 | return result; |
347 | } | 348 | } |
348 | 349 | ||
349 | void POP3wrapper::login() | 350 | void POP3wrapper::login() |
350 | { | 351 | { |
351 | /* we'll hold the line */ | 352 | /* we'll hold the line */ |
352 | if ( m_pop3 != NULL ) return; | 353 | if ( m_pop3 != NULL ) return; |
353 | 354 | ||
354 | const char *server, *user, *pass; | 355 | const char *server, *user, *pass; |
355 | uint16_t port; | 356 | uint16_t port; |
356 | int err = MAILPOP3_NO_ERROR; | 357 | int err = MAILPOP3_NO_ERROR; |
357 | 358 | ||
358 | server = account->getServer().latin1(); | 359 | server = account->getServer().latin1(); |
359 | port = account->getPort().toUInt(); | 360 | port = account->getPort().toUInt(); |
360 | user = account->getUser().latin1(); | 361 | |
361 | pass = account->getPassword().latin1(); | 362 | if ( account->getUser().isEmpty() || account->getPassword().isEmpty() ) { |
363 | LoginDialog login( account->getUser(), account->getPassword(), NULL, 0, true ); | ||
364 | login.show(); | ||
365 | if ( QDialog::Accepted == login.exec() ) { | ||
366 | // ok | ||
367 | user = strdup( login.getUser().latin1() ); | ||
368 | pass = strdup( login.getPassword().latin1() ); | ||
369 | } else { | ||
370 | // cancel | ||
371 | qDebug( "POP3: Login canceled" ); | ||
372 | return; | ||
373 | } | ||
374 | } else { | ||
375 | user = account->getUser().latin1(); | ||
376 | pass = account->getPassword().latin1(); | ||
377 | } | ||
362 | 378 | ||
363 | m_pop3 = mailpop3_new( 200, &pop3_progress ); | 379 | m_pop3 = mailpop3_new( 200, &pop3_progress ); |
364 | 380 | ||
365 | // connect | 381 | // connect |
366 | if (account->getSSL()) { | 382 | if (account->getSSL()) { |
367 | err = mailpop3_ssl_connect( m_pop3, (char*)server, port ); | 383 | err = mailpop3_ssl_connect( m_pop3, (char*)server, port ); |
368 | } else { | 384 | } else { |
369 | err = mailpop3_socket_connect( m_pop3, (char*)server, port ); | 385 | err = mailpop3_socket_connect( m_pop3, (char*)server, port ); |
370 | } | 386 | } |
371 | 387 | ||
372 | if ( err != MAILPOP3_NO_ERROR ) { | 388 | if ( err != MAILPOP3_NO_ERROR ) { |
373 | qDebug( "pop3: error connecting to %s\n reason: %s", server, | 389 | qDebug( "pop3: error connecting to %s\n reason: %s", server, |
374 | m_pop3->pop3_response ); | 390 | m_pop3->pop3_response ); |
375 | mailpop3_free( m_pop3 ); | 391 | mailpop3_free( m_pop3 ); |
376 | m_pop3 = NULL; | 392 | m_pop3 = NULL; |
377 | return; | 393 | return; |
378 | } | 394 | } |
379 | qDebug( "POP3: connected!" ); | 395 | qDebug( "POP3: connected!" ); |
380 | 396 | ||
381 | // login | 397 | // login |
382 | // TODO: decide if apop or plain login should be used | 398 | // TODO: decide if apop or plain login should be used |
383 | err = mailpop3_login( m_pop3, (char *) user, (char *) pass ); | 399 | err = mailpop3_login( m_pop3, (char *) user, (char *) pass ); |
384 | if ( err != MAILPOP3_NO_ERROR ) { | 400 | if ( err != MAILPOP3_NO_ERROR ) { |
385 | qDebug( "pop3: error logging in: %s", m_pop3->pop3_response ); | 401 | qDebug( "pop3: error logging in: %s", m_pop3->pop3_response ); |
386 | logout(); | 402 | logout(); |
387 | return; | 403 | return; |
388 | } | 404 | } |
389 | 405 | ||
390 | qDebug( "POP3: logged in!" ); | 406 | qDebug( "POP3: logged in!" ); |
391 | } | 407 | } |
392 | 408 | ||
393 | void POP3wrapper::logout() | 409 | void POP3wrapper::logout() |
394 | { | 410 | { |
395 | int err = MAILPOP3_NO_ERROR; | 411 | int err = MAILPOP3_NO_ERROR; |
396 | if ( m_pop3 == NULL ) return; | 412 | if ( m_pop3 == NULL ) return; |
397 | err = mailpop3_quit( m_pop3 ); | 413 | err = mailpop3_quit( m_pop3 ); |
398 | mailpop3_free( m_pop3 ); | 414 | mailpop3_free( m_pop3 ); |
399 | m_pop3 = NULL; | 415 | m_pop3 = NULL; |
400 | } | 416 | } |
401 | 417 | ||
402 | 418 | ||
403 | QList<Folder>* POP3wrapper::listFolders() | 419 | QList<Folder>* POP3wrapper::listFolders() |
404 | { | 420 | { |
405 | /* TODO: integrate MH directories | 421 | /* TODO: integrate MH directories |
406 | but not before version 0.1 ;) | 422 | but not before version 0.1 ;) |
407 | */ | 423 | */ |
408 | QList<Folder> * folders = new QList<Folder>(); | 424 | QList<Folder> * folders = new QList<Folder>(); |
409 | folders->setAutoDelete( false ); | 425 | folders->setAutoDelete( false ); |
410 | Folder*inb=new Folder("INBOX","/"); | 426 | Folder*inb=new Folder("INBOX","/"); |
411 | folders->append(inb); | 427 | folders->append(inb); |
412 | return folders; | 428 | return folders; |
413 | } | 429 | } |
414 | 430 | ||
415 | QString POP3wrapper::fetchTextPart(const RecMail&,const RecPart&) | 431 | QString POP3wrapper::fetchTextPart(const RecMail&,const RecPart&) |
416 | { | 432 | { |
417 | return ""; | 433 | return ""; |
418 | } | 434 | } |
419 | 435 | ||
420 | void POP3wrapper::deleteMail(const RecMail&mail) | 436 | void POP3wrapper::deleteMail(const RecMail&mail) |
421 | { | 437 | { |
422 | login(); | 438 | login(); |
423 | if (!m_pop3) return; | 439 | if (!m_pop3) return; |
424 | int err = mailpop3_dele(m_pop3,mail.getNumber()); | 440 | int err = mailpop3_dele(m_pop3,mail.getNumber()); |
425 | if (err != MAILPOP3_NO_ERROR) { | 441 | if (err != MAILPOP3_NO_ERROR) { |
diff --git a/noncore/net/mail/pop3wrapper.cpp b/noncore/net/mail/pop3wrapper.cpp index 22a4c70..b0b985c 100644 --- a/noncore/net/mail/pop3wrapper.cpp +++ b/noncore/net/mail/pop3wrapper.cpp | |||
@@ -1,67 +1,68 @@ | |||
1 | #include <stdlib.h> | 1 | #include <stdlib.h> |
2 | #include "pop3wrapper.h" | 2 | #include "pop3wrapper.h" |
3 | #include "mailtypes.h" | 3 | #include "mailtypes.h" |
4 | #include "logindialog.h" | ||
4 | #include <libetpan/mailpop3.h> | 5 | #include <libetpan/mailpop3.h> |
5 | #include <libetpan/mailmime.h> | 6 | #include <libetpan/mailmime.h> |
6 | #include <libetpan/data_message_driver.h> | 7 | #include <libetpan/data_message_driver.h> |
7 | #include <qfile.h> | 8 | #include <qfile.h> |
8 | 9 | ||
9 | /* we don't fetch messages larger than 5 MB */ | 10 | /* we don't fetch messages larger than 5 MB */ |
10 | #define HARD_MSG_SIZE_LIMIT 5242880 | 11 | #define HARD_MSG_SIZE_LIMIT 5242880 |
11 | 12 | ||
12 | POP3wrapper::POP3wrapper( POP3account *a ) | 13 | POP3wrapper::POP3wrapper( POP3account *a ) |
13 | { | 14 | { |
14 | account = a; | 15 | account = a; |
15 | m_pop3 = NULL; | 16 | m_pop3 = NULL; |
16 | msgTempName = a->getFileName()+"_msg_cache"; | 17 | msgTempName = a->getFileName()+"_msg_cache"; |
17 | last_msg_id = 0; | 18 | last_msg_id = 0; |
18 | } | 19 | } |
19 | 20 | ||
20 | POP3wrapper::~POP3wrapper() | 21 | POP3wrapper::~POP3wrapper() |
21 | { | 22 | { |
22 | logout(); | 23 | logout(); |
23 | QFile msg_cache(msgTempName); | 24 | QFile msg_cache(msgTempName); |
24 | if (msg_cache.exists()) { | 25 | if (msg_cache.exists()) { |
25 | msg_cache.remove(); | 26 | msg_cache.remove(); |
26 | } | 27 | } |
27 | } | 28 | } |
28 | 29 | ||
29 | void POP3wrapper::pop3_progress( size_t current, size_t maximum ) | 30 | void POP3wrapper::pop3_progress( size_t current, size_t maximum ) |
30 | { | 31 | { |
31 | //qDebug( "POP3: %i of %i", current, maximum ); | 32 | //qDebug( "POP3: %i of %i", current, maximum ); |
32 | } | 33 | } |
33 | 34 | ||
34 | RecBody POP3wrapper::fetchBody( const RecMail &mail ) | 35 | RecBody POP3wrapper::fetchBody( const RecMail &mail ) |
35 | { | 36 | { |
36 | int err = MAILPOP3_NO_ERROR; | 37 | int err = MAILPOP3_NO_ERROR; |
37 | char *message; | 38 | char *message; |
38 | size_t length = 0; | 39 | size_t length = 0; |
39 | 40 | ||
40 | login(); | 41 | login(); |
41 | if ( !m_pop3 ) { | 42 | if ( !m_pop3 ) { |
42 | return RecBody(); | 43 | return RecBody(); |
43 | } | 44 | } |
44 | 45 | ||
45 | RecBody body; | 46 | RecBody body; |
46 | 47 | ||
47 | QFile msg_cache(msgTempName); | 48 | QFile msg_cache(msgTempName); |
48 | 49 | ||
49 | if (mail.Msgsize()>HARD_MSG_SIZE_LIMIT) { | 50 | if (mail.Msgsize()>HARD_MSG_SIZE_LIMIT) { |
50 | qDebug("Message to large: %i",mail.Msgsize()); | 51 | qDebug("Message to large: %i",mail.Msgsize()); |
51 | return body; | 52 | return body; |
52 | } | 53 | } |
53 | if (mail.getNumber()!=last_msg_id) { | 54 | if (mail.getNumber()!=last_msg_id) { |
54 | if (msg_cache.exists()) { | 55 | if (msg_cache.exists()) { |
55 | msg_cache.remove(); | 56 | msg_cache.remove(); |
56 | } | 57 | } |
57 | msg_cache.open(IO_ReadWrite|IO_Truncate); | 58 | msg_cache.open(IO_ReadWrite|IO_Truncate); |
58 | last_msg_id = mail.getNumber(); | 59 | last_msg_id = mail.getNumber(); |
59 | err = mailpop3_retr( m_pop3, mail.getNumber(), &message, &length ); | 60 | err = mailpop3_retr( m_pop3, mail.getNumber(), &message, &length ); |
60 | if ( err != MAILPOP3_NO_ERROR ) { | 61 | if ( err != MAILPOP3_NO_ERROR ) { |
61 | qDebug( "POP3: error retrieving body with index %i", mail.getNumber() ); | 62 | qDebug( "POP3: error retrieving body with index %i", mail.getNumber() ); |
62 | last_msg_id = 0; | 63 | last_msg_id = 0; |
63 | return RecBody(); | 64 | return RecBody(); |
64 | } | 65 | } |
65 | msg_cache.writeBlock(message,length); | 66 | msg_cache.writeBlock(message,length); |
66 | } else { | 67 | } else { |
67 | QString msg=""; | 68 | QString msg=""; |
@@ -296,130 +297,145 @@ QString POP3wrapper::parseAddressList( mailimf_address_list *list ) | |||
296 | 297 | ||
297 | QString POP3wrapper::parseGroup( mailimf_group *group ) | 298 | QString POP3wrapper::parseGroup( mailimf_group *group ) |
298 | { | 299 | { |
299 | QString result( "" ); | 300 | QString result( "" ); |
300 | 301 | ||
301 | result.append( group->grp_display_name ); | 302 | result.append( group->grp_display_name ); |
302 | result.append( ": " ); | 303 | result.append( ": " ); |
303 | 304 | ||
304 | if ( group->grp_mb_list != NULL ) { | 305 | if ( group->grp_mb_list != NULL ) { |
305 | result.append( parseMailboxList( group->grp_mb_list ) ); | 306 | result.append( parseMailboxList( group->grp_mb_list ) ); |
306 | } | 307 | } |
307 | 308 | ||
308 | result.append( ";" ); | 309 | result.append( ";" ); |
309 | 310 | ||
310 | return result; | 311 | return result; |
311 | } | 312 | } |
312 | 313 | ||
313 | QString POP3wrapper::parseMailbox( mailimf_mailbox *box ) | 314 | QString POP3wrapper::parseMailbox( mailimf_mailbox *box ) |
314 | { | 315 | { |
315 | QString result( "" ); | 316 | QString result( "" ); |
316 | 317 | ||
317 | if ( box->mb_display_name == NULL ) { | 318 | if ( box->mb_display_name == NULL ) { |
318 | result.append( box->mb_addr_spec ); | 319 | result.append( box->mb_addr_spec ); |
319 | } else { | 320 | } else { |
320 | result.append( convert_String(box->mb_display_name).latin1() ); | 321 | result.append( convert_String(box->mb_display_name).latin1() ); |
321 | result.append( " <" ); | 322 | result.append( " <" ); |
322 | result.append( box->mb_addr_spec ); | 323 | result.append( box->mb_addr_spec ); |
323 | result.append( ">" ); | 324 | result.append( ">" ); |
324 | } | 325 | } |
325 | 326 | ||
326 | return result; | 327 | return result; |
327 | } | 328 | } |
328 | 329 | ||
329 | QString POP3wrapper::parseMailboxList( mailimf_mailbox_list *list ) | 330 | QString POP3wrapper::parseMailboxList( mailimf_mailbox_list *list ) |
330 | { | 331 | { |
331 | QString result( "" ); | 332 | QString result( "" ); |
332 | 333 | ||
333 | bool first = true; | 334 | bool first = true; |
334 | for ( clistiter *current = clist_begin( list->mb_list ); current != NULL; current = current->next ) { | 335 | for ( clistiter *current = clist_begin( list->mb_list ); current != NULL; current = current->next ) { |
335 | mailimf_mailbox *box = (mailimf_mailbox *) current->data; | 336 | mailimf_mailbox *box = (mailimf_mailbox *) current->data; |
336 | 337 | ||
337 | if ( !first ) { | 338 | if ( !first ) { |
338 | result.append( "," ); | 339 | result.append( "," ); |
339 | } else { | 340 | } else { |
340 | first = false; | 341 | first = false; |
341 | } | 342 | } |
342 | 343 | ||
343 | result.append( parseMailbox( box ) ); | 344 | result.append( parseMailbox( box ) ); |
344 | } | 345 | } |
345 | 346 | ||
346 | return result; | 347 | return result; |
347 | } | 348 | } |
348 | 349 | ||
349 | void POP3wrapper::login() | 350 | void POP3wrapper::login() |
350 | { | 351 | { |
351 | /* we'll hold the line */ | 352 | /* we'll hold the line */ |
352 | if ( m_pop3 != NULL ) return; | 353 | if ( m_pop3 != NULL ) return; |
353 | 354 | ||
354 | const char *server, *user, *pass; | 355 | const char *server, *user, *pass; |
355 | uint16_t port; | 356 | uint16_t port; |
356 | int err = MAILPOP3_NO_ERROR; | 357 | int err = MAILPOP3_NO_ERROR; |
357 | 358 | ||
358 | server = account->getServer().latin1(); | 359 | server = account->getServer().latin1(); |
359 | port = account->getPort().toUInt(); | 360 | port = account->getPort().toUInt(); |
360 | user = account->getUser().latin1(); | 361 | |
361 | pass = account->getPassword().latin1(); | 362 | if ( account->getUser().isEmpty() || account->getPassword().isEmpty() ) { |
363 | LoginDialog login( account->getUser(), account->getPassword(), NULL, 0, true ); | ||
364 | login.show(); | ||
365 | if ( QDialog::Accepted == login.exec() ) { | ||
366 | // ok | ||
367 | user = strdup( login.getUser().latin1() ); | ||
368 | pass = strdup( login.getPassword().latin1() ); | ||
369 | } else { | ||
370 | // cancel | ||
371 | qDebug( "POP3: Login canceled" ); | ||
372 | return; | ||
373 | } | ||
374 | } else { | ||
375 | user = account->getUser().latin1(); | ||
376 | pass = account->getPassword().latin1(); | ||
377 | } | ||
362 | 378 | ||
363 | m_pop3 = mailpop3_new( 200, &pop3_progress ); | 379 | m_pop3 = mailpop3_new( 200, &pop3_progress ); |
364 | 380 | ||
365 | // connect | 381 | // connect |
366 | if (account->getSSL()) { | 382 | if (account->getSSL()) { |
367 | err = mailpop3_ssl_connect( m_pop3, (char*)server, port ); | 383 | err = mailpop3_ssl_connect( m_pop3, (char*)server, port ); |
368 | } else { | 384 | } else { |
369 | err = mailpop3_socket_connect( m_pop3, (char*)server, port ); | 385 | err = mailpop3_socket_connect( m_pop3, (char*)server, port ); |
370 | } | 386 | } |
371 | 387 | ||
372 | if ( err != MAILPOP3_NO_ERROR ) { | 388 | if ( err != MAILPOP3_NO_ERROR ) { |
373 | qDebug( "pop3: error connecting to %s\n reason: %s", server, | 389 | qDebug( "pop3: error connecting to %s\n reason: %s", server, |
374 | m_pop3->pop3_response ); | 390 | m_pop3->pop3_response ); |
375 | mailpop3_free( m_pop3 ); | 391 | mailpop3_free( m_pop3 ); |
376 | m_pop3 = NULL; | 392 | m_pop3 = NULL; |
377 | return; | 393 | return; |
378 | } | 394 | } |
379 | qDebug( "POP3: connected!" ); | 395 | qDebug( "POP3: connected!" ); |
380 | 396 | ||
381 | // login | 397 | // login |
382 | // TODO: decide if apop or plain login should be used | 398 | // TODO: decide if apop or plain login should be used |
383 | err = mailpop3_login( m_pop3, (char *) user, (char *) pass ); | 399 | err = mailpop3_login( m_pop3, (char *) user, (char *) pass ); |
384 | if ( err != MAILPOP3_NO_ERROR ) { | 400 | if ( err != MAILPOP3_NO_ERROR ) { |
385 | qDebug( "pop3: error logging in: %s", m_pop3->pop3_response ); | 401 | qDebug( "pop3: error logging in: %s", m_pop3->pop3_response ); |
386 | logout(); | 402 | logout(); |
387 | return; | 403 | return; |
388 | } | 404 | } |
389 | 405 | ||
390 | qDebug( "POP3: logged in!" ); | 406 | qDebug( "POP3: logged in!" ); |
391 | } | 407 | } |
392 | 408 | ||
393 | void POP3wrapper::logout() | 409 | void POP3wrapper::logout() |
394 | { | 410 | { |
395 | int err = MAILPOP3_NO_ERROR; | 411 | int err = MAILPOP3_NO_ERROR; |
396 | if ( m_pop3 == NULL ) return; | 412 | if ( m_pop3 == NULL ) return; |
397 | err = mailpop3_quit( m_pop3 ); | 413 | err = mailpop3_quit( m_pop3 ); |
398 | mailpop3_free( m_pop3 ); | 414 | mailpop3_free( m_pop3 ); |
399 | m_pop3 = NULL; | 415 | m_pop3 = NULL; |
400 | } | 416 | } |
401 | 417 | ||
402 | 418 | ||
403 | QList<Folder>* POP3wrapper::listFolders() | 419 | QList<Folder>* POP3wrapper::listFolders() |
404 | { | 420 | { |
405 | /* TODO: integrate MH directories | 421 | /* TODO: integrate MH directories |
406 | but not before version 0.1 ;) | 422 | but not before version 0.1 ;) |
407 | */ | 423 | */ |
408 | QList<Folder> * folders = new QList<Folder>(); | 424 | QList<Folder> * folders = new QList<Folder>(); |
409 | folders->setAutoDelete( false ); | 425 | folders->setAutoDelete( false ); |
410 | Folder*inb=new Folder("INBOX","/"); | 426 | Folder*inb=new Folder("INBOX","/"); |
411 | folders->append(inb); | 427 | folders->append(inb); |
412 | return folders; | 428 | return folders; |
413 | } | 429 | } |
414 | 430 | ||
415 | QString POP3wrapper::fetchTextPart(const RecMail&,const RecPart&) | 431 | QString POP3wrapper::fetchTextPart(const RecMail&,const RecPart&) |
416 | { | 432 | { |
417 | return ""; | 433 | return ""; |
418 | } | 434 | } |
419 | 435 | ||
420 | void POP3wrapper::deleteMail(const RecMail&mail) | 436 | void POP3wrapper::deleteMail(const RecMail&mail) |
421 | { | 437 | { |
422 | login(); | 438 | login(); |
423 | if (!m_pop3) return; | 439 | if (!m_pop3) return; |
424 | int err = mailpop3_dele(m_pop3,mail.getNumber()); | 440 | int err = mailpop3_dele(m_pop3,mail.getNumber()); |
425 | if (err != MAILPOP3_NO_ERROR) { | 441 | if (err != MAILPOP3_NO_ERROR) { |