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
(Unicode C++) POP3 Auto-Refresh Office365 Access TokenSee more Office365 ExamplesDemonstrates how to automatically recover from an expired OAuth2 access token when OAuth2 authentication fails in the POP3 protocol. If the server responds with "-ERR Authentication failure: unknown user name or bad password.", then we refresh the access token and retry.
#include <CkMailManW.h> #include <CkJsonObjectW.h> #include <CkOAuth2W.h> #include <CkStringBuilderW.h> void ChilkatSample(void) { // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkMailManW mailman; mailman.put_MailHost(L"outlook.office365.com"); mailman.put_MailPort(995); mailman.put_PopSsl(true); // Use your O365 email address here. mailman.put_PopUsername(L"OFFICE365_EMAIL_ADDRESS"); // When using OAuth2 authentication, leave the password empty. mailman.put_PopPassword(L""); // Load our previously obtained OAuth2 access token. CkJsonObjectW jsonToken; bool success = jsonToken.LoadFile(L"qa_data/tokens/office365.json"); if (success == false) { wprintf(L"%s\n",jsonToken.lastErrorText()); return; } mailman.put_OAuth2AccessToken(jsonToken.stringOf(L"access_token")); // Make the TLS connection to the outlook.office365.com POP3 server. success = mailman.Pop3Connect(); if (success != true) { wprintf(L"%s\n",mailman.lastErrorText()); return; } // Authenticate using XOAUTH2 success = mailman.Pop3Authenticate(); if (success != true) { // If we're still connected to the mail server, then it means the server sent a non-success response, // Such as: -ERR Authentication failure: unknown user name or bad password. if (mailman.get_IsPop3Connected() == true) { // Refresh the OAuth2 access token, and if successful, save the new (refreshed) access token and try authenticating again. CkOAuth2W oauth2; // Use your actual Directory (tenant) ID instead of "112d7ed6-71bf-4eba-a866-738364321bfc" oauth2.put_TokenEndpoint(L"https://login.microsoftonline.com/112d7ed6-71bf-4eba-a866-738364321bfc/oauth2/v2.0/token"); // Replace these with your Azure App Registration's actual values. oauth2.put_ClientId(L"CLIENT_ID"); oauth2.put_ClientSecret(L"CLIENT_SECRET"); // Get the "refresh_token" oauth2.put_RefreshToken(jsonToken.stringOf(L"refresh_token")); // Send the HTTP POST to refresh the access token.. success = oauth2.RefreshAccessToken(); if (success != true) { wprintf(L"%s\n",oauth2.lastErrorText()); return; } wprintf(L"New access token: %s\n",oauth2.accessToken()); wprintf(L"New refresh token: %s\n",oauth2.refreshToken()); // Update the JSON with the new tokens. jsonToken.UpdateString(L"access_token",oauth2.accessToken()); jsonToken.UpdateString(L"refresh_token",oauth2.refreshToken()); // Save the new JSON access token response to a file. CkStringBuilderW sbJson; jsonToken.put_EmitCompact(false); jsonToken.EmitSb(sbJson); sbJson.WriteFile(L"qa_data/tokens/office365.json",L"utf-8",false); wprintf(L"New Access Token = %s\n",oauth2.accessToken()); // Update the mailman with the new access token. mailman.put_OAuth2AccessToken(oauth2.accessToken()); // Retry the authentication. success = mailman.Pop3Authenticate(); if (success == false) { wprintf(L"%s\n",mailman.lastErrorText()); return; } } else { wprintf(L"%s\n",mailman.lastErrorText()); return; } } // Find out how many emails are on the server.. int numEmails = mailman.CheckMail(); if (numEmails < 0) { wprintf(L"%s\n",mailman.lastErrorText()); return; } // Examine the POP3 session log: wprintf(L"%s\n",mailman.pop3SessionLog()); // The POP3 session log will look something like this: // **** Connected to outlook.office365.com:995 // < +OK The Microsoft Exchange POP3 service is ready. [QwBIADIAUABSADEANgBDAEEAMAAwADEAMgAuAG4AYQBtAHAAcgBkADEANgAuAHAAcgBvAGQALgBvAHUAdABsAG8AbwBrAC4AYwBvAG0A] // > AUTH XOAUTH2 // < + // > <base64 string in XOAUTH2 format> // < -ERR Authentication failure: unknown user name or bad password. // > AUTH XOAUTH2 // < + // > <base64 string in XOAUTH2 format> // < +OK User successfully authenticated. // > STAT // < +OK 248 46637086 // End the POP3 session and close the connection to the GMail server. success = mailman.Pop3EndSession(); if (success != true) { wprintf(L"%s\n",mailman.lastErrorText()); return; } wprintf(L"Finished.\n"); } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.