Chilkat HOME Android™ Classic ASP C C++ C# Mono C# .NET Core C# C# UWP/WinRT DataFlex Delphi ActiveX Delphi DLL Visual FoxPro Java Lianja MFC Objective-C Perl PHP ActiveX PHP Extension PowerBuilder PowerShell PureBasic CkPython Chilkat2-Python Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ Visual Basic 6.0 VB.NET VB.NET UWP/WinRT VBScript Xojo Plugin Node.js Excel Go
(MFC) ETrade Renew Access TokenRenews an ETrade OAuth access token. For more information, see https://apisb.etrade.com/docs/api/authorization/renew_access_token.html
#include <CkHttp.h> #include <CkJsonObject.h> #include <CkHttpResponse.h> #include <CkStringBuilder.h> #include <CkHashtable.h> #include <CkFileAccess.h> void ChilkatSample(void) { CkString strOut; // This requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkHttp http; http.put_OAuth1(true); http.put_OAuthVerifier(""); http.put_OAuthConsumerKey("ETRADE_CONSUMER_KEY"); http.put_OAuthConsumerSecret("ETRADE_CONSUMER_SECRET"); // Load the access token previously obtained via the OAuth1 Authorization CkJsonObject jsonToken; bool success = jsonToken.LoadFile("qa_data/tokens/etrade.json"); if (success != true) { strOut.append("Failed to load OAuth1 token"); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } http.put_OAuthToken(jsonToken.stringOf("oauth_token")); http.put_OAuthTokenSecret(jsonToken.stringOf("oauth_token_secret")); CkHttpResponse *resp = http.QuickGetObj("https://api.etrade.com/oauth/renew_access_token"); if (http.get_LastMethodSuccess() != true) { strOut.append(http.lastErrorText()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // Make sure a successful response was received. if (resp->get_StatusCode() != 200) { strOut.append(resp->statusLine()); strOut.append("\r\n"); strOut.append(resp->header()); strOut.append("\r\n"); strOut.append(resp->bodyStr()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // If successful, the resp.BodyStr contains something like this: // oauth_token=%3TiQRgQCRGPo7Xdk6G8QDSEzX0Jsy6sKNcULcDavAGgU%3D&oauth_token_secret=%7RrC9scEpzcwSEMy4vE7nodSzPLqfRINnTNY4voczyFM%3D strOut.append(resp->bodyStr()); strOut.append("\r\n"); CkStringBuilder sbRespBody; resp->GetBodySb(sbRespBody); if (sbRespBody.ContentsEqual("Access Token has been renewed",false)) { // The documentation at https://apisb.etrade.com/docs/api/authorization/renew_access_token.html // indicates that the response should be as described above. However, the response received when // trying to refresh a non-expired token was "Access Token has been renewed" strOut.append("Keeping the same access token, but it's renewed..."); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } CkHashtable hashTab; hashTab.AddQueryParams(resp->bodyStr()); const char *accessToken = hashTab.lookupStr("oauth_token"); const char *accessTokenSecret = hashTab.lookupStr("oauth_token_secret"); delete resp; // The access token + secret is what should be saved and used for // subsequent REST API calls. strOut.append("Access Token = "); strOut.append(accessToken); strOut.append("\r\n"); strOut.append("Access Token Secret = "); strOut.append(accessTokenSecret); strOut.append("\r\n"); // Save this access token for future calls. // Just in case we need user_id and screen_name, save those also.. CkJsonObject json; json.AppendString("oauth_token",accessToken); json.AppendString("oauth_token_secret",accessTokenSecret); CkFileAccess fac; fac.WriteEntireTextFile("qa_data/tokens/etrade.json",json.emit(),"utf-8",false); strOut.append("Success."); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); } |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.