/[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.16 by sysadm, Sat Jun 21 06:52:24 2025 UTC Revision 1.23 by sysadm, Thu Nov 20 14:40:17 2025 UTC
# Line 1  Line 1 
1  /***************************************************************************  /* SPDX-License-Identifier: GPL-3.0-or-later */
2                                                   database.c  -  description  /*
3                                                           -------------------   * database
4          Copyright            : (C) 2004-2025 by Leaflet   *   - configuration and function of DB connection
5          Email                : leaflet@leafok.com   *
6   ***************************************************************************/   * Copyright (C) 2004-2025  Leaflet <leaflet@leafok.com>
7     */
8  /***************************************************************************  
9   *                                                                         *  #ifdef HAVE_CONFIG_H
10   *   This program is free software; you can redistribute it and/or modify  *  #include "config.h"
11   *   it under the terms of the GNU General Public License as published by  *  #endif
  *   the Free Software Foundation; either version 3 of the License, or     *  
  *   (at your option) any later version.                                   *  
  *                                                                         *  
  ***************************************************************************/  
12    
13  #include "common.h"  #include "common.h"
14  #include "database.h"  #include "database.h"
15  #include "log.h"  #include "log.h"
16    #include <mysql.h>
17  #include <stdio.h>  #include <stdio.h>
18  #include <mysql/mysql.h>  #include <string.h>
19    
20  // Global declaration for database  // Global declaration for database
21  char DB_host[256];  char DB_ca_cert[FILE_PATH_LEN] = "conf/ca_cert.pem";
22  char DB_username[50];  char DB_host[DB_host_max_len + 1];
23  char DB_password[50];  char DB_username[DB_username_max_len + 1];
24  char DB_database[50];  char DB_password[DB_password_max_len + 1];
25  char DB_timezone[50];  char DB_database[DB_database_max_len + 1];
26    char DB_timezone[DB_timezone_max_len + 1];
27    
28  MYSQL *db_open()  MYSQL *db_open()
29  {  {
30          MYSQL *db = NULL;          MYSQL *db = NULL;
31            my_bool disabled = 0;
32          char sql[SQL_BUFFER_LEN];          char sql[SQL_BUFFER_LEN];
33    
34          db = mysql_init(NULL);          db = mysql_init(NULL);
# Line 39  MYSQL *db_open() Line 38  MYSQL *db_open()
38                  return NULL;                  return NULL;
39          }          }
40    
41            mysql_ssl_set(db, NULL, NULL, DB_ca_cert, NULL, NULL);
42            mysql_optionsv(db, MYSQL_OPT_SSL_VERIFY_SERVER_CERT, &disabled);
43    
44          if (mysql_real_connect(db, DB_host, DB_username, DB_password, DB_database,          if (mysql_real_connect(db, DB_host, DB_username, DB_password, DB_database,
45                                                     0, NULL, 0) == NULL)                                                     0, NULL, 0) == NULL)
46          {          {
# Line 47  MYSQL *db_open() Line 49  MYSQL *db_open()
49                  return NULL;                  return NULL;
50          }          }
51    
52          if (mysql_set_character_set(db, "gb2312") != 0)          if (mysql_set_character_set(db, "utf8") != 0)
53          {          {
54                  log_error("Set character set error: %s\n", mysql_error(db));                  log_error("Set character set error: %s\n", mysql_error(db));
55                  mysql_close(db);                  mysql_close(db);


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

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