summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/mail/libmailwrapper/pop3wrapper.cpp41
-rw-r--r--noncore/net/mail/libmailwrapper/pop3wrapper.h1
-rw-r--r--noncore/net/mail/pop3wrapper.cpp41
-rw-r--r--noncore/net/mail/pop3wrapper.h1
4 files changed, 76 insertions, 8 deletions
diff --git a/noncore/net/mail/libmailwrapper/pop3wrapper.cpp b/noncore/net/mail/libmailwrapper/pop3wrapper.cpp
index 08e97f4..6decb6a 100644
--- a/noncore/net/mail/libmailwrapper/pop3wrapper.cpp
+++ b/noncore/net/mail/libmailwrapper/pop3wrapper.cpp
@@ -6,6 +6,7 @@
6POP3wrapper::POP3wrapper( POP3account *a ) 6POP3wrapper::POP3wrapper( POP3account *a )
7{ 7{
8 account = a; 8 account = a;
9 m_pop3 = NULL;
9} 10}
10 11
11POP3wrapper::~POP3wrapper() 12POP3wrapper::~POP3wrapper()
@@ -20,14 +21,46 @@ void POP3wrapper::pop3_progress( size_t current, size_t maximum )
20 21
21void POP3wrapper::listMessages( QList<RecMail> &target ) 22void POP3wrapper::listMessages( QList<RecMail> &target )
22{ 23{
24 int err = MAILPOP3_NO_ERROR;
25 char *header;
26 size_t length;
27 carray *messages;
28
23 login(); 29 login();
24 //TODO: list messages 30 mailpop3_list( m_pop3, &messages );
31
32 for ( int i = carray_count( messages ); i > 0; i-- ) {
33 mailpop3_msg_info *info = (mailpop3_msg_info *) carray_get( messages, i - 1 );
34
35 err = mailpop3_header( m_pop3, info->index, &header, &length );
36 if ( err != MAILPOP3_NO_ERROR ) {
37 qDebug( "POP3: error retrieving header msgid: %i", info->index );
38 logout();
39 return;
40 }
41 RecMail *mail = parseHeader( header );
42 mail->setNumber( info->index );
43 target.append( mail );
44 }
45
25 logout(); 46 logout();
26} 47}
27 48
49RecMail *POP3wrapper::parseHeader( const char *h )
50{
51 RecMail *mail = new RecMail();
52 QString header( h );
53
54 //TODO: parse header - maybe something like this is already implemented in libetpan?
55 mail->setSubject( "Blah blubb" );
56
57 return mail;
58}
59
28void POP3wrapper::login() 60void POP3wrapper::login()
29{ 61{
30 logout(); 62 if ( m_pop3 != NULL ) logout();
63
31 const char *server, *user, *pass; 64 const char *server, *user, *pass;
32 uint16_t port; 65 uint16_t port;
33 int err = MAILPOP3_NO_ERROR; 66 int err = MAILPOP3_NO_ERROR;
@@ -37,7 +70,7 @@ void POP3wrapper::login()
37 user = account->getUser().latin1(); 70 user = account->getUser().latin1();
38 pass = account->getPassword().latin1(); 71 pass = account->getPassword().latin1();
39 72
40 m_pop3 = mailpop3_new( 20, &pop3_progress ); 73 m_pop3 = mailpop3_new( 200, &pop3_progress );
41 74
42 // connect 75 // connect
43 err = mailpop3_socket_connect( m_pop3, (char *) server, port ); 76 err = mailpop3_socket_connect( m_pop3, (char *) server, port );
@@ -65,7 +98,7 @@ void POP3wrapper::login()
65void POP3wrapper::logout() 98void POP3wrapper::logout()
66{ 99{
67 int err = MAILPOP3_NO_ERROR; 100 int err = MAILPOP3_NO_ERROR;
68 if ( !m_pop3 ) return; 101 if ( m_pop3 == NULL ) return;
69 err = mailpop3_quit( m_pop3 ); 102 err = mailpop3_quit( m_pop3 );
70 mailpop3_free( m_pop3 ); 103 mailpop3_free( m_pop3 );
71 m_pop3 = NULL; 104 m_pop3 = NULL;
diff --git a/noncore/net/mail/libmailwrapper/pop3wrapper.h b/noncore/net/mail/libmailwrapper/pop3wrapper.h
index b791409..f242746 100644
--- a/noncore/net/mail/libmailwrapper/pop3wrapper.h
+++ b/noncore/net/mail/libmailwrapper/pop3wrapper.h
@@ -20,6 +20,7 @@ protected:
20 void logout(); 20 void logout();
21 21
22private: 22private:
23 RecMail *parseHeader( const char *header );
23 POP3account *account; 24 POP3account *account;
24 mailpop3 *m_pop3; 25 mailpop3 *m_pop3;
25 26
diff --git a/noncore/net/mail/pop3wrapper.cpp b/noncore/net/mail/pop3wrapper.cpp
index 08e97f4..6decb6a 100644
--- a/noncore/net/mail/pop3wrapper.cpp
+++ b/noncore/net/mail/pop3wrapper.cpp
@@ -6,6 +6,7 @@
6POP3wrapper::POP3wrapper( POP3account *a ) 6POP3wrapper::POP3wrapper( POP3account *a )
7{ 7{
8 account = a; 8 account = a;
9 m_pop3 = NULL;
9} 10}
10 11
11POP3wrapper::~POP3wrapper() 12POP3wrapper::~POP3wrapper()
@@ -20,14 +21,46 @@ void POP3wrapper::pop3_progress( size_t current, size_t maximum )
20 21
21void POP3wrapper::listMessages( QList<RecMail> &target ) 22void POP3wrapper::listMessages( QList<RecMail> &target )
22{ 23{
24 int err = MAILPOP3_NO_ERROR;
25 char *header;
26 size_t length;
27 carray *messages;
28
23 login(); 29 login();
24 //TODO: list messages 30 mailpop3_list( m_pop3, &messages );
31
32 for ( int i = carray_count( messages ); i > 0; i-- ) {
33 mailpop3_msg_info *info = (mailpop3_msg_info *) carray_get( messages, i - 1 );
34
35 err = mailpop3_header( m_pop3, info->index, &header, &length );
36 if ( err != MAILPOP3_NO_ERROR ) {
37 qDebug( "POP3: error retrieving header msgid: %i", info->index );
38 logout();
39 return;
40 }
41 RecMail *mail = parseHeader( header );
42 mail->setNumber( info->index );
43 target.append( mail );
44 }
45
25 logout(); 46 logout();
26} 47}
27 48
49RecMail *POP3wrapper::parseHeader( const char *h )
50{
51 RecMail *mail = new RecMail();
52 QString header( h );
53
54 //TODO: parse header - maybe something like this is already implemented in libetpan?
55 mail->setSubject( "Blah blubb" );
56
57 return mail;
58}
59
28void POP3wrapper::login() 60void POP3wrapper::login()
29{ 61{
30 logout(); 62 if ( m_pop3 != NULL ) logout();
63
31 const char *server, *user, *pass; 64 const char *server, *user, *pass;
32 uint16_t port; 65 uint16_t port;
33 int err = MAILPOP3_NO_ERROR; 66 int err = MAILPOP3_NO_ERROR;
@@ -37,7 +70,7 @@ void POP3wrapper::login()
37 user = account->getUser().latin1(); 70 user = account->getUser().latin1();
38 pass = account->getPassword().latin1(); 71 pass = account->getPassword().latin1();
39 72
40 m_pop3 = mailpop3_new( 20, &pop3_progress ); 73 m_pop3 = mailpop3_new( 200, &pop3_progress );
41 74
42 // connect 75 // connect
43 err = mailpop3_socket_connect( m_pop3, (char *) server, port ); 76 err = mailpop3_socket_connect( m_pop3, (char *) server, port );
@@ -65,7 +98,7 @@ void POP3wrapper::login()
65void POP3wrapper::logout() 98void POP3wrapper::logout()
66{ 99{
67 int err = MAILPOP3_NO_ERROR; 100 int err = MAILPOP3_NO_ERROR;
68 if ( !m_pop3 ) return; 101 if ( m_pop3 == NULL ) return;
69 err = mailpop3_quit( m_pop3 ); 102 err = mailpop3_quit( m_pop3 );
70 mailpop3_free( m_pop3 ); 103 mailpop3_free( m_pop3 );
71 m_pop3 = NULL; 104 m_pop3 = NULL;
diff --git a/noncore/net/mail/pop3wrapper.h b/noncore/net/mail/pop3wrapper.h
index b791409..f242746 100644
--- a/noncore/net/mail/pop3wrapper.h
+++ b/noncore/net/mail/pop3wrapper.h
@@ -20,6 +20,7 @@ protected:
20 void logout(); 20 void logout();
21 21
22private: 22private:
23 RecMail *parseHeader( const char *header );
23 POP3account *account; 24 POP3account *account;
24 mailpop3 *m_pop3; 25 mailpop3 *m_pop3;
25 26