Delphi DLL
Delphi DLL
IMAP Get List of Flags
See more IMAP Examples
When a mailbox is selected, the server response includes a list of flags:The FLAGS response occurs as a result of a SELECT or EXAMINE command. The flag parenthesized list identifies the flags (at a minimum, the system-defined flags) that are applicable for this mailbox. Flags other than the system flags can also exist, depending on server implementation.This example demonstrates how to capture the SELECT (or EXAMINE) response, and parse the list of flags.
Chilkat Delphi DLL Downloads
uses
Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, StringTable, StringBuilder, Imap;
...
procedure TForm1.Button1Click(Sender: TObject);
var
success: Boolean;
imap: HCkImap;
selectResponse: PWideChar;
sbResponse: HCkStringBuilder;
sbFlagList: HCkStringBuilder;
numReplaced: Integer;
flagsTable: HCkStringTable;
i: Integer;
begin
success := False;
imap := CkImap_Create();
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
// Connect to an IMAP server.
// Use TLS
CkImap_putSsl(imap,True);
CkImap_putPort(imap,993);
success := CkImap_Connect(imap,'MY-IMAP-DOMAIN');
if (success <> True) then
begin
Memo1.Lines.Add(CkImap__lastErrorText(imap));
Exit;
end;
// Login
success := CkImap_Login(imap,'MY-IMAP-LOGIN','MY-IMAP-PASSWORD');
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;
// The LastResponse property contains the full response of the last command.
selectResponse := CkImap__lastResponse(imap);
Memo1.Lines.Add(selectResponse);
// For example, on GMail, the SELECT response looks like this:
// * FLAGS (\Answered \Flagged \Draft \Deleted \Seen $Forwarded $NotPhishing $Phishing $label1 $label2 $label3 $label4 $label5 Junk NonJunk)
// * OK [PERMANENTFLAGS (\Answered \Flagged \Draft \Deleted \Seen $Forwarded $NotPhishing $Phishing $label1 $label2 $label3 $label4 $label5 Junk NonJunk \*)] Flags permitted.
// * OK [UIDVALIDITY 3] UIDs valid.
// * 46 EXISTS
// * 0 RECENT
// * OK [UIDNEXT 4147] Predicted next UID.
// * OK [HIGHESTMODSEQ 402971]
// aaac OK [READ-WRITE] INBOX selected. (Success)
// The goal of this example is to capture the list of FLAGS.
// All IMAP servers will respond with the list of flags in a SPACE separated list enclosed in parentheses.
sbResponse := CkStringBuilder_Create();
CkStringBuilder_Append(sbResponse,selectResponse);
// Get just the list of flags:
sbFlagList := CkStringBuilder_Create();
CkStringBuilder_Append(sbFlagList,CkStringBuilder__getAfterBetween(sbResponse,'* FLAGS','(',')'));
Memo1.Lines.Add(CkStringBuilder__getAsString(sbFlagList));
// sbFlagList contains this:
//
// \Answered \Flagged \Draft \Deleted \Seen $Forwarded $NotPhishing $Phishing $label1 $label2 $label3 $label4 $label5 Junk NonJunk
//
// Make sure no more than one SPACE char in a row exists.
CkStringBuilder_TrimInsideSpaces(sbFlagList);
// Modify sbFlagList to one flag per line
numReplaced := CkStringBuilder_Replace(sbFlagList,' ',#13#10);
// Load a StringTable with the flag names.
flagsTable := CkStringTable_Create();
CkStringTable_AppendFromSb(flagsTable,sbFlagList);
// Iterate over the individual flag names:
i := 0;
while i < CkStringTable_getCount(flagsTable) do
begin
Memo1.Lines.Add(IntToStr(i) + ': ' + CkStringTable__stringAt(flagsTable,i));
i := i + 1;
end;
// The output is:
//
// 0: \Answered
// 1: \Flagged
// 2: \Draft
// 3: \Deleted
// 4: \Seen
// 5: $Forwarded
// 6: $NotPhishing
// 7: $Phishing
// 8: $label1
// 9: $label2
// 10: $label3
// 11: $label4
// 12: $label5
// 13: Junk
// 14: NonJunk
//
CkImap_Dispose(imap);
CkStringBuilder_Dispose(sbResponse);
CkStringBuilder_Dispose(sbFlagList);
CkStringTable_Dispose(flagsTable);
end;