Blocked revisions 94543 via svnmerge
[asterisk/asterisk.git] / cdr / cdr_sqlite.c
index 3d4d793..601e5b2 100644 (file)
@@ -22,6 +22,7 @@
  * \brief Store CDR records in a SQLite database.
  * 
  * \author Holger Schurig <hs4233@mail.mn-solutions.de>
+ * \extref SQLite http://www.sqlite.org/
  *
  * See also
  * \arg \ref Config_cdr
  * 
  * Creates the database and table on-the-fly
  * \ingroup cdr_drivers
+ *
+ * \note This module has been marked deprecated in favor for cdr_sqlite3_custom
  */
 
 /*** MODULEINFO
        <depend>sqlite</depend>
  ***/
 
-#include <sys/types.h>
-
-#include <unistd.h>
-#include <string.h>
-#include <stdlib.h>
-#include <stdio.h>
-#include <sqlite.h>
-
 #include "asterisk.h"
 
 ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
 
+#include <sqlite.h>
+
 #include "asterisk/channel.h"
 #include "asterisk/module.h"
-#include "asterisk/logger.h"
 #include "asterisk/utils.h"
+#include "asterisk/paths.h"
 
 #define LOG_UNIQUEID   0
 #define LOG_USERFIELD  0
@@ -58,7 +55,6 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
 /* When you change the DATE_FORMAT, be sure to change the CHAR(19) below to something else */
 #define DATE_FORMAT "%Y-%m-%d %T"
 
-static char *desc = "SQLite CDR Backend";
 static char *name = "sqlite";
 static sqlite* db = NULL;
 
@@ -95,24 +91,20 @@ static int sqlite_log(struct ast_cdr *cdr)
 {
        int res = 0;
        char *zErr = 0;
-       struct tm tm;
-       time_t t;
+       struct ast_tm tm;
        char startstr[80], answerstr[80], endstr[80];
        int count;
 
        ast_mutex_lock(&sqlite_lock);
 
-       t = cdr->start.tv_sec;
-       localtime_r(&t, &tm);
-       strftime(startstr, sizeof(startstr), DATE_FORMAT, &tm);
+       ast_localtime(&cdr->start, &tm, NULL);
+       ast_strftime(startstr, sizeof(startstr), DATE_FORMAT, &tm);
 
-       t = cdr->answer.tv_sec;
-       localtime_r(&t, &tm);
-       strftime(answerstr, sizeof(answerstr), DATE_FORMAT, &tm);
+       ast_localtime(&cdr->answer, &tm, NULL);
+       ast_strftime(answerstr, sizeof(answerstr), DATE_FORMAT, &tm);
 
-       t = cdr->end.tv_sec;
-       localtime_r(&t, &tm);
-       strftime(endstr, sizeof(endstr), DATE_FORMAT, &tm);
+       ast_localtime(&cdr->end, &tm, NULL);
+       ast_strftime(endstr, sizeof(endstr), DATE_FORMAT, &tm);
 
        for(count=0; count<5; count++) {
                res = sqlite_exec_printf(db,
@@ -160,20 +152,14 @@ static int sqlite_log(struct ast_cdr *cdr)
        
        if (zErr) {
                ast_log(LOG_ERROR, "cdr_sqlite: %s\n", zErr);
-               free(zErr);
+               ast_free(zErr);
        }
 
        ast_mutex_unlock(&sqlite_lock);
        return res;
 }
 
-
-static const char *description(void)
-{
-       return desc;
-}
-
-static int unload_module(void *mod)
+static int unload_module(void)
 {
        if (db)
                sqlite_close(db);
@@ -181,18 +167,21 @@ static int unload_module(void *mod)
        return 0;
 }
 
-static int load_module(void *mod)
+static int load_module(void)
 {
        char *zErr;
        char fn[PATH_MAX];
        int res;
 
+       ast_log(LOG_WARNING, "This module has been marked deprecated in favor of "
+               "using cdr_sqlite3_custom. (May be removed after Asterisk 1.6)\n");
+
        /* is the database there? */
        snprintf(fn, sizeof(fn), "%s/cdr.db", ast_config_AST_LOG_DIR);
-       db = sqlite_open(fn, 0660, &zErr);
+       db = sqlite_open(fn, AST_FILE_MODE, &zErr);
        if (!db) {
                ast_log(LOG_ERROR, "cdr_sqlite: %s\n", zErr);
-               free(zErr);
+               ast_free(zErr);
                return -1;
        }
 
@@ -202,14 +191,14 @@ static int load_module(void *mod)
                res = sqlite_exec(db, sql_create_table, NULL, NULL, &zErr);
                if (res) {
                        ast_log(LOG_ERROR, "cdr_sqlite: Unable to create table 'cdr': %s\n", zErr);
-                       free(zErr);
+                       ast_free(zErr);
                        goto err;
                }
 
                /* TODO: here we should probably create an index */
        }
        
-       res = ast_cdr_register(name, desc, sqlite_log);
+       res = ast_cdr_register(name, ast_module_info->description, sqlite_log);
        if (res) {
                ast_log(LOG_ERROR, "Unable to register SQLite CDR handling\n");
                return -1;
@@ -222,14 +211,4 @@ err:
        return -1;
 }
 
-static int reload(void *mod)
-{
-       return 0;
-}
-
-static const char *key(void)
-{
-       return ASTERISK_GPL_KEY;
-}
-
-STD_MOD(MOD_0, reload, NULL, NULL);
+AST_MODULE_INFO_STANDARD(ASTERISK_GPL_KEY, "SQLite CDR Backend");