Unicode C++
Unicode C++
Refresh eBay Application Access Token
See more eBay Examples
This example shows how to get a new eBay REST API access token when the original is close to expiration.Chilkat Unicode C++ Downloads
#include <CkJsonObjectW.h>
#include <CkOAuth2W.h>
void ChilkatSample(void)
{
bool success = false;
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
// The previously fetched eBay access token looks like this:
// {
// "access_token": "v^1.1#i^1# ... HwSAAA=",
// "expires_in": 7200,
// "refresh_token": "v^1.1#i^1# ... FXjEyODQ=",
// "refresh_token_expires_in": 47304000,
// "token_type": "User Access Token"
// }
CkJsonObjectW json;
success = json.LoadFile(L"qa_data/tokens/ebay-access-token.json");
if (success == false) {
wprintf(L"Failed to load the existing ebay access token JSON.\n");
return;
}
CkOAuth2W oauth2;
oauth2.put_TokenEndpoint(L"https://api.sandbox.ebay.com/identity/v1/oauth2/token");
// Replace these with actual values.
oauth2.put_ClientId(L"EBAY_CLIENT_ID");
oauth2.put_ClientSecret(L"EBAY_CLIENT_SECRET");
// Get the "refresh_token"
oauth2.put_RefreshToken(json.stringOf(L"refresh_token"));
// Send the HTTP POST to refresh the access token..
success = oauth2.RefreshAccessToken();
if (success == false) {
wprintf(L"%s\n",oauth2.lastErrorText());
return;
}
// Load the access token response into the JSON object
json.Load(oauth2.accessTokenResponse());
// Save the new JSON access token response to a file.
// The access + refresh tokens contained in this JSON will be needed for the next refresh.
json.put_EmitCompact(false);
json.WriteFile(L"qa_data/tokens/ebay-access-token.json");
wprintf(L"OAuth2 authorization granted!\n");
wprintf(L"New Access Token = %s\n",oauth2.accessToken());
}