![]() |
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
(Delphi DLL) 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
uses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics, Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, JsonObject, HttpCurl; ... procedure TForm1.Button1Click(Sender: TObject); var success: Boolean; httpCurl: HCkHttpCurl; targetCurl: PWideChar; fnName: PWideChar; jsonPath: PWideChar; jsonOAuth2: HCkJsonObject; statusCode: Integer; responseJson: HCkJsonObject; begin success := False; httpCurl := CkHttpCurl_Create(); // The target curl command we ultimately want to execute. // It requires a {{site_id}} value, which is not yet known. 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. fnName := 'getSite'; CkHttpCurl_AddFunction(httpCurl,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". jsonPath := 'id'; CkHttpCurl_AddOutput(httpCurl,fnName,jsonPath,'site_id'); // Provide a value for site_name, which is required by the getSite function. CkHttpCurl_SetVar(httpCurl,'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). jsonOAuth2 := CkJsonObject_Create(); CkJsonObject_putEnableSecrets(jsonOAuth2,True); CkJsonObject_UpdateString(jsonOAuth2,'oauth2.client_id','!!sharepoint|oauth2|client_id'); CkJsonObject_UpdateString(jsonOAuth2,'oauth2.client_secret','!!sharepoint|oauth2|client_secret'); CkJsonObject_UpdateString(jsonOAuth2,'oauth2.scope','https://graph.microsoft.com/.default'); CkJsonObject_UpdateString(jsonOAuth2,'oauth2.token_endpoint','!!sharepoint|oauth2|token_endpoint'); // ---------------------------------------------------------------------------------------------------------------------- CkHttpCurl_SetAuth(httpCurl,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. success := CkHttpCurl_DoYourThing(httpCurl,targetCurl); if (success = False) then begin Memo1.Lines.Add(CkHttpCurl__lastErrorText(httpCurl)); Exit; end; // Retrieve and display the HTTP response status code. statusCode := CkHttpCurl_getStatusCode(httpCurl); Memo1.Lines.Add('response status code: ' + IntToStr(statusCode)); // Load and display the JSON response from the final curl command. responseJson := CkJsonObject_Create(); CkJsonObject_putEmitCompact(responseJson,False); CkHttpCurl_GetResponseJson(httpCurl,responseJson); Memo1.Lines.Add(CkJsonObject__emit(responseJson)); CkHttpCurl_Dispose(httpCurl); CkJsonObject_Dispose(jsonOAuth2); CkJsonObject_Dispose(responseJson); end; |
||||
© 2000-2026 Chilkat Software, Inc. All Rights Reserved.