diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/cfg_file.h | 1 | ||||
-rw-r--r-- | src/cfg_xml.c | 64 | ||||
-rw-r--r-- | src/main.c | 31 | ||||
-rw-r--r-- | src/main.h | 7 | ||||
-rw-r--r-- | src/protocol.c | 6 |
5 files changed, 73 insertions, 36 deletions
diff --git a/src/cfg_file.h b/src/cfg_file.h index f58c228c7..fc1ba547a 100644 --- a/src/cfg_file.h +++ b/src/cfg_file.h @@ -236,6 +236,7 @@ struct worker_conf { GHashTable *params; /**< params for worker */ GQueue *active_workers; /**< linked list of spawned workers */ gboolean has_socket; /**< whether we should make listening socket in main process */ + gpointer *ctx; /**< worker's context */ }; /** diff --git a/src/cfg_xml.c b/src/cfg_xml.c index 4acc48673..8fad5f03a 100644 --- a/src/cfg_xml.c +++ b/src/cfg_xml.c @@ -826,13 +826,44 @@ options_handle_nameserver (struct config_file *cfg, struct rspamd_xml_userdata * } /* Worker section */ + +struct wrk_cbdata { + struct worker_conf *wrk; + struct config_file *cfg; + struct rspamd_xml_userdata *ctx; +}; + +static void +worker_foreach_callback (gpointer k, gpointer v, gpointer ud) +{ + struct wrk_cbdata *cd = ud; + struct xml_config_param *cparam; + GHashTable *worker_config; + + if (cd->wrk->ctx == NULL) { + cd->wrk->ctx = init_workers_ctx (cd->wrk->type); + } + + if (!worker_options || (worker_config = g_hash_table_lookup (worker_options, &cd->wrk->type)) == NULL || + (cparam = g_hash_table_lookup (worker_config, k)) == NULL) { + msg_warn ("unregistered worker attribute '%s' for worker %s", k, process_to_str (cd->wrk->type)); + } + else { + + if (cd->wrk->ctx != NULL) { + cparam->handler (cd->cfg, cd->ctx, NULL, v, NULL, cd->wrk->ctx, cparam->offset); + } + else { + msg_err ("Bad error detected: module %s has not initialized its context", process_to_str (cd->wrk->type)); + } + } +} + gboolean worker_handle_param (struct config_file *cfg, struct rspamd_xml_userdata *ctx, const gchar *tag, GHashTable *attrs, gchar *data, gpointer user_data, gpointer dest_struct, gint offset) { struct worker_conf *wrk = ctx->section_pointer; const gchar *name; - struct xml_config_param *cparam; - GHashTable *worker_config; if (g_ascii_strcasecmp (tag, "option") == 0 || g_ascii_strcasecmp (tag, "param") == 0) { if (attrs == NULL || (name = g_hash_table_lookup (attrs, "name")) == NULL) { @@ -844,18 +875,11 @@ worker_handle_param (struct config_file *cfg, struct rspamd_xml_userdata *ctx, c name = memory_pool_strdup (cfg->cfg_pool, tag); } - if (!worker_options || - (worker_config = g_hash_table_lookup (worker_options, &wrk->type)) == NULL || - (cparam = g_hash_table_lookup (worker_config, name)) == NULL) { - msg_warn ("unregistered worker attribute '%s' for worker %s", name, process_to_str (wrk->type)); - g_hash_table_insert (wrk->params, (char *)name, memory_pool_strdup (cfg->cfg_pool, data)); - } - else { - return cparam->handler (cfg, ctx, attrs, data, NULL, cparam->user_data, cparam->offset); - } + g_hash_table_insert (wrk->params, (char *)name, memory_pool_strdup (cfg->cfg_pool, data)); return TRUE; } + gboolean worker_handle_type (struct config_file *cfg, struct rspamd_xml_userdata *ctx, GHashTable *attrs, gchar *data, gpointer user_data, gpointer dest_struct, gint offset) { @@ -1764,6 +1788,7 @@ rspamd_xml_end_element (GMarkupParseContext *context, const gchar *element_name, struct statfile *st; gboolean res; gpointer tptr; + struct wrk_cbdata wcd; if (g_ascii_strcasecmp (element_name, "if") == 0) { tptr = g_queue_pop_head (ud->if_stack); @@ -1845,6 +1870,12 @@ rspamd_xml_end_element (GMarkupParseContext *context, const gchar *element_name, case XML_READ_WORKER: CHECK_TAG ("worker", FALSE); if (res) { + /* Parse params */ + wcd.wrk = ud->section_pointer; + wcd.cfg = ud->cfg; + wcd.ctx = ud; + g_hash_table_foreach (wcd.wrk->params, + worker_foreach_callback, &wcd); /* Insert object to list */ ud->cfg->workers = g_list_prepend (ud->cfg->workers, ud->section_pointer); } @@ -2163,17 +2194,6 @@ register_worker_opt (gint wtype, const gchar *optname, element_handler_func func param->name = optname; g_hash_table_insert (worker, (char *)optname, param); } - else { - /* Param already exists replace it */ - msg_warn ("replace old handler for param '%s'", optname); - g_free (param); - param = g_malloc (sizeof (struct xml_config_param)); - param->handler = func; - param->user_data = dest_struct; - param->offset = offset; - param->name = optname; - g_hash_table_insert (worker, (char *)optname, param); - } } /* Register new classifier option */ diff --git a/src/main.c b/src/main.c index 23c67912d..c6055e2de 100644 --- a/src/main.c +++ b/src/main.c @@ -331,7 +331,13 @@ fork_worker (struct rspamd_main *rspamd, struct worker_conf *cf) cur->type = cf->type; cur->pid = fork (); cur->cf = g_malloc (sizeof (struct worker_conf)); - cur->ctx = rspamd->workers_ctx[cf->type]; + /* Copy or init context */ + if (cf->ctx) { + cur->ctx = cf->ctx; + } + else { + cur->ctx = init_workers_ctx (cf->type); + } memcpy (cur->cf, cf, sizeof (struct worker_conf)); cur->pending = FALSE; switch (cur->pid) { @@ -788,13 +794,21 @@ print_symbols_cache (struct config_file *cfg) } } -static void -init_workers_ctx (struct rspamd_main *main) +gpointer +init_workers_ctx (enum process_type type) { - main->workers_ctx[TYPE_WORKER] = init_worker (); - main->workers_ctx[TYPE_CONTROLLER] = init_controller (); - main->workers_ctx[TYPE_FUZZY] = init_fuzzy_storage (); - main->workers_ctx[TYPE_SMTP] = init_smtp_worker (); + switch (type) { + case TYPE_WORKER: + return init_worker (); + case TYPE_CONTROLLER: + return init_controller (); + case TYPE_FUZZY: + return init_fuzzy_storage (); + case TYPE_SMTP: + return init_smtp_worker (); + default: + return NULL; + } } gint @@ -866,9 +880,6 @@ main (gint argc, gchar **argv, gchar **env) counters = rspamd_hash_new_shared (rspamd_main->server_pool, g_str_hash, g_str_equal, 64); /* Init listen sockets hash */ listen_sockets = g_hash_table_new (g_direct_hash, g_direct_equal); - - /* Init contextes */ - init_workers_ctx (rspamd_main); /* Init classifiers options */ register_classifier_opt ("bayes", "min_tokens"); diff --git a/src/main.h b/src/main.h index 6ac24e7ad..812877d15 100644 --- a/src/main.h +++ b/src/main.h @@ -92,8 +92,6 @@ struct rspamd_main { guint ev_initialized; /**< is event system is initialized */ struct rspamd_stat *stat; /**< pointer to statistics */ - gpointer workers_ctx[TYPE_MAX]; /** Array of workers' contexts */ - memory_pool_t *server_pool; /**< server's memory pool */ statfile_pool_t *statfile_pool; /**< shared statfiles pool */ GHashTable *workers; /**< workers pool indexed by pid */ @@ -280,6 +278,11 @@ void start_greylist_storage (struct rspamd_worker *worker); void register_custom_controller_command (const gchar *name, controller_func_t handler, gboolean privilleged, gboolean require_message); /** + * Initialize context for worker of specified type + */ +gpointer init_workers_ctx (enum process_type type); + +/** * If set, reopen log file on next write */ extern struct rspamd_main *rspamd_main; diff --git a/src/protocol.c b/src/protocol.c index fe9621e21..ebca96bc7 100644 --- a/src/protocol.c +++ b/src/protocol.c @@ -582,8 +582,10 @@ parse_header (struct worker_task *task, f_str_t * line) } break; default: - msg_info ("wrong header: %s", headern); - return FALSE; + if (!task->is_http) { + msg_info ("wrong header: %s", headern); + return FALSE; + } } return TRUE; |