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
(Swift 3,4,5...) 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
func chilkatTest() { // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. var integrationKey: String? = "DIMS3V5QDVG9J9ABRXC4" var secretKey: String? = "HWVQ46nubLBxhnRlKddTltWIi3hL0fIQF2qTvLab" let http = CkoHttp()! http.accept = "application/json" // Use your own hostname here: var url: String? = "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 let req = CkoHttpRequest()! req.addParam("username", value: "matt") req.addParam("factor", value: "push") // The device ID can be obtained from the preauth response. See Duo Preauth Example req.addParam("device", value: "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", value: "1") var resp: CkoHttpResponse? = http.postUrlEncoded(url, req: req) if http.lastMethodSuccess == false { print("\(http.lastErrorText!)") return } print("status code = \(resp!.statusCode.intValue)") let json = CkoJsonObject()! var success: Bool = json.load(resp!.bodyStr) json.emitCompact = false print("\(json.emit()!)") if resp!.statusCode.intValue != 200 { resp = nil return } // Sample successful output: // status code = 200 // { // "stat": "OK", // "response": { // "txid": "45f7c92b-f45f-4862-8545-e0f58e78075a" // } // } var txid: String? = json.string(of: "response.txid") resp = nil // Use your own hostname here: let sbUrl = CkoStringBuilder()! sbUrl.append("https://api-a03782e1.duosecurity.com/auth/v2/auth_status?txid=") sbUrl.append(txid) print("Auth status URL: \(sbUrl.getAsString()!)") let sbResult = CkoStringBuilder()! var responseStatus: String? var responseStatus_msg: String? // Wait for a response... var i: Int = 0 var maxWaitIterations: Int = 100 while i < maxWaitIterations { // Wait 3 seconds. http.sleepMs(3000) print("Polling...") resp = http.quickRequest("GET", url: sbUrl.getAsString()) if http.lastMethodSuccess == false { print("\(http.lastErrorText!)") return } if resp!.statusCode.intValue != 200 { print("error status code = \(resp!.statusCode.intValue)") print("\(resp!.bodyStr!)") print("Failed.") resp = nil 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.string(ofSb: "response.result", sb: sbResult) responseStatus = json.string(of: "response.status") responseStatus_msg = json.string(of: "response.status_msg") print("\(sbResult.getAsString()!)") print("\(responseStatus!)") print("\(responseStatus_msg!)") print("") resp = nil if sbResult.contentsEqual("waiting", caseSensitive: true) == true { i = i + 1 } else { // Force loop exit.. i = maxWaitIterations } } print("Finished.") } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.