| 
									
										
										
										
											2009-06-23 23:57:07 +00:00
										 |  |  | \section{Storage Backends} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-23 23:57:07 +00:00
										 |  |  | \subsection{Microsoft SQL Server} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	Asterisk can currently store CDRs into an MSSQL database in | 
					
						
							| 
									
										
										
										
											2010-06-28 15:33:32 +00:00
										 |  |  | 	two different ways:  cdr_odbc or cdr_tds | 
					
						
							| 
									
										
										
										
											2009-06-23 23:53:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	Call Data Records can be stored using unixODBC (which requires | 
					
						
							| 
									
										
										
										
											2010-06-28 15:33:32 +00:00
										 |  |  | 	the FreeTDS package) [cdr_odbc] or directly by using just the | 
					
						
							|  |  |  | 	FreeTDS package [cdr_tds]  The following provide some | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	examples known to get asterisk working with mssql. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	NOTE:  Only choose one db connector. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-28 15:33:32 +00:00
										 |  |  | \subsubsection{ODBC using cdr_odbc} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	Compile, configure, and install the latest unixODBC package: | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \begin{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | \begin{verbatim} | 
					
						
							|  |  |  | 	tar -zxvf unixODBC-2.2.9.tar.gz && | 
					
						
							|  |  |  | 	cd unixODBC-2.2.9 && | 
					
						
							|  |  |  | 	./configure --sysconfdir=/etc --prefix=/usr --disable-gui && | 
					
						
							|  |  |  | 	make && | 
					
						
							|  |  |  | 	make install | 
					
						
							|  |  |  | \end{verbatim} | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \end{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	Compile, configure, and install the latest FreeTDS package: | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \begin{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | \begin{verbatim} | 
					
						
							|  |  |  | 	tar -zxvf freetds-0.62.4.tar.gz && | 
					
						
							|  |  |  | 	cd freetds-0.62.4 && | 
					
						
							|  |  |  | 	./configure --prefix=/usr --with-tdsver=7.0 \ | 
					
						
							|  |  |  |                  --with-unixodbc=/usr/lib && | 
					
						
							|  |  |  | 	make && make install | 
					
						
							|  |  |  | \end{verbatim} | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \end{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	Compile, or recompile, asterisk so that it will now add support | 
					
						
							| 
									
										
										
										
											2010-06-28 15:33:32 +00:00
										 |  |  | 	for cdr_odbc. | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \begin{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | \begin{verbatim} | 
					
						
							|  |  |  | 	make clean && ./configure --with-odbc && | 
					
						
							|  |  |  | 	make update && | 
					
						
							|  |  |  | 	make && | 
					
						
							|  |  |  | 	make install | 
					
						
							|  |  |  | \end{verbatim} | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \end{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	Setup odbc configuration files.  These are working examples | 
					
						
							|  |  |  | 	from my system.  You will need to modify for your setup. | 
					
						
							|  |  |  | 	You are not required to store usernames or passwords here. | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \begin{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | \begin{verbatim} | 
					
						
							|  |  |  | 	/etc/odbcinst.ini | 
					
						
							|  |  |  | 	   [FreeTDS] | 
					
						
							|  |  |  | 	   Description    = FreeTDS ODBC driver for MSSQL | 
					
						
							|  |  |  | 	   Driver         = /usr/lib/libtdsodbc.so | 
					
						
							|  |  |  | 	   Setup          = /usr/lib/libtdsS.so | 
					
						
							|  |  |  | 	   FileUsage      = 1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/etc/odbc.ini | 
					
						
							|  |  |  | 	   [MSSQL-asterisk] | 
					
						
							|  |  |  | 	   description         = Asterisk ODBC for MSSQL | 
					
						
							|  |  |  | 	   driver              = FreeTDS | 
					
						
							|  |  |  | 	   server              = 192.168.1.25 | 
					
						
							|  |  |  | 	   port                = 1433 | 
					
						
							|  |  |  | 	   database            = voipdb | 
					
						
							|  |  |  | 	   tds_version         = 7.0 | 
					
						
							|  |  |  | 	   language            = us_english | 
					
						
							|  |  |  | \end{verbatim} | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \end{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		Only install one database connector.  Do not confuse asterisk | 
					
						
							| 
									
										
										
										
											2010-06-28 15:33:32 +00:00
										 |  |  | 		by using both ODBC (cdr_odbc) and FreeTDS (cdr_tds). | 
					
						
							|  |  |  | 		This command will erase the contents of cdr_tds.conf | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \begin{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | \begin{verbatim} | 
					
						
							|  |  |  | 		[ -f /etc/asterisk/cdr_tds.conf ] > /etc/asterisk/cdr_tds.conf | 
					
						
							|  |  |  | \end{verbatim} | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \end{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 		NOTE:  unixODBC requires the freeTDS package, but asterisk does | 
					
						
							|  |  |  | 		not call freeTDS directly. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-28 15:33:32 +00:00
										 |  |  | 		Now set up cdr_odbc configuration files.  These are working samples | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 		from my system.  You will need to modify for your setup. Define | 
					
						
							|  |  |  | 		your usernames and passwords here, secure file as well. | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \begin{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | \begin{verbatim} | 
					
						
							|  |  |  | 		/etc/asterisk/cdr_odbc.conf | 
					
						
							|  |  |  | 		   [global] | 
					
						
							|  |  |  | 		   dsn=MSSQL-asterisk | 
					
						
							|  |  |  | 		   username=voipdbuser | 
					
						
							|  |  |  | 		   password=voipdbpass | 
					
						
							|  |  |  | 		   loguniqueid=yes | 
					
						
							|  |  |  | \end{verbatim} | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \end{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 		And finally, create the 'cdr' table in your mssql database. | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \begin{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | \begin{verbatim} | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | 		CREATE TABLE cdr ( | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 		        [calldate]      [datetime]              NOT NULL , | 
					
						
							|  |  |  | 		        [clid]          [varchar] (80)          NOT NULL , | 
					
						
							|  |  |  | 		        [src]           [varchar] (80)          NOT NULL , | 
					
						
							|  |  |  | 		        [dst]           [varchar] (80)          NOT NULL , | 
					
						
							|  |  |  | 		        [dcontext]      [varchar] (80)          NOT NULL , | 
					
						
							|  |  |  | 		        [channel]       [varchar] (80)          NOT NULL , | 
					
						
							|  |  |  | 		        [dstchannel]    [varchar] (80)          NOT NULL , | 
					
						
							|  |  |  | 		        [lastapp]       [varchar] (80)          NOT NULL , | 
					
						
							|  |  |  | 		        [lastdata]      [varchar] (80)          NOT NULL , | 
					
						
							|  |  |  | 		        [duration]      [int]                   NOT NULL , | 
					
						
							|  |  |  | 		        [billsec]       [int]                   NOT NULL , | 
					
						
							|  |  |  | 		        [disposition]   [varchar] (45)          NOT NULL , | 
					
						
							|  |  |  | 		        [amaflags]      [int]                   NOT NULL , | 
					
						
							|  |  |  | 		        [accountcode]   [varchar] (20)          NOT NULL , | 
					
						
							| 
									
										
										
										
											2009-04-28 17:31:43 +00:00
										 |  |  | 		        [uniqueid]      [varchar] (150)         NOT NULL , | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 		        [userfield]     [varchar] (255)         NOT NULL | 
					
						
							|  |  |  | 		) | 
					
						
							|  |  |  | \end{verbatim} | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \end{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 		Start asterisk in verbose mode, you should see that asterisk | 
					
						
							|  |  |  | 		logs a connection to the database and will now record every | 
					
						
							|  |  |  | 		call to the database when it's complete. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-28 15:33:32 +00:00
										 |  |  | \subsubsection{TDS, using cdr_tds} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 		Compile, configure, and install the latest FreeTDS package: | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \begin{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | \begin{verbatim} | 
					
						
							|  |  |  | 		   tar -zxvf freetds-0.62.4.tar.gz && | 
					
						
							|  |  |  | 		   cd freetds-0.62.4 && | 
					
						
							|  |  |  | 		   ./configure --prefix=/usr --with-tdsver=7.0 | 
					
						
							|  |  |  | 		   make && | 
					
						
							|  |  |  | 		   make install | 
					
						
							|  |  |  | \end{verbatim} | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \end{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  |                 Compile, or recompile, asterisk so that it will now add support | 
					
						
							| 
									
										
										
										
											2010-06-28 15:33:32 +00:00
										 |  |  |                 for cdr_tds. | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \begin{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | \begin{verbatim} | 
					
						
							|  |  |  |                    make clean && ./configure --with-tds && | 
					
						
							|  |  |  |                    make update && | 
					
						
							|  |  |  |                    make && | 
					
						
							|  |  |  |                    make install | 
					
						
							|  |  |  | \end{verbatim} | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \end{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  |                 Only install one database connector.  Do not confuse asterisk | 
					
						
							| 
									
										
										
										
											2010-06-28 15:33:32 +00:00
										 |  |  |                 by using both ODBC (cdr_odbc) and FreeTDS (cdr_tds). | 
					
						
							|  |  |  |                 This command will erase the contents of cdr_odbc.conf | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \begin{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | \begin{verbatim} | 
					
						
							|  |  |  | 		[ -f /etc/asterisk/cdr_odbc.conf ] > /etc/asterisk/cdr_odbc.conf | 
					
						
							|  |  |  | \end{verbatim} | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \end{astlisting} | 
					
						
							| 
									
										
										
										
											2010-06-28 15:33:32 +00:00
										 |  |  |                 Setup cdr_tds configuration files.  These are working samples | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  |                 from my system.  You will need to modify for your setup. Define | 
					
						
							|  |  |  |                 your usernames and passwords here, secure file as well. | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \begin{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | \begin{verbatim} | 
					
						
							|  |  |  |                 /etc/asterisk/cdr_tds.conf | 
					
						
							|  |  |  | 		   [global] | 
					
						
							|  |  |  | 		   hostname=192.168.1.25 | 
					
						
							|  |  |  | 		   port=1433 | 
					
						
							|  |  |  | 		   dbname=voipdb | 
					
						
							|  |  |  | 		   user=voipdbuser | 
					
						
							|  |  |  | 		   password=voipdpass | 
					
						
							|  |  |  | 		   charset=BIG5 | 
					
						
							|  |  |  | \end{verbatim} | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \end{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  |                 And finally, create the 'cdr' table in your mssql database. | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \begin{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | \begin{verbatim} | 
					
						
							|  |  |  | 		CREATE TABLE cdr ( | 
					
						
							|  |  |  | 		        [accountcode]   [varchar] (20)          NULL , | 
					
						
							|  |  |  | 		        [src]           [varchar] (80)          NULL , | 
					
						
							|  |  |  | 		        [dst]           [varchar] (80)          NULL , | 
					
						
							|  |  |  | 		        [dcontext]      [varchar] (80)          NULL , | 
					
						
							|  |  |  | 		        [clid]          [varchar] (80)          NULL , | 
					
						
							|  |  |  | 		        [channel]       [varchar] (80)          NULL , | 
					
						
							|  |  |  | 		        [dstchannel]    [varchar] (80)          NULL , | 
					
						
							|  |  |  | 		        [lastapp]       [varchar] (80)          NULL , | 
					
						
							|  |  |  | 		        [lastdata]      [varchar] (80)          NULL , | 
					
						
							|  |  |  | 		        [start]         [datetime]              NULL , | 
					
						
							|  |  |  | 		        [answer]        [datetime]              NULL , | 
					
						
							|  |  |  | 		        [end]           [datetime]              NULL , | 
					
						
							|  |  |  | 		        [duration]      [int]                   NULL , | 
					
						
							|  |  |  | 		        [billsec]       [int]                   NULL , | 
					
						
							|  |  |  | 		        [disposition]   [varchar] (20)          NULL , | 
					
						
							|  |  |  | 		        [amaflags]      [varchar] (16)          NULL , | 
					
						
							| 
									
										
										
										
											2009-04-28 17:31:43 +00:00
										 |  |  | 		        [uniqueid]      [varchar] (150)         NULL , | 
					
						
							| 
									
										
										
										
											2008-08-13 14:41:49 +00:00
										 |  |  | 		        [userfield]     [varchar] (256)         NULL | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 		) | 
					
						
							|  |  |  | \end{verbatim} | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \end{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  |                 Start asterisk in verbose mode, you should see that asterisk | 
					
						
							|  |  |  |                 logs a connection to the database and will now record every | 
					
						
							|  |  |  |                 call to the database when it's complete. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-23 23:57:07 +00:00
										 |  |  | \subsection{MySQL} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-30 16:40:38 +00:00
										 |  |  | \subsubsection{ODBC} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-28 15:33:32 +00:00
										 |  |  | Using MySQL for CDR records is supported by using ODBC and the cdr_odbc module. | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-30 16:40:38 +00:00
										 |  |  | \subsubsection{Native} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Alternatively, there is a native MySQL CDR module. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-28 15:33:32 +00:00
										 |  |  | To use it, configure the module in cdr_mysql.conf.  Create a table called cdr under the database name you will be using the following schema. | 
					
						
							| 
									
										
										
										
											2009-06-30 16:40:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | \begin{astlisting} | 
					
						
							|  |  |  | \begin{verbatim} | 
					
						
							|  |  |  | CREATE TABLE cdr ( | 
					
						
							|  |  |  |   calldate datetime NOT NULL default '0000-00-00 00:00:00', | 
					
						
							|  |  |  |   clid varchar(80) NOT NULL default '', | 
					
						
							|  |  |  |   src varchar(80) NOT NULL default '', | 
					
						
							|  |  |  |   dst varchar(80) NOT NULL default '', | 
					
						
							|  |  |  |   dcontext varchar(80) NOT NULL default '', | 
					
						
							|  |  |  |   channel varchar(80) NOT NULL default '', | 
					
						
							|  |  |  |   dstchannel varchar(80) NOT NULL default '', | 
					
						
							|  |  |  |   lastapp varchar(80) NOT NULL default '', | 
					
						
							|  |  |  |   lastdata varchar(80) NOT NULL default '', | 
					
						
							|  |  |  |   duration int(11) NOT NULL default '0', | 
					
						
							|  |  |  |   billsec int(11) NOT NULL default '0', | 
					
						
							|  |  |  |   disposition varchar(45) NOT NULL default '', | 
					
						
							|  |  |  |   amaflags int(11) NOT NULL default '0', | 
					
						
							|  |  |  |   accountcode varchar(20) NOT NULL default '', | 
					
						
							|  |  |  |   uniqueid varchar(32) NOT NULL default '', | 
					
						
							|  |  |  |   userfield varchar(255) NOT NULL default '' | 
					
						
							|  |  |  | ); | 
					
						
							|  |  |  | \end{verbatim} | 
					
						
							|  |  |  | \end{astlisting} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-23 23:57:07 +00:00
										 |  |  | \subsection{PostgreSQL} | 
					
						
							| 
									
										
										
										
											2010-06-28 15:33:32 +00:00
										 |  |  |         If you want to go directly to postgresql database, and have the cdr_pgsql.so | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  |         compiled you can use the following sample setup. | 
					
						
							|  |  |  |         On Debian, before compiling asterisk, just install libpqxx-dev. | 
					
						
							|  |  |  |         Other distros will likely have a similiar package. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         Once you have the compile done, | 
					
						
							| 
									
										
										
										
											2010-06-28 15:33:32 +00:00
										 |  |  |         copy the sample cdr_pgsql.conf file or create your own. | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         Here is a sample: | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \begin{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | \begin{verbatim} | 
					
						
							|  |  |  |         /etc/asterisk/cdr_pgsql.conf | 
					
						
							|  |  |  |           ; Sample Asterisk config file for CDR logging to PostgresSQL | 
					
						
							|  |  |  |           [global] | 
					
						
							|  |  |  |           hostname=localhost | 
					
						
							|  |  |  |           port=5432 | 
					
						
							|  |  |  |           dbname=asterisk | 
					
						
							|  |  |  |           password=password | 
					
						
							|  |  |  |           user=postgres | 
					
						
							|  |  |  |           table=cdr | 
					
						
							|  |  |  | \end{verbatim} | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \end{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  |         Now create a table in postgresql for your cdrs | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \begin{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | \begin{verbatim} | 
					
						
							|  |  |  |         CREATE TABLE cdr ( | 
					
						
							| 
									
										
										
										
											2010-07-14 16:09:11 +00:00
										 |  |  |                 calldate      timestamp             NOT NULL , | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  |                 clid          varchar (80)          NOT NULL , | 
					
						
							|  |  |  |                 src           varchar (80)          NOT NULL , | 
					
						
							|  |  |  |                 dst           varchar (80)          NOT NULL , | 
					
						
							|  |  |  |                 dcontext      varchar (80)          NOT NULL , | 
					
						
							|  |  |  |                 channel       varchar (80)          NOT NULL , | 
					
						
							|  |  |  |                 dstchannel    varchar (80)          NOT NULL , | 
					
						
							|  |  |  |                 lastapp       varchar (80)          NOT NULL , | 
					
						
							|  |  |  |                 lastdata      varchar (80)          NOT NULL , | 
					
						
							|  |  |  |                 duration      int                   NOT NULL , | 
					
						
							|  |  |  |                 billsec       int                   NOT NULL , | 
					
						
							|  |  |  |                 disposition   varchar (45)          NOT NULL , | 
					
						
							|  |  |  |                 amaflags      int                   NOT NULL , | 
					
						
							|  |  |  |                 accountcode   varchar (20)          NOT NULL , | 
					
						
							| 
									
										
										
										
											2009-04-28 17:31:43 +00:00
										 |  |  |                 uniqueid      varchar (150)         NOT NULL , | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  |                 userfield     varchar (255)         NOT NULL | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  | \end{verbatim} | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | \end{astlisting} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-23 23:57:07 +00:00
										 |  |  | \subsection{SQLite 2} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-28 15:33:32 +00:00
										 |  |  | SQLite version 2 is supported in cdr_sqlite. | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-23 23:57:07 +00:00
										 |  |  | \subsection{SQLite 3} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-28 15:33:32 +00:00
										 |  |  | SQLite version 3 is supported in cdr_sqlite3\_custom. | 
					
						
							| 
									
										
										
										
											2009-06-23 23:57:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-23 22:47:26 +00:00
										 |  |  | \subsection{RADIUS} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-23 22:47:26 +00:00
										 |  |  | \subsubsection{What is needed} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | \begin{itemize} | 
					
						
							|  |  |  | 	\item FreeRADIUS server | 
					
						
							|  |  |  | 	\item Radiusclient-ng library | 
					
						
							|  |  |  | 	\item Asterisk PBX | 
					
						
							|  |  |  | \end{itemize} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-14 15:26:37 +00:00
										 |  |  | \begin{figure}[h] | 
					
						
							|  |  |  | \begin{center} | 
					
						
							|  |  |  | \setlength{\unitlength}{4cm} | 
					
						
							|  |  |  | \begin{picture}(3,.75) | 
					
						
							|  |  |  | \put(0,0){\line(0,1){.75}} | 
					
						
							|  |  |  | \put(0,.75){\line(1,0){1.5}} | 
					
						
							|  |  |  | \put(1.5,0){\line(0,1){.75}} | 
					
						
							|  |  |  | \put(0,0){\line(1,0){1.5}} | 
					
						
							|  |  |  | \put(.1,.4){\makebox(1.3,.3){Asterisk PBX}} | 
					
						
							|  |  |  | \put(.1,.4){\line(1,0){1.3}} | 
					
						
							|  |  |  | \put(.1,.1){\line(1,0){1.3}} | 
					
						
							|  |  |  | \put(.1,.1){\line(0,1){.3}} | 
					
						
							|  |  |  | \put(1.4,.1){\line(0,1){.3}} | 
					
						
							|  |  |  | \put(.1,.1){\makebox(1.3,.3){RADIUS Client}} | 
					
						
							|  |  |  | \put(1.8,0){\line(0,1){.5}} | 
					
						
							|  |  |  | \put(1.8,.5){\line(1,0){1.1}} | 
					
						
							|  |  |  | \put(1.8,0){\line(1,0){1.1}} | 
					
						
							|  |  |  | \put(2.9,0){\line(0,1){.5}} | 
					
						
							|  |  |  | \put(1.8,.275){\makebox(1.1,.1){RADIUS Server}} | 
					
						
							|  |  |  | \put(1.8,.125){\makebox(1.1,.1){$(FreeRADIUS)$}} | 
					
						
							|  |  |  | \thicklines | 
					
						
							|  |  |  | \put(1.4,.3){\vector(1,0){.4}} | 
					
						
							|  |  |  | \put(1.8,.2){\vector(-1,0){.4}} | 
					
						
							|  |  |  | \thinlines | 
					
						
							|  |  |  | \end{picture} | 
					
						
							|  |  |  | \end{center} | 
					
						
							|  |  |  | \caption{Asterisk/RADIUS Integration} | 
					
						
							|  |  |  | \end{figure} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | \subsubsection{Installation of the Radiusclient library} | 
					
						
							| 
									
										
										
										
											2007-10-12 15:50:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-23 23:53:45 +00:00
										 |  |  | 	Download the sources from | 
					
						
							| 
									
										
										
										
											2007-10-12 15:50:29 +00:00
										 |  |  | 	\url{http://developer.berlios.de/projects/radiusclient-ng/} | 
					
						
							| 
									
										
										
										
											2009-06-23 23:53:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-12 15:50:29 +00:00
										 |  |  | 	Untar the source tarball: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{verbatim} | 
					
						
							|  |  |  | 	root@localhost:/usr/local/src# tar xvfz radiusclient-ng-0.5.2.tar.gz | 
					
						
							|  |  |  | \end{verbatim} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Compile and install the library: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{verbatim} | 
					
						
							|  |  |  | 	root@localhost:/usr/local/src# cd radiusclient-ng-0.5.2 | 
					
						
							|  |  |  | 	root@localhost:/usr/local/src/radiusclient-ng-0.5.2# ./configure | 
					
						
							|  |  |  | 	root@localhost:/usr/local/src/radiusclient-ng-0.5.2# make | 
					
						
							|  |  |  | 	root@localhost:/usr/local/src/radiusclient-ng-0.5.2# make install | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | \end{verbatim} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \subsubsection{Configuration of the Radiusclient library} | 
					
						
							| 
									
										
										
										
											2009-06-23 23:53:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	By default all the configuration files of the radiusclient library will | 
					
						
							| 
									
										
										
										
											2007-10-12 15:50:29 +00:00
										 |  |  | 	be in \path{/usr/local/etc/radiusclient-ng} directory. | 
					
						
							| 
									
										
										
										
											2009-06-23 23:53:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	File "radiusclient.conf" | 
					
						
							|  |  |  | 		Open the file and find lines containing the following: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			authserver      localhost | 
					
						
							| 
									
										
										
										
											2009-06-23 23:53:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | 	This is the hostname or IP address of the RADIUS server used for | 
					
						
							|  |  |  | 	authentication. You will have to change this unless the server is | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	running on the same host as your Asterisk PBX. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			acctserver      localhost | 
					
						
							| 
									
										
										
										
											2007-10-12 15:50:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | 	This is the hostname or IP address of the RADIUS server used for | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	accounting. You will have to change this unless the server is running | 
					
						
							|  |  |  | 	on the same host as your Asterisk PBX. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | 	\textbf{File "servers"} | 
					
						
							| 
									
										
										
										
											2009-06-23 23:53:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	RADIUS protocol uses simple access control mechanism based on shared | 
					
						
							|  |  |  | 	secrets that allows RADIUS servers to limit access from RADIUS clients. | 
					
						
							| 
									
										
										
										
											2009-06-23 23:53:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | 	A RADIUS server is configured with a secret string and only RADIUS | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	clients that have the same secret will be accepted. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | 	You need to configure a shared secret for each server you have | 
					
						
							|  |  |  | 	configured in radiusclient.conf file in the previous step. The shared | 
					
						
							| 
									
										
										
										
											2007-10-12 15:50:29 +00:00
										 |  |  | 	secrets are stored in \path{/usr/local/etc/radiusclient-ng/servers} file. | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | 	Each line contains hostname of a RADIUS server and shared secret | 
					
						
							|  |  |  | 	used in communication with that server. The two values are separated | 
					
						
							|  |  |  | 	by white spaces. Configure shared secrets for every RADIUS server you | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	are going to use. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-12 15:50:29 +00:00
										 |  |  | 	\textbf{File "dictionary"} | 
					
						
							| 
									
										
										
										
											2009-06-23 23:53:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | 	Asterisk uses some attributes that are not included in the | 
					
						
							|  |  |  | 	dictionary of radiusclient library, therefore it is necessary to add | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	them. A file called dictionary.digium (kept in the contrib dir) | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | 	was created to list all new attributes used by Asterisk. | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	Add to the end of the main dictionary file | 
					
						
							| 
									
										
										
										
											2007-10-12 15:50:29 +00:00
										 |  |  | 	\path{/usr/local/etc/radiusclient-ng/dictionary} the line: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 		\$INCLUDE /path/to/dictionary.digium | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \subsubsection{Install FreeRADIUS Server (Version 1.1.1)} | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	Download sources tarball from: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-26 14:49:51 +00:00
										 |  |  | 		\url{http://freeradius.org/} | 
					
						
							| 
									
										
										
										
											2009-06-23 23:53:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	Untar, configure, build, and install the server: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{verbatim} | 
					
						
							|  |  |  | 	root@localhost:/usr/local/src# tar xvfz freeradius-1.1.1.tar.gz | 
					
						
							|  |  |  | 	root@localhost:/usr/local/src# cd freeradius-1.1.1 | 
					
						
							|  |  |  | 	root@localhost"/usr/local/src/freeradius-1.1.1# ./configure | 
					
						
							|  |  |  | 	root@localhost"/usr/local/src/freeradius-1.1.1# make | 
					
						
							|  |  |  | 	root@localhost"/usr/local/src/freeradius-1.1.1# make install | 
					
						
							|  |  |  | \end{verbatim} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | 	All the configuration files of FreeRADIUS server will be in | 
					
						
							|  |  |  | 	/usr/local/etc/raddb directory. | 
					
						
							| 
									
										
										
										
											2009-06-23 23:53:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | \subsubsection{Configuration of the FreeRADIUS Server} | 
					
						
							| 
									
										
										
										
											2009-06-23 23:53:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	There are several files that have to be modified to configure the | 
					
						
							|  |  |  | 	RADIUS server. These are presented next. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	File "clients.conf" | 
					
						
							| 
									
										
										
										
											2009-06-23 23:53:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | 	File \path{/usr/local/etc/raddb/clients.conf} contains description of | 
					
						
							|  |  |  | 	RADIUS clients that are allowed to use the server. For each of the | 
					
						
							|  |  |  | 	clients you need to specify its hostname or IP address and also a | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	shared secret. The shared secret must be the same string you configured | 
					
						
							|  |  |  | 	in radiusclient library. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Example: | 
					
						
							|  |  |  | \begin{verbatim} | 
					
						
							|  |  |  | 		client myhost { | 
					
						
							|  |  |  | 		    secret = mysecret | 
					
						
							|  |  |  | 		    shortname = foo | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-06-23 23:53:45 +00:00
										 |  |  | \end{verbatim} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | 	This fragment allows access from RADIUS clients on "myhost" if they use | 
					
						
							| 
									
										
										
										
											2009-06-23 23:53:45 +00:00
										 |  |  | 	"mysecret" as the shared secret. | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	The file already contains an entry for localhost (127.0.0.1), so if you | 
					
						
							|  |  |  | 	are running the RADIUS server on the same host as your Asterisk server, | 
					
						
							|  |  |  | 	then modify the existing entry instead, replacing the default password. | 
					
						
							| 
									
										
										
										
											2009-06-23 23:53:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	File "dictionary" | 
					
						
							| 
									
										
										
										
											2009-06-23 23:53:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | 	Note: as of version 1.1.2, the dictionary.digium file ships with FreeRADIUS. | 
					
						
							|  |  |  | 	The following procedure brings the dictionary.digium file to previous versions | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	of FreeRADIUS. | 
					
						
							| 
									
										
										
										
											2009-06-23 23:53:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | 	File \path{/usr/local/etc/raddb/dictionary} contains the dictionary of | 
					
						
							|  |  |  | 	FreeRADIUS server. You have to add the same dictionary file | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	(dictionary.digium), which you added to the dictionary of radiusclient-ng | 
					
						
							|  |  |  | 	library. You can include it into the main file, adding the following line at the | 
					
						
							| 
									
										
										
										
											2007-10-12 15:50:29 +00:00
										 |  |  | 	end of file \path{/usr/local/etc/raddb/dictionary}: | 
					
						
							| 
									
										
										
										
											2009-06-23 23:53:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	\$INCLUDE /path/to/dictionary.digium | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | 	That will include the same new attribute definitions that are used | 
					
						
							|  |  |  | 	in radiusclient-ng library so the client and server will understand each | 
					
						
							|  |  |  | 	other. | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \subsubsection{Asterisk Accounting Configuration} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Compilation and installation: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         The module will be compiled as long as the radiusclient-ng | 
					
						
							|  |  |  |         library has been detected on your system. | 
					
						
							| 
									
										
										
										
											2009-06-23 23:53:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | 	By default FreeRADIUS server will log all accounting requests into | 
					
						
							|  |  |  | 	\path{/usr/local/var/log/radius/radacct} directory in form of plain text files. | 
					
						
							|  |  |  | 	The server will create one file for each hostname in the directory. The | 
					
						
							|  |  |  | 	following example shows how the log files look like. | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-12 15:50:29 +00:00
										 |  |  | 	Asterisk now generates Call Detail Records. See \path{/include/asterisk/cdr.h} | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  | 	for all the fields which are recorded. By default, records in comma | 
					
						
							|  |  |  | 	separated values will be created in \path{/var/log/asterisk/cdr-csv}. | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-28 15:33:32 +00:00
										 |  |  | 	The configuration file for cdr_radius.so module is \path{/etc/asterisk/cdr.conf} | 
					
						
							| 
									
										
										
										
											2009-06-23 23:53:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | 	This is where you can set CDR related parameters as well as the path to | 
					
						
							|  |  |  | 	the radiusclient-ng library configuration file. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-23 22:47:26 +00:00
										 |  |  | \subsubsection{Logged Values} | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | \begin{verbatim} | 
					
						
							|  |  |  |   "Asterisk-Acc-Code",          The account name of detail records | 
					
						
							|  |  |  |   "Asterisk-Src", | 
					
						
							|  |  |  |   "Asterisk-Dst", | 
					
						
							|  |  |  |   "Asterisk-Dst-Ctx",           The destination context | 
					
						
							|  |  |  |   "Asterisk-Clid", | 
					
						
							|  |  |  |   "Asterisk-Chan",              The channel | 
					
						
							|  |  |  |   "Asterisk-Dst-Chan",	        (if applicable) | 
					
						
							| 
									
										
										
										
											2007-10-15 13:12:51 +00:00
										 |  |  |   "Asterisk-Last-App",	        Last application run on the channel | 
					
						
							|  |  |  |   "Asterisk-Last-Data",         Argument to the last channel | 
					
						
							|  |  |  |   "Asterisk-Start-Time", | 
					
						
							|  |  |  |   "Asterisk-Answer-Time", | 
					
						
							|  |  |  |   "Asterisk-End-Time", | 
					
						
							|  |  |  |   "Asterisk-Duration",          Duration is the whole length that the entire | 
					
						
							|  |  |  |                                 call lasted. ie. call rx'd to hangup | 
					
						
							|  |  |  |                                 "end time" minus "start time" | 
					
						
							|  |  |  |   "Asterisk-Bill-Sec", 	        The duration that a call was up after other | 
					
						
							|  |  |  |                                 end answered which will be <= to duration | 
					
						
							|  |  |  |                                 "end time" minus "answer time" | 
					
						
							|  |  |  |   "Asterisk-Disposition",    	  ANSWERED, NO ANSWER, BUSY | 
					
						
							|  |  |  |   "Asterisk-AMA-Flags",       	DOCUMENTATION, BILL, IGNORE etc, specified on | 
					
						
							|  |  |  |                                 a per channel basis like accountcode. | 
					
						
							|  |  |  |   "Asterisk-Unique-ID",         Unique call identifier | 
					
						
							|  |  |  |   "Asterisk-User-Field"	        User field set via SetCDRUserField | 
					
						
							| 
									
										
										
										
											2007-03-15 22:29:45 +00:00
										 |  |  | \end{verbatim} |