123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 |
- /*!
- * \file
- * \ingroup db
- * \brief Database support for modules.
- *
- * Database support functions for modules.
- *
- * @cond
- * WARNING:
- * This file was autogenerated from the XML source file
- * ../../modules/matrix/kamailio-matrix.xml.
- * It can be regenerated by running 'make modules' in the db/schema
- * directory of the source code. You need to have xsltproc and
- * docbook-xsl stylesheets installed.
- * ALL CHANGES DONE HERE WILL BE LOST IF THE FILE IS REGENERATED
- * @endcond
- */
- #include "db_matrix.h"
- /* database variables */
- /* TODO assign read-write or read-only URI, introduce a parameter in XML */
- //extern str matrix_db_url;
- db1_con_t * matrix_dbh = NULL;
- db_func_t matrix_dbf;
- str matrix_table = str_init("matrix");
- /* column names */
- str matrix_first_col = str_init("first");
- str matrix_second_col = str_init("second");
- str matrix_res_col = str_init("res");
- /* table version */
- const unsigned int matrix_version = 1;
- /*
- * Closes the DB connection.
- */
- void matrix_db_close(void) {
- if (matrix_dbh) {
- matrix_dbf.close(matrix_dbh);
- matrix_dbh = NULL;
- }
- }
- /*!
- * Initialises the DB API, check the table version and closes the connection.
- * This should be called from the mod_init function.
- *
- * \return 0 means ok, -1 means an error occured.
- */
- int matrix_db_init(void) {
- if (!matrix_db_url.s || !matrix_db_url.len) {
- LM_ERR("you have to set the db_url module parameter.\n");
- return -1;
- }
- if (db_bind_mod(&matrix_db_url, &matrix_dbf) < 0) {
- LM_ERR("can't bind database module.\n");
- return -1;
- }
- if ((matrix_dbh = matrix_dbf.init(&matrix_db_url)) == NULL) {
- LM_ERR("can't connect to database.\n");
- return -1;
- }
- if (
- (db_check_table_version(&matrix_dbf, matrix_dbh, &matrix_table, matrix_version) < 0)
- ) {
- LM_ERR("during table version check.\n");
- matrix_db_close();
- return -1;
- }
- matrix_db_close();
- return 0;
- }
- /*!
- * Initialize the DB connection without checking the table version and DB URL.
- * This should be called from child_init. An already existing database
- * connection will be closed, and a new one created.
- *
- * \return 0 means ok, -1 means an error occured.
- */
- int matrix_db_open(void) {
- if (matrix_dbh) {
- matrix_dbf.close(matrix_dbh);
- }
- if ((matrix_dbh = matrix_dbf.init(&matrix_db_url)) == NULL) {
- LM_ERR("can't connect to database.\n");
- return -1;
- }
- return 0;
- }
|