When querying for the structure of the CDR table, remove the schema, if it
authorTilghman Lesher <tilghman@meg.abyt.es>
Mon, 15 Dec 2008 18:09:58 +0000 (18:09 +0000)
committerTilghman Lesher <tilghman@meg.abyt.es>
Mon, 15 Dec 2008 18:09:58 +0000 (18:09 +0000)
exists.
(Closes issue #14058)

git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@164349 65c4cc65-6c06-0410-ace0-fbb531ad65f3

cdr/cdr_pgsql.c

index 34ba9dd..5e8e486 100644 (file)
@@ -469,12 +469,20 @@ static int config_module(int reload)
        if (PQstatus(conn) != CONNECTION_BAD) {
                char sqlcmd[512];
                char *fname, *ftype, *flen, *fnotnull, *fdef;
+               char *tableptr;
                int i, rows;
                ast_debug(1, "Successfully connected to PostgreSQL database.\n");
                connected = 1;
 
+               /* Remove any schema name from the table */
+               if ((tableptr = strrchr(table, '.'))) {
+                       tableptr++;
+               } else {
+                       tableptr = table;
+               }
+
                /* Query the columns */
-               snprintf(sqlcmd, sizeof(sqlcmd), "select a.attname, t.typname, a.attlen, a.attnotnull, d.adsrc from pg_class c, pg_type t, pg_attribute a left outer join pg_attrdef d on a.atthasdef and d.adrelid = a.attrelid and d.adnum = a.attnum where c.oid = a.attrelid and a.atttypid = t.oid and (a.attnum > 0) and c.relname = '%s' order by c.relname, attnum", table);
+               snprintf(sqlcmd, sizeof(sqlcmd), "select a.attname, t.typname, a.attlen, a.attnotnull, d.adsrc from pg_class c, pg_type t, pg_attribute a left outer join pg_attrdef d on a.atthasdef and d.adrelid = a.attrelid and d.adnum = a.attnum where c.oid = a.attrelid and a.atttypid = t.oid and (a.attnum > 0) and c.relname = '%s' order by c.relname, attnum", tableptr);
                result = PQexec(conn, sqlcmd);
                if (PQresultStatus(result) != PGRES_TUPLES_OK) {
                        pgerror = PQresultErrorMessage(result);