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
(Unicode C) Duo Auth API - Async AuthSee more Duo Auth MFA ExamplesIf you enable async, then your application will be able to retrieve real-time status updates from the authentication process, rather than receiving no information until the process is complete. Note: This example requires Chilkat v9.5.0.89 or greater. For more information, see https://duo.com/docs/authapi#/auth_status
#include <C_CkHttpW.h> #include <C_CkHttpRequestW.h> #include <C_CkHttpResponseW.h> #include <C_CkJsonObjectW.h> #include <C_CkStringBuilderW.h> void ChilkatSample(void) { const wchar_t *integrationKey; const wchar_t *secretKey; HCkHttpW http; const wchar_t *url; HCkHttpRequestW req; HCkHttpResponseW resp; HCkJsonObjectW json; BOOL success; const wchar_t *txid; HCkStringBuilderW sbUrl; HCkStringBuilderW sbResult; const wchar_t *responseStatus; const wchar_t *responseStatus_msg; int i; int maxWaitIterations; // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. integrationKey = L"DIMS3V5QDVG9J9ABRXC4"; secretKey = L"HWVQ46nubLBxhnRlKddTltWIi3hL0fIQF2qTvLab"; http = CkHttpW_Create(); CkHttpW_putAccept(http,L"application/json"); // Use your own hostname here: url = L"https://api-a03782e1.duosecurity.com/auth/v2/auth"; // This example requires Chilkat v9.5.0.89 or greater because Chilkat will automatically // generate and send the HMAC signature for the requires based on the integration key and secret key. CkHttpW_putLogin(http,integrationKey); CkHttpW_putPassword(http,secretKey); req = CkHttpRequestW_Create(); CkHttpRequestW_AddParam(req,L"username",L"matt"); CkHttpRequestW_AddParam(req,L"factor",L"push"); // The device ID can be obtained from the preauth response. See Duo Preauth Example CkHttpRequestW_AddParam(req,L"device",L"DP6GYVTQ5NK82BMR851F"); // Add the async param to get an immediate response, then periodically check for updates to find out when the MFA authentication completes for fails. CkHttpRequestW_AddParam(req,L"async",L"1"); resp = CkHttpW_PostUrlEncoded(http,url,req); if (CkHttpW_getLastMethodSuccess(http) == FALSE) { wprintf(L"%s\n",CkHttpW_lastErrorText(http)); CkHttpW_Dispose(http); CkHttpRequestW_Dispose(req); return; } wprintf(L"status code = %d\n",CkHttpResponseW_getStatusCode(resp)); json = CkJsonObjectW_Create(); success = CkJsonObjectW_Load(json,CkHttpResponseW_bodyStr(resp)); CkJsonObjectW_putEmitCompact(json,FALSE); wprintf(L"%s\n",CkJsonObjectW_emit(json)); if (CkHttpResponseW_getStatusCode(resp) != 200) { CkHttpResponseW_Dispose(resp); CkHttpW_Dispose(http); CkHttpRequestW_Dispose(req); CkJsonObjectW_Dispose(json); return; } // Sample successful output: // status code = 200 // { // "stat": "OK", // "response": { // "txid": "45f7c92b-f45f-4862-8545-e0f58e78075a" // } // } txid = CkJsonObjectW_stringOf(json,L"response.txid"); CkHttpResponseW_Dispose(resp); // Use your own hostname here: sbUrl = CkStringBuilderW_Create(); CkStringBuilderW_Append(sbUrl,L"https://api-a03782e1.duosecurity.com/auth/v2/auth_status?txid="); CkStringBuilderW_Append(sbUrl,txid); wprintf(L"Auth status URL: %s\n",CkStringBuilderW_getAsString(sbUrl)); sbResult = CkStringBuilderW_Create(); // Wait for a response... i = 0; maxWaitIterations = 100; while (i < maxWaitIterations) { // Wait 3 seconds. CkHttpW_SleepMs(http,3000); wprintf(L"Polling...\n"); resp = CkHttpW_QuickRequest(http,L"GET",CkStringBuilderW_getAsString(sbUrl)); if (CkHttpW_getLastMethodSuccess(http) == FALSE) { wprintf(L"%s\n",CkHttpW_lastErrorText(http)); CkHttpW_Dispose(http); CkHttpRequestW_Dispose(req); CkJsonObjectW_Dispose(json); CkStringBuilderW_Dispose(sbUrl); CkStringBuilderW_Dispose(sbResult); return; } if (CkHttpResponseW_getStatusCode(resp) != 200) { wprintf(L"error status code = %d\n",CkHttpResponseW_getStatusCode(resp)); wprintf(L"%s\n",CkHttpResponseW_bodyStr(resp)); wprintf(L"Failed.\n"); CkHttpResponseW_Dispose(resp); CkHttpW_Dispose(http); CkHttpRequestW_Dispose(req); CkJsonObjectW_Dispose(json); CkStringBuilderW_Dispose(sbUrl); CkStringBuilderW_Dispose(sbResult); return; } // Sample response: // { // "stat": "OK", // "response": { // "result": "waiting", // "status": "pushed", // "status_msg": "Pushed a login request to your phone..." // } // } CkJsonObjectW_Load(json,CkHttpResponseW_bodyStr(resp)); // The responseResult can be "allow", "deny", or "waiting" CkStringBuilderW_Clear(sbResult); CkJsonObjectW_StringOfSb(json,L"response.result",sbResult); responseStatus = CkJsonObjectW_stringOf(json,L"response.status"); responseStatus_msg = CkJsonObjectW_stringOf(json,L"response.status_msg"); wprintf(L"%s\n",CkStringBuilderW_getAsString(sbResult)); wprintf(L"%s\n",responseStatus); wprintf(L"%s\n",responseStatus_msg); wprintf(L"\n"); CkHttpResponseW_Dispose(resp); if (CkStringBuilderW_ContentsEqual(sbResult,L"waiting",TRUE) == TRUE) { i = i + 1; } else { // Force loop exit.. i = maxWaitIterations; } } wprintf(L"Finished.\n"); CkHttpW_Dispose(http); CkHttpRequestW_Dispose(req); CkJsonObjectW_Dispose(json); CkStringBuilderW_Dispose(sbUrl); CkStringBuilderW_Dispose(sbResult); } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.