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
(Visual Basic 6.0) 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. Dim jsonToken As New ChilkatJsonObject Dim success As Long success = jsonToken.LoadFile("qa_data/tokens/office365.json") If (success = 0) Then Debug.Print "Failed to open the office365 OAuth JSON file." Exit Sub End If Dim imap As New ChilkatImap imap.Ssl = 1 imap.Port = 993 ' Connect to the Office365 IMAP server. success = imap.Connect("outlook.office365.com") If (success <> 1) Then Debug.Print imap.LastErrorText Exit Sub End If ' Use OAuth2 authentication. imap.AuthMethod = "XOAUTH2" ' Login using our username (i.e. email address) and the access token for the password. success = imap.Login("OFFICE365_EMAIL_ADDRESS",jsonToken.StringOf("access_token")) If (success <> 1) Then Debug.Print imap.LastErrorText Exit Sub End If Debug.Print "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. Dim refName As String refName = "" ' 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: Dim wildcardedMailbox As String wildcardedMailbox = "*" Dim mboxes As Mailboxes Set mboxes = imap.ListMailboxes(refName,wildcardedMailbox) If (imap.LastMethodSuccess = 0) Then Debug.Print imap.LastErrorText Exit Sub End If Dim i As Long i = 0 Do While i < mboxes.Count Debug.Print mboxes.GetName(i) i = i + 1 Loop ' 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 = imap.Disconnect() |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.