FreeSWITCH custom CDR guide and dividing CDR logs by accountcode
We will be configuring the cdr_csv module to log all calls going through a specific extension to a seperate file. This is useful if you would like to monitor all calls hitting a certain extension in your dialplan without having to dig through the master CDR file. We will assume that you have setup your FreeSWITCH system using our previous tutorial, FreeSWITCH 1.6 Quick Install Guide for Debian Jessie
CDR
First make sure the mod_cdr_csv module is uncommented in /etc/freeswitch/autoload_configs/modules.conf
<load module="mod_cdr_csv"/>
Next we need to create a new template in /etc/freeswitch/autoload_configs/cdr_csv.conf.xml
. Note that the template will need to be named the same as whatever account code you decide to use in your dialplan later. When an accountcode matches a template name, FreeSWITCH will create a unique CDR file for all calls specified as that accountcode.
<template name="test_in">"${caller_id_number}","${start_stamp}","${answer_stamp}","${end_stamp}","${accountcode}"</template>
This template will log the caller id, start of call time, answer time, end of call time, and accountcode name to test_in.csv in the log-base directory, which defaults to /var/log/freeswitch/cdr-csv/
You can find a list of cdr variables here
Dialplan
Now in your dialplan you will need to set the accountcode. In my dialplan, I am bridging to a user once it hits my default context, which is where I decided to set the account code. Below you will see the accountcode set before the call is bridged to the 1000
user.
<action application="set" data="accountcode=test_in"/>
<action application="bridge" data="USER/1000@default"/>
You will need to reload FreeSWITCH after making these changes. If you are on Debian 8, you can run systemctl restart freeswitch
. Once FreeSWITCH is reloaded you should see a seperate CDR file at /var/log/freeswitch/cdr-csv/test_in.csv
, which will only contain calls flagged with the accountcode test_in
.