2004-01-19 02:30:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Asterisk billing support - Call Detail Records
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								----------------------------------------------
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Asterisk generates Call Detail Records in a database or in a comma
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								separated text file. 
							 
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:28:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2004-01-19 02:30:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								   * cdr_csv supports comma separated text file storage, this is the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     default driver
							 
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:28:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								   * cdr_manager supports CDR information via the AMI, The Asterisk Manager
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     interface
							 
						 
					
						
							
								
									
										
										
										
											2004-01-19 02:30:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								   * cdr_odbc supports UnixODBC databases, see http://www.unixodbc.org
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     for an updated list of supported databases, from MySQL to MsSQL
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     and text files.
							 
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:28:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								   * cdr_tds supports FreeTDS databases (Among them MS SQL)
							 
						 
					
						
							
								
									
										
										
										
											2006-03-12 17:27:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									NOTE: Please read doc/freetds.txt for information on possible
							 
						 
					
						
							
								
									
										
										
										
											2006-01-10 08:52:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									problems with the FreeTDS driver
							 
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:28:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								   * cdr_sqlite supports SQlite
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   * cdr_pgsql supports PostgreSQL
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-12-01 22:17:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								In the asterisk-addons subversion repository, there's a cdr_mysql driver for
							 
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:28:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								MySQL.
							 
						 
					
						
							
								
									
										
										
										
											2004-01-19 02:30:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Applications
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								------------
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-02-23 22:48:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    * SetAccount  		Set account code for billing
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    * SetAMAFlags 		Sets AMA flags
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    * NoCDR  			Make sure no CDR is saved for a specific call
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    * ResetCDR  		Reset CDR
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    * ForkCDR 			Save current CDR and start a new CDR for this call
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    * Authenticate 		Authenticates and sets the account code
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    * SetCDRUserField   	Set CDR user field
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    * AppendCDRUserField   	Append data to CDR User field 
							 
						 
					
						
							
								
									
										
										
										
											2004-01-19 02:30:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								For more information, use the "show application" command.
							 
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:28:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								You can set default account codes and AMA flags for devices in 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								channel configuration files, like sip.conf, iax.conf etc.
							 
						 
					
						
							
								
									
										
										
										
											2004-01-19 02:30:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Fields of the CDR in Asterisk
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-----------------------------
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2006-01-10 08:52:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								   1. accountcode:	What account number to use, (string, 20 characters)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   2. src:		Caller*ID number (string, 80 characters)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   3. dst:		Destination extension (string, 80 characters)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   4. dcontext:		Destination context (string, 80 characters)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   5. clid:		Caller*ID with text (80 characters)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   6. channel:		Channel used (80 characters)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   7. dstchannel:	Destination channel if appropriate (80 characters)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   8. lastapp:		Last application if appropriate (80 characters)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   9. lastdata:		Last application data (arguments) (80 characters)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  10. start:		Start of call (date/time)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  11. answer:		Answer of call (date/time)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  12. end:		End of call (date/time)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  13. duration:		Total time in system, in seconds (integer), from dial to hangup
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  14. billsec:		Total time call is up, in seconds (integer), from answer to hangup
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  15. disposition:	What happened to the call: ANSWERED, NO ANSWER, BUSY
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  16. amaflags:		What flags to use: DOCUMENTATION, BILL, IGNORE etc, 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      			specified on a per channel basis like accountcode.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  17. user field:	A user-defined field, maximum 255 characters 
							 
						 
					
						
							
								
									
										
										
										
											2004-01-19 02:30:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								In some cases, uniqueid is appended:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2006-01-10 08:52:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    * uniqueid:		Unique Channel Identifier (32 characters) 
							 
						 
					
						
							
								
									
										
										
										
											2004-01-19 02:30:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      This needs to be enabled in the source code at compile time
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2001-10-18 15:27:19 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								ONE IMPORTANT NOTE: If you are trying to collect records on IAX to IAX calls
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								you need to be aware that by default, IAX will attempt to transfer calls
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								in this situation (if DTMF is not required).  When the transfer is completed
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the call is dumped from the middle machine and thus the call detail records
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								will report a short call time.  If you want detailed records you must
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								turn off IAX transfer, but unless your servers are very close together, you
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								will definitely get a latency hit from doing so.
							 
						 
					
						
							
								
									
										
										
										
											2004-01-19 02:30:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-02-23 22:48:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								____________________________________
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								CDR Variables
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								------------------------------------
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-05-15 23:32:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								If the channel has a cdr, that cdr record has its own set of variables which 
							 
						 
					
						
							
								
									
										
										
										
											2005-02-23 22:48:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								can be accessed just like channel variables. The following builtin variables
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								are available.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								${CDR(clid)}			Caller ID
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								${CDR(src)}			Source 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								${CDR(dst)}			Destination
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								${CDR(dcontext)}		Destination context
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								${CDR(channel)}			Channel name
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								${CDR(dstchannel)}		Destination channel
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								${CDR(lastapp)}			Last app executed
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								${CDR(lastdata)}		Last app's arguments
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								${CDR(start)}			Time the call started.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								${CDR(answer)}			Time the call was answered.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								${CDR(end)}			Time the call ended.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								${CDR(duration)}		Duration of the call.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								${CDR(billsec)}			Duration of the call once it was answered.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								${CDR(disposition)}		ANSWERED, NO ANSWER, BUSY
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								${CDR(amaflags)}		DOCUMENTATION, BILL, IGNORE etc
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								${CDR(accountcode)}		The channel's account code.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								${CDR(uniqueid)}		The channel's unique id.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								${CDR(userfield)}		The channels uses specified field.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-05-15 23:32:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								In addition, you can set your own extra variables by using Set(CDR(name)=value).
							 
						 
					
						
							
								
									
										
										
										
											2005-02-23 22:48:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								______________________________
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								cdr_csv2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								------------------------------
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This module is an experimental new cdr module to demonstrate the cdr vars.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								usage(
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*) Create a file called cdr.conf and place it in your /etc/asterisk (or wherever your config files are) in the [cdr_csv2] section.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*) Add an entry called format to indicate any format you want for the output.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The following format string will emulate the regular cdr file format:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[cdr_csv2]
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								format => "${CDR(clid)}","${CDR(src)}","${CDR(dst)}","${CDR(dcontext)}","${CDR(channel)}","${CDR(dstchannel)}","${CDR(lastapp)}","${CDR(lastdata)}","${CDR(start)}","${CDR(answer)}","${CDR(end)}","${CDR(duration)}","${CDR(billsec)}","${CDR(disposition)}","${CDR(amaflags)}","${CDR(accountcode)}","${CDR(uniqueid)}","${CDR(userfield)}"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2006-09-11 17:02:37 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								You can put anything you want as the value of format including new cdr vars you make up or any global variables.
							 
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:28:27 +00:00