summaryrefslogtreecommitdiff
authoralwin <alwin>2004-10-23 19:42:19 (UTC)
committer alwin <alwin>2004-10-23 19:42:19 (UTC)
commitb3d4cb2af9cd4b3a56b581ba89a4c9fa0d9312af (patch) (unidiff)
tree993e629f5f8c1dcf66e1c294d840cc4aa0100ae1
parentb5d111eb79896d02aa13d41a04ce6aa4dbc4aa49 (diff)
downloadopie-b3d4cb2af9cd4b3a56b581ba89a4c9fa0d9312af.zip
opie-b3d4cb2af9cd4b3a56b581ba89a4c9fa0d9312af.tar.gz
opie-b3d4cb2af9cd4b3a56b581ba89a4c9fa0d9312af.tar.bz2
holla - fixed a wonderfull bug letting opie-mail crash when
accessing some pop3-server
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/mail/libmailwrapper/genericwrapper.cpp15
1 files changed, 7 insertions, 8 deletions
diff --git a/noncore/net/mail/libmailwrapper/genericwrapper.cpp b/noncore/net/mail/libmailwrapper/genericwrapper.cpp
index 3e4293b..1caa375 100644
--- a/noncore/net/mail/libmailwrapper/genericwrapper.cpp
+++ b/noncore/net/mail/libmailwrapper/genericwrapper.cpp
@@ -116,49 +116,49 @@ QString Genericwrapper::getencoding(mailmime_mechanism*aEnc)
116 enc = "8bit"; 116 enc = "8bit";
117 break; 117 break;
118 case MAILMIME_MECHANISM_BINARY: 118 case MAILMIME_MECHANISM_BINARY:
119 enc = "binary"; 119 enc = "binary";
120 break; 120 break;
121 case MAILMIME_MECHANISM_QUOTED_PRINTABLE: 121 case MAILMIME_MECHANISM_QUOTED_PRINTABLE:
122 enc = "quoted-printable"; 122 enc = "quoted-printable";
123 break; 123 break;
124 case MAILMIME_MECHANISM_BASE64: 124 case MAILMIME_MECHANISM_BASE64:
125 enc = "base64"; 125 enc = "base64";
126 break; 126 break;
127 case MAILMIME_MECHANISM_TOKEN: 127 case MAILMIME_MECHANISM_TOKEN:
128 default: 128 default:
129 if (aEnc->enc_token) { 129 if (aEnc->enc_token) {
130 enc = QString(aEnc->enc_token); 130 enc = QString(aEnc->enc_token);
131 } 131 }
132 break; 132 break;
133 } 133 }
134 return enc; 134 return enc;
135} 135}
136 136
137void Genericwrapper::traverseBody(RecBodyP&target,mailmessage*message,mailmime*mime,QValueList<int>recList,unsigned int current_rec,int current_count) 137void Genericwrapper::traverseBody(RecBodyP&target,mailmessage*message,mailmime*mime,QValueList<int>recList,unsigned int current_rec,int current_count)
138{ 138{
139 if (current_rec >= 10) { 139 if (current_rec >= 10) {
140 odebug << "too deep recursion!" << oendl; 140 odebug << "too deep recursion!" << oendl;
141 } 141 }
142 if (!message || !mime) { 142 if (!message || !mime) {
143 return; 143 return;
144 } 144 }
145 int r; 145 int r;
146 char*data = 0; 146 char*data = 0;
147 size_t len; 147 size_t len;
148 clistiter * cur = 0; 148 clistiter * cur = 0;
149 QString b; 149 QString b;
150 RecPartP part = new RecPart(); 150 RecPartP part = new RecPart();
151 151
152 switch (mime->mm_type) { 152 switch (mime->mm_type) {
153 case MAILMIME_SINGLE: 153 case MAILMIME_SINGLE:
154 { 154 {
155 QValueList<int>countlist = recList; 155 QValueList<int>countlist = recList;
156 countlist.append(current_count); 156 countlist.append(current_count);
157 r = mailmessage_fetch_section(message,mime,&data,&len); 157 r = mailmessage_fetch_section(message,mime,&data,&len);
158 part->setSize(len); 158 part->setSize(len);
159 part->setPositionlist(countlist); 159 part->setPositionlist(countlist);
160 b = gen_attachment_id(); 160 b = gen_attachment_id();
161 part->setIdentifier(b); 161 part->setIdentifier(b);
162 fillSingleBody(part,message,mime); 162 fillSingleBody(part,message,mime);
163 if (part->Type()=="text" && target->Bodytext().isNull()) { 163 if (part->Type()=="text" && target->Bodytext().isNull()) {
164 encodedString*rs = new encodedString(); 164 encodedString*rs = new encodedString();
@@ -253,49 +253,49 @@ QString Genericwrapper::parseDateTime( mailimf_date_time *date )
253 253
254QString Genericwrapper::parseAddressList( mailimf_address_list *list ) 254QString Genericwrapper::parseAddressList( mailimf_address_list *list )
255{ 255{
256 QString result( "" ); 256 QString result( "" );
257 257
258 bool first = true; 258 bool first = true;
259 if (list == 0) return result; 259 if (list == 0) return result;
260 for ( clistiter *current = clist_begin( list->ad_list ); current != NULL; current = current->next ) { 260 for ( clistiter *current = clist_begin( list->ad_list ); current != NULL; current = current->next ) {
261 mailimf_address *addr = (mailimf_address *) current->data; 261 mailimf_address *addr = (mailimf_address *) current->data;
262 262
263 if ( !first ) { 263 if ( !first ) {
264 result.append( "," ); 264 result.append( "," );
265 } else { 265 } else {
266 first = false; 266 first = false;
267 } 267 }
268 268
269 switch ( addr->ad_type ) { 269 switch ( addr->ad_type ) {
270 case MAILIMF_ADDRESS_MAILBOX: 270 case MAILIMF_ADDRESS_MAILBOX:
271 result.append( parseMailbox( addr->ad_data.ad_mailbox ) ); 271 result.append( parseMailbox( addr->ad_data.ad_mailbox ) );
272 break; 272 break;
273 case MAILIMF_ADDRESS_GROUP: 273 case MAILIMF_ADDRESS_GROUP:
274 result.append( parseGroup( addr->ad_data.ad_group ) ); 274 result.append( parseGroup( addr->ad_data.ad_group ) );
275 break; 275 break;
276 default: 276 default:
277 odebug << "Generic: unkown mailimf address type" << oendl; 277 odebug << "Generic: unkown mailimf address type" << oendl;
278 break; 278 break;
279 } 279 }
280 } 280 }
281 281
282 return result; 282 return result;
283} 283}
284 284
285QString Genericwrapper::parseGroup( mailimf_group *group ) 285QString Genericwrapper::parseGroup( mailimf_group *group )
286{ 286{
287 QString result( "" ); 287 QString result( "" );
288 288
289 result.append( group->grp_display_name ); 289 result.append( group->grp_display_name );
290 result.append( ": " ); 290 result.append( ": " );
291 291
292 if ( group->grp_mb_list != NULL ) { 292 if ( group->grp_mb_list != NULL ) {
293 result.append( parseMailboxList( group->grp_mb_list ) ); 293 result.append( parseMailboxList( group->grp_mb_list ) );
294 } 294 }
295 295
296 result.append( ";" ); 296 result.append( ";" );
297 297
298 return result; 298 return result;
299} 299}
300 300
301QString Genericwrapper::parseMailbox( mailimf_mailbox *box ) 301QString Genericwrapper::parseMailbox( mailimf_mailbox *box )
@@ -346,132 +346,131 @@ encodedString* Genericwrapper::fetchRawPart(const RecMailP&,const RecPartP&part)
346{ 346{
347 QMap<QString,encodedString*>::ConstIterator it = bodyCache.find(part->Identifier()); 347 QMap<QString,encodedString*>::ConstIterator it = bodyCache.find(part->Identifier());
348 if (it==bodyCache.end()) return new encodedString(); 348 if (it==bodyCache.end()) return new encodedString();
349 encodedString*t = it.data(); 349 encodedString*t = it.data();
350 return t; 350 return t;
351} 351}
352 352
353QString Genericwrapper::fetchTextPart(const RecMailP&mail,const RecPartP&part) 353QString Genericwrapper::fetchTextPart(const RecMailP&mail,const RecPartP&part)
354{ 354{
355 encodedString*t = fetchDecodedPart(mail,part); 355 encodedString*t = fetchDecodedPart(mail,part);
356 QString text=t->Content(); 356 QString text=t->Content();
357 delete t; 357 delete t;
358 return text; 358 return text;
359} 359}
360 360
361void Genericwrapper::cleanMimeCache() 361void Genericwrapper::cleanMimeCache()
362{ 362{
363 QMap<QString,encodedString*>::Iterator it = bodyCache.begin(); 363 QMap<QString,encodedString*>::Iterator it = bodyCache.begin();
364 for (;it!=bodyCache.end();++it) { 364 for (;it!=bodyCache.end();++it) {
365 encodedString*t = it.data(); 365 encodedString*t = it.data();
366 //it.setValue(0); 366 //it.setValue(0);
367 if (t) delete t; 367 if (t) delete t;
368 } 368 }
369 bodyCache.clear(); 369 bodyCache.clear();
370 odebug << "Genericwrapper: cache cleaned" << oendl; 370 odebug << "Genericwrapper: cache cleaned" << oendl;
371} 371}
372 372
373QStringList Genericwrapper::parseInreplies(mailimf_in_reply_to * in_replies) 373QStringList Genericwrapper::parseInreplies(mailimf_in_reply_to * in_replies)
374{ 374{
375 QStringList res; 375 QStringList res;
376 if (!in_replies || !in_replies->mid_list) return res; 376 if (!in_replies || !in_replies->mid_list) return res;
377 clistiter * current = 0; 377 clistiter * current = 0;
378 for ( current = clist_begin( in_replies->mid_list ); current != NULL; current = current->next ) { 378 for ( current = clist_begin( in_replies->mid_list ); current != NULL; current = current->next ) {
379 QString h((char*)current->data); 379 QString h((char*)current->data);
380 while (h.length()>0 && h[0]=='<') { 380 while (h.length()>0 && h[0]=='<') {
381 h.remove(0,1); 381 h.remove(0,1);
382 } 382 }
383 while (h.length()>0 && h[h.length()-1]=='>') { 383 while (h.length()>0 && h[h.length()-1]=='>') {
384 h.remove(h.length()-1,1); 384 h.remove(h.length()-1,1);
385 } 385 }
386 if (h.length()>0) { 386 if (h.length()>0) {
387 res.append(h); 387 res.append(h);
388 } 388 }
389 } 389 }
390 return res; 390 return res;
391} 391}
392 392
393void Genericwrapper::parseList(QValueList<Opie::Core::OSmartPointer<RecMail> > &target,mailsession*session,const QString&mailbox,bool mbox_as_to) 393void Genericwrapper::parseList(QValueList<Opie::Core::OSmartPointer<RecMail> > &target,mailsession*session,const QString&mailbox,bool mbox_as_to)
394{ 394{
395 int r; 395 int r;
396 mailmessage_list * env_list = 0; 396 mailmessage_list * env_list = 0;
397 r = mailsession_get_messages_list(session,&env_list); 397 r = mailsession_get_messages_list(session,&env_list);
398 if (r != MAIL_NO_ERROR) { 398 if (r != MAIL_NO_ERROR) {
399 odebug << "Error message list" << oendl; 399 odebug << "Error message list" << oendl;
400 return; 400 return;
401 } 401 }
402 r = mailsession_get_envelopes_list(session, env_list); 402 r = mailsession_get_envelopes_list(session, env_list);
403 if (r != MAIL_NO_ERROR) { 403 if (r != MAIL_NO_ERROR) {
404 odebug << "Error filling message list" << oendl; 404 odebug << "Error filling message list" << oendl;
405 if (env_list) { 405 if (env_list) {
406 mailmessage_list_free(env_list); 406 mailmessage_list_free(env_list);
407 } 407 }
408 return; 408 return;
409 } 409 }
410 mailimf_references * refs = 0; 410 mailimf_references * refs = 0;
411 mailimf_in_reply_to * in_replies = 0; 411 mailimf_in_reply_to * in_replies = 0;
412 uint32_t i = 0; 412 uint32_t i = 0;
413 for(; i < carray_count(env_list->msg_tab) ; ++i) { 413 for(; i < carray_count(env_list->msg_tab) ; ++i) {
414 mailmessage * msg; 414 mailmessage * msg;
415 QBitArray mFlags(7); 415 QBitArray mFlags(7);
416 msg = (mailmessage*)carray_get(env_list->msg_tab, i); 416 msg = (mailmessage*)carray_get(env_list->msg_tab, i);
417 if (msg->msg_fields == NULL) { 417 if (msg->msg_fields == NULL) {
418 //odebug << "could not fetch envelope of message " << i << "" << oendl; 418 //odebug << "could not fetch envelope of message " << i << "" << oendl;
419 continue; 419 continue;
420 } 420 }
421 RecMailP mail = new RecMail(); 421 RecMailP mail = new RecMail();
422 mail->setWrapper(this); 422 mail->setWrapper(this);
423 mail_flags * flag_result = 0; 423 mail_flags * flag_result = 0;
424 r = mailmessage_get_flags(msg,&flag_result); 424 r = mailmessage_get_flags(msg,&flag_result);
425 if (r == MAIL_ERROR_NOT_IMPLEMENTED) { 425 if (r == MAIL_ERROR_NOT_IMPLEMENTED) {
426 mFlags.setBit(FLAG_SEEN); 426 mFlags.setBit(FLAG_SEEN);
427 } 427 }
428 mailimf_single_fields single_fields; 428 mailimf_single_fields single_fields;
429 mailimf_single_fields_init(&single_fields, msg->msg_fields); 429 mailimf_single_fields_init(&single_fields, msg->msg_fields);
430 mail->setMsgsize(msg->msg_size); 430 mail->setMsgsize(msg->msg_size);
431 mail->setFlags(mFlags); 431 mail->setFlags(mFlags);
432 mail->setMbox(mailbox); 432 mail->setMbox(mailbox);
433 mail->setNumber(msg->msg_index); 433 mail->setNumber(msg->msg_index);
434 if (single_fields.fld_subject) 434 if (single_fields.fld_subject)
435 mail->setSubject( convert_String(single_fields.fld_subject->sbj_value)); 435 mail->setSubject( convert_String(single_fields.fld_subject->sbj_value));
436 if (single_fields.fld_from) 436 if (single_fields.fld_from)
437 mail->setFrom(parseMailboxList(single_fields.fld_from->frm_mb_list)); 437 mail->setFrom(parseMailboxList(single_fields.fld_from->frm_mb_list));
438 if (!mbox_as_to) { 438 if (!mbox_as_to) {
439 if (single_fields.fld_to) 439 if (single_fields.fld_to)
440 mail->setTo( parseAddressList( single_fields.fld_to->to_addr_list ) ); 440 mail->setTo( parseAddressList( single_fields.fld_to->to_addr_list ) );
441 } else { 441 } else {
442 mail->setTo(mailbox); 442 mail->setTo(mailbox);
443 } 443 }
444 if (single_fields.fld_cc) 444 if (single_fields.fld_cc)
445 mail->setCC( parseAddressList( single_fields.fld_cc->cc_addr_list ) ); 445 mail->setCC( parseAddressList( single_fields.fld_cc->cc_addr_list ) );
446 if (single_fields.fld_bcc) 446 if (single_fields.fld_bcc)
447 mail->setBcc( parseAddressList( single_fields.fld_bcc->bcc_addr_list ) ); 447 mail->setBcc( parseAddressList( single_fields.fld_bcc->bcc_addr_list ) );
448 if (single_fields.fld_orig_date) 448 if (single_fields.fld_orig_date)
449 mail->setDate( parseDateTime( single_fields.fld_orig_date->dt_date_time ) ); 449 mail->setDate( parseDateTime( single_fields.fld_orig_date->dt_date_time ) );
450 // crashes when accessing pop3 account? 450 // crashes when accessing pop3 account?
451 if (single_fields.fld_message_id->mid_value) { 451 if (single_fields.fld_message_id && single_fields.fld_message_id->mid_value) {
452 mail->setMsgid(QString(single_fields.fld_message_id->mid_value)); 452 mail->setMsgid(QString(single_fields.fld_message_id->mid_value));
453 odebug << "Msgid == " << mail->Msgid().latin1() << "" << oendl;
454 } 453 }
455 454
456 if (single_fields.fld_reply_to) { 455 if (single_fields.fld_reply_to) {
457 QStringList t = parseAddressList(single_fields.fld_reply_to->rt_addr_list); 456 QStringList t = parseAddressList(single_fields.fld_reply_to->rt_addr_list);
458 if (t.count()>0) { 457 if (t.count()>0) {
459 mail->setReplyto(t[0]); 458 mail->setReplyto(t[0]);
460 } 459 }
461 } 460 }
462#if 0 461#if 0
463 refs = single_fields.fld_references; 462 refs = single_fields.fld_references;
464 if (refs && refs->mid_list && clist_count(refs->mid_list)) { 463 if (refs && refs->mid_list && clist_count(refs->mid_list)) {
465 char * text = (char*)refs->mid_list->first->data; 464 char * text = (char*)refs->mid_list->first->data;
466 mail->setReplyto(QString(text)); 465 mail->setReplyto(QString(text));
467 } 466 }
468#endif 467#endif
469 if (single_fields.fld_in_reply_to && single_fields.fld_in_reply_to->mid_list && 468 if (single_fields.fld_in_reply_to && single_fields.fld_in_reply_to->mid_list &&
470 clist_count(single_fields.fld_in_reply_to->mid_list)) { 469 clist_count(single_fields.fld_in_reply_to->mid_list)) {
471 mail->setInreply(parseInreplies(single_fields.fld_in_reply_to)); 470 mail->setInreply(parseInreplies(single_fields.fld_in_reply_to));
472 } 471 }
473 target.append(mail); 472 target.append(mail);
474 } 473 }
475 if (env_list) { 474 if (env_list) {
476 mailmessage_list_free(env_list); 475 mailmessage_list_free(env_list);
477 } 476 }