bdb_sval.c

00001 /* $Id$
00002  *
00003  * Copyright (C) 2006-2007 Sippy Software, Inc. <sales@sippysoft.com>
00004  *
00005  * This file is part of ser, a free SIP server.
00006  *
00007  * ser is free software; you can redistribute it and/or modify
00008  * it under the terms of the GNU General Public License as published by
00009  * the Free Software Foundation; either version 2 of the License, or
00010  * (at your option) any later version
00011  *
00012  * For a license to use the ser software under conditions
00013  * other than those described here, or to purchase support for this
00014  * software, please contact iptel.org by e-mail at the following addresses:
00015  *    info@iptel.org
00016  *
00017  * ser is distributed in the hope that it will be useful,
00018  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00019  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00020  * GNU General Public License for more details.
00021  *
00022  * You should have received a copy of the GNU General Public License
00023  * along with this program; if not, write to the Free Software
00024  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
00025  *
00026  */
00027 
00028 
00029 #include "bdb.h"
00030 
00031 int bdb_srow_db2bdb(db_con_t* _h, db_key_t* _k, db_op_t* _op, db_val_t* _v, int _n, bdb_srow_p *_r)
00032 {
00033         bdb_srow_p      r;
00034         bdb_table_p     t;
00035         bdb_column_p    c;
00036 
00037         int             found;
00038         int             use_key, found_key, key_idx;
00039         int             i;
00040         int             c_idx;
00041         bdb_sval_p      v;
00042 
00043         *_r = NULL;
00044 
00045         if ((t = bdb_find_table(CON_TABLE(_h))) == NULL) {
00046 #ifdef BDB_EXTRA_DEBUG
00047                 LOG(L_ERR, "BDB:bdb_srow_db2bdb: no table in use\n");
00048 #endif
00049                 return -1;
00050         };
00051 
00052         key_idx = -1;
00053         use_key = 0;
00054 
00055         /* check if all columns exist */
00056         for (i = 0; i < _n; i++) {
00057                 found = 0;
00058                 /* key column is always first one */
00059                 for (c = t->cols, found_key = 1; c != NULL; c = c->next, found_key = 0) {
00060                         if (!strcmp(_k[i], c->name.s)) {
00061                                 found = 1;
00062                                 break;
00063                         }
00064                 }
00065                 if (found_key == 1) {
00066                         /* use key only if it is used in clause and operator is '=' */
00067                         if (!use_key && (_op == NULL || (_op != NULL && !strcmp(_op[i], OP_EQ)))) {
00068                                 key_idx = i;
00069                                 use_key = 1;
00070                         }
00071                 }
00072                 if (!found) {
00073                         LOG(L_ERR, "BDB:bdb_srow_db2bdb: column '%s' does not exist\n", _k[i]);
00074                         return -1;
00075                 }
00076         }
00077 
00078         r = pkg_malloc(sizeof(*r));
00079         memset(r, 0, sizeof(*r));
00080 
00081         /* filling data into row */
00082         for (c = t->cols, c_idx = 0; c != NULL; c = c->next, c_idx++) {
00083                 for (i = 0; i < _n; i++) {
00084                         if (!strcmp(_k[i], c->name.s)) {
00085 #ifdef BDB_EXTRA_DEBUG
00086                                 LOG(L_NOTICE, "BDB:bdb_srow_db2bdb: filling column '%.*s', c_idx = %0d\n", c->name.len, c->name.s, c_idx);
00087 #endif
00088                                 v = pkg_malloc(sizeof(*v));
00089                                 memset(v, 0, sizeof(*v));
00090 
00091                                 v->c_idx = c_idx;
00092 
00093                                 bdb_push_sfield(r, v);
00094 
00095                                 if (bdb_sfield_db2bdb(v, &_v[i], (!_op) ? NULL : _op[i]) < 0) {
00096                                         bdb_free_srow(r);
00097                                         return -1;
00098                                 };
00099 
00100                                 if (use_key && i == key_idx) {
00101                                         bdb_set_skey(r, v);
00102                                 }
00103                         }
00104                 }
00105         };
00106 
00107         *_r = r;
00108 
00109         return 0;
00110 };
00111 
00112 
00113 void bdb_free_srow(bdb_srow_p _r)
00114 {
00115         if (_r->fields != NULL) {
00116                 bdb_free_sfield_list(_r->fields);
00117         }
00118 
00119         pkg_free(_r);
00120 };
00121 
00122 
00123 void bdb_free_sfield(bdb_sval_p _v)
00124 {
00125         if (!VAL_NULL(&(_v->v))) {
00126                 if (VAL_TYPE(&(_v->v)) == DB_STR || VAL_TYPE(&(_v->v)) == DB_STRING ||
00127                     VAL_TYPE(&(_v->v)) == DB_BLOB) {
00128                         pkg_free(VAL_STR(&(_v->v)).s);
00129                 }
00130         }
00131         pkg_free(_v);
00132 };
00133 
00134 
00135 void bdb_free_sfield_list(bdb_sval_p _v)
00136 {
00137         bdb_sval_p     curr, next;
00138 
00139         for (curr = _v; curr != NULL;) {
00140                 next = curr->next;
00141                 bdb_free_sfield(curr);
00142                 curr = next;
00143         }
00144 };
00145 
00146 
00147 void bdb_push_sfield(bdb_srow_p _r, bdb_sval_p _v)
00148 {
00149         bdb_sval_p      f;
00150 
00151         if (_r->fields == NULL) {
00152                 _r->fields = _v;
00153                 return;
00154         }
00155         f = _r->fields;
00156         while (f->next != NULL) {
00157                 f = f->next;
00158         }
00159         f->next = _v;
00160 };
00161 
00162 
00163 void bdb_set_skey(bdb_srow_p _r, bdb_sval_p _v)
00164 {
00165         /* NULL is not allowed for primary key */
00166         if (VAL_NULL(&(_v->v)))
00167                 return;
00168 
00169         switch (VAL_TYPE(&(_v->v))) {
00170         case DB_INT:
00171                 _r->key.data = &VAL_INT(&(_v->v));
00172                 _r->key.size = sizeof(VAL_INT(&(_v->v)));
00173                 break;
00174         case DB_FLOAT:
00175                 _r->key.data = &VAL_FLOAT(&(_v->v));
00176                 _r->key.size = sizeof(VAL_FLOAT(&(_v->v)));
00177                 break;
00178         case DB_DATETIME:
00179                 _r->key.data = &VAL_TIME(&(_v->v));
00180                 _r->key.size = sizeof(VAL_TIME(&(_v->v)));
00181                 break;
00182         case DB_BLOB:
00183                 _r->key.data = VAL_BLOB(&(_v->v)).s;
00184                 _r->key.size = VAL_BLOB(&(_v->v)).len;
00185                 break;
00186         case DB_DOUBLE:
00187                 _r->key.data = &VAL_DOUBLE(&(_v->v));
00188                 _r->key.size = sizeof(VAL_DOUBLE(&(_v->v)));
00189                 break;
00190         case DB_STRING:
00191                 _r->key.data = (void *)VAL_STRING(&(_v->v));
00192                 _r->key.size = strlen(VAL_STRING(&(_v->v))) + 1;
00193                 break;
00194         case DB_STR:
00195                 _r->key.data = VAL_STR(&(_v->v)).s;
00196                 _r->key.size = VAL_STR(&(_v->v)).len;
00197                 break;
00198         case DB_BITMAP:
00199                 _r->key.data = &VAL_BITMAP(&(_v->v));
00200                 _r->key.size = sizeof(VAL_BITMAP(&(_v->v)));
00201                 break;
00202         default:
00203                 LOG(L_ERR, "BDB:bdb_set_skey: unknown column type: %0X\n", VAL_TYPE(&(_v->v)));
00204                 break;
00205         }
00206 
00207 #ifdef BDB_EXTRA_DEBUG
00208         LOG(L_NOTICE, "BDB:bdb_set_skey: use key '%.*s' (%d bytes)\n", _r->key.size, (char *)_r->key.data, _r->key.size);
00209 #endif
00210 };
00211 
00212 
00213 int bdb_sfield_db2bdb(bdb_sval_p v, db_val_t* _v, db_op_t _op)
00214 {
00215         char    *s;
00216 
00217         VAL_NULL(&(v->v)) = VAL_NULL(_v);
00218         VAL_TYPE(&(v->v)) = VAL_TYPE(_v);
00219 
00220         if (!VAL_NULL(&(v->v))) {
00221                 switch (VAL_TYPE(_v)) {
00222                 case DB_INT:
00223                         VAL_INT(&(v->v)) = VAL_INT(_v);
00224                         break;
00225                 case DB_FLOAT:
00226                         VAL_FLOAT(&(v->v)) = VAL_FLOAT(_v);
00227                         break;
00228                 case DB_DATETIME:
00229                         VAL_TIME(&(v->v)) = VAL_TIME(_v);
00230                         break;
00231                 case DB_BLOB:
00232                         s = pkg_malloc(VAL_BLOB(_v).len);
00233                         memcpy(s, VAL_BLOB(_v).s, VAL_BLOB(_v).len);
00234                         VAL_BLOB(&(v->v)).s = s;
00235                         VAL_BLOB(&(v->v)).len = VAL_BLOB(_v).len;
00236                         break;
00237                 case DB_DOUBLE:
00238                         VAL_DOUBLE(&(v->v)) = VAL_DOUBLE(_v);
00239                         break;
00240                 case DB_STRING:
00241                         VAL_STR(&(v->v)).len = strlen(VAL_STRING(_v)) + 1;
00242                         s = pkg_malloc(VAL_STR(&(v->v)).len);
00243                         strcpy(s, VAL_STRING(_v));
00244                         VAL_STRING(&(v->v)) = s;
00245                         break;
00246                 case DB_STR:
00247                         s = pkg_malloc(VAL_STR(_v).len);
00248                         memcpy(s, VAL_STR(_v).s, VAL_STR(_v).len);
00249                         VAL_STR(&(v->v)).s = s;
00250                         VAL_STR(&(v->v)).len = VAL_STR(_v).len;
00251                         break;
00252                 case DB_BITMAP:
00253                         VAL_BITMAP(&(v->v)) = VAL_BITMAP(_v);
00254                         break;
00255                 default:
00256                         LOG(L_ERR, "BDB:bdb_sfield_db2bdb: unknown column type: %0X\n", VAL_TYPE(_v));
00257                         return -1;
00258                         break;
00259                 }
00260 
00261                 if (!_op || !strcmp(_op, OP_EQ)) {
00262                         v->op = BDB_OP_EQ;
00263                 } else if (!strcmp(_op, OP_LT)) {
00264                         v->op = BDB_OP_LT;
00265                 } else if (!strcmp(_op, OP_GT)) {
00266                         v->op = BDB_OP_GT;
00267                 } else if (!strcmp(_op, OP_LEQ)) {
00268                         v->op = BDB_OP_LEQ;
00269                 } else if (!strcmp(_op, OP_GEQ)) {
00270                         v->op = BDB_OP_GEQ;
00271                 } else {
00272                         LOG(L_ERR, "BDB:sbdb_field_db2bdb: unknown operator: %s\n", _op);
00273                         return -1;
00274                 }
00275         }
00276 
00277         return 0;
00278 };
00279 
00280