![]() |
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
(Visual FoxPro) curl Dependency Engine Multi-Step Execution PlanSee more CURL ExamplesThis example expands on the basic concept by demonstrating a multi-step execution plan, where several Instead of resolving a single missing input with one helper command, the target When the
Once all dependencies are identified, a multi-step execution plan is constructed. Each The execution plan is then carried out step by step, with intermediate results flowing between commands, and the final step being the target Note: This example requires Chilkat v11.5.0 or greater. For more information, see https://www.chilkatsoft.com/curl_dependency_engine.asp
LOCAL lnSuccess LOCAL loHttpCurl LOCAL lcTargetCurl LOCAL lcFnName LOCAL lcJsonPath LOCAL loJsonOAuth2 LOCAL lnStatusCode LOCAL loResponseJson lnSuccess = 0 loHttpCurl = CreateObject('Chilkat.HttpCurl') * The final curl command we want to execute. * It depends on {{drive_id}}, which is not yet known. lcTargetCurl = "curl -X GET https://graph.microsoft.com/v1.0/drives/{{drive_id}}/root/children" * Define a helper function that can produce drive_id. * This function lists drives for a given site, which requires {{site_id}}. lcFnName = "getDrives" loHttpCurl.AddFunction(lcFnName,"curl -X GET https://graph.microsoft.com/v1.0/sites/{{site_id}}/drives") * Define the output of getDrives. * The JSON response contains an array named "value". * We take the first element (value[0]) and extract its "id" as drive_id. lcJsonPath = "value[0].id" loHttpCurl.AddOutput(lcFnName,lcJsonPath,"drive_id") * drive_id depends on site_id, which is also not yet known. * Define another helper function to obtain site_id. lcFnName = "getSite" loHttpCurl.AddFunction(lcFnName,"GET https://graph.microsoft.com/v1.0/sites/root:/sites/{{site_name}}") * Map the "id" field from the getSite response to the variable site_id. lcJsonPath = "id" loHttpCurl.AddOutput(lcFnName,lcJsonPath,"site_id") * Provide the initial known input. * site_name is the starting value that allows the dependency chain to be resolved. loHttpCurl.SetVar("site_name","test") * ---------------------------------------------------------------------------------------------------------------------- * Configure OAuth2 authentication using the client credentials flow. * Secrets (client_id, client_secret, token_endpoint) are retrieved from the * local secrets manager because EnableSecrets is enabled. loJsonOAuth2 = CreateObject('Chilkat.JsonObject') loJsonOAuth2.EnableSecrets = 1 loJsonOAuth2.UpdateString("oauth2.client_id","!!sharepoint|oauth2|client_id") loJsonOAuth2.UpdateString("oauth2.client_secret","!!sharepoint|oauth2|client_secret") loJsonOAuth2.UpdateString("oauth2.scope","https://graph.microsoft.com/.default") loJsonOAuth2.UpdateString("oauth2.token_endpoint","!!sharepoint|oauth2|token_endpoint") loHttpCurl.SetAuth(loJsonOAuth2) * ---------------------------------------------------------------------------------------------------------------------- * Execute the target curl command. * Internally, the system will: * * 1) Detect that {{drive_id}} is required but not defined. * 2) Find that "getDrives" can produce drive_id. * 3) Detect that getDrives requires {{site_id}}, which is also not defined. * 4) Find that "getSite" can produce site_id. * 5) Verify that getSite requires {{site_name}}, which is already known. * 6) Build a multi-step execution plan: * - First: run getSite (produces site_id) * - Second: run getDrives (produces drive_id) * - Third: run the target curl (uses drive_id) lnSuccess = loHttpCurl.DoYourThing(lcTargetCurl) IF (lnSuccess = 0) THEN ? loHttpCurl.LastErrorText RELEASE loHttpCurl RELEASE loJsonOAuth2 CANCEL ENDIF * Retrieve and display the HTTP response status code. lnStatusCode = loHttpCurl.StatusCode ? "response status code: " + STR(lnStatusCode) * Load and display the JSON response from the final curl command. loResponseJson = CreateObject('Chilkat.JsonObject') loResponseJson.EmitCompact = 0 loHttpCurl.GetResponseJson(loResponseJson) ? loResponseJson.Emit() RELEASE loHttpCurl RELEASE loJsonOAuth2 RELEASE loResponseJson |
||||
© 2000-2026 Chilkat Software, Inc. All Rights Reserved.