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

Contents of /lbbs/src/database.c

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.25 - (show annotations)
Fri Nov 21 02:49:26 2025 UTC (3 months, 3 weeks ago) by sysadm
Branch: MAIN
Changes since 1.24: +12 -0 lines
Content type: text/x-csrc
Add alternative implementation with MariaDB client

1 /* SPDX-License-Identifier: GPL-3.0-or-later */
2 /*
3 * database
4 * - configuration and function of DB connection
5 *
6 * Copyright (C) 2004-2025 Leaflet <leaflet@leafok.com>
7 */
8
9 #ifdef HAVE_CONFIG_H
10 #include "config.h"
11 #endif
12
13 #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 *db_open()
29 {
30 MYSQL *db = NULL;
31 #ifdef HAVE_MARIADB_CLIENT
32 my_bool disabled = 0;
33 #else
34 unsigned int ssl_mode = SSL_MODE_VERIFY_CA;
35 #endif
36 char sql[SQL_BUFFER_LEN];
37
38 db = mysql_init(NULL);
39 if (db == NULL)
40 {
41 log_error("mysql_init() failed\n");
42 return NULL;
43 }
44
45 if (mysql_ssl_set(db, NULL, NULL, DB_ca_cert, NULL, NULL) != 0)
46 {
47 log_error("mysql_ssl_set() error\n");
48 return NULL;
49 }
50
51 #ifdef HAVE_MARIADB_CLIENT
52 if (mysql_optionsv(db, MYSQL_OPT_SSL_VERIFY_SERVER_CERT, &disabled) != 0)
53 {
54 log_error("mysql_optionsv() error\n");
55 return NULL;
56 }
57 #else
58 if (mysql_options(db, MYSQL_OPT_SSL_MODE, &ssl_mode) != 0)
59 {
60 log_error("mysql_options() error\n");
61 return NULL;
62 }
63 #endif
64
65 if (mysql_real_connect(db, DB_host, DB_username, DB_password, DB_database,
66 0, NULL, 0) == NULL)
67 {
68 log_error("mysql_real_connect() error: %s\n", mysql_error(db));
69 mysql_close(db);
70 return NULL;
71 }
72
73 if (mysql_set_character_set(db, "utf8") != 0)
74 {
75 log_error("Set character set error: %s\n", mysql_error(db));
76 mysql_close(db);
77 return NULL;
78 }
79
80 snprintf(sql, sizeof(sql),
81 "SET time_zone = '%s'",
82 DB_timezone);
83
84 if (mysql_query(db, sql) != 0)
85 {
86 log_error("Set timezone error: %s\n", mysql_error(db));
87 mysql_close(db);
88 return NULL;
89 }
90
91 return db;
92 }

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