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
(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
// This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. string integrationKey = "DIMS3V5QDVG9J9ABRXC4"; string secretKey = "HWVQ46nubLBxhnRlKddTltWIi3hL0fIQF2qTvLab"; Chilkat.Http http = new Chilkat.Http(); http.Accept = "application/json"; // Use your own hostname here: string url = "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. http.Login = integrationKey; http.Password = secretKey; Chilkat.HttpRequest req = new Chilkat.HttpRequest(); req.AddParam("username","matt"); req.AddParam("factor","push"); // The device ID can be obtained from the preauth response. See Duo Preauth Example req.AddParam("device","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. req.AddParam("async","1"); Chilkat.HttpResponse resp = http.PostUrlEncoded(url,req); if (http.LastMethodSuccess == false) { Debug.WriteLine(http.LastErrorText); return; } Debug.WriteLine("status code = " + Convert.ToString(resp.StatusCode)); Chilkat.JsonObject json = new Chilkat.JsonObject(); bool success = json.Load(resp.BodyStr); json.EmitCompact = false; Debug.WriteLine(json.Emit()); if (resp.StatusCode != 200) { return; } // Sample successful output: // status code = 200 // { // "stat": "OK", // "response": { // "txid": "45f7c92b-f45f-4862-8545-e0f58e78075a" // } // } string txid = json.StringOf("response.txid"); // Use your own hostname here: Chilkat.StringBuilder sbUrl = new Chilkat.StringBuilder(); sbUrl.Append("https://api-a03782e1.duosecurity.com/auth/v2/auth_status?txid="); sbUrl.Append(txid); Debug.WriteLine("Auth status URL: " + sbUrl.GetAsString()); Chilkat.StringBuilder sbResult = new Chilkat.StringBuilder(); string responseStatus; string responseStatus_msg; // Wait for a response... int i = 0; int maxWaitIterations = 100; while (i < maxWaitIterations) { // Wait 3 seconds. http.SleepMs(3000); Debug.WriteLine("Polling..."); resp = http.QuickRequest("GET",sbUrl.GetAsString()); if (http.LastMethodSuccess == false) { Debug.WriteLine(http.LastErrorText); return; } if (resp.StatusCode != 200) { Debug.WriteLine("error status code = " + Convert.ToString(resp.StatusCode)); Debug.WriteLine(resp.BodyStr); Debug.WriteLine("Failed."); return; } // Sample response: // { // "stat": "OK", // "response": { // "result": "waiting", // "status": "pushed", // "status_msg": "Pushed a login request to your phone..." // } // } json.Load(resp.BodyStr); // The responseResult can be "allow", "deny", or "waiting" sbResult.Clear(); json.StringOfSb("response.result",sbResult); responseStatus = json.StringOf("response.status"); responseStatus_msg = json.StringOf("response.status_msg"); Debug.WriteLine(sbResult.GetAsString()); Debug.WriteLine(responseStatus); Debug.WriteLine(responseStatus_msg); Debug.WriteLine(""); if (sbResult.ContentsEqual("waiting",true) == true) { i = i + 1; } else { // Force loop exit.. i = maxWaitIterations; } } Debug.WriteLine("Finished."); |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.