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

Contents of /lbbs/src/database.c

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.22 - (show annotations)
Sun Nov 16 11:06:06 2025 UTC (4 months ago) by sysadm
Branch: MAIN
Changes since 1.21: +1 -1 lines
Content type: text/x-csrc
Update mysql.h file path

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 <stdio.h>
17 #include <mysql.h>
18
19 // Global declaration for database
20 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 = NULL;
29 char sql[SQL_BUFFER_LEN];
30
31 db = mysql_init(NULL);
32 if (db == NULL)
33 {
34 log_error("mysql_init() failed\n");
35 return NULL;
36 }
37
38 if (mysql_real_connect(db, DB_host, DB_username, DB_password, DB_database,
39 0, NULL, 0) == NULL)
40 {
41 log_error("mysql_real_connect() error: %s\n", mysql_error(db));
42 mysql_close(db);
43 return NULL;
44 }
45
46 if (mysql_set_character_set(db, "utf8") != 0)
47 {
48 log_error("Set character set error: %s\n", mysql_error(db));
49 mysql_close(db);
50 return NULL;
51 }
52
53 snprintf(sql, sizeof(sql),
54 "SET time_zone = '%s'",
55 DB_timezone);
56
57 if (mysql_query(db, sql) != 0)
58 {
59 log_error("Set timezone error: %s\n", mysql_error(db));
60 mysql_close(db);
61 return NULL;
62 }
63
64 return db;
65 }

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