Chilkat2-Python
Chilkat2-Python
Examine Yahoo Mail IMAP Session Log
See more Yahoo Mail Examples
To examine the IMAP session log, set the KeepSessionLog property = _TRUE_, and then examine the contents of the SessionLog property.Chilkat Chilkat2-Python Downloads
import sys
import chilkat2
success = False
# This example assumes the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.
# See Get Yahoo Mail OAuth2 Access Token for Desktop App
# for sample code showing how to obtain a Yahoo Mail access token.
# In this example, our access token was previously saved to the following file which contains JSON like this:
# {
# "access_token": "kCVQdnOdul...LHucA--",
# "refresh_token": "AIenVXETSo0jklFBVkPS8vVm8E.Ej9ToRG.xDbDYmZ65WIs5t6CZhDrD",
# "expires_in": 3600,
# "token_type": "bearer",
# "xoauth_yahoo_guid": "HGDQCVF5JB4YDOWHITQJFBHCWA"
# }
json = chilkat2.JsonObject()
success = json.LoadFile("qa_data/tokens/yahooMail.json")
if (success != True):
print("Failed to load Yahoo Mail access token file.")
sys.exit()
accessToken = json.StringOf("access_token")
# Do OAuth2 authentication by using the access token as the password in the Login method below...
imap = chilkat2.Imap()
imap.Ssl = True
imap.Port = 993
# Tell Chilkat IMAP to keep a session log.
imap.KeepSessionLog = True
# Connect to the Yahoo IMAP server.
success = imap.Connect("imap.mail.yahoo.com")
if (success == False):
print(imap.LastErrorText)
sys.exit()
# Indicate that XOAUTH2 authentication is to be used:
imap.AuthMethod = "XOAUTH2"
# Login
# Use the email address of the Yahoo Mail account that granted authorization.
success = imap.Login("user@yahoo.com",accessToken)
if (success != True):
print(imap.LastErrorText)
else:
print("Successfully authenticated with Yahoo IMAP using XOAUTH2!")
# Get the list of mailboxes.
refName = ""
wildcardedMailbox = "*"
subscribed = False
mboxes = chilkat2.Mailboxes()
success = imap.MbxList(subscribed,refName,wildcardedMailbox,mboxes)
if (success == False):
print(imap.LastErrorText)
sys.exit()
i = 0
while i < mboxes.Count :
print(mboxes.GetName(i))
i = i + 1
# Sample output looks like this:
# Archive
# Bulk Mail
# Draft
# Inbox
# Inbox/emailsWithAttach
# Inbox/test
# Sent
# Trash
# Examine the session log
print(imap.SessionLog)
# Sample session log
# ----INFO----
# Connecting to IMAP server at imap.mail.yahoo.com:993
# ----IMAP RESPONSE----
# * OK [CAPABILITY IMAP4rev1 SASL-IR AUTH=PLAIN AUTH=XOAUTH2 AUTH=OAUTHBEARER ID MOVE NAMESPACE XYMHIGHESTMODSEQ UIDPLUS LITERAL+ CHILDREN X-MSG-EXT OBJECTID] IMAP4rev1 Hello
# ----IMAP REQUEST----
# aaab AUTHENTICATE XOAUTH2
# ----IMAP RESPONSE----
# aaab OK AUTHENTICATE completed
# ----IMAP REQUEST----
# aaac LIST "" "*"
# ----IMAP RESPONSE----
# * LIST (\Archive \HasNoChildren) "/" "Archive"
# * LIST (\Junk \HasNoChildren) "/" "Bulk Mail"
# * LIST (\Drafts \HasNoChildren) "/" "Draft"
# * LIST (\HasChildren) "/" "Inbox"
# * LIST (\HasNoChildren) "/" "Inbox/emailsWithAttach"
# * LIST (\HasNoChildren) "/" "Inbox/test"
# * LIST (\Sent \HasNoChildren) "/" "Sent"
# * LIST (\Trash \HasNoChildren) "/" "Trash"
# aaac OK LIST completed
# Disconnect from the IMAP server.
success = imap.Disconnect()