Delphi ActiveX
Delphi ActiveX
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 ActiveX Downloads
uses
Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Chilkat_TLB;
...
procedure TForm1.Button1Click(Sender: TObject);
var
success: Integer;
http: TChilkatHttp;
json: TChilkatJsonObject;
sbRequestBody: TChilkatStringBuilder;
resp: TChilkatHttpResponse;
sbResponseBody: TChilkatStringBuilder;
jResp: TChilkatJsonObject;
respStatusCode: Integer;
answered: Integer;
business_phone_number: WideString;
customer_city: WideString;
customer_country: WideString;
customer_name: WideString;
customer_phone_number: WideString;
customer_state: WideString;
direction: WideString;
duration: Integer;
id: WideString;
recording: WideString;
recording_duration: WideString;
start_time: WideString;
tracking_phone_number: WideString;
voicemail: Integer;
begin
success := 0;
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
http := TChilkatHttp.Create(Self);
// 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 := TChilkatJsonObject.Create(Self);
json.UpdateString('note','Call customer back tomorrow');
json.UpdateString('tags[0]','New Client');
json.UpdateString('lead_status','good_lead');
json.UpdateString('value','$1.00');
json.UpdateBool('append_tags',1);
http.SetRequestHeader('Authorization','Token token={api_token}');
http.SetRequestHeader('Content-Type','application/json');
sbRequestBody := TChilkatStringBuilder.Create(Self);
json.EmitSb(sbRequestBody.ControlInterface);
resp := TChilkatHttpResponse.Create(Self);
success := http.HttpSb('PUT','https://api.callrail.com/v3/a/{account_id}/calls/{call_id}.json',sbRequestBody.ControlInterface,'utf-8','application/json',resp.ControlInterface);
if (success = 0) then
begin
Memo1.Lines.Add(http.LastErrorText);
Exit;
end;
sbResponseBody := TChilkatStringBuilder.Create(Self);
resp.GetBodySb(sbResponseBody.ControlInterface);
jResp := TChilkatJsonObject.Create(Self);
jResp.LoadSb(sbResponseBody.ControlInterface);
jResp.EmitCompact := 0;
Memo1.Lines.Add('Response Body:');
Memo1.Lines.Add(jResp.Emit());
respStatusCode := resp.StatusCode;
Memo1.Lines.Add('Response Status Code = ' + IntToStr(respStatusCode));
if (respStatusCode >= 400) then
begin
Memo1.Lines.Add('Response Header:');
Memo1.Lines.Add(resp.Header);
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 := jResp.BoolOf('answered');
business_phone_number := jResp.StringOf('business_phone_number');
customer_city := jResp.StringOf('customer_city');
customer_country := jResp.StringOf('customer_country');
customer_name := jResp.StringOf('customer_name');
customer_phone_number := jResp.StringOf('customer_phone_number');
customer_state := jResp.StringOf('customer_state');
direction := jResp.StringOf('direction');
duration := jResp.IntOf('duration');
id := jResp.StringOf('id');
recording := jResp.StringOf('recording');
recording_duration := jResp.StringOf('recording_duration');
start_time := jResp.StringOf('start_time');
tracking_phone_number := jResp.StringOf('tracking_phone_number');
voicemail := jResp.BoolOf('voicemail');
end;