Sample code for 30+ languages & platforms
Visual FoxPro

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 Visual FoxPro Downloads

Visual FoxPro
LOCAL lnSuccess
LOCAL loHttp
LOCAL loJson
LOCAL loSbRequestBody
LOCAL loResp
LOCAL loSbResponseBody
LOCAL loJResp
LOCAL lnRespStatusCode
LOCAL lnAnswered
LOCAL lcBusiness_phone_number
LOCAL lcCustomer_city
LOCAL lcCustomer_country
LOCAL lcCustomer_name
LOCAL lcCustomer_phone_number
LOCAL lcCustomer_state
LOCAL lcDirection
LOCAL lnDuration
LOCAL lcId
LOCAL lcRecording
LOCAL lcRecording_duration
LOCAL lcStart_time
LOCAL lcTracking_phone_number
LOCAL lnVoicemail

lnSuccess = 0

* This example assumes the Chilkat API to have been previously unlocked.
* See Global Unlock Sample for sample code.

loHttp = CreateObject('Chilkat.Http')

* 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
* }

loJson = CreateObject('Chilkat.JsonObject')
loJson.UpdateString("note","Call customer back tomorrow")
loJson.UpdateString("tags[0]","New Client")
loJson.UpdateString("lead_status","good_lead")
loJson.UpdateString("value","$1.00")
loJson.UpdateBool("append_tags",1)

loHttp.SetRequestHeader("Authorization","Token token={api_token}")
loHttp.SetRequestHeader("Content-Type","application/json")

loSbRequestBody = CreateObject('Chilkat.StringBuilder')
loJson.EmitSb(loSbRequestBody)

loResp = CreateObject('Chilkat.HttpResponse')
lnSuccess = loHttp.HttpSb("PUT","https://api.callrail.com/v3/a/{account_id}/calls/{call_id}.json",loSbRequestBody,"utf-8","application/json",loResp)
IF (lnSuccess = 0) THEN
    ? loHttp.LastErrorText
    RELEASE loHttp
    RELEASE loJson
    RELEASE loSbRequestBody
    RELEASE loResp
    CANCEL
ENDIF

loSbResponseBody = CreateObject('Chilkat.StringBuilder')
loResp.GetBodySb(loSbResponseBody)
loJResp = CreateObject('Chilkat.JsonObject')
loJResp.LoadSb(loSbResponseBody)
loJResp.EmitCompact = 0

? "Response Body:"
? loJResp.Emit()

lnRespStatusCode = loResp.StatusCode
? "Response Status Code = " + STR(lnRespStatusCode)
IF (lnRespStatusCode >= 400) THEN
    ? "Response Header:"
    ? loResp.Header
    ? "Failed."
    RELEASE loHttp
    RELEASE loJson
    RELEASE loSbRequestBody
    RELEASE loResp
    RELEASE loSbResponseBody
    RELEASE loJResp
    CANCEL
ENDIF

* 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

lnAnswered = loJResp.BoolOf("answered")
lcBusiness_phone_number = loJResp.StringOf("business_phone_number")
lcCustomer_city = loJResp.StringOf("customer_city")
lcCustomer_country = loJResp.StringOf("customer_country")
lcCustomer_name = loJResp.StringOf("customer_name")
lcCustomer_phone_number = loJResp.StringOf("customer_phone_number")
lcCustomer_state = loJResp.StringOf("customer_state")
lcDirection = loJResp.StringOf("direction")
lnDuration = loJResp.IntOf("duration")
lcId = loJResp.StringOf("id")
lcRecording = loJResp.StringOf("recording")
lcRecording_duration = loJResp.StringOf("recording_duration")
lcStart_time = loJResp.StringOf("start_time")
lcTracking_phone_number = loJResp.StringOf("tracking_phone_number")
lnVoicemail = loJResp.BoolOf("voicemail")

RELEASE loHttp
RELEASE loJson
RELEASE loSbRequestBody
RELEASE loResp
RELEASE loSbResponseBody
RELEASE loJResp