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
(Unicode C++) List Yahoo Mail IMAP MailboxesSee more Yahoo Mail ExamplesList Yahoo Mail mailboxes.
#include <CkJsonObjectW.h> #include <CkImapW.h> #include <CkMailboxesW.h> void ChilkatSample(void) { // 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" // } CkJsonObjectW json; bool success = json.LoadFile(L"qa_data/tokens/yahooMail.json"); if (success != true) { wprintf(L"Failed to load GMail access token file.\n"); return; } const wchar_t *accessToken = json.stringOf(L"access_token"); // Do OAuth2 authentication by using the access token as the password in the Login method below... CkImapW imap; imap.put_Ssl(true); imap.put_Port(993); // Connect to the Yahoo IMAP server. success = imap.Connect(L"imap.mail.yahoo.com"); if (success != true) { wprintf(L"%s\n",imap.lastErrorText()); return; } // Indicate that XOAUTH2 authentication is to be used: imap.put_AuthMethod(L"XOAUTH2"); // Login // Use the email address of the GMail account that granted authorization. success = imap.Login(L"user@yahoo.com",accessToken); if (success != true) { wprintf(L"%s\n",imap.lastErrorText()); } else { wprintf(L"Successfully authenticated with Yahoo IMAP using XOAUTH2!\n"); } // The ListMailboxes method returns a Mailboxes object // that contains the collection of mailboxes. // It accepts two arguments: a refName and a wildcardedMailbox. const wchar_t *refName = L""; // 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: const wchar_t *wildcardedMailbox = L"*"; CkMailboxesW *mboxes = imap.ListMailboxes(refName,wildcardedMailbox); if (imap.get_LastMethodSuccess() == false) { wprintf(L"%s\n",imap.lastErrorText()); return; } int i = 0; while (i < mboxes->get_Count()) { wprintf(L"%s\n",mboxes->getName(i)); i = i + 1; } // Sample output looks like this: // Archive // Bulk Mail // Draft // Inbox // Inbox/emailsWithAttach // Inbox/test // Sent // Trash // Disconnect from the IMAP server. success = imap.Disconnect(); delete mboxes; } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.