Unicode C
Unicode C
Fetch Full Email Given Email Header
When you fetch email headers using UIDs instead of sequence numbers, the email object (which includes only the header) will have auto-generatedckx-imap-* headers. These headers provide details like the UID and attachments. The IMAP UID is found in the ckx-imap-uid header. Additionally, the ckx-imap-isUid header indicates whether the email header was downloaded by UID, showing YES or NO. Since sequence numbers can change if emails are deleted, UIDs are essential for downloading the correct full email.
The Chilkat Email object offers a GetImapUid method to retrieve the UID from the ckx-imap-uid header. This UID can be used to fetch the full email.
Chilkat Unicode C Downloads
#include <C_CkImapW.h>
#include <C_CkEmailW.h>
void ChilkatSample(void)
{
BOOL success;
HCkImapW imap;
HCkEmailW emailHeader;
HCkEmailW emailFull;
int uid;
BOOL isUid;
int uidFromCkxHeader;
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"***",L"***");
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;
}
emailHeader = CkEmailW_Create();
emailFull = CkEmailW_Create();
uid = 2014;
isUid = TRUE;
// Fetch only the email header
success = CkImapW_FetchEmail(imap,TRUE,uid,isUid,emailHeader);
if (success == FALSE) {
wprintf(L"%s\n",CkImapW_lastErrorText(imap));
CkImapW_Dispose(imap);
CkEmailW_Dispose(emailHeader);
CkEmailW_Dispose(emailFull);
return;
}
// Now fetch the full email
uidFromCkxHeader = CkEmailW_GetImapUid(emailHeader);
if (uidFromCkxHeader < 0) {
// Failed.
wprintf(L"No ckx-imap-uid header was found.\n");
CkImapW_Dispose(imap);
CkEmailW_Dispose(emailHeader);
CkEmailW_Dispose(emailFull);
return;
}
success = CkImapW_FetchEmail(imap,FALSE,uid,isUid,emailFull);
if (success == FALSE) {
wprintf(L"%s\n",CkImapW_lastErrorText(imap));
CkImapW_Dispose(imap);
CkEmailW_Dispose(emailHeader);
CkEmailW_Dispose(emailFull);
return;
}
// OK, we have the full email, do whatever we want...
// Disconnect from the IMAP server.
success = CkImapW_Disconnect(imap);
CkImapW_Dispose(imap);
CkEmailW_Dispose(emailHeader);
CkEmailW_Dispose(emailFull);
}