diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2021-10-19 11:54:34 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2021-10-19 11:54:34 +0100 |
commit | 5aa13cc4161d866ec72974b662f6ec76bdb88c27 (patch) | |
tree | 268655476ff138cff5e2703b4fd34a9750d81ffb /src/libstat/backends/cdb_backend.cxx | |
parent | 8650b54cda050ede64decf6bd61649573f4a071f (diff) | |
download | rspamd-5aa13cc4161d866ec72974b662f6ec76bdb88c27.tar.gz rspamd-5aa13cc4161d866ec72974b662f6ec76bdb88c27.zip |
[Project] Cdb: Finish backend implementation
Diffstat (limited to 'src/libstat/backends/cdb_backend.cxx')
-rw-r--r-- | src/libstat/backends/cdb_backend.cxx | 59 |
1 files changed, 53 insertions, 6 deletions
diff --git a/src/libstat/backends/cdb_backend.cxx b/src/libstat/backends/cdb_backend.cxx index 89d5be9b2..5b5b42cdf 100644 --- a/src/libstat/backends/cdb_backend.cxx +++ b/src/libstat/backends/cdb_backend.cxx @@ -118,6 +118,20 @@ public: auto load_cdb() -> tl::expected<bool, std::string>; auto process_token(const rspamd_token_t *tok) const -> std::optional<float>; + constexpr auto is_spam() const -> bool { + return st->stcf->is_spam; + } + auto get_learns() const -> std::uint64_t { + if (is_spam()) { + return learns_spam; + } + else { + return learns_ham; + } + } + auto get_total_learns() const -> std::uint64_t { + return learns_spam + learns_ham; + } private: struct rspamd_statfile *st; cdb_shared_storage::cdb_element_t db; @@ -230,7 +244,7 @@ ro_backend::process_token(const rspamd_token_t *tok) const -> std::optional<floa if (maybe_value) { auto [spam_count, ham_count] = maybe_value.value(); - if (st->stcf->is_spam) { + if (is_spam()) { return spam_count; } else { @@ -321,6 +335,8 @@ open_cdb(struct rspamd_statfile *st) -> tl::expected<ro_backend, std::string> } +#define CDB_FROM_RAW(p) (reinterpret_cast<rspamd::stat::cdb::ro_backend *>(p)) + /* C exports */ gpointer rspamd_cdb_init(struct rspamd_stat_ctx* ctx, @@ -357,14 +373,42 @@ rspamd_cdb_process_tokens(struct rspamd_task* task, gint id, gpointer ctx) { - return false; + auto *cdbp = CDB_FROM_RAW(ctx); + bool seen_values = false; + + for (auto i = 0u; i < tokens->len; i++) { + rspamd_token_t *tok; + tok = reinterpret_cast<rspamd_token_t *>(g_ptr_array_index(tokens, i)); + + auto res = cdbp->process_token(tok); + + if (res) { + tok->values[id] = res.value(); + seen_values = true; + } + else { + tok->values[id] = 0; + } + } + + if (seen_values) { + if (cdbp->is_spam()) { + task->flags |= RSPAMD_TASK_FLAG_HAS_SPAM_TOKENS; + } + else { + task->flags |= RSPAMD_TASK_FLAG_HAS_HAM_TOKENS; + } + } + + return true; + } gboolean rspamd_cdb_finalize_process(struct rspamd_task* task, gpointer runtime, gpointer ctx) { - return false; + return true; } gboolean rspamd_cdb_learn_tokens(struct rspamd_task* task, @@ -387,7 +431,8 @@ gulong rspamd_cdb_total_learns(struct rspamd_task* task, gpointer runtime, gpointer ctx) { - return 0; + auto *cdbp = CDB_FROM_RAW(ctx); + return cdbp->get_total_learns(); } gulong rspamd_cdb_inc_learns(struct rspamd_task* task, @@ -408,7 +453,8 @@ rspamd_cdb_learns(struct rspamd_task* task, gpointer runtime, gpointer ctx) { - return 0; + auto *cdbp = CDB_FROM_RAW(ctx); + return cdbp->get_learns(); } ucl_object_t* rspamd_cdb_get_stat(gpointer runtime, gpointer ctx) @@ -423,5 +469,6 @@ rspamd_cdb_load_tokenizer_config(gpointer runtime, gsize* len) void rspamd_cdb_close(gpointer ctx) { - + auto *cdbp = CDB_FROM_RAW(ctx); + delete cdbp; }
\ No newline at end of file |