aboutsummaryrefslogtreecommitdiffstats
path: root/src/libstat/backends
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2017-06-05 14:24:12 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2017-06-05 14:24:12 +0100
commita7b93b3828a859f09b35fcec29a2553e73b41942 (patch)
treef77fec31462d1bc5e138c60dfb9a1cff57b19bde /src/libstat/backends
parent5d55f0179c6c6b1655e174a4f30f8396bcea8cd7 (diff)
downloadrspamd-a7b93b3828a859f09b35fcec29a2553e73b41942.tar.gz
rspamd-a7b93b3828a859f09b35fcec29a2553e73b41942.zip
[Minor] Fix store_tokens in new bayes layout
Diffstat (limited to 'src/libstat/backends')
-rw-r--r--src/libstat/backends/redis_backend.c63
1 files changed, 43 insertions, 20 deletions
diff --git a/src/libstat/backends/redis_backend.c b/src/libstat/backends/redis_backend.c
index 7f76eb831..ef6448a00 100644
--- a/src/libstat/backends/redis_backend.c
+++ b/src/libstat/backends/redis_backend.c
@@ -444,7 +444,7 @@ rspamd_redis_tokens_to_query (struct rspamd_task *task,
"%s\r\n",
cmd_len, command,
l0, n0,
- 1, rt->stcf->is_spam ? "1" : "0",
+ 1, rt->stcf->is_spam ? "S" : "H",
l1, n1);
}
else {
@@ -499,25 +499,48 @@ rspamd_redis_tokens_to_query (struct rspamd_task *task,
}
if (rt->ctx->store_tokens) {
- /*
- * We also store tokens in form
- * HSET arg0_keys <token_id> "token_string"
- * ZINCRBY arg0_zlist <token_id> 1.0
- */
- if (tok->t1 && tok->t2) {
- redisAsyncCommand (rt->redis, NULL, NULL,
- "HSET %b_tokens %b %b:%b",
- prefix, (size_t)prefix_len,
- n0, (size_t)l0,
- tok->t1->begin, tok->t1->len,
- tok->t2->begin, tok->t2->len);
+
+ if (!rt->ctx->new_schema) {
+ /*
+ * We store tokens in form
+ * HSET prefix_tokens <token_id> "token_string"
+ * ZINCRBY prefix_z 1.0 <token_id>
+ */
+ if (tok->t1 && tok->t2) {
+ redisAsyncCommand (rt->redis, NULL, NULL,
+ "HSET %b_tokens %b %b:%b",
+ prefix, (size_t) prefix_len,
+ n0, (size_t) l0,
+ tok->t1->begin, tok->t1->len,
+ tok->t2->begin, tok->t2->len);
+ } else if (tok->t1) {
+ redisAsyncCommand (rt->redis, NULL, NULL,
+ "HSET %b_tokens %b %b",
+ prefix, (size_t) prefix_len,
+ n0, (size_t) l0,
+ tok->t1->begin, tok->t1->len);
+ }
}
- else if (tok->t1) {
- redisAsyncCommand (rt->redis, NULL, NULL,
- "HSET %b_tokens %b %b",
- prefix, (size_t)prefix_len,
- n0, (size_t)l0,
- tok->t1->begin, tok->t1->len);
+ else {
+ /*
+ * We store tokens in form
+ * HSET <token_id> "tokens" "token_string"
+ * ZINCRBY prefix_z 1.0 <token_id>
+ */
+ if (tok->t1 && tok->t2) {
+ redisAsyncCommand (rt->redis, NULL, NULL,
+ "HSET %b %s %b:%b",
+ n0, (size_t) l0,
+ "tokens",
+ tok->t1->begin, tok->t1->len,
+ tok->t2->begin, tok->t2->len);
+ } else if (tok->t1) {
+ redisAsyncCommand (rt->redis, NULL, NULL,
+ "HSET %b %s %b",
+ n0, (size_t) l0,
+ "tokens",
+ tok->t1->begin, tok->t1->len);
+ }
}
redisAsyncCommand (rt->redis, NULL, NULL,
@@ -546,7 +569,7 @@ rspamd_redis_tokens_to_query (struct rspamd_task *task,
"%s\r\n",
cmd_len, command,
l0, n0,
- 1, rt->stcf->is_spam ? "1" : "0");
+ 1, rt->stcf->is_spam ? "S" : "H");
ret = redisAsyncFormattedCommand (rt->redis, NULL, NULL,
out->str, out->len);