summaryrefslogtreecommitdiff
path: root/noncore
authoralwin <alwin>2003-12-23 01:58:59 (UTC)
committer alwin <alwin>2003-12-23 01:58:59 (UTC)
commit127c50cc446de489c702400ebc5fc4874f6311b2 (patch) (side-by-side diff)
tree86ba684107eb2258e22b613c8c0dfa1a0c8a1bda /noncore
parent04a7006c0392c02941e263d4d35edeeb2f98223d (diff)
downloadopie-127c50cc446de489c702400ebc5fc4874f6311b2.zip
opie-127c50cc446de489c702400ebc5fc4874f6311b2.tar.gz
opie-127c50cc446de489c702400ebc5fc4874f6311b2.tar.bz2
UFFFFFFF
flushing send queue mostly finished. Attention: To get it work you must apply the patches from the libetpan/ directory! ToDo: - when flush then select a smtp-account to use for when there are more than one smtp accounts. (opiemail.cpp) This moment I just use the first one. - the special funs in mboxwrapper (deleting range of mail, storing a message to a folder) should go to all mailbox wrappers, means into the global interface of them. - cleanup/review the code of the smtp-wrapper.
Diffstat (limited to 'noncore') (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/mail/libmailwrapper/mailwrapper.cpp1
-rw-r--r--noncore/net/mail/libmailwrapper/mboxwrapper.cpp66
-rw-r--r--noncore/net/mail/libmailwrapper/mboxwrapper.h3
-rw-r--r--noncore/net/mail/libmailwrapper/smtpwrapper.cpp333
-rw-r--r--noncore/net/mail/libmailwrapper/smtpwrapper.h18
-rw-r--r--noncore/net/mail/mailwrapper.cpp1
-rw-r--r--noncore/net/mail/mboxwrapper.cpp66
-rw-r--r--noncore/net/mail/mboxwrapper.h3
-rw-r--r--noncore/net/mail/opiemail.cpp19
-rw-r--r--noncore/net/mail/smtpwrapper.cpp333
-rw-r--r--noncore/net/mail/smtpwrapper.h18
11 files changed, 585 insertions, 276 deletions
diff --git a/noncore/net/mail/libmailwrapper/mailwrapper.cpp b/noncore/net/mail/libmailwrapper/mailwrapper.cpp
index c5d4265..f8efd09 100644
--- a/noncore/net/mail/libmailwrapper/mailwrapper.cpp
+++ b/noncore/net/mail/libmailwrapper/mailwrapper.cpp
@@ -10,3 +10,2 @@
#include "logindialog.h"
-//#include "mail.h"
#include "defines.h"
diff --git a/noncore/net/mail/libmailwrapper/mboxwrapper.cpp b/noncore/net/mail/libmailwrapper/mboxwrapper.cpp
index 8117cef..293ae1b 100644
--- a/noncore/net/mail/libmailwrapper/mboxwrapper.cpp
+++ b/noncore/net/mail/libmailwrapper/mboxwrapper.cpp
@@ -219 +219,67 @@ void MBOXwrapper::storeMessage(const char*msg,size_t length, const QString&folde
}
+
+void MBOXwrapper::fetchRawBody(const RecMail&mail,char**target,size_t*length)
+{
+ RecBody body;
+ mailstorage*storage = mailstorage_new(NULL);
+ QString p = MBOXPath+"/";
+ p+=mail.getMbox();
+ mailmessage * msg;
+ char*data=0;
+ size_t size;
+
+ int r = mbox_mailstorage_init(storage,strdup(p.latin1()),0,0,0);
+ mailfolder*folder;
+ folder = mailfolder_new( storage,strdup(p.latin1()),NULL);
+ r = mailfolder_connect(folder);
+ if (r != MAIL_NO_ERROR) {
+ qDebug("Error initializing mbox");
+ mailfolder_free(folder);
+ mailstorage_free(storage);
+ return;
+ }
+ r = mailsession_get_message(folder->fld_session, mail.getNumber(), &msg);
+ if (r != MAIL_NO_ERROR) {
+ qDebug("Error fetching mail %i",mail.getNumber());
+ mailfolder_free(folder);
+ mailstorage_free(storage);
+ return;
+ }
+ r = mailmessage_fetch(msg,&data,&size);
+ if (r != MAIL_NO_ERROR) {
+ qDebug("Error fetching mail %i",mail.getNumber());
+ mailfolder_free(folder);
+ mailstorage_free(storage);
+ mailmessage_free(msg);
+ return;
+ }
+ *target = data;
+ *length = size;
+ mailfolder_free(folder);
+ mailstorage_free(storage);
+ mailmessage_free(msg);
+}
+
+void MBOXwrapper::deleteMails(const QString & mailbox,QList<RecMail> &target)
+{
+ QString p = MBOXPath+"/";
+ p+=mailbox;
+ mailmbox_folder*f = 0;
+ int r = mailmbox_init(p.latin1(),0,1,0,&f);
+ if (r != MAIL_NO_ERROR) {
+ qDebug("Error init folder");
+ return;
+ }
+ for (unsigned int i=0; i < target.count();++i) {
+ r = mailmbox_delete_msg(f,target.at(i)->getNumber());
+ if (r!=MAILMBOX_NO_ERROR) {
+ qDebug("error delete mail");
+ }
+ }
+ r = mailmbox_expunge(f);
+ if (r != MAILMBOX_NO_ERROR) {
+ qDebug("error expunge mailbox");
+ }
+ mailmbox_done(f);
+}
+
diff --git a/noncore/net/mail/libmailwrapper/mboxwrapper.h b/noncore/net/mail/libmailwrapper/mboxwrapper.h
index 1bbaf79..f64ad52 100644
--- a/noncore/net/mail/libmailwrapper/mboxwrapper.h
+++ b/noncore/net/mail/libmailwrapper/mboxwrapper.h
@@ -27,2 +27,5 @@ public:
+ virtual void fetchRawBody(const RecMail&mail,char**target,size_t*length);
+ virtual void deleteMails(const QString & mailbox,QList<RecMail> &target);
+
protected:
diff --git a/noncore/net/mail/libmailwrapper/smtpwrapper.cpp b/noncore/net/mail/libmailwrapper/smtpwrapper.cpp
index a6a46ba..b81a87f 100644
--- a/noncore/net/mail/libmailwrapper/smtpwrapper.cpp
+++ b/noncore/net/mail/libmailwrapper/smtpwrapper.cpp
@@ -7,10 +7,5 @@
#include <qdir.h>
+#include <qt.h>
#include <libetpan/libetpan.h>
-#if 0
-#include <libetpan/mailimf.h>
-#include <libetpan/mailsmtp.h>
-#include <libetpan/mailstorage.h>
-#include <libetpan/maildriver.h>
-#endif
@@ -20,2 +15,3 @@
#include "logindialog.h"
+#include "mailtypes.h"
#include "defines.h"
@@ -210,8 +206,10 @@ err_free:
-mailmime *SMTPwrapper::buildFilePart(const QString&filename,const QString&mimetype )
+mailmime *SMTPwrapper::buildFilePart(const QString&filename,const QString&mimetype,const QString&TextContent )
{
- mailmime * filePart;
- mailmime_fields * fields;
- mailmime_content * content;
- mailmime_parameter * param = NULL;
+ mailmime * filePart = 0;
+ mailmime_fields * fields = 0;
+ mailmime_content * content = 0;
+ mailmime_parameter * param = 0;
+ char*name = 0;
+ char*file = 0;
int err;
@@ -219,47 +217,74 @@ mailmime *SMTPwrapper::buildFilePart(const QString&filename,const QString&mimety
int pos = filename.findRev( '/' );
- QString tmp = filename.right( filename.length() - ( pos + 1 ) );
- char *name = strdup( tmp.latin1() ); // just filename
- char *file = strdup( filename.latin1() ); // full name with path
+
+ if (filename.length()>0) {
+ QString tmp = filename.right( filename.length() - ( pos + 1 ) );
+ name = strdup( tmp.latin1() ); // just filename
+ file = strdup( filename.latin1() ); // full name with path
+ }
char *mime = strdup( mimetype.latin1() ); // mimetype -e.g. text/plain
- fields = mailmime_fields_new_filename(
- MAILMIME_DISPOSITION_TYPE_ATTACHMENT, name,
- MAILMIME_MECHANISM_BASE64 );
- if ( fields == NULL ) goto err_free;
-
- content = mailmime_content_new_with_str( mime );
- if ( content == NULL ) goto err_free_fields;
-
- if ( mimetype.compare( "text/plain" ) == 0 ) {
+ int disptype = MAILMIME_DISPOSITION_TYPE_ATTACHMENT;
+ int mechanism = MAILMIME_MECHANISM_BASE64;
+
+ if ( mimetype.startsWith( "text/" ) ) {
param = mailmime_parameter_new( strdup( "charset" ),
- strdup( "iso-8859-1" ) );
- if ( param == NULL ) goto err_free_content;
-
- err = clist_append( content->ct_parameters, param );
- if ( err != MAILIMF_NO_ERROR ) goto err_free_param;
+ strdup( "iso-8859-1" ) );
+ disptype = MAILMIME_DISPOSITION_TYPE_INLINE;
+ mechanism = MAILMIME_MECHANISM_QUOTED_PRINTABLE;
}
- filePart = mailmime_new_empty( content, fields );
- if ( filePart == NULL ) goto err_free_param;
-
- err = mailmime_set_body_file( filePart, file );
- if ( err != MAILIMF_NO_ERROR ) goto err_free_filePart;
+ fields = mailmime_fields_new_filename(
+ disptype, name,
+ mechanism );
+ content = mailmime_content_new_with_str( mime );
+ if (content!=0 && fields != 0) {
+ if (param) {
+ clist_append(content->ct_parameters,param);
+ param = 0;
+ }
+ if (filename.length()>0) {
+ QFileInfo f(filename);
+ param = mailmime_parameter_new(strdup("name"),strdup(f.fileName().latin1()));
+ clist_append(content->ct_parameters,param);
+ param = 0;
+ }
+ filePart = mailmime_new_empty( content, fields );
+ }
+ if (filePart) {
+ if (filename.length()>0) {
+ err = mailmime_set_body_file( filePart, file );
+ } else {
+ err = mailmime_set_body_text(filePart,strdup(TextContent.ascii()),TextContent.length());
+ }
+ if (err != MAILIMF_NO_ERROR) {
+ qDebug("Error setting body with file %s",file);
+ mailmime_free( filePart );
+ filePart = 0;
+ }
+ }
+ if (!filePart) {
+ if ( param != NULL ) {
+ mailmime_parameter_free( param );
+ }
+ if (content) {
+ mailmime_content_free( content );
+ } else {
+ if (mime) {
+ free( mime );
+ }
+ }
+ if (fields) {
+ mailmime_fields_free( fields );
+ } else {
+ if (name) {
+ free( name );
+ }
+ if (file) {
+ free( file );
+ }
+ }
+ }
return filePart; // Success :)
-err_free_filePart:
- mailmime_free( filePart );
-err_free_param:
- if ( param != NULL ) mailmime_parameter_free( param );
-err_free_content:
- mailmime_content_free( content );
-err_free_fields:
- mailmime_fields_free( fields );
-err_free:
- free( name );
- free( mime );
- free( file );
- qDebug( "buildFilePart - error" );
-
- return NULL; // Error :(
}
@@ -269,4 +294,5 @@ void SMTPwrapper::addFileParts( mailmime *message,const QList<Attachment>&files
const Attachment *it;
- /* work around for the brainfucked qlist which can not act with const values */
- for ( it = ((QList<Attachment>)files).first(); it; it = ((QList<Attachment>)files).next() ) {
+ unsigned int count = files.count();
+ qDebug("List contains %i values",count);
+ for ( unsigned int i = 0; i < count; ++i ) {
qDebug( "Adding file" );
@@ -274,16 +300,15 @@ void SMTPwrapper::addFileParts( mailmime *message,const QList<Attachment>&files
int err;
+ it = ((QList<Attachment>)files).at(i);
- filePart = buildFilePart( it->getFileName(), it->getMimeType() );
- if ( filePart == NULL ) goto err_free;
-
+ filePart = buildFilePart( it->getFileName(), it->getMimeType(),"" );
+ if ( filePart == NULL ) {
+ qDebug( "addFileParts: error adding file:" );
+ qDebug( it->getFileName() );
+ continue;
+ }
err = mailmime_smart_add_part( message, filePart );
- if ( err != MAILIMF_NO_ERROR ) goto err_free_filePart;
-
- continue; // Success :)
-
- err_free_filePart:
- mailmime_free( filePart );
- err_free:
- qDebug( "addFileParts: error adding file:" );
- qDebug( it->getFileName() );
+ if ( err != MAILIMF_NO_ERROR ) {
+ mailmime_free( filePart );
+ qDebug("error smart add");
+ }
}
@@ -305,3 +330,7 @@ mailmime *SMTPwrapper::createMimeMail(const Mail &mail )
- txtPart = buildTxtPart( mail.getMessage() );
+ if (mail.getAttachments().count()==0) {
+ txtPart = buildTxtPart( mail.getMessage() );
+ } else {
+ txtPart = buildFilePart("","text/plain",mail.getMessage());
+ }
if ( txtPart == NULL ) goto err_free_message;
@@ -393,8 +422,5 @@ clist *SMTPwrapper::createRcptList( mailimf_fields *fields )
-char *SMTPwrapper::getFrom( mailmime *mail )
+char *SMTPwrapper::getFrom( mailimf_field *ffrom)
{
char *from = NULL;
-
- mailimf_field *ffrom;
- ffrom = getField( mail->mm_data.mm_message.mm_fields, MAILIMF_FIELD_FROM );
if ( ffrom && (ffrom->fld_type == MAILIMF_FIELD_FROM)
@@ -412,3 +438,10 @@ char *SMTPwrapper::getFrom( mailmime *mail )
-SMTPaccount *SMTPwrapper::getAccount(const QString&from )
+char *SMTPwrapper::getFrom( mailmime *mail )
+{
+ mailimf_field *ffrom = 0;
+ ffrom = getField( mail->mm_data.mm_message.mm_fields, MAILIMF_FIELD_FROM );
+ return getFrom(ffrom);
+}
+
+SMTPaccount *SMTPwrapper::getAccount(const QString&name )
{
@@ -421,5 +454,5 @@ SMTPaccount *SMTPwrapper::getAccount(const QString&from )
smtp = static_cast<SMTPaccount *>(it);
- if ( smtp->getMail().compare( from ) == 0 ) {
+ if ( smtp->getName()== name ) {
qDebug( "SMTPaccount found for" );
- qDebug( from );
+ qDebug( name );
return smtp;
@@ -437,5 +470,5 @@ QString SMTPwrapper::getTmpFile() {
QDir dir( "/tmp" );
- QStringList::Iterator it;
QStringList list = dir.entryList( "opiemail-tmp-*" );
+
do {
@@ -485,35 +518,2 @@ void SMTPwrapper::readFromFile(const QString&file, char **data, size_t *size )
*size=msg.length();
-
-#if 0
- char *buf;
- struct stat st;
- int fd, count = 0, total = 0;
-
- fd = open( file.latin1(), O_RDONLY, 0 );
- if ( fd == -1 ) return;
-
- if ( fstat( fd, &st ) != 0 ) goto err_close;
- if ( !st.st_size ) goto err_close;
-
- buf = (char *) malloc( st.st_size );
- if ( !buf ) goto err_close;
-
- while ( ( total < st.st_size ) && ( count >= 0 ) ) {
- count = read( fd, buf + total, st.st_size - total );
- total += count;
- }
- if ( count < 0 ) goto err_free;
-
- *data = buf;
- *size = st.st_size;
-
- close( fd );
-
- return; // Success :)
-
-err_free:
- free( buf );
-err_close:
- close( fd );
-#endif
}
@@ -522,3 +522,3 @@ void SMTPwrapper::progress( size_t current, size_t maximum )
{
- qDebug( "Current: %i of %i", current, maximum );
+// qDebug( "Current: %i of %i", current, maximum );
}
@@ -534,24 +534,15 @@ void SMTPwrapper::storeMail(char*mail, size_t length, const QString&box)
-void SMTPwrapper::smtpSend( mailmime *mail,bool later )
+void SMTPwrapper::smtpSend( mailmime *mail,bool later, SMTPaccount *smtp )
{
- mailsmtp *session;
- clist *rcpts;
- char *from, *data, *server, *user = NULL, *pass = NULL;
+ clist *rcpts = 0;
+ char *from, *data;
size_t size;
- int err;
- bool ssl;
- uint16_t port;
-
- from = getFrom( mail );
- SMTPaccount *smtp = getAccount( from );
if ( smtp == NULL ) {
- free(from);
return;
}
- rcpts = createRcptList( mail->mm_data.mm_message.mm_fields );
-
+ from = data = 0;
+
QString file = getTmpFile();
writeToFile( file, mail );
-
readFromFile( file, &data, &size );
@@ -560,10 +551,22 @@ void SMTPwrapper::smtpSend( mailmime *mail,bool later )
- storeMail(data,size,(later?"Outgoing":"Sent"));
-
if (later) {
- smtp_address_list_free( rcpts );
+ storeMail(data,size,"Outgoing");
if (data) free( data );
- if (from) free(from);
return;
}
+ from = getFrom( mail );
+ rcpts = createRcptList( mail->mm_data.mm_message.mm_fields );
+ smtpSend(from,rcpts,data,size,smtp);
+}
+
+int SMTPwrapper::smtpSend(char*from,clist*rcpts,char*data,size_t size, SMTPaccount *smtp )
+{
+ char *server, *user, *pass;
+ bool ssl;
+ uint16_t port;
+ mailsmtp *session;
+ int err,result;
+
+ result = 1;
+ server = user = pass = 0;
server = strdup( smtp->getServer().latin1() );
@@ -583,6 +586,6 @@ void SMTPwrapper::smtpSend( mailmime *mail,bool later )
}
- if ( err != MAILSMTP_NO_ERROR ) goto free_mem_session;
+ if ( err != MAILSMTP_NO_ERROR ) {result = 0;goto free_mem_session;}
err = mailsmtp_init( session );
- if ( err != MAILSMTP_NO_ERROR ) goto free_con_session;
+ if ( err != MAILSMTP_NO_ERROR ) {result = 0; goto free_con_session;}
@@ -600,3 +603,3 @@ void SMTPwrapper::smtpSend( mailmime *mail,bool later )
} else {
- goto free_con_session;
+ result = 0; goto free_con_session;
}
@@ -613,5 +616,6 @@ void SMTPwrapper::smtpSend( mailmime *mail,bool later )
err = mailsmtp_send( session, from, rcpts, data, size );
- if ( err != MAILSMTP_NO_ERROR ) goto free_con_session;
+ if ( err != MAILSMTP_NO_ERROR ) {result = 0; goto free_con_session;}
qDebug( "Mail sent." );
+ storeMail(data,size,"Sent");
@@ -622,6 +626,6 @@ free_mem_session:
free_mem:
- smtp_address_list_free( rcpts );
+ if (rcpts) smtp_address_list_free( rcpts );
if (data) free( data );
- if (from) free(from);
if (server) free( server );
+ if (from) free( from );
if ( smtp->getLogin() ) {
@@ -630,3 +634,3 @@ free_mem:
}
- free( from );
+ return result;
}
@@ -636,3 +640,5 @@ void SMTPwrapper::sendMail(const Mail&mail,bool later )
mailmime * mimeMail;
-
+
+ SMTPaccount *smtp = getAccount(mail.getName());
+
mimeMail = createMimeMail(mail );
@@ -641,5 +647,68 @@ void SMTPwrapper::sendMail(const Mail&mail,bool later )
} else {
- smtpSend( mimeMail,later );
+ smtpSend( mimeMail,later,smtp);
mailmime_free( mimeMail );
+ qDebug("Clean up done");
+ }
+}
+
+int SMTPwrapper::sendQueuedMail(MBOXwrapper*wrap,SMTPaccount*smtp,RecMail*which)
+{
+ char*data = 0;
+ size_t length = 0;
+ size_t curTok = 0;
+ mailimf_fields *fields = 0;
+ mailimf_field*ffrom = 0;
+ clist *rcpts = 0;
+ char*from = 0;
+
+ wrap->fetchRawBody(*which,&data,&length);
+ if (!data) return 0;
+ int err = mailimf_fields_parse( data, length, &curTok, &fields );
+ if (err != MAILIMF_NO_ERROR) {
+ free(data);
+ delete wrap;
+ return 0;
+ }
+
+ rcpts = createRcptList( fields );
+ ffrom = getField(fields, MAILIMF_FIELD_FROM );
+ from = getFrom(ffrom);
+ qDebug("Size: %i vs. %i",length,strlen(data));
+ if (rcpts && from) {
+ return smtpSend(from,rcpts,data,strlen(data),smtp );
}
+ return 0;
+}
+
+/* this is a special fun */
+void SMTPwrapper::flushOutbox(SMTPaccount*smtp)
+{
+ if (!smtp) return;
+ QString localfolders = (QString) getenv( "HOME" ) + QString("/Applications/opiemail/localmail/");
+ MBOXwrapper*wrap = new MBOXwrapper(localfolders);
+ if (!wrap) {
+ qDebug("memory error");
+ return;
+ }
+ QList<RecMail> mailsToSend;
+ QList<RecMail> mailsToRemove;
+ QString mbox("Outgoing");
+ wrap->listMessages(mbox,mailsToSend);
+ if (mailsToSend.count()==0) {
+ delete wrap;
+ return;
+ }
+ mailsToSend.setAutoDelete(false);
+ while (mailsToSend.count()>0) {
+ if (sendQueuedMail(wrap,smtp,mailsToSend.at(0))==0) {
+ QMessageBox::critical(0,tr("Error sending mail"),
+ tr("Error sending queued mail - breaking"));
+ break;
+ }
+ mailsToRemove.append(mailsToSend.at(0));
+ mailsToSend.removeFirst();
+ }
+ wrap->deleteMails(mbox,mailsToRemove);
+ mailsToSend.setAutoDelete(true);
+ delete wrap;
}
diff --git a/noncore/net/mail/libmailwrapper/smtpwrapper.h b/noncore/net/mail/libmailwrapper/smtpwrapper.h
index 41e9a8c..c0dcc11 100644
--- a/noncore/net/mail/libmailwrapper/smtpwrapper.h
+++ b/noncore/net/mail/libmailwrapper/smtpwrapper.h
@@ -12,2 +12,4 @@
class Mail;
+class MBOXwrapper;
+class RecMail;
class Attachment;
@@ -27,2 +29,3 @@ public:
void sendMail(const Mail& mail,bool later=false );
+ void flushOutbox(SMTPaccount*smtp);
@@ -36,7 +39,5 @@ protected:
mailmime *buildTxtPart(const QString&str );
- mailmime *buildFilePart(const QString&filename,const QString&mimetype );
- void smtpSend( mailmime *mail,bool later );
- mailimf_field *getField( mailimf_fields *fields, int type );
+ mailmime *buildFilePart(const QString&filename,const QString&mimetype,const QString&content);
+ void smtpSend( mailmime *mail,bool later, SMTPaccount *smtp );
clist *createRcptList( mailimf_fields *fields );
- char *getFrom( mailmime *mail );
SMTPaccount *getAccount(const QString&from );
@@ -44,4 +45,4 @@ protected:
void readFromFile(const QString&file, char **data, size_t *size );
- void storeMail(char*mail, size_t length, const QString&box);
+ static void storeMail(char*mail, size_t length, const QString&box);
static QString mailsmtpError( int err );
@@ -50,4 +51,11 @@ protected:
static void addRcpts( clist *list, mailimf_address_list *addr_list );
+ static char *getFrom( mailmime *mail );
+ static char *getFrom( mailimf_field *ffrom);
+ static mailimf_field *getField( mailimf_fields *fields, int type );
+ static int smtpSend(char*from,clist*rcpts,char*data,size_t size, SMTPaccount *smtp );
+
void storeMail(mailmime*mail, const QString&box);
Settings *settings;
+
+ int sendQueuedMail(MBOXwrapper*wrap,SMTPaccount*smtp,RecMail*which);
};
diff --git a/noncore/net/mail/mailwrapper.cpp b/noncore/net/mail/mailwrapper.cpp
index c5d4265..f8efd09 100644
--- a/noncore/net/mail/mailwrapper.cpp
+++ b/noncore/net/mail/mailwrapper.cpp
@@ -10,3 +10,2 @@
#include "logindialog.h"
-//#include "mail.h"
#include "defines.h"
diff --git a/noncore/net/mail/mboxwrapper.cpp b/noncore/net/mail/mboxwrapper.cpp
index 8117cef..293ae1b 100644
--- a/noncore/net/mail/mboxwrapper.cpp
+++ b/noncore/net/mail/mboxwrapper.cpp
@@ -219 +219,67 @@ void MBOXwrapper::storeMessage(const char*msg,size_t length, const QString&folde
}
+
+void MBOXwrapper::fetchRawBody(const RecMail&mail,char**target,size_t*length)
+{
+ RecBody body;
+ mailstorage*storage = mailstorage_new(NULL);
+ QString p = MBOXPath+"/";
+ p+=mail.getMbox();
+ mailmessage * msg;
+ char*data=0;
+ size_t size;
+
+ int r = mbox_mailstorage_init(storage,strdup(p.latin1()),0,0,0);
+ mailfolder*folder;
+ folder = mailfolder_new( storage,strdup(p.latin1()),NULL);
+ r = mailfolder_connect(folder);
+ if (r != MAIL_NO_ERROR) {
+ qDebug("Error initializing mbox");
+ mailfolder_free(folder);
+ mailstorage_free(storage);
+ return;
+ }
+ r = mailsession_get_message(folder->fld_session, mail.getNumber(), &msg);
+ if (r != MAIL_NO_ERROR) {
+ qDebug("Error fetching mail %i",mail.getNumber());
+ mailfolder_free(folder);
+ mailstorage_free(storage);
+ return;
+ }
+ r = mailmessage_fetch(msg,&data,&size);
+ if (r != MAIL_NO_ERROR) {
+ qDebug("Error fetching mail %i",mail.getNumber());
+ mailfolder_free(folder);
+ mailstorage_free(storage);
+ mailmessage_free(msg);
+ return;
+ }
+ *target = data;
+ *length = size;
+ mailfolder_free(folder);
+ mailstorage_free(storage);
+ mailmessage_free(msg);
+}
+
+void MBOXwrapper::deleteMails(const QString & mailbox,QList<RecMail> &target)
+{
+ QString p = MBOXPath+"/";
+ p+=mailbox;
+ mailmbox_folder*f = 0;
+ int r = mailmbox_init(p.latin1(),0,1,0,&f);
+ if (r != MAIL_NO_ERROR) {
+ qDebug("Error init folder");
+ return;
+ }
+ for (unsigned int i=0; i < target.count();++i) {
+ r = mailmbox_delete_msg(f,target.at(i)->getNumber());
+ if (r!=MAILMBOX_NO_ERROR) {
+ qDebug("error delete mail");
+ }
+ }
+ r = mailmbox_expunge(f);
+ if (r != MAILMBOX_NO_ERROR) {
+ qDebug("error expunge mailbox");
+ }
+ mailmbox_done(f);
+}
+
diff --git a/noncore/net/mail/mboxwrapper.h b/noncore/net/mail/mboxwrapper.h
index 1bbaf79..f64ad52 100644
--- a/noncore/net/mail/mboxwrapper.h
+++ b/noncore/net/mail/mboxwrapper.h
@@ -27,2 +27,5 @@ public:
+ virtual void fetchRawBody(const RecMail&mail,char**target,size_t*length);
+ virtual void deleteMails(const QString & mailbox,QList<RecMail> &target);
+
protected:
diff --git a/noncore/net/mail/opiemail.cpp b/noncore/net/mail/opiemail.cpp
index 7ab4e0d..9257866 100644
--- a/noncore/net/mail/opiemail.cpp
+++ b/noncore/net/mail/opiemail.cpp
@@ -1 +1,2 @@
+#include <qmessagebox.h>
#include "opiemail.h"
@@ -3,2 +4,3 @@
#include "composemail.h"
+#include "smtpwrapper.h"
@@ -30,2 +32,19 @@ void OpieMail::slotSendQueued()
qDebug( "Send Queued" );
+ SMTPaccount *smtp = 0;
+
+ QList<Account> list = settings->getAccounts();
+ Account *it;
+// if (list.count()==1) {
+ for ( it = list.first(); it; it = list.next() ) {
+ if ( it->getType().compare( "SMTP" ) == 0 ) {
+ smtp = static_cast<SMTPaccount *>(it);
+ break;
+ }
+ }
+// }
+ if (smtp) {
+ SMTPwrapper * wrap = new SMTPwrapper(settings);
+ wrap->flushOutbox(smtp);
+ QMessageBox::information(0,tr("Info"),tr("Mail queue flushed"));
+ }
}
diff --git a/noncore/net/mail/smtpwrapper.cpp b/noncore/net/mail/smtpwrapper.cpp
index a6a46ba..b81a87f 100644
--- a/noncore/net/mail/smtpwrapper.cpp
+++ b/noncore/net/mail/smtpwrapper.cpp
@@ -7,10 +7,5 @@
#include <qdir.h>
+#include <qt.h>
#include <libetpan/libetpan.h>
-#if 0
-#include <libetpan/mailimf.h>
-#include <libetpan/mailsmtp.h>
-#include <libetpan/mailstorage.h>
-#include <libetpan/maildriver.h>
-#endif
@@ -20,2 +15,3 @@
#include "logindialog.h"
+#include "mailtypes.h"
#include "defines.h"
@@ -210,8 +206,10 @@ err_free:
-mailmime *SMTPwrapper::buildFilePart(const QString&filename,const QString&mimetype )
+mailmime *SMTPwrapper::buildFilePart(const QString&filename,const QString&mimetype,const QString&TextContent )
{
- mailmime * filePart;
- mailmime_fields * fields;
- mailmime_content * content;
- mailmime_parameter * param = NULL;
+ mailmime * filePart = 0;
+ mailmime_fields * fields = 0;
+ mailmime_content * content = 0;
+ mailmime_parameter * param = 0;
+ char*name = 0;
+ char*file = 0;
int err;
@@ -219,47 +217,74 @@ mailmime *SMTPwrapper::buildFilePart(const QString&filename,const QString&mimety
int pos = filename.findRev( '/' );
- QString tmp = filename.right( filename.length() - ( pos + 1 ) );
- char *name = strdup( tmp.latin1() ); // just filename
- char *file = strdup( filename.latin1() ); // full name with path
+
+ if (filename.length()>0) {
+ QString tmp = filename.right( filename.length() - ( pos + 1 ) );
+ name = strdup( tmp.latin1() ); // just filename
+ file = strdup( filename.latin1() ); // full name with path
+ }
char *mime = strdup( mimetype.latin1() ); // mimetype -e.g. text/plain
- fields = mailmime_fields_new_filename(
- MAILMIME_DISPOSITION_TYPE_ATTACHMENT, name,
- MAILMIME_MECHANISM_BASE64 );
- if ( fields == NULL ) goto err_free;
-
- content = mailmime_content_new_with_str( mime );
- if ( content == NULL ) goto err_free_fields;
-
- if ( mimetype.compare( "text/plain" ) == 0 ) {
+ int disptype = MAILMIME_DISPOSITION_TYPE_ATTACHMENT;
+ int mechanism = MAILMIME_MECHANISM_BASE64;
+
+ if ( mimetype.startsWith( "text/" ) ) {
param = mailmime_parameter_new( strdup( "charset" ),
- strdup( "iso-8859-1" ) );
- if ( param == NULL ) goto err_free_content;
-
- err = clist_append( content->ct_parameters, param );
- if ( err != MAILIMF_NO_ERROR ) goto err_free_param;
+ strdup( "iso-8859-1" ) );
+ disptype = MAILMIME_DISPOSITION_TYPE_INLINE;
+ mechanism = MAILMIME_MECHANISM_QUOTED_PRINTABLE;
}
- filePart = mailmime_new_empty( content, fields );
- if ( filePart == NULL ) goto err_free_param;
-
- err = mailmime_set_body_file( filePart, file );
- if ( err != MAILIMF_NO_ERROR ) goto err_free_filePart;
+ fields = mailmime_fields_new_filename(
+ disptype, name,
+ mechanism );
+ content = mailmime_content_new_with_str( mime );
+ if (content!=0 && fields != 0) {
+ if (param) {
+ clist_append(content->ct_parameters,param);
+ param = 0;
+ }
+ if (filename.length()>0) {
+ QFileInfo f(filename);
+ param = mailmime_parameter_new(strdup("name"),strdup(f.fileName().latin1()));
+ clist_append(content->ct_parameters,param);
+ param = 0;
+ }
+ filePart = mailmime_new_empty( content, fields );
+ }
+ if (filePart) {
+ if (filename.length()>0) {
+ err = mailmime_set_body_file( filePart, file );
+ } else {
+ err = mailmime_set_body_text(filePart,strdup(TextContent.ascii()),TextContent.length());
+ }
+ if (err != MAILIMF_NO_ERROR) {
+ qDebug("Error setting body with file %s",file);
+ mailmime_free( filePart );
+ filePart = 0;
+ }
+ }
+ if (!filePart) {
+ if ( param != NULL ) {
+ mailmime_parameter_free( param );
+ }
+ if (content) {
+ mailmime_content_free( content );
+ } else {
+ if (mime) {
+ free( mime );
+ }
+ }
+ if (fields) {
+ mailmime_fields_free( fields );
+ } else {
+ if (name) {
+ free( name );
+ }
+ if (file) {
+ free( file );
+ }
+ }
+ }
return filePart; // Success :)
-err_free_filePart:
- mailmime_free( filePart );
-err_free_param:
- if ( param != NULL ) mailmime_parameter_free( param );
-err_free_content:
- mailmime_content_free( content );
-err_free_fields:
- mailmime_fields_free( fields );
-err_free:
- free( name );
- free( mime );
- free( file );
- qDebug( "buildFilePart - error" );
-
- return NULL; // Error :(
}
@@ -269,4 +294,5 @@ void SMTPwrapper::addFileParts( mailmime *message,const QList<Attachment>&files
const Attachment *it;
- /* work around for the brainfucked qlist which can not act with const values */
- for ( it = ((QList<Attachment>)files).first(); it; it = ((QList<Attachment>)files).next() ) {
+ unsigned int count = files.count();
+ qDebug("List contains %i values",count);
+ for ( unsigned int i = 0; i < count; ++i ) {
qDebug( "Adding file" );
@@ -274,16 +300,15 @@ void SMTPwrapper::addFileParts( mailmime *message,const QList<Attachment>&files
int err;
+ it = ((QList<Attachment>)files).at(i);
- filePart = buildFilePart( it->getFileName(), it->getMimeType() );
- if ( filePart == NULL ) goto err_free;
-
+ filePart = buildFilePart( it->getFileName(), it->getMimeType(),"" );
+ if ( filePart == NULL ) {
+ qDebug( "addFileParts: error adding file:" );
+ qDebug( it->getFileName() );
+ continue;
+ }
err = mailmime_smart_add_part( message, filePart );
- if ( err != MAILIMF_NO_ERROR ) goto err_free_filePart;
-
- continue; // Success :)
-
- err_free_filePart:
- mailmime_free( filePart );
- err_free:
- qDebug( "addFileParts: error adding file:" );
- qDebug( it->getFileName() );
+ if ( err != MAILIMF_NO_ERROR ) {
+ mailmime_free( filePart );
+ qDebug("error smart add");
+ }
}
@@ -305,3 +330,7 @@ mailmime *SMTPwrapper::createMimeMail(const Mail &mail )
- txtPart = buildTxtPart( mail.getMessage() );
+ if (mail.getAttachments().count()==0) {
+ txtPart = buildTxtPart( mail.getMessage() );
+ } else {
+ txtPart = buildFilePart("","text/plain",mail.getMessage());
+ }
if ( txtPart == NULL ) goto err_free_message;
@@ -393,8 +422,5 @@ clist *SMTPwrapper::createRcptList( mailimf_fields *fields )
-char *SMTPwrapper::getFrom( mailmime *mail )
+char *SMTPwrapper::getFrom( mailimf_field *ffrom)
{
char *from = NULL;
-
- mailimf_field *ffrom;
- ffrom = getField( mail->mm_data.mm_message.mm_fields, MAILIMF_FIELD_FROM );
if ( ffrom && (ffrom->fld_type == MAILIMF_FIELD_FROM)
@@ -412,3 +438,10 @@ char *SMTPwrapper::getFrom( mailmime *mail )
-SMTPaccount *SMTPwrapper::getAccount(const QString&from )
+char *SMTPwrapper::getFrom( mailmime *mail )
+{
+ mailimf_field *ffrom = 0;
+ ffrom = getField( mail->mm_data.mm_message.mm_fields, MAILIMF_FIELD_FROM );
+ return getFrom(ffrom);
+}
+
+SMTPaccount *SMTPwrapper::getAccount(const QString&name )
{
@@ -421,5 +454,5 @@ SMTPaccount *SMTPwrapper::getAccount(const QString&from )
smtp = static_cast<SMTPaccount *>(it);
- if ( smtp->getMail().compare( from ) == 0 ) {
+ if ( smtp->getName()== name ) {
qDebug( "SMTPaccount found for" );
- qDebug( from );
+ qDebug( name );
return smtp;
@@ -437,5 +470,5 @@ QString SMTPwrapper::getTmpFile() {
QDir dir( "/tmp" );
- QStringList::Iterator it;
QStringList list = dir.entryList( "opiemail-tmp-*" );
+
do {
@@ -485,35 +518,2 @@ void SMTPwrapper::readFromFile(const QString&file, char **data, size_t *size )
*size=msg.length();
-
-#if 0
- char *buf;
- struct stat st;
- int fd, count = 0, total = 0;
-
- fd = open( file.latin1(), O_RDONLY, 0 );
- if ( fd == -1 ) return;
-
- if ( fstat( fd, &st ) != 0 ) goto err_close;
- if ( !st.st_size ) goto err_close;
-
- buf = (char *) malloc( st.st_size );
- if ( !buf ) goto err_close;
-
- while ( ( total < st.st_size ) && ( count >= 0 ) ) {
- count = read( fd, buf + total, st.st_size - total );
- total += count;
- }
- if ( count < 0 ) goto err_free;
-
- *data = buf;
- *size = st.st_size;
-
- close( fd );
-
- return; // Success :)
-
-err_free:
- free( buf );
-err_close:
- close( fd );
-#endif
}
@@ -522,3 +522,3 @@ void SMTPwrapper::progress( size_t current, size_t maximum )
{
- qDebug( "Current: %i of %i", current, maximum );
+// qDebug( "Current: %i of %i", current, maximum );
}
@@ -534,24 +534,15 @@ void SMTPwrapper::storeMail(char*mail, size_t length, const QString&box)
-void SMTPwrapper::smtpSend( mailmime *mail,bool later )
+void SMTPwrapper::smtpSend( mailmime *mail,bool later, SMTPaccount *smtp )
{
- mailsmtp *session;
- clist *rcpts;
- char *from, *data, *server, *user = NULL, *pass = NULL;
+ clist *rcpts = 0;
+ char *from, *data;
size_t size;
- int err;
- bool ssl;
- uint16_t port;
-
- from = getFrom( mail );
- SMTPaccount *smtp = getAccount( from );
if ( smtp == NULL ) {
- free(from);
return;
}
- rcpts = createRcptList( mail->mm_data.mm_message.mm_fields );
-
+ from = data = 0;
+
QString file = getTmpFile();
writeToFile( file, mail );
-
readFromFile( file, &data, &size );
@@ -560,10 +551,22 @@ void SMTPwrapper::smtpSend( mailmime *mail,bool later )
- storeMail(data,size,(later?"Outgoing":"Sent"));
-
if (later) {
- smtp_address_list_free( rcpts );
+ storeMail(data,size,"Outgoing");
if (data) free( data );
- if (from) free(from);
return;
}
+ from = getFrom( mail );
+ rcpts = createRcptList( mail->mm_data.mm_message.mm_fields );
+ smtpSend(from,rcpts,data,size,smtp);
+}
+
+int SMTPwrapper::smtpSend(char*from,clist*rcpts,char*data,size_t size, SMTPaccount *smtp )
+{
+ char *server, *user, *pass;
+ bool ssl;
+ uint16_t port;
+ mailsmtp *session;
+ int err,result;
+
+ result = 1;
+ server = user = pass = 0;
server = strdup( smtp->getServer().latin1() );
@@ -583,6 +586,6 @@ void SMTPwrapper::smtpSend( mailmime *mail,bool later )
}
- if ( err != MAILSMTP_NO_ERROR ) goto free_mem_session;
+ if ( err != MAILSMTP_NO_ERROR ) {result = 0;goto free_mem_session;}
err = mailsmtp_init( session );
- if ( err != MAILSMTP_NO_ERROR ) goto free_con_session;
+ if ( err != MAILSMTP_NO_ERROR ) {result = 0; goto free_con_session;}
@@ -600,3 +603,3 @@ void SMTPwrapper::smtpSend( mailmime *mail,bool later )
} else {
- goto free_con_session;
+ result = 0; goto free_con_session;
}
@@ -613,5 +616,6 @@ void SMTPwrapper::smtpSend( mailmime *mail,bool later )
err = mailsmtp_send( session, from, rcpts, data, size );
- if ( err != MAILSMTP_NO_ERROR ) goto free_con_session;
+ if ( err != MAILSMTP_NO_ERROR ) {result = 0; goto free_con_session;}
qDebug( "Mail sent." );
+ storeMail(data,size,"Sent");
@@ -622,6 +626,6 @@ free_mem_session:
free_mem:
- smtp_address_list_free( rcpts );
+ if (rcpts) smtp_address_list_free( rcpts );
if (data) free( data );
- if (from) free(from);
if (server) free( server );
+ if (from) free( from );
if ( smtp->getLogin() ) {
@@ -630,3 +634,3 @@ free_mem:
}
- free( from );
+ return result;
}
@@ -636,3 +640,5 @@ void SMTPwrapper::sendMail(const Mail&mail,bool later )
mailmime * mimeMail;
-
+
+ SMTPaccount *smtp = getAccount(mail.getName());
+
mimeMail = createMimeMail(mail );
@@ -641,5 +647,68 @@ void SMTPwrapper::sendMail(const Mail&mail,bool later )
} else {
- smtpSend( mimeMail,later );
+ smtpSend( mimeMail,later,smtp);
mailmime_free( mimeMail );
+ qDebug("Clean up done");
+ }
+}
+
+int SMTPwrapper::sendQueuedMail(MBOXwrapper*wrap,SMTPaccount*smtp,RecMail*which)
+{
+ char*data = 0;
+ size_t length = 0;
+ size_t curTok = 0;
+ mailimf_fields *fields = 0;
+ mailimf_field*ffrom = 0;
+ clist *rcpts = 0;
+ char*from = 0;
+
+ wrap->fetchRawBody(*which,&data,&length);
+ if (!data) return 0;
+ int err = mailimf_fields_parse( data, length, &curTok, &fields );
+ if (err != MAILIMF_NO_ERROR) {
+ free(data);
+ delete wrap;
+ return 0;
+ }
+
+ rcpts = createRcptList( fields );
+ ffrom = getField(fields, MAILIMF_FIELD_FROM );
+ from = getFrom(ffrom);
+ qDebug("Size: %i vs. %i",length,strlen(data));
+ if (rcpts && from) {
+ return smtpSend(from,rcpts,data,strlen(data),smtp );
}
+ return 0;
+}
+
+/* this is a special fun */
+void SMTPwrapper::flushOutbox(SMTPaccount*smtp)
+{
+ if (!smtp) return;
+ QString localfolders = (QString) getenv( "HOME" ) + QString("/Applications/opiemail/localmail/");
+ MBOXwrapper*wrap = new MBOXwrapper(localfolders);
+ if (!wrap) {
+ qDebug("memory error");
+ return;
+ }
+ QList<RecMail> mailsToSend;
+ QList<RecMail> mailsToRemove;
+ QString mbox("Outgoing");
+ wrap->listMessages(mbox,mailsToSend);
+ if (mailsToSend.count()==0) {
+ delete wrap;
+ return;
+ }
+ mailsToSend.setAutoDelete(false);
+ while (mailsToSend.count()>0) {
+ if (sendQueuedMail(wrap,smtp,mailsToSend.at(0))==0) {
+ QMessageBox::critical(0,tr("Error sending mail"),
+ tr("Error sending queued mail - breaking"));
+ break;
+ }
+ mailsToRemove.append(mailsToSend.at(0));
+ mailsToSend.removeFirst();
+ }
+ wrap->deleteMails(mbox,mailsToRemove);
+ mailsToSend.setAutoDelete(true);
+ delete wrap;
}
diff --git a/noncore/net/mail/smtpwrapper.h b/noncore/net/mail/smtpwrapper.h
index 41e9a8c..c0dcc11 100644
--- a/noncore/net/mail/smtpwrapper.h
+++ b/noncore/net/mail/smtpwrapper.h
@@ -12,2 +12,4 @@
class Mail;
+class MBOXwrapper;
+class RecMail;
class Attachment;
@@ -27,2 +29,3 @@ public:
void sendMail(const Mail& mail,bool later=false );
+ void flushOutbox(SMTPaccount*smtp);
@@ -36,7 +39,5 @@ protected:
mailmime *buildTxtPart(const QString&str );
- mailmime *buildFilePart(const QString&filename,const QString&mimetype );
- void smtpSend( mailmime *mail,bool later );
- mailimf_field *getField( mailimf_fields *fields, int type );
+ mailmime *buildFilePart(const QString&filename,const QString&mimetype,const QString&content);
+ void smtpSend( mailmime *mail,bool later, SMTPaccount *smtp );
clist *createRcptList( mailimf_fields *fields );
- char *getFrom( mailmime *mail );
SMTPaccount *getAccount(const QString&from );
@@ -44,4 +45,4 @@ protected:
void readFromFile(const QString&file, char **data, size_t *size );
- void storeMail(char*mail, size_t length, const QString&box);
+ static void storeMail(char*mail, size_t length, const QString&box);
static QString mailsmtpError( int err );
@@ -50,4 +51,11 @@ protected:
static void addRcpts( clist *list, mailimf_address_list *addr_list );
+ static char *getFrom( mailmime *mail );
+ static char *getFrom( mailimf_field *ffrom);
+ static mailimf_field *getField( mailimf_fields *fields, int type );
+ static int smtpSend(char*from,clist*rcpts,char*data,size_t size, SMTPaccount *smtp );
+
void storeMail(mailmime*mail, const QString&box);
Settings *settings;
+
+ int sendQueuedMail(MBOXwrapper*wrap,SMTPaccount*smtp,RecMail*which);
};