diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2014-12-20 13:40:35 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2014-12-20 13:40:35 +0000 |
commit | eda0029062ca38641a59674987873811742f08f8 (patch) | |
tree | 85f05d995cd0424108a303b7aa0c238a80d92cbf /src/libserver/fuzzy_backend.c | |
parent | b0b003e18e947d33186746fc989216dc55918f61 (diff) | |
download | rspamd-eda0029062ca38641a59674987873811742f08f8.tar.gz rspamd-eda0029062ca38641a59674987873811742f08f8.zip |
Implement direct checking.
Diffstat (limited to 'src/libserver/fuzzy_backend.c')
-rw-r--r-- | src/libserver/fuzzy_backend.c | 46 |
1 files changed, 39 insertions, 7 deletions
diff --git a/src/libserver/fuzzy_backend.c b/src/libserver/fuzzy_backend.c index c70afb445..0b78b2ac0 100644 --- a/src/libserver/fuzzy_backend.c +++ b/src/libserver/fuzzy_backend.c @@ -107,7 +107,7 @@ static struct rspamd_fuzzy_stmts { .idx = RSPAMD_FUZZY_BACKEND_INSERT, .sql = "INSERT INTO digests(flag, digest, value, time) VALUES" "(?1, ?2, ?3, ?4);", - .args = "STII", + .args = "SDII", .stmt = NULL, .result = SQLITE_DONE }, @@ -121,8 +121,8 @@ static struct rspamd_fuzzy_stmts { }, { .idx = RSPAMD_FUZZY_BACKEND_CHECK, - .sql = "SELECT * FROM digests WHERE digest==?1 AND flag==?2;", - .args = "TI", + .sql = "SELECT value, time FROM digests WHERE digest==?1 AND flag==?2;", + .args = "DS", .stmt = NULL, .result = SQLITE_ROW }, @@ -135,8 +135,8 @@ static struct rspamd_fuzzy_stmts { }, { .idx = RSPAMD_FUZZY_BACKEND_DELETE, - .sql = "", - .args = "", + .sql = "DELETE FROM digests WHERE digest==?1 AND flag==?2;", + .args = "DS", .stmt = NULL, .result = SQLITE_DONE } @@ -205,7 +205,7 @@ rspamd_fuzzy_backend_run_stmt (struct rspamd_fuzzy_backend *bk, int idx, ...) for (i = 0; argtypes[i] != '\0'; i++) { switch (argtypes[i]) { case 'T': - sqlite3_bind_text(stmt, i + 1, va_arg (ap, const char*), -1, + sqlite3_bind_text (stmt, i + 1, va_arg (ap, const char*), -1, SQLITE_STATIC); break; case 'I': @@ -214,6 +214,11 @@ rspamd_fuzzy_backend_run_stmt (struct rspamd_fuzzy_backend *bk, int idx, ...) case 'S': sqlite3_bind_int (stmt, i + 1, va_arg (ap, gint)); break; + case 'D': + /* Special case for digests variable */ + sqlite3_bind_text (stmt, i + 1, va_arg (ap, const char*), 64, + SQLITE_STATIC); + break; } } @@ -471,9 +476,36 @@ rspamd_fuzzy_backend_open (const gchar *path, GError **err) struct rspamd_fuzzy_reply rspamd_fuzzy_backend_check (struct rspamd_fuzzy_backend *backend, - const struct rspamd_fuzzy_cmd *cmd) + const struct rspamd_fuzzy_cmd *cmd, gint64 expire) { + struct rspamd_fuzzy_reply rep = {0, 0.0}; + const struct rspamd_fuzzy_shingle_cmd *shcmd; + int rc; + gint64 timestamp; + + /* Try direct match first of all */ + rc = rspamd_fuzzy_backend_run_stmt (backend, RSPAMD_FUZZY_BACKEND_CHECK, + cmd->digest, cmd->flag); + + if (rc == SQLITE_OK) { + timestamp = sqlite3_column_int64 ( + prepared_stmts[RSPAMD_FUZZY_BACKEND_CHECK].stmt, 1); + if (time (NULL) - timestamp > expire) { + /* Expire element */ + rspamd_fuzzy_backend_run_stmt (backend, RSPAMD_FUZZY_BACKEND_DELETE, + cmd->digest, cmd->flag); + } + else { + rep.value = sqlite3_column_int64 ( + prepared_stmts[RSPAMD_FUZZY_BACKEND_CHECK].stmt, 0); + rep.prob = 1.0; + } + } + else if (cmd->shingles_count > 0) { + /* Fuzzy match */ + } + return rep; } gboolean |