Main Page | Alphabetical List | Data Structures | Directories | File List | Data Fields | Globals

dbpool_mysql.c

Go to the documentation of this file.
00001 /* ==================================================================== 
00002  * The Kannel Software License, Version 1.0 
00003  * 
00004  * Copyright (c) 2001-2008 Kannel Group  
00005  * Copyright (c) 1998-2001 WapIT Ltd.   
00006  * All rights reserved. 
00007  * 
00008  * Redistribution and use in source and binary forms, with or without 
00009  * modification, are permitted provided that the following conditions 
00010  * are met: 
00011  * 
00012  * 1. Redistributions of source code must retain the above copyright 
00013  *    notice, this list of conditions and the following disclaimer. 
00014  * 
00015  * 2. Redistributions in binary form must reproduce the above copyright 
00016  *    notice, this list of conditions and the following disclaimer in 
00017  *    the documentation and/or other materials provided with the 
00018  *    distribution. 
00019  * 
00020  * 3. The end-user documentation included with the redistribution, 
00021  *    if any, must include the following acknowledgment: 
00022  *       "This product includes software developed by the 
00023  *        Kannel Group (http://www.kannel.org/)." 
00024  *    Alternately, this acknowledgment may appear in the software itself, 
00025  *    if and wherever such third-party acknowledgments normally appear. 
00026  * 
00027  * 4. The names "Kannel" and "Kannel Group" must not be used to 
00028  *    endorse or promote products derived from this software without 
00029  *    prior written permission. For written permission, please  
00030  *    contact org@kannel.org. 
00031  * 
00032  * 5. Products derived from this software may not be called "Kannel", 
00033  *    nor may "Kannel" appear in their name, without prior written 
00034  *    permission of the Kannel Group. 
00035  * 
00036  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED 
00037  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 
00038  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 
00039  * DISCLAIMED.  IN NO EVENT SHALL THE KANNEL GROUP OR ITS CONTRIBUTORS 
00040  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,  
00041  * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT  
00042  * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR  
00043  * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,  
00044  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE  
00045  * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,  
00046  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
00047  * ==================================================================== 
00048  * 
00049  * This software consists of voluntary contributions made by many 
00050  * individuals on behalf of the Kannel Group.  For more information on  
00051  * the Kannel Group, please see <http://www.kannel.org/>. 
00052  * 
00053  * Portions of this software are based upon software originally written at  
00054  * WapIT Ltd., Helsinki, Finland for the Kannel project.  
00055  */ 
00056 
00057 /*
00058  * dbpool_mysql.c - implement MySQL operations for generic database connection pool
00059  *
00060  * Stipe Tolj <stolj@wapme.de>
00061  *      2003 Initial version.
00062  * Alexander Malysh <a.malysh@centrium.de>
00063  *      2003 Made dbpool more generic.
00064  */
00065 
00066 #ifdef HAVE_MYSQL
00067 #include <mysql.h>
00068 
00069 
00070 static void *mysql_open_conn(const DBConf *db_conf)
00071 {
00072     MYSQL *mysql = NULL;
00073     MySQLConf *conf = db_conf->mysql; /* make compiler happy */
00074 
00075     /* sanity check */
00076     if (conf == NULL)
00077         return NULL;
00078 
00079     /* pre-allocate */
00080     mysql = gw_malloc(sizeof(MYSQL));
00081     gw_assert(mysql != NULL);
00082 
00083     /* initialize mysql structures */
00084     if (!mysql_init(mysql)) {
00085         error(0, "MYSQL: init failed!");
00086         error(0, "MYSQL: %s", mysql_error(mysql));
00087         goto failed;
00088     }
00089 
00090     if (!mysql_real_connect(mysql, octstr_get_cstr(conf->host),
00091                             octstr_get_cstr(conf->username),
00092                             octstr_get_cstr(conf->password),
00093                             octstr_get_cstr(conf->database), 
00094                             conf->port, NULL, 0)) {
00095         error(0, "MYSQL: can not connect to database!");
00096         error(0, "MYSQL: %s", mysql_error(mysql));
00097         goto failed;
00098     }
00099 
00100     info(0, "MYSQL: Connected to server at %s.", octstr_get_cstr(conf->host));
00101     info(0, "MYSQL: server version %s, client version %s.",
00102            mysql_get_server_info(mysql), mysql_get_client_info());
00103 
00104     return mysql;
00105 
00106 failed:
00107     if (mysql != NULL) 
00108         gw_free(mysql);
00109     return NULL;
00110 }
00111 
00112 
00113 static void mysql_close_conn(void *conn)
00114 {
00115     if (conn == NULL)
00116         return;
00117 
00118     mysql_close((MYSQL*) conn);
00119     gw_free(conn);
00120 }
00121 
00122 
00123 static int mysql_check_conn(void *conn)
00124 {
00125     if (conn == NULL)
00126         return -1;
00127 
00128     if (mysql_ping((MYSQL*) conn)) {
00129         error(0, "MYSQL: database check failed!");
00130         error(0, "MYSQL: %s", mysql_error(conn));
00131         return -1;
00132     }
00133 
00134     return 0;
00135 }
00136 
00137 
00138 static void mysql_conf_destroy(DBConf *db_conf)
00139 {
00140     MySQLConf *conf = db_conf->mysql;
00141 
00142     octstr_destroy(conf->host);
00143     octstr_destroy(conf->username);
00144     octstr_destroy(conf->password);
00145     octstr_destroy(conf->database);
00146 
00147     gw_free(conf);
00148     gw_free(db_conf);
00149 }
00150 
00151 
00152 static struct db_ops mysql_ops = {
00153     .open = mysql_open_conn,
00154     .close = mysql_close_conn,
00155     .check = mysql_check_conn,
00156     .conf_destroy = mysql_conf_destroy
00157 };
00158 
00159 #endif /* HAVE_MYSQL */
00160 
See file LICENSE for details about the license agreement for using, modifying, copying or deriving work from this software.