From 434db5193380185cc1b6347ff5882ad558f401d4 Mon Sep 17 00:00:00 2001 From: jgf Date: Wed, 10 Dec 2003 08:59:11 +0000 Subject: retrieve headers from mailbox --- 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 @@ POP3wrapper::POP3wrapper( POP3account *a ) { account = a; + m_pop3 = NULL; } POP3wrapper::~POP3wrapper() @@ -20,14 +21,46 @@ void POP3wrapper::pop3_progress( size_t current, size_t maximum ) void POP3wrapper::listMessages( QList &target ) { + int err = MAILPOP3_NO_ERROR; + char *header; + size_t length; + carray *messages; + login(); - //TODO: list messages + mailpop3_list( m_pop3, &messages ); + + for ( int i = carray_count( messages ); i > 0; i-- ) { + mailpop3_msg_info *info = (mailpop3_msg_info *) carray_get( messages, i - 1 ); + + err = mailpop3_header( m_pop3, info->index, &header, &length ); + if ( err != MAILPOP3_NO_ERROR ) { + qDebug( "POP3: error retrieving header msgid: %i", info->index ); + logout(); + return; + } + RecMail *mail = parseHeader( header ); + mail->setNumber( info->index ); + target.append( mail ); + } + logout(); } +RecMail *POP3wrapper::parseHeader( const char *h ) +{ + RecMail *mail = new RecMail(); + QString header( h ); + + //TODO: parse header - maybe something like this is already implemented in libetpan? + mail->setSubject( "Blah blubb" ); + + return mail; +} + void POP3wrapper::login() { - logout(); + if ( m_pop3 != NULL ) logout(); + const char *server, *user, *pass; uint16_t port; int err = MAILPOP3_NO_ERROR; @@ -37,7 +70,7 @@ void POP3wrapper::login() user = account->getUser().latin1(); pass = account->getPassword().latin1(); - m_pop3 = mailpop3_new( 20, &pop3_progress ); + m_pop3 = mailpop3_new( 200, &pop3_progress ); // connect err = mailpop3_socket_connect( m_pop3, (char *) server, port ); @@ -65,7 +98,7 @@ void POP3wrapper::login() void POP3wrapper::logout() { int err = MAILPOP3_NO_ERROR; - if ( !m_pop3 ) return; + if ( m_pop3 == NULL ) return; err = mailpop3_quit( m_pop3 ); mailpop3_free( m_pop3 ); 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: void logout(); private: + RecMail *parseHeader( const char *header ); POP3account *account; mailpop3 *m_pop3; 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 @@ POP3wrapper::POP3wrapper( POP3account *a ) { account = a; + m_pop3 = NULL; } POP3wrapper::~POP3wrapper() @@ -20,14 +21,46 @@ void POP3wrapper::pop3_progress( size_t current, size_t maximum ) void POP3wrapper::listMessages( QList &target ) { + int err = MAILPOP3_NO_ERROR; + char *header; + size_t length; + carray *messages; + login(); - //TODO: list messages + mailpop3_list( m_pop3, &messages ); + + for ( int i = carray_count( messages ); i > 0; i-- ) { + mailpop3_msg_info *info = (mailpop3_msg_info *) carray_get( messages, i - 1 ); + + err = mailpop3_header( m_pop3, info->index, &header, &length ); + if ( err != MAILPOP3_NO_ERROR ) { + qDebug( "POP3: error retrieving header msgid: %i", info->index ); + logout(); + return; + } + RecMail *mail = parseHeader( header ); + mail->setNumber( info->index ); + target.append( mail ); + } + logout(); } +RecMail *POP3wrapper::parseHeader( const char *h ) +{ + RecMail *mail = new RecMail(); + QString header( h ); + + //TODO: parse header - maybe something like this is already implemented in libetpan? + mail->setSubject( "Blah blubb" ); + + return mail; +} + void POP3wrapper::login() { - logout(); + if ( m_pop3 != NULL ) logout(); + const char *server, *user, *pass; uint16_t port; int err = MAILPOP3_NO_ERROR; @@ -37,7 +70,7 @@ void POP3wrapper::login() user = account->getUser().latin1(); pass = account->getPassword().latin1(); - m_pop3 = mailpop3_new( 20, &pop3_progress ); + m_pop3 = mailpop3_new( 200, &pop3_progress ); // connect err = mailpop3_socket_connect( m_pop3, (char *) server, port ); @@ -65,7 +98,7 @@ void POP3wrapper::login() void POP3wrapper::logout() { int err = MAILPOP3_NO_ERROR; - if ( !m_pop3 ) return; + if ( m_pop3 == NULL ) return; err = mailpop3_quit( m_pop3 ); mailpop3_free( m_pop3 ); 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: void logout(); private: + RecMail *parseHeader( const char *header ); POP3account *account; mailpop3 *m_pop3; -- cgit v0.9.0.2