![]() |
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
(Android™) 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
// Important: Don't forget to include the call to System.loadLibrary // as shown at the bottom of this code sample. package com.test; import android.app.Activity; import com.chilkatsoft.*; import android.widget.TextView; import android.os.Bundle; public class SimpleActivity extends Activity { private static final String TAG = "Chilkat"; // Called when the activity is first created. @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); boolean success = false; CkHttpCurl httpCurl = new CkHttpCurl(); // The final curl command we want to execute. // It depends on {{drive_id}}, which is not yet known. String targetCurl = "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}}. String fnName = "getDrives"; httpCurl.AddFunction(fnName,"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. String jsonPath = "value[0].id"; httpCurl.AddOutput(fnName,jsonPath,"drive_id"); // drive_id depends on site_id, which is also not yet known. // Define another helper function to obtain site_id. fnName = "getSite"; httpCurl.AddFunction(fnName,"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. jsonPath = "id"; httpCurl.AddOutput(fnName,jsonPath,"site_id"); // Provide the initial known input. // site_name is the starting value that allows the dependency chain to be resolved. httpCurl.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. CkJsonObject jsonOAuth2 = new CkJsonObject(); jsonOAuth2.put_EnableSecrets(true); jsonOAuth2.UpdateString("oauth2.client_id","!!sharepoint|oauth2|client_id"); jsonOAuth2.UpdateString("oauth2.client_secret","!!sharepoint|oauth2|client_secret"); jsonOAuth2.UpdateString("oauth2.scope","https://graph.microsoft.com/.default"); jsonOAuth2.UpdateString("oauth2.token_endpoint","!!sharepoint|oauth2|token_endpoint"); httpCurl.SetAuth(jsonOAuth2); // ---------------------------------------------------------------------------------------------------------------------- // 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) success = httpCurl.DoYourThing(targetCurl); if (success == false) { Log.i(TAG, httpCurl.lastErrorText()); return; } // Retrieve and display the HTTP response status code. int statusCode = httpCurl.get_StatusCode(); Log.i(TAG, "response status code: " + String.valueOf(statusCode)); // Load and display the JSON response from the final curl command. CkJsonObject responseJson = new CkJsonObject(); responseJson.put_EmitCompact(false); httpCurl.GetResponseJson(responseJson); Log.i(TAG, responseJson.emit()); } static { System.loadLibrary("chilkat"); // Note: If the incorrect library name is passed to System.loadLibrary, // then you will see the following error message at application startup: //"The application <your-application-name> has stopped unexpectedly. Please try again." } } |
||||
© 2000-2026 Chilkat Software, Inc. All Rights Reserved.