2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								/*
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  Asterisk  - -  An  open  source  telephony  toolkit . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  Copyright  ( C )  2007 ,  Tilghman  Lesher 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  Tilghman  Lesher  < cdr_adaptive_odbc__v1 @ the - tilghman . com > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  See  http : //www.asterisk.org for more information about
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  the  Asterisk  project .  Please  do  not  directly  contact 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  any  of  the  maintainers  of  this  project  for  assistance ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  the  project  provides  a  web  site ,  mailing  lists  and  IRC 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  channels  for  your  use . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  This  program  is  free  software ,  distributed  under  the  terms  of 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  the  GNU  General  Public  License  Version  2.  See  the  LICENSE  file 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  at  the  top  of  the  source  tree . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-02-26 08:45:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								/*!
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  \ file 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								 *  \ brief  Adaptive  ODBC  CDR  backend 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 17:48:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								 *  \ author  Tilghman  Lesher  < cdr_adaptive_odbc__v1 @ the - tilghman . com > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  \ ingroup  cdr_drivers 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/*** MODULEINFO
  
						 
					
						
							
								
									
										
										
										
											2010-08-23 21:35:09 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									< depend > res_odbc < / depend > 
							 
						 
					
						
							
								
									
										
										
										
											2011-07-14 20:28:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									< support_level > core < / support_level > 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								 * * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  "asterisk.h" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								ASTERISK_FILE_VERSION ( __FILE__ ,  " $Revision$ " )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  <sys/types.h> 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  <time.h> 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  <sql.h> 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  <sqlext.h> 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  <sqltypes.h> 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  "asterisk/config.h" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  "asterisk/channel.h" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  "asterisk/lock.h" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  "asterisk/linkedlists.h" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  "asterisk/res_odbc.h" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  "asterisk/cdr.h" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  "asterisk/module.h" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# define	CONFIG	"cdr_adaptive_odbc.conf" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-02-26 08:45:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								static  const  char  name [ ]  =  " Adaptive ODBC " ;  
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								/* Optimization to reduce number of memory allocations */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  int  maxsize  =  512 ,  maxsize2  =  512 ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								struct  columns  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									char  * name ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									char  * cdrname ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-01-15 23:52:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									char  * filtervalue ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-14 22:36:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									char  * staticvalue ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									SQLSMALLINT  type ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									SQLINTEGER  size ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									SQLSMALLINT  decimals ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									SQLSMALLINT  radix ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									SQLSMALLINT  nullable ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									SQLINTEGER  octetlen ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									AST_LIST_ENTRY ( columns )  list ; 
							 
						 
					
						
							
								
									
										
										
										
											2010-12-31 09:29:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									unsigned  int  negatefiltervalue : 1 ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								} ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								struct  tables  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									char  * connection ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									char  * table ; 
							 
						 
					
						
							
								
									
										
										
										
											2012-02-03 16:50:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									char  * schema ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-09-11 21:45:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									unsigned  int  usegmtime : 1 ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									AST_LIST_HEAD_NOLOCK ( odbc_columns ,  columns )  columns ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									AST_RWLIST_ENTRY ( tables )  list ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								} ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  AST_RWLIST_HEAD_STATIC ( odbc_tables ,  tables ) ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  int  load_config ( void )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									struct  ast_config  * cfg ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									struct  ast_variable  * var ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									const  char  * tmp ,  * catg ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									struct  tables  * tableptr ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									struct  columns  * entry ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									struct  odbc_obj  * obj ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									char  columnname [ 80 ] ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									char  connection [ 40 ] ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									char  table [ 40 ] ; 
							 
						 
					
						
							
								
									
										
										
										
											2012-02-03 16:50:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									char  schema [ 40 ] ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									int  lenconnection ,  lentable ,  lenschema ,  usegmtime  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									SQLLEN  sqlptr ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									int  res  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									SQLHSTMT  stmt  =  NULL ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-08-16 21:09:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									struct  ast_flags  config_flags  =  {  0  } ;  /* Part of our config comes from the database */ 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-08-16 21:09:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									cfg  =  ast_config_load ( CONFIG ,  config_flags ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-19 19:25:14 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( ! cfg  | |  cfg  = =  CONFIG_STATUS_FILEINVALID )  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										ast_log ( LOG_WARNING ,  " Unable to load  "  CONFIG  " .  No adaptive ODBC CDRs. \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  - 1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( catg  =  ast_category_browse ( cfg ,  NULL ) ;  catg ;  catg  =  ast_category_browse ( cfg ,  catg ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										var  =  ast_variable_browse ( cfg ,  catg ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( ! var ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											continue ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( ast_strlen_zero ( tmp  =  ast_variable_retrieve ( cfg ,  catg ,  " connection " ) ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											ast_log ( LOG_WARNING ,  " No connection parameter found in '%s'.  Skipping. \n " ,  catg ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											continue ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ast_copy_string ( connection ,  tmp ,  sizeof ( connection ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										lenconnection  =  strlen ( connection ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-09-11 21:45:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if  ( ! ast_strlen_zero ( tmp  =  ast_variable_retrieve ( cfg ,  catg ,  " usegmtime " ) ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											usegmtime  =  ast_true ( tmp ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-05-21 02:05:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										/* When loading, we want to be sure we can connect. */ 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										obj  =  ast_odbc_request_obj ( connection ,  1 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( ! obj )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											ast_log ( LOG_WARNING ,  " No such connection '%s' in the '%s' section of  "  CONFIG  " .  Check res_odbc.conf. \n " ,  connection ,  catg ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											continue ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( ast_strlen_zero ( tmp  =  ast_variable_retrieve ( cfg ,  catg ,  " table " ) ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											ast_log ( LOG_NOTICE ,  " No table name found.  Assuming 'cdr'. \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											tmp  =  " cdr " ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ast_copy_string ( table ,  tmp ,  sizeof ( table ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										lentable  =  strlen ( table ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2012-02-03 16:50:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if  ( ast_strlen_zero ( tmp  =  ast_variable_retrieve ( cfg ,  catg ,  " schema " ) ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											tmp  =  " " ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ast_copy_string ( schema ,  tmp ,  sizeof ( schema ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										lenschema  =  strlen ( schema ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										res  =  SQLAllocHandle ( SQL_HANDLE_STMT ,  obj - > con ,  & stmt ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( ( res  ! =  SQL_SUCCESS )  & &  ( res  ! =  SQL_SUCCESS_WITH_INFO ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											ast_log ( LOG_WARNING ,  " SQL Alloc Handle failed on connection '%s'! \n " ,  connection ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											ast_odbc_release_obj ( obj ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											continue ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2012-02-03 16:50:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										res  =  SQLColumns ( stmt ,  NULL ,  0 ,  lenschema  = =  0  ?  NULL  :  ( unsigned  char  * ) schema ,  SQL_NTS ,  ( unsigned  char  * ) table ,  SQL_NTS ,  ( unsigned  char  * ) " % " ,  SQL_NTS ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										if  ( ( res  ! =  SQL_SUCCESS )  & &  ( res  ! =  SQL_SUCCESS_WITH_INFO ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											ast_log ( LOG_ERROR ,  " Unable to query database columns on connection '%s'.  Skipping. \n " ,  connection ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2012-02-03 16:50:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											SQLFreeHandle ( SQL_HANDLE_STMT ,  stmt ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
											ast_odbc_release_obj ( obj ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											continue ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2012-02-03 16:50:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										tableptr  =  ast_calloc ( sizeof ( char ) ,  sizeof ( * tableptr )  +  lenconnection  +  1  +  lentable  +  1  +  lenschema  +  1 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										if  ( ! tableptr )  { 
							 
						 
					
						
							
								
									
										
										
										
											2012-02-03 16:50:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											ast_log ( LOG_ERROR ,  " Out of memory creating entry for table '%s' on connection '%s'%s%s%s \n " ,  table ,  connection , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												lenschema  ?  "  (schema ' "  :  " " ,  lenschema  ?  schema  :  " " ,  lenschema  ?  " ') "  :  " " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SQLFreeHandle ( SQL_HANDLE_STMT ,  stmt ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
											ast_odbc_release_obj ( obj ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											res  =  - 1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-09-11 21:45:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										tableptr - > usegmtime  =  usegmtime ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										tableptr - > connection  =  ( char  * ) tableptr  +  sizeof ( * tableptr ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										tableptr - > table  =  ( char  * ) tableptr  +  sizeof ( * tableptr )  +  lenconnection  +  1 ; 
							 
						 
					
						
							
								
									
										
										
										
											2012-02-03 16:50:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										tableptr - > schema  =  ( char  * ) tableptr  +  sizeof ( * tableptr )  +  lenconnection  +  1  +  lentable  +  1 ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										ast_copy_string ( tableptr - > connection ,  connection ,  lenconnection  +  1 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ast_copy_string ( tableptr - > table ,  table ,  lentable  +  1 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2012-02-03 16:50:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										ast_copy_string ( tableptr - > schema ,  schema ,  lenschema  +  1 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-07-26 15:49:18 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										ast_verb ( 3 ,  " Found adaptive CDR table %s@%s. \n " ,  tableptr - > table ,  tableptr - > connection ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-21 02:05:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-01-17 00:13:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										/* Check for filters first */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										for  ( var  =  ast_variable_browse ( cfg ,  catg ) ;  var ;  var  =  var - > next )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( strncmp ( var - > name ,  " filter " ,  6 )  = =  0 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2010-12-31 09:29:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												int  negate  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-01-17 00:13:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												char  * cdrvar  =  ast_strdupa ( var - > name  +  6 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												cdrvar  =  ast_strip ( cdrvar ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2010-12-31 09:29:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												if  ( cdrvar [ strlen ( cdrvar )  -  1 ]  = =  ' ! ' )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													negate  =  1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													cdrvar [ strlen ( cdrvar )  -  1 ]  =  ' \0 ' ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													ast_trim_blanks ( cdrvar ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												ast_verb ( 3 ,  " Found filter %s'%s' for cdr variable %s in %s@%s \n " ,  negate  ?  " ! "  :  " " ,  var - > value ,  cdrvar ,  tableptr - > table ,  tableptr - > connection ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-01-17 00:13:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												entry  =  ast_calloc ( sizeof ( char ) ,  sizeof ( * entry )  +  strlen ( cdrvar )  +  1  +  strlen ( var - > value )  +  1 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												if  ( ! entry )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													ast_log ( LOG_ERROR ,  " Out of memory creating filter entry for CDR variable '%s' in table '%s' on connection '%s' \n " ,  cdrvar ,  table ,  connection ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													res  =  - 1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												/* NULL column entry means this isn't a column in the database */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												entry - > name  =  NULL ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												entry - > cdrname  =  ( char  * ) entry  +  sizeof ( * entry ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												entry - > filtervalue  =  ( char  * ) entry  +  sizeof ( * entry )  +  strlen ( cdrvar )  +  1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												strcpy ( entry - > cdrname ,  cdrvar ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												strcpy ( entry - > filtervalue ,  var - > value ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2010-12-31 09:29:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												entry - > negatefiltervalue  =  negate ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-01-17 00:13:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												AST_LIST_INSERT_TAIL ( & ( tableptr - > columns ) ,  entry ,  list ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										while  ( ( res  =  SQLFetch ( stmt ) )  ! =  SQL_NO_DATA  & &  res  ! =  SQL_ERROR )  { 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-14 22:36:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											char  * cdrvar  =  " " ,  * staticvalue  =  " " ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SQLGetData ( stmt ,   4 ,  SQL_C_CHAR ,  columnname ,  sizeof ( columnname ) ,  & sqlptr ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											/* Is there an alias for this column? */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											/* NOTE: This seems like a non-optimal parse method, but I'm going
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											 *  for  user  configuration  readability ,  rather  than  fast  parsing .  We 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											 *  really  don ' t  parse  this  file  all  that  often ,  anyway . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											for  ( var  =  ast_variable_browse ( cfg ,  catg ) ;  var ;  var  =  var - > next )  { 
							 
						 
					
						
							
								
									
										
										
										
											2008-01-15 23:52:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												if  ( strncmp ( var - > name ,  " alias " ,  5 )  = =  0  & &  strcasecmp ( var - > value ,  columnname )  = =  0 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2008-08-07 00:52:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													char  * alias  =  ast_strdupa ( var - > name  +  5 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													cdrvar  =  ast_strip ( alias ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-07-26 15:49:18 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													ast_verb ( 3 ,  " Found alias %s for column %s in %s@%s \n " ,  cdrvar ,  columnname ,  tableptr - > table ,  tableptr - > connection ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
													break ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-14 22:36:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												}  else  if  ( strncmp ( var - > name ,  " static " ,  6 )  = =  0  & &  strcasecmp ( var - > value ,  columnname )  = =  0 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													char  * item  =  ast_strdupa ( var - > name  +  6 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													item  =  ast_strip ( item ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													if  ( item [ 0 ]  = =  ' " '  & &  item [ strlen ( item )  -  1 ]  = =  ' " ' )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														/* Remove surrounding quotes */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														item [ strlen ( item )  -  1 ]  =  ' \0 ' ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														item + + ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													staticvalue  =  item ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
												} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
									
										
										
										
											2008-01-15 23:52:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-11-14 22:36:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											entry  =  ast_calloc ( sizeof ( char ) ,  sizeof ( * entry )  +  strlen ( columnname )  +  1  +  strlen ( cdrvar )  +  1  +  strlen ( staticvalue )  +  1 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
											if  ( ! entry )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												ast_log ( LOG_ERROR ,  " Out of memory creating entry for column '%s' in table '%s' on connection '%s' \n " ,  columnname ,  table ,  connection ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												res  =  - 1 ; 
							 
						 
					
						
							
								
									
										
										
										
											2012-02-03 16:50:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												SQLFreeHandle ( SQL_HANDLE_STMT ,  stmt ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
												break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											entry - > name  =  ( char  * ) entry  +  sizeof ( * entry ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											strcpy ( entry - > name ,  columnname ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( ! ast_strlen_zero ( cdrvar ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												entry - > cdrname  =  entry - > name  +  strlen ( columnname )  +  1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												strcpy ( entry - > cdrname ,  cdrvar ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-14 22:36:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											}  else  {  /* Point to same place as the column name */ 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
												entry - > cdrname  =  ( char  * ) entry  +  sizeof ( * entry ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-14 22:36:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( ! ast_strlen_zero ( staticvalue ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												entry - > staticvalue  =  entry - > cdrname  +  strlen ( entry - > cdrname )  +  1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												strcpy ( entry - > staticvalue ,  staticvalue ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SQLGetData ( stmt ,   5 ,  SQL_C_SHORT ,  & entry - > type ,  sizeof ( entry - > type ) ,  NULL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SQLGetData ( stmt ,   7 ,  SQL_C_LONG ,  & entry - > size ,  sizeof ( entry - > size ) ,  NULL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SQLGetData ( stmt ,   9 ,  SQL_C_SHORT ,  & entry - > decimals ,  sizeof ( entry - > decimals ) ,  NULL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SQLGetData ( stmt ,  10 ,  SQL_C_SHORT ,  & entry - > radix ,  sizeof ( entry - > radix ) ,  NULL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SQLGetData ( stmt ,  11 ,  SQL_C_SHORT ,  & entry - > nullable ,  sizeof ( entry - > nullable ) ,  NULL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SQLGetData ( stmt ,  16 ,  SQL_C_LONG ,  & entry - > octetlen ,  sizeof ( entry - > octetlen ) ,  NULL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-07-27 23:21:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											/* Specification states that the octenlen should be the maximum number of bytes
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											 *  returned  in  a  char  or  binary  column ,  but  it  seems  that  some  drivers  just  set 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											 *  it  to  NULL .  ( Bad  Postgres !  No  biscuit ! )  */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( entry - > octetlen  = =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												entry - > octetlen  =  entry - > size ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-07-30 15:22:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											ast_verb ( 10 ,  " Found %s column with type %hd with len %ld, octetlen %ld, and numlen (%hd,%hd) \n " ,  entry - > name ,  entry - > type ,  ( long )  entry - > size ,  ( long )  entry - > octetlen ,  entry - > decimals ,  entry - > radix ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
											/* Insert column info into column list */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											AST_LIST_INSERT_TAIL ( & ( tableptr - > columns ) ,  entry ,  list ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											res  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-05-24 03:27:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										SQLFreeHandle ( SQL_HANDLE_STMT ,  stmt ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										ast_odbc_release_obj ( obj ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( AST_LIST_FIRST ( & ( tableptr - > columns ) ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											AST_RWLIST_INSERT_TAIL ( & odbc_tables ,  tableptr ,  list ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										else 
							 
						 
					
						
							
								
									
										
										
										
											2007-06-06 21:20:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											ast_free ( tableptr ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2012-03-28 19:39:24 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									ast_config_destroy ( cfg ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									return  res ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  int  free_config ( void )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									struct  tables  * table ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									struct  columns  * entry ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									while  ( ( table  =  AST_RWLIST_REMOVE_HEAD ( & odbc_tables ,  list ) ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										while  ( ( entry  =  AST_LIST_REMOVE_HEAD ( & ( table - > columns ) ,  list ) ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											ast_free ( entry ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ast_free ( table ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  SQLHSTMT  generic_prepare ( struct  odbc_obj  * obj ,  void  * data )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									int  res ,  i ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									SQLHSTMT  stmt ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									SQLINTEGER  nativeerror  =  0 ,  numfields  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									SQLSMALLINT  diagbytes  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									unsigned  char  state [ 10 ] ,  diagnostic [ 256 ] ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									res  =  SQLAllocHandle  ( SQL_HANDLE_STMT ,  obj - > con ,  & stmt ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( ( res  ! =  SQL_SUCCESS )  & &  ( res  ! =  SQL_SUCCESS_WITH_INFO ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ast_log ( LOG_WARNING ,  " SQL Alloc Handle failed! \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  NULL ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-05-21 21:13:09 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									res  =  SQLPrepare ( stmt ,  ( unsigned  char  * )  data ,  SQL_NTS ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									if  ( ( res  ! =  SQL_SUCCESS )  & &  ( res  ! =  SQL_SUCCESS_WITH_INFO ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2009-05-21 21:13:09 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										ast_log ( LOG_WARNING ,  " SQL Prepare failed![%s] \n " ,  ( char  * )  data ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										SQLGetDiagField ( SQL_HANDLE_STMT ,  stmt ,  1 ,  SQL_DIAG_NUMBER ,  & numfields ,  SQL_IS_INTEGER ,  & diagbytes ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										for  ( i  =  0 ;  i  <  numfields ;  i + + )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SQLGetDiagRec ( SQL_HANDLE_STMT ,  stmt ,  i  +  1 ,  state ,  & nativeerror ,  diagnostic ,  sizeof ( diagnostic ) ,  & diagbytes ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											ast_log ( LOG_WARNING ,  " SQL Execute returned an error %d: %s: %s (%d) \n " ,  res ,  state ,  diagnostic ,  diagbytes ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( i  >  10 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												ast_log ( LOG_WARNING ,  " Oh, that was good.  There are really %d diagnostics? \n " ,  ( int ) numfields ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										SQLFreeHandle  ( SQL_HANDLE_STMT ,  stmt ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  NULL ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  stmt ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# define LENGTHEN_BUF1(size)														\ 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											do  { 																\
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												/* Lengthen buffer, if necessary */ 								\
							 
						 
					
						
							
								
									
										
										
										
											2009-12-30 17:53:29 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												if  ( ast_str_strlen ( sql )  +  size  +  1  >  ast_str_size ( sql ) )  { 		\
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													if  ( ast_str_make_space ( & sql ,  ( ( ast_str_size ( sql )  +  size  +  1 )  /  512  +  1 )  *  512 )  ! =  0 )  {  \
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														ast_log ( LOG_ERROR ,  " Unable to allocate sufficient memory.  Insert CDR '%s:%s' failed. \n " ,  tableptr - > connection ,  tableptr - > table ) ;  \
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														ast_free ( sql ) ; 											\
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														ast_free ( sql2 ) ; 											\
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														AST_RWLIST_UNLOCK ( & odbc_tables ) ; 						\
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														return  - 1 ; 												\
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													} 															\
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												} 																\
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											}  while  ( 0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# define LENGTHEN_BUF2(size)														\ 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											do  { 																\
							 
						 
					
						
							
								
									
										
										
										
											2009-12-30 17:53:29 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												if  ( ast_str_strlen ( sql2 )  +  size  +  1  >  ast_str_size ( sql2 ) )  { 		\
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													if  ( ast_str_make_space ( & sql2 ,  ( ( ast_str_size ( sql2 )  +  size  +  3 )  /  512  +  1 )  *  512 )  ! =  0 )  {  \
							 
						 
					
						
							
								
									
										
										
										
											2008-02-29 23:53:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														ast_log ( LOG_ERROR ,  " Unable to allocate sufficient memory.  Insert CDR '%s:%s' failed. \n " ,  tableptr - > connection ,  tableptr - > table ) ;  \
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														ast_free ( sql ) ; 											\
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														ast_free ( sql2 ) ; 											\
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														AST_RWLIST_UNLOCK ( & odbc_tables ) ; 						\
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														return  - 1 ; 												\
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													} 															\
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												} 																\
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											}  while  ( 0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  int  odbc_log ( struct  ast_cdr  * cdr )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									struct  tables  * tableptr ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									struct  columns  * entry ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									struct  odbc_obj  * obj ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-02-29 23:53:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									struct  ast_str  * sql  =  ast_str_create ( maxsize ) ,  * sql2  =  ast_str_create ( maxsize2 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									char  * tmp ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									char  colbuf [ 1024 ] ,  * colptr ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									SQLHSTMT  stmt  =  NULL ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-22 02:41:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									SQLLEN  rows  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-11-01 05:44:40 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( ! sql  | |  ! sql2 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( sql ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											ast_free ( sql ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( sql2 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											ast_free ( sql2 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  - 1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									if  ( AST_RWLIST_RDLOCK ( & odbc_tables ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ast_log ( LOG_ERROR ,  " Unable to lock table list.  Insert CDR(s) failed. \n " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-11-01 05:44:40 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										ast_free ( sql ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ast_free ( sql2 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										return  - 1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									AST_LIST_TRAVERSE ( & odbc_tables ,  tableptr ,  list )  { 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										int  first  =  1 ; 
							 
						 
					
						
							
								
									
										
										
										
											2012-02-03 16:50:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if  ( ast_strlen_zero ( tableptr - > schema ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											ast_str_set ( & sql ,  0 ,  " INSERT INTO %s ( " ,  tableptr - > table ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										}  else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											ast_str_set ( & sql ,  0 ,  " INSERT INTO %s.%s ( " ,  tableptr - > schema ,  tableptr - > table ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2008-02-29 23:53:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										ast_str_set ( & sql2 ,  0 ,  "  VALUES ( " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-12-13 17:46:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										/* No need to check the connection now; we'll handle any failure in prepare_and_execute */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( ! ( obj  =  ast_odbc_request_obj ( tableptr - > connection ,  0 ) ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											ast_log ( LOG_WARNING ,  " cdr_adaptive_odbc: Unable to retrieve database handle for '%s:%s'.  CDR failed: %s \n " ,  tableptr - > connection ,  tableptr - > table ,  ast_str_buffer ( sql ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-12-13 17:46:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											continue ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										AST_LIST_TRAVERSE ( & ( tableptr - > columns ) ,  entry ,  list )  { 
							 
						 
					
						
							
								
									
										
										
										
											2008-09-11 21:45:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											int  datefield  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( strcasecmp ( entry - > cdrname ,  " start " )  = =  0 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												datefield  =  1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											}  else  if  ( strcasecmp ( entry - > cdrname ,  " answer " )  = =  0 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												datefield  =  2 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											}  else  if  ( strcasecmp ( entry - > cdrname ,  " end " )  = =  0 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												datefield  =  3 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
											/* Check if we have a similarly named variable */ 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-14 22:36:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											if  ( entry - > staticvalue )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												colptr  =  ast_strdupa ( entry - > staticvalue ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											}  else  if  ( datefield  & &  tableptr - > usegmtime )  { 
							 
						 
					
						
							
								
									
										
										
										
											2008-10-08 12:15:06 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												struct  timeval  date_tv  =  ( datefield  = =  1 )  ?  cdr - > start  :  ( datefield  = =  2 )  ?  cdr - > answer  :  cdr - > end ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-09-11 21:45:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												struct  ast_tm  tm  =  {  0 ,  } ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-10-08 12:15:06 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												ast_localtime ( & date_tv ,  & tm ,  " UTC " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-09-11 21:45:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												ast_strftime ( colbuf ,  sizeof ( colbuf ) ,  " %Y-%m-%d %H:%M:%S " ,  & tm ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-14 22:36:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												colptr  =  colbuf ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-09-11 21:45:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											}  else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												ast_cdr_getvar ( cdr ,  entry - > cdrname ,  & colptr ,  colbuf ,  sizeof ( colbuf ) ,  0 ,  datefield  ?  0  :  1 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( colptr )  { 
							 
						 
					
						
							
								
									
										
										
										
											2008-01-15 23:52:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												/* Check first if the column filters this entry.  Note that this
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												 *  is  very  specifically  NOT  ast_strlen_zero ( ) ,  because  the  filter 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												 *  could  legitimately  specify  that  the  field  is  blank ,  which  is 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												 *  different  from  the  field  being  unspecified  ( NULL ) .  */ 
							 
						 
					
						
							
								
									
										
										
										
											2010-12-31 09:29:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												if  ( ( entry - > filtervalue  & &  ! entry - > negatefiltervalue  & &  strcasecmp ( colptr ,  entry - > filtervalue )  ! =  0 )  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													( entry - > filtervalue  & &  entry - > negatefiltervalue  & &  strcasecmp ( colptr ,  entry - > filtervalue )  = =  0 ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2008-01-15 23:52:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													ast_verb ( 4 ,  " CDR column '%s' with value '%s' does not match filter of " 
							 
						 
					
						
							
								
									
										
										
										
											2010-12-31 09:29:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														"  %s'%s'.  Cancelling this CDR. \n " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														entry - > cdrname ,  colptr ,  entry - > negatefiltervalue  ?  " ! "  :  " " ,  entry - > filtervalue ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-01-15 23:52:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													goto  early_release ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-01-17 00:13:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												/* Only a filter? */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												if  ( ast_strlen_zero ( entry - > name ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													continue ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
												LENGTHEN_BUF1 ( strlen ( entry - > name ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												switch  ( entry - > type )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_CHAR : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_VARCHAR : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_LONGVARCHAR : 
							 
						 
					
						
							
								
									
										
										
										
											2012-03-07 15:08:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# ifdef HAVE_ODBC_WCHAR 
  
						 
					
						
							
								
									
										
										
										
											2012-02-28 22:01:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												case  SQL_WCHAR : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_WVARCHAR : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_WLONGVARCHAR : 
							 
						 
					
						
							
								
									
										
										
										
											2012-03-07 15:08:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# endif 
  
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
												case  SQL_BINARY : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_VARBINARY : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_LONGVARBINARY : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_GUID : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													/* For these two field names, get the rendered form, instead of the raw
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													 *  form  ( but  only  when  we ' re  dealing  with  a  character - based  field ) . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													 */ 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-14 22:36:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													if  ( strcasecmp ( entry - > name ,  " disposition " )  = =  0 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														ast_cdr_getvar ( cdr ,  entry - > name ,  & colptr ,  colbuf ,  sizeof ( colbuf ) ,  0 ,  0 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-14 22:36:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													}  else  if  ( strcasecmp ( entry - > name ,  " amaflags " )  = =  0 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														ast_cdr_getvar ( cdr ,  entry - > name ,  & colptr ,  colbuf ,  sizeof ( colbuf ) ,  0 ,  0 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-14 22:36:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													} 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													/* Truncate too-long fields */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													if  ( entry - > type  ! =  SQL_GUID )  { 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-14 22:36:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														if  ( strlen ( colptr )  >  entry - > octetlen )  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
															colptr [ entry - > octetlen ]  =  ' \0 ' ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-14 22:36:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														} 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
													} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													ast_str_append ( & sql ,  0 ,  " %s%s " ,  first  ?  " "  :  " , " ,  entry - > name ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
													LENGTHEN_BUF2 ( strlen ( colptr ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													/* Encode value, with escaping */ 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													ast_str_append ( & sql2 ,  0 ,  " %s' " ,  first  ?  " "  :  " , " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
													for  ( tmp  =  colptr ;  * tmp ;  tmp + + )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														if  ( * tmp  = =  ' \' ' )  { 
							 
						 
					
						
							
								
									
										
										
										
											2008-02-29 23:53:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
															ast_str_append ( & sql2 ,  0 ,  " '' " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-12-13 17:46:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														}  else  if  ( * tmp  = =  ' \\ '  & &  ast_odbc_backslash_is_escape ( obj ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2008-02-29 23:53:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
															ast_str_append ( & sql2 ,  0 ,  " \\ \\ " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														}  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2008-02-29 23:53:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
															ast_str_append ( & sql2 ,  0 ,  " %c " ,  * tmp ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													} 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													ast_str_append ( & sql2 ,  0 ,  " ' " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
													break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_TYPE_DATE : 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-30 17:53:29 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													if  ( ast_strlen_zero ( colptr ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														continue ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													}  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														int  year  =  0 ,  month  =  0 ,  day  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-08-10 19:20:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														if  ( sscanf ( colptr ,  " %4d-%2d-%2d " ,  & year ,  & month ,  & day )  ! =  3  | |  year  < =  0  | | 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
															month  < =  0  | |  month  >  12  | |  day  <  0  | |  day  >  31  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															( ( month  = =  4  | |  month  = =  6  | |  month  = =  9  | |  month  = =  11 )  & &  day  = =  31 )  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															( month  = =  2  & &  year  %  400  = =  0  & &  day  >  29 )  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															( month  = =  2  & &  year  %  100  = =  0  & &  day  >  28 )  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															( month  = =  2  & &  year  %  4  = =  0  & &  day  >  29 )  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															( month  = =  2  & &  year  %  4  ! =  0  & &  day  >  28 ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															ast_log ( LOG_WARNING ,  " CDR variable %s is not a valid date ('%s'). \n " ,  entry - > name ,  colptr ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
															continue ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-11-14 22:36:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														if  ( year  >  0  & &  year  <  100 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
															year  + =  2000 ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-14 22:36:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														} 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														ast_str_append ( & sql ,  0 ,  " %s%s " ,  first  ?  " "  :  " , " ,  entry - > name ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-01-11 18:35:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														LENGTHEN_BUF2 ( 17 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														ast_str_append ( & sql2 ,  0 ,  " %s{ d '%04d-%02d-%02d' } " ,  first  ?  " "  :  " , " ,  year ,  month ,  day ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
													} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_TYPE_TIME : 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-30 17:53:29 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													if  ( ast_strlen_zero ( colptr ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														continue ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													}  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														int  hour  =  0 ,  minute  =  0 ,  second  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-08-10 19:20:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														int  count  =  sscanf ( colptr ,  " %2d:%2d:%2d " ,  & hour ,  & minute ,  & second ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														if  ( ( count  ! =  2  & &  count  ! =  3 )  | |  hour  <  0  | |  hour  >  23  | |  minute  <  0  | |  minute  >  59  | |  second  <  0  | |  second  >  59 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															ast_log ( LOG_WARNING ,  " CDR variable %s is not a valid time ('%s'). \n " ,  entry - > name ,  colptr ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
															continue ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														ast_str_append ( & sql ,  0 ,  " %s%s " ,  first  ?  " "  :  " , " ,  entry - > name ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-01-11 18:35:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														LENGTHEN_BUF2 ( 15 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														ast_str_append ( & sql2 ,  0 ,  " %s{ t '%02d:%02d:%02d' } " ,  first  ?  " "  :  " , " ,  hour ,  minute ,  second ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
													} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_TYPE_TIMESTAMP : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_TIMESTAMP : 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-30 17:53:29 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													if  ( ast_strlen_zero ( colptr ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														continue ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													}  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														int  year  =  0 ,  month  =  0 ,  day  =  0 ,  hour  =  0 ,  minute  =  0 ,  second  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-08-10 19:20:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														int  count  =  sscanf ( colptr ,  " %4d-%2d-%2d %2d:%2d:%2d " ,  & year ,  & month ,  & day ,  & hour ,  & minute ,  & second ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														if  ( ( count  ! =  3  & &  count  ! =  5  & &  count  ! =  6 )  | |  year  < =  0  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															month  < =  0  | |  month  >  12  | |  day  <  0  | |  day  >  31  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															( ( month  = =  4  | |  month  = =  6  | |  month  = =  9  | |  month  = =  11 )  & &  day  = =  31 )  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															( month  = =  2  & &  year  %  400  = =  0  & &  day  >  29 )  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															( month  = =  2  & &  year  %  100  = =  0  & &  day  >  28 )  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															( month  = =  2  & &  year  %  4  = =  0  & &  day  >  29 )  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															( month  = =  2  & &  year  %  4  ! =  0  & &  day  >  28 )  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															hour  >  23  | |  minute  >  59  | |  second  >  59  | |  hour  <  0  | |  minute  <  0  | |  second  <  0 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															ast_log ( LOG_WARNING ,  " CDR variable %s is not a valid timestamp ('%s'). \n " ,  entry - > name ,  colptr ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
															continue ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-11-14 22:36:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														if  ( year  >  0  & &  year  <  100 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
															year  + =  2000 ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-14 22:36:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														} 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														ast_str_append ( & sql ,  0 ,  " %s%s " ,  first  ?  " "  :  " , " ,  entry - > name ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-01-11 18:35:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														LENGTHEN_BUF2 ( 26 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														ast_str_append ( & sql2 ,  0 ,  " %s{ ts '%04d-%02d-%02d %02d:%02d:%02d' } " ,  first  ?  " "  :  " , " ,  year ,  month ,  day ,  hour ,  minute ,  second ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
													} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_INTEGER : 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-30 17:53:29 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													if  ( ast_strlen_zero ( colptr ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														continue ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													}  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														int  integer  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-08-10 19:20:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														if  ( sscanf ( colptr ,  " %30d " ,  & integer )  ! =  1 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
															ast_log ( LOG_WARNING ,  " CDR variable %s is not an integer. \n " ,  entry - > name ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
															continue ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														ast_str_append ( & sql ,  0 ,  " %s%s " ,  first  ?  " "  :  " , " ,  entry - > name ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														LENGTHEN_BUF2 ( 12 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														ast_str_append ( & sql2 ,  0 ,  " %s%d " ,  first  ?  " "  :  " , " ,  integer ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
													} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_BIGINT : 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-30 17:53:29 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													if  ( ast_strlen_zero ( colptr ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														continue ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													}  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														long  long  integer  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-08-10 19:20:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														if  ( sscanf ( colptr ,  " %30lld " ,  & integer )  ! =  1 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
															ast_log ( LOG_WARNING ,  " CDR variable %s is not an integer. \n " ,  entry - > name ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
															continue ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														ast_str_append ( & sql ,  0 ,  " %s%s " ,  first  ?  " "  :  " , " ,  entry - > name ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														LENGTHEN_BUF2 ( 24 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														ast_str_append ( & sql2 ,  0 ,  " %s%lld " ,  first  ?  " "  :  " , " ,  integer ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
													} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_SMALLINT : 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-30 17:53:29 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													if  ( ast_strlen_zero ( colptr ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														continue ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													}  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														short  integer  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-08-10 19:20:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														if  ( sscanf ( colptr ,  " %30hd " ,  & integer )  ! =  1 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
															ast_log ( LOG_WARNING ,  " CDR variable %s is not an integer. \n " ,  entry - > name ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
															continue ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														ast_str_append ( & sql ,  0 ,  " %s%s " ,  first  ?  " "  :  " , " ,  entry - > name ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														LENGTHEN_BUF2 ( 6 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														ast_str_append ( & sql2 ,  0 ,  " %s%d " ,  first  ?  " "  :  " , " ,  integer ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
													} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_TINYINT : 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-30 17:53:29 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													if  ( ast_strlen_zero ( colptr ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														continue ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													}  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														char  integer  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-08-10 19:20:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														if  ( sscanf ( colptr ,  " %30hhd " ,  & integer )  ! =  1 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
															ast_log ( LOG_WARNING ,  " CDR variable %s is not an integer. \n " ,  entry - > name ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
															continue ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														ast_str_append ( & sql ,  0 ,  " %s%s " ,  first  ?  " "  :  " , " ,  entry - > name ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														LENGTHEN_BUF2 ( 4 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														ast_str_append ( & sql2 ,  0 ,  " %s%d " ,  first  ?  " "  :  " , " ,  integer ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
													} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_BIT : 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-30 17:53:29 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													if  ( ast_strlen_zero ( colptr ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														continue ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													}  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														char  integer  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-08-10 19:20:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														if  ( sscanf ( colptr ,  " %30hhd " ,  & integer )  ! =  1 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
															ast_log ( LOG_WARNING ,  " CDR variable %s is not an integer. \n " ,  entry - > name ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
															continue ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														if  ( integer  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															integer  =  1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														ast_str_append ( & sql ,  0 ,  " %s%s " ,  first  ?  " "  :  " , " ,  entry - > name ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														LENGTHEN_BUF2 ( 2 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														ast_str_append ( & sql2 ,  0 ,  " %s%d " ,  first  ?  " "  :  " , " ,  integer ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
													} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_NUMERIC : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_DECIMAL : 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-30 17:53:29 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													if  ( ast_strlen_zero ( colptr ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														continue ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													}  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														double  number  =  0.0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2010-06-08 23:48:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														if  ( ! strcasecmp ( entry - > cdrname ,  " billsec " ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															if  ( ! ast_tvzero ( cdr - > answer ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
																snprintf ( colbuf ,  sizeof ( colbuf ) ,  " %lf " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
																			( double )  ( ast_tvdiff_us ( cdr - > end ,  cdr - > answer )  /  1000000.0 ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															}  else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
																ast_copy_string ( colbuf ,  " 0 " ,  sizeof ( colbuf ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														}  else  if  ( ! strcasecmp ( entry - > cdrname ,  " duration " ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															snprintf ( colbuf ,  sizeof ( colbuf ) ,  " %lf " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
																		( double )  ( ast_tvdiff_us ( cdr - > end ,  cdr - > start )  /  1000000.0 ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															if  ( ! ast_strlen_zero ( colbuf ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
																colptr  =  colbuf ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-08-10 19:20:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														if  ( sscanf ( colptr ,  " %30lf " ,  & number )  ! =  1 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
															ast_log ( LOG_WARNING ,  " CDR variable %s is not an numeric type. \n " ,  entry - > name ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
															continue ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														ast_str_append ( & sql ,  0 ,  " %s%s " ,  first  ?  " "  :  " , " ,  entry - > name ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														LENGTHEN_BUF2 ( entry - > decimals ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														ast_str_append ( & sql2 ,  0 ,  " %s%*.*lf " ,  first  ?  " "  :  " , " ,  entry - > decimals ,  entry - > radix ,  number ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
													} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_FLOAT : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_REAL : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												case  SQL_DOUBLE : 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-30 17:53:29 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													if  ( ast_strlen_zero ( colptr ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														continue ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													}  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														double  number  =  0.0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2010-06-08 23:48:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														if  ( ! strcasecmp ( entry - > cdrname ,  " billsec " ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															if  ( ! ast_tvzero ( cdr - > answer ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
																snprintf ( colbuf ,  sizeof ( colbuf ) ,  " %lf " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
																			( double )  ( ast_tvdiff_us ( cdr - > end ,  cdr - > answer )  /  1000000.0 ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															}  else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
																ast_copy_string ( colbuf ,  " 0 " ,  sizeof ( colbuf ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														}  else  if  ( ! strcasecmp ( entry - > cdrname ,  " duration " ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															snprintf ( colbuf ,  sizeof ( colbuf ) ,  " %lf " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
																		( double )  ( ast_tvdiff_us ( cdr - > end ,  cdr - > start )  /  1000000.0 ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															if  ( ! ast_strlen_zero ( colbuf ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
																colptr  =  colbuf ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-08-10 19:20:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														if  ( sscanf ( colptr ,  " %30lf " ,  & number )  ! =  1 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
															ast_log ( LOG_WARNING ,  " CDR variable %s is not an numeric type. \n " ,  entry - > name ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
															continue ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														ast_str_append ( & sql ,  0 ,  " %s%s " ,  first  ?  " "  :  " , " ,  entry - > name ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
														LENGTHEN_BUF2 ( entry - > decimals ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														ast_str_append ( & sql2 ,  0 ,  " %s%lf " ,  first  ?  " "  :  " , " ,  number ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
													} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												default : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													ast_log ( LOG_WARNING ,  " Column type %d (field '%s:%s:%s') is unsupported at this time. \n " ,  entry - > type ,  tableptr - > connection ,  tableptr - > table ,  entry - > name ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													continue ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
												} 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												first  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* Concatenate the two constructed buffers */ 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										LENGTHEN_BUF1 ( ast_str_strlen ( sql2 ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ast_str_append ( & sql ,  0 ,  " ) " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ast_str_append ( & sql2 ,  0 ,  " ) " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ast_str_append ( & sql ,  0 ,  " %s " ,  ast_str_buffer ( sql2 ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										ast_verb ( 11 ,  " [%s] \n " ,  ast_str_buffer ( sql ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-12-13 17:46:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										stmt  =  ast_odbc_prepare_and_execute ( obj ,  generic_prepare ,  ast_str_buffer ( sql ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-12-13 17:46:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if  ( stmt )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SQLRowCount ( stmt ,  & rows ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SQLFreeHandle ( SQL_HANDLE_STMT ,  stmt ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( rows  = =  0 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											ast_log ( LOG_WARNING ,  " cdr_adaptive_odbc: Insert failed on '%s:%s'.  CDR failed: %s \n " ,  tableptr - > connection ,  tableptr - > table ,  ast_str_buffer ( sql ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2008-01-15 23:52:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								early_release :  
						 
					
						
							
								
									
										
										
										
											2007-12-13 17:46:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										ast_odbc_release_obj ( obj ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									AST_RWLIST_UNLOCK ( & odbc_tables ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Next time, just allocate buffers that are that big to start with. */ 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( ast_str_strlen ( sql )  >  maxsize )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										maxsize  =  ast_str_strlen ( sql ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-14 22:36:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-13 08:36:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( ast_str_strlen ( sql2 )  >  maxsize2 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										maxsize2  =  ast_str_strlen ( sql2 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-14 22:36:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ast_free ( sql ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ast_free ( sql2 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  int  unload_module ( void )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ast_cdr_unregister ( name ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( AST_RWLIST_WRLOCK ( & odbc_tables ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ast_cdr_register ( name ,  ast_module_info - > description ,  odbc_log ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ast_log ( LOG_ERROR ,  " Unable to lock column list.  Unload failed. \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  - 1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									free_config ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									AST_RWLIST_UNLOCK ( & odbc_tables ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  int  load_module ( void )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( AST_RWLIST_WRLOCK ( & odbc_tables ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ast_log ( LOG_ERROR ,  " Unable to lock column list.  Load failed. \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									load_config ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									AST_RWLIST_UNLOCK ( & odbc_tables ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ast_cdr_register ( name ,  ast_module_info - > description ,  odbc_log ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  int  reload ( void )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( AST_RWLIST_WRLOCK ( & odbc_tables ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ast_log ( LOG_ERROR ,  " Unable to lock column list.  Reload failed. \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  - 1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									free_config ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									load_config ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									AST_RWLIST_UNLOCK ( & odbc_tables ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-07-20 19:35:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								AST_MODULE_INFO ( ASTERISK_GPL_KEY ,  AST_MODFLAG_LOAD_ORDER ,  " Adaptive ODBC CDR backend " ,  
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									. load  =  load_module , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									. unload  =  unload_module , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									. reload  =  reload , 
							 
						 
					
						
							
								
									
										
										
										
											2010-07-20 19:35:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									. load_pri  =  AST_MODPRI_CDR_DRIVER , 
							 
						 
					
						
							
								
									
										
										
										
											2007-05-18 20:21:11 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								) ;