diff options
-rw-r--r-- | config.h.in | 2 | ||||
-rw-r--r-- | src/cfg_file.h | 17 | ||||
-rw-r--r-- | src/cfg_rcl.c | 32 | ||||
-rw-r--r-- | src/cfg_rcl.h | 17 | ||||
-rw-r--r-- | src/cfg_xml.c | 25 |
5 files changed, 67 insertions, 26 deletions
diff --git a/config.h.in b/config.h.in index dd1af0f55..d678e2998 100644 --- a/config.h.in +++ b/config.h.in @@ -494,7 +494,7 @@ typedef struct module_s { typedef struct worker_s { const gchar *name; - gpointer (*worker_init_func)(void); + gpointer (*worker_init_func)(struct config_file *cfg); void (*worker_start_func)(struct rspamd_worker *worker); gboolean has_socket; gboolean unique; diff --git a/src/cfg_file.h b/src/cfg_file.h index bfbc0efa9..89e4870db 100644 --- a/src/cfg_file.h +++ b/src/cfg_file.h @@ -11,7 +11,9 @@ #include "upstream.h" #include "memcached.h" #include "symbols_cache.h" +#include "cfg_rcl.h" #include "utlist.h" +#include "rcl/rcl.h" #define DEFAULT_BIND_PORT 768 #define DEFAULT_CONTROL_PORT 7608 @@ -253,6 +255,19 @@ struct rspamd_worker_bind_conf { struct rspamd_worker_bind_conf *next; }; +struct rspamd_worker_param_parser { + rspamd_rcl_handler_t handler; /**< handler function */ + struct rspamd_rcl_struct_parser parser; /**< parser attributes */ + const gchar *name; /**< parameter's name */ + UT_hash_handle hh; /**< hash by name */ +}; + +struct rspamd_worker_cfg_parser { + struct rspamd_worker_param_parser *parsers; /**< parsers hash */ + gint type; /**< workers quark */ + UT_hash_handle hh; /**< hash by type */ +}; + /** * Config params for rspamd worker */ @@ -268,6 +283,7 @@ struct worker_conf { 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 */ + rspamd_cl_object_t *options; /**< other worker's options */ }; /** @@ -330,6 +346,7 @@ struct config_file { GList *filters; /**< linked list of all filters */ GList *workers; /**< linked list of all workers params */ + struct rspamd_worker_cfg_parser *wrk_parsers; /**< hash for worker config parsers, indexed by worker quarks */ gchar *filters_str; /**< string of filters */ GHashTable* modules_opts; /**< hash for module options indexed by module name */ GHashTable* modules_metas; /**< hash for module meta options indexed by module name*/ diff --git a/src/cfg_rcl.c b/src/cfg_rcl.c index 70f51f8cd..5c27a2516 100644 --- a/src/cfg_rcl.c +++ b/src/cfg_rcl.c @@ -388,7 +388,7 @@ rspamd_rcl_worker_handler (struct config_file *cfg, rspamd_cl_object_t *obj, } wrk->type = qtype; if (wrk->worker->worker_init_func) { - wrk->ctx = wrk->worker->worker_init_func (); + wrk->ctx = wrk->worker->worker_init_func (cfg); } } else { @@ -897,3 +897,33 @@ rspamd_rcl_parse_struct_boolean (struct config_file *cfg, rspamd_cl_object_t *ob return TRUE; } + +void +rspamd_rcl_register_worker_option (struct config_file *cfg, gint type, const gchar *name, + rspamd_rcl_handler_t handler, gpointer target, gsize offset, gint flags) +{ + struct rspamd_worker_param_parser *nhandler; + struct rspamd_worker_cfg_parser *nparser; + + HASH_FIND_INT (cfg->wrk_parsers, &type, nparser); + if (nparser == NULL) { + /* Allocate new parser for this worker */ + nparser = memory_pool_alloc0 (cfg->cfg_pool, sizeof (struct rspamd_worker_cfg_parser)); + nparser->type = type; + HASH_ADD_INT (cfg->wrk_parsers, type, nparser); + } + + HASH_FIND_STR (nparser->parsers, name, nhandler); + if (nhandler != NULL) { + msg_warn ("handler for parameter %s is already registered for worker type %s", + name, g_quark_to_string (type)); + return; + } + nhandler = memory_pool_alloc0 (cfg->cfg_pool, sizeof (struct rspamd_worker_param_parser)); + nhandler->name = name; + nhandler->parser.flags = flags; + nhandler->parser.offset = offset; + nhandler->parser.user_struct = target; + nhandler->handler = handler; + HASH_ADD_STR (nparser->parsers, name, nhandler); +} diff --git a/src/cfg_rcl.h b/src/cfg_rcl.h index 223431d79..1b19783cf 100644 --- a/src/cfg_rcl.h +++ b/src/cfg_rcl.h @@ -26,7 +26,6 @@ #include "config.h" #include "rcl/rcl.h" -#include "main.h" #define CFG_RCL_ERROR cfg_rcl_error_quark () static inline GQuark @@ -36,6 +35,7 @@ cfg_rcl_error_quark (void) } struct rspamd_rcl_section; +struct config_file; struct rspamd_rcl_struct_parser { gpointer user_struct; @@ -198,4 +198,19 @@ gboolean rspamd_rcl_parse_struct_string_list (struct config_file *cfg, rspamd_cl gboolean rspamd_rcl_parse_struct_boolean (struct config_file *cfg, rspamd_cl_object_t *obj, gpointer ud, struct rspamd_rcl_section *section, GError **err); +/** + * Utility functions + */ + +/** + * Register new parser for a worker type of an option with the specified name + * @param cfg config structure + * @param type type of worker (GQuark) + * @param name name of option + * @param handler handler of option + * @param target opaque target structure + * @param offset offset inside a structure + */ +void rspamd_rcl_register_worker_option (struct config_file *cfg, gint type, const gchar *name, + rspamd_rcl_handler_t handler, gpointer target, gsize offset, gint flags); #endif /* CFG_RCL_H_ */ diff --git a/src/cfg_xml.c b/src/cfg_xml.c index fc7245390..215371f2f 100644 --- a/src/cfg_xml.c +++ b/src/cfg_xml.c @@ -1022,7 +1022,7 @@ worker_handle_type (struct config_file *cfg, struct rspamd_xml_userdata *ctx, GH } wrk->type = type; if (wrk->worker->worker_init_func) { - wrk->ctx = wrk->worker->worker_init_func (); + wrk->ctx = wrk->worker->worker_init_func (cfg); } } else { @@ -2525,28 +2525,7 @@ register_module_opt (const gchar *mname, const gchar *optname, enum module_opt_t void register_worker_opt (gint wtype, const gchar *optname, element_handler_func func, gpointer dest_struct, gint offset) { - struct xml_config_param *param; - GHashTable *worker; - gint *new_key; - - if (worker_options == NULL) { - worker_options = g_hash_table_new (g_int_hash, g_int_equal); - } - if ((worker = g_hash_table_lookup (worker_options, &wtype)) == NULL) { - worker = g_hash_table_new (rspamd_str_hash, rspamd_str_equal); - new_key = g_malloc (sizeof (gint)); - *new_key = wtype; - g_hash_table_insert (worker_options, new_key, worker); - } - if ((param = g_hash_table_lookup (worker, optname)) == NULL) { - /* Register new 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); - } + msg_err ("this function is depreciated and must not be used"); } /* Register new classifier option */ |