/[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.9 by sysadm, Wed Apr 30 09:18:19 2025 UTC Revision 1.21 by sysadm, Tue Nov 11 00:28:05 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    
13  #include "common.h"  #include "common.h"
14    #include "database.h"
15  #include "log.h"  #include "log.h"
 #include <mysql.h>  
16  #include <stdio.h>  #include <stdio.h>
17    #include <mysql/mysql.h>
18    
19  MYSQL *  // Global declaration for database
20  db_open()  char DB_host[DB_host_max_len + 1];
21    char DB_username[DB_username_max_len + 1];
22    char DB_password[DB_password_max_len + 1];
23    char DB_database[DB_database_max_len + 1];
24    char DB_timezone[DB_timezone_max_len + 1];
25    
26    MYSQL *db_open()
27  {  {
28          MYSQL *db;          MYSQL *db = NULL;
29          char sql[1024];          char sql[SQL_BUFFER_LEN];
30    
31          db = mysql_init(NULL);          db = mysql_init(NULL);
32          if (db == NULL)          if (db == NULL)
# Line 33  db_open() Line 35  db_open()
35                  return NULL;                  return NULL;
36          }          }
37    
38          db = 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,
39                                                          0, NULL, 0);                                                     0, NULL, 0) == NULL)
         if (db == NULL)  
40          {          {
41                  log_error("mysql_connect() failed\n");                  log_error("mysql_real_connect() error: %s\n", mysql_error(db));
42                    mysql_close(db);
43                  return NULL;                  return NULL;
44          }          }
45    
46          if (mysql_set_character_set(db, "gb2312") != 0)          if (mysql_set_character_set(db, "utf8") != 0)
47          {          {
48                  log_error("Set character set failed\n");                  log_error("Set character set error: %s\n", mysql_error(db));
49                    mysql_close(db);
50                  return NULL;                  return NULL;
51          }          }
52    
53          sprintf(sql,          snprintf(sql, sizeof(sql),
54                  "SET time_zone = '%s'",                           "SET time_zone = '%s'",
55                  DB_timezone);                           DB_timezone);
56    
57          if (mysql_query(db, sql) != 0)          if (mysql_query(db, sql) != 0)
58          {          {
59                  log_error("Set timezone failed\n");                  log_error("Set timezone error: %s\n", mysql_error(db));
60                    mysql_close(db);
61                  return NULL;                  return NULL;
62          }          }
63    


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

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