summaryrefslogtreecommitdiff
path: root/noncore/net/mail/libmailwrapper
authoralwin <alwin>2003-12-28 02:45:07 (UTC)
committer alwin <alwin>2003-12-28 02:45:07 (UTC)
commitd1a7eb08cad465c5fc0de53f75aaecf7803f0945 (patch) (unidiff)
tree422b73af760cdd44e4fbbc96bd6876a15939ff19 /noncore/net/mail/libmailwrapper
parente889485e945d8fa9564566f286114be10d2a1ce5 (diff)
downloadopie-d1a7eb08cad465c5fc0de53f75aaecf7803f0945.zip
opie-d1a7eb08cad465c5fc0de53f75aaecf7803f0945.tar.gz
opie-d1a7eb08cad465c5fc0de53f75aaecf7803f0945.tar.bz2
- dir handling for mbox accounts (delete, new, delete all mail)
- fixed memory leaks in mbox account class - reduced count of used string constants while using "tr" with context string - mbox displays messages into global status bar - fixed a possible raise condition when deleting a mail directory
Diffstat (limited to 'noncore/net/mail/libmailwrapper') (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/mail/libmailwrapper/genericwrapper.h2
-rw-r--r--noncore/net/mail/libmailwrapper/mboxwrapper.cpp126
-rw-r--r--noncore/net/mail/libmailwrapper/mboxwrapper.h8
-rw-r--r--noncore/net/mail/libmailwrapper/pop3wrapper.cpp7
-rw-r--r--noncore/net/mail/libmailwrapper/pop3wrapper.h3
5 files changed, 113 insertions, 33 deletions
diff --git a/noncore/net/mail/libmailwrapper/genericwrapper.h b/noncore/net/mail/libmailwrapper/genericwrapper.h
index 12f6928..90c4b50 100644
--- a/noncore/net/mail/libmailwrapper/genericwrapper.h
+++ b/noncore/net/mail/libmailwrapper/genericwrapper.h
@@ -49,8 +49,6 @@ protected:
49 static void fillParameters(RecPart&target,clist*parameters); 49 static void fillParameters(RecPart&target,clist*parameters);
50 static QString getencoding(mailmime_mechanism*aEnc); 50 static QString getencoding(mailmime_mechanism*aEnc);
51 51
52 POP3account *account;
53 mailpop3 *m_pop3;
54 QString msgTempName; 52 QString msgTempName;
55 unsigned int last_msg_id; 53 unsigned int last_msg_id;
56 QMap<QString,encodedString*> bodyCache; 54 QMap<QString,encodedString*> bodyCache;
diff --git a/noncore/net/mail/libmailwrapper/mboxwrapper.cpp b/noncore/net/mail/libmailwrapper/mboxwrapper.cpp
index 6d69263..162a0c9 100644
--- a/noncore/net/mail/libmailwrapper/mboxwrapper.cpp
+++ b/noncore/net/mail/libmailwrapper/mboxwrapper.cpp
@@ -2,9 +2,9 @@
2#include "mailtypes.h" 2#include "mailtypes.h"
3#include "mailwrapper.h" 3#include "mailwrapper.h"
4#include <libetpan/libetpan.h> 4#include <libetpan/libetpan.h>
5#include <libetpan/mailstorage.h>
6#include <qdir.h> 5#include <qdir.h>
7#include <stdlib.h> 6#include <stdlib.h>
7#include <qpe/global.h>
8 8
9MBOXwrapper::MBOXwrapper(const QString & mbox_dir) 9MBOXwrapper::MBOXwrapper(const QString & mbox_dir)
10 : Genericwrapper(),MBOXPath(mbox_dir) 10 : Genericwrapper(),MBOXPath(mbox_dir)
@@ -24,19 +24,15 @@ void MBOXwrapper::listMessages(const QString & mailbox, QList<RecMail> &target )
24 mailstorage*storage = mailstorage_new(NULL); 24 mailstorage*storage = mailstorage_new(NULL);
25 QString p = MBOXPath+"/"; 25 QString p = MBOXPath+"/";
26 p+=mailbox; 26 p+=mailbox;
27 char*fname = 0; 27
28 28 int r = mbox_mailstorage_init(storage,(char*)p.latin1(),0,0,0);
29 fname = strdup(p.latin1());
30
31 int r = mbox_mailstorage_init(storage,fname,0,0,0);
32 mailfolder*folder; 29 mailfolder*folder;
33 folder = mailfolder_new( storage,fname,NULL); 30 folder = mailfolder_new( storage,(char*)p.latin1(),NULL);
34 r = mailfolder_connect(folder); 31 r = mailfolder_connect(folder);
35 if (r != MAIL_NO_ERROR) { 32 if (r != MAIL_NO_ERROR) {
36 qDebug("Error initializing mbox"); 33 qDebug("Error initializing mbox");
37 mailfolder_free(folder); 34 mailfolder_free(folder);
38 mailstorage_free(storage); 35 mailstorage_free(storage);
39 free(fname);
40 return; 36 return;
41 } 37 }
42 mailmessage_list * env_list = 0; 38 mailmessage_list * env_list = 0;
@@ -45,7 +41,6 @@ void MBOXwrapper::listMessages(const QString & mailbox, QList<RecMail> &target )
45 qDebug("Error message list"); 41 qDebug("Error message list");
46 mailfolder_free(folder); 42 mailfolder_free(folder);
47 mailstorage_free(storage); 43 mailstorage_free(storage);
48 free(fname);
49 return; 44 return;
50 } 45 }
51 r = mailsession_get_envelopes_list(folder->fld_session, env_list); 46 r = mailsession_get_envelopes_list(folder->fld_session, env_list);
@@ -56,12 +51,12 @@ void MBOXwrapper::listMessages(const QString & mailbox, QList<RecMail> &target )
56 } 51 }
57 mailfolder_free(folder); 52 mailfolder_free(folder);
58 mailstorage_free(storage); 53 mailstorage_free(storage);
59 free(fname);
60 return; 54 return;
61 } 55 }
62 mailimf_references * refs; 56 mailimf_references * refs;
63 57
64 for(int i = 0 ; i < carray_count(env_list->msg_tab) ; ++i) { 58 uint32_t i = 0;
59 for(; i < carray_count(env_list->msg_tab) ; ++i) {
65 mailmessage * msg; 60 mailmessage * msg;
66 QBitArray mFlags(7); 61 QBitArray mFlags(7);
67 msg = (mailmessage*)carray_get(env_list->msg_tab, i); 62 msg = (mailmessage*)carray_get(env_list->msg_tab, i);
@@ -110,7 +105,7 @@ void MBOXwrapper::listMessages(const QString & mailbox, QList<RecMail> &target )
110 mailfolder_disconnect(folder); 105 mailfolder_disconnect(folder);
111 mailfolder_free(folder); 106 mailfolder_free(folder);
112 mailstorage_free(storage); 107 mailstorage_free(storage);
113 free(fname); 108 Global::statusMessage(tr("Mailbox has %1 mail(s)").arg(i));
114} 109}
115 110
116QList<Folder>* MBOXwrapper::listFolders() 111QList<Folder>* MBOXwrapper::listFolders()
@@ -134,10 +129,9 @@ void MBOXwrapper::deleteMail(const RecMail&mail)
134 mailstorage*storage = mailstorage_new(NULL); 129 mailstorage*storage = mailstorage_new(NULL);
135 QString p = MBOXPath+"/"; 130 QString p = MBOXPath+"/";
136 p+=mail.getMbox(); 131 p+=mail.getMbox();
137 mailmessage * msg; 132 int r = mbox_mailstorage_init(storage,(char*)p.latin1(),0,0,0);
138 int r = mbox_mailstorage_init(storage,strdup(p.latin1()),0,0,0);
139 mailfolder*folder; 133 mailfolder*folder;
140 folder = mailfolder_new( storage,strdup(p.latin1()),NULL); 134 folder = mailfolder_new( storage,(char*)p.latin1(),NULL);
141 r = mailfolder_connect(folder); 135 r = mailfolder_connect(folder);
142 if (r != MAIL_NO_ERROR) { 136 if (r != MAIL_NO_ERROR) {
143 qDebug("Error initializing mbox"); 137 qDebug("Error initializing mbox");
@@ -167,9 +161,9 @@ RecBody MBOXwrapper::fetchBody( const RecMail &mail )
167 char*data=0; 161 char*data=0;
168 size_t size; 162 size_t size;
169 163
170 int r = mbox_mailstorage_init(storage,strdup(p.latin1()),0,0,0); 164 int r = mbox_mailstorage_init(storage,(char*)p.latin1(),0,0,0);
171 mailfolder*folder; 165 mailfolder*folder;
172 folder = mailfolder_new( storage,strdup(p.latin1()),NULL); 166 folder = mailfolder_new( storage,(char*)p.latin1(),NULL);
173 r = mailfolder_connect(folder); 167 r = mailfolder_connect(folder);
174 if (r != MAIL_NO_ERROR) { 168 if (r != MAIL_NO_ERROR) {
175 qDebug("Error initializing mbox"); 169 qDebug("Error initializing mbox");
@@ -205,8 +199,22 @@ void MBOXwrapper::mbox_progress( size_t current, size_t maximum )
205 qDebug("MBOX %i von %i",current,maximum); 199 qDebug("MBOX %i von %i",current,maximum);
206} 200}
207 201
208void MBOXwrapper::createFolder(const QString&) 202int MBOXwrapper::createMbox(const QString&folder,const Folder*,const QString&,bool )
209{ 203{
204 QString p = MBOXPath+"/";
205 p+=folder;
206 QFileInfo fi(p);
207 if (fi.exists()) {
208 Global::statusMessage(tr("Mailbox exists."));
209 return 0;
210 }
211 mailmbox_folder*f = 0;
212 if (mailmbox_init(p.latin1(),0,1,0,&f) != MAIL_NO_ERROR) {
213 Global::statusMessage(tr("Error init folder"));
214 return 0;
215 }
216 if (f) mailmbox_done(f);
217 return 1;
210} 218}
211 219
212void MBOXwrapper::storeMessage(const char*msg,size_t length, const QString&folder) 220void MBOXwrapper::storeMessage(const char*msg,size_t length, const QString&folder)
@@ -216,12 +224,12 @@ void MBOXwrapper::storeMessage(const char*msg,size_t length, const QString&folde
216 mailmbox_folder*f = 0; 224 mailmbox_folder*f = 0;
217 int r = mailmbox_init(p.latin1(),0,1,0,&f); 225 int r = mailmbox_init(p.latin1(),0,1,0,&f);
218 if (r != MAIL_NO_ERROR) { 226 if (r != MAIL_NO_ERROR) {
219 qDebug("Error init folder"); 227 Global::statusMessage(tr("Error init folder"));
220 return; 228 return;
221 } 229 }
222 r = mailmbox_append_message(f,msg,length); 230 r = mailmbox_append_message(f,msg,length);
223 if (r != MAIL_NO_ERROR) { 231 if (r != MAIL_NO_ERROR) {
224 qDebug("Error writing message folder"); 232 Global::statusMessage(tr("Error writing to message folder"));
225 } 233 }
226 mailmbox_done(f); 234 mailmbox_done(f);
227} 235}
@@ -236,26 +244,26 @@ void MBOXwrapper::fetchRawBody(const RecMail&mail,char**target,size_t*length)
236 char*data=0; 244 char*data=0;
237 size_t size; 245 size_t size;
238 246
239 int r = mbox_mailstorage_init(storage,strdup(p.latin1()),0,0,0); 247 int r = mbox_mailstorage_init(storage,(char*)p.latin1(),0,0,0);
240 mailfolder*folder; 248 mailfolder*folder;
241 folder = mailfolder_new( storage,strdup(p.latin1()),NULL); 249 folder = mailfolder_new( storage,(char*)p.latin1(),NULL);
242 r = mailfolder_connect(folder); 250 r = mailfolder_connect(folder);
243 if (r != MAIL_NO_ERROR) { 251 if (r != MAIL_NO_ERROR) {
244 qDebug("Error initializing mbox"); 252 Global::statusMessage(tr("Error initializing mbox"));
245 mailfolder_free(folder); 253 mailfolder_free(folder);
246 mailstorage_free(storage); 254 mailstorage_free(storage);
247 return; 255 return;
248 } 256 }
249 r = mailsession_get_message(folder->fld_session, mail.getNumber(), &msg); 257 r = mailsession_get_message(folder->fld_session, mail.getNumber(), &msg);
250 if (r != MAIL_NO_ERROR) { 258 if (r != MAIL_NO_ERROR) {
251 qDebug("Error fetching mail %i",mail.getNumber()); 259 Global::statusMessage(tr("Error fetching mail %i").arg(mail.getNumber()));
252 mailfolder_free(folder); 260 mailfolder_free(folder);
253 mailstorage_free(storage); 261 mailstorage_free(storage);
254 return; 262 return;
255 } 263 }
256 r = mailmessage_fetch(msg,&data,&size); 264 r = mailmessage_fetch(msg,&data,&size);
257 if (r != MAIL_NO_ERROR) { 265 if (r != MAIL_NO_ERROR) {
258 qDebug("Error fetching mail %i",mail.getNumber()); 266 Global::statusMessage(tr("Error fetching mail %i").arg(mail.getNumber()));
259 mailfolder_free(folder); 267 mailfolder_free(folder);
260 mailstorage_free(storage); 268 mailstorage_free(storage);
261 mailmessage_free(msg); 269 mailmessage_free(msg);
@@ -278,6 +286,14 @@ void MBOXwrapper::deleteMails(const QString & mailbox,QList<RecMail> &target)
278 qDebug("Error init folder"); 286 qDebug("Error init folder");
279 return; 287 return;
280 } 288 }
289 deleteMails(f,target);
290 mailmbox_done(f);
291}
292
293void MBOXwrapper::deleteMails(mailmbox_folder*f,QList<RecMail> &target)
294{
295 if (!f) return;
296 int r;
281 for (unsigned int i=0; i < target.count();++i) { 297 for (unsigned int i=0; i < target.count();++i) {
282 r = mailmbox_delete_msg(f,target.at(i)->getNumber()); 298 r = mailmbox_delete_msg(f,target.at(i)->getNumber());
283 if (r!=MAILMBOX_NO_ERROR) { 299 if (r!=MAILMBOX_NO_ERROR) {
@@ -288,6 +304,64 @@ void MBOXwrapper::deleteMails(const QString & mailbox,QList<RecMail> &target)
288 if (r != MAILMBOX_NO_ERROR) { 304 if (r != MAILMBOX_NO_ERROR) {
289 qDebug("error expunge mailbox"); 305 qDebug("error expunge mailbox");
290 } 306 }
291 mailmbox_done(f); 307}
308
309int MBOXwrapper::deleteAllMail(const Folder*tfolder)
310{
311 if (!tfolder) return 0;
312 QString p = MBOXPath+tfolder->getDisplayName();
313 int res = 1;
314
315 mailfolder*folder = 0;
316 mailmessage_list*l=0;
317 mailstorage*storage = mailstorage_new(NULL);
318 int r = mbox_mailstorage_init(storage,(char*)p.latin1(),0,0,0);
319 if (r != MAIL_NO_ERROR) {
320 Global::statusMessage(tr("Error initializing mbox"));
321 res = 0;
322 }
323 if (res) {
324 folder = mailfolder_new( storage,(char*)p.latin1(),NULL);
325 r = mailfolder_connect(folder);
326 if (r != MAIL_NO_ERROR) {
327 Global::statusMessage(tr("Error initializing mbox"));
328 res = 0;
329 }
330 }
331 if (res) {
332 r = mailsession_get_messages_list(folder->fld_session,&l);
333 if (r != MAIL_NO_ERROR) {
334 qDebug("Error message list");
335 res=0;
336 }
337 }
338 for(unsigned int i = 0 ; l!= 0 && res==1 && i < carray_count(l->msg_tab) ; ++i) {
339 r = mailsession_remove_message(folder->fld_session,i+1);
340 if (r != MAIL_NO_ERROR) {
341 Global::statusMessage(tr("Error deleting mail %1").arg(i+1));
342 res = 0;
343 break;
344 }
345 }
346 if (l) mailmessage_list_free(l);
347 if (folder) mailfolder_free(folder);
348 if (storage) mailstorage_free(storage);
349 return res;
350}
351
352int MBOXwrapper::deleteMbox(const Folder*tfolder)
353{
354 if (!tfolder) return 0;
355 QString p = MBOXPath+tfolder->getDisplayName();
356 QFile fi(p);
357 if (!fi.exists()) {
358 Global::statusMessage(tr("Mailbox doesn't exist."));
359 return 0;
360 }
361 if (!fi.remove()) {
362 Global::statusMessage(tr("Error deleting Mailbox."));
363 return 0;
364 }
365 return 1;
292} 366}
293 367
diff --git a/noncore/net/mail/libmailwrapper/mboxwrapper.h b/noncore/net/mail/libmailwrapper/mboxwrapper.h
index f64ad52..226a544 100644
--- a/noncore/net/mail/libmailwrapper/mboxwrapper.h
+++ b/noncore/net/mail/libmailwrapper/mboxwrapper.h
@@ -6,6 +6,7 @@
6 6
7class RecMail; 7class RecMail;
8class RecBody; 8class RecBody;
9struct mailmbox_folder;
9 10
10class MBOXwrapper : public Genericwrapper 11class MBOXwrapper : public Genericwrapper
11{ 12{
@@ -19,7 +20,10 @@ public:
19 20
20 virtual void deleteMail(const RecMail&mail); 21 virtual void deleteMail(const RecMail&mail);
21 virtual void answeredMail(const RecMail&mail); 22 virtual void answeredMail(const RecMail&mail);
22 virtual void createFolder(const QString&aFolder); 23
24 virtual int createMbox(const QString&folder,const Folder*f=0,const QString&d="",bool s=false);
25 virtual int deleteMbox(const Folder*);
26
23 virtual void storeMessage(const char*msg,size_t length, const QString&folder); 27 virtual void storeMessage(const char*msg,size_t length, const QString&folder);
24 28
25 virtual RecBody fetchBody( const RecMail &mail ); 29 virtual RecBody fetchBody( const RecMail &mail );
@@ -27,8 +31,10 @@ public:
27 31
28 virtual void fetchRawBody(const RecMail&mail,char**target,size_t*length); 32 virtual void fetchRawBody(const RecMail&mail,char**target,size_t*length);
29 virtual void deleteMails(const QString & mailbox,QList<RecMail> &target); 33 virtual void deleteMails(const QString & mailbox,QList<RecMail> &target);
34 virtual int deleteAllMail(const Folder*);
30 35
31protected: 36protected:
37 static void deleteMails(mailmbox_folder*f,QList<RecMail> &target);
32 QString MBOXPath; 38 QString MBOXPath;
33}; 39};
34 40
diff --git a/noncore/net/mail/libmailwrapper/pop3wrapper.cpp b/noncore/net/mail/libmailwrapper/pop3wrapper.cpp
index efd83ba..b85fbf6 100644
--- a/noncore/net/mail/libmailwrapper/pop3wrapper.cpp
+++ b/noncore/net/mail/libmailwrapper/pop3wrapper.cpp
@@ -2,9 +2,8 @@
2#include "pop3wrapper.h" 2#include "pop3wrapper.h"
3#include "mailtypes.h" 3#include "mailtypes.h"
4#include "logindialog.h" 4#include "logindialog.h"
5#include <libetpan/mailpop3.h> 5#include <libetpan/libetpan.h>
6#include <libetpan/mailmime.h> 6#include <qpe/global.h>
7#include <libetpan/data_message_driver.h>
8#include <qfile.h> 7#include <qfile.h>
9 8
10/* we don't fetch messages larger than 5 MB */ 9/* we don't fetch messages larger than 5 MB */
@@ -112,6 +111,7 @@ void POP3wrapper::listMessages(const QString &, QList<RecMail> &target )
112 111
113 login(); 112 login();
114 if (!m_pop3) return; 113 if (!m_pop3) return;
114
115 mailpop3_list( m_pop3, &messages ); 115 mailpop3_list( m_pop3, &messages );
116 116
117 for (unsigned int i = 0; i < carray_count(messages);++i) { 117 for (unsigned int i = 0; i < carray_count(messages);++i) {
@@ -132,6 +132,7 @@ void POP3wrapper::listMessages(const QString &, QList<RecMail> &target )
132 target.append( mail ); 132 target.append( mail );
133 free(header); 133 free(header);
134 } 134 }
135 Global::statusMessage( tr("Mailbox contains %1 mail(s)").arg(carray_count(messages)-m_pop3->pop3_deleted_count));
135} 136}
136 137
137void POP3wrapper::login() 138void POP3wrapper::login()
diff --git a/noncore/net/mail/libmailwrapper/pop3wrapper.h b/noncore/net/mail/libmailwrapper/pop3wrapper.h
index b738cca..7502720 100644
--- a/noncore/net/mail/libmailwrapper/pop3wrapper.h
+++ b/noncore/net/mail/libmailwrapper/pop3wrapper.h
@@ -26,7 +26,8 @@ public:
26protected: 26protected:
27 void login(); 27 void login();
28 void logout(); 28 void logout();
29 29 POP3account *account;
30 mailpop3 *m_pop3;
30}; 31};
31 32
32#endif 33#endif