aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2014-12-19 15:45:11 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2014-12-19 15:45:11 +0000
commitcb2b69d24c8ca1ab987956717b9076ae43c4fee2 (patch)
tree2c586ac1316605d7b16f28695134c1baedb7f340
parentb26afb57c80333a9b5a68a31d613bed32e2c6796 (diff)
downloadrspamd-cb2b69d24c8ca1ab987956717b9076ae43c4fee2.tar.gz
rspamd-cb2b69d24c8ca1ab987956717b9076ae43c4fee2.zip
Add backend open.
-rw-r--r--src/fuzzy_storage.c3
-rw-r--r--src/libserver/fuzzy_backend.c75
2 files changed, 72 insertions, 6 deletions
diff --git a/src/fuzzy_storage.c b/src/fuzzy_storage.c
index 41e844ff2..e4b0b4e6c 100644
--- a/src/fuzzy_storage.c
+++ b/src/fuzzy_storage.c
@@ -54,8 +54,7 @@
#define MAX_RETRIES 40
/* Weight of hash to consider it frequent */
#define DEFAULT_FREQUENT_SCORE 100
-/* Magic sequence for hashes file */
-#define FUZZY_FILE_MAGIC "rsh"
+
/* Current version of fuzzy hash file format */
#define CURRENT_FUZZY_VERSION 1
diff --git a/src/libserver/fuzzy_backend.c b/src/libserver/fuzzy_backend.c
index 17f0eb802..9bdf9fc1c 100644
--- a/src/libserver/fuzzy_backend.c
+++ b/src/libserver/fuzzy_backend.c
@@ -26,14 +26,81 @@
#include "fuzzy_backend.h"
#include "fuzzy_storage.h"
+#include <sqlite3.h>
-struct rspamd_fuzzy_backend;
+/* Magic sequence for hashes file */
+#define FUZZY_FILE_MAGIC "rsh"
-struct
-rspamd_fuzzy_backend* rspamd_fuzzy_backend_open (const gchar *path,
- GError **err)
+struct rspamd_fuzzy_backend {
+ sqlite3 *db;
+ const char *path;
+};
+
+static GQuark
+rspamd_fuzzy_backend_quark(void)
{
+ return g_quark_from_static_string ("fuzzy-storage-backend");
+}
+struct rspamd_fuzzy_backend*
+rspamd_fuzzy_backend_open (const gchar *path, GError **err)
+{
+ gchar *dir, header[4];
+ gint fd, r;
+ struct rspamd_fuzzy_backend *res;
+
+ /* First of all we check path for existence */
+ dir = g_path_get_dirname (path);
+ if (dir == NULL) {
+ g_set_error (err, rspamd_fuzzy_backend_quark (),
+ errno, "Cannot get directory name for %s: %s", path,
+ strerror (errno));
+ return NULL;
+ }
+
+ if (access (path, W_OK) == -1 && access (dir, W_OK) == -1) {
+ g_set_error (err, rspamd_fuzzy_backend_quark (),
+ errno, "Cannot access directory %s to create database: %s",
+ dir, strerror (errno));
+ g_free (dir);
+
+ return NULL;
+ }
+
+ g_free (dir);
+ if ((fd = open (path, O_RDONLY)) == -1) {
+ g_set_error (err, rspamd_fuzzy_backend_quark (),
+ errno, "Cannot open file %s: %s",
+ path, strerror (errno));
+
+ return NULL;
+ }
+
+ /* Check for legacy format */
+ if ((r = read (fd, header, sizeof (header))) == sizeof (header)) {
+ if (memcmp (header, FUZZY_FILE_MAGIC, sizeof (header) - 1) == 0) {
+ msg_info ("Trying to convert old fuzzy database");
+ if (!rspamd_fuzzy_backend_convert (fd, err)) {
+ close (fd);
+ return NULL;
+ }
+ }
+ close (fd);
+ }
+
+ /* Open database */
+ if ((res = rspamd_fuzzy_backend_open_db (path, err)) == NULL) {
+ GError *tmp = NULL;
+
+ if ((res = rspamd_fuzzy_backend_create_db (path, tmp)) == NULL) {
+ g_clear_error (err);
+ g_propagate_error (err, tmp);
+ return NULL;
+ }
+ g_clear_error (err);
+ }
+
+ return res;
}
struct rspamd_fuzzy_reply