Sample code for 30+ languages & platforms
AutoIt

Search IMAP Mailbox for Email Matching Criteria

Searching an IMAP mailbox for messages that match search criteria.

Chilkat AutoIt Downloads

AutoIt
Local $bSuccess = False

; This example requires the Chilkat API to have been previously unlocked.
; See Global Unlock Sample for sample code.

$oImap = ObjCreate("Chilkat.Imap")

; Connect to an IMAP server.
; Use TLS
$oImap.Ssl = True
$oImap.Port = 993
$bSuccess = $oImap.Connect("imap.example.com")
If ($bSuccess = False) Then
    ConsoleWrite($oImap.LastErrorText & @CRLF)
    Exit
EndIf

; Login
$bSuccess = $oImap.Login("myLogin","myPassword")
If ($bSuccess = False) Then
    ConsoleWrite($oImap.LastErrorText & @CRLF)
    Exit
EndIf

; Select an IMAP mailbox
$bSuccess = $oImap.SelectMailbox("Inbox")
If ($bSuccess = False) Then
    ConsoleWrite($oImap.LastErrorText & @CRLF)
    Exit
EndIf

; We can choose to fetch UIDs or sequence numbers.
Local $bFetchUids = True

; Here are examples of different search criteria:

; Return all messages.
Local $sAllMsgs = "ALL"

; Search for already-answered emails.
Local $sAnswered = "ANSWERED"

; Search for messages on a specific date.
; The date string is DD-Month-YYYY where Month is
; Jan, Feb, Mar, Apr, May, Jun, Jul, Aug, Sep, Oct, Nov, or Dec.
Local $sOnDate = "SENTON 05-Mar-2007"

; Search for messages between two dates.  SENTBEFORE
; finds emails sent before a date, and SENTSINCE finds
; email sent on or after a date.  The "AND" operation
; is implied by joining criteria, separated by spaces.
Local $sBetweenDates = "SENTSINCE 01-Mar-2007 SENTBEFORE 05-Mar-2007"

; Another example of AND: find all unanswered emails
; sent after 04-Mar-2007 with "Problem" in the subject:
Local $sComplexSearch1 = "UNANSWERED SENTSINCE 04-Mar-2007 Subject ""Problem"""

; Find messages with a specific string in the body:
Local $sBodySearch = "BODY ""problem solved"""

; Using OR.  The syntax is OR <criteria1> <criteria2>. 
; The "OR" comes first, followed by each criteria.
; For example, to match all emails with "Help" or "Question" in the subject.
; You'll notice that literal strings may be quoted or unquoted.
; If a literal contains SPACE characters, quote it:
Local $sOrSearch = "OR SUBJECT Help SUBJECT Question"

; ----------------------------------------------
; Strings are case-insensitive when searching....
; ----------------------------------------------

; Find all emails sent from yahoo.com addresses:
Local $sFromSearch = "FROM yahoo.com"
; Find all emails sent from anyone with "John" in their name:
Local $sJohnSearch = "FROM John"

; Find emails with the RECENT flag set:
Local $sRecentSearch = "RECENT"

; Find emails that don't have the recent flag set:
Local $sNotRecentSearch = "NOT RECENT"
; This is synonymous with "OLD":
Local $sOldSearch = "OLD"

; Find all emails marked for deletion:
Local $sMarkedForDeleteSearch = "DELETED"

; Find all emails having a specified header field with a value
; containing a substring:
Local $sHeaderSearch = "HEADER DomainKey-Signature paypal.com"

; Find any emails having a specific header field.  If the 
; 2nd argument to the "HEADER" criteria is an empty string,
; any email having the header field is returned regardless
; of the header field's content.
; Find any emails with a DomainKey-Signature field:
Local $sHeaderExistsSearch = "HEADER DomainKey-Signature """""

; Find NEW emails: these are emails that have the RECENT flag
; set, but not the SEEN flag:
Local $sNewSearch = "NEW"

; Find emails larger than a certain number of bytes:
Local $sizeLargerSearch = "LARGER 500000"

; Find emails marked as seen or not already seen:
Local $seenSearch = "SEEN"
Local $sNotSeenSearch = "NOT SEEN"

; Find emails having a given substring in the TO header field:
Local $sToSearch = "TO support@chilkatsoft.com"
; A more long-winded way to do the same thing:
Local $sToSearch2 = "HEADER TO support@chilkatsoft.com"

; Find emails smaller than a size in bytes:
Local $smallerSearch = "SMALLER 30000"

; Find emails that have a substring anywhere in the header
; or body:
Local $sFullSubstringSearch = "TEXT ""Zip Component"""

; Pass any of the above strings here to test a search:
$oMessageSet = ObjCreate("Chilkat.MessageSet")
$bSuccess = $oImap.QueryMbx($sOrSearch,$bFetchUids,$oMessageSet)
If ($bSuccess = False) Then
    ConsoleWrite($oImap.LastErrorText & @CRLF)
    Exit
EndIf

; Fetch the email headers into a bundle object:
$oBundle = ObjCreate("Chilkat.EmailBundle")
Local $bHeadersOnly = True
$bSuccess = $oImap.FetchMsgSet($bHeadersOnly,$oMessageSet,$oBundle)
If ($bSuccess = False) Then
    ConsoleWrite($oImap.LastErrorText & @CRLF)
    Exit
EndIf

; Display the Subject and From of each email.
$oEmail = ObjCreate("Chilkat.Email")
Local $i = 0
While $i < $oBundle.MessageCount
    $oBundle.EmailAt($i,$oEmail)

    ConsoleWrite($oEmail.GetHeaderField("Date") & @CRLF)
    ConsoleWrite($oEmail.Subject & @CRLF)
    ConsoleWrite($oEmail.From & @CRLF)
    ConsoleWrite("--" & @CRLF)

    $i = $i + 1
Wend

; Disconnect from the IMAP server.
$bSuccess = $oImap.Disconnect()