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
(C++) List Yahoo Mail IMAP MailboxesSee more Yahoo Mail ExamplesList Yahoo Mail mailboxes.
#include <CkJsonObject.h> #include <CkImap.h> #include <CkMailboxes.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" // } CkJsonObject json; bool success = json.LoadFile("qa_data/tokens/yahooMail.json"); if (success != true) { std::cout << "Failed to load GMail access token file." << "\r\n"; return; } const char *accessToken = json.stringOf("access_token"); // Do OAuth2 authentication by using the access token as the password in the Login method below... CkImap imap; imap.put_Ssl(true); imap.put_Port(993); // Connect to the Yahoo IMAP server. success = imap.Connect("imap.mail.yahoo.com"); if (success != true) { std::cout << imap.lastErrorText() << "\r\n"; return; } // Indicate that XOAUTH2 authentication is to be used: imap.put_AuthMethod("XOAUTH2"); // Login // Use the email address of the GMail account that granted authorization. success = imap.Login("user@yahoo.com",accessToken); if (success != true) { std::cout << imap.lastErrorText() << "\r\n"; } else { std::cout << "Successfully authenticated with Yahoo IMAP using XOAUTH2!" << "\r\n"; } // The ListMailboxes method returns a Mailboxes object // that contains the collection of mailboxes. // It accepts two arguments: a refName and a wildcardedMailbox. const char *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: const char *wildcardedMailbox = "*"; CkMailboxes *mboxes = imap.ListMailboxes(refName,wildcardedMailbox); if (imap.get_LastMethodSuccess() == false) { std::cout << imap.lastErrorText() << "\r\n"; return; } int i = 0; while (i < mboxes->get_Count()) { std::cout << mboxes->getName(i) << "\r\n"; 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.