PowerShell
PowerShell
Search IMAP Mailbox for Email Matching Criteria
Searching an IMAP mailbox for messages that match search criteria.Chilkat PowerShell Downloads
Add-Type -Path "C:\chilkat\ChilkatDotNet47-x64\ChilkatDotNet47.dll"
$success = $false
# This example requires the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.
$imap = New-Object Chilkat.Imap
# Connect to an IMAP server.
# Use TLS
$imap.Ssl = $true
$imap.Port = 993
$success = $imap.Connect("imap.example.com")
if ($success -eq $false) {
$($imap.LastErrorText)
exit
}
# Login
$success = $imap.Login("myLogin","myPassword")
if ($success -eq $false) {
$($imap.LastErrorText)
exit
}
# Select an IMAP mailbox
$success = $imap.SelectMailbox("Inbox")
if ($success -eq $false) {
$($imap.LastErrorText)
exit
}
# We can choose to fetch UIDs or sequence numbers.
$fetchUids = $true
# Here are examples of different search criteria:
# Return all messages.
$allMsgs = "ALL"
# Search for already-answered emails.
$answered = "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.
$onDate = "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.
$betweenDates = "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:
$complexSearch1 = "UNANSWERED SENTSINCE 04-Mar-2007 Subject `"Problem`""
# Find messages with a specific string in the body:
$bodySearch = "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:
$orSearch = "OR SUBJECT Help SUBJECT Question"
# ----------------------------------------------
# Strings are case-insensitive when searching....
# ----------------------------------------------
# Find all emails sent from yahoo.com addresses:
$fromSearch = "FROM yahoo.com"
# Find all emails sent from anyone with "John" in their name:
$johnSearch = "FROM John"
# Find emails with the RECENT flag set:
$recentSearch = "RECENT"
# Find emails that don't have the recent flag set:
$notRecentSearch = "NOT RECENT"
# This is synonymous with "OLD":
$oldSearch = "OLD"
# Find all emails marked for deletion:
$markedForDeleteSearch = "DELETED"
# Find all emails having a specified header field with a value
# containing a substring:
$headerSearch = "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:
$headerExistsSearch = "HEADER DomainKey-Signature `"`""
# Find NEW emails: these are emails that have the RECENT flag
# set, but not the SEEN flag:
$newSearch = "NEW"
# Find emails larger than a certain number of bytes:
$sizeLargerSearch = "LARGER 500000"
# Find emails marked as seen or not already seen:
$seenSearch = "SEEN"
$notSeenSearch = "NOT SEEN"
# Find emails having a given substring in the TO header field:
$toSearch = "TO support@chilkatsoft.com"
# A more long-winded way to do the same thing:
$toSearch2 = "HEADER TO support@chilkatsoft.com"
# Find emails smaller than a size in bytes:
$smallerSearch = "SMALLER 30000"
# Find emails that have a substring anywhere in the header
# or body:
$fullSubstringSearch = "TEXT `"Zip Component`""
# Pass any of the above strings here to test a search:
$messageSet = New-Object Chilkat.MessageSet
$success = $imap.QueryMbx($orSearch,$fetchUids,$messageSet)
if ($success -eq $false) {
$($imap.LastErrorText)
exit
}
# Fetch the email headers into a bundle object:
$bundle = New-Object Chilkat.EmailBundle
$headersOnly = $true
$success = $imap.FetchMsgSet($headersOnly,$messageSet,$bundle)
if ($success -eq $false) {
$($imap.LastErrorText)
exit
}
# Display the Subject and From of each email.
$email = New-Object Chilkat.Email
$i = 0
while ($i -lt $bundle.MessageCount) {
$bundle.EmailAt($i,$email)
$($email.GetHeaderField("Date"))
$($email.Subject)
$($email.From)
$("--")
$i = $i + 1
}
# Disconnect from the IMAP server.
$success = $imap.Disconnect()