Delphi DLL
Delphi DLL
CallRail API - Update a Call
See more CallRail Examples
Updates a call object in the target account. You can use the API to add a Tag or a Note to a call, or to set the call’s lead status.Chilkat Delphi DLL Downloads
uses
Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Http, StringBuilder, HttpResponse, JsonObject;
...
procedure TForm1.Button1Click(Sender: TObject);
var
success: Boolean;
http: HCkHttp;
json: HCkJsonObject;
sbRequestBody: HCkStringBuilder;
resp: HCkHttpResponse;
sbResponseBody: HCkStringBuilder;
jResp: HCkJsonObject;
respStatusCode: Integer;
answered: Boolean;
business_phone_number: PWideChar;
customer_city: PWideChar;
customer_country: PWideChar;
customer_name: PWideChar;
customer_phone_number: PWideChar;
customer_state: PWideChar;
direction: PWideChar;
duration: Integer;
id: PWideChar;
recording: PWideChar;
recording_duration: PWideChar;
start_time: PWideChar;
tracking_phone_number: PWideChar;
voicemail: Boolean;
begin
success := False;
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
http := CkHttp_Create();
// Implements the following CURL command:
// curl -H "Authorization: Token token={api_token}" \
// -X PUT \
// -H "Content-Type: application/json" \
// -v \
// -d '{
// "note": "Call customer back tomorrow",
// "tags": ["New Client"],
// "lead_status": "good_lead",
// "value": "$1.00",
// "append_tags": true,
// }' \
// "https://api.callrail.com/v3/a/{account_id}/calls/{call_id}.json"
// Use the following online tool to generate HTTP code from a CURL command
// Convert a cURL Command to HTTP Source Code
// Use this online tool to generate code from sample JSON:
// Generate Code to Create JSON
// The following JSON is sent in the request body.
// {
// "note": "Call customer back tomorrow",
// "tags": [
// "New Client"
// ],
// "lead_status": "good_lead",
// "value": "$1.00",
// "append_tags": true
// }
json := CkJsonObject_Create();
CkJsonObject_UpdateString(json,'note','Call customer back tomorrow');
CkJsonObject_UpdateString(json,'tags[0]','New Client');
CkJsonObject_UpdateString(json,'lead_status','good_lead');
CkJsonObject_UpdateString(json,'value','$1.00');
CkJsonObject_UpdateBool(json,'append_tags',True);
CkHttp_SetRequestHeader(http,'Authorization','Token token={api_token}');
CkHttp_SetRequestHeader(http,'Content-Type','application/json');
sbRequestBody := CkStringBuilder_Create();
CkJsonObject_EmitSb(json,sbRequestBody);
resp := CkHttpResponse_Create();
success := CkHttp_HttpSb(http,'PUT','https://api.callrail.com/v3/a/{account_id}/calls/{call_id}.json',sbRequestBody,'utf-8','application/json',resp);
if (success = False) then
begin
Memo1.Lines.Add(CkHttp__lastErrorText(http));
Exit;
end;
sbResponseBody := CkStringBuilder_Create();
CkHttpResponse_GetBodySb(resp,sbResponseBody);
jResp := CkJsonObject_Create();
CkJsonObject_LoadSb(jResp,sbResponseBody);
CkJsonObject_putEmitCompact(jResp,False);
Memo1.Lines.Add('Response Body:');
Memo1.Lines.Add(CkJsonObject__emit(jResp));
respStatusCode := CkHttpResponse_getStatusCode(resp);
Memo1.Lines.Add('Response Status Code = ' + IntToStr(respStatusCode));
if (respStatusCode >= 400) then
begin
Memo1.Lines.Add('Response Header:');
Memo1.Lines.Add(CkHttpResponse__header(resp));
Memo1.Lines.Add('Failed.');
Exit;
end;
// Sample JSON response:
// (Sample code for parsing the JSON response is shown below)
// {
// "answered": false,
// "business_phone_number": null,
// "customer_city": "Denver",
// "customer_country": "US",
// "customer_name": "RUEGSEGGER SIMO",
// "customer_phone_number": "+13036231131",
// "customer_state": "CO",
// "direction": "inbound",
// "duration": 4,
// "id": "CAL8154748ae6bd4e278a7cddd38a662f4f",
// "recording": "https://api.callrail.com/v3/a/227799611/calls/213472384/recording.json",
// "recording_duration": "27",
// "start_time": "2017-01-24T11:27:48.119-05:00",
// "tracking_phone_number": "+13038163491",
// "voicemail": false
// }
// Sample code for parsing the JSON response...
// Use the following online tool to generate parsing code from sample JSON:
// Generate Parsing Code from JSON
answered := CkJsonObject_BoolOf(jResp,'answered');
business_phone_number := CkJsonObject__stringOf(jResp,'business_phone_number');
customer_city := CkJsonObject__stringOf(jResp,'customer_city');
customer_country := CkJsonObject__stringOf(jResp,'customer_country');
customer_name := CkJsonObject__stringOf(jResp,'customer_name');
customer_phone_number := CkJsonObject__stringOf(jResp,'customer_phone_number');
customer_state := CkJsonObject__stringOf(jResp,'customer_state');
direction := CkJsonObject__stringOf(jResp,'direction');
duration := CkJsonObject_IntOf(jResp,'duration');
id := CkJsonObject__stringOf(jResp,'id');
recording := CkJsonObject__stringOf(jResp,'recording');
recording_duration := CkJsonObject__stringOf(jResp,'recording_duration');
start_time := CkJsonObject__stringOf(jResp,'start_time');
tracking_phone_number := CkJsonObject__stringOf(jResp,'tracking_phone_number');
voicemail := CkJsonObject_BoolOf(jResp,'voicemail');
CkHttp_Dispose(http);
CkJsonObject_Dispose(json);
CkStringBuilder_Dispose(sbRequestBody);
CkHttpResponse_Dispose(resp);
CkStringBuilder_Dispose(sbResponseBody);
CkJsonObject_Dispose(jResp);
end;