diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-09-28 10:40:43 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-09-28 10:40:43 +0100 |
commit | 762aeb28d3086386baf6b87bf8fb35198757aeec (patch) | |
tree | 6261e503616a4af3bb126b3904baca4ef4623871 /src | |
parent | c698e465d766a9c48014150ebb96a7f92aee7cca (diff) | |
download | rspamd-762aeb28d3086386baf6b87bf8fb35198757aeec.tar.gz rspamd-762aeb28d3086386baf6b87bf8fb35198757aeec.zip |
Enable foreign keys in sqlite3.
Diffstat (limited to 'src')
-rw-r--r-- | src/libserver/fuzzy_backend.c | 8 | ||||
-rw-r--r-- | src/libutil/sqlite_utils.c | 9 |
2 files changed, 15 insertions, 2 deletions
diff --git a/src/libserver/fuzzy_backend.c b/src/libserver/fuzzy_backend.c index ce6bd6a5a..016ee2b5a 100644 --- a/src/libserver/fuzzy_backend.c +++ b/src/libserver/fuzzy_backend.c @@ -408,7 +408,8 @@ rspamd_fuzzy_backend_open (const gchar *path, GError **err) gint fd; struct rspamd_fuzzy_backend *backend; static const char sqlite_wal[] = "PRAGMA journal_mode=\"wal\";", - fallback_journal[] = "PRAGMA journal_mode=\"off\";"; + fallback_journal[] = "PRAGMA journal_mode=\"off\";", + foreign_keys[] = "PRAGMA foreign_keys=\"ON\";"; int rc; if (path == NULL) { @@ -466,6 +467,11 @@ rspamd_fuzzy_backend_open (const gchar *path, GError **err) sqlite3_exec (backend->db, fallback_journal, NULL, NULL, NULL); } + if ((rc = sqlite3_exec (backend->db, foreign_keys, NULL, NULL, NULL)) != + SQLITE_OK) { + msg_warn_fuzzy_backend ("foreign keys are not supported", rc); + } + /* Cleanup database */ rspamd_fuzzy_backend_run_simple (RSPAMD_FUZZY_BACKEND_VACUUM, backend, NULL); diff --git a/src/libutil/sqlite_utils.c b/src/libutil/sqlite_utils.c index 0dea2edc2..d677a0dc2 100644 --- a/src/libutil/sqlite_utils.c +++ b/src/libutil/sqlite_utils.c @@ -249,7 +249,8 @@ rspamd_sqlite3_open_or_create (rspamd_mempool_t *pool, const gchar *path, const gchar lock_path[PATH_MAX], dbdir[PATH_MAX], *pdir; static const char sqlite_wal[] = "PRAGMA journal_mode=\"wal\";", exclusive_lock_sql[] = "PRAGMA locking_mode=\"exclusive\";", - fsync_sql[] = "PRAGMA synchronous=1;"; + fsync_sql[] = "PRAGMA synchronous=1;", + foreign_keys[] = "PRAGMA foreign_keys=\"ON\";"; gboolean create = FALSE, has_lock = FALSE; flags = SQLITE_OPEN_READWRITE; @@ -377,6 +378,12 @@ rspamd_sqlite3_open_or_create (rspamd_mempool_t *pool, const gchar *path, const sqlite3_errmsg (sqlite)); } + if ((rc = sqlite3_exec (sqlite, foreign_keys, NULL, NULL, NULL)) != + SQLITE_OK) { + msg_warn_pool ("cannot enable foreign keys: %s", + sqlite3_errmsg (sqlite)); + } + if (has_lock) { msg_debug_pool ("removing lock from %s", lock_path); rspamd_file_unlock (lock_fd, FALSE); |