142 lines
3.9 KiB
C
142 lines
3.9 KiB
C
|
#ifndef DB_UTILS_H
|
||
|
#define DB_UTILS_H
|
||
|
|
||
|
#include <sqlite3.h>
|
||
|
#include <json-c/json.h>
|
||
|
#include "utils.h"
|
||
|
|
||
|
const char * db_file = "~/.r.db";
|
||
|
|
||
|
char * db_file_expanded(){
|
||
|
char * expanded = expand_home_directory(db_file);
|
||
|
static char result[4096];
|
||
|
result[0] = 0;
|
||
|
strcpy(result, expanded);
|
||
|
free(expanded);
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
void db_initialize();
|
||
|
json_object * db_set(const char *key, const char *value);
|
||
|
json_object* db_get(const char *key);
|
||
|
json_object* db_query(const char *query);
|
||
|
|
||
|
|
||
|
void db_initialize() {
|
||
|
sqlite3 *db;
|
||
|
char *err_msg = 0;
|
||
|
int rc = sqlite3_open(db_file_expanded(), &db);
|
||
|
|
||
|
if (rc != SQLITE_OK) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
const char *sql = "CREATE TABLE IF NOT EXISTS kv_store (key TEXT PRIMARY KEY, value TEXT);";
|
||
|
rc = sqlite3_exec(db, sql, 0, 0, &err_msg);
|
||
|
|
||
|
if (rc != SQLITE_OK) {
|
||
|
sqlite3_free(err_msg);
|
||
|
}
|
||
|
|
||
|
sqlite3_close(db);
|
||
|
}
|
||
|
|
||
|
|
||
|
json_object * db_set(const char *key, const char *value) {
|
||
|
sqlite3 *db;
|
||
|
char *err_msg = 0;
|
||
|
int rc = sqlite3_open(db_file_expanded(), &db);
|
||
|
|
||
|
if (rc != SQLITE_OK) {
|
||
|
return NULL;
|
||
|
}
|
||
|
|
||
|
char *sql = sqlite3_mprintf("INSERT INTO kv_store (key, value) VALUES (%Q, %Q)", key, value);
|
||
|
rc = sqlite3_exec(db, sql, 0, 0, &err_msg);
|
||
|
sqlite3_free(sql);
|
||
|
|
||
|
if (rc != SQLITE_OK) {
|
||
|
sqlite3_free(err_msg);
|
||
|
sqlite3_close(db);
|
||
|
return NULL;
|
||
|
}
|
||
|
|
||
|
sqlite3_close(db);
|
||
|
return json_object_new_string("Success");
|
||
|
}
|
||
|
|
||
|
json_object* db_get(const char *key) {
|
||
|
sqlite3 *db;
|
||
|
sqlite3_stmt *stmt;
|
||
|
json_object *result = json_object_new_object();
|
||
|
const char *value = NULL;
|
||
|
|
||
|
int rc = sqlite3_open(db_file_expanded(), &db);
|
||
|
if (rc != SQLITE_OK) {
|
||
|
return NULL;
|
||
|
}
|
||
|
|
||
|
const char *sql = "SELECT value FROM kv_store WHERE key = ?";
|
||
|
sqlite3_prepare_v2(db, sql, -1, &stmt, NULL);
|
||
|
sqlite3_bind_text(stmt, 1, key, -1, SQLITE_STATIC);
|
||
|
|
||
|
if (sqlite3_step(stmt) == SQLITE_ROW) {
|
||
|
value = (const char *)sqlite3_column_text(stmt, 0);
|
||
|
}
|
||
|
|
||
|
if (value) {
|
||
|
json_object_object_add(result, "value", json_object_new_string(value));
|
||
|
} else {
|
||
|
json_object_object_add(result, "error", json_object_new_string("Key not found"));
|
||
|
}
|
||
|
|
||
|
sqlite3_finalize(stmt);
|
||
|
sqlite3_close(db);
|
||
|
return result;
|
||
|
}
|
||
|
json_object* db_query(const char *query) {
|
||
|
sqlite3 *db;
|
||
|
sqlite3_stmt *stmt;
|
||
|
json_object *result = json_object_new_array();
|
||
|
|
||
|
int rc = sqlite3_open(db_file_expanded(), &db);
|
||
|
if (rc != SQLITE_OK) {
|
||
|
return NULL;
|
||
|
}
|
||
|
|
||
|
sqlite3_prepare_v2(db, query, -1, &stmt, NULL);
|
||
|
while (sqlite3_step(stmt) == SQLITE_ROW) {
|
||
|
json_object *row = json_object_new_object();
|
||
|
for (int i = 0; i < sqlite3_column_count(stmt); i++) {
|
||
|
const char *col_name = sqlite3_column_name(stmt, i);
|
||
|
switch (sqlite3_column_type(stmt, i)) {
|
||
|
case SQLITE_INTEGER:
|
||
|
json_object_object_add(row, col_name, json_object_new_int64(sqlite3_column_int64(stmt, i)));
|
||
|
break;
|
||
|
case SQLITE_FLOAT:
|
||
|
json_object_object_add(row, col_name, json_object_new_double(sqlite3_column_double(stmt, i)));
|
||
|
break;
|
||
|
case SQLITE_TEXT:
|
||
|
json_object_object_add(row, col_name, json_object_new_string((const char *)sqlite3_column_text(stmt, i)));
|
||
|
break;
|
||
|
case SQLITE_BLOB:
|
||
|
json_object_object_add(row, col_name, json_object_new_string_len((const char *)sqlite3_column_blob(stmt, i), sqlite3_column_bytes(stmt, i)));
|
||
|
break;
|
||
|
case SQLITE_NULL:
|
||
|
default:
|
||
|
json_object_object_add(row, col_name, json_object_new_string("NULL"));
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
json_object_array_add(result, row);
|
||
|
}
|
||
|
|
||
|
sqlite3_finalize(stmt);
|
||
|
sqlite3_close(db);
|
||
|
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
|
||
|
#endif // DB_UTILS_H
|