Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Delphi DLL) Move Selected Emails to another Mailbox FolderDownloads emails one by one in a selected mailbox, decides which emails are to be moved, and then moves the set of messages to another mailbox folder.
uses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics, Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Imap, Email, MessageSet; ... procedure TForm1.Button1Click(Sender: TObject); var imap: HCkImap; success: Boolean; numEmails: Integer; mset: HCkMessageSet; i: Integer; email: HCkEmail; destFolder: PWideChar; begin // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. imap := CkImap_Create(); // Connect to an IMAP server. // Use TLS CkImap_putSsl(imap,True); CkImap_putPort(imap,993); success := CkImap_Connect(imap,'imap.someMailServer.com'); if (success <> True) then begin Memo1.Lines.Add(CkImap__lastErrorText(imap)); Exit; end; // Login success := CkImap_Login(imap,'myLogin','myPassword'); if (success <> True) then begin Memo1.Lines.Add(CkImap__lastErrorText(imap)); Exit; end; // Select an IMAP mailbox success := CkImap_SelectMailbox(imap,'Inbox'); if (success <> True) then begin Memo1.Lines.Add(CkImap__lastErrorText(imap)); Exit; end; // Normally, when an email is downloaded, its "Seen" flag is automatically set. // We don't want our program to be interfering with the "Seen" flags. // To do this, set the PeekMode to True. CkImap_putPeekMode(imap,True); // After selecting the mailbox, the NumMessages property // will contain the number of emails in the mailbox. // When sequence numbers (not UIDs) are used to reference emails, // they range from 1 to N, where N is the number of messages in the mailbox. // This example will download the headers by sequence numbers. numEmails := CkImap_getNumMessages(imap); mset := CkMessageSet_Create(); // Indicate that mset contains sequence numbers, not UIDs. CkMessageSet_putHasUids(mset,False); // Fetch each email and decide for each if it is to be moved // to a particular other mailbox. If so, we'll add the sequence number to // the mset, and then move all emails in the mset to the other mailbox. i := 0; while i < numEmails do begin // Fetch the email by sequence number. email := CkImap_FetchSingle(imap,i + 1,False); if (CkImap_getLastMethodSuccess(imap) <> True) then begin Memo1.Lines.Add(CkImap__lastErrorText(imap)); Exit; end; // If it is decided to move the email, add the sequence number to mset, like this: CkMessageSet_InsertId(mset,i + 1); CkEmail_Dispose(email); end; // If there are emails in mset to be moved, then do it.. if (CkMessageSet_getCount(mset) > 0) then begin destFolder := 'Inbox/SomeOtherFolder'; // Assuming your IMAP server supports the feature that allows for messages to be moved to another folder... success := CkImap_MoveMessages(imap,mset,destFolder); if (success <> True) then begin Memo1.Lines.Add(CkImap__lastErrorText(imap)); Exit; end; end; // Disconnect from the IMAP server. success := CkImap_Disconnect(imap); CkImap_Dispose(imap); CkMessageSet_Dispose(mset); end; |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.