-rw-r--r-- | noncore/net/mail/imapwrapper.cpp | 43 | ||||
-rw-r--r-- | noncore/net/mail/imapwrapper.h | 3 | ||||
-rw-r--r-- | noncore/net/mail/libmailwrapper/imapwrapper.cpp | 43 | ||||
-rw-r--r-- | noncore/net/mail/libmailwrapper/imapwrapper.h | 3 |
4 files changed, 84 insertions, 8 deletions
diff --git a/noncore/net/mail/imapwrapper.cpp b/noncore/net/mail/imapwrapper.cpp index f7e93aa..ae196bb 100644 --- a/noncore/net/mail/imapwrapper.cpp +++ b/noncore/net/mail/imapwrapper.cpp | |||
@@ -508,143 +508,180 @@ encodedString*IMAPwrapper::fetchRawPart(const RecMail&mail,const QValueList<int> | |||
508 | if (msg_att_item->att_type == MAILIMAP_MSG_ATT_ITEM_STATIC) { | 508 | if (msg_att_item->att_type == MAILIMAP_MSG_ATT_ITEM_STATIC) { |
509 | if (msg_att_item->att_data.att_static->att_type == MAILIMAP_MSG_ATT_BODY_SECTION) { | 509 | if (msg_att_item->att_data.att_static->att_type == MAILIMAP_MSG_ATT_BODY_SECTION) { |
510 | char*text = msg_att_item->att_data.att_static->att_data.att_body_section->sec_body_part; | 510 | char*text = msg_att_item->att_data.att_static->att_data.att_body_section->sec_body_part; |
511 | /* detach - we take over the content */ | 511 | /* detach - we take over the content */ |
512 | msg_att_item->att_data.att_static->att_data.att_body_section->sec_body_part = 0L; | 512 | msg_att_item->att_data.att_static->att_data.att_body_section->sec_body_part = 0L; |
513 | res->setContent(text,msg_att_item->att_data.att_static->att_data.att_body_section->sec_length); | 513 | res->setContent(text,msg_att_item->att_data.att_static->att_data.att_body_section->sec_length); |
514 | } | 514 | } |
515 | } | 515 | } |
516 | } | 516 | } |
517 | } else { | 517 | } else { |
518 | qDebug("error fetching text: %s",m_imap->imap_response); | 518 | qDebug("error fetching text: %s",m_imap->imap_response); |
519 | } | 519 | } |
520 | if (result) mailimap_fetch_list_free(result); | 520 | if (result) mailimap_fetch_list_free(result); |
521 | return res; | 521 | return res; |
522 | } | 522 | } |
523 | 523 | ||
524 | /* current_recursion is for recursive calls. | 524 | /* current_recursion is for recursive calls. |
525 | current_count means the position inside the internal loop! */ | 525 | current_count means the position inside the internal loop! */ |
526 | void IMAPwrapper::traverseBody(const RecMail&mail,mailimap_body*body,RecBody&target_body, | 526 | void IMAPwrapper::traverseBody(const RecMail&mail,mailimap_body*body,RecBody&target_body, |
527 | int current_recursion,QValueList<int>recList,int current_count) | 527 | int current_recursion,QValueList<int>recList,int current_count) |
528 | { | 528 | { |
529 | if (!body || current_recursion>=10) { | 529 | if (!body || current_recursion>=10) { |
530 | return; | 530 | return; |
531 | } | 531 | } |
532 | ++current_count; | ||
533 | switch (body->bd_type) { | 532 | switch (body->bd_type) { |
534 | case MAILIMAP_BODY_1PART: | 533 | case MAILIMAP_BODY_1PART: |
535 | { | 534 | { |
536 | QValueList<int>countlist = recList; | 535 | QValueList<int>countlist = recList; |
537 | countlist.append(current_count); | 536 | countlist.append(current_count); |
538 | RecPart currentPart; | 537 | RecPart currentPart; |
539 | mailimap_body_type_1part*part1 = body->bd_data.bd_body_1part; | 538 | mailimap_body_type_1part*part1 = body->bd_data.bd_body_1part; |
540 | QString id(""); | 539 | QString id(""); |
541 | currentPart.setPositionlist(countlist); | 540 | currentPart.setPositionlist(countlist); |
542 | for (unsigned int j = 0; j < countlist.count();++j) { | 541 | for (unsigned int j = 0; j < countlist.count();++j) { |
543 | id+=(j>0?" ":""); | 542 | id+=(j>0?" ":""); |
544 | id+=QString("%1").arg(countlist[j]); | 543 | id+=QString("%1").arg(countlist[j]); |
545 | } | 544 | } |
546 | qDebug("ID = %s",id.latin1()); | 545 | qDebug("ID = %s",id.latin1()); |
547 | currentPart.setIdentifier(id); | 546 | currentPart.setIdentifier(id); |
548 | fillSinglePart(currentPart,part1); | 547 | fillSinglePart(currentPart,part1); |
549 | /* important: Check for is NULL 'cause a body can be empty! | 548 | /* important: Check for is NULL 'cause a body can be empty! |
550 | And we put it only into the mail if it is the FIRST part */ | 549 | And we put it only into the mail if it is the FIRST part */ |
551 | if (part1->bd_type==MAILIMAP_BODY_TYPE_1PART_TEXT && target_body.Bodytext().isNull() && countlist[0]==1) { | 550 | if (part1->bd_type==MAILIMAP_BODY_TYPE_1PART_TEXT && target_body.Bodytext().isNull() && countlist[0]==1) { |
552 | QString body_text = fetchTextPart(mail,countlist,true,currentPart.Encoding()); | 551 | QString body_text = fetchTextPart(mail,countlist,true,currentPart.Encoding()); |
553 | target_body.setDescription(currentPart); | 552 | target_body.setDescription(currentPart); |
554 | target_body.setBodytext(body_text); | 553 | target_body.setBodytext(body_text); |
554 | if (countlist.count()>1) { | ||
555 | target_body.addPart(currentPart); | ||
556 | } | ||
555 | } else { | 557 | } else { |
556 | target_body.addPart(currentPart); | 558 | target_body.addPart(currentPart); |
557 | } | 559 | } |
558 | if (part1->bd_type==MAILIMAP_BODY_TYPE_1PART_MSG) { | 560 | if (part1->bd_type==MAILIMAP_BODY_TYPE_1PART_MSG) { |
559 | traverseBody(mail,part1->bd_data.bd_type_msg->bd_body,target_body,current_recursion+1,countlist); | 561 | traverseBody(mail,part1->bd_data.bd_type_msg->bd_body,target_body,current_recursion+1,countlist); |
560 | } | 562 | } |
561 | } | 563 | } |
562 | break; | 564 | break; |
563 | case MAILIMAP_BODY_MPART: | 565 | case MAILIMAP_BODY_MPART: |
564 | { | 566 | { |
567 | QValueList<int>countlist = recList; | ||
565 | clistcell*current=0; | 568 | clistcell*current=0; |
566 | mailimap_body*current_body=0; | 569 | mailimap_body*current_body=0; |
567 | unsigned int ccount = current_count-1; | 570 | unsigned int ccount = 1; |
568 | mailimap_body_type_mpart*mailDescription = body->bd_data.bd_body_mpart; | 571 | mailimap_body_type_mpart*mailDescription = body->bd_data.bd_body_mpart; |
569 | for (current=clist_begin(mailDescription->bd_list);current!=0;current=clist_next(current)) { | 572 | for (current=clist_begin(mailDescription->bd_list);current!=0;current=clist_next(current)) { |
570 | current_body = (mailimap_body*)current->data; | 573 | current_body = (mailimap_body*)current->data; |
571 | traverseBody(mail,current_body,target_body,current_recursion+1,recList,ccount); | 574 | if (current_body->bd_type==MAILIMAP_BODY_MPART) { |
575 | RecPart targetPart; | ||
576 | targetPart.setType("multipart"); | ||
577 | fillMultiPart(targetPart,mailDescription); | ||
578 | countlist.append(current_count); | ||
579 | targetPart.setPositionlist(countlist); | ||
580 | target_body.addPart(targetPart); | ||
581 | QString id(""); | ||
582 | for (unsigned int j = 0; j < countlist.count();++j) { | ||
583 | id+=(j>0?" ":""); | ||
584 | id+=QString("%1").arg(countlist[j]); | ||
585 | } | ||
586 | qDebug("ID(mpart) = %s",id.latin1()); | ||
587 | } | ||
588 | traverseBody(mail,current_body,target_body,current_recursion+1,countlist,ccount); | ||
589 | if (current_body->bd_type==MAILIMAP_BODY_MPART) { | ||
590 | countlist = recList; | ||
591 | } | ||
572 | ++ccount; | 592 | ++ccount; |
573 | } | 593 | } |
574 | } | 594 | } |
575 | break; | 595 | break; |
576 | default: | 596 | default: |
577 | break; | 597 | break; |
578 | } | 598 | } |
579 | } | 599 | } |
580 | 600 | ||
581 | void IMAPwrapper::fillSinglePart(RecPart&target_part,mailimap_body_type_1part*Description) | 601 | void IMAPwrapper::fillSinglePart(RecPart&target_part,mailimap_body_type_1part*Description) |
582 | { | 602 | { |
583 | if (!Description) { | 603 | if (!Description) { |
584 | return; | 604 | return; |
585 | } | 605 | } |
586 | switch (Description->bd_type) { | 606 | switch (Description->bd_type) { |
587 | case MAILIMAP_BODY_TYPE_1PART_TEXT: | 607 | case MAILIMAP_BODY_TYPE_1PART_TEXT: |
588 | target_part.setType("text"); | 608 | target_part.setType("text"); |
589 | fillSingleTextPart(target_part,Description->bd_data.bd_type_text); | 609 | fillSingleTextPart(target_part,Description->bd_data.bd_type_text); |
590 | break; | 610 | break; |
591 | case MAILIMAP_BODY_TYPE_1PART_BASIC: | 611 | case MAILIMAP_BODY_TYPE_1PART_BASIC: |
592 | fillSingleBasicPart(target_part,Description->bd_data.bd_type_basic); | 612 | fillSingleBasicPart(target_part,Description->bd_data.bd_type_basic); |
593 | break; | 613 | break; |
594 | case MAILIMAP_BODY_TYPE_1PART_MSG: | 614 | case MAILIMAP_BODY_TYPE_1PART_MSG: |
595 | target_part.setType("message"); | 615 | target_part.setType("message"); |
596 | fillSingleMsgPart(target_part,Description->bd_data.bd_type_msg); | 616 | fillSingleMsgPart(target_part,Description->bd_data.bd_type_msg); |
597 | break; | 617 | break; |
598 | default: | 618 | default: |
599 | break; | 619 | break; |
600 | } | 620 | } |
601 | } | 621 | } |
602 | 622 | ||
603 | void IMAPwrapper::fillSingleTextPart(RecPart&target_part,mailimap_body_type_text*which) | 623 | void IMAPwrapper::fillSingleTextPart(RecPart&target_part,mailimap_body_type_text*which) |
604 | { | 624 | { |
605 | if (!which) { | 625 | if (!which) { |
606 | return; | 626 | return; |
607 | } | 627 | } |
608 | QString sub; | 628 | QString sub; |
609 | sub = which->bd_media_text; | 629 | sub = which->bd_media_text; |
630 | qDebug("Type= text/%s",which->bd_media_text); | ||
610 | target_part.setSubtype(sub.lower()); | 631 | target_part.setSubtype(sub.lower()); |
611 | target_part.setLines(which->bd_lines); | 632 | target_part.setLines(which->bd_lines); |
612 | fillBodyFields(target_part,which->bd_fields); | 633 | fillBodyFields(target_part,which->bd_fields); |
613 | } | 634 | } |
614 | 635 | ||
615 | void IMAPwrapper::fillSingleMsgPart(RecPart&target_part,mailimap_body_type_msg*which) | 636 | void IMAPwrapper::fillSingleMsgPart(RecPart&target_part,mailimap_body_type_msg*which) |
616 | { | 637 | { |
617 | if (!which) { | 638 | if (!which) { |
618 | return; | 639 | return; |
619 | } | 640 | } |
620 | target_part.setSubtype("rfc822"); | 641 | target_part.setSubtype("rfc822"); |
621 | qDebug("Message part"); | 642 | qDebug("Message part"); |
622 | /* we set this type to text/plain */ | 643 | /* we set this type to text/plain */ |
623 | target_part.setLines(which->bd_lines); | 644 | target_part.setLines(which->bd_lines); |
624 | fillBodyFields(target_part,which->bd_fields); | 645 | fillBodyFields(target_part,which->bd_fields); |
625 | } | 646 | } |
626 | 647 | ||
648 | void IMAPwrapper::fillMultiPart(RecPart&target_part,mailimap_body_type_mpart*which) | ||
649 | { | ||
650 | if (!which) return; | ||
651 | target_part.setSubtype(which->bd_media_subtype); | ||
652 | if (which->bd_ext_mpart && which->bd_ext_mpart->bd_parameter && which->bd_ext_mpart->bd_parameter->pa_list) { | ||
653 | clistcell*cur = 0; | ||
654 | mailimap_single_body_fld_param*param=0; | ||
655 | for (cur = clist_begin(which->bd_ext_mpart->bd_parameter->pa_list);cur!=NULL;cur=clist_next(cur)) { | ||
656 | param = (mailimap_single_body_fld_param*)cur->data; | ||
657 | if (param) { | ||
658 | target_part.addParameter(QString(param->pa_name).lower(),QString(param->pa_value)); | ||
659 | } | ||
660 | } | ||
661 | } | ||
662 | } | ||
663 | |||
627 | void IMAPwrapper::fillSingleBasicPart(RecPart&target_part,mailimap_body_type_basic*which) | 664 | void IMAPwrapper::fillSingleBasicPart(RecPart&target_part,mailimap_body_type_basic*which) |
628 | { | 665 | { |
629 | if (!which) { | 666 | if (!which) { |
630 | return; | 667 | return; |
631 | } | 668 | } |
632 | QString type,sub; | 669 | QString type,sub; |
633 | switch (which->bd_media_basic->med_type) { | 670 | switch (which->bd_media_basic->med_type) { |
634 | case MAILIMAP_MEDIA_BASIC_APPLICATION: | 671 | case MAILIMAP_MEDIA_BASIC_APPLICATION: |
635 | type = "application"; | 672 | type = "application"; |
636 | break; | 673 | break; |
637 | case MAILIMAP_MEDIA_BASIC_AUDIO: | 674 | case MAILIMAP_MEDIA_BASIC_AUDIO: |
638 | type = "audio"; | 675 | type = "audio"; |
639 | break; | 676 | break; |
640 | case MAILIMAP_MEDIA_BASIC_IMAGE: | 677 | case MAILIMAP_MEDIA_BASIC_IMAGE: |
641 | type = "image"; | 678 | type = "image"; |
642 | break; | 679 | break; |
643 | case MAILIMAP_MEDIA_BASIC_MESSAGE: | 680 | case MAILIMAP_MEDIA_BASIC_MESSAGE: |
644 | type = "message"; | 681 | type = "message"; |
645 | break; | 682 | break; |
646 | case MAILIMAP_MEDIA_BASIC_VIDEO: | 683 | case MAILIMAP_MEDIA_BASIC_VIDEO: |
647 | type = "video"; | 684 | type = "video"; |
648 | break; | 685 | break; |
649 | case MAILIMAP_MEDIA_BASIC_OTHER: | 686 | case MAILIMAP_MEDIA_BASIC_OTHER: |
650 | default: | 687 | default: |
diff --git a/noncore/net/mail/imapwrapper.h b/noncore/net/mail/imapwrapper.h index e5846f8..7941046 100644 --- a/noncore/net/mail/imapwrapper.h +++ b/noncore/net/mail/imapwrapper.h | |||
@@ -31,36 +31,37 @@ public: | |||
31 | virtual int deleteAllMail(const Folder*folder); | 31 | virtual int deleteAllMail(const Folder*folder); |
32 | 32 | ||
33 | virtual RecBody fetchBody(const RecMail&mail); | 33 | virtual RecBody fetchBody(const RecMail&mail); |
34 | virtual QString fetchTextPart(const RecMail&mail,const RecPart&part); | 34 | virtual QString fetchTextPart(const RecMail&mail,const RecPart&part); |
35 | virtual encodedString* fetchDecodedPart(const RecMail&mail,const RecPart&part); | 35 | virtual encodedString* fetchDecodedPart(const RecMail&mail,const RecPart&part); |
36 | virtual encodedString* fetchRawPart(const RecMail&mail,const RecPart&part); | 36 | virtual encodedString* fetchRawPart(const RecMail&mail,const RecPart&part); |
37 | 37 | ||
38 | virtual int createMbox(const QString&,const Folder*parentfolder=0,const QString& delemiter="/",bool getsubfolder=false); | 38 | virtual int createMbox(const QString&,const Folder*parentfolder=0,const QString& delemiter="/",bool getsubfolder=false); |
39 | virtual int deleteMbox(const Folder*folder); | 39 | virtual int deleteMbox(const Folder*folder); |
40 | 40 | ||
41 | static void imap_progress( size_t current, size_t maximum ); | 41 | static void imap_progress( size_t current, size_t maximum ); |
42 | 42 | ||
43 | protected: | 43 | protected: |
44 | RecMail*parse_list_result(mailimap_msg_att*); | 44 | RecMail*parse_list_result(mailimap_msg_att*); |
45 | void login(); | 45 | void login(); |
46 | void logout(); | 46 | void logout(); |
47 | 47 | ||
48 | virtual QString fetchTextPart(const RecMail&mail,const QValueList<int>&path,bool internal_call=false,const QString&enc=""); | 48 | virtual QString fetchTextPart(const RecMail&mail,const QValueList<int>&path,bool internal_call=false,const QString&enc=""); |
49 | virtual encodedString*fetchRawPart(const RecMail&mail,const QValueList<int>&path,bool internal_call); | 49 | virtual encodedString*fetchRawPart(const RecMail&mail,const QValueList<int>&path,bool internal_call); |
50 | 50 | ||
51 | void fillSinglePart(RecPart&target_part,mailimap_body_type_1part*Description); | 51 | void fillSinglePart(RecPart&target_part,mailimap_body_type_1part*Description); |
52 | void fillSingleTextPart(RecPart&target_part,mailimap_body_type_text*which); | 52 | void fillSingleTextPart(RecPart&target_part,mailimap_body_type_text*which); |
53 | void fillSingleBasicPart(RecPart&target_part,mailimap_body_type_basic*which); | 53 | void fillSingleBasicPart(RecPart&target_part,mailimap_body_type_basic*which); |
54 | void fillSingleMsgPart(RecPart&target_part,mailimap_body_type_msg*which); | 54 | void fillSingleMsgPart(RecPart&target_part,mailimap_body_type_msg*which); |
55 | void traverseBody(const RecMail&mail,mailimap_body*body,RecBody&target_body,int current_recursion,QValueList<int>recList,int current_count=0); | 55 | void fillMultiPart(RecPart&target_part,mailimap_body_type_mpart*which); |
56 | void traverseBody(const RecMail&mail,mailimap_body*body,RecBody&target_body,int current_recursion,QValueList<int>recList,int current_count=1); | ||
56 | 57 | ||
57 | /* just helpers */ | 58 | /* just helpers */ |
58 | static void fillBodyFields(RecPart&target_part,mailimap_body_fields*which); | 59 | static void fillBodyFields(RecPart&target_part,mailimap_body_fields*which); |
59 | static QStringList address_list_to_stringlist(clist*list); | 60 | static QStringList address_list_to_stringlist(clist*list); |
60 | 61 | ||
61 | 62 | ||
62 | IMAPaccount *account; | 63 | IMAPaccount *account; |
63 | mailimap *m_imap; | 64 | mailimap *m_imap; |
64 | }; | 65 | }; |
65 | 66 | ||
66 | #endif | 67 | #endif |
diff --git a/noncore/net/mail/libmailwrapper/imapwrapper.cpp b/noncore/net/mail/libmailwrapper/imapwrapper.cpp index f7e93aa..ae196bb 100644 --- a/noncore/net/mail/libmailwrapper/imapwrapper.cpp +++ b/noncore/net/mail/libmailwrapper/imapwrapper.cpp | |||
@@ -508,143 +508,180 @@ encodedString*IMAPwrapper::fetchRawPart(const RecMail&mail,const QValueList<int> | |||
508 | if (msg_att_item->att_type == MAILIMAP_MSG_ATT_ITEM_STATIC) { | 508 | if (msg_att_item->att_type == MAILIMAP_MSG_ATT_ITEM_STATIC) { |
509 | if (msg_att_item->att_data.att_static->att_type == MAILIMAP_MSG_ATT_BODY_SECTION) { | 509 | if (msg_att_item->att_data.att_static->att_type == MAILIMAP_MSG_ATT_BODY_SECTION) { |
510 | char*text = msg_att_item->att_data.att_static->att_data.att_body_section->sec_body_part; | 510 | char*text = msg_att_item->att_data.att_static->att_data.att_body_section->sec_body_part; |
511 | /* detach - we take over the content */ | 511 | /* detach - we take over the content */ |
512 | msg_att_item->att_data.att_static->att_data.att_body_section->sec_body_part = 0L; | 512 | msg_att_item->att_data.att_static->att_data.att_body_section->sec_body_part = 0L; |
513 | res->setContent(text,msg_att_item->att_data.att_static->att_data.att_body_section->sec_length); | 513 | res->setContent(text,msg_att_item->att_data.att_static->att_data.att_body_section->sec_length); |
514 | } | 514 | } |
515 | } | 515 | } |
516 | } | 516 | } |
517 | } else { | 517 | } else { |
518 | qDebug("error fetching text: %s",m_imap->imap_response); | 518 | qDebug("error fetching text: %s",m_imap->imap_response); |
519 | } | 519 | } |
520 | if (result) mailimap_fetch_list_free(result); | 520 | if (result) mailimap_fetch_list_free(result); |
521 | return res; | 521 | return res; |
522 | } | 522 | } |
523 | 523 | ||
524 | /* current_recursion is for recursive calls. | 524 | /* current_recursion is for recursive calls. |
525 | current_count means the position inside the internal loop! */ | 525 | current_count means the position inside the internal loop! */ |
526 | void IMAPwrapper::traverseBody(const RecMail&mail,mailimap_body*body,RecBody&target_body, | 526 | void IMAPwrapper::traverseBody(const RecMail&mail,mailimap_body*body,RecBody&target_body, |
527 | int current_recursion,QValueList<int>recList,int current_count) | 527 | int current_recursion,QValueList<int>recList,int current_count) |
528 | { | 528 | { |
529 | if (!body || current_recursion>=10) { | 529 | if (!body || current_recursion>=10) { |
530 | return; | 530 | return; |
531 | } | 531 | } |
532 | ++current_count; | ||
533 | switch (body->bd_type) { | 532 | switch (body->bd_type) { |
534 | case MAILIMAP_BODY_1PART: | 533 | case MAILIMAP_BODY_1PART: |
535 | { | 534 | { |
536 | QValueList<int>countlist = recList; | 535 | QValueList<int>countlist = recList; |
537 | countlist.append(current_count); | 536 | countlist.append(current_count); |
538 | RecPart currentPart; | 537 | RecPart currentPart; |
539 | mailimap_body_type_1part*part1 = body->bd_data.bd_body_1part; | 538 | mailimap_body_type_1part*part1 = body->bd_data.bd_body_1part; |
540 | QString id(""); | 539 | QString id(""); |
541 | currentPart.setPositionlist(countlist); | 540 | currentPart.setPositionlist(countlist); |
542 | for (unsigned int j = 0; j < countlist.count();++j) { | 541 | for (unsigned int j = 0; j < countlist.count();++j) { |
543 | id+=(j>0?" ":""); | 542 | id+=(j>0?" ":""); |
544 | id+=QString("%1").arg(countlist[j]); | 543 | id+=QString("%1").arg(countlist[j]); |
545 | } | 544 | } |
546 | qDebug("ID = %s",id.latin1()); | 545 | qDebug("ID = %s",id.latin1()); |
547 | currentPart.setIdentifier(id); | 546 | currentPart.setIdentifier(id); |
548 | fillSinglePart(currentPart,part1); | 547 | fillSinglePart(currentPart,part1); |
549 | /* important: Check for is NULL 'cause a body can be empty! | 548 | /* important: Check for is NULL 'cause a body can be empty! |
550 | And we put it only into the mail if it is the FIRST part */ | 549 | And we put it only into the mail if it is the FIRST part */ |
551 | if (part1->bd_type==MAILIMAP_BODY_TYPE_1PART_TEXT && target_body.Bodytext().isNull() && countlist[0]==1) { | 550 | if (part1->bd_type==MAILIMAP_BODY_TYPE_1PART_TEXT && target_body.Bodytext().isNull() && countlist[0]==1) { |
552 | QString body_text = fetchTextPart(mail,countlist,true,currentPart.Encoding()); | 551 | QString body_text = fetchTextPart(mail,countlist,true,currentPart.Encoding()); |
553 | target_body.setDescription(currentPart); | 552 | target_body.setDescription(currentPart); |
554 | target_body.setBodytext(body_text); | 553 | target_body.setBodytext(body_text); |
554 | if (countlist.count()>1) { | ||
555 | target_body.addPart(currentPart); | ||
556 | } | ||
555 | } else { | 557 | } else { |
556 | target_body.addPart(currentPart); | 558 | target_body.addPart(currentPart); |
557 | } | 559 | } |
558 | if (part1->bd_type==MAILIMAP_BODY_TYPE_1PART_MSG) { | 560 | if (part1->bd_type==MAILIMAP_BODY_TYPE_1PART_MSG) { |
559 | traverseBody(mail,part1->bd_data.bd_type_msg->bd_body,target_body,current_recursion+1,countlist); | 561 | traverseBody(mail,part1->bd_data.bd_type_msg->bd_body,target_body,current_recursion+1,countlist); |
560 | } | 562 | } |
561 | } | 563 | } |
562 | break; | 564 | break; |
563 | case MAILIMAP_BODY_MPART: | 565 | case MAILIMAP_BODY_MPART: |
564 | { | 566 | { |
567 | QValueList<int>countlist = recList; | ||
565 | clistcell*current=0; | 568 | clistcell*current=0; |
566 | mailimap_body*current_body=0; | 569 | mailimap_body*current_body=0; |
567 | unsigned int ccount = current_count-1; | 570 | unsigned int ccount = 1; |
568 | mailimap_body_type_mpart*mailDescription = body->bd_data.bd_body_mpart; | 571 | mailimap_body_type_mpart*mailDescription = body->bd_data.bd_body_mpart; |
569 | for (current=clist_begin(mailDescription->bd_list);current!=0;current=clist_next(current)) { | 572 | for (current=clist_begin(mailDescription->bd_list);current!=0;current=clist_next(current)) { |
570 | current_body = (mailimap_body*)current->data; | 573 | current_body = (mailimap_body*)current->data; |
571 | traverseBody(mail,current_body,target_body,current_recursion+1,recList,ccount); | 574 | if (current_body->bd_type==MAILIMAP_BODY_MPART) { |
575 | RecPart targetPart; | ||
576 | targetPart.setType("multipart"); | ||
577 | fillMultiPart(targetPart,mailDescription); | ||
578 | countlist.append(current_count); | ||
579 | targetPart.setPositionlist(countlist); | ||
580 | target_body.addPart(targetPart); | ||
581 | QString id(""); | ||
582 | for (unsigned int j = 0; j < countlist.count();++j) { | ||
583 | id+=(j>0?" ":""); | ||
584 | id+=QString("%1").arg(countlist[j]); | ||
585 | } | ||
586 | qDebug("ID(mpart) = %s",id.latin1()); | ||
587 | } | ||
588 | traverseBody(mail,current_body,target_body,current_recursion+1,countlist,ccount); | ||
589 | if (current_body->bd_type==MAILIMAP_BODY_MPART) { | ||
590 | countlist = recList; | ||
591 | } | ||
572 | ++ccount; | 592 | ++ccount; |
573 | } | 593 | } |
574 | } | 594 | } |
575 | break; | 595 | break; |
576 | default: | 596 | default: |
577 | break; | 597 | break; |
578 | } | 598 | } |
579 | } | 599 | } |
580 | 600 | ||
581 | void IMAPwrapper::fillSinglePart(RecPart&target_part,mailimap_body_type_1part*Description) | 601 | void IMAPwrapper::fillSinglePart(RecPart&target_part,mailimap_body_type_1part*Description) |
582 | { | 602 | { |
583 | if (!Description) { | 603 | if (!Description) { |
584 | return; | 604 | return; |
585 | } | 605 | } |
586 | switch (Description->bd_type) { | 606 | switch (Description->bd_type) { |
587 | case MAILIMAP_BODY_TYPE_1PART_TEXT: | 607 | case MAILIMAP_BODY_TYPE_1PART_TEXT: |
588 | target_part.setType("text"); | 608 | target_part.setType("text"); |
589 | fillSingleTextPart(target_part,Description->bd_data.bd_type_text); | 609 | fillSingleTextPart(target_part,Description->bd_data.bd_type_text); |
590 | break; | 610 | break; |
591 | case MAILIMAP_BODY_TYPE_1PART_BASIC: | 611 | case MAILIMAP_BODY_TYPE_1PART_BASIC: |
592 | fillSingleBasicPart(target_part,Description->bd_data.bd_type_basic); | 612 | fillSingleBasicPart(target_part,Description->bd_data.bd_type_basic); |
593 | break; | 613 | break; |
594 | case MAILIMAP_BODY_TYPE_1PART_MSG: | 614 | case MAILIMAP_BODY_TYPE_1PART_MSG: |
595 | target_part.setType("message"); | 615 | target_part.setType("message"); |
596 | fillSingleMsgPart(target_part,Description->bd_data.bd_type_msg); | 616 | fillSingleMsgPart(target_part,Description->bd_data.bd_type_msg); |
597 | break; | 617 | break; |
598 | default: | 618 | default: |
599 | break; | 619 | break; |
600 | } | 620 | } |
601 | } | 621 | } |
602 | 622 | ||
603 | void IMAPwrapper::fillSingleTextPart(RecPart&target_part,mailimap_body_type_text*which) | 623 | void IMAPwrapper::fillSingleTextPart(RecPart&target_part,mailimap_body_type_text*which) |
604 | { | 624 | { |
605 | if (!which) { | 625 | if (!which) { |
606 | return; | 626 | return; |
607 | } | 627 | } |
608 | QString sub; | 628 | QString sub; |
609 | sub = which->bd_media_text; | 629 | sub = which->bd_media_text; |
630 | qDebug("Type= text/%s",which->bd_media_text); | ||
610 | target_part.setSubtype(sub.lower()); | 631 | target_part.setSubtype(sub.lower()); |
611 | target_part.setLines(which->bd_lines); | 632 | target_part.setLines(which->bd_lines); |
612 | fillBodyFields(target_part,which->bd_fields); | 633 | fillBodyFields(target_part,which->bd_fields); |
613 | } | 634 | } |
614 | 635 | ||
615 | void IMAPwrapper::fillSingleMsgPart(RecPart&target_part,mailimap_body_type_msg*which) | 636 | void IMAPwrapper::fillSingleMsgPart(RecPart&target_part,mailimap_body_type_msg*which) |
616 | { | 637 | { |
617 | if (!which) { | 638 | if (!which) { |
618 | return; | 639 | return; |
619 | } | 640 | } |
620 | target_part.setSubtype("rfc822"); | 641 | target_part.setSubtype("rfc822"); |
621 | qDebug("Message part"); | 642 | qDebug("Message part"); |
622 | /* we set this type to text/plain */ | 643 | /* we set this type to text/plain */ |
623 | target_part.setLines(which->bd_lines); | 644 | target_part.setLines(which->bd_lines); |
624 | fillBodyFields(target_part,which->bd_fields); | 645 | fillBodyFields(target_part,which->bd_fields); |
625 | } | 646 | } |
626 | 647 | ||
648 | void IMAPwrapper::fillMultiPart(RecPart&target_part,mailimap_body_type_mpart*which) | ||
649 | { | ||
650 | if (!which) return; | ||
651 | target_part.setSubtype(which->bd_media_subtype); | ||
652 | if (which->bd_ext_mpart && which->bd_ext_mpart->bd_parameter && which->bd_ext_mpart->bd_parameter->pa_list) { | ||
653 | clistcell*cur = 0; | ||
654 | mailimap_single_body_fld_param*param=0; | ||
655 | for (cur = clist_begin(which->bd_ext_mpart->bd_parameter->pa_list);cur!=NULL;cur=clist_next(cur)) { | ||
656 | param = (mailimap_single_body_fld_param*)cur->data; | ||
657 | if (param) { | ||
658 | target_part.addParameter(QString(param->pa_name).lower(),QString(param->pa_value)); | ||
659 | } | ||
660 | } | ||
661 | } | ||
662 | } | ||
663 | |||
627 | void IMAPwrapper::fillSingleBasicPart(RecPart&target_part,mailimap_body_type_basic*which) | 664 | void IMAPwrapper::fillSingleBasicPart(RecPart&target_part,mailimap_body_type_basic*which) |
628 | { | 665 | { |
629 | if (!which) { | 666 | if (!which) { |
630 | return; | 667 | return; |
631 | } | 668 | } |
632 | QString type,sub; | 669 | QString type,sub; |
633 | switch (which->bd_media_basic->med_type) { | 670 | switch (which->bd_media_basic->med_type) { |
634 | case MAILIMAP_MEDIA_BASIC_APPLICATION: | 671 | case MAILIMAP_MEDIA_BASIC_APPLICATION: |
635 | type = "application"; | 672 | type = "application"; |
636 | break; | 673 | break; |
637 | case MAILIMAP_MEDIA_BASIC_AUDIO: | 674 | case MAILIMAP_MEDIA_BASIC_AUDIO: |
638 | type = "audio"; | 675 | type = "audio"; |
639 | break; | 676 | break; |
640 | case MAILIMAP_MEDIA_BASIC_IMAGE: | 677 | case MAILIMAP_MEDIA_BASIC_IMAGE: |
641 | type = "image"; | 678 | type = "image"; |
642 | break; | 679 | break; |
643 | case MAILIMAP_MEDIA_BASIC_MESSAGE: | 680 | case MAILIMAP_MEDIA_BASIC_MESSAGE: |
644 | type = "message"; | 681 | type = "message"; |
645 | break; | 682 | break; |
646 | case MAILIMAP_MEDIA_BASIC_VIDEO: | 683 | case MAILIMAP_MEDIA_BASIC_VIDEO: |
647 | type = "video"; | 684 | type = "video"; |
648 | break; | 685 | break; |
649 | case MAILIMAP_MEDIA_BASIC_OTHER: | 686 | case MAILIMAP_MEDIA_BASIC_OTHER: |
650 | default: | 687 | default: |
diff --git a/noncore/net/mail/libmailwrapper/imapwrapper.h b/noncore/net/mail/libmailwrapper/imapwrapper.h index e5846f8..7941046 100644 --- a/noncore/net/mail/libmailwrapper/imapwrapper.h +++ b/noncore/net/mail/libmailwrapper/imapwrapper.h | |||
@@ -31,36 +31,37 @@ public: | |||
31 | virtual int deleteAllMail(const Folder*folder); | 31 | virtual int deleteAllMail(const Folder*folder); |
32 | 32 | ||
33 | virtual RecBody fetchBody(const RecMail&mail); | 33 | virtual RecBody fetchBody(const RecMail&mail); |
34 | virtual QString fetchTextPart(const RecMail&mail,const RecPart&part); | 34 | virtual QString fetchTextPart(const RecMail&mail,const RecPart&part); |
35 | virtual encodedString* fetchDecodedPart(const RecMail&mail,const RecPart&part); | 35 | virtual encodedString* fetchDecodedPart(const RecMail&mail,const RecPart&part); |
36 | virtual encodedString* fetchRawPart(const RecMail&mail,const RecPart&part); | 36 | virtual encodedString* fetchRawPart(const RecMail&mail,const RecPart&part); |
37 | 37 | ||
38 | virtual int createMbox(const QString&,const Folder*parentfolder=0,const QString& delemiter="/",bool getsubfolder=false); | 38 | virtual int createMbox(const QString&,const Folder*parentfolder=0,const QString& delemiter="/",bool getsubfolder=false); |
39 | virtual int deleteMbox(const Folder*folder); | 39 | virtual int deleteMbox(const Folder*folder); |
40 | 40 | ||
41 | static void imap_progress( size_t current, size_t maximum ); | 41 | static void imap_progress( size_t current, size_t maximum ); |
42 | 42 | ||
43 | protected: | 43 | protected: |
44 | RecMail*parse_list_result(mailimap_msg_att*); | 44 | RecMail*parse_list_result(mailimap_msg_att*); |
45 | void login(); | 45 | void login(); |
46 | void logout(); | 46 | void logout(); |
47 | 47 | ||
48 | virtual QString fetchTextPart(const RecMail&mail,const QValueList<int>&path,bool internal_call=false,const QString&enc=""); | 48 | virtual QString fetchTextPart(const RecMail&mail,const QValueList<int>&path,bool internal_call=false,const QString&enc=""); |
49 | virtual encodedString*fetchRawPart(const RecMail&mail,const QValueList<int>&path,bool internal_call); | 49 | virtual encodedString*fetchRawPart(const RecMail&mail,const QValueList<int>&path,bool internal_call); |
50 | 50 | ||
51 | void fillSinglePart(RecPart&target_part,mailimap_body_type_1part*Description); | 51 | void fillSinglePart(RecPart&target_part,mailimap_body_type_1part*Description); |
52 | void fillSingleTextPart(RecPart&target_part,mailimap_body_type_text*which); | 52 | void fillSingleTextPart(RecPart&target_part,mailimap_body_type_text*which); |
53 | void fillSingleBasicPart(RecPart&target_part,mailimap_body_type_basic*which); | 53 | void fillSingleBasicPart(RecPart&target_part,mailimap_body_type_basic*which); |
54 | void fillSingleMsgPart(RecPart&target_part,mailimap_body_type_msg*which); | 54 | void fillSingleMsgPart(RecPart&target_part,mailimap_body_type_msg*which); |
55 | void traverseBody(const RecMail&mail,mailimap_body*body,RecBody&target_body,int current_recursion,QValueList<int>recList,int current_count=0); | 55 | void fillMultiPart(RecPart&target_part,mailimap_body_type_mpart*which); |
56 | void traverseBody(const RecMail&mail,mailimap_body*body,RecBody&target_body,int current_recursion,QValueList<int>recList,int current_count=1); | ||
56 | 57 | ||
57 | /* just helpers */ | 58 | /* just helpers */ |
58 | static void fillBodyFields(RecPart&target_part,mailimap_body_fields*which); | 59 | static void fillBodyFields(RecPart&target_part,mailimap_body_fields*which); |
59 | static QStringList address_list_to_stringlist(clist*list); | 60 | static QStringList address_list_to_stringlist(clist*list); |
60 | 61 | ||
61 | 62 | ||
62 | IMAPaccount *account; | 63 | IMAPaccount *account; |
63 | mailimap *m_imap; | 64 | mailimap *m_imap; |
64 | }; | 65 | }; |
65 | 66 | ||
66 | #endif | 67 | #endif |