![]() |
Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java JavaScript 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
(PowerBuilder) curl Dependency Engine Simple ExampleSee more CURL ExamplesThis example demonstrates a simple way to define When the
The execution plan is then carried out, with the final step being the target curl command originally passed to Note: This example requires Chilkat v11.5.0 or greater. For more information, see https://www.chilkatsoft.com/curl_dependency_engine.asp
integer li_rc integer li_Success oleobject loo_HttpCurl string ls_TargetCurl string ls_FnName string ls_JsonPath oleobject loo_JsonOAuth2 integer li_StatusCode oleobject loo_ResponseJson li_Success = 0 loo_HttpCurl = create oleobject li_rc = loo_HttpCurl.ConnectToNewObject("Chilkat.HttpCurl") if li_rc < 0 then destroy loo_HttpCurl MessageBox("Error","Connecting to COM object failed") return end if // The target curl command we ultimately want to execute. // It requires a {{site_id}} value, which is not yet known. ls_TargetCurl = "GET https://graph.microsoft.com/v1.0/sites/{{site_id}}/drives" // Because site_id is unknown, we define a helper function (curl command) // that can retrieve it. ls_FnName = "getSite" loo_HttpCurl.AddFunction(ls_FnName,"GET https://graph.microsoft.com/v1.0/sites/root:/sites/{{site_name}}") // Define the outputs produced by the helper function. // Outputs are extracted from the JSON response using JSON paths. // Here, the "id" field from the response is mapped to the variable "site_id". ls_JsonPath = "id" loo_HttpCurl.AddOutput(ls_FnName,ls_JsonPath,"site_id") // Provide a value for site_name, which is required by the getSite function. loo_HttpCurl.SetVar("site_name","test") // ---------------------------------------------------------------------------------------------------------------------- // Build the OAuth2 configuration used for authentication. // This uses the client credentials flow, with secrets retrieved // from the local secrets manager (because EnableSecrets = true). loo_JsonOAuth2 = create oleobject li_rc = loo_JsonOAuth2.ConnectToNewObject("Chilkat.JsonObject") loo_JsonOAuth2.EnableSecrets = 1 loo_JsonOAuth2.UpdateString("oauth2.client_id","!!sharepoint|oauth2|client_id") loo_JsonOAuth2.UpdateString("oauth2.client_secret","!!sharepoint|oauth2|client_secret") loo_JsonOAuth2.UpdateString("oauth2.scope","https://graph.microsoft.com/.default") loo_JsonOAuth2.UpdateString("oauth2.token_endpoint","!!sharepoint|oauth2|token_endpoint") // ---------------------------------------------------------------------------------------------------------------------- loo_HttpCurl.SetAuth(loo_JsonOAuth2) // Execute the target curl command. // Internally, the system will: // 1) Detect that {{site_id}} is required but not yet defined. // 2) Find that the "getSite" function can produce site_id. // 3) Verify that getSite's input (site_name) is already available. // 4) Build an execution plan: first run getSite, then run the target curl. li_Success = loo_HttpCurl.DoYourThing(ls_TargetCurl) if li_Success = 0 then Write-Debug loo_HttpCurl.LastErrorText destroy loo_HttpCurl destroy loo_JsonOAuth2 return end if // Retrieve and display the HTTP response status code. li_StatusCode = loo_HttpCurl.StatusCode Write-Debug "response status code: " + string(li_StatusCode) // Load and display the JSON response from the final curl command. loo_ResponseJson = create oleobject li_rc = loo_ResponseJson.ConnectToNewObject("Chilkat.JsonObject") loo_ResponseJson.EmitCompact = 0 loo_HttpCurl.GetResponseJson(loo_ResponseJson) Write-Debug loo_ResponseJson.Emit() destroy loo_HttpCurl destroy loo_JsonOAuth2 destroy loo_ResponseJson |
||||
© 2000-2026 Chilkat Software, Inc. All Rights Reserved.