aboutsummaryrefslogtreecommitdiffstats
path: root/src/cfg_file.y
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@rambler-co.ru>2009-06-17 19:31:48 +0400
committerVsevolod Stakhov <vsevolod@rambler-co.ru>2009-06-17 19:31:48 +0400
commitbca226772e9747a4587866a50122d4a8f7973b26 (patch)
treeaae459617c9b3a7a82dd0b9e2a8b03be11e3ff52 /src/cfg_file.y
parent453ecf68e3b51941944dbc3b1dece11342be3810 (diff)
downloadrspamd-bca226772e9747a4587866a50122d4a8f7973b26.tar.gz
rspamd-bca226772e9747a4587866a50122d4a8f7973b26.zip
* Introduce new system of workers spawning and configuring, now rspamd can be easily extended by new types of wrokers
* Rework config system and avoid from using queue (3) lists * Upgrade version to 0.2.0 as config format is now incompatible with older one
Diffstat (limited to 'src/cfg_file.y')
-rw-r--r--src/cfg_file.y293
1 files changed, 136 insertions, 157 deletions
diff --git a/src/cfg_file.y b/src/cfg_file.y
index e4e4d8dbe..0062cdeea 100644
--- a/src/cfg_file.y
+++ b/src/cfg_file.y
@@ -13,15 +13,17 @@
#else
#include "perl.h"
#endif
+#define YYDEBUG 1
extern struct config_file *cfg;
extern int yylineno;
extern char *yytext;
-LIST_HEAD (moduleoptq, module_opt) *cur_module_opt = NULL;
+GList *cur_module_opt = NULL;
struct metric *cur_metric = NULL;
struct statfile *cur_statfile = NULL;
struct statfile_section *cur_section = NULL;
+struct worker_conf *cur_worker = NULL;
%}
@@ -41,14 +43,14 @@ struct statfile_section *cur_section = NULL;
%token MAXSIZE SIZELIMIT SECONDS BEANSTALK MYSQL USER PASSWORD DATABASE
%token TEMPDIR PIDFILE SERVERS ERROR_TIME DEAD_TIME MAXERRORS CONNECT_TIMEOUT PROTOCOL RECONNECT_TIMEOUT
%token READ_SERVERS WRITE_SERVER DIRECTORY_SERVERS MAILBOX_QUERY USERS_QUERY LASTLOGIN_QUERY
-%token MEMCACHED WORKERS REQUIRE MODULE
+%token MEMCACHED WORKER TYPE REQUIRE MODULE
%token MODULE_OPT PARAM VARIABLE
%token HEADER_FILTERS MIME_FILTERS MESSAGE_FILTERS URL_FILTERS FACTORS METRIC NAME
%token REQUIRED_SCORE FUNCTION FRACT COMPOSITES CONTROL PASSWORD
%token LOGGING LOG_TYPE LOG_TYPE_CONSOLE LOG_TYPE_SYSLOG LOG_TYPE_FILE
%token LOG_LEVEL LOG_LEVEL_DEBUG LOG_LEVEL_INFO LOG_LEVEL_WARNING LOG_LEVEL_ERROR LOG_FACILITY LOG_FILENAME
%token STATFILE ALIAS PATTERN WEIGHT STATFILE_POOL_SIZE SIZE TOKENIZER CLASSIFIER
-%token DELIVERY LMTP ENABLED AGENT SECTION LUACODE RAW_MODE PROFILE_FILE
+%token DELIVERY LMTP ENABLED AGENT SECTION LUACODE RAW_MODE PROFILE_FILE COUNT
%type <string> STRING
%type <string> VARIABLE
@@ -71,12 +73,10 @@ file : /* empty */
;
command :
- bindsock
- | control
| tempdir
| pidfile
| memcached
- | workers
+ | worker
| require
| header_filters
| mime_filters
@@ -90,8 +90,6 @@ command :
| logging
| statfile
| statfile_pool_size
- | lmtp
- | delivery
| luacode
| raw_mode
| profile_file
@@ -120,63 +118,6 @@ pidfile :
}
;
-control:
- CONTROL OBRACE controlbody EBRACE
- ;
-
-controlbody:
- controlcmd SEMICOLON
- | controlbody controlcmd SEMICOLON
- ;
-
-controlcmd:
- controlsock
- | controlpassword
- ;
-
-controlsock:
- BINDSOCK EQSIGN bind_cred {
- if (!parse_bind_line (cfg, $3, CRED_CONTROL)) {
- yyerror ("yyparse: parse_bind_line");
- YYERROR;
- }
- cfg->controller_enabled = 1;
- free ($3);
- }
- ;
-controlpassword:
- PASSWORD EQSIGN QUOTEDSTRING {
- cfg->control_password = memory_pool_strdup (cfg->cfg_pool, $3);
- }
- ;
-
-bindsock:
- BINDSOCK EQSIGN bind_cred {
- if (!parse_bind_line (cfg, $3, CRED_NORMAL)) {
- yyerror ("yyparse: parse_bind_line");
- YYERROR;
- }
- free ($3);
- }
- ;
-
-bind_cred:
- STRING {
- $$ = $1;
- }
- | IPADDR{
- $$ = $1;
- }
- | DOMAINNAME {
- $$ = $1;
- }
- | HOSTPORT {
- $$ = $1;
- }
- | QUOTEDSTRING {
- $$ = $1;
- }
- ;
header_filters:
HEADER_FILTERS EQSIGN QUOTEDSTRING {
@@ -283,12 +224,137 @@ memcached_protocol:
}
}
;
-workers:
- WORKERS EQSIGN NUMBER {
- cfg->workers_number = $3;
+
+/* Workers section */
+worker:
+ WORKER OBRACE workerbody EBRACE {
+ cfg->workers = g_list_prepend (cfg->workers, cur_worker);
+ cur_worker = NULL;
+ }
+ ;
+
+workerbody:
+ workercmd SEMICOLON
+ | workerbody workercmd SEMICOLON
+ ;
+
+workercmd:
+ | bindsock
+ | workertype
+ | workercount
+ | workerparam
+ ;
+
+bindsock:
+ BINDSOCK EQSIGN bind_cred {
+ if (cur_worker == NULL) {
+ cur_worker = memory_pool_alloc0 (cfg->cfg_pool, sizeof (struct worker_conf));
+ cur_worker->params = g_hash_table_new (g_str_hash, g_str_equal);
+ memory_pool_add_destructor (cfg->cfg_pool, (pool_destruct_func)g_hash_table_destroy, cur_worker->params);
+#ifdef HAVE_SC_NPROCESSORS_ONLN
+ cur_worker->count = sysconf (_SC_NPROCESSORS_ONLN);
+#else
+ cur_worker->count = DEFAULT_WORKERS_NUM;
+#endif
+ }
+
+ if (!parse_bind_line (cfg, cur_worker, $3)) {
+ yyerror ("yyparse: parse_bind_line");
+ YYERROR;
+ }
+ free ($3);
+ }
+ ;
+
+bind_cred:
+ STRING {
+ $$ = $1;
+ }
+ | IPADDR{
+ $$ = $1;
+ }
+ | DOMAINNAME {
+ $$ = $1;
+ }
+ | HOSTPORT {
+ $$ = $1;
+ }
+ | QUOTEDSTRING {
+ $$ = $1;
+ }
+ ;
+
+workertype:
+ TYPE EQSIGN QUOTEDSTRING {
+ if (cur_worker == NULL) {
+ cur_worker = memory_pool_alloc0 (cfg->cfg_pool, sizeof (struct worker_conf));
+ cur_worker->params = g_hash_table_new (g_str_hash, g_str_equal);
+ memory_pool_add_destructor (cfg->cfg_pool, (pool_destruct_func)g_hash_table_destroy, cur_worker->params);
+#ifdef HAVE_SC_NPROCESSORS_ONLN
+ cur_worker->count = sysconf (_SC_NPROCESSORS_ONLN);
+#else
+ cur_worker->count = DEFAULT_WORKERS_NUM;
+#endif
+ }
+
+ if (g_ascii_strcasecmp ($3, "normal") == 0) {
+ cur_worker->type = TYPE_WORKER;
+ }
+ else if (g_ascii_strcasecmp ($3, "controller") == 0) {
+ cur_worker->type = TYPE_CONTROLLER;
+ }
+ else if (g_ascii_strcasecmp ($3, "lmtp") == 0) {
+ cur_worker->type = TYPE_LMTP;
+ }
+ else if (g_ascii_strcasecmp ($3, "fuzzy") == 0) {
+ cur_worker->type = TYPE_FUZZY;
+ }
+ else {
+ yyerror ("yyparse: unknown worker type: %s", $3);
+ YYERROR;
+ }
+ }
+ ;
+
+workercount:
+ COUNT EQSIGN NUMBER {
+ if (cur_worker == NULL) {
+ cur_worker = memory_pool_alloc0 (cfg->cfg_pool, sizeof (struct worker_conf));
+ cur_worker->params = g_hash_table_new (g_str_hash, g_str_equal);
+ memory_pool_add_destructor (cfg->cfg_pool, (pool_destruct_func)g_hash_table_destroy, cur_worker->params);
+#ifdef HAVE_SC_NPROCESSORS_ONLN
+ cur_worker->count = sysconf (_SC_NPROCESSORS_ONLN);
+#else
+ cur_worker->count = DEFAULT_WORKERS_NUM;
+#endif
+ }
+
+ if ($3 > 0) {
+ cur_worker->count = $3;
+ }
+ else {
+ yyerror ("yyparse: invalid number of workers: %d", $3);
+ YYERROR;
+ }
}
;
+workerparam:
+ STRING EQSIGN QUOTEDSTRING {
+ if (cur_worker == NULL) {
+ cur_worker = memory_pool_alloc0 (cfg->cfg_pool, sizeof (struct worker_conf));
+ cur_worker->params = g_hash_table_new (g_str_hash, g_str_equal);
+ memory_pool_add_destructor (cfg->cfg_pool, (pool_destruct_func)g_hash_table_destroy, cur_worker->params);
+#ifdef HAVE_SC_NPROCESSORS_ONLN
+ cur_worker->count = sysconf (_SC_NPROCESSORS_ONLN);
+#else
+ cur_worker->count = DEFAULT_WORKERS_NUM;
+#endif
+ }
+
+ g_hash_table_insert (cur_worker->params, $1, $3);
+ }
+
metric:
METRIC OBRACE metricbody EBRACE {
if (cur_metric == NULL || cur_metric->name == NULL) {
@@ -411,7 +477,7 @@ requirecmd:
YYERROR;
}
cur->path = $3;
- LIST_INSERT_HEAD (&cfg->perl_modules, cur, next);
+ cfg->perl_modules = g_list_prepend (cfg->perl_modules, cur);
#else
yyerror ("require command is not available when perl support is not compiled");
YYERROR;
@@ -453,14 +519,10 @@ moduleoptbody:
optcmd:
PARAM EQSIGN QUOTEDSTRING {
struct module_opt *mopt;
- if (cur_module_opt == NULL) {
- cur_module_opt = g_malloc (sizeof (cur_module_opt));
- LIST_INIT (cur_module_opt);
- }
mopt = memory_pool_alloc (cfg->cfg_pool, sizeof (struct module_opt));
mopt->param = $1;
mopt->value = $3;
- LIST_INSERT_HEAD (cur_module_opt, mopt, next);
+ cur_module_opt = g_list_prepend (cur_module_opt, mopt);
}
| VARIABLE EQSIGN QUOTEDSTRING {
g_hash_table_insert (cfg->variables, $1, $3);
@@ -749,89 +811,6 @@ statfile_pool_size:
}
;
-lmtp:
- LMTP OBRACE lmtpbody EBRACE
- ;
-
-lmtpbody:
- lmtpcmd SEMICOLON
- | lmtpbody lmtpcmd SEMICOLON
- ;
-
-lmtpcmd:
- lmtpenabled
- | lmtpsock
- | lmtpmetric
- | lmtpworkers
- ;
-
-lmtpenabled:
- ENABLED EQSIGN FLAG {
- cfg->lmtp_enable = $3;
- }
- ;
-
-lmtpsock:
- BINDSOCK EQSIGN bind_cred {
- if (!parse_bind_line (cfg, $3, CRED_LMTP)) {
- yyerror ("yyparse: parse_bind_line");
- YYERROR;
- }
- free ($3);
- }
- ;
-lmtpmetric:
- METRIC EQSIGN QUOTEDSTRING {
- cfg->lmtp_metric = memory_pool_strdup (cfg->cfg_pool, $3);
- }
- ;
-lmtpworkers:
- WORKERS EQSIGN NUMBER {
- cfg->lmtp_workers_number = $3;
- }
- ;
-
-delivery:
- DELIVERY OBRACE deliverybody EBRACE
- ;
-
-deliverybody:
- deliverycmd SEMICOLON
- | deliverybody deliverycmd SEMICOLON
- ;
-
-deliverycmd:
- deliveryenabled
- | deliverysock
- | deliveryagent
- | deliverylmtp
- ;
-
-deliveryenabled:
- ENABLED EQSIGN FLAG {
- cfg->delivery_enable = $3;
- }
- ;
-
-deliverysock:
- BINDSOCK EQSIGN bind_cred {
- if (!parse_bind_line (cfg, $3, CRED_DELIVERY)) {
- yyerror ("yyparse: parse_bind_line");
- YYERROR;
- }
- free ($3);
- }
- ;
-deliverylmtp:
- LMTP EQSIGN FLAG {
- cfg->deliver_lmtp = $3;
- }
- ;
-deliveryagent:
- AGENT EQSIGN QUOTEDSTRING {
- cfg->deliver_agent_path = memory_pool_strdup (cfg->cfg_pool, $3);
- }
- ;
luacode:
LUACODE