summaryrefslogtreecommitdiff
authoralwin <alwin>2004-01-08 19:15:10 (UTC)
committer alwin <alwin>2004-01-08 19:15:10 (UTC)
commit6287f011db0a566d17ae1614d8129f421125d934 (patch) (unidiff)
tree8c449974e9b577fe8dcc5348c4d109e82659b218
parent44443aec5d4b8f974b30b1e9b4ea920d6582add1 (diff)
downloadopie-6287f011db0a566d17ae1614d8129f421125d934.zip
opie-6287f011db0a566d17ae1614d8129f421125d934.tar.gz
opie-6287f011db0a566d17ae1614d8129f421125d934.tar.bz2
MH storage implemented
local folders will be type of MH not MBOX
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/mail/accountview.cpp64
-rw-r--r--noncore/net/mail/accountview.h18
-rw-r--r--noncore/net/mail/libmailwrapper/abstractmail.cpp3
-rw-r--r--noncore/net/mail/libmailwrapper/genericwrapper.cpp8
-rw-r--r--noncore/net/mail/libmailwrapper/genericwrapper.h4
-rw-r--r--noncore/net/mail/libmailwrapper/libmailwrapper.pro6
-rw-r--r--noncore/net/mail/libmailwrapper/mailwrapper.cpp18
-rw-r--r--noncore/net/mail/libmailwrapper/mailwrapper.h11
-rw-r--r--noncore/net/mail/libmailwrapper/mboxwrapper.h1
-rw-r--r--noncore/net/mail/libmailwrapper/mhwrapper.cpp330
-rw-r--r--noncore/net/mail/libmailwrapper/mhwrapper.h50
-rw-r--r--noncore/net/mail/libmailwrapper/smtpwrapper.cpp3
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)
532AccountViewItem::AccountViewItem( QListViewItem *parent , QListViewItem*after ) 532AccountViewItem::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
538AccountViewItem::~AccountViewItem() 538AccountViewItem::~AccountViewItem()
539{ 539{
540} 540}
541 541
542AccountView*AccountViewItem::accountView() 542AccountView*AccountViewItem::accountView()
543{ 543{
544 return m_Backlink; 544 return m_Backlink;
545} 545}
546 546
547void AccountViewItem::deleteAllMail(AbstractMail*wrapper,Folder*folder) 547void 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
566AccountView::AccountView( QWidget *parent, const char *name, WFlags flags ) 566AccountView::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
577AccountView::~AccountView() 577AccountView::~AccountView()
578{ 578{
579 imapAccounts.clear(); 579 imapAccounts.clear();
580 mboxAccounts.clear(); 580 mhAccounts.clear();
581} 581}
582 582
583void AccountView::slotContextMenu(int id) 583void 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
590void AccountView::slotHold(int button, QListViewItem * item,const QPoint&,int) 590void 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
603void AccountView::populate( QList<Account> list ) 603void 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
627void AccountView::refresh(QListViewItem *item) { 627void 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
640void AccountView::refreshCurrent() 640void 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
651void AccountView::refreshAll() 651void AccountView::refreshAll()
652{ 652{
653 653
654} 654}
655 655
656RecBody AccountView::fetchBody(const RecMail&aMail) 656RecBody 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
664void AccountView::setupFolderselect(Selectstore*sels) 664void 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
682void AccountView::downloadMails(Folder*fromFolder,AbstractMail*fromWrapper) 682void 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
710MBOXviewItem::MBOXviewItem( const QString&aPath, AccountView *parent ) 710MHviewItem::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
721MBOXviewItem::~MBOXviewItem() 721MHviewItem::~MHviewItem()
722{ 722{
723 delete wrapper; 723 delete wrapper;
724} 724}
725 725
726AbstractMail *MBOXviewItem::getWrapper() 726AbstractMail *MHviewItem::getWrapper()
727{ 727{
728 return wrapper; 728 return wrapper;
729} 729}
730 730
731void MBOXviewItem::refresh( QList<RecMail> & ) 731void MHviewItem::refresh( QList<RecMail> & )
732{ 732{
733 refresh(false); 733 refresh(false);
734} 734}
735 735
736void MBOXviewItem::refresh(bool force) 736void 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
757RecBody MBOXviewItem::fetchBody( const RecMail &mail ) 757RecBody 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
763QPopupMenu * MBOXviewItem::getContextMenu() 763QPopupMenu * 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
773void MBOXviewItem::createFolder() 773void 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
785QStringList MBOXviewItem::subFolders() 785QStringList 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
798void MBOXviewItem::contextMenuSelected(int which) 798void 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
812MBOXfolderItem::~MBOXfolderItem() 812MHfolderItem::~MHfolderItem()
813{ 813{
814 delete folder; 814 delete folder;
815} 815}
816 816
817MBOXfolderItem::MBOXfolderItem( Folder *folderInit, MBOXviewItem *parent , QListViewItem*after ) 817MHfolderItem::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
832Folder*MBOXfolderItem::getFolder() 832Folder*MHfolderItem::getFolder()
833{ 833{
834 return folder; 834 return folder;
835} 835}
836 836
837void MBOXfolderItem::refresh(QList<RecMail>&target) 837void 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
843RecBody MBOXfolderItem::fetchBody(const RecMail&aMail) 843RecBody MHfolderItem::fetchBody(const RecMail&aMail)
844{ 844{
845 return mbox->getWrapper()->fetchBody(aMail); 845 return mbox->getWrapper()->fetchBody(aMail);
846} 846}
847 847
848void MBOXfolderItem::deleteFolder() 848void 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
869QPopupMenu * MBOXfolderItem::getContextMenu() 869QPopupMenu * 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
880void MBOXfolderItem::downloadMails() 880void 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
887void MBOXfolderItem::contextMenuSelected(int which) 887void 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
74class IMAPfolderItem; 74class IMAPfolderItem;
75 75
76class IMAPviewItem : public AccountViewItem 76class IMAPviewItem : public AccountViewItem
77{ 77{
78 friend class IMAPfolderItem; 78 friend class IMAPfolderItem;
79public: 79public:
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
91protected: 91protected:
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
100class IMAPfolderItem : public AccountViewItem 100class IMAPfolderItem : public AccountViewItem
101{ 101{
102 102
103public: 103public:
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;
113protected: 113protected:
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
121class MBOXviewItem : public AccountViewItem 121class MHviewItem : public AccountViewItem
122{ 122{
123 friend class MBOXfolderItem; 123 friend class MHfolderItem;
124 124
125public: 125public:
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
136protected: 136protected:
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
143class MBOXfolderItem : public AccountViewItem 143class MHfolderItem : public AccountViewItem
144{ 144{
145 145
146public: 146public:
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
155protected: 155protected:
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
162class AccountView : public QListView 162class AccountView : public QListView
163{ 163{
164 Q_OBJECT 164 Q_OBJECT
165 165
166public: 166public:
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
173public slots: 173public 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
181signals: 181signals:
182 void refreshMailview(QList<RecMail>*); 182 void refreshMailview(QList<RecMail>*);
183 183
184protected: 184protected:
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
14AbstractMail* AbstractMail::getWrapper(IMAPaccount *a) 15AbstractMail* AbstractMail::getWrapper(IMAPaccount *a)
15{ 16{
16 return new IMAPwrapper(a); 17 return new IMAPwrapper(a);
17} 18}
18 19
19AbstractMail* AbstractMail::getWrapper(POP3account *a) 20AbstractMail* AbstractMail::getWrapper(POP3account *a)
20{ 21{
21 return new POP3wrapper(a); 22 return new POP3wrapper(a);
22} 23}
23 24
24AbstractMail* AbstractMail::getWrapper(const QString&a,const QString&name) 25AbstractMail* 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
29encodedString* AbstractMail::decode_String(const encodedString*text,const QString&enc) 30encodedString* 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
59QString AbstractMail::convert_String(const char*text) 60QString 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
5Genericwrapper::Genericwrapper() 5Genericwrapper::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
11Genericwrapper::~Genericwrapper() 13Genericwrapper::~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
16void Genericwrapper::fillSingleBody(RecPart&target,mailmessage*,mailmime*mime) 24void 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
9class RecMail; 9class RecMail;
10class RecBody; 10class RecBody;
11class encodedString; 11class encodedString;
12struct mailpop3; 12struct mailpop3;
13struct mailmessage; 13struct mailmessage;
14struct mailmime; 14struct mailmime;
15struct mailmime_mechanism; 15struct mailmime_mechanism;
16struct mailimf_mailbox_list; 16struct mailimf_mailbox_list;
17struct mailimf_mailbox; 17struct mailimf_mailbox;
18struct mailimf_date_time; 18struct mailimf_date_time;
19struct mailimf_group; 19struct mailimf_group;
20struct mailimf_address_list; 20struct mailimf_address_list;
21struct mailsession; 21struct mailsession;
22struct mailstorage;
23struct 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 */
27class Genericwrapper : public AbstractMail 29class Genericwrapper : public AbstractMail
28{ 30{
29 Q_OBJECT 31 Q_OBJECT
30public: 32public:
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
42protected: 44protected:
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 @@
1TEMPLATE = lib 1TEMPLATE = lib
2CONFIG += qt warn_on debug 2CONFIG += qt warn_on debug
3 3
4HEADERS = mailwrapper.h \ 4HEADERS = 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
17SOURCES = imapwrapper.cpp \ 18SOURCES = 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
34INCLUDEPATH += $(OPIEDIR)/include 36INCLUDEPATH += $(OPIEDIR)/include
35 37
36CONFTEST = $$system( echo $CONFIG_TARGET_MACOSX ) 38CONFTEST = $$system( echo $CONFIG_TARGET_MACOSX )
37contains( CONFTEST, y ){ 39contains( 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
43DESTDIR = $(OPIEDIR)/lib$(PROJMAK) 45DESTDIR = $(OPIEDIR)/lib$(PROJMAK)
44TARGET = mailwrapper 46TARGET = mailwrapper
45 47
46include ( $(OPIEDIR)/include.pro ) 48include ( $(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
24Attachment::Attachment( DocLnk lnk ) 24Attachment::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
30Folder::Folder(const QString&tmp_name, const QString&sep ) 30Folder::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
37const QString& Folder::Separator()const 38const QString& Folder::Separator()const
38{ 39{
39 return separator; 40 return separator;
40} 41}
41 42
42IMAPFolder::IMAPFolder(const QString&name,const QString&sep, bool select,bool no_inf, const QString&prefix ) 43IMAPFolder::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
56static unsigned char base64chars[] = 58static 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 */
63QString IMAPFolder::decodeFolderName( const QString &name ) 65QString 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
145Mail::Mail() 147Mail::Mail()
146 :name(""), mail(""), to(""), cc(""), bcc(""), reply(""), subject(""), message("") 148 :name(""), mail(""), to(""), cc(""), bcc(""), reply(""), subject(""), message("")
147{ 149{
148} 150}
151
152MHFolder::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
29class Mail 29class Mail
30{ 30{
31public: 31public:
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
59private: 59private:
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
64class Folder : public QObject 64class Folder : public QObject
65{ 65{
66 Q_OBJECT 66 Q_OBJECT
67 67
68public: 68public:
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
76protected: 77protected:
77 QString nameDisplay, name, separator; 78 QString nameDisplay, name, separator,prefix;
78 79};
80
81class MHFolder : public Folder
82{
83 Q_OBJECT
84public:
85 MHFolder(const QString&disp_name,const QString&mbox);
79}; 86};
80 87
81class IMAPFolder : public Folder 88class 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
7class RecMail; 7class RecMail;
8class RecBody; 8class RecBody;
9class encodedString; 9class encodedString;
10struct mailmbox_folder; 10struct mailmbox_folder;
11 11
12class MBOXwrapper : public Genericwrapper 12class MBOXwrapper : public Genericwrapper
13{ 13{
14 Q_OBJECT 14 Q_OBJECT
15
15public: 16public:
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
40protected: 41protected:
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
9const QString MHwrapper::wrapperType="MH";
10
11MHwrapper::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
27void 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
49void 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
58MHwrapper::~MHwrapper()
59{
60 clean_storage();
61}
62
63void 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
79QList<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
103void 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
120void MHwrapper::answeredMail(const RecMail&)
121{
122}
123
124RecBody 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
150void MHwrapper::mbox_progress( size_t current, size_t maximum )
151{
152 qDebug("MH %i von %i",current,maximum);
153}
154
155QString 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
170int 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
187void 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
206encodedString* 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
237void 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
253int 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
288int 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
305void 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
322const QString&MHwrapper::getType()const
323{
324 return wrapperType;
325}
326
327const 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
7class RecMail;
8class RecBody;
9class encodedString;
10struct mailmbox_folder;
11
12class MHwrapper : public Genericwrapper
13{
14 Q_OBJECT
15public:
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
40protected:
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
23const char* SMTPwrapper::USER_AGENT="OpieMail v0.3"; 23const char* SMTPwrapper::USER_AGENT="OpieMail v0.3";
24 24
25progressMailSend*SMTPwrapper::sendProgress = 0; 25progressMailSend*SMTPwrapper::sendProgress = 0;
26 26
27SMTPwrapper::SMTPwrapper( Settings *s ) 27SMTPwrapper::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
38void SMTPwrapper::emitQCop( int queued ) { 38void 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
43QString SMTPwrapper::mailsmtpError( int errnum ) 43QString 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
456char *SMTPwrapper::getFrom( mailimf_field *ffrom) 456char *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
472char *SMTPwrapper::getFrom( mailmime *mail ) 472char *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
480void SMTPwrapper::progress( size_t current, size_t maximum ) 480void 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
488void SMTPwrapper::storeMail(const char*mail, size_t length, const QString&box) 488void 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
497void SMTPwrapper::smtpSend( mailmime *mail,bool later, SMTPaccount *smtp ) 498void 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
537int SMTPwrapper::smtpSend(char*from,clist*rcpts,const char*data,size_t size, SMTPaccount *smtp ) 538int 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;