[svn-commits] oej: branch oej/codename-appleraisin-trunk r176937 - /team/oej/codename-apple...
SVN commits to the Digium repositories
svn-commits at lists.digium.com
Wed Feb 18 06:23:02 CST 2009
Author: oej
Date: Wed Feb 18 06:23:02 2009
New Revision: 176937
URL: http://svn.digium.com/svn-view/asterisk?view=rev&rev=176937
Log:
Adding support for put, get, del and "datbase show" on the cli.
Modified:
team/oej/codename-appleraisin-trunk/main/db.c
Modified: team/oej/codename-appleraisin-trunk/main/db.c
URL: http://svn.digium.com/svn-view/asterisk/team/oej/codename-appleraisin-trunk/main/db.c?view=diff&rev=176937&r1=176936&r2=176937
==============================================================================
--- team/oej/codename-appleraisin-trunk/main/db.c (original)
+++ team/oej/codename-appleraisin-trunk/main/db.c Wed Feb 18 06:23:02 2009
@@ -25,6 +25,13 @@
* \note DB3 is licensed under Sleepycat Public License and is thus incompatible
* with GPL. To avoid having to make another exception (and complicate
* licensing even further) we elect to use DB1 which is BSD licensed
+ *
+ * \note AstDB realtime
+ * AstDB realtime works with the basic operations - put, get, del
+ * Database show also works.
+ *
+ * The tree/family operations doesn't currently work. Maybe tree and family needs
+ * to be separate fields in the database, instead of one single field as I've tried with.
*/
#include "asterisk.h"
@@ -77,7 +84,7 @@
if (db_rt) {
return 0;
}
- db_rt=ast_check_realtime(db_rt_family);
+ db_rt = ast_check_realtime(db_rt_family);
if (!db_rt && !astdb && !(astdb = dbopen(ast_config_AST_DB, O_CREAT | O_RDWR, AST_FILE_MODE, DB_BTREE, NULL))) {
ast_log(LOG_WARNING, "Unable to open Asterisk database '%s': %s\n", ast_config_AST_DB, strerror(errno));
return -1;
@@ -91,38 +98,49 @@
*/
static struct ast_variable *db_realtime_getall(const char *key)
{
- struct ast_variable *resultset, *cur;
+ struct ast_variable *resultset = NULL, *cur;
struct ast_variable *data, *returnset = NULL;
- char *name, *value;
+ const char *name = NULL, *value = NULL;
+ struct ast_config *variablelist = NULL;
+ const char *cat = NULL;
if (ast_strlen_zero(key)) {
/* Load all entries in the astdb */
- resultset = ast_load_realtime(db_rt_family, db_rt_sysnamelabel, db_rt_sysname, SENTINEL);
- } else {
- resultset = ast_load_realtime(db_rt_family, db_rt_sysnamelabel, db_rt_sysname, db_rt_name, key, SENTINEL);
- }
- if (!resultset) {
+ variablelist = ast_load_realtime_multientry(db_rt_family, db_rt_sysnamelabel, db_rt_sysname, SENTINEL);
+ } else {
+ variablelist = ast_load_realtime_multientry(db_rt_family, db_rt_sysnamelabel, db_rt_sysname, db_rt_name, key, SENTINEL);
+ }
+ if (!variablelist) {
return NULL;
}
/* Now we need to start converting all this stuff. We have thre ast_variable sets per record in the result set */
-
- cur = resultset;
-
- /* skip the system name */
- while (cur) {
- if (!strcmp(cur->name, db_rt_name) {
- name = cur->value;
- } else if (!strcmp(cur->name, db_rt_value) {
- value = cur->value;
- data = ast_variable_new(name, value);
- data->next = returnset;
- returnset = data;
- }
- cur = cur->next;
+ while ((cat = ast_category_browse(variablelist, cat))) {
+ cur = resultset = ast_variable_browse(variablelist, cat);
+
+ /* skip the system name */
+ while (cur) {
+ if (!strcmp(cur->name, db_rt_name)) {
+ name = cur->value;
+ } else if (!strcmp(cur->name, db_rt_value)) {
+ value = cur->value;
+ data = ast_variable_new(name, value, "");
+ ast_debug(2, "#### Found Variable %s with value %s \n", name, value);
+ /* Add this to the returnset */
+ data->next = returnset;
+ returnset = data;
+ } else {
+ if (ast_strlen_zero(cur->name))
+ ast_debug(2, "#### Skipping strange record \n");
+ else
+ ast_debug(2, "#### Skipping %s with value %s \n", cur->name, cur->value);
+ }
+ cur = cur->next;
+ }
}
/* Clean up the resultset */
- ast_variable_destroy(resultset);
+ ast_variables_destroy(resultset);
+ ast_config_destroy(variablelist);
return returnset;
}
@@ -219,13 +237,20 @@
fullkeylen = snprintf(fullkey, sizeof(fullkey), "/%s/%s", family, keys);
if (db_rt) {
+ int rowsaffected ;
/* Now, the question here is if we're overwriting or adding
First, let's try updating it.
*/
- res = ast_update_realtime(db_rt_family, db_rt_sysnamelabel, db_rt_sysname, db_rt_name, fullkey, db_rt_value, value, SENTINEL);
- if (!res) {
+ ast_debug(2, ".... Trying ast_update_realtime\n");
+ /* Update_realtime with mysql returns the number of rows affected */
+ rowsaffected = ast_update_realtime(db_rt_family, db_rt_name, fullkey, db_rt_sysnamelabel, db_rt_sysname, db_rt_value, value, SENTINEL);
+ res = rowsaffected > 0 ? 0 : 1;
+ if (res) {
+ ast_debug(2, ".... Trying ast_store_realtime\n");
/* Update failed, let's try adding a new record */
res = ast_store_realtime(db_rt_family, db_rt_sysnamelabel, db_rt_sysname, db_rt_name, fullkey, db_rt_value, value, SENTINEL);
+ /* Ast_store_realtime with mysql returns 0 if ok, -1 if bad */
+
}
} else {
memset(&key, 0, sizeof(key));
@@ -263,7 +288,7 @@
if (db_rt) {
struct ast_variable *var;
- var = ast_load_realtime(db_rt_family, db_rt_sysnamelabel, db_rt_sysname, db_rt_family, db_rt_name, fullkey, SENTINEL);
+ var = ast_load_realtime(db_rt_family, db_rt_sysnamelabel, db_rt_sysname, db_rt_name, fullkey, SENTINEL);
if (!var) {
res = 0;
} else {
@@ -321,7 +346,8 @@
fullkeylen = snprintf(fullkey, sizeof(fullkey), "/%s/%s", family, keys);
if (db_rt) {
- res = ast_destroy_realtime(db_rt_family, db_rt_sysnamelabel, db_rt_sysname, db_rt_name, fullkey, SENTINEL);
+ int rowcount = ast_destroy_realtime(db_rt_family, db_rt_sysnamelabel, db_rt_sysname, db_rt_name, fullkey, SENTINEL);
+ res = rowcount > 0 ? 0 : 1;
} else {
memset(&key, 0, sizeof(key));
key.data = fullkey;
@@ -434,6 +460,11 @@
return NULL;
case CLI_GENERATE:
return NULL;
+ }
+
+ if (db_rt) {
+ ast_cli(a->fd, "deltree is not implemented for astdb/realtime ...yet\n");
+ return CLI_SUCCESS;
}
if ((a->argc < 3) || (a->argc > 4))
@@ -561,6 +592,10 @@
return NULL;
case CLI_GENERATE:
return NULL;
+ }
+ if (db_rt) {
+ ast_cli(a->fd, "showkey is not implemented for astdb/realtime ...yet\n");
+ return CLI_SUCCESS;
}
if (a->argc == 3) {
@@ -779,6 +814,10 @@
astman_send_error(s, m, "No family specified.");
return 0;
}
+ if (db_rt) {
+ astman_send_error(s, m, "Deltree not supported in ast/db realtime");
+ return 0;
+ }
if (!ast_strlen_zero(key))
res = ast_db_deltree(family, key);
More information about the svn-commits
mailing list