diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-03-17 10:15:08 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-03-17 10:15:08 +0000 |
commit | e6694fe2d42af438533c43b56b452521eccb314f (patch) | |
tree | 6cd66f656364a7db83880076c461d6f3bfd9eebf /src | |
parent | 6f6375852ffcd4760925bdc5a540ff23e6d1729a (diff) | |
download | rspamd-e6694fe2d42af438533c43b56b452521eccb314f.tar.gz rspamd-e6694fe2d42af438533c43b56b452521eccb314f.zip |
[Feature] Add regexp maps support to multimap module
Diffstat (limited to 'src')
-rw-r--r-- | src/plugins/lua/multimap.lua | 53 |
1 files changed, 34 insertions, 19 deletions
diff --git a/src/plugins/lua/multimap.lua b/src/plugins/lua/multimap.lua index 44240f195..a8d807656 100644 --- a/src/plugins/lua/multimap.lua +++ b/src/plugins/lua/multimap.lua @@ -53,17 +53,17 @@ local function multimap_callback(task, pre_filter) end else -- regexp case - if not rule['regexp'] then + if not rule['re_filter'] then local type,pat = string.match(filter, '(regexp:)(.+)') if type and pat then - rule['regexp'] = regexp.create(pat) + rule['re_filter'] = regexp.create(pat) end end - if not rule['regexp'] then + if not rule['re_filter'] then rspamd_logger.errx(task, 'bad search filter: %s', filter) else - local results = rule['regexp']:search(input) + local results = rule['re_filter']:search(input) if results then return results[1] end @@ -164,17 +164,17 @@ local function multimap_callback(task, pre_filter) return nil end elseif string.find(filter, 'tld:regexp:') then - if not r['regexp'] then + if not r['re_filter'] then local type,pat = string.match(filter, '(regexp:)(.+)') if type and pat then - r['regexp'] = regexp.create(pat) + r['re_filter'] = regexp.create(pat) end end - if not r['regexp'] then + if not r['re_filter'] then rspamd_logger.errx(task, 'bad search filter: %s', filter) else - local results = r['regexp']:search(url:get_tld()) + local results = r['re_filter']:search(url:get_tld()) if results then return results[1] else @@ -182,17 +182,17 @@ local function multimap_callback(task, pre_filter) end end elseif string.find(filter, 'full:regexp:') then - if not r['regexp'] then + if not r['re_filter'] then local type,pat = string.match(filter, '(regexp:)(.+)') if type and pat then - r['regexp'] = regexp.create(pat) + r['re_filter'] = regexp.create(pat) end end - if not r['regexp'] then + if not r['re_filter'] then rspamd_logger.errx(task, 'bad search filter: %s', filter) else - local results = r['regexp']:search(url:get_text()) + local results = r['re_filter']:search(url:get_text()) if results then return results[1] else @@ -200,17 +200,17 @@ local function multimap_callback(task, pre_filter) end end elseif string.find(filter, 'regexp:') then - if not r['regexp'] then + if not r['re_filter'] then local type,pat = string.match(filter, '(regexp:)(.+)') if type and pat then - r['regexp'] = regexp.create(pat) + r['re_filter'] = regexp.create(pat) end end - if not r['regexp'] then + if not r['re_filter'] then rspamd_logger.errx(task, 'bad search filter: %s', filter) else - local results = r['regexp']:search(url:get_host()) + local results = r['re_filter']:search(url:get_host()) if results then return results[1] else @@ -353,8 +353,11 @@ local function add_multimap_rule(key, newrule) end else if newrule['type'] == 'ip' then - newrule['radix'] = rspamd_config:add_radix_map (newrule['map'], - newrule['description']) + newrule['radix'] = rspamd_config:add_map ({ + url = newrule['map'], + description = newrule['description'], + type = 'radix' + }) if newrule['radix'] then ret = true else @@ -365,7 +368,19 @@ local function add_multimap_rule(key, newrule) or newrule['type'] == 'rcpt' or newrule['type'] == 'from' or newrule['type'] == 'url' then - newrule['hash'] = rspamd_config:add_hash_map (newrule['map'], newrule['description']) + if newrule['regexp'] then + newrule['hash'] = rspamd_config:add_map ({ + url = newrule['map'], + description = newrule['description'], + type = 'regexp' + }) + else + newrule['hash'] = rspamd_config:add_map ({ + url = newrule['map'], + description = newrule['description'], + type = 'set' + }) + end if newrule['hash'] then ret = true else |