Unicode C
Unicode C
Move Selected Emails to another Mailbox Folder
See more IMAP Examples
Downloads 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.Chilkat Unicode C Downloads
#include <C_CkImapW.h>
#include <C_CkMessageSetW.h>
#include <C_CkEmailW.h>
void ChilkatSample(void)
{
BOOL success;
HCkImapW imap;
int numEmails;
HCkMessageSetW mset;
HCkEmailW email;
int i;
const wchar_t *destFolder;
success = FALSE;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
imap = CkImapW_Create();
// Connect to an IMAP server.
// Use TLS
CkImapW_putSsl(imap,TRUE);
CkImapW_putPort(imap,993);
success = CkImapW_Connect(imap,L"imap.example.com");
if (success == FALSE) {
wprintf(L"%s\n",CkImapW_lastErrorText(imap));
CkImapW_Dispose(imap);
return;
}
// Login
success = CkImapW_Login(imap,L"myLogin",L"myPassword");
if (success == FALSE) {
wprintf(L"%s\n",CkImapW_lastErrorText(imap));
CkImapW_Dispose(imap);
return;
}
// Select an IMAP mailbox
success = CkImapW_SelectMailbox(imap,L"Inbox");
if (success == FALSE) {
wprintf(L"%s\n",CkImapW_lastErrorText(imap));
CkImapW_Dispose(imap);
return;
}
// 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.
CkImapW_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 = CkImapW_getNumMessages(imap);
mset = CkMessageSetW_Create();
// Indicate that mset contains sequence numbers, not UIDs.
CkMessageSetW_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.
email = CkEmailW_Create();
i = 0;
while (i < numEmails) {
// Fetch the email by sequence number.
success = CkImapW_FetchEmail(imap,FALSE,i + 1,FALSE,email);
if (success == FALSE) {
wprintf(L"%s\n",CkImapW_lastErrorText(imap));
CkImapW_Dispose(imap);
CkMessageSetW_Dispose(mset);
CkEmailW_Dispose(email);
return;
}
// If it is decided to move the email, add the sequence number to mset, like this:
CkMessageSetW_InsertId(mset,i + 1);
}
// If there are emails in mset to be moved, then do it..
if (CkMessageSetW_getCount(mset) > 0) {
destFolder = L"Inbox/SomeOtherFolder";
// Assuming your IMAP server supports the feature that allows for messages to be moved to another folder...
success = CkImapW_MoveMessages(imap,mset,destFolder);
if (success == FALSE) {
wprintf(L"%s\n",CkImapW_lastErrorText(imap));
CkImapW_Dispose(imap);
CkMessageSetW_Dispose(mset);
CkEmailW_Dispose(email);
return;
}
}
// Disconnect from the IMAP server.
success = CkImapW_Disconnect(imap);
CkImapW_Dispose(imap);
CkMessageSetW_Dispose(mset);
CkEmailW_Dispose(email);
}