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) Auth0 Server-to-Server Access Token (Client Credentials flow)Demonstrates how to obtain an Auth0 access token using client credentials (client_id and client_secret). This is just a matter of duplicating this CURL command: curl --request POST --url 'https://chilkat.auth0.com/oauth/token' \ --header 'content-type: application/json' \ --data '{"grant_type":"client_credentials","client_id": "xxxx","client_secret": "xxxx","audience": "https://api.example.com/geocoding/v1/"}'
#include <CkJsonObject.h> #include <CkHttp.h> #include <CkHttpResponse.h> void ChilkatSample(void) { CkString strOut; // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. // We want to duplicate this curl command: // // curl --request POST // --url 'https://chilkat.auth0.com/oauth/token' \ // --header 'content-type: application/json' \ // --data '{"grant_type":"client_credentials","client_id": "my_client_id","client_secret": "my_client_secret","audience": "https://api.example.com/geocoding/v1/"}' // Build the JSON body of the request. CkJsonObject json; json.UpdateString("grant_type","client_credentials"); json.UpdateString("client_id","AUTH0-CLIENT-ID"); json.UpdateString("client_secret","AUTH0-CLIENT-SECRET"); json.UpdateString("audience","https://api.example.com/geocoding/v1/"); // IMPORTANT: You would use your own url. You would not use "chilkat.auth0.com". // Instead you would use "your_name.auth0.com" CkHttp http; CkHttpResponse *resp = http.PostJson3("https://chilkat.auth0.com/oauth/token","application/json",json); if (http.get_LastMethodSuccess() != true) { strOut.append(http.lastErrorText()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // A 200 response status code indicates success. In the success case, the response body // contains the JSON access token, such as: // { // "access_token": "eyJz93a...k4laUWw", // "token_type":"Bearer", // "expires_in":86400 // } // strOut.append("response status code = "); strOut.appendInt(resp->get_StatusCode()); strOut.append("\r\n"); // The repsonse is JSON if successful and also JSON for errors. CkJsonObject jsonResp; jsonResp.put_EmitCompact(false); jsonResp.Load(resp->bodyStr()); if (resp->get_StatusCode() != 200) { // The response body contains error information in JSON format. strOut.append(jsonResp.emit()); strOut.append("\r\n"); delete resp; // An example of an error response: // { // "error": "access_denied", // "error_description": "Client is not authorized to access \"https://api.example.com/geocoding/v1/\". You might probably want to create a \"client-grant\" associated to this API. See: https://auth0.com/docs/api/v2#!/Client_Grants/post_client_grants" // } SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } strOut.append("Success!"); strOut.append("\r\n"); strOut.append(jsonResp.emit()); strOut.append("\r\n"); // A successful JSON response body looks like this: // { // "access_token": "eyJz93a...k4laUWw", // "token_type":"Bearer", // "expires_in":86400 // } delete resp; SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); } |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.