/[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.24 by sysadm, Fri Nov 21 02:28:15 2025 UTC Revision 1.28 by sysadm, Fri Dec 19 06:16:26 2025 UTC
# Line 13  Line 13 
13  #include "common.h"  #include "common.h"
14  #include "database.h"  #include "database.h"
15  #include "log.h"  #include "log.h"
16    #include <errno.h>
17    #include <fcntl.h>
18  #include <mysql.h>  #include <mysql.h>
19  #include <stdio.h>  #include <stdio.h>
20  #include <string.h>  #include <string.h>
21    #include <sys/stat.h>
22    
23  // Global declaration for database  // Global declaration for database
24  char DB_ca_cert[FILE_PATH_LEN] = "conf/ca_cert.pem";  char DB_ca_cert[FILE_PATH_LEN] = "conf/ca_cert.pem";
# Line 28  char DB_timezone[DB_timezone_max_len + 1 Line 31  char DB_timezone[DB_timezone_max_len + 1
31  MYSQL *db_open()  MYSQL *db_open()
32  {  {
33          MYSQL *db = NULL;          MYSQL *db = NULL;
34          unsigned int ssl_mode = SSL_MODE_VERIFY_CA;  #ifdef HAVE_MARIADB_CLIENT
35            my_bool verify_server_cert = 0;
36    #else
37            unsigned int ssl_mode = SSL_MODE_PREFERRED;
38    #endif
39          char sql[SQL_BUFFER_LEN];          char sql[SQL_BUFFER_LEN];
40            int fd;
41            int have_ca_cert = 0;
42    
43          db = mysql_init(NULL);          db = mysql_init(NULL);
44          if (db == NULL)          if (db == NULL)
45          {          {
46                  log_error("mysql_init() failed\n");                  log_error("mysql_init() failed");
47                  return NULL;                  return NULL;
48          }          }
49    
50          if (mysql_ssl_set(db, NULL, NULL, DB_ca_cert, NULL, NULL) != 0)          fd = open(DB_ca_cert, O_RDONLY);
51            if (fd == -1)
52          {          {
53                  log_error("mysql_ssl_set() error\n");                  if (errno != ENOENT)
54                    {
55                            log_error("open(%s) error: %d", DB_ca_cert, errno);
56                    }
57            }
58            else
59            {
60                    close(fd);
61                    have_ca_cert = 1;
62    #ifndef HAVE_MARIADB_CLIENT
63                    ssl_mode = SSL_MODE_VERIFY_CA;
64    #endif
65            }
66    
67            if (mysql_ssl_set(db, NULL, NULL, (have_ca_cert ? DB_ca_cert : NULL), NULL, NULL) != 0)
68            {
69                    log_error("mysql_ssl_set() error");
70                  return NULL;                  return NULL;
71          }          }
72    
73    #ifdef HAVE_MARIADB_CLIENT
74            if (mysql_optionsv(db, MYSQL_OPT_SSL_VERIFY_SERVER_CERT, &verify_server_cert) != 0)
75            {
76                    log_error("mysql_optionsv() error");
77                    return NULL;
78            }
79    #else
80          if (mysql_options(db, MYSQL_OPT_SSL_MODE, &ssl_mode) != 0)          if (mysql_options(db, MYSQL_OPT_SSL_MODE, &ssl_mode) != 0)
81          {          {
82                  log_error("mysql_options() error\n");                  log_error("mysql_options() error");
83                  return NULL;                  return NULL;
84          }          }
85    #endif
86    
87          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,
88                                                     0, NULL, 0) == NULL)                                                     0, NULL, 0) == NULL)
89          {          {
90                  log_error("mysql_real_connect() error: %s\n", mysql_error(db));                  log_error("mysql_real_connect() error: %s", mysql_error(db));
91                  mysql_close(db);                  mysql_close(db);
92                  return NULL;                  return NULL;
93          }          }
94    
95          if (mysql_set_character_set(db, "utf8") != 0)          if (mysql_set_character_set(db, "utf8") != 0)
96          {          {
97                  log_error("Set character set error: %s\n", mysql_error(db));                  log_error("Set character set error: %s", mysql_error(db));
98                  mysql_close(db);                  mysql_close(db);
99                  return NULL;                  return NULL;
100          }          }
# Line 71  MYSQL *db_open() Line 105  MYSQL *db_open()
105    
106          if (mysql_query(db, sql) != 0)          if (mysql_query(db, sql) != 0)
107          {          {
108                  log_error("Set timezone error: %s\n", mysql_error(db));                  log_error("Set timezone error: %s", mysql_error(db));
109                  mysql_close(db);                  mysql_close(db);
110                  return NULL;                  return NULL;
111          }          }


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

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