Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(AutoIt) Office365 IMAP List MailboxesSee more Office365 ExamplesList the Office365 IMAP mailboxes.
; An Office365 OAuth2 access token must first be obtained prior ; to running this code. ; Getting the OAuth2 access token for the 1st time requires the O365 account owner's ; interactive authorizaition via a web browser. Afterwards, the access token ; can be repeatedly refreshed automatically. ; See the following examples for getting and refreshing an OAuth2 access token ; Get Office365 SMTP/IMAP/POP3 OAuth2 Access Token ; Refresh Office365 SMTP/IMAP/POP3 OAuth2 Access Token ; First get our previously obtained OAuth2 access token. $oJsonToken = ObjCreate("Chilkat.JsonObject") Local $bSuccess = $oJsonToken.LoadFile("qa_data/tokens/office365.json") If ($bSuccess = False) Then ConsoleWrite("Failed to open the office365 OAuth JSON file." & @CRLF) Exit EndIf $oImap = ObjCreate("Chilkat.Imap") $oImap.Ssl = True $oImap.Port = 993 ; Connect to the Office365 IMAP server. $bSuccess = $oImap.Connect("outlook.office365.com") If ($bSuccess <> True) Then ConsoleWrite($oImap.LastErrorText & @CRLF) Exit EndIf ; Use OAuth2 authentication. $oImap.AuthMethod = "XOAUTH2" ; Login using our username (i.e. email address) and the access token for the password. $bSuccess = $oImap.Login("OFFICE365_EMAIL_ADDRESS",$oJsonToken.StringOf("access_token")) If ($bSuccess <> True) Then ConsoleWrite($oImap.LastErrorText & @CRLF) Exit EndIf ConsoleWrite("O365 OAuth authentication is successful." & @CRLF) ; The ListMailboxes method returns a Mailboxes object ; that contains the collection of mailboxes. ; It accepts two arguments: a refName and a wildcardedMailbox. Local $sRefName = "" ; refName is usually set to an empty string. ; A non-empty reference name argument is the name of a mailbox or a level of ; mailbox hierarchy, and indicates the context in which the mailbox ; name is interpreted. ; Select all mailboxes matching this pattern: Local $sWildcardedMailbox = "*" Local $oMboxes = $oImap.ListMailboxes($sRefName,$sWildcardedMailbox) If ($oImap.LastMethodSuccess = False) Then ConsoleWrite($oImap.LastErrorText & @CRLF) Exit EndIf Local $i = 0 While $i < $oMboxes.Count ConsoleWrite($oMboxes.GetName($i) & @CRLF) $i = $i + 1 Wend ; Sample output looks like this: ; Archive ; Calendar ; Calendar/Birthdays ; Calendar/United States holidays ; Contacts ; Conversation History ; Deleted Items ; Drafts ; INBOX ; INBOX/abc ; INBOX/misc ; INBOX/misc/birdeye ; INBOX/old ; INBOX/old/large ; INBOX/receipts ; Journal ; Junk Email ; Notes ; Outbox ; RSS Subscriptions ; Sent Items ; Sync Issues ; Sync Issues/Conflicts ; Sync Issues/Local Failures ; Sync Issues/Server Failures ; Tasks ; Trash ; Disconnect from the IMAP server. $bSuccess = $oImap.Disconnect() |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.