Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(PureBasic) Office365 IMAP List MailboxesSee more Office365 ExamplesList the Office365 IMAP mailboxes.
IncludeFile "CkMailboxes.pb" IncludeFile "CkJsonObject.pb" IncludeFile "CkImap.pb" Procedure ChilkatExample() ; 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. jsonToken.i = CkJsonObject::ckCreate() If jsonToken.i = 0 Debug "Failed to create object." ProcedureReturn EndIf success.i = CkJsonObject::ckLoadFile(jsonToken,"qa_data/tokens/office365.json") If success = 0 Debug "Failed to open the office365 OAuth JSON file." CkJsonObject::ckDispose(jsonToken) ProcedureReturn EndIf imap.i = CkImap::ckCreate() If imap.i = 0 Debug "Failed to create object." ProcedureReturn EndIf CkImap::setCkSsl(imap, 1) CkImap::setCkPort(imap, 993) ; Connect to the Office365 IMAP server. success = CkImap::ckConnect(imap,"outlook.office365.com") If success <> 1 Debug CkImap::ckLastErrorText(imap) CkJsonObject::ckDispose(jsonToken) CkImap::ckDispose(imap) ProcedureReturn EndIf ; Use OAuth2 authentication. CkImap::setCkAuthMethod(imap, "XOAUTH2") ; Login using our username (i.e. email address) and the access token for the password. success = CkImap::ckLogin(imap,"OFFICE365_EMAIL_ADDRESS",CkJsonObject::ckStringOf(jsonToken,"access_token")) If success <> 1 Debug CkImap::ckLastErrorText(imap) CkJsonObject::ckDispose(jsonToken) CkImap::ckDispose(imap) ProcedureReturn EndIf Debug "O365 OAuth authentication is successful." ; The ListMailboxes method returns a Mailboxes object ; that contains the collection of mailboxes. ; It accepts two arguments: a refName and a wildcardedMailbox. refName.s = "" ; 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: wildcardedMailbox.s = "*" mboxes.i = CkImap::ckListMailboxes(imap,refName,wildcardedMailbox) If CkImap::ckLastMethodSuccess(imap) = 0 Debug CkImap::ckLastErrorText(imap) CkJsonObject::ckDispose(jsonToken) CkImap::ckDispose(imap) ProcedureReturn EndIf i.i = 0 While i < CkMailboxes::ckCount(mboxes) Debug CkMailboxes::ckGetName(mboxes,i) 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. success = CkImap::ckDisconnect(imap) CkMailboxes::ckDispose(mboxes) CkJsonObject::ckDispose(jsonToken) CkImap::ckDispose(imap) ProcedureReturn EndProcedure |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.