author | alwin <alwin> | 2004-01-08 19:15:10 (UTC) |
---|---|---|
committer | alwin <alwin> | 2004-01-08 19:15:10 (UTC) |
commit | 6287f011db0a566d17ae1614d8129f421125d934 (patch) (unidiff) | |
tree | 8c449974e9b577fe8dcc5348c4d109e82659b218 | |
parent | 44443aec5d4b8f974b30b1e9b4ea920d6582add1 (diff) | |
download | opie-6287f011db0a566d17ae1614d8129f421125d934.zip opie-6287f011db0a566d17ae1614d8129f421125d934.tar.gz opie-6287f011db0a566d17ae1614d8129f421125d934.tar.bz2 |
MH storage implemented
local folders will be type of MH not MBOX
-rw-r--r-- | noncore/net/mail/accountview.cpp | 64 | ||||
-rw-r--r-- | noncore/net/mail/accountview.h | 18 | ||||
-rw-r--r-- | noncore/net/mail/libmailwrapper/abstractmail.cpp | 3 | ||||
-rw-r--r-- | noncore/net/mail/libmailwrapper/genericwrapper.cpp | 8 | ||||
-rw-r--r-- | noncore/net/mail/libmailwrapper/genericwrapper.h | 4 | ||||
-rw-r--r-- | noncore/net/mail/libmailwrapper/libmailwrapper.pro | 6 | ||||
-rw-r--r-- | noncore/net/mail/libmailwrapper/mailwrapper.cpp | 18 | ||||
-rw-r--r-- | noncore/net/mail/libmailwrapper/mailwrapper.h | 11 | ||||
-rw-r--r-- | noncore/net/mail/libmailwrapper/mboxwrapper.h | 1 | ||||
-rw-r--r-- | noncore/net/mail/libmailwrapper/mhwrapper.cpp | 330 | ||||
-rw-r--r-- | noncore/net/mail/libmailwrapper/mhwrapper.h | 50 | ||||
-rw-r--r-- | noncore/net/mail/libmailwrapper/smtpwrapper.cpp | 3 |
12 files changed, 468 insertions, 48 deletions
diff --git a/noncore/net/mail/accountview.cpp b/noncore/net/mail/accountview.cpp index 9f4f358..62cbf62 100644 --- a/noncore/net/mail/accountview.cpp +++ b/noncore/net/mail/accountview.cpp | |||
@@ -532,371 +532,371 @@ AccountViewItem::AccountViewItem( QListViewItem *parent) | |||
532 | AccountViewItem::AccountViewItem( QListViewItem *parent , QListViewItem*after ) | 532 | AccountViewItem::AccountViewItem( QListViewItem *parent , QListViewItem*after ) |
533 | :QListViewItem( parent,after ) | 533 | :QListViewItem( parent,after ) |
534 | { | 534 | { |
535 | m_Backlink = 0; | 535 | m_Backlink = 0; |
536 | } | 536 | } |
537 | 537 | ||
538 | AccountViewItem::~AccountViewItem() | 538 | AccountViewItem::~AccountViewItem() |
539 | { | 539 | { |
540 | } | 540 | } |
541 | 541 | ||
542 | AccountView*AccountViewItem::accountView() | 542 | AccountView*AccountViewItem::accountView() |
543 | { | 543 | { |
544 | return m_Backlink; | 544 | return m_Backlink; |
545 | } | 545 | } |
546 | 546 | ||
547 | void AccountViewItem::deleteAllMail(AbstractMail*wrapper,Folder*folder) | 547 | void AccountViewItem::deleteAllMail(AbstractMail*wrapper,Folder*folder) |
548 | { | 548 | { |
549 | if (!wrapper) return; | 549 | if (!wrapper) return; |
550 | QString fname=""; | 550 | QString fname=""; |
551 | if (folder) fname = folder->getDisplayName(); | 551 | if (folder) fname = folder->getDisplayName(); |
552 | int yesno = QMessageBox::warning(0,QObject::tr("Delete all mails",contextName), | 552 | int yesno = QMessageBox::warning(0,QObject::tr("Delete all mails",contextName), |
553 | QObject::tr("<center>Realy delete all mails in box <br>%1</center>",contextName). | 553 | QObject::tr("<center>Realy delete all mails in box <br>%1</center>",contextName). |
554 | arg(fname), | 554 | arg(fname), |
555 | QObject::tr("Yes",contextName), | 555 | QObject::tr("Yes",contextName), |
556 | QObject::tr("No",contextName),QString::null,1,1); | 556 | QObject::tr("No",contextName),QString::null,1,1); |
557 | qDebug("Auswahl: %i",yesno); | 557 | qDebug("Auswahl: %i",yesno); |
558 | if (yesno == 0) { | 558 | if (yesno == 0) { |
559 | if (wrapper->deleteAllMail(folder)) { | 559 | if (wrapper->deleteAllMail(folder)) { |
560 | AccountView * view = (AccountView*)listView(); | 560 | AccountView * view = (AccountView*)listView(); |
561 | if (view) view->refreshCurrent(); | 561 | if (view) view->refreshCurrent(); |
562 | } | 562 | } |
563 | } | 563 | } |
564 | } | 564 | } |
565 | 565 | ||
566 | AccountView::AccountView( QWidget *parent, const char *name, WFlags flags ) | 566 | AccountView::AccountView( QWidget *parent, const char *name, WFlags flags ) |
567 | : QListView( parent, name, flags ) | 567 | : QListView( parent, name, flags ) |
568 | { | 568 | { |
569 | connect( this, SIGNAL( selectionChanged( QListViewItem * ) ), | 569 | connect( this, SIGNAL( selectionChanged( QListViewItem * ) ), |
570 | SLOT( refresh( QListViewItem * ) ) ); | 570 | SLOT( refresh( QListViewItem * ) ) ); |
571 | connect( this, SIGNAL( mouseButtonPressed(int, QListViewItem *,const QPoint&,int ) ),this, | 571 | connect( this, SIGNAL( mouseButtonPressed(int, QListViewItem *,const QPoint&,int ) ),this, |
572 | SLOT( slotHold( int, QListViewItem *,const QPoint&,int ) ) ); | 572 | SLOT( slotHold( int, QListViewItem *,const QPoint&,int ) ) ); |
573 | 573 | ||
574 | setSorting(0); | 574 | setSorting(0); |
575 | } | 575 | } |
576 | 576 | ||
577 | AccountView::~AccountView() | 577 | AccountView::~AccountView() |
578 | { | 578 | { |
579 | imapAccounts.clear(); | 579 | imapAccounts.clear(); |
580 | mboxAccounts.clear(); | 580 | mhAccounts.clear(); |
581 | } | 581 | } |
582 | 582 | ||
583 | void AccountView::slotContextMenu(int id) | 583 | void AccountView::slotContextMenu(int id) |
584 | { | 584 | { |
585 | AccountViewItem *view = static_cast<AccountViewItem *>(currentItem()); | 585 | AccountViewItem *view = static_cast<AccountViewItem *>(currentItem()); |
586 | if (!view) return; | 586 | if (!view) return; |
587 | view->contextMenuSelected(id); | 587 | view->contextMenuSelected(id); |
588 | } | 588 | } |
589 | 589 | ||
590 | void AccountView::slotHold(int button, QListViewItem * item,const QPoint&,int) | 590 | void AccountView::slotHold(int button, QListViewItem * item,const QPoint&,int) |
591 | { | 591 | { |
592 | if (button==1) {return;} | 592 | if (button==1) {return;} |
593 | if (!item) return; | 593 | if (!item) return; |
594 | AccountViewItem *view = static_cast<AccountViewItem *>(item); | 594 | AccountViewItem *view = static_cast<AccountViewItem *>(item); |
595 | QPopupMenu*m = view->getContextMenu(); | 595 | QPopupMenu*m = view->getContextMenu(); |
596 | if (!m) return; | 596 | if (!m) return; |
597 | connect(m,SIGNAL(activated(int)),this,SLOT(slotContextMenu(int))); | 597 | connect(m,SIGNAL(activated(int)),this,SLOT(slotContextMenu(int))); |
598 | m->setFocus(); | 598 | m->setFocus(); |
599 | m->exec( QPoint( QCursor::pos().x(), QCursor::pos().y()) ); | 599 | m->exec( QPoint( QCursor::pos().x(), QCursor::pos().y()) ); |
600 | delete m; | 600 | delete m; |
601 | } | 601 | } |
602 | 602 | ||
603 | void AccountView::populate( QList<Account> list ) | 603 | void AccountView::populate( QList<Account> list ) |
604 | { | 604 | { |
605 | clear(); | 605 | clear(); |
606 | 606 | ||
607 | imapAccounts.clear(); | 607 | imapAccounts.clear(); |
608 | mboxAccounts.clear(); | 608 | mhAccounts.clear(); |
609 | 609 | ||
610 | mboxAccounts.append(new MBOXviewItem(AbstractMail::defaultLocalfolder(),this)); | 610 | mhAccounts.append(new MHviewItem(AbstractMail::defaultLocalfolder(),this)); |
611 | 611 | ||
612 | Account *it; | 612 | Account *it; |
613 | for ( it = list.first(); it; it = list.next() ) { | 613 | for ( it = list.first(); it; it = list.next() ) { |
614 | if ( it->getType().compare( "IMAP" ) == 0 ) { | 614 | if ( it->getType().compare( "IMAP" ) == 0 ) { |
615 | IMAPaccount *imap = static_cast<IMAPaccount *>(it); | 615 | IMAPaccount *imap = static_cast<IMAPaccount *>(it); |
616 | qDebug( "added IMAP " + imap->getAccountName() ); | 616 | qDebug( "added IMAP " + imap->getAccountName() ); |
617 | imapAccounts.append(new IMAPviewItem( imap, this )); | 617 | imapAccounts.append(new IMAPviewItem( imap, this )); |
618 | } else if ( it->getType().compare( "POP3" ) == 0 ) { | 618 | } else if ( it->getType().compare( "POP3" ) == 0 ) { |
619 | POP3account *pop3 = static_cast<POP3account *>(it); | 619 | POP3account *pop3 = static_cast<POP3account *>(it); |
620 | qDebug( "added POP3 " + pop3->getAccountName() ); | 620 | qDebug( "added POP3 " + pop3->getAccountName() ); |
621 | /* must not be hold 'cause it isn't required */ | 621 | /* must not be hold 'cause it isn't required */ |
622 | (void) new POP3viewItem( pop3, this ); | 622 | (void) new POP3viewItem( pop3, this ); |
623 | } | 623 | } |
624 | } | 624 | } |
625 | } | 625 | } |
626 | 626 | ||
627 | void AccountView::refresh(QListViewItem *item) { | 627 | void AccountView::refresh(QListViewItem *item) { |
628 | 628 | ||
629 | qDebug("AccountView refresh..."); | 629 | qDebug("AccountView refresh..."); |
630 | if ( item ) { | 630 | if ( item ) { |
631 | m_currentItem = item; | 631 | m_currentItem = item; |
632 | QList<RecMail> headerlist; | 632 | QList<RecMail> headerlist; |
633 | headerlist.setAutoDelete(true); | 633 | headerlist.setAutoDelete(true); |
634 | AccountViewItem *view = static_cast<AccountViewItem *>(item); | 634 | AccountViewItem *view = static_cast<AccountViewItem *>(item); |
635 | view->refresh(headerlist); | 635 | view->refresh(headerlist); |
636 | emit refreshMailview(&headerlist); | 636 | emit refreshMailview(&headerlist); |
637 | } | 637 | } |
638 | } | 638 | } |
639 | 639 | ||
640 | void AccountView::refreshCurrent() | 640 | void AccountView::refreshCurrent() |
641 | { | 641 | { |
642 | m_currentItem = currentItem(); | 642 | m_currentItem = currentItem(); |
643 | if ( !m_currentItem ) return; | 643 | if ( !m_currentItem ) return; |
644 | QList<RecMail> headerlist; | 644 | QList<RecMail> headerlist; |
645 | headerlist.setAutoDelete(true); | 645 | headerlist.setAutoDelete(true); |
646 | AccountViewItem *view = static_cast<AccountViewItem *>(m_currentItem); | 646 | AccountViewItem *view = static_cast<AccountViewItem *>(m_currentItem); |
647 | view->refresh(headerlist); | 647 | view->refresh(headerlist); |
648 | emit refreshMailview(&headerlist); | 648 | emit refreshMailview(&headerlist); |
649 | } | 649 | } |
650 | 650 | ||
651 | void AccountView::refreshAll() | 651 | void AccountView::refreshAll() |
652 | { | 652 | { |
653 | 653 | ||
654 | } | 654 | } |
655 | 655 | ||
656 | RecBody AccountView::fetchBody(const RecMail&aMail) | 656 | RecBody AccountView::fetchBody(const RecMail&aMail) |
657 | { | 657 | { |
658 | QListViewItem*item = selectedItem (); | 658 | QListViewItem*item = selectedItem (); |
659 | if (!item) return RecBody(); | 659 | if (!item) return RecBody(); |
660 | AccountViewItem *view = static_cast<AccountViewItem *>(item); | 660 | AccountViewItem *view = static_cast<AccountViewItem *>(item); |
661 | return view->fetchBody(aMail); | 661 | return view->fetchBody(aMail); |
662 | } | 662 | } |
663 | 663 | ||
664 | void AccountView::setupFolderselect(Selectstore*sels) | 664 | void AccountView::setupFolderselect(Selectstore*sels) |
665 | { | 665 | { |
666 | sels->showMaximized(); | 666 | sels->showMaximized(); |
667 | QStringList sFolders; | 667 | QStringList sFolders; |
668 | unsigned int i = 0; | 668 | unsigned int i = 0; |
669 | for (i=0; i < mboxAccounts.count();++i) { | 669 | for (i=0; i < mhAccounts.count();++i) { |
670 | mboxAccounts[i]->refresh(false); | 670 | mhAccounts[i]->refresh(false); |
671 | sFolders = mboxAccounts[i]->subFolders(); | 671 | sFolders = mhAccounts[i]->subFolders(); |
672 | sels->addAccounts(mboxAccounts[i]->getWrapper(),sFolders); | 672 | sels->addAccounts(mhAccounts[i]->getWrapper(),sFolders); |
673 | } | 673 | } |
674 | for (i=0; i < imapAccounts.count();++i) { | 674 | for (i=0; i < imapAccounts.count();++i) { |
675 | if (imapAccounts[i]->offline()) | 675 | if (imapAccounts[i]->offline()) |
676 | continue; | 676 | continue; |
677 | imapAccounts[i]->refreshFolders(false); | 677 | imapAccounts[i]->refreshFolders(false); |
678 | sels->addAccounts(imapAccounts[i]->getWrapper(),imapAccounts[i]->subFolders()); | 678 | sels->addAccounts(imapAccounts[i]->getWrapper(),imapAccounts[i]->subFolders()); |
679 | } | 679 | } |
680 | } | 680 | } |
681 | 681 | ||
682 | void AccountView::downloadMails(Folder*fromFolder,AbstractMail*fromWrapper) | 682 | void AccountView::downloadMails(Folder*fromFolder,AbstractMail*fromWrapper) |
683 | { | 683 | { |
684 | AbstractMail*targetMail = 0; | 684 | AbstractMail*targetMail = 0; |
685 | QString targetFolder = ""; | 685 | QString targetFolder = ""; |
686 | Selectstore sels; | 686 | Selectstore sels; |
687 | setupFolderselect(&sels); | 687 | setupFolderselect(&sels); |
688 | if (!sels.exec()) return; | 688 | if (!sels.exec()) return; |
689 | targetMail = sels.currentMail(); | 689 | targetMail = sels.currentMail(); |
690 | targetFolder = sels.currentFolder(); | 690 | targetFolder = sels.currentFolder(); |
691 | if ( (fromWrapper==targetMail && fromFolder->getName()==targetFolder) || | 691 | if ( (fromWrapper==targetMail && fromFolder->getName()==targetFolder) || |
692 | targetFolder.isEmpty()) { | 692 | targetFolder.isEmpty()) { |
693 | return; | 693 | return; |
694 | } | 694 | } |
695 | if (sels.newFolder() && !targetMail->createMbox(targetFolder)) { | 695 | if (sels.newFolder() && !targetMail->createMbox(targetFolder)) { |
696 | QMessageBox::critical(0,tr("Error creating new Folder"), | 696 | QMessageBox::critical(0,tr("Error creating new Folder"), |
697 | tr("<center>Error while creating<br>new folder - breaking.</center>")); | 697 | tr("<center>Error while creating<br>new folder - breaking.</center>")); |
698 | return; | 698 | return; |
699 | } | 699 | } |
700 | qDebug("Targetfolder: %s",targetFolder.latin1()); | 700 | qDebug("Targetfolder: %s",targetFolder.latin1()); |
701 | qDebug("Fromfolder: %s",fromFolder->getName().latin1()); | 701 | qDebug("Fromfolder: %s",fromFolder->getName().latin1()); |
702 | fromWrapper->mvcpAllMails(fromFolder,targetFolder,targetMail,sels.moveMails()); | 702 | fromWrapper->mvcpAllMails(fromFolder,targetFolder,targetMail,sels.moveMails()); |
703 | refreshCurrent(); | 703 | refreshCurrent(); |
704 | } | 704 | } |
705 | 705 | ||
706 | /** | 706 | /** |
707 | * MBOX Account stuff | 707 | * MH Account stuff |
708 | */ | 708 | */ |
709 | 709 | ||
710 | MBOXviewItem::MBOXviewItem( const QString&aPath, AccountView *parent ) | 710 | MHviewItem::MHviewItem( const QString&aPath, AccountView *parent ) |
711 | : AccountViewItem( parent ) | 711 | : AccountViewItem( parent ) |
712 | { | 712 | { |
713 | m_Path = aPath; | 713 | m_Path = aPath; |
714 | /* be carefull - the space within settext is wanted - thats why the string twice */ | 714 | /* be carefull - the space within settext is wanted - thats why the string twice */ |
715 | wrapper = AbstractMail::getWrapper( m_Path,"Local Folders"); | 715 | wrapper = AbstractMail::getWrapper( m_Path,"Local Folders"); |
716 | setPixmap( 0, PIXMAP_LOCALFOLDER ); | 716 | setPixmap( 0, PIXMAP_LOCALFOLDER ); |
717 | setText( 0, " Local Folders" ); | 717 | setText( 0, " Local Folders" ); |
718 | setOpen( true ); | 718 | setOpen( true ); |
719 | } | 719 | } |
720 | 720 | ||
721 | MBOXviewItem::~MBOXviewItem() | 721 | MHviewItem::~MHviewItem() |
722 | { | 722 | { |
723 | delete wrapper; | 723 | delete wrapper; |
724 | } | 724 | } |
725 | 725 | ||
726 | AbstractMail *MBOXviewItem::getWrapper() | 726 | AbstractMail *MHviewItem::getWrapper() |
727 | { | 727 | { |
728 | return wrapper; | 728 | return wrapper; |
729 | } | 729 | } |
730 | 730 | ||
731 | void MBOXviewItem::refresh( QList<RecMail> & ) | 731 | void MHviewItem::refresh( QList<RecMail> & ) |
732 | { | 732 | { |
733 | refresh(false); | 733 | refresh(false); |
734 | } | 734 | } |
735 | 735 | ||
736 | void MBOXviewItem::refresh(bool force) | 736 | void MHviewItem::refresh(bool force) |
737 | { | 737 | { |
738 | if (childCount()>0 && force==false) return; | 738 | if (childCount()>0 && force==false) return; |
739 | QList<Folder> *folders = wrapper->listFolders(); | 739 | QList<Folder> *folders = wrapper->listFolders(); |
740 | QListViewItem *child = firstChild(); | 740 | QListViewItem *child = firstChild(); |
741 | while ( child ) { | 741 | while ( child ) { |
742 | QListViewItem *tmp = child; | 742 | QListViewItem *tmp = child; |
743 | child = child->nextSibling(); | 743 | child = child->nextSibling(); |
744 | delete tmp; | 744 | delete tmp; |
745 | } | 745 | } |
746 | Folder *it; | 746 | Folder *it; |
747 | QListViewItem*item = 0; | 747 | QListViewItem*item = 0; |
748 | for ( it = folders->first(); it; it = folders->next() ) { | 748 | for ( it = folders->first(); it; it = folders->next() ) { |
749 | item = new MBOXfolderItem( it, this , item ); | 749 | item = new MHfolderItem( it, this , item ); |
750 | item->setSelectable(it->may_select()); | 750 | item->setSelectable(it->may_select()); |
751 | } | 751 | } |
752 | // !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 752 | // !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! |
753 | folders->setAutoDelete(false); | 753 | folders->setAutoDelete(false); |
754 | delete folders; | 754 | delete folders; |
755 | } | 755 | } |
756 | 756 | ||
757 | RecBody MBOXviewItem::fetchBody( const RecMail &mail ) | 757 | RecBody MHviewItem::fetchBody( const RecMail &mail ) |
758 | { | 758 | { |
759 | qDebug( "MBOX fetchBody" ); | 759 | qDebug( "MH fetchBody" ); |
760 | return wrapper->fetchBody( mail ); | 760 | return wrapper->fetchBody( mail ); |
761 | } | 761 | } |
762 | 762 | ||
763 | QPopupMenu * MBOXviewItem::getContextMenu() | 763 | QPopupMenu * MHviewItem::getContextMenu() |
764 | { | 764 | { |
765 | QPopupMenu *m = new QPopupMenu(0); | 765 | QPopupMenu *m = new QPopupMenu(0); |
766 | if (m) { | 766 | if (m) { |
767 | m->insertItem(QObject::tr("Refresh folder list",contextName),0); | 767 | m->insertItem(QObject::tr("Refresh folder list",contextName),0); |
768 | m->insertItem(QObject::tr("Create new folder",contextName),1); | 768 | m->insertItem(QObject::tr("Create new folder",contextName),1); |
769 | } | 769 | } |
770 | return m; | 770 | return m; |
771 | } | 771 | } |
772 | 772 | ||
773 | void MBOXviewItem::createFolder() | 773 | void MHviewItem::createFolder() |
774 | { | 774 | { |
775 | Newmdirdlg ndirdlg(0,0,true); | 775 | Newmdirdlg ndirdlg(0,0,true); |
776 | ndirdlg.showMaximized(); | 776 | ndirdlg.showMaximized(); |
777 | if (ndirdlg.exec()) { | 777 | if (ndirdlg.exec()) { |
778 | QString ndir = ndirdlg.Newdir(); | 778 | QString ndir = ndirdlg.Newdir(); |
779 | if (wrapper->createMbox(ndir)) { | 779 | if (wrapper->createMbox(ndir)) { |
780 | refresh(true); | 780 | refresh(true); |
781 | } | 781 | } |
782 | } | 782 | } |
783 | } | 783 | } |
784 | 784 | ||
785 | QStringList MBOXviewItem::subFolders() | 785 | QStringList MHviewItem::subFolders() |
786 | { | 786 | { |
787 | QStringList result; | 787 | QStringList result; |
788 | QListViewItem *child = firstChild(); | 788 | QListViewItem *child = firstChild(); |
789 | while ( child ) { | 789 | while ( child ) { |
790 | MBOXfolderItem *tmp = (MBOXfolderItem*)child; | 790 | MHfolderItem *tmp = (MHfolderItem*)child; |
791 | child = child->nextSibling(); | 791 | child = child->nextSibling(); |
792 | result.append(tmp->getFolder()->getName()); | 792 | result.append(tmp->getFolder()->getDisplayName()); |
793 | } | 793 | } |
794 | qDebug("Size of result: %i",result.count()); | 794 | qDebug("Size of result: %i",result.count()); |
795 | return result; | 795 | return result; |
796 | } | 796 | } |
797 | 797 | ||
798 | void MBOXviewItem::contextMenuSelected(int which) | 798 | void MHviewItem::contextMenuSelected(int which) |
799 | { | 799 | { |
800 | switch (which) { | 800 | switch (which) { |
801 | case 0: | 801 | case 0: |
802 | refresh(true); | 802 | refresh(true); |
803 | break; | 803 | break; |
804 | case 1: | 804 | case 1: |
805 | createFolder(); | 805 | createFolder(); |
806 | break; | 806 | break; |
807 | default: | 807 | default: |
808 | break; | 808 | break; |
809 | } | 809 | } |
810 | } | 810 | } |
811 | 811 | ||
812 | MBOXfolderItem::~MBOXfolderItem() | 812 | MHfolderItem::~MHfolderItem() |
813 | { | 813 | { |
814 | delete folder; | 814 | delete folder; |
815 | } | 815 | } |
816 | 816 | ||
817 | MBOXfolderItem::MBOXfolderItem( Folder *folderInit, MBOXviewItem *parent , QListViewItem*after ) | 817 | MHfolderItem::MHfolderItem( Folder *folderInit, MHviewItem *parent , QListViewItem*after ) |
818 | : AccountViewItem( parent,after ) | 818 | : AccountViewItem( parent,after ) |
819 | { | 819 | { |
820 | folder = folderInit; | 820 | folder = folderInit; |
821 | mbox = parent; | 821 | mbox = parent; |
822 | if (folder->getDisplayName().lower() == "outgoing") { | 822 | if (folder->getDisplayName().lower() == "outgoing") { |
823 | setPixmap( 0, PIXMAP_OUTBOXFOLDER ); | 823 | setPixmap( 0, PIXMAP_OUTBOXFOLDER ); |
824 | } else if (folder->getDisplayName().lower() == "inbox") { | 824 | } else if (folder->getDisplayName().lower() == "inbox") { |
825 | setPixmap( 0, PIXMAP_INBOXFOLDER); | 825 | setPixmap( 0, PIXMAP_INBOXFOLDER); |
826 | } else { | 826 | } else { |
827 | setPixmap( 0, PIXMAP_MBOXFOLDER ); | 827 | setPixmap( 0, PIXMAP_MBOXFOLDER ); |
828 | } | 828 | } |
829 | setText( 0, folder->getDisplayName() ); | 829 | setText( 0, folder->getDisplayName() ); |
830 | } | 830 | } |
831 | 831 | ||
832 | Folder*MBOXfolderItem::getFolder() | 832 | Folder*MHfolderItem::getFolder() |
833 | { | 833 | { |
834 | return folder; | 834 | return folder; |
835 | } | 835 | } |
836 | 836 | ||
837 | void MBOXfolderItem::refresh(QList<RecMail>&target) | 837 | void MHfolderItem::refresh(QList<RecMail>&target) |
838 | { | 838 | { |
839 | if (folder->may_select()) | 839 | if (folder->may_select()) |
840 | mbox->getWrapper()->listMessages( folder->getName(),target ); | 840 | mbox->getWrapper()->listMessages( folder->getName(),target ); |
841 | } | 841 | } |
842 | 842 | ||
843 | RecBody MBOXfolderItem::fetchBody(const RecMail&aMail) | 843 | RecBody MHfolderItem::fetchBody(const RecMail&aMail) |
844 | { | 844 | { |
845 | return mbox->getWrapper()->fetchBody(aMail); | 845 | return mbox->getWrapper()->fetchBody(aMail); |
846 | } | 846 | } |
847 | 847 | ||
848 | void MBOXfolderItem::deleteFolder() | 848 | void MHfolderItem::deleteFolder() |
849 | { | 849 | { |
850 | int yesno = QMessageBox::warning(0,QObject::tr("Delete folder",contextName), | 850 | int yesno = QMessageBox::warning(0,QObject::tr("Delete folder",contextName), |
851 | QObject::tr("<center>Realy delete folder <br><b>%1</b><br>and all if it content?</center>",contextName).arg(folder->getDisplayName()), | 851 | QObject::tr("<center>Realy delete folder <br><b>%1</b><br>and all if it content?</center>",contextName).arg(folder->getDisplayName()), |
852 | QObject::tr("Yes",contextName), | 852 | QObject::tr("Yes",contextName), |
853 | QObject::tr("No",contextName),QString::null,1,1); | 853 | QObject::tr("No",contextName),QString::null,1,1); |
854 | qDebug("Auswahl: %i",yesno); | 854 | qDebug("Auswahl: %i",yesno); |
855 | if (yesno == 0) { | 855 | if (yesno == 0) { |
856 | if (mbox->getWrapper()->deleteMbox(folder)) { | 856 | if (mbox->getWrapper()->deleteMbox(folder)) { |
857 | QListView*v=listView(); | 857 | QListView*v=listView(); |
858 | MBOXviewItem * box = mbox; | 858 | MHviewItem * box = mbox; |
859 | /* be carefull - after that this object is destroyd so don't use | 859 | /* be carefull - after that this object is destroyd so don't use |
860 | * any member of it after that call!!*/ | 860 | * any member of it after that call!!*/ |
861 | mbox->refresh(true); | 861 | mbox->refresh(true); |
862 | if (v) { | 862 | if (v) { |
863 | v->setSelected(box,true); | 863 | v->setSelected(box,true); |
864 | } | 864 | } |
865 | } | 865 | } |
866 | } | 866 | } |
867 | } | 867 | } |
868 | 868 | ||
869 | QPopupMenu * MBOXfolderItem::getContextMenu() | 869 | QPopupMenu * MHfolderItem::getContextMenu() |
870 | { | 870 | { |
871 | QPopupMenu *m = new QPopupMenu(0); | 871 | QPopupMenu *m = new QPopupMenu(0); |
872 | if (m) { | 872 | if (m) { |
873 | m->insertItem(QObject::tr("Delete all mails",contextName),0); | 873 | m->insertItem(QObject::tr("Delete all mails",contextName),0); |
874 | m->insertItem(QObject::tr("Delete folder",contextName),1); | 874 | m->insertItem(QObject::tr("Delete folder",contextName),1); |
875 | m->insertItem(QObject::tr("Move/Copie all mails",contextName),2); | 875 | m->insertItem(QObject::tr("Move/Copie all mails",contextName),2); |
876 | } | 876 | } |
877 | return m; | 877 | return m; |
878 | } | 878 | } |
879 | 879 | ||
880 | void MBOXfolderItem::downloadMails() | 880 | void MHfolderItem::downloadMails() |
881 | { | 881 | { |
882 | AccountView*bl = mbox->accountView(); | 882 | AccountView*bl = mbox->accountView(); |
883 | if (!bl) return; | 883 | if (!bl) return; |
884 | bl->downloadMails(folder,mbox->getWrapper()); | 884 | bl->downloadMails(folder,mbox->getWrapper()); |
885 | } | 885 | } |
886 | 886 | ||
887 | void MBOXfolderItem::contextMenuSelected(int which) | 887 | void MHfolderItem::contextMenuSelected(int which) |
888 | { | 888 | { |
889 | switch(which) { | 889 | switch(which) { |
890 | case 0: | 890 | case 0: |
891 | deleteAllMail(mbox->getWrapper(),folder); | 891 | deleteAllMail(mbox->getWrapper(),folder); |
892 | break; | 892 | break; |
893 | case 1: | 893 | case 1: |
894 | deleteFolder(); | 894 | deleteFolder(); |
895 | break; | 895 | break; |
896 | case 2: | 896 | case 2: |
897 | downloadMails(); | 897 | downloadMails(); |
898 | break; | 898 | break; |
899 | default: | 899 | default: |
900 | break; | 900 | break; |
901 | } | 901 | } |
902 | } | 902 | } |
diff --git a/noncore/net/mail/accountview.h b/noncore/net/mail/accountview.h index d9b5558..f5a2973 100644 --- a/noncore/net/mail/accountview.h +++ b/noncore/net/mail/accountview.h | |||
@@ -73,118 +73,118 @@ protected: | |||
73 | 73 | ||
74 | class IMAPfolderItem; | 74 | class IMAPfolderItem; |
75 | 75 | ||
76 | class IMAPviewItem : public AccountViewItem | 76 | class IMAPviewItem : public AccountViewItem |
77 | { | 77 | { |
78 | friend class IMAPfolderItem; | 78 | friend class IMAPfolderItem; |
79 | public: | 79 | public: |
80 | IMAPviewItem( IMAPaccount *a, AccountView *parent ); | 80 | IMAPviewItem( IMAPaccount *a, AccountView *parent ); |
81 | virtual ~IMAPviewItem(); | 81 | virtual ~IMAPviewItem(); |
82 | virtual void refresh(QList<RecMail>&); | 82 | virtual void refresh(QList<RecMail>&); |
83 | virtual RecBody fetchBody(const RecMail&); | 83 | virtual RecBody fetchBody(const RecMail&); |
84 | AbstractMail *getWrapper(); | 84 | AbstractMail *getWrapper(); |
85 | virtual QPopupMenu * getContextMenu(); | 85 | virtual QPopupMenu * getContextMenu(); |
86 | virtual void contextMenuSelected(int); | 86 | virtual void contextMenuSelected(int); |
87 | const QStringList&subFolders(); | 87 | const QStringList&subFolders(); |
88 | virtual void refreshFolders(bool force=false); | 88 | virtual void refreshFolders(bool force=false); |
89 | bool offline(); | 89 | bool offline(); |
90 | 90 | ||
91 | protected: | 91 | protected: |
92 | IMAPfolderItem*findSubItem(const QString&path,IMAPfolderItem*start=0); | 92 | IMAPfolderItem*findSubItem(const QString&path,IMAPfolderItem*start=0); |
93 | virtual void createNewFolder(); | 93 | virtual void createNewFolder(); |
94 | virtual void removeChilds(); | 94 | virtual void removeChilds(); |
95 | IMAPaccount *account; | 95 | IMAPaccount *account; |
96 | AbstractMail *wrapper; | 96 | AbstractMail *wrapper; |
97 | QStringList currentFolders; | 97 | QStringList currentFolders; |
98 | }; | 98 | }; |
99 | 99 | ||
100 | class IMAPfolderItem : public AccountViewItem | 100 | class IMAPfolderItem : public AccountViewItem |
101 | { | 101 | { |
102 | 102 | ||
103 | public: | 103 | public: |
104 | IMAPfolderItem( Folder *folder, IMAPviewItem *parent , QListViewItem*after ); | 104 | IMAPfolderItem( Folder *folder, IMAPviewItem *parent , QListViewItem*after ); |
105 | IMAPfolderItem( Folder *folder, IMAPfolderItem *parent , QListViewItem*after, IMAPviewItem *master ); | 105 | IMAPfolderItem( Folder *folder, IMAPfolderItem *parent , QListViewItem*after, IMAPviewItem *master ); |
106 | virtual ~IMAPfolderItem(); | 106 | virtual ~IMAPfolderItem(); |
107 | virtual void refresh(QList<RecMail>&); | 107 | virtual void refresh(QList<RecMail>&); |
108 | virtual RecBody fetchBody(const RecMail&); | 108 | virtual RecBody fetchBody(const RecMail&); |
109 | bool matchName(const QString&name)const; | 109 | bool matchName(const QString&name)const; |
110 | virtual QPopupMenu * getContextMenu(); | 110 | virtual QPopupMenu * getContextMenu(); |
111 | virtual void contextMenuSelected(int); | 111 | virtual void contextMenuSelected(int); |
112 | virtual const QString& Delemiter()const; | 112 | virtual const QString& Delemiter()const; |
113 | protected: | 113 | protected: |
114 | virtual void createNewFolder(); | 114 | virtual void createNewFolder(); |
115 | virtual void deleteFolder(); | 115 | virtual void deleteFolder(); |
116 | virtual void downloadMails(); | 116 | virtual void downloadMails(); |
117 | Folder *folder; | 117 | Folder *folder; |
118 | IMAPviewItem *imap; | 118 | IMAPviewItem *imap; |
119 | }; | 119 | }; |
120 | 120 | ||
121 | class MBOXviewItem : public AccountViewItem | 121 | class MHviewItem : public AccountViewItem |
122 | { | 122 | { |
123 | friend class MBOXfolderItem; | 123 | friend class MHfolderItem; |
124 | 124 | ||
125 | public: | 125 | public: |
126 | MBOXviewItem( const QString&aMboxPath, AccountView *parent ); | 126 | MHviewItem( const QString&aMboxPath, AccountView *parent ); |
127 | virtual ~MBOXviewItem(); | 127 | virtual ~MHviewItem(); |
128 | virtual void refresh( QList<RecMail> &target ); | 128 | virtual void refresh( QList<RecMail> &target ); |
129 | virtual RecBody fetchBody( const RecMail &mail ); | 129 | virtual RecBody fetchBody( const RecMail &mail ); |
130 | AbstractMail *getWrapper(); | 130 | AbstractMail *getWrapper(); |
131 | virtual QPopupMenu * getContextMenu(); | 131 | virtual QPopupMenu * getContextMenu(); |
132 | virtual void contextMenuSelected(int); | 132 | virtual void contextMenuSelected(int); |
133 | QStringList subFolders(); | 133 | QStringList subFolders(); |
134 | virtual void refresh(bool force=false); | 134 | virtual void refresh(bool force=false); |
135 | 135 | ||
136 | protected: | 136 | protected: |
137 | virtual void createFolder(); | 137 | virtual void createFolder(); |
138 | QString m_Path; | 138 | QString m_Path; |
139 | AbstractMail *wrapper; | 139 | AbstractMail *wrapper; |
140 | 140 | ||
141 | }; | 141 | }; |
142 | 142 | ||
143 | class MBOXfolderItem : public AccountViewItem | 143 | class MHfolderItem : public AccountViewItem |
144 | { | 144 | { |
145 | 145 | ||
146 | public: | 146 | public: |
147 | MBOXfolderItem( Folder *folder, MBOXviewItem *parent , QListViewItem*after ); | 147 | MHfolderItem( Folder *folder, MHviewItem *parent , QListViewItem*after ); |
148 | virtual ~MBOXfolderItem(); | 148 | virtual ~MHfolderItem(); |
149 | virtual void refresh(QList<RecMail>&); | 149 | virtual void refresh(QList<RecMail>&); |
150 | virtual RecBody fetchBody(const RecMail&); | 150 | virtual RecBody fetchBody(const RecMail&); |
151 | virtual QPopupMenu * getContextMenu(); | 151 | virtual QPopupMenu * getContextMenu(); |
152 | virtual void contextMenuSelected(int); | 152 | virtual void contextMenuSelected(int); |
153 | virtual Folder*getFolder(); | 153 | virtual Folder*getFolder(); |
154 | 154 | ||
155 | protected: | 155 | protected: |
156 | void downloadMails(); | 156 | void downloadMails(); |
157 | virtual void deleteFolder(); | 157 | virtual void deleteFolder(); |
158 | Folder *folder; | 158 | Folder *folder; |
159 | MBOXviewItem *mbox; | 159 | MHviewItem *mbox; |
160 | }; | 160 | }; |
161 | 161 | ||
162 | class AccountView : public QListView | 162 | class AccountView : public QListView |
163 | { | 163 | { |
164 | Q_OBJECT | 164 | Q_OBJECT |
165 | 165 | ||
166 | public: | 166 | public: |
167 | AccountView( QWidget *parent = 0, const char *name = 0, WFlags flags = 0 ); | 167 | AccountView( QWidget *parent = 0, const char *name = 0, WFlags flags = 0 ); |
168 | virtual ~AccountView(); | 168 | virtual ~AccountView(); |
169 | virtual void populate( QList<Account> list ); | 169 | virtual void populate( QList<Account> list ); |
170 | virtual RecBody fetchBody(const RecMail&aMail); | 170 | virtual RecBody fetchBody(const RecMail&aMail); |
171 | virtual void downloadMails(Folder*fromFolder,AbstractMail*fromWrapper); | 171 | virtual void downloadMails(Folder*fromFolder,AbstractMail*fromWrapper); |
172 | 172 | ||
173 | public slots: | 173 | public slots: |
174 | virtual void refreshAll(); | 174 | virtual void refreshAll(); |
175 | virtual void refresh(QListViewItem *item); | 175 | virtual void refresh(QListViewItem *item); |
176 | virtual void refreshCurrent(); | 176 | virtual void refreshCurrent(); |
177 | virtual void slotHold(int, QListViewItem *,const QPoint&,int); | 177 | virtual void slotHold(int, QListViewItem *,const QPoint&,int); |
178 | virtual void slotContextMenu(int id); | 178 | virtual void slotContextMenu(int id); |
179 | void setupFolderselect(Selectstore*sels); | 179 | void setupFolderselect(Selectstore*sels); |
180 | 180 | ||
181 | signals: | 181 | signals: |
182 | void refreshMailview(QList<RecMail>*); | 182 | void refreshMailview(QList<RecMail>*); |
183 | 183 | ||
184 | protected: | 184 | protected: |
185 | QListViewItem* m_currentItem; | 185 | QListViewItem* m_currentItem; |
186 | QValueList<IMAPviewItem*> imapAccounts; | 186 | QValueList<IMAPviewItem*> imapAccounts; |
187 | QValueList<MBOXviewItem*> mboxAccounts; | 187 | QValueList<MHviewItem*> mhAccounts; |
188 | }; | 188 | }; |
189 | 189 | ||
190 | #endif | 190 | #endif |
diff --git a/noncore/net/mail/libmailwrapper/abstractmail.cpp b/noncore/net/mail/libmailwrapper/abstractmail.cpp index 0280803..592cd5e 100644 --- a/noncore/net/mail/libmailwrapper/abstractmail.cpp +++ b/noncore/net/mail/libmailwrapper/abstractmail.cpp | |||
@@ -1,74 +1,75 @@ | |||
1 | #include "abstractmail.h" | 1 | #include "abstractmail.h" |
2 | #include "imapwrapper.h" | 2 | #include "imapwrapper.h" |
3 | #include "pop3wrapper.h" | 3 | #include "pop3wrapper.h" |
4 | #include "mhwrapper.h" | ||
4 | #include "mboxwrapper.h" | 5 | #include "mboxwrapper.h" |
5 | #include "mailtypes.h" | 6 | #include "mailtypes.h" |
6 | 7 | ||
7 | #include <qstring.h> | 8 | #include <qstring.h> |
8 | #include <qfile.h> | 9 | #include <qfile.h> |
9 | #include <qtextstream.h> | 10 | #include <qtextstream.h> |
10 | #include <stdlib.h> | 11 | #include <stdlib.h> |
11 | #include <libetpan/mailmime_content.h> | 12 | #include <libetpan/mailmime_content.h> |
12 | #include <libetpan/mailmime.h> | 13 | #include <libetpan/mailmime.h> |
13 | 14 | ||
14 | AbstractMail* AbstractMail::getWrapper(IMAPaccount *a) | 15 | AbstractMail* AbstractMail::getWrapper(IMAPaccount *a) |
15 | { | 16 | { |
16 | return new IMAPwrapper(a); | 17 | return new IMAPwrapper(a); |
17 | } | 18 | } |
18 | 19 | ||
19 | AbstractMail* AbstractMail::getWrapper(POP3account *a) | 20 | AbstractMail* AbstractMail::getWrapper(POP3account *a) |
20 | { | 21 | { |
21 | return new POP3wrapper(a); | 22 | return new POP3wrapper(a); |
22 | } | 23 | } |
23 | 24 | ||
24 | AbstractMail* AbstractMail::getWrapper(const QString&a,const QString&name) | 25 | AbstractMail* AbstractMail::getWrapper(const QString&a,const QString&name) |
25 | { | 26 | { |
26 | return new MBOXwrapper(a,name); | 27 | return new MHwrapper(a,name); |
27 | } | 28 | } |
28 | 29 | ||
29 | encodedString* AbstractMail::decode_String(const encodedString*text,const QString&enc) | 30 | encodedString* AbstractMail::decode_String(const encodedString*text,const QString&enc) |
30 | { | 31 | { |
31 | qDebug("Decode string start"); | 32 | qDebug("Decode string start"); |
32 | char*result_text; | 33 | char*result_text; |
33 | size_t index = 0; | 34 | size_t index = 0; |
34 | /* reset for recursive use! */ | 35 | /* reset for recursive use! */ |
35 | size_t target_length = 0; | 36 | size_t target_length = 0; |
36 | result_text = 0; | 37 | result_text = 0; |
37 | int mimetype = MAILMIME_MECHANISM_7BIT; | 38 | int mimetype = MAILMIME_MECHANISM_7BIT; |
38 | if (enc.lower()=="quoted-printable") { | 39 | if (enc.lower()=="quoted-printable") { |
39 | mimetype = MAILMIME_MECHANISM_QUOTED_PRINTABLE; | 40 | mimetype = MAILMIME_MECHANISM_QUOTED_PRINTABLE; |
40 | } else if (enc.lower()=="base64") { | 41 | } else if (enc.lower()=="base64") { |
41 | mimetype = MAILMIME_MECHANISM_BASE64; | 42 | mimetype = MAILMIME_MECHANISM_BASE64; |
42 | } else if (enc.lower()=="8bit") { | 43 | } else if (enc.lower()=="8bit") { |
43 | mimetype = MAILMIME_MECHANISM_8BIT; | 44 | mimetype = MAILMIME_MECHANISM_8BIT; |
44 | } else if (enc.lower()=="binary") { | 45 | } else if (enc.lower()=="binary") { |
45 | mimetype = MAILMIME_MECHANISM_BINARY; | 46 | mimetype = MAILMIME_MECHANISM_BINARY; |
46 | } | 47 | } |
47 | 48 | ||
48 | int err = mailmime_part_parse(text->Content(),text->Length(),&index,mimetype, | 49 | int err = mailmime_part_parse(text->Content(),text->Length(),&index,mimetype, |
49 | &result_text,&target_length); | 50 | &result_text,&target_length); |
50 | 51 | ||
51 | encodedString* result = new encodedString(); | 52 | encodedString* result = new encodedString(); |
52 | if (err == MAILIMF_NO_ERROR) { | 53 | if (err == MAILIMF_NO_ERROR) { |
53 | result->setContent(result_text,target_length); | 54 | result->setContent(result_text,target_length); |
54 | } | 55 | } |
55 | qDebug("Decode string finished"); | 56 | qDebug("Decode string finished"); |
56 | return result; | 57 | return result; |
57 | } | 58 | } |
58 | 59 | ||
59 | QString AbstractMail::convert_String(const char*text) | 60 | QString AbstractMail::convert_String(const char*text) |
60 | { | 61 | { |
61 | size_t index = 0; | 62 | size_t index = 0; |
62 | char*res = 0; | 63 | char*res = 0; |
63 | 64 | ||
64 | /* attention - doesn't work with arm systems! */ | 65 | /* attention - doesn't work with arm systems! */ |
65 | int err = mailmime_encoded_phrase_parse("iso-8859-1", | 66 | int err = mailmime_encoded_phrase_parse("iso-8859-1", |
66 | text, strlen(text),&index, "iso-8859-1",&res); | 67 | text, strlen(text),&index, "iso-8859-1",&res); |
67 | if (err != MAILIMF_NO_ERROR) { | 68 | if (err != MAILIMF_NO_ERROR) { |
68 | if (res) free(res); | 69 | if (res) free(res); |
69 | return QString(text); | 70 | return QString(text); |
70 | } | 71 | } |
71 | if (res) { | 72 | if (res) { |
72 | QString result(res); | 73 | QString result(res); |
73 | free(res); | 74 | free(res); |
74 | return result; | 75 | return result; |
diff --git a/noncore/net/mail/libmailwrapper/genericwrapper.cpp b/noncore/net/mail/libmailwrapper/genericwrapper.cpp index 2d1596d..b1e4459 100644 --- a/noncore/net/mail/libmailwrapper/genericwrapper.cpp +++ b/noncore/net/mail/libmailwrapper/genericwrapper.cpp | |||
@@ -1,60 +1,68 @@ | |||
1 | #include "genericwrapper.h" | 1 | #include "genericwrapper.h" |
2 | #include <libetpan/libetpan.h> | 2 | #include <libetpan/libetpan.h> |
3 | #include "mailtypes.h" | 3 | #include "mailtypes.h" |
4 | 4 | ||
5 | Genericwrapper::Genericwrapper() | 5 | Genericwrapper::Genericwrapper() |
6 | : AbstractMail() | 6 | : AbstractMail() |
7 | { | 7 | { |
8 | bodyCache.clear(); | 8 | bodyCache.clear(); |
9 | m_storage = 0; | ||
10 | m_folder = 0; | ||
9 | } | 11 | } |
10 | 12 | ||
11 | Genericwrapper::~Genericwrapper() | 13 | Genericwrapper::~Genericwrapper() |
12 | { | 14 | { |
15 | if (m_folder) { | ||
16 | mailfolder_free(m_folder); | ||
17 | } | ||
18 | if (m_storage) { | ||
19 | mailstorage_free(m_storage); | ||
20 | } | ||
13 | cleanMimeCache(); | 21 | cleanMimeCache(); |
14 | } | 22 | } |
15 | 23 | ||
16 | void Genericwrapper::fillSingleBody(RecPart&target,mailmessage*,mailmime*mime) | 24 | void Genericwrapper::fillSingleBody(RecPart&target,mailmessage*,mailmime*mime) |
17 | { | 25 | { |
18 | if (!mime) { | 26 | if (!mime) { |
19 | return; | 27 | return; |
20 | } | 28 | } |
21 | mailmime_field*field = 0; | 29 | mailmime_field*field = 0; |
22 | mailmime_single_fields fields; | 30 | mailmime_single_fields fields; |
23 | memset(&fields, 0, sizeof(struct mailmime_single_fields)); | 31 | memset(&fields, 0, sizeof(struct mailmime_single_fields)); |
24 | if (mime->mm_mime_fields != NULL) { | 32 | if (mime->mm_mime_fields != NULL) { |
25 | mailmime_single_fields_init(&fields, mime->mm_mime_fields, | 33 | mailmime_single_fields_init(&fields, mime->mm_mime_fields, |
26 | mime->mm_content_type); | 34 | mime->mm_content_type); |
27 | } | 35 | } |
28 | 36 | ||
29 | mailmime_content*type = fields.fld_content; | 37 | mailmime_content*type = fields.fld_content; |
30 | clistcell*current; | 38 | clistcell*current; |
31 | if (!type) { | 39 | if (!type) { |
32 | target.setType("text"); | 40 | target.setType("text"); |
33 | target.setSubtype("plain"); | 41 | target.setSubtype("plain"); |
34 | } else { | 42 | } else { |
35 | target.setSubtype(type->ct_subtype); | 43 | target.setSubtype(type->ct_subtype); |
36 | switch(type->ct_type->tp_data.tp_discrete_type->dt_type) { | 44 | switch(type->ct_type->tp_data.tp_discrete_type->dt_type) { |
37 | case MAILMIME_DISCRETE_TYPE_TEXT: | 45 | case MAILMIME_DISCRETE_TYPE_TEXT: |
38 | target.setType("text"); | 46 | target.setType("text"); |
39 | break; | 47 | break; |
40 | case MAILMIME_DISCRETE_TYPE_IMAGE: | 48 | case MAILMIME_DISCRETE_TYPE_IMAGE: |
41 | target.setType("image"); | 49 | target.setType("image"); |
42 | break; | 50 | break; |
43 | case MAILMIME_DISCRETE_TYPE_AUDIO: | 51 | case MAILMIME_DISCRETE_TYPE_AUDIO: |
44 | target.setType("audio"); | 52 | target.setType("audio"); |
45 | break; | 53 | break; |
46 | case MAILMIME_DISCRETE_TYPE_VIDEO: | 54 | case MAILMIME_DISCRETE_TYPE_VIDEO: |
47 | target.setType("video"); | 55 | target.setType("video"); |
48 | break; | 56 | break; |
49 | case MAILMIME_DISCRETE_TYPE_APPLICATION: | 57 | case MAILMIME_DISCRETE_TYPE_APPLICATION: |
50 | target.setType("application"); | 58 | target.setType("application"); |
51 | break; | 59 | break; |
52 | case MAILMIME_DISCRETE_TYPE_EXTENSION: | 60 | case MAILMIME_DISCRETE_TYPE_EXTENSION: |
53 | default: | 61 | default: |
54 | if (type->ct_type->tp_data.tp_discrete_type->dt_extension) { | 62 | if (type->ct_type->tp_data.tp_discrete_type->dt_extension) { |
55 | target.setType(type->ct_type->tp_data.tp_discrete_type->dt_extension); | 63 | target.setType(type->ct_type->tp_data.tp_discrete_type->dt_extension); |
56 | } | 64 | } |
57 | break; | 65 | break; |
58 | } | 66 | } |
59 | if (type->ct_parameters) { | 67 | if (type->ct_parameters) { |
60 | fillParameters(target,type->ct_parameters); | 68 | fillParameters(target,type->ct_parameters); |
diff --git a/noncore/net/mail/libmailwrapper/genericwrapper.h b/noncore/net/mail/libmailwrapper/genericwrapper.h index 1d65c0a..e471dc8 100644 --- a/noncore/net/mail/libmailwrapper/genericwrapper.h +++ b/noncore/net/mail/libmailwrapper/genericwrapper.h | |||
@@ -1,62 +1,66 @@ | |||
1 | #ifndef __GENERIC_WRAPPER_H | 1 | #ifndef __GENERIC_WRAPPER_H |
2 | #define __GENERIC_WRAPPER_H | 2 | #define __GENERIC_WRAPPER_H |
3 | 3 | ||
4 | #include "abstractmail.h" | 4 | #include "abstractmail.h" |
5 | #include <qmap.h> | 5 | #include <qmap.h> |
6 | #include <qstring.h> | 6 | #include <qstring.h> |
7 | #include <libetpan/clist.h> | 7 | #include <libetpan/clist.h> |
8 | 8 | ||
9 | class RecMail; | 9 | class RecMail; |
10 | class RecBody; | 10 | class RecBody; |
11 | class encodedString; | 11 | class encodedString; |
12 | struct mailpop3; | 12 | struct mailpop3; |
13 | struct mailmessage; | 13 | struct mailmessage; |
14 | struct mailmime; | 14 | struct mailmime; |
15 | struct mailmime_mechanism; | 15 | struct mailmime_mechanism; |
16 | struct mailimf_mailbox_list; | 16 | struct mailimf_mailbox_list; |
17 | struct mailimf_mailbox; | 17 | struct mailimf_mailbox; |
18 | struct mailimf_date_time; | 18 | struct mailimf_date_time; |
19 | struct mailimf_group; | 19 | struct mailimf_group; |
20 | struct mailimf_address_list; | 20 | struct mailimf_address_list; |
21 | struct mailsession; | 21 | struct mailsession; |
22 | struct mailstorage; | ||
23 | struct mailfolder; | ||
22 | 24 | ||
23 | /* this class hold just the funs shared between | 25 | /* this class hold just the funs shared between |
24 | * mbox and pop3 (later mh, too) mail access. | 26 | * mbox and pop3 (later mh, too) mail access. |
25 | * it is not desigend to make a instance of it! | 27 | * it is not desigend to make a instance of it! |
26 | */ | 28 | */ |
27 | class Genericwrapper : public AbstractMail | 29 | class Genericwrapper : public AbstractMail |
28 | { | 30 | { |
29 | Q_OBJECT | 31 | Q_OBJECT |
30 | public: | 32 | public: |
31 | Genericwrapper(); | 33 | Genericwrapper(); |
32 | virtual ~Genericwrapper(); | 34 | virtual ~Genericwrapper(); |
33 | 35 | ||
34 | virtual encodedString* fetchDecodedPart(const RecMail&mail,const RecPart&part); | 36 | virtual encodedString* fetchDecodedPart(const RecMail&mail,const RecPart&part); |
35 | virtual encodedString* fetchRawPart(const RecMail&mail,const RecPart&part); | 37 | virtual encodedString* fetchRawPart(const RecMail&mail,const RecPart&part); |
36 | virtual QString fetchTextPart(const RecMail&mail,const RecPart&part); | 38 | virtual QString fetchTextPart(const RecMail&mail,const RecPart&part); |
37 | virtual void cleanMimeCache(); | 39 | virtual void cleanMimeCache(); |
38 | virtual int deleteMbox(const Folder*){return 1;} | 40 | virtual int deleteMbox(const Folder*){return 1;} |
39 | virtual void logout(){}; | 41 | virtual void logout(){}; |
40 | virtual void storeMessage(const char*msg,size_t length, const QString&folder){}; | 42 | virtual void storeMessage(const char*msg,size_t length, const QString&folder){}; |
41 | 43 | ||
42 | protected: | 44 | protected: |
43 | RecMail *parseHeader( const char *header ); | 45 | RecMail *parseHeader( const char *header ); |
44 | RecBody parseMail( mailmessage * msg ); | 46 | RecBody parseMail( mailmessage * msg ); |
45 | QString parseMailboxList( mailimf_mailbox_list *list ); | 47 | QString parseMailboxList( mailimf_mailbox_list *list ); |
46 | QString parseMailbox( mailimf_mailbox *box ); | 48 | QString parseMailbox( mailimf_mailbox *box ); |
47 | QString parseGroup( mailimf_group *group ); | 49 | QString parseGroup( mailimf_group *group ); |
48 | QString parseAddressList( mailimf_address_list *list ); | 50 | QString parseAddressList( mailimf_address_list *list ); |
49 | QString parseDateTime( mailimf_date_time *date ); | 51 | QString parseDateTime( mailimf_date_time *date ); |
50 | 52 | ||
51 | void traverseBody(RecBody&target,mailmessage*message,mailmime*mime,QValueList<int>recList,unsigned int current_rek=0,int current_count=1); | 53 | void traverseBody(RecBody&target,mailmessage*message,mailmime*mime,QValueList<int>recList,unsigned int current_rek=0,int current_count=1); |
52 | static void fillSingleBody(RecPart&target,mailmessage*message,mailmime*mime); | 54 | static void fillSingleBody(RecPart&target,mailmessage*message,mailmime*mime); |
53 | static void fillParameters(RecPart&target,clist*parameters); | 55 | static void fillParameters(RecPart&target,clist*parameters); |
54 | static QString getencoding(mailmime_mechanism*aEnc); | 56 | static QString getencoding(mailmime_mechanism*aEnc); |
55 | virtual void parseList(QList<RecMail> &target,mailsession*session,const QString&mailbox); | 57 | virtual void parseList(QList<RecMail> &target,mailsession*session,const QString&mailbox); |
56 | 58 | ||
57 | QString msgTempName; | 59 | QString msgTempName; |
58 | unsigned int last_msg_id; | 60 | unsigned int last_msg_id; |
59 | QMap<QString,encodedString*> bodyCache; | 61 | QMap<QString,encodedString*> bodyCache; |
62 | mailstorage * m_storage; | ||
63 | mailfolder*m_folder; | ||
60 | }; | 64 | }; |
61 | 65 | ||
62 | #endif | 66 | #endif |
diff --git a/noncore/net/mail/libmailwrapper/libmailwrapper.pro b/noncore/net/mail/libmailwrapper/libmailwrapper.pro index 18583bb..71f6cca 100644 --- a/noncore/net/mail/libmailwrapper/libmailwrapper.pro +++ b/noncore/net/mail/libmailwrapper/libmailwrapper.pro | |||
@@ -1,46 +1,48 @@ | |||
1 | TEMPLATE = lib | 1 | TEMPLATE = lib |
2 | CONFIG += qt warn_on debug | 2 | CONFIG += qt warn_on debug |
3 | 3 | ||
4 | HEADERS = mailwrapper.h \ | 4 | HEADERS = mailwrapper.h \ |
5 | imapwrapper.h \ | 5 | imapwrapper.h \ |
6 | mailtypes.h \ | 6 | mailtypes.h \ |
7 | pop3wrapper.h \ | 7 | pop3wrapper.h \ |
8 | abstractmail.h \ | 8 | abstractmail.h \ |
9 | smtpwrapper.h \ | 9 | smtpwrapper.h \ |
10 | genericwrapper.h \ | 10 | genericwrapper.h \ |
11 | mboxwrapper.h \ | 11 | mboxwrapper.h \ |
12 | settings.h \ | 12 | settings.h \ |
13 | logindialog.h \ | 13 | logindialog.h \ |
14 | sendmailprogress.h \ | 14 | sendmailprogress.h \ |
15 | statusmail.h | 15 | statusmail.h \ |
16 | mhwrapper.h | ||
16 | 17 | ||
17 | SOURCES = imapwrapper.cpp \ | 18 | SOURCES = imapwrapper.cpp \ |
18 | mailwrapper.cpp \ | 19 | mailwrapper.cpp \ |
19 | mailtypes.cpp \ | 20 | mailtypes.cpp \ |
20 | pop3wrapper.cpp \ | 21 | pop3wrapper.cpp \ |
21 | abstractmail.cpp \ | 22 | abstractmail.cpp \ |
22 | smtpwrapper.cpp \ | 23 | smtpwrapper.cpp \ |
23 | genericwrapper.cpp \ | 24 | genericwrapper.cpp \ |
24 | mboxwrapper.cpp \ | 25 | mboxwrapper.cpp \ |
25 | settings.cpp \ | 26 | settings.cpp \ |
26 | logindialog.cpp \ | 27 | logindialog.cpp \ |
27 | sendmailprogress.cpp \ | 28 | sendmailprogress.cpp \ |
28 | statusmail.cpp | 29 | statusmail.cpp \ |
30 | mhwrapper.cpp | ||
29 | 31 | ||
30 | INTERFACES = logindialogui.ui \ | 32 | INTERFACES = logindialogui.ui \ |
31 | sendmailprogressui.ui | 33 | sendmailprogressui.ui |
32 | 34 | ||
33 | 35 | ||
34 | INCLUDEPATH += $(OPIEDIR)/include | 36 | INCLUDEPATH += $(OPIEDIR)/include |
35 | 37 | ||
36 | CONFTEST = $$system( echo $CONFIG_TARGET_MACOSX ) | 38 | CONFTEST = $$system( echo $CONFIG_TARGET_MACOSX ) |
37 | contains( CONFTEST, y ){ | 39 | contains( CONFTEST, y ){ |
38 | LIBS += -lqpe -letpan -lssl -lcrypto -liconv | 40 | LIBS += -lqpe -letpan -lssl -lcrypto -liconv |
39 | }else{ | 41 | }else{ |
40 | LIBS += -lqpe -letpan -lssl -lcrypto | 42 | LIBS += -lqpe -letpan -lssl -lcrypto |
41 | } | 43 | } |
42 | 44 | ||
43 | DESTDIR = $(OPIEDIR)/lib$(PROJMAK) | 45 | DESTDIR = $(OPIEDIR)/lib$(PROJMAK) |
44 | TARGET = mailwrapper | 46 | TARGET = mailwrapper |
45 | 47 | ||
46 | include ( $(OPIEDIR)/include.pro ) | 48 | include ( $(OPIEDIR)/include.pro ) |
diff --git a/noncore/net/mail/libmailwrapper/mailwrapper.cpp b/noncore/net/mail/libmailwrapper/mailwrapper.cpp index 75b9343..ebdbf4b 100644 --- a/noncore/net/mail/libmailwrapper/mailwrapper.cpp +++ b/noncore/net/mail/libmailwrapper/mailwrapper.cpp | |||
@@ -1,95 +1,97 @@ | |||
1 | #include <stdlib.h> | 1 | #include <stdlib.h> |
2 | #include <sys/stat.h> | 2 | #include <sys/stat.h> |
3 | #include <sys/types.h> | 3 | #include <sys/types.h> |
4 | #include <unistd.h> | 4 | #include <unistd.h> |
5 | #include <fcntl.h> | 5 | #include <fcntl.h> |
6 | #include <string.h> | 6 | #include <string.h> |
7 | #include <qdir.h> | 7 | #include <qdir.h> |
8 | 8 | ||
9 | #include "mailwrapper.h" | 9 | #include "mailwrapper.h" |
10 | //#include "logindialog.h" | 10 | //#include "logindialog.h" |
11 | //#include "defines.h" | 11 | //#include "defines.h" |
12 | 12 | ||
13 | #define UNDEFINED 64 | 13 | #define UNDEFINED 64 |
14 | #define MAXLINE 76 | 14 | #define MAXLINE 76 |
15 | #define UTF16MASK 0x03FFUL | 15 | #define UTF16MASK 0x03FFUL |
16 | #define UTF16SHIFT 10 | 16 | #define UTF16SHIFT 10 |
17 | #define UTF16BASE 0x10000UL | 17 | #define UTF16BASE 0x10000UL |
18 | #define UTF16HIGHSTART 0xD800UL | 18 | #define UTF16HIGHSTART 0xD800UL |
19 | #define UTF16HIGHEND 0xDBFFUL | 19 | #define UTF16HIGHEND 0xDBFFUL |
20 | #define UTF16LOSTART 0xDC00UL | 20 | #define UTF16LOSTART 0xDC00UL |
21 | #define UTF16LOEND 0xDFFFUL | 21 | #define UTF16LOEND 0xDFFFUL |
22 | 22 | ||
23 | 23 | ||
24 | Attachment::Attachment( DocLnk lnk ) | 24 | Attachment::Attachment( DocLnk lnk ) |
25 | { | 25 | { |
26 | doc = lnk; | 26 | doc = lnk; |
27 | size = QFileInfo( doc.file() ).size(); | 27 | size = QFileInfo( doc.file() ).size(); |
28 | } | 28 | } |
29 | 29 | ||
30 | Folder::Folder(const QString&tmp_name, const QString&sep ) | 30 | Folder::Folder(const QString&tmp_name, const QString&sep ) |
31 | { | 31 | { |
32 | name = tmp_name; | 32 | name = tmp_name; |
33 | nameDisplay = name; | 33 | nameDisplay = name; |
34 | separator = sep; | 34 | separator = sep; |
35 | prefix = ""; | ||
35 | } | 36 | } |
36 | 37 | ||
37 | const QString& Folder::Separator()const | 38 | const QString& Folder::Separator()const |
38 | { | 39 | { |
39 | return separator; | 40 | return separator; |
40 | } | 41 | } |
41 | 42 | ||
42 | IMAPFolder::IMAPFolder(const QString&name,const QString&sep, bool select,bool no_inf, const QString&prefix ) | 43 | IMAPFolder::IMAPFolder(const QString&name,const QString&sep, bool select,bool no_inf, const QString&aprefix ) |
43 | : Folder( name,sep ),m_MaySelect(select),m_NoInferior(no_inf) | 44 | : Folder( name,sep ),m_MaySelect(select),m_NoInferior(no_inf) |
44 | { | 45 | { |
45 | // Decode IMAP foldername | 46 | // Decode IMAP foldername |
46 | nameDisplay = IMAPFolder::decodeFolderName( name ); | 47 | nameDisplay = IMAPFolder::decodeFolderName( name ); |
47 | qDebug( "folder " + name + " - displayed as " + nameDisplay ); | 48 | qDebug( "folder " + name + " - displayed as " + nameDisplay ); |
49 | prefix = aprefix; | ||
48 | 50 | ||
49 | if (prefix.length()>0) { | 51 | if (prefix.length()>0) { |
50 | if (nameDisplay.startsWith(prefix) && nameDisplay.length()>prefix.length()) { | 52 | if (nameDisplay.startsWith(prefix) && nameDisplay.length()>prefix.length()) { |
51 | nameDisplay=nameDisplay.right(nameDisplay.length()-prefix.length()); | 53 | nameDisplay=nameDisplay.right(nameDisplay.length()-prefix.length()); |
52 | } | 54 | } |
53 | } | 55 | } |
54 | } | 56 | } |
55 | 57 | ||
56 | static unsigned char base64chars[] = | 58 | static unsigned char base64chars[] = |
57 | "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+,"; | 59 | "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+,"; |
58 | 60 | ||
59 | /** | 61 | /** |
60 | * Decodes base64 encoded parts of the imapfolder name | 62 | * Decodes base64 encoded parts of the imapfolder name |
61 | * Code taken from kde cvs: kdebase/kioslave/imap4/rfcdecoder.cc | 63 | * Code taken from kde cvs: kdebase/kioslave/imap4/rfcdecoder.cc |
62 | */ | 64 | */ |
63 | QString IMAPFolder::decodeFolderName( const QString &name ) | 65 | QString IMAPFolder::decodeFolderName( const QString &name ) |
64 | { | 66 | { |
65 | unsigned char c, i, bitcount; | 67 | unsigned char c, i, bitcount; |
66 | unsigned long ucs4, utf16, bitbuf; | 68 | unsigned long ucs4, utf16, bitbuf; |
67 | unsigned char base64[256], utf8[6]; | 69 | unsigned char base64[256], utf8[6]; |
68 | unsigned long srcPtr = 0; | 70 | unsigned long srcPtr = 0; |
69 | QCString dst = ""; | 71 | QCString dst = ""; |
70 | QCString src = name.ascii(); | 72 | QCString src = name.ascii(); |
71 | 73 | ||
72 | /* initialize modified base64 decoding table */ | 74 | /* initialize modified base64 decoding table */ |
73 | memset(base64, UNDEFINED, sizeof(base64)); | 75 | memset(base64, UNDEFINED, sizeof(base64)); |
74 | for (i = 0; i < sizeof(base64chars); ++i) { | 76 | for (i = 0; i < sizeof(base64chars); ++i) { |
75 | base64[(int)base64chars[i]] = i; | 77 | base64[(int)base64chars[i]] = i; |
76 | } | 78 | } |
77 | 79 | ||
78 | /* loop until end of string */ | 80 | /* loop until end of string */ |
79 | while (srcPtr < src.length ()) { | 81 | while (srcPtr < src.length ()) { |
80 | c = src[srcPtr++]; | 82 | c = src[srcPtr++]; |
81 | /* deal with literal characters and &- */ | 83 | /* deal with literal characters and &- */ |
82 | if (c != '&' || src[srcPtr] == '-') { | 84 | if (c != '&' || src[srcPtr] == '-') { |
83 | /* encode literally */ | 85 | /* encode literally */ |
84 | dst += c; | 86 | dst += c; |
85 | /* skip over the '-' if this is an &- sequence */ | 87 | /* skip over the '-' if this is an &- sequence */ |
86 | if (c == '&') | 88 | if (c == '&') |
87 | srcPtr++; | 89 | srcPtr++; |
88 | } else { | 90 | } else { |
89 | /* convert modified UTF-7 -> UTF-16 -> UCS-4 -> UTF-8 -> HEX */ | 91 | /* convert modified UTF-7 -> UTF-16 -> UCS-4 -> UTF-8 -> HEX */ |
90 | bitbuf = 0; | 92 | bitbuf = 0; |
91 | bitcount = 0; | 93 | bitcount = 0; |
92 | ucs4 = 0; | 94 | ucs4 = 0; |
93 | while ((c = base64[(unsigned char) src[srcPtr]]) != UNDEFINED) { | 95 | while ((c = base64[(unsigned char) src[srcPtr]]) != UNDEFINED) { |
94 | ++srcPtr; | 96 | ++srcPtr; |
95 | bitbuf = (bitbuf << 6) | c; | 97 | bitbuf = (bitbuf << 6) | c; |
@@ -101,48 +103,62 @@ QString IMAPFolder::decodeFolderName( const QString &name ) | |||
101 | /* convert UTF16 to UCS4 */ | 103 | /* convert UTF16 to UCS4 */ |
102 | if (utf16 >= UTF16HIGHSTART && utf16 <= UTF16HIGHEND) { | 104 | if (utf16 >= UTF16HIGHSTART && utf16 <= UTF16HIGHEND) { |
103 | ucs4 = (utf16 - UTF16HIGHSTART) << UTF16SHIFT; | 105 | ucs4 = (utf16 - UTF16HIGHSTART) << UTF16SHIFT; |
104 | continue; | 106 | continue; |
105 | } else if (utf16 >= UTF16LOSTART && utf16 <= UTF16LOEND) { | 107 | } else if (utf16 >= UTF16LOSTART && utf16 <= UTF16LOEND) { |
106 | ucs4 += utf16 - UTF16LOSTART + UTF16BASE; | 108 | ucs4 += utf16 - UTF16LOSTART + UTF16BASE; |
107 | } else { | 109 | } else { |
108 | ucs4 = utf16; | 110 | ucs4 = utf16; |
109 | } | 111 | } |
110 | /* convert UTF-16 range of UCS4 to UTF-8 */ | 112 | /* convert UTF-16 range of UCS4 to UTF-8 */ |
111 | if (ucs4 <= 0x7fUL) { | 113 | if (ucs4 <= 0x7fUL) { |
112 | utf8[0] = ucs4; | 114 | utf8[0] = ucs4; |
113 | i = 1; | 115 | i = 1; |
114 | } else if (ucs4 <= 0x7ffUL) { | 116 | } else if (ucs4 <= 0x7ffUL) { |
115 | utf8[0] = 0xc0 | (ucs4 >> 6); | 117 | utf8[0] = 0xc0 | (ucs4 >> 6); |
116 | utf8[1] = 0x80 | (ucs4 & 0x3f); | 118 | utf8[1] = 0x80 | (ucs4 & 0x3f); |
117 | i = 2; | 119 | i = 2; |
118 | } else if (ucs4 <= 0xffffUL) { | 120 | } else if (ucs4 <= 0xffffUL) { |
119 | utf8[0] = 0xe0 | (ucs4 >> 12); | 121 | utf8[0] = 0xe0 | (ucs4 >> 12); |
120 | utf8[1] = 0x80 | ((ucs4 >> 6) & 0x3f); | 122 | utf8[1] = 0x80 | ((ucs4 >> 6) & 0x3f); |
121 | utf8[2] = 0x80 | (ucs4 & 0x3f); | 123 | utf8[2] = 0x80 | (ucs4 & 0x3f); |
122 | i = 3; | 124 | i = 3; |
123 | } else { | 125 | } else { |
124 | utf8[0] = 0xf0 | (ucs4 >> 18); | 126 | utf8[0] = 0xf0 | (ucs4 >> 18); |
125 | utf8[1] = 0x80 | ((ucs4 >> 12) & 0x3f); | 127 | utf8[1] = 0x80 | ((ucs4 >> 12) & 0x3f); |
126 | utf8[2] = 0x80 | ((ucs4 >> 6) & 0x3f); | 128 | utf8[2] = 0x80 | ((ucs4 >> 6) & 0x3f); |
127 | utf8[3] = 0x80 | (ucs4 & 0x3f); | 129 | utf8[3] = 0x80 | (ucs4 & 0x3f); |
128 | i = 4; | 130 | i = 4; |
129 | } | 131 | } |
130 | /* copy it */ | 132 | /* copy it */ |
131 | for (c = 0; c < i; ++c) { | 133 | for (c = 0; c < i; ++c) { |
132 | dst += utf8[c]; | 134 | dst += utf8[c]; |
133 | } | 135 | } |
134 | } | 136 | } |
135 | } | 137 | } |
136 | /* skip over trailing '-' in modified UTF-7 encoding */ | 138 | /* skip over trailing '-' in modified UTF-7 encoding */ |
137 | if (src[srcPtr] == '-') | 139 | if (src[srcPtr] == '-') |
138 | ++srcPtr; | 140 | ++srcPtr; |
139 | } | 141 | } |
140 | } | 142 | } |
141 | 143 | ||
142 | return QString::fromUtf8( dst.data() ); | 144 | return QString::fromUtf8( dst.data() ); |
143 | } | 145 | } |
144 | 146 | ||
145 | Mail::Mail() | 147 | Mail::Mail() |
146 | :name(""), mail(""), to(""), cc(""), bcc(""), reply(""), subject(""), message("") | 148 | :name(""), mail(""), to(""), cc(""), bcc(""), reply(""), subject(""), message("") |
147 | { | 149 | { |
148 | } | 150 | } |
151 | |||
152 | MHFolder::MHFolder(const QString&disp_name,const QString&mbox) | ||
153 | : Folder( disp_name,"/" ) | ||
154 | { | ||
155 | separator = "/"; | ||
156 | name = mbox; | ||
157 | if (!disp_name.startsWith("/") && disp_name.length()>0) | ||
158 | name+="/"; | ||
159 | name+=disp_name; | ||
160 | if (disp_name.length()==0) { | ||
161 | nameDisplay = separator; | ||
162 | } | ||
163 | prefix = mbox; | ||
164 | } | ||
diff --git a/noncore/net/mail/libmailwrapper/mailwrapper.h b/noncore/net/mail/libmailwrapper/mailwrapper.h index a60777d..caaa3a2 100644 --- a/noncore/net/mail/libmailwrapper/mailwrapper.h +++ b/noncore/net/mail/libmailwrapper/mailwrapper.h | |||
@@ -24,69 +24,76 @@ protected: | |||
24 | DocLnk doc; | 24 | DocLnk doc; |
25 | int size; | 25 | int size; |
26 | 26 | ||
27 | }; | 27 | }; |
28 | 28 | ||
29 | class Mail | 29 | class Mail |
30 | { | 30 | { |
31 | public: | 31 | public: |
32 | Mail(); | 32 | Mail(); |
33 | /* Possible that this destructor must not be declared virtual | 33 | /* Possible that this destructor must not be declared virtual |
34 | * 'cause it seems that it will never have some child classes. | 34 | * 'cause it seems that it will never have some child classes. |
35 | * in this case this object will not get a virtual table -> memory and | 35 | * in this case this object will not get a virtual table -> memory and |
36 | * speed will be a little bit better? | 36 | * speed will be a little bit better? |
37 | */ | 37 | */ |
38 | virtual ~Mail(){} | 38 | virtual ~Mail(){} |
39 | void addAttachment( Attachment *att ) { attList.append( att ); } | 39 | void addAttachment( Attachment *att ) { attList.append( att ); } |
40 | const QList<Attachment>& getAttachments()const { return attList; } | 40 | const QList<Attachment>& getAttachments()const { return attList; } |
41 | void removeAttachment( Attachment *att ) { attList.remove( att ); } | 41 | void removeAttachment( Attachment *att ) { attList.remove( att ); } |
42 | const QString&getName()const { return name; } | 42 | const QString&getName()const { return name; } |
43 | void setName( QString s ) { name = s; } | 43 | void setName( QString s ) { name = s; } |
44 | const QString&getMail()const{ return mail; } | 44 | const QString&getMail()const{ return mail; } |
45 | void setMail( const QString&s ) { mail = s; } | 45 | void setMail( const QString&s ) { mail = s; } |
46 | const QString&getTo()const{ return to; } | 46 | const QString&getTo()const{ return to; } |
47 | void setTo( const QString&s ) { to = s; } | 47 | void setTo( const QString&s ) { to = s; } |
48 | const QString&getCC()const{ return cc; } | 48 | const QString&getCC()const{ return cc; } |
49 | void setCC( const QString&s ) { cc = s; } | 49 | void setCC( const QString&s ) { cc = s; } |
50 | const QString&getBCC()const { return bcc; } | 50 | const QString&getBCC()const { return bcc; } |
51 | void setBCC( const QString&s ) { bcc = s; } | 51 | void setBCC( const QString&s ) { bcc = s; } |
52 | const QString&getMessage()const { return message; } | 52 | const QString&getMessage()const { return message; } |
53 | void setMessage( const QString&s ) { message = s; } | 53 | void setMessage( const QString&s ) { message = s; } |
54 | const QString&getSubject()const { return subject; } | 54 | const QString&getSubject()const { return subject; } |
55 | void setSubject( const QString&s ) { subject = s; } | 55 | void setSubject( const QString&s ) { subject = s; } |
56 | const QString&getReply()const{ return reply; } | 56 | const QString&getReply()const{ return reply; } |
57 | void setReply( const QString&a ) { reply = a; } | 57 | void setReply( const QString&a ) { reply = a; } |
58 | 58 | ||
59 | private: | 59 | private: |
60 | QList<Attachment> attList; | 60 | QList<Attachment> attList; |
61 | QString name, mail, to, cc, bcc, reply, subject, message; | 61 | QString name, mail, to, cc, bcc, reply, subject, message; |
62 | }; | 62 | }; |
63 | 63 | ||
64 | class Folder : public QObject | 64 | class Folder : public QObject |
65 | { | 65 | { |
66 | Q_OBJECT | 66 | Q_OBJECT |
67 | 67 | ||
68 | public: | 68 | public: |
69 | Folder( const QString&init_name,const QString&sep ); | 69 | Folder( const QString&init_name,const QString&sep ); |
70 | const QString&getDisplayName()const { return nameDisplay; } | 70 | const QString&getDisplayName()const { return nameDisplay; } |
71 | const QString&getName()const { return name; } | 71 | const QString&getName()const { return name; } |
72 | const QString&getPrefix()const{return prefix; } | ||
72 | virtual bool may_select()const{return true;} | 73 | virtual bool may_select()const{return true;} |
73 | virtual bool no_inferior()const{return true;} | 74 | virtual bool no_inferior()const{return true;} |
74 | const QString&Separator()const; | 75 | const QString&Separator()const; |
75 | 76 | ||
76 | protected: | 77 | protected: |
77 | QString nameDisplay, name, separator; | 78 | QString nameDisplay, name, separator,prefix; |
78 | 79 | }; | |
80 | |||
81 | class MHFolder : public Folder | ||
82 | { | ||
83 | Q_OBJECT | ||
84 | public: | ||
85 | MHFolder(const QString&disp_name,const QString&mbox); | ||
79 | }; | 86 | }; |
80 | 87 | ||
81 | class IMAPFolder : public Folder | 88 | class IMAPFolder : public Folder |
82 | { | 89 | { |
83 | public: | 90 | public: |
84 | IMAPFolder(const QString&name, const QString&sep, bool select=true,bool noinf=false,const QString&prefix="" ); | 91 | IMAPFolder(const QString&name, const QString&sep, bool select=true,bool noinf=false,const QString&prefix="" ); |
85 | virtual bool may_select()const{return m_MaySelect;} | 92 | virtual bool may_select()const{return m_MaySelect;} |
86 | virtual bool no_inferior()const{return m_NoInferior;} | 93 | virtual bool no_inferior()const{return m_NoInferior;} |
87 | private: | 94 | private: |
88 | static QString decodeFolderName( const QString &name ); | 95 | static QString decodeFolderName( const QString &name ); |
89 | bool m_MaySelect,m_NoInferior; | 96 | bool m_MaySelect,m_NoInferior; |
90 | }; | 97 | }; |
91 | 98 | ||
92 | #endif | 99 | #endif |
diff --git a/noncore/net/mail/libmailwrapper/mboxwrapper.h b/noncore/net/mail/libmailwrapper/mboxwrapper.h index 194ff86..a579a3d 100644 --- a/noncore/net/mail/libmailwrapper/mboxwrapper.h +++ b/noncore/net/mail/libmailwrapper/mboxwrapper.h | |||
@@ -1,47 +1,48 @@ | |||
1 | #ifndef __MBOX_WRAPPER_H | 1 | #ifndef __MBOX_WRAPPER_H |
2 | #define __MBOX_WRAPPER_H | 2 | #define __MBOX_WRAPPER_H |
3 | 3 | ||
4 | #include "genericwrapper.h" | 4 | #include "genericwrapper.h" |
5 | #include <qstring.h> | 5 | #include <qstring.h> |
6 | 6 | ||
7 | class RecMail; | 7 | class RecMail; |
8 | class RecBody; | 8 | class RecBody; |
9 | class encodedString; | 9 | class encodedString; |
10 | struct mailmbox_folder; | 10 | struct mailmbox_folder; |
11 | 11 | ||
12 | class MBOXwrapper : public Genericwrapper | 12 | class MBOXwrapper : public Genericwrapper |
13 | { | 13 | { |
14 | Q_OBJECT | 14 | Q_OBJECT |
15 | |||
15 | public: | 16 | public: |
16 | MBOXwrapper(const QString & dir,const QString&name); | 17 | MBOXwrapper(const QString & dir,const QString&name); |
17 | virtual ~MBOXwrapper(); | 18 | virtual ~MBOXwrapper(); |
18 | 19 | ||
19 | virtual void listMessages(const QString & mailbox, QList<RecMail> &target ); | 20 | virtual void listMessages(const QString & mailbox, QList<RecMail> &target ); |
20 | virtual QList<Folder>* listFolders(); | 21 | virtual QList<Folder>* listFolders(); |
21 | virtual void statusFolder(folderStat&target_stat,const QString & mailbox="INBOX"); | 22 | virtual void statusFolder(folderStat&target_stat,const QString & mailbox="INBOX"); |
22 | 23 | ||
23 | virtual void deleteMail(const RecMail&mail); | 24 | virtual void deleteMail(const RecMail&mail); |
24 | virtual void answeredMail(const RecMail&mail); | 25 | virtual void answeredMail(const RecMail&mail); |
25 | 26 | ||
26 | virtual int createMbox(const QString&folder,const Folder*f=0,const QString&d="",bool s=false); | 27 | virtual int createMbox(const QString&folder,const Folder*f=0,const QString&d="",bool s=false); |
27 | virtual int deleteMbox(const Folder*); | 28 | virtual int deleteMbox(const Folder*); |
28 | 29 | ||
29 | virtual void storeMessage(const char*msg,size_t length, const QString&folder); | 30 | virtual void storeMessage(const char*msg,size_t length, const QString&folder); |
30 | 31 | ||
31 | virtual RecBody fetchBody( const RecMail &mail ); | 32 | virtual RecBody fetchBody( const RecMail &mail ); |
32 | static void mbox_progress( size_t current, size_t maximum ); | 33 | static void mbox_progress( size_t current, size_t maximum ); |
33 | 34 | ||
34 | virtual encodedString* fetchRawBody(const RecMail&mail); | 35 | virtual encodedString* fetchRawBody(const RecMail&mail); |
35 | virtual void deleteMails(const QString & FolderName,QList<RecMail> &target); | 36 | virtual void deleteMails(const QString & FolderName,QList<RecMail> &target); |
36 | virtual int deleteAllMail(const Folder*); | 37 | virtual int deleteAllMail(const Folder*); |
37 | virtual const QString&getType()const; | 38 | virtual const QString&getType()const; |
38 | virtual const QString&getName()const; | 39 | virtual const QString&getName()const; |
39 | 40 | ||
40 | protected: | 41 | protected: |
41 | static void deleteMails(mailmbox_folder*f,QList<RecMail> &target); | 42 | static void deleteMails(mailmbox_folder*f,QList<RecMail> &target); |
42 | QString MBOXPath; | 43 | QString MBOXPath; |
43 | QString MBOXName; | 44 | QString MBOXName; |
44 | static const QString wrapperType; | 45 | static const QString wrapperType; |
45 | }; | 46 | }; |
46 | 47 | ||
47 | #endif | 48 | #endif |
diff --git a/noncore/net/mail/libmailwrapper/mhwrapper.cpp b/noncore/net/mail/libmailwrapper/mhwrapper.cpp new file mode 100644 index 0000000..85f9cf0 --- a/dev/null +++ b/noncore/net/mail/libmailwrapper/mhwrapper.cpp | |||
@@ -0,0 +1,330 @@ | |||
1 | #include "mhwrapper.h" | ||
2 | #include "mailtypes.h" | ||
3 | #include "mailwrapper.h" | ||
4 | #include <libetpan/libetpan.h> | ||
5 | #include <qdir.h> | ||
6 | #include <stdlib.h> | ||
7 | #include <qpe/global.h> | ||
8 | |||
9 | const QString MHwrapper::wrapperType="MH"; | ||
10 | |||
11 | MHwrapper::MHwrapper(const QString & mbox_dir,const QString&mbox_name) | ||
12 | : Genericwrapper(),MHPath(mbox_dir),MHName(mbox_name) | ||
13 | { | ||
14 | if (MHPath.length()>0) { | ||
15 | if (MHPath[MHPath.length()-1]=='/') { | ||
16 | MHPath=MHPath.left(MHPath.length()-1); | ||
17 | } | ||
18 | qDebug(MHPath); | ||
19 | QDir dir(MHPath); | ||
20 | if (!dir.exists()) { | ||
21 | dir.mkdir(MHPath); | ||
22 | } | ||
23 | init_storage(); | ||
24 | } | ||
25 | } | ||
26 | |||
27 | void MHwrapper::init_storage() | ||
28 | { | ||
29 | int r; | ||
30 | QString pre = MHPath; | ||
31 | if (!m_storage) { | ||
32 | m_storage = mailstorage_new(NULL); | ||
33 | r = mh_mailstorage_init(m_storage,(char*)pre.latin1(),0,0,0); | ||
34 | if (r != MAIL_NO_ERROR) { | ||
35 | qDebug("error initializing storage"); | ||
36 | mailstorage_free(m_storage); | ||
37 | m_storage = 0; | ||
38 | return; | ||
39 | } | ||
40 | } | ||
41 | r = mailstorage_connect(m_storage); | ||
42 | if (r!=MAIL_NO_ERROR) { | ||
43 | qDebug("error connecting storage"); | ||
44 | mailstorage_free(m_storage); | ||
45 | m_storage = 0; | ||
46 | } | ||
47 | } | ||
48 | |||
49 | void MHwrapper::clean_storage() | ||
50 | { | ||
51 | if (m_storage) { | ||
52 | mailstorage_disconnect(m_storage); | ||
53 | mailstorage_free(m_storage); | ||
54 | m_storage = 0; | ||
55 | } | ||
56 | } | ||
57 | |||
58 | MHwrapper::~MHwrapper() | ||
59 | { | ||
60 | clean_storage(); | ||
61 | } | ||
62 | |||
63 | void MHwrapper::listMessages(const QString & mailbox, QList<RecMail> &target ) | ||
64 | { | ||
65 | init_storage(); | ||
66 | if (!m_storage) { | ||
67 | return; | ||
68 | } | ||
69 | QString f = buildPath(mailbox); | ||
70 | int r = mailsession_select_folder(m_storage->sto_session,(char*)mailbox.latin1()); | ||
71 | if (r!=MAIL_NO_ERROR) { | ||
72 | qDebug("error selecting folder!"); | ||
73 | return; | ||
74 | } | ||
75 | parseList(target,m_storage->sto_session,f); | ||
76 | Global::statusMessage(tr("Mailbox has %1 mail(s)").arg(target.count())); | ||
77 | } | ||
78 | |||
79 | QList<Folder>* MHwrapper::listFolders() | ||
80 | { | ||
81 | QList<Folder> * folders = new QList<Folder>(); | ||
82 | folders->setAutoDelete( false ); | ||
83 | init_storage(); | ||
84 | if (!m_storage) { | ||
85 | return folders; | ||
86 | } | ||
87 | mail_list*flist = 0; | ||
88 | clistcell*current=0; | ||
89 | int r = mailsession_list_folders(m_storage->sto_session,NULL,&flist); | ||
90 | if (r != MAIL_NO_ERROR || !flist) { | ||
91 | qDebug("error getting folder list"); | ||
92 | return folders; | ||
93 | } | ||
94 | for (current=clist_begin(flist->mb_list);current!=0;current=clist_next(current)) { | ||
95 | QString t = (char*)current->data; | ||
96 | t.replace(0,MHPath.length(),""); | ||
97 | folders->append(new MHFolder(t,MHPath)); | ||
98 | } | ||
99 | mail_list_free(flist); | ||
100 | return folders; | ||
101 | } | ||
102 | |||
103 | void MHwrapper::deleteMail(const RecMail&mail) | ||
104 | { | ||
105 | init_storage(); | ||
106 | if (!m_storage) { | ||
107 | return; | ||
108 | } | ||
109 | int r = mailsession_select_folder(m_storage->sto_session,(char*)mail.getMbox().latin1()); | ||
110 | if (r!=MAIL_NO_ERROR) { | ||
111 | qDebug("error selecting folder!"); | ||
112 | return; | ||
113 | } | ||
114 | r = mailsession_remove_message(m_storage->sto_session,mail.getNumber()); | ||
115 | if (r != MAIL_NO_ERROR) { | ||
116 | qDebug("error deleting mail"); | ||
117 | } | ||
118 | } | ||
119 | |||
120 | void MHwrapper::answeredMail(const RecMail&) | ||
121 | { | ||
122 | } | ||
123 | |||
124 | RecBody MHwrapper::fetchBody( const RecMail &mail ) | ||
125 | { | ||
126 | RecBody body; | ||
127 | init_storage(); | ||
128 | if (!m_storage) { | ||
129 | return body; | ||
130 | } | ||
131 | mailmessage * msg; | ||
132 | char*data=0; | ||
133 | size_t size; | ||
134 | |||
135 | /* mail should hold the complete path! */ | ||
136 | int r = mailsession_select_folder(m_storage->sto_session,(char*)mail.getMbox().latin1()); | ||
137 | if (r != MAIL_NO_ERROR) { | ||
138 | return body; | ||
139 | } | ||
140 | r = mailsession_get_message(m_storage->sto_session, mail.getNumber(), &msg); | ||
141 | if (r != MAIL_NO_ERROR) { | ||
142 | qDebug("Error fetching mail %i",mail.getNumber()); | ||
143 | return body; | ||
144 | } | ||
145 | body = parseMail(msg); | ||
146 | mailmessage_fetch_result_free(msg,data); | ||
147 | return body; | ||
148 | } | ||
149 | |||
150 | void MHwrapper::mbox_progress( size_t current, size_t maximum ) | ||
151 | { | ||
152 | qDebug("MH %i von %i",current,maximum); | ||
153 | } | ||
154 | |||
155 | QString MHwrapper::buildPath(const QString&p) | ||
156 | { | ||
157 | QString f=""; | ||
158 | if (p.length()==0||p=="/") | ||
159 | return MHPath; | ||
160 | if (!p.startsWith(MHPath)) { | ||
161 | f+=MHPath; | ||
162 | } | ||
163 | if (!p.startsWith("/")) { | ||
164 | f+="/"; | ||
165 | } | ||
166 | f+=p; | ||
167 | return f; | ||
168 | } | ||
169 | |||
170 | int MHwrapper::createMbox(const QString&folder,const Folder*,const QString&,bool ) | ||
171 | { | ||
172 | init_storage(); | ||
173 | if (!m_storage) { | ||
174 | return 0; | ||
175 | } | ||
176 | QString f = buildPath(folder); | ||
177 | int r = mailsession_create_folder(m_storage->sto_session,(char*)f.latin1()); | ||
178 | if (r != MAIL_NO_ERROR) { | ||
179 | qDebug("error creating folder"); | ||
180 | return 0; | ||
181 | } | ||
182 | qDebug("Folder created"); | ||
183 | mailstorage_disconnect(m_storage); | ||
184 | return 1; | ||
185 | } | ||
186 | |||
187 | void MHwrapper::storeMessage(const char*msg,size_t length, const QString&Folder) | ||
188 | { | ||
189 | init_storage(); | ||
190 | if (!m_storage) { | ||
191 | return; | ||
192 | } | ||
193 | QString f = buildPath(Folder); | ||
194 | int r = mailsession_select_folder(m_storage->sto_session,(char*)f.latin1()); | ||
195 | if (r!=MAIL_NO_ERROR) { | ||
196 | qDebug("error selecting folder!"); | ||
197 | return; | ||
198 | } | ||
199 | r = mailsession_append_message(m_storage->sto_session,(char*)msg,length); | ||
200 | if (r!=MAIL_NO_ERROR) { | ||
201 | qDebug("error storing mail"); | ||
202 | } | ||
203 | return; | ||
204 | } | ||
205 | |||
206 | encodedString* MHwrapper::fetchRawBody(const RecMail&mail) | ||
207 | { | ||
208 | encodedString*result = 0; | ||
209 | init_storage(); | ||
210 | if (!m_storage) { | ||
211 | return result; | ||
212 | } | ||
213 | mailmessage * msg = 0; | ||
214 | char*data=0; | ||
215 | size_t size; | ||
216 | int r = mailsession_select_folder(m_storage->sto_session,(char*)mail.getMbox().latin1()); | ||
217 | if (r!=MAIL_NO_ERROR) { | ||
218 | qDebug("error selecting folder!"); | ||
219 | return result; | ||
220 | } | ||
221 | r = mailsession_get_message(m_storage->sto_session, mail.getNumber(), &msg); | ||
222 | if (r != MAIL_NO_ERROR) { | ||
223 | Global::statusMessage(tr("Error fetching mail %i").arg(mail.getNumber())); | ||
224 | return 0; | ||
225 | } | ||
226 | r = mailmessage_fetch(msg,&data,&size); | ||
227 | if (r != MAIL_NO_ERROR) { | ||
228 | Global::statusMessage(tr("Error fetching mail %i").arg(mail.getNumber())); | ||
229 | if (msg) mailmessage_free(msg); | ||
230 | return 0; | ||
231 | } | ||
232 | result = new encodedString(data,size); | ||
233 | if (msg) mailmessage_free(msg); | ||
234 | return result; | ||
235 | } | ||
236 | |||
237 | void MHwrapper::deleteMails(const QString & mailbox,QList<RecMail> &target) | ||
238 | { | ||
239 | #if 0 | ||
240 | QString p = MHPath+"/"; | ||
241 | p+=mailbox; | ||
242 | mailmbox_folder*f = 0; | ||
243 | int r = mailmbox_init(p.latin1(),0,1,0,&f); | ||
244 | if (r != MAIL_NO_ERROR) { | ||
245 | qDebug("Error init folder"); | ||
246 | return; | ||
247 | } | ||
248 | deleteMails(f,target); | ||
249 | mailmbox_done(f); | ||
250 | #endif | ||
251 | } | ||
252 | |||
253 | int MHwrapper::deleteAllMail(const Folder*tfolder) | ||
254 | { | ||
255 | init_storage(); | ||
256 | if (!m_storage) { | ||
257 | return 0; | ||
258 | } | ||
259 | int res = 1; | ||
260 | if (!tfolder) return 0; | ||
261 | int r = mailsession_select_folder(m_storage->sto_session,(char*)tfolder->getName().latin1()); | ||
262 | if (r!=MAIL_NO_ERROR) { | ||
263 | qDebug("error selecting folder!"); | ||
264 | return 0; | ||
265 | } | ||
266 | mailmessage_list*l=0; | ||
267 | r = mailsession_get_messages_list(m_storage->sto_session,&l); | ||
268 | if (r != MAIL_NO_ERROR) { | ||
269 | qDebug("Error message list"); | ||
270 | res = 0; | ||
271 | } | ||
272 | unsigned j = 0; | ||
273 | for(unsigned int i = 0 ; l!= 0 && res==1 && i < carray_count(l->msg_tab) ; ++i) { | ||
274 | mailmessage * msg; | ||
275 | msg = (mailmessage*)carray_get(l->msg_tab, i); | ||
276 | j = msg->msg_index; | ||
277 | r = mailsession_remove_message(m_storage->sto_session,j); | ||
278 | if (r != MAIL_NO_ERROR) { | ||
279 | Global::statusMessage(tr("Error deleting mail %1").arg(i+1)); | ||
280 | res = 0; | ||
281 | break; | ||
282 | } | ||
283 | } | ||
284 | if (l) mailmessage_list_free(l); | ||
285 | return res; | ||
286 | } | ||
287 | |||
288 | int MHwrapper::deleteMbox(const Folder*tfolder) | ||
289 | { | ||
290 | init_storage(); | ||
291 | if (!m_storage) { | ||
292 | return 0; | ||
293 | } | ||
294 | if (!tfolder) return 0; | ||
295 | int r = mailsession_delete_folder(m_storage->sto_session,(char*)tfolder->getName().latin1()); | ||
296 | if (r != MAIL_NO_ERROR) { | ||
297 | qDebug("error deleting mail box"); | ||
298 | return 0; | ||
299 | } | ||
300 | qDebug("mail box deleted"); | ||
301 | mailstorage_disconnect(m_storage); | ||
302 | return 1; | ||
303 | } | ||
304 | |||
305 | void MHwrapper::statusFolder(folderStat&target_stat,const QString & mailbox) | ||
306 | { | ||
307 | init_storage(); | ||
308 | if (!m_storage) { | ||
309 | return; | ||
310 | } | ||
311 | target_stat.message_count = 0; | ||
312 | target_stat.message_unseen = 0; | ||
313 | target_stat.message_recent = 0; | ||
314 | QString f = buildPath(mailbox); | ||
315 | int r = mailsession_status_folder(m_storage->sto_session,(char*)f.latin1(),&target_stat.message_count, | ||
316 | &target_stat.message_recent,&target_stat.message_unseen); | ||
317 | if (r != MAIL_NO_ERROR) { | ||
318 | Global::statusMessage(tr("Error retrieving status")); | ||
319 | } | ||
320 | } | ||
321 | |||
322 | const QString&MHwrapper::getType()const | ||
323 | { | ||
324 | return wrapperType; | ||
325 | } | ||
326 | |||
327 | const QString&MHwrapper::getName()const | ||
328 | { | ||
329 | return MHName; | ||
330 | } | ||
diff --git a/noncore/net/mail/libmailwrapper/mhwrapper.h b/noncore/net/mail/libmailwrapper/mhwrapper.h new file mode 100644 index 0000000..7f028b4 --- a/dev/null +++ b/noncore/net/mail/libmailwrapper/mhwrapper.h | |||
@@ -0,0 +1,50 @@ | |||
1 | #ifndef __MH_WRAPPER_H | ||
2 | #define __MH_WRAPPER_H | ||
3 | |||
4 | #include "genericwrapper.h" | ||
5 | #include <qstring.h> | ||
6 | |||
7 | class RecMail; | ||
8 | class RecBody; | ||
9 | class encodedString; | ||
10 | struct mailmbox_folder; | ||
11 | |||
12 | class MHwrapper : public Genericwrapper | ||
13 | { | ||
14 | Q_OBJECT | ||
15 | public: | ||
16 | MHwrapper(const QString & dir,const QString&name); | ||
17 | virtual ~MHwrapper(); | ||
18 | |||
19 | virtual void listMessages(const QString & mailbox, QList<RecMail> &target ); | ||
20 | virtual QList<Folder>* listFolders(); | ||
21 | virtual void statusFolder(folderStat&target_stat,const QString & mailbox="INBOX"); | ||
22 | |||
23 | virtual void deleteMail(const RecMail&mail); | ||
24 | virtual void answeredMail(const RecMail&mail); | ||
25 | |||
26 | virtual int createMbox(const QString&folder,const Folder*f=0,const QString&d="",bool s=false); | ||
27 | virtual int deleteMbox(const Folder*); | ||
28 | |||
29 | virtual void storeMessage(const char*msg,size_t length, const QString&folder); | ||
30 | |||
31 | virtual RecBody fetchBody( const RecMail &mail ); | ||
32 | static void mbox_progress( size_t current, size_t maximum ); | ||
33 | |||
34 | virtual encodedString* fetchRawBody(const RecMail&mail); | ||
35 | virtual void deleteMails(const QString & FolderName,QList<RecMail> &target); | ||
36 | virtual int deleteAllMail(const Folder*); | ||
37 | virtual const QString&getType()const; | ||
38 | virtual const QString&getName()const; | ||
39 | |||
40 | protected: | ||
41 | QString buildPath(const QString&p); | ||
42 | QString MHPath; | ||
43 | QString MHName; | ||
44 | static const QString wrapperType; | ||
45 | |||
46 | void init_storage(); | ||
47 | void clean_storage(); | ||
48 | }; | ||
49 | |||
50 | #endif | ||
diff --git a/noncore/net/mail/libmailwrapper/smtpwrapper.cpp b/noncore/net/mail/libmailwrapper/smtpwrapper.cpp index 281b88e..08f6bb7 100644 --- a/noncore/net/mail/libmailwrapper/smtpwrapper.cpp +++ b/noncore/net/mail/libmailwrapper/smtpwrapper.cpp | |||
@@ -1,65 +1,65 @@ | |||
1 | #include <stdlib.h> | 1 | #include <stdlib.h> |
2 | #include <sys/stat.h> | 2 | #include <sys/stat.h> |
3 | #include <sys/types.h> | 3 | #include <sys/types.h> |
4 | #include <unistd.h> | 4 | #include <unistd.h> |
5 | #include <fcntl.h> | 5 | #include <fcntl.h> |
6 | #include <string.h> | 6 | #include <string.h> |
7 | #include <qdir.h> | 7 | #include <qdir.h> |
8 | #include <qt.h> | 8 | #include <qt.h> |
9 | 9 | ||
10 | #include <qpe/config.h> | 10 | #include <qpe/config.h> |
11 | #include <qpe/qcopenvelope_qws.h> | 11 | #include <qpe/qcopenvelope_qws.h> |
12 | 12 | ||
13 | #include <libetpan/libetpan.h> | 13 | #include <libetpan/libetpan.h> |
14 | 14 | ||
15 | #include "smtpwrapper.h" | 15 | #include "smtpwrapper.h" |
16 | #include "mailwrapper.h" | 16 | #include "mailwrapper.h" |
17 | #include "mboxwrapper.h" | 17 | #include "abstractmail.h" |
18 | #include "logindialog.h" | 18 | #include "logindialog.h" |
19 | #include "mailtypes.h" | 19 | #include "mailtypes.h" |
20 | //#include "defines.h" | 20 | //#include "defines.h" |
21 | #include "sendmailprogress.h" | 21 | #include "sendmailprogress.h" |
22 | 22 | ||
23 | const char* SMTPwrapper::USER_AGENT="OpieMail v0.3"; | 23 | const char* SMTPwrapper::USER_AGENT="OpieMail v0.3"; |
24 | 24 | ||
25 | progressMailSend*SMTPwrapper::sendProgress = 0; | 25 | progressMailSend*SMTPwrapper::sendProgress = 0; |
26 | 26 | ||
27 | SMTPwrapper::SMTPwrapper( Settings *s ) | 27 | SMTPwrapper::SMTPwrapper( Settings *s ) |
28 | : QObject() | 28 | : QObject() |
29 | { | 29 | { |
30 | settings = s; | 30 | settings = s; |
31 | Config cfg( "mail" ); | 31 | Config cfg( "mail" ); |
32 | cfg.setGroup( "Status" ); | 32 | cfg.setGroup( "Status" ); |
33 | m_queuedMail = cfg.readNumEntry( "outgoing", 0 ); | 33 | m_queuedMail = cfg.readNumEntry( "outgoing", 0 ); |
34 | emit queuedMails( m_queuedMail ); | 34 | emit queuedMails( m_queuedMail ); |
35 | connect( this, SIGNAL( queuedMails( int ) ), this, SLOT( emitQCop( int ) ) ); | 35 | connect( this, SIGNAL( queuedMails( int ) ), this, SLOT( emitQCop( int ) ) ); |
36 | } | 36 | } |
37 | 37 | ||
38 | void SMTPwrapper::emitQCop( int queued ) { | 38 | void SMTPwrapper::emitQCop( int queued ) { |
39 | QCopEnvelope env( "QPE/Pim", "outgoingMails(int)" ); | 39 | QCopEnvelope env( "QPE/Pim", "outgoingMails(int)" ); |
40 | env << queued; | 40 | env << queued; |
41 | } | 41 | } |
42 | 42 | ||
43 | QString SMTPwrapper::mailsmtpError( int errnum ) | 43 | QString SMTPwrapper::mailsmtpError( int errnum ) |
44 | { | 44 | { |
45 | switch ( errnum ) { | 45 | switch ( errnum ) { |
46 | case MAILSMTP_NO_ERROR: | 46 | case MAILSMTP_NO_ERROR: |
47 | return tr( "No error" ); | 47 | return tr( "No error" ); |
48 | case MAILSMTP_ERROR_UNEXPECTED_CODE: | 48 | case MAILSMTP_ERROR_UNEXPECTED_CODE: |
49 | return tr( "Unexpected error code" ); | 49 | return tr( "Unexpected error code" ); |
50 | case MAILSMTP_ERROR_SERVICE_NOT_AVAILABLE: | 50 | case MAILSMTP_ERROR_SERVICE_NOT_AVAILABLE: |
51 | return tr( "Service not available" ); | 51 | return tr( "Service not available" ); |
52 | case MAILSMTP_ERROR_STREAM: | 52 | case MAILSMTP_ERROR_STREAM: |
53 | return tr( "Stream error" ); | 53 | return tr( "Stream error" ); |
54 | case MAILSMTP_ERROR_HOSTNAME: | 54 | case MAILSMTP_ERROR_HOSTNAME: |
55 | return tr( "gethostname() failed" ); | 55 | return tr( "gethostname() failed" ); |
56 | case MAILSMTP_ERROR_NOT_IMPLEMENTED: | 56 | case MAILSMTP_ERROR_NOT_IMPLEMENTED: |
57 | return tr( "Not implemented" ); | 57 | return tr( "Not implemented" ); |
58 | case MAILSMTP_ERROR_ACTION_NOT_TAKEN: | 58 | case MAILSMTP_ERROR_ACTION_NOT_TAKEN: |
59 | return tr( "Error, action not taken" ); | 59 | return tr( "Error, action not taken" ); |
60 | case MAILSMTP_ERROR_EXCEED_STORAGE_ALLOCATION: | 60 | case MAILSMTP_ERROR_EXCEED_STORAGE_ALLOCATION: |
61 | return tr( "Data exceeds storage allocation" ); | 61 | return tr( "Data exceeds storage allocation" ); |
62 | case MAILSMTP_ERROR_IN_PROCESSING: | 62 | case MAILSMTP_ERROR_IN_PROCESSING: |
63 | return tr( "Error in processing" ); | 63 | return tr( "Error in processing" ); |
64 | // case MAILSMTP_ERROR_INSUFFISANT_SYSTEM_STORAGE: | 64 | // case MAILSMTP_ERROR_INSUFFISANT_SYSTEM_STORAGE: |
65 | // return tr( "Insufficient system storage" ); | 65 | // return tr( "Insufficient system storage" ); |
@@ -445,96 +445,97 @@ clist *SMTPwrapper::createRcptList( mailimf_fields *fields ) | |||
445 | } | 445 | } |
446 | 446 | ||
447 | field = getField( fields, MAILIMF_FIELD_BCC ); | 447 | field = getField( fields, MAILIMF_FIELD_BCC ); |
448 | if ( field && (field->fld_type == MAILIMF_FIELD_BCC) | 448 | if ( field && (field->fld_type == MAILIMF_FIELD_BCC) |
449 | && field->fld_data.fld_bcc->bcc_addr_list ) { | 449 | && field->fld_data.fld_bcc->bcc_addr_list ) { |
450 | addRcpts( rcptList, field->fld_data.fld_bcc->bcc_addr_list ); | 450 | addRcpts( rcptList, field->fld_data.fld_bcc->bcc_addr_list ); |
451 | } | 451 | } |
452 | 452 | ||
453 | return rcptList; | 453 | return rcptList; |
454 | } | 454 | } |
455 | 455 | ||
456 | char *SMTPwrapper::getFrom( mailimf_field *ffrom) | 456 | char *SMTPwrapper::getFrom( mailimf_field *ffrom) |
457 | { | 457 | { |
458 | char *from = NULL; | 458 | char *from = NULL; |
459 | if ( ffrom && (ffrom->fld_type == MAILIMF_FIELD_FROM) | 459 | if ( ffrom && (ffrom->fld_type == MAILIMF_FIELD_FROM) |
460 | && ffrom->fld_data.fld_from->frm_mb_list && ffrom->fld_data.fld_from->frm_mb_list->mb_list ) { | 460 | && ffrom->fld_data.fld_from->frm_mb_list && ffrom->fld_data.fld_from->frm_mb_list->mb_list ) { |
461 | clist *cl = ffrom->fld_data.fld_from->frm_mb_list->mb_list; | 461 | clist *cl = ffrom->fld_data.fld_from->frm_mb_list->mb_list; |
462 | clistiter *it; | 462 | clistiter *it; |
463 | for ( it = clist_begin( cl ); it; it = it->next ) { | 463 | for ( it = clist_begin( cl ); it; it = it->next ) { |
464 | mailimf_mailbox *mb = (mailimf_mailbox *) it->data; | 464 | mailimf_mailbox *mb = (mailimf_mailbox *) it->data; |
465 | from = strdup( mb->mb_addr_spec ); | 465 | from = strdup( mb->mb_addr_spec ); |
466 | } | 466 | } |
467 | } | 467 | } |
468 | 468 | ||
469 | return from; | 469 | return from; |
470 | } | 470 | } |
471 | 471 | ||
472 | char *SMTPwrapper::getFrom( mailmime *mail ) | 472 | char *SMTPwrapper::getFrom( mailmime *mail ) |
473 | { | 473 | { |
474 | /* no need to delete - its just a pointer to structure content */ | 474 | /* no need to delete - its just a pointer to structure content */ |
475 | mailimf_field *ffrom = 0; | 475 | mailimf_field *ffrom = 0; |
476 | ffrom = getField( mail->mm_data.mm_message.mm_fields, MAILIMF_FIELD_FROM ); | 476 | ffrom = getField( mail->mm_data.mm_message.mm_fields, MAILIMF_FIELD_FROM ); |
477 | return getFrom(ffrom); | 477 | return getFrom(ffrom); |
478 | } | 478 | } |
479 | 479 | ||
480 | void SMTPwrapper::progress( size_t current, size_t maximum ) | 480 | void SMTPwrapper::progress( size_t current, size_t maximum ) |
481 | { | 481 | { |
482 | if (SMTPwrapper::sendProgress) { | 482 | if (SMTPwrapper::sendProgress) { |
483 | SMTPwrapper::sendProgress->setSingleMail(current, maximum ); | 483 | SMTPwrapper::sendProgress->setSingleMail(current, maximum ); |
484 | qApp->processEvents(); | 484 | qApp->processEvents(); |
485 | } | 485 | } |
486 | } | 486 | } |
487 | 487 | ||
488 | void SMTPwrapper::storeMail(const char*mail, size_t length, const QString&box) | 488 | void SMTPwrapper::storeMail(const char*mail, size_t length, const QString&box) |
489 | { | 489 | { |
490 | if (!mail) return; | 490 | if (!mail) return; |
491 | QString localfolders = AbstractMail::defaultLocalfolder(); | 491 | QString localfolders = AbstractMail::defaultLocalfolder(); |
492 | AbstractMail*wrap = AbstractMail::getWrapper(localfolders); | 492 | AbstractMail*wrap = AbstractMail::getWrapper(localfolders); |
493 | wrap->createMbox(box); | ||
493 | wrap->storeMessage(mail,length,box); | 494 | wrap->storeMessage(mail,length,box); |
494 | delete wrap; | 495 | delete wrap; |
495 | } | 496 | } |
496 | 497 | ||
497 | void SMTPwrapper::smtpSend( mailmime *mail,bool later, SMTPaccount *smtp ) | 498 | void SMTPwrapper::smtpSend( mailmime *mail,bool later, SMTPaccount *smtp ) |
498 | { | 499 | { |
499 | clist *rcpts = 0; | 500 | clist *rcpts = 0; |
500 | char *from, *data; | 501 | char *from, *data; |
501 | size_t size; | 502 | size_t size; |
502 | 503 | ||
503 | if ( smtp == NULL ) { | 504 | if ( smtp == NULL ) { |
504 | return; | 505 | return; |
505 | } | 506 | } |
506 | from = data = 0; | 507 | from = data = 0; |
507 | 508 | ||
508 | mailmessage * msg = 0; | 509 | mailmessage * msg = 0; |
509 | msg = mime_message_init(mail); | 510 | msg = mime_message_init(mail); |
510 | mime_message_set_tmpdir(msg,getenv( "HOME" )); | 511 | mime_message_set_tmpdir(msg,getenv( "HOME" )); |
511 | int r = mailmessage_fetch(msg,&data,&size); | 512 | int r = mailmessage_fetch(msg,&data,&size); |
512 | mime_message_detach_mime(msg); | 513 | mime_message_detach_mime(msg); |
513 | mailmessage_free(msg); | 514 | mailmessage_free(msg); |
514 | if (r != MAIL_NO_ERROR || !data) { | 515 | if (r != MAIL_NO_ERROR || !data) { |
515 | if (data) free(data); | 516 | if (data) free(data); |
516 | qDebug("Error fetching mime..."); | 517 | qDebug("Error fetching mime..."); |
517 | return; | 518 | return; |
518 | } | 519 | } |
519 | msg = 0; | 520 | msg = 0; |
520 | if (later) { | 521 | if (later) { |
521 | storeMail(data,size,"Outgoing"); | 522 | storeMail(data,size,"Outgoing"); |
522 | if (data) free( data ); | 523 | if (data) free( data ); |
523 | Config cfg( "mail" ); | 524 | Config cfg( "mail" ); |
524 | cfg.setGroup( "Status" ); | 525 | cfg.setGroup( "Status" ); |
525 | cfg.writeEntry( "outgoing", ++m_queuedMail ); | 526 | cfg.writeEntry( "outgoing", ++m_queuedMail ); |
526 | emit queuedMails( m_queuedMail ); | 527 | emit queuedMails( m_queuedMail ); |
527 | return; | 528 | return; |
528 | } | 529 | } |
529 | from = getFrom( mail ); | 530 | from = getFrom( mail ); |
530 | rcpts = createRcptList( mail->mm_data.mm_message.mm_fields ); | 531 | rcpts = createRcptList( mail->mm_data.mm_message.mm_fields ); |
531 | smtpSend(from,rcpts,data,size,smtp); | 532 | smtpSend(from,rcpts,data,size,smtp); |
532 | if (data) {free(data);} | 533 | if (data) {free(data);} |
533 | if (from) {free(from);} | 534 | if (from) {free(from);} |
534 | if (rcpts) smtp_address_list_free( rcpts ); | 535 | if (rcpts) smtp_address_list_free( rcpts ); |
535 | } | 536 | } |
536 | 537 | ||
537 | int SMTPwrapper::smtpSend(char*from,clist*rcpts,const char*data,size_t size, SMTPaccount *smtp ) | 538 | int SMTPwrapper::smtpSend(char*from,clist*rcpts,const char*data,size_t size, SMTPaccount *smtp ) |
538 | { | 539 | { |
539 | const char *server, *user, *pass; | 540 | const char *server, *user, *pass; |
540 | bool ssl; | 541 | bool ssl; |