Back to Collection Items
var
http: HCkHttp;
success: Boolean;
sbResponseBody: HCkStringBuilder;
jResp: HCkJsonObject;
respStatusCode: Integer;
strVal: PWideChar;
Target: PWideChar;
Id: PWideChar;
Version: PWideChar;
Secret: PWideChar;
IncludeFullUser: Boolean;
IncludeFullSource: Boolean;
i: Integer;
count_i: Integer;
begin
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
http := CkHttp_Create();
CkHttp_putBasicAuth(http,True);
CkHttp_putLogin(http,'username');
CkHttp_putPassword(http,'password');
sbResponseBody := CkStringBuilder_Create();
success := CkHttp_QuickGetSb(http,'https://domain.com/v2/apps/{{appId}}/integrations/:integrationId/webhooks/:webhookId',sbResponseBody);
if (success = False) then
begin
Memo1.Lines.Add(CkHttp__lastErrorText(http));
Exit;
end;
jResp := CkJsonObject_Create();
CkJsonObject_LoadSb(jResp,sbResponseBody);
CkJsonObject_putEmitCompact(jResp,False);
Memo1.Lines.Add('Response Body:');
Memo1.Lines.Add(CkJsonObject__emit(jResp));
respStatusCode := CkHttp_getLastStatus(http);
Memo1.Lines.Add('Response Status Code = ' + IntToStr(respStatusCode));
if (respStatusCode >= 400) then
begin
Memo1.Lines.Add('Response Header:');
Memo1.Lines.Add(CkHttp__lastHeader(http));
Memo1.Lines.Add('Failed.');
Exit;
end;
// Sample JSON response:
// (Sample code for parsing the JSON response is shown below)
// {
// "webhook": {
// "target": "http://example.com/callback",
// "triggers": [
// "conversation:read",
// "conversation:message"
// ],
// "id": "5e554d2cac66fb73a3c01871",
// "version": "v2",
// "secret": "8564b3e6a8b20a4bdb68b05ce9bc5936",
// "includeFullUser": false,
// "includeFullSource": false
// }
// }
// Sample code for parsing the JSON response...
// Use this online tool to generate parsing code from sample JSON: Generate JSON Parsing Code
Target := CkJsonObject__stringOf(jResp,'webhook.target');
Id := CkJsonObject__stringOf(jResp,'webhook.id');
Version := CkJsonObject__stringOf(jResp,'webhook.version');
Secret := CkJsonObject__stringOf(jResp,'webhook.secret');
IncludeFullUser := CkJsonObject_BoolOf(jResp,'webhook.includeFullUser');
IncludeFullSource := CkJsonObject_BoolOf(jResp,'webhook.includeFullSource');
i := 0;
count_i := CkJsonObject_SizeOfArray(jResp,'webhook.triggers');
while i < count_i do
begin
CkJsonObject_putI(jResp,i);
strVal := CkJsonObject__stringOf(jResp,'webhook.triggers[i]');
i := i + 1;
end;
CkHttp_Dispose(http);
CkStringBuilder_Dispose(sbResponseBody);
CkJsonObject_Dispose(jResp);
Curl Command
curl -X GET
-u 'username:password'
https://domain.com/v2/apps/{{appId}}/integrations/:integrationId/webhooks/:webhookId
Postman Collection Item JSON
{
"name": "Get Webhook",
"_postman_id": "53ff00f3-25eb-4c04-9236-d734ab114e9c",
"request": {
"method": "GET",
"header": [
],
"url": {
"raw": "{{url}}/v2/apps/{{appId}}/integrations/:integrationId/webhooks/:webhookId",
"host": [
"{{url}}"
],
"path": [
"v2",
"apps",
"{{appId}}",
"integrations",
":integrationId",
"webhooks",
":webhookId"
],
"variable": [
{
"key": "integrationId"
},
{
"key": "webhookId"
}
]
},
"description": "Gets the specified webhook associated with a Sunshine Conversations Connect integration or a custom integration."
},
"response": [
{
"id": "38580f86-f580-45a4-b44e-e8b5fe7eb249",
"name": "Ok",
"originalRequest": {
"method": "GET",
"header": [
{
"description": {
"content": "Added as a part of security scheme: bearer",
"type": "text/plain"
},
"key": "Authorization",
"value": "Bearer <token>"
}
],
"url": {
"raw": "{{baseUrl}}/v2/apps/:appId/integrations/:integrationId/webhooks/:webhookId",
"host": [
"{{baseUrl}}"
],
"path": [
"v2",
"apps",
":appId",
"integrations",
":integrationId",
"webhooks",
":webhookId"
],
"variable": [
{
"key": "appId"
},
{
"key": "integrationId"
},
{
"key": "webhookId"
}
]
}
},
"status": "OK",
"code": 200,
"_postman_previewlanguage": "json",
"header": [
{
"key": "Content-Type",
"value": "application/json"
}
],
"cookie": [
],
"body": "{\n \"webhook\": {\n \"target\": \"http://example.com/callback\",\n \"triggers\": [\n \"conversation:read\",\n \"conversation:message\"\n ],\n \"id\": \"5e554d2cac66fb73a3c01871\",\n \"version\": \"v2\",\n \"secret\": \"8564b3e6a8b20a4bdb68b05ce9bc5936\",\n \"includeFullUser\": false,\n \"includeFullSource\": false\n }\n}"
},
{
"id": "4818c85e-2c1e-4517-9caf-d42cd9952dc1",
"name": "Not Found",
"originalRequest": {
"method": "GET",
"header": [
{
"description": {
"content": "Added as a part of security scheme: bearer",
"type": "text/plain"
},
"key": "Authorization",
"value": "Bearer <token>"
}
],
"url": {
"raw": "{{baseUrl}}/v2/apps/:appId/integrations/:integrationId/webhooks/:webhookId",
"host": [
"{{baseUrl}}"
],
"path": [
"v2",
"apps",
":appId",
"integrations",
":integrationId",
"webhooks",
":webhookId"
],
"variable": [
{
"key": "appId"
},
{
"key": "integrationId"
},
{
"key": "webhookId"
}
]
}
},
"status": "Not Found",
"code": 404,
"_postman_previewlanguage": "text",
"header": [
{
"key": "Content-Type",
"value": "text/plain"
}
],
"cookie": [
],
"body": ""
}
]
}