diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2018-06-19 17:01:46 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2018-06-19 17:01:46 +0100 |
commit | 5bf6c2c3ab9d103705e41d0a47e96a47946d8aa0 (patch) | |
tree | 8b1844156465f257b30f9d7a54628ecdc71c748f | |
parent | 6c9aa44cf660d804345a6881c7ac6bf66d65b07a (diff) | |
download | rspamd-5bf6c2c3ab9d103705e41d0a47e96a47946d8aa0.tar.gz rspamd-5bf6c2c3ab9d103705e41d0a47e96a47946d8aa0.zip |
[Minor] Allow to tokenize task externally in API
-rw-r--r-- | src/libstat/stat_api.h | 10 | ||||
-rw-r--r-- | src/libstat/stat_process.c | 13 |
2 files changed, 21 insertions, 2 deletions
diff --git a/src/libstat/stat_api.h b/src/libstat/stat_api.h index a4e02a591..1ade4ccd5 100644 --- a/src/libstat/stat_api.h +++ b/src/libstat/stat_api.h @@ -39,6 +39,8 @@ typedef struct rspamd_stat_token_s { guint flags; } rspamd_stat_token_t; +struct rspamd_stat_ctx; + /** * The results of statistics processing: * - error @@ -63,6 +65,14 @@ void rspamd_stat_init (struct rspamd_config *cfg, struct event_base *ev_base); void rspamd_stat_close (void); /** + * Tokenize task + * @param st_ctx + * @param task + */ +void rspamd_stat_process_tokenize (struct rspamd_stat_ctx *st_ctx, + struct rspamd_task *task); + +/** * Classify the task specified and insert symbols if needed * @param task * @param L lua state diff --git a/src/libstat/stat_process.c b/src/libstat/stat_process.c index 4f7f4e703..eb8b8bd7c 100644 --- a/src/libstat/stat_process.c +++ b/src/libstat/stat_process.c @@ -307,7 +307,7 @@ rspamd_stat_tokenize_parts_metadata (struct rspamd_stat_ctx *st_ctx, /* * Tokenize task using the tokenizer specified */ -static void +void rspamd_stat_process_tokenize (struct rspamd_stat_ctx *st_ctx, struct rspamd_task *task) { @@ -322,6 +322,12 @@ rspamd_stat_process_tokenize (struct rspamd_stat_ctx *st_ctx, guchar hout[rspamd_cryptobox_HASHBYTES]; gchar *b32_hout; + if (st_ctx == NULL) { + st_ctx = rspamd_stat_get_ctx (); + } + + g_assert (st_ctx != NULL); + for (i = 0; i < task->text_parts->len; i++) { part = g_ptr_array_index (task->text_parts, i); @@ -409,7 +415,10 @@ rspamd_stat_preprocess (struct rspamd_stat_ctx *st_ctx, struct rspamd_statfile *st; gpointer bk_run; - rspamd_stat_process_tokenize (st_ctx, task); + if (task->tokens == NULL) { + rspamd_stat_process_tokenize (st_ctx, task); + } + task->stat_runtimes = g_ptr_array_sized_new (st_ctx->statfiles->len); g_ptr_array_set_size (task->stat_runtimes, st_ctx->statfiles->len); rspamd_mempool_add_destructor (task->task_pool, |