Sample code for 30+ languages & platforms
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

Delphi ActiveX
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;