/[LeafOK_CVS]/lbbs/src/database.c
ViewVC logotype

Diff of /lbbs/src/database.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 1.2 by sysadm, Wed Oct 20 07:46:32 2004 UTC Revision 1.24 by sysadm, Fri Nov 21 02:28:15 2025 UTC
# Line 1  Line 1 
1  /***************************************************************************  /* SPDX-License-Identifier: GPL-3.0-or-later */
2                           database.c  -  description  /*
3                               -------------------   * database
4      begin                : Mon Oct 11 2004   *   - configuration and function of DB connection
5      copyright            : (C) 2004 by Leaflet   *
6      email                : leaflet@leafok.com   * Copyright (C) 2004-2025  Leaflet <leaflet@leafok.com>
7   ***************************************************************************/   */
8    
9  /***************************************************************************  #ifdef HAVE_CONFIG_H
10   *                                                                         *  #include "config.h"
11   *   This program is free software; you can redistribute it and/or modify  *  #endif
  *   it under the terms of the GNU General Public License as published by  *  
  *   the Free Software Foundation; either version 2 of the License, or     *  
  *   (at your option) any later version.                                   *  
  *                                                                         *  
  ***************************************************************************/  
12    
 #include "bbs.h"  
13  #include "common.h"  #include "common.h"
14    #include "database.h"
15    #include "log.h"
16    #include <mysql.h>
17    #include <stdio.h>
18    #include <string.h>
19    
20    // Global declaration for database
21    char DB_ca_cert[FILE_PATH_LEN] = "conf/ca_cert.pem";
22    char DB_host[DB_host_max_len + 1];
23    char DB_username[DB_username_max_len + 1];
24    char DB_password[DB_password_max_len + 1];
25    char DB_database[DB_database_max_len + 1];
26    char DB_timezone[DB_timezone_max_len + 1];
27    
28  MYSQL *  MYSQL *db_open()
 db_open ()  
29  {  {
30    MYSQL *db;          MYSQL *db = NULL;
31              unsigned int ssl_mode = SSL_MODE_VERIFY_CA;
32    db = mysql_init(NULL);          char sql[SQL_BUFFER_LEN];
33    if (db == NULL)  
34    {          db = mysql_init(NULL);
35      log_error("mysql_init() failed\n");          if (db == NULL)
36      return NULL;          {
37    }                  log_error("mysql_init() failed\n");
38                    return NULL;
39    db = mysql_real_connect(db, DB_host, DB_username, DB_password, DB_database,          }
40      0, NULL, 0);  
41    if (db == NULL)          if (mysql_ssl_set(db, NULL, NULL, DB_ca_cert, NULL, NULL) != 0)
42    {          {
43      log_error("mysql_connect() failed\n");                  log_error("mysql_ssl_set() error\n");
44      return NULL;                  return NULL;
45    }          }
46    
47            if (mysql_options(db, MYSQL_OPT_SSL_MODE, &ssl_mode) != 0)
48            {
49                    log_error("mysql_options() error\n");
50                    return NULL;
51            }
52    
53            if (mysql_real_connect(db, DB_host, DB_username, DB_password, DB_database,
54                                                       0, NULL, 0) == NULL)
55            {
56                    log_error("mysql_real_connect() error: %s\n", mysql_error(db));
57                    mysql_close(db);
58                    return NULL;
59            }
60    
61            if (mysql_set_character_set(db, "utf8") != 0)
62            {
63                    log_error("Set character set error: %s\n", mysql_error(db));
64                    mysql_close(db);
65                    return NULL;
66            }
67    
68            snprintf(sql, sizeof(sql),
69                             "SET time_zone = '%s'",
70                             DB_timezone);
71    
72            if (mysql_query(db, sql) != 0)
73            {
74                    log_error("Set timezone error: %s\n", mysql_error(db));
75                    mysql_close(db);
76                    return NULL;
77            }
78    
79            return db;
80  }  }


Legend:
Removed lines/characters  
Changed lines/characters
  Added lines/characters

webmaster@leafok.com
ViewVC Help
Powered by ViewVC 1.3.0-beta1