Call Detail Records
CDRs (Call Detail Records) provide a summary view of a call leg.
Schema
Call Detail Records
Key | Description | Type | Default | Required | Support Level |
---|---|---|---|---|---|
app_name | The 2600Hz application that issued the CDR | string() | false | ||
app_version | The internal 2600Hz version number of the application that issued the CDR | string() | false | ||
billing_seconds | The number of seconds the call leg can be billed for (typically from when the call leg is answered | integer() | false | ||
call_direction | Direction of the call, relative to the media switch | string('inbound' | 'outbound') | false | ||
call_id | Unique identifier of the call leg | string() | true | ||
callee_id_name | The indicated name of the callee | string() | false | ||
callee_id_number | The indicated number of the callee | string() | false | ||
caller_id_name | The indicated name of the caller | string() | false | ||
caller_id_number | The indicated number of the caller | string() | false | ||
channel_call_state | Media Server channel call state | string() | false | ||
channel_created_time | Unix timestamp in microseconds of channel create | integer() | false | ||
channel_name | Media Server channel name | string() | false | ||
channel_state | Media Server channel state | string() | false | ||
custom_application_vars | Any custom-set values | object() | false | ||
custom_channel_vars | 2600Hz specific key/value pairs set on the channel | object() | false | ||
custom_sip_headers.in | Custom SIP Headers to be applied to calls inbound to 2600Hz from the endpoint | #/definitions/custom_sip_headers | false | ||
custom_sip_headers.out | Custom SIP Headers to be applied to calls outbound from 2600Hz to the endpoint | #/definitions/custom_sip_headers | false | ||
custom_sip_headers.^[a-zA-z0-9_\-]+$ | The SIP header to add | `string() | boolean() | integer()` | |
custom_sip_headers | A property list of SIP headers | object() | false | ||
digits_dialed | All the DTMF tones detected on this leg of the call | string() | false | ||
disposition | Who sent the SIP BYE message | string() | false | ||
duration_seconds | The duration of the call leg, in seconds | integer() | false | ||
event_category | 2600Hz specific key (Event-Category) included on each payload it publishes | string() | false | ||
event_name | 2600Hz specific key (Event-Name) included on each payload it publishes | string() | false | ||
fax_bad_rows | Number of rows that failed to transfer | string() | false | ||
fax_ecm_used | Was ECM (error correction mode) used on the fax | string() | false | ||
fax_result_code | Media Server’s result code of the transmission | string() | false | ||
fax_result_text | Error String, if any, or ‘OK’ if successful | string() | false | ||
fax_success | Whether the fax was considered a success or not | string() | false | ||
fax_total_pages | Number of pages in the fax | string() | false | ||
fax_transfer_rate | Baud of the fax transfer | string() | false | ||
fax_transferred_pages | Number of pages transferred | string() | false | ||
from | Built by 2600Hz, depending on direction, to represent the From user | string() | false | ||
from_tag | SIP From TAG | string() | false | ||
from_uri | The From SIP URI | string() | false | ||
hangup_cause | The reason for the call leg’s termination | string() | false | ||
hangup_code | The SIP hangup code, if available | string() | false | ||
interaction_id | correlating ID among related call legs | string() | false | ||
interaction_key | Unique portion of the interaction ID | string() | false | ||
interaction_time | Timestamp of the creation of the interaction ID | integer() | false | ||
local_sdp | The SDP negotiated by the local agent | string() | false | ||
media_server | The hostname of the media server that processed the call | string() | false | ||
msg_id | 2600Hz specific key (Msg-Id) assigned to each payload it publishes | string() | false | ||
node | The ecallmgr which issued the CDR | string() | false | ||
other_leg_call_id | If this leg was bridged, the call-id of the opposite leg | string() | false | ||
other_leg_caller_id_name | Caller ID name of the bridged leg | string() | false | ||
other_leg_caller_id_number | Caller ID number of the bridged leg | string() | false | ||
other_leg_destination_number | Dialed number of the other leg | string() | false | ||
other_leg_direction | direction of the other leg, relative to the media server | string() | false | ||
presence_id | ID used in NOTIFY SIP messages | string() | false | ||
remote_sdp | The SDP negotiated by the remote agent | string() | false | ||
request | Built by 2600Hz this is the processed request URI | string() | false | ||
ringing_seconds | How many seconds the leg was ringing (pre-answer) | integer() | false | ||
switch_hostname | Media Server hostname (as reported by the switch) | string() | false | ||
switch_nodename | Media Server node name (as known in ecallmgr) | string() | false | ||
switch_uri | Media Server URI | string() | false | ||
switch_url | Media Server URL | string() | false | ||
timestamp | UTC timestamp, in Gregorian seconds, of when the CDR was generated | integer() | false | ||
to | Built by 2600Hz, depending on direction, to represent the To user | string() | false | ||
to_tag | SIP TO Tag | string() | false | ||
to_uri | The To SIP URI | string() | false | ||
user_agent | User agent header from SIP packet | string() | false |
custom_sip_headers
Custom SIP headers applied to an INVITE
Key | Description | Type | Default | Required | Support Level |
---|---|---|---|---|---|
^[a-zA-z0-9_\-]+$ | The SIP header to add | `string() | boolean() | integer()` |
Fetch
Prerequisites
By default requests are paginated. The default page size is 50 records though it can vary based on the system’s configuration. It is recommended to fetch CDRs by page to not overload the system on particularly busy accounts.
Clients should use the next_start_key
to move to the next page on subsequent requests.
Filtering results.
2600Hz provides filters to filter out rows from the results. This can be helpful if you’re looking for rows related to each other (like the same presence_id
, for instance).
Timestamps
2600Hz timestamps, unless otherwise noted, are in Gregorian seconds. Alternative timestamp formats are generally noted by the field name (e.g. unix_timestamp
, rfc1036
, or iso8601
).
Fetch request
GET /v2/accounts/{ACCOUNT_ID}/cdrs
curl -v -X GET \
-H "X-Auth-Token: {AUTH_TOKEN}" \
http://{SERVER}:8000/v2/accounts/{ACCOUNT_ID}/cdrs
Fetch CDRs within a time range
curl -v -X GET \
-H "X-Auth-Token: {AUTH_TOKEN}" \
http://{SERVER}:8000/v2/accounts/{ACCOUNT_ID}/cdrs?created_from={FROM_TIMESTAMP}&created_to={TO_TIMESTAMP}
Convert timestamps to local timezone (vs UTC)
Get CDRs and update datetime field to local time zone (using seconds for timeoffset from UTC time) - Timestamps must still be in Gregorian time:
curl -v -X GET \
-H "X-Auth-Token: {AUTH_TOKEN}" \
http://{SERVER}:8000/v2/accounts/{ACCOUNT_ID}/cdrs?created_from={FROM_TIMESTAMP}&created_to={TO_TIMESTAMP}&utc_offset={SECONDS_OFFSET}
Fetch as CSV instead of JSON
curl -v -X GET \
-H "Accept: text/csv" \
-H "X-Auth-Token: {AUTH_TOKEN}" \
http://{SERVER}:8000/v2/accounts/{ACCOUNT_ID}/cdrs
Fetch as CSV with defined filename
Using request headers:
curl -v -X GET \
-H "Accept: text/csv" \
-H "X-Auth-Token: {AUTH_TOKEN}" \
-H "X-File-Name: {FILE_NAME}" \
http://{SERVER}:8000/v2/accounts/{ACCOUNT_ID}/cdrs
Alternatively on the querystring:
curl -v -X GET \
-H "Accept: text/csv" \
-H "X-Auth-Token: {AUTH_TOKEN}" \
http://{SERVER}:8000/v2/accounts/{ACCOUNT_ID}/cdrs?file_name={FILE_NAME}
Fetch a CDR’s details
GET /v2/accounts/{ACCOUNT_ID}/cdrs/{CDR_ID}
curl -v -X GET \
-H "X-Auth-Token: {AUTH_TOKEN}" \
http://{SERVER}:8000/v2/accounts/{ACCOUNT_ID}/cdrs/{CDR_ID}
Fetch interaction summary
GET /v2/accounts/{ACCOUNT_ID}/cdrs/interaction
curl -v -X GET \
-H "X-Auth-Token: {AUTH_TOKEN}" \
http://{SERVER}:8000/v2/accounts/{ACCOUNT_ID}/cdrs/interaction
Fetch all legs related to an interaction
Crossbar cdrs was extended to provide simplified interaction call detail records. It groups all CDRs that interacted with each other to form a list of calls.
GET /v2/accounts/{ACCOUNT_ID}/cdrs/legs/{INTERACTION_ID}
curl -v -X GET \
-H "X-Auth-Token: {AUTH_TOKEN}" \
http://{SERVER}:8000/v2/accounts/{ACCOUNT_ID}/cdrs/legs/{INTERACTION_ID}
Variations
You can select CDRs/interactions for a specific user by adding them to the URI:
GET /v2/accounts/{ACCOUNT_ID}/users/{USER_ID}/cdrs
Notes on fields
Some fields need a little more explanation to help you understand what they are telling you about the call leg.
call_direction
- direction of the leg, relative to the media switchinbound
- leg came into the media switch (typically the A-leg)outbound
- leg started on the media switch (typically the B-leg)
hangup_cause
- The reason why the call leg ended. See the FreeSWITCH Hangup Causes page for descriptions.billing_seconds
- How many seconds of the call are billable (post answer, normally)to
- Depends on the direction of the leg- outbound - Uses the presence-id or else it uses the SIP Request address
- inbound - the SIP To header
2600Hz-specific properties
These are properties set by 2600Hz for internal purposes. These are the properties found under the custom_channel_vars
property at the top-level of the CDR JSON object. The non-exhaustive list of properties:
account_id
- Account ID this leg belongs toauthorizing_id
- Document ID used to authorize this call legauthorizing_type
- Type of document used to authorize calldevice
- the call leg is to/from a known 2600Hz devicemobile
- the call leg is to/from a known 2600Hz mobile deviceresource
- the call leg is from a known offnet carrieroutbound_fax
bridge_id
- Typically the A-leg’s call-id; helps with tracking transfersecallmgr_node
- Which ecallmgr node is processing the call legfetch_id
- The dialplan XML fetch ID from FreeSWITCHrealm
- the SIP realm of the accountresource_id
- Resource ID used for the leg; typically a carrier, local or global, that the call was routed tousername
- the SIP username of the endpoint that started the leg
Billing-related Properties
These properties relate to how the leg was rated and billed. Some of these properties are not accessible via Crossbar, but may exist on the CDR
reseller_billing
- tag describing what billing was used for the resellerreseller_id
- Account ID of the reseller for the account of this legaccount_billing
- tag describing what billing was used for the accountrate
- Rate of the callbase_cost
- How much the call costs to start (if per-minute)rate_name
- Name of the rate doc usedsurcharge
- Surcharge added to the legrate_minimum
- Minimum number of seconds to bill forrate_increment
- Increment of seconds to bill for
Fax-specific Properties
These properties may exist on a CDR for a fax request (inbound or outbound):
fax_transfer_rate
- Baud of the fax transferfax_bad_rows
- Number of rows that failed to transferfax_total_pages
- Number of pages in the fax (seefax_transferred_pages
for how many made it)fax_transferred_pages
- Number of pages transferredfax_ecm_used
- Was ECM (error correction mode) used on the faxfax_result_text
- Error String, if any, or ‘OK’ if successfulfax_result_code
- Result code of the transmissionfax_success
- boolean for whether the fax was considered a successfax_t38
- boolean for whether the fax T.38 was used
Resource Properties
All resource properties are set by the Stepswitch application.
resource_type
- This property attempts to explain the reason the resource was used. The possible values are:- offnet-origination - Inbound call from a resource/carrier to a 2600Hz account
- offnet-termination - Outbound call from a 2600Hz account to a resource/carrier
- onnet-origination - Inbound call from a 2600Hz account to another 2600Hz account
- onnet-termination - Outbound call from a 2600Hz account to another 2600Hz account
global_resource
- This boolean is TRUE when the channel has been created by processing a resource from the offnet database, and FALSE if the resource is from an account database (local).resource_id
- This is resource document id used to create the channel