Add peercontext parameter for default outbound context (bug #1929)
[asterisk/asterisk.git] / cdr / cdr_odbc.c
index c9209a3..acd2327 100755 (executable)
@@ -41,7 +41,7 @@ static char *dsn = NULL, *username = NULL, *password = NULL, *loguniqueid = NULL
 static int dsn_alloc = 0, username_alloc = 0, password_alloc = 0, loguniqueid_alloc = 0;
 static int connected = 0;
 
-static ast_mutex_t odbc_lock = AST_MUTEX_INITIALIZER;
+AST_MUTEX_DEFINE_STATIC(odbc_lock);
 
 static int odbc_do_query(void);
 static int odbc_init(void);
@@ -73,8 +73,8 @@ static int odbc_log(struct ast_cdr *cdr)
        {
                sprintf(sqlcmd,"INSERT INTO cdr "
                "(calldate,clid,src,dst,dcontext,channel,dstchannel,lastapp,"
-               "lastdata,duration,billsec,disposition,amaflags,accountcode,uniqueid) "
-               "VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)");
+               "lastdata,duration,billsec,disposition,amaflags,accountcode,uniqueid,userfield) "
+               "VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)");
        }
        else
        {
@@ -100,7 +100,7 @@ static int odbc_log(struct ast_cdr *cdr)
 
        if((ODBC_res != SQL_SUCCESS) && (ODBC_res != SQL_SUCCESS_WITH_INFO))
        {
-               if(option_verbose > 3)
+               if(option_verbose > 10)
                        ast_verbose( VERBOSE_PREFIX_4 "cdr_odbc: Failure in AllocStatement %d\n", ODBC_res);
                SQLGetDiagRec(SQL_HANDLE_DBC, ODBC_con, 1, ODBC_stat, &ODBC_err, ODBC_msg, 100, &ODBC_mlen);
                SQLFreeHandle(SQL_HANDLE_STMT, ODBC_stmt);      
@@ -117,7 +117,7 @@ static int odbc_log(struct ast_cdr *cdr)
        
        if((ODBC_res != SQL_SUCCESS) && (ODBC_res != SQL_SUCCESS_WITH_INFO))
        {
-               if(option_verbose > 3)
+               if(option_verbose > 10)
                        ast_verbose( VERBOSE_PREFIX_4 "cdr_odbc: Error in PREPARE %d\n", ODBC_res);
                SQLGetDiagRec(SQL_HANDLE_DBC, ODBC_con, 1, ODBC_stat, &ODBC_err, ODBC_msg, 100, &ODBC_mlen);
                SQLFreeHandle(SQL_HANDLE_STMT, ODBC_stmt);
@@ -126,24 +126,25 @@ static int odbc_log(struct ast_cdr *cdr)
                return 0;
        }
 
-       SQLBindParameter(ODBC_stmt, 1, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, 0, 0, &timestr, 0, NULL);
-       SQLBindParameter(ODBC_stmt, 2, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, 0, 0, cdr->clid, 0, NULL);
-       SQLBindParameter(ODBC_stmt, 3, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, 0, 0, cdr->src, 0, NULL);
-       SQLBindParameter(ODBC_stmt, 4, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, 0, 0, cdr->dst, 0, NULL);
-       SQLBindParameter(ODBC_stmt, 5, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, 0, 0, cdr->dcontext, 0, NULL);
-       SQLBindParameter(ODBC_stmt, 6, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, 0, 0, cdr->channel, 0, NULL);
-       SQLBindParameter(ODBC_stmt, 7, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, 0, 0, cdr->dstchannel, 0, NULL);
-       SQLBindParameter(ODBC_stmt, 8, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, 0, 0, cdr->lastapp, 0, NULL);
-       SQLBindParameter(ODBC_stmt, 9, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, 0, 0, cdr->lastdata, 0, NULL);
-       SQLBindParameter(ODBC_stmt, 10, SQL_PARAM_INPUT, SQL_C_SSHORT, SQL_INTEGER, 0, 0, &cdr->duration, 0, NULL);
-       SQLBindParameter(ODBC_stmt, 11, SQL_PARAM_INPUT, SQL_C_SSHORT, SQL_INTEGER, 0, 0, &cdr->billsec, 0, NULL);
-       SQLBindParameter(ODBC_stmt, 12, SQL_PARAM_INPUT, SQL_C_SSHORT, SQL_INTEGER, 0, 0, &cdr->disposition, 0, NULL);
-       SQLBindParameter(ODBC_stmt, 13, SQL_PARAM_INPUT, SQL_C_SSHORT, SQL_INTEGER, 0, 0, &cdr->amaflags, 0, NULL);
-       SQLBindParameter(ODBC_stmt, 14, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, 0, 0, cdr->accountcode, 0, NULL);
+       SQLBindParameter(ODBC_stmt, 1, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, sizeof(timestr), 0, &timestr, 0, NULL);
+       SQLBindParameter(ODBC_stmt, 2, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, sizeof(cdr->clid), 0, cdr->clid, 0, NULL);
+       SQLBindParameter(ODBC_stmt, 3, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, sizeof(cdr->src), 0, cdr->src, 0, NULL);
+       SQLBindParameter(ODBC_stmt, 4, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, sizeof(cdr->dst), 0, cdr->dst, 0, NULL);
+       SQLBindParameter(ODBC_stmt, 5, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, sizeof(cdr->dcontext), 0, cdr->dcontext, 0, NULL);
+       SQLBindParameter(ODBC_stmt, 6, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, sizeof(cdr->channel), 0, cdr->channel, 0, NULL);
+       SQLBindParameter(ODBC_stmt, 7, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, sizeof(cdr->dstchannel), 0, cdr->dstchannel, 0, NULL);
+       SQLBindParameter(ODBC_stmt, 8, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, sizeof(cdr->lastapp), 0, cdr->lastapp, 0, NULL);
+       SQLBindParameter(ODBC_stmt, 9, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, sizeof(cdr->lastdata), 0, cdr->lastdata, 0, NULL);
+       SQLBindParameter(ODBC_stmt, 10, SQL_PARAM_INPUT, SQL_C_SLONG, SQL_INTEGER, 0, 0, &cdr->duration, 0, NULL);
+       SQLBindParameter(ODBC_stmt, 11, SQL_PARAM_INPUT, SQL_C_SLONG, SQL_INTEGER, 0, 0, &cdr->billsec, 0, NULL);
+       SQLBindParameter(ODBC_stmt, 12, SQL_PARAM_INPUT, SQL_C_SLONG, SQL_INTEGER, 0, 0, &cdr->disposition, 0, NULL);
+       SQLBindParameter(ODBC_stmt, 13, SQL_PARAM_INPUT, SQL_C_SLONG, SQL_INTEGER, 0, 0, &cdr->amaflags, 0, NULL);
+       SQLBindParameter(ODBC_stmt, 14, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, sizeof(cdr->accountcode), 0, cdr->accountcode, 0, NULL);
 
        if((loguniqueid != NULL) && ((strcmp(loguniqueid, "1") == 0) || (strcmp(loguniqueid, "yes") == 0)))
        {
-               SQLBindParameter(ODBC_stmt, 15, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, 0, 0, cdr->uniqueid, 0, NULL);
+               SQLBindParameter(ODBC_stmt, 15, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, sizeof(cdr->uniqueid), 0, cdr->uniqueid, 0, NULL);
+               SQLBindParameter(ODBC_stmt, 16, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, sizeof(cdr->userfield), 0, cdr->userfield, 0, NULL);
        }
 
        if(connected)
@@ -151,25 +152,25 @@ static int odbc_log(struct ast_cdr *cdr)
                res = odbc_do_query();
                if(res < 0)
                {
-                       if(option_verbose > 3)          
+                       if(option_verbose > 10)         
                                ast_verbose( VERBOSE_PREFIX_4 "cdr_odbc: Query FAILED Call not logged!\n");
                        res = odbc_init();
-                       if(option_verbose > 3)
+                       if(option_verbose > 10)
                                ast_verbose( VERBOSE_PREFIX_4 "cdr_odbc: Reconnecting to dsn %s\n", dsn);
                        if(res < 0)
                        {
-                               if(option_verbose > 3)
+                               if(option_verbose > 10)
                                        ast_verbose( VERBOSE_PREFIX_4 "cdr_odbc: %s has gone away!\n", dsn);
                                connected = 0;
                        }
                        else
                        {
-                               if(option_verbose > 3)
+                               if(option_verbose > 10)
                                        ast_verbose( VERBOSE_PREFIX_4 "cdr_odbc: Trying Query again!\n");
                                res = odbc_do_query();
                                if(res < 0)
                                {
-                                       if(option_verbose > 3)
+                                       if(option_verbose > 10)
                                                ast_verbose( VERBOSE_PREFIX_4 "cdr_odbc: Query FAILED Call not logged!\n");
                                }
                        }
@@ -177,7 +178,7 @@ static int odbc_log(struct ast_cdr *cdr)
        }
        else
        {
-               if(option_verbose > 3)
+               if(option_verbose > 10)
                        ast_verbose( VERBOSE_PREFIX_4 "cdr_odbc: Query FAILED Call not logged!\n");
        }
        ast_mutex_unlock(&odbc_lock);
@@ -194,7 +195,7 @@ static int odbc_unload_module(void)
        ast_mutex_lock(&odbc_lock);
        if (connected)
        {
-               if(option_verbose > 3)
+               if(option_verbose > 10)
                        ast_verbose( VERBOSE_PREFIX_4 "cdr_odbc: Disconnecting from %s\n", dsn);
                SQLFreeHandle(SQL_HANDLE_STMT, ODBC_stmt);
                SQLDisconnect(ODBC_con);
@@ -204,7 +205,7 @@ static int odbc_unload_module(void)
        }
        if (dsn && dsn_alloc)
        {
-               if(option_verbose > 3)
+               if(option_verbose > 10)
                        ast_verbose( VERBOSE_PREFIX_4 "cdr_odbc: free dsn\n");
                free(dsn);
                dsn = NULL;
@@ -212,7 +213,7 @@ static int odbc_unload_module(void)
        }
        if (username && username_alloc)
        {
-               if(option_verbose > 3)
+               if(option_verbose > 10)
                        ast_verbose( VERBOSE_PREFIX_4 "cdr_odbc: free username\n");
                free(username);
                username = NULL;
@@ -220,7 +221,7 @@ static int odbc_unload_module(void)
        }
        if (password && password_alloc)
        {
-               if(option_verbose > 3)
+               if(option_verbose > 10)
                        ast_verbose( VERBOSE_PREFIX_4 "cdr_odbc: free password\n");
                free(password);
                password = NULL;
@@ -228,7 +229,7 @@ static int odbc_unload_module(void)
        }
        if (loguniqueid && loguniqueid_alloc)
        {
-               if(option_verbose > 3)
+               if(option_verbose > 10)
                        ast_verbose( VERBOSE_PREFIX_4 "cdr_odbc: free loguniqueid\n");
                free(loguniqueid);
                loguniqueid = NULL;
@@ -241,7 +242,7 @@ static int odbc_unload_module(void)
 
 static int odbc_load_module(void)
 {
-       int res;
+       int res = 0;
        struct ast_config *cfg;
        struct ast_variable *var;
        char *tmp;
@@ -252,13 +253,13 @@ static int odbc_load_module(void)
        if (!cfg)
        {
                ast_log(LOG_WARNING, "cdr_odbc: Unable to load config for ODBC CDR's: %s\n", config);
-               return 0;
+               goto out;
        }
        
        var = ast_variable_browse(cfg, "global");
        if (!var) {
                /* nothing configured */
-               return 0;
+               goto out;
        }
 
        tmp = ast_variable_retrieve(cfg,"global","dsn");
@@ -332,7 +333,7 @@ static int odbc_load_module(void)
                {
                        strcpy(loguniqueid,tmp);
                        loguniqueid_alloc = 1;
-                       ast_log(LOG_WARNING,"cdr_odbc: Logging uniqueid\n");
+                       ast_log(LOG_NOTICE,"cdr_odbc: Logging uniqueid\n");
                }
                else
                {
@@ -368,6 +369,7 @@ static int odbc_load_module(void)
        {
                ast_log(LOG_ERROR, "cdr_odbc: Unable to register ODBC CDR handling\n");
        }
+out:
        ast_mutex_unlock(&odbc_lock);
        return res;
 }
@@ -383,7 +385,7 @@ static int odbc_do_query(void)
 
        if((ODBC_res != SQL_SUCCESS) && (ODBC_res != SQL_SUCCESS_WITH_INFO))
        {
-               if(option_verbose > 3)
+               if(option_verbose > 10)
                        ast_verbose( VERBOSE_PREFIX_4 "cdr_odbc: Error in Query %d\n", ODBC_res);
                SQLGetDiagRec(SQL_HANDLE_DBC, ODBC_con, 1, ODBC_stat, &ODBC_err, ODBC_msg, 100, &ODBC_mlen);
                SQLFreeHandle(SQL_HANDLE_STMT, ODBC_stmt);
@@ -392,7 +394,7 @@ static int odbc_do_query(void)
        }
        else
        {
-               if(option_verbose > 3)
+               if(option_verbose > 10)
                        ast_verbose( VERBOSE_PREFIX_4 "cdr_odbc: Query Successful!\n");
                connected = 1;
        }
@@ -412,7 +414,7 @@ static int odbc_init(void)
 
                if((ODBC_res != SQL_SUCCESS) && (ODBC_res != SQL_SUCCESS_WITH_INFO))
                {
-                       if(option_verbose > 3)
+                       if(option_verbose > 10)
                                ast_verbose( VERBOSE_PREFIX_4 "cdr_odbc: Error AllocHandle\n");
                        connected = 0;
                        return -1;
@@ -422,7 +424,7 @@ static int odbc_init(void)
 
                if((ODBC_res != SQL_SUCCESS) && (ODBC_res != SQL_SUCCESS_WITH_INFO))
                {
-                       if(option_verbose > 3)
+                       if(option_verbose > 10)
                                ast_verbose( VERBOSE_PREFIX_4 "cdr_odbc: Error SetEnv\n");
                        SQLFreeHandle(SQL_HANDLE_ENV, ODBC_env);
                        connected = 0;
@@ -433,7 +435,7 @@ static int odbc_init(void)
 
                if((ODBC_res != SQL_SUCCESS) && (ODBC_res != SQL_SUCCESS_WITH_INFO))
                {
-                       if(option_verbose > 3)
+                       if(option_verbose > 10)
                                ast_verbose( VERBOSE_PREFIX_4 "cdr_odbc: Error AllocHDB %d\n", ODBC_res);
                        SQLFreeHandle(SQL_HANDLE_ENV, ODBC_env);
                        connected = 0;
@@ -447,7 +449,7 @@ static int odbc_init(void)
 
        if((ODBC_res != SQL_SUCCESS) && (ODBC_res != SQL_SUCCESS_WITH_INFO))
        {
-               if(option_verbose > 3)
+               if(option_verbose > 10)
                        ast_verbose( VERBOSE_PREFIX_4 "cdr_odbc: Error SQLConnect %d\n", ODBC_res);
                SQLGetDiagRec(SQL_HANDLE_DBC, ODBC_con, 1, ODBC_stat, &ODBC_err, ODBC_msg, 100, &ODBC_mlen);
                SQLFreeHandle(SQL_HANDLE_ENV, ODBC_env);
@@ -456,7 +458,7 @@ static int odbc_init(void)
        }
        else
        {
-               if(option_verbose > 3)
+               if(option_verbose > 10)
                        ast_verbose( VERBOSE_PREFIX_4 "cdr_odbc: Connected to %s\n", dsn);
                connected = 1;
        }