/[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.25 by sysadm, Fri Nov 21 02:49:26 2025 UTC Revision 1.26 by sysadm, Wed Nov 26 14:38:27 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 29  MYSQL *db_open() Line 32  MYSQL *db_open()
32  {  {
33          MYSQL *db = NULL;          MYSQL *db = NULL;
34  #ifdef HAVE_MARIADB_CLIENT  #ifdef HAVE_MARIADB_CLIENT
35          my_bool disabled = 0;          my_bool verify_server_cert = 0;
36  #else  #else
37          unsigned int ssl_mode = SSL_MODE_VERIFY_CA;          unsigned int ssl_mode = SSL_MODE_PREFERRED;
38  #endif  #endif
39          char sql[SQL_BUFFER_LEN];          char sql[SQL_BUFFER_LEN];
40            int fd;
41    
42          db = mysql_init(NULL);          db = mysql_init(NULL);
43          if (db == NULL)          if (db == NULL)
# Line 42  MYSQL *db_open() Line 46  MYSQL *db_open()
46                  return NULL;                  return NULL;
47          }          }
48    
49            fd = open(DB_ca_cert, O_RDONLY);
50            if (fd == -1)
51            {
52                    if (errno != ENOENT)
53                    {
54                            log_error("open(%s) error: %d\n", DB_ca_cert, errno);
55                    }
56            }
57            else
58            {
59                    close(fd);
60    #ifndef HAVE_MARIADB_CLIENT
61                    ssl_mode = SSL_MODE_VERIFY_CA;
62    #endif
63            }
64    
65          if (mysql_ssl_set(db, NULL, NULL, DB_ca_cert, NULL, NULL) != 0)          if (mysql_ssl_set(db, NULL, NULL, DB_ca_cert, NULL, NULL) != 0)
66          {          {
67                  log_error("mysql_ssl_set() error\n");                  log_error("mysql_ssl_set() error\n");
# Line 49  MYSQL *db_open() Line 69  MYSQL *db_open()
69          }          }
70    
71  #ifdef HAVE_MARIADB_CLIENT  #ifdef HAVE_MARIADB_CLIENT
72          if (mysql_optionsv(db, MYSQL_OPT_SSL_VERIFY_SERVER_CERT, &disabled) != 0)          if (mysql_optionsv(db, MYSQL_OPT_SSL_VERIFY_SERVER_CERT, &verify_server_cert) != 0)
73          {          {
74                  log_error("mysql_optionsv() error\n");                  log_error("mysql_optionsv() error\n");
75                  return NULL;                  return NULL;


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

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