1
1
mirror of https://github.com/profanity-im/profanity.git synced 2025-01-03 14:57:42 -05:00

database: Define chatlog database location

This commit is contained in:
Michael Vetter 2020-03-18 18:56:22 +01:00
parent 994411d470
commit a7163b24f3
3 changed files with 29 additions and 6 deletions

View File

@ -3,6 +3,7 @@
* vim: expandtab:ts=4:sts=4:sw=4
*
* Copyright (C) 2012 - 2019 James Booth <boothj5@gmail.com>
* Copyright (C) 2020 Michael Vetter <jubalh@idoru.org>
*
* This file is part of Profanity.
*
@ -138,6 +139,22 @@ files_get_log_file(char *log_file)
return result;
}
char*
files_get_chatlog_database_path(void)
{
gchar *xdg_data = _files_get_xdg_data_home();
GString *logfile = g_string_new(xdg_data);
g_string_append(logfile, "/profanity/chatlog.db");
char *result = strdup(logfile->str);
free(xdg_data);
g_string_free(logfile, TRUE);
return result;
}
char*
files_get_config_path(char *config_base)
{

View File

@ -60,6 +60,7 @@ void files_create_directories(void);
char* files_get_config_path(char *config_base);
char* files_get_data_path(char *data_base);
char* files_get_chatlog_database_path(void);
char* files_get_log_file(char *log_file);
char* files_get_inputrc_file(void);

View File

@ -36,46 +36,51 @@
#include <sqlite3.h>
#include "log.h"
#include "config/files.h"
static sqlite3 *g_log_database;
static sqlite3 *g_chatlog_database;
bool
log_database_init(void)
{
int ret = sqlite3_initialize();
char *filename = "test";
char *filename = files_get_chatlog_database_path();
if (ret != SQLITE_OK) {
free(filename);
log_error("Error initializing SQLite database: %d", ret);
return FALSE;
}
ret = sqlite3_open(filename, &g_log_database);
ret = sqlite3_open(filename, &g_chatlog_database);
if (ret != SQLITE_OK) {
const char *err_msg = sqlite3_errmsg(g_log_database);
const char *err_msg = sqlite3_errmsg(g_chatlog_database);
log_error("Error opening SQLite database: %s", err_msg);
free(filename);
return FALSE;
}
char *err_msg;
char *query = "CREATE TABLE IF NOT EXISTS `ChatLogs` ( `id` INTEGER PRIMARY KEY, `jid` TEXT NOT NULL, `message` TEXT, `timestamp` TEXT)";
if( SQLITE_OK != sqlite3_exec(g_db, query, NULL, 0, &err_msg)) {
if( SQLITE_OK != sqlite3_exec(g_chatlog_database, query, NULL, 0, &err_msg)) {
if (err_msg) {
log_error("SQLite error: %s", err_msg);
sqlite3_free(err_msg);
} else {
log_error("Unknown SQLite error");
}
free(filename);
return FALSE;
}
log_debug("Initialized SQLite database: %s", filename);
free(filename);
return TRUE;
}
void
log_database_close(void)
{
sqlite3_close(g_log_database);
sqlite3_close(g_chatlog_database);
sqlite3_shutdown();
}