Back to Collection Items
#include <CkHttp.h>
#include <CkJsonObject.h>
#include <CkHttpResponse.h>
#include <CkStringBuilder.h>
void ChilkatSample(void)
{
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
CkHttp http;
bool success;
// Use this online tool to generate code from sample JSON: Generate Code to Create JSON
// The following JSON is sent in the request body.
// {
// "startInfo": {
// "ReleaseKey": "{{releaseKey}}",
// "JobsCount": 1,
// "JobPriority": "Normal",
// "Strategy": "ModernJobsCount",
// "RuntimeType": "Unattended",
// "InputArguments": "{\"status\":\"Sold\"}"
// }
// }
CkJsonObject json;
json.UpdateString("startInfo.ReleaseKey","{{releaseKey}}");
json.UpdateInt("startInfo.JobsCount",1);
json.UpdateString("startInfo.JobPriority","Normal");
json.UpdateString("startInfo.Strategy","ModernJobsCount");
json.UpdateString("startInfo.RuntimeType","Unattended");
json.UpdateString("startInfo.InputArguments","{\"status\":\"Sold\"}");
http.SetRequestHeader("Content-Type","application/json");
// Adds the "Authorization: Bearer <access_token>" header.
http.put_AuthToken("<access_token>");
http.SetRequestHeader("X-UIPATH-OrganizationUnitId","{{folderId}}");
CkHttpResponse *resp = http.PostJson3("https://domain.com/odata/Jobs/UiPath.Server.Configuration.OData.StartJobs","application/json",json);
if (http.get_LastMethodSuccess() == false) {
std::cout << http.lastErrorText() << "\r\n";
return;
}
CkStringBuilder sbResponseBody;
resp->GetBodySb(sbResponseBody);
CkJsonObject jResp;
jResp.LoadSb(sbResponseBody);
jResp.put_EmitCompact(false);
std::cout << "Response Body:" << "\r\n";
std::cout << jResp.emit() << "\r\n";
int respStatusCode = resp->get_StatusCode();
std::cout << "Response Status Code = " << respStatusCode << "\r\n";
if (respStatusCode >= 400) {
std::cout << "Response Header:" << "\r\n";
std::cout << resp->header() << "\r\n";
std::cout << "Failed." << "\r\n";
delete resp;
return;
}
delete resp;
// Sample JSON response:
// (Sample code for parsing the JSON response is shown below)
// {
// "@odata.context": "https://cloud.uipath.com/org/tenant/orchestrator_/odata/$metadata#Jobs",
// "value": [
// {
// "Key": "4d7ea00a-996b-4a7d-961b-9068d9a519b3",
// "StartTime": null,
// "EndTime": null,
// "State": "Pending",
// "JobPriority": "Normal",
// "Source": "Manual",
// "SourceType": "Manual",
// "BatchExecutionKey": "1e089817-98da-4dd0-b527-7aea211c4ef9",
// "Info": null,
// "CreationTime": "2021-04-20T09:06:13.78Z",
// "StartingScheduleId": null,
// "ReleaseName": "Update existsing pet by ID",
// "Type": "Unattended",
// "InputArguments": "{\"status\":\"Sold\"}",
// "OutputArguments": null,
// "HostMachineName": null,
// "HasMediaRecorded": false,
// "PersistenceId": null,
// "ResumeVersion": null,
// "StopStrategy": null,
// "RuntimeType": "Unattended",
// "RequiresUserInteraction": true,
// "ReleaseVersionId": null,
// "EntryPointPath": null,
// "OrganizationUnitId": 515128,
// "OrganizationUnitFullyQualifiedName": null,
// "Reference": "",
// "ProcessType": "Process",
// "Id": 14435785
// }
// ]
// }
// Sample code for parsing the JSON response...
// Use this online tool to generate parsing code from sample JSON: Generate JSON Parsing Code
// Chilkat functions returning "const char *" return a pointer to temporary internal memory owned and managed by Chilkat.
const char *Key = 0;
const char *StartTime = 0;
const char *EndTime = 0;
const char *State = 0;
const char *JobPriority = 0;
const char *Source = 0;
const char *SourceType = 0;
const char *BatchExecutionKey = 0;
const char *Info = 0;
const char *CreationTime = 0;
const char *StartingScheduleId = 0;
const char *ReleaseName = 0;
const char *v_Type = 0;
const char *InputArguments = 0;
const char *OutputArguments = 0;
const char *HostMachineName = 0;
bool HasMediaRecorded;
const char *PersistenceId = 0;
const char *ResumeVersion = 0;
const char *StopStrategy = 0;
const char *RuntimeType = 0;
bool RequiresUserInteraction;
const char *ReleaseVersionId = 0;
const char *EntryPointPath = 0;
int OrganizationUnitId;
const char *OrganizationUnitFullyQualifiedName = 0;
const char *Reference = 0;
const char *ProcessType = 0;
int Id;
const char *odata_context = jResp.stringOf("\"@odata.context\"");
int i = 0;
int count_i = jResp.SizeOfArray("value");
while (i < count_i) {
jResp.put_I(i);
Key = jResp.stringOf("value[i].Key");
StartTime = jResp.stringOf("value[i].StartTime");
EndTime = jResp.stringOf("value[i].EndTime");
State = jResp.stringOf("value[i].State");
JobPriority = jResp.stringOf("value[i].JobPriority");
Source = jResp.stringOf("value[i].Source");
SourceType = jResp.stringOf("value[i].SourceType");
BatchExecutionKey = jResp.stringOf("value[i].BatchExecutionKey");
Info = jResp.stringOf("value[i].Info");
CreationTime = jResp.stringOf("value[i].CreationTime");
StartingScheduleId = jResp.stringOf("value[i].StartingScheduleId");
ReleaseName = jResp.stringOf("value[i].ReleaseName");
v_Type = jResp.stringOf("value[i].Type");
InputArguments = jResp.stringOf("value[i].InputArguments");
OutputArguments = jResp.stringOf("value[i].OutputArguments");
HostMachineName = jResp.stringOf("value[i].HostMachineName");
HasMediaRecorded = jResp.BoolOf("value[i].HasMediaRecorded");
PersistenceId = jResp.stringOf("value[i].PersistenceId");
ResumeVersion = jResp.stringOf("value[i].ResumeVersion");
StopStrategy = jResp.stringOf("value[i].StopStrategy");
RuntimeType = jResp.stringOf("value[i].RuntimeType");
RequiresUserInteraction = jResp.BoolOf("value[i].RequiresUserInteraction");
ReleaseVersionId = jResp.stringOf("value[i].ReleaseVersionId");
EntryPointPath = jResp.stringOf("value[i].EntryPointPath");
OrganizationUnitId = jResp.IntOf("value[i].OrganizationUnitId");
OrganizationUnitFullyQualifiedName = jResp.stringOf("value[i].OrganizationUnitFullyQualifiedName");
Reference = jResp.stringOf("value[i].Reference");
ProcessType = jResp.stringOf("value[i].ProcessType");
Id = jResp.IntOf("value[i].Id");
i = i + 1;
}
}
Curl Command
curl -X POST
-H "Authorization: Bearer <access_token>"
-H "Content-Type: application/json"
-H "X-UIPATH-OrganizationUnitId: {{folderId}}"
-d '{
"startInfo": {
"ReleaseKey": "{{releaseKey}}",
"JobsCount": 1,
"JobPriority": "Normal",
"Strategy": "ModernJobsCount",
"RuntimeType": "Unattended",
"InputArguments": "{\"status\":\"Sold\"}"
}
}'
https://domain.com/odata/Jobs/UiPath.Server.Configuration.OData.StartJobs
Postman Collection Item JSON
{
"name": "Start Process",
"event": [
{
"listen": "prerequest",
"script": {
"exec": [
""
],
"type": "text/javascript"
}
},
{
"listen": "test",
"script": {
"exec": [
"pm.test(\"Status code is 201\", function () {\r",
" pm.response.to.have.status(201);\r",
"});\r",
"\r",
"//set JobId key\r",
"var myResponse = pm.response.json();\r",
"pm.collectionVariables.set(\"jobId\", myResponse.value[0].Id);\r",
"console.log(pm.collectionVariables.get(\"jobId\"));"
],
"type": "text/javascript"
}
}
],
"request": {
"method": "POST",
"header": [
{
"key": "Content-Type",
"value": "application/json",
"type": "text"
},
{
"key": "X-UIPATH-OrganizationUnitId",
"value": "{{folderId}}",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\r\n \"startInfo\": {\r\n \"ReleaseKey\": \"{{releaseKey}}\",\r\n \"JobsCount\": 1,\r\n \"JobPriority\": \"Normal\",\r\n \"Strategy\": \"ModernJobsCount\",\r\n \"RuntimeType\": \"Unattended\",\r\n \"InputArguments\": \"{\\\"status\\\":\\\"Sold\\\"}\"\r\n }\r\n}"
},
"url": {
"raw": "{{url}}/odata/Jobs/UiPath.Server.Configuration.OData.StartJobs",
"host": [
"{{url}}"
],
"path": [
"odata",
"Jobs",
"UiPath.Server.Configuration.OData.StartJobs"
]
},
"description": "Within Orchestrator, a **Process** that is running or has been run is called a **Job**. To start a **Job** you need to hand over at least the following request body input parameters:\n\n1. `ReleaseKey`: The ID you get in the previous step _GET Releases by name_. The Orchestator needs this key to run a specific version of a process.\n2. `Strategy`: For modern folders we recommend to make use of _ModernJobsCount_.\n3. `JobsCount`: How often the job will be executed.\n4. `InputArguments`: If your job has input parameters, they can be sent as a JSON string in the _InputArguments_ field. If it does not, this field will be ignored. See how input arguments are handed over in this example.\n\nFind more details on how to start of job [here](https://docs.uipath.com/orchestrator/docs/managing-jobs)."
},
"response": [
{
"name": "Start Process",
"originalRequest": {
"method": "POST",
"header": [
{
"key": "Content-Type",
"value": "application/json",
"type": "text"
},
{
"key": "X-UIPATH-OrganizationUnitId",
"value": "{{folderId}}",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\r\n \"startInfo\": {\r\n \"ReleaseKey\": \"{{releaseKey}}\",\r\n \"JobsCount\": 1,\r\n \"JobPriority\": \"Normal\",\r\n \"Strategy\": \"ModernJobsCount\",\r\n \"RuntimeType\": \"Unattended\",\r\n \"InputArguments\": \"{\\\"status\\\":\\\"Sold\\\"}\"\r\n }\r\n}"
},
"url": {
"raw": "{{url}}/odata/Jobs/UiPath.Server.Configuration.OData.StartJobs",
"host": [
"{{url}}"
],
"path": [
"odata",
"Jobs",
"UiPath.Server.Configuration.OData.StartJobs"
]
}
},
"status": "Created",
"code": 201,
"_postman_previewlanguage": "json",
"header": [
{
"key": "Date",
"value": "Tue, 20 Apr 2021 09:06:13 GMT"
},
{
"key": "Content-Type",
"value": "application/json; odata.metadata=minimal; odata.streaming=true"
},
{
"key": "Transfer-Encoding",
"value": "chunked"
},
{
"key": "Connection",
"value": "keep-alive"
},
{
"key": "Cache-Control",
"value": "no-cache, no-store, must-revalidate"
},
{
"key": "Pragma",
"value": "no-cache"
},
{
"key": "Expires",
"value": "-1"
},
{
"key": "Request-Context",
"value": "appId=cid-v1:04884d99-0742-441b-a23c-847133cb0130"
},
{
"key": "X-Robots-Tag",
"value": "noindex,nofollow"
},
{
"key": "X-Download-Options",
"value": "noopen"
},
{
"key": "X-XSS-Protection",
"value": "1"
},
{
"key": "X-Content-Type-Options",
"value": "nosniff"
},
{
"key": "X-Frame-Options",
"value": "Deny"
},
{
"key": "Strict-Transport-Security",
"value": "max-age=31536000; includeSubDomains"
},
{
"key": "Content-Security-Policy",
"value": "default-src 'self';script-src 'self';style-src 'self' 'unsafe-inline';img-src 'self' data: https://*.blob.core.windows.net https://*.amazonaws.com blob:;font-src 'self' data:;connect-src 'self' wss: https://sentry.io https://studio-feedback.azure-api.net https://storage.googleapis.com https://*.service.signalr.net https://*.blob.core.windows.net https://*.amazonaws.com dc.services.visualstudio.com;worker-src 'self' blob:"
},
{
"key": "X-Correlation-ID",
"value": "9dca99ab-1885-4420-830c-e3490ae41aad"
},
{
"key": "OData-Version",
"value": "4.0"
},
{
"key": "api-supported-versions",
"value": "12.0"
},
{
"key": "CF-Cache-Status",
"value": "DYNAMIC"
},
{
"key": "cf-request-id",
"value": "099020c99a00000fae930af000000001"
},
{
"key": "Expect-CT",
"value": "max-age=604800, report-uri=\"https://report-uri.cloudflare.com/cdn-cgi/beacon/expect-ct\""
},
{
"key": "Server",
"value": "cloudflare"
},
{
"key": "CF-RAY",
"value": "642d37228be00fae-VIE"
}
],
"cookie": [
],
"body": "{\n \"@odata.context\": \"https://cloud.uipath.com/org/tenant/orchestrator_/odata/$metadata#Jobs\",\n \"value\": [\n {\n \"Key\": \"4d7ea00a-996b-4a7d-961b-9068d9a519b3\",\n \"StartTime\": null,\n \"EndTime\": null,\n \"State\": \"Pending\",\n \"JobPriority\": \"Normal\",\n \"Source\": \"Manual\",\n \"SourceType\": \"Manual\",\n \"BatchExecutionKey\": \"1e089817-98da-4dd0-b527-7aea211c4ef9\",\n \"Info\": null,\n \"CreationTime\": \"2021-04-20T09:06:13.78Z\",\n \"StartingScheduleId\": null,\n \"ReleaseName\": \"Update existsing pet by ID\",\n \"Type\": \"Unattended\",\n \"InputArguments\": \"{\\\"status\\\":\\\"Sold\\\"}\",\n \"OutputArguments\": null,\n \"HostMachineName\": null,\n \"HasMediaRecorded\": false,\n \"PersistenceId\": null,\n \"ResumeVersion\": null,\n \"StopStrategy\": null,\n \"RuntimeType\": \"Unattended\",\n \"RequiresUserInteraction\": true,\n \"ReleaseVersionId\": null,\n \"EntryPointPath\": null,\n \"OrganizationUnitId\": 515128,\n \"OrganizationUnitFullyQualifiedName\": null,\n \"Reference\": \"\",\n \"ProcessType\": \"Process\",\n \"Id\": 14435785\n }\n ]\n}"
}
]
}