diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-02-06 16:22:36 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-02-06 16:22:36 +0000 |
commit | e8b71e4179c343e3707fb5a1b94dae6cc8b90681 (patch) | |
tree | fc2ae41a9b5646834799db6f47b71e2e08138385 /src/plugins/lua/settings.lua | |
parent | ea46a2f8c7732b13be1e4cee7618c7293706aa55 (diff) | |
parent | a46ea28a80f6285bd79ffde2a25c4e29493765ee (diff) | |
download | rspamd-e8b71e4179c343e3707fb5a1b94dae6cc8b90681.tar.gz rspamd-e8b71e4179c343e3707fb5a1b94dae6cc8b90681.zip |
Merge pull request #138 from fatalbanana/master
Allow applying settings to authenticated users
Diffstat (limited to 'src/plugins/lua/settings.lua')
-rw-r--r-- | src/plugins/lua/settings.lua | 34 |
1 files changed, 32 insertions, 2 deletions
diff --git a/src/plugins/lua/settings.lua b/src/plugins/lua/settings.lua index debd62632..01c266a3f 100644 --- a/src/plugins/lua/settings.lua +++ b/src/plugins/lua/settings.lua @@ -70,7 +70,7 @@ local function check_settings(task) return false end - local function check_specific_setting(name, rule, ip, from, rcpt) + local function check_specific_setting(name, rule, ip, from, rcpt, user) local res = false if rule['ip'] and ip then @@ -100,6 +100,15 @@ local function check_settings(task) end end + if not res and rule['user'] and user then + for _, i in ipairs(rule['user']) do + res = check_addr_setting(i, user) + if res then + break + end + end + end + if res then if rule['whitelist'] then return {whitelist = true} @@ -120,11 +129,26 @@ local function check_settings(task) local ip = task:get_from_ip() local from = task:get_from() local rcpt = task:get_recipients() + local uname = task:get_user() + local user = {} + if uname then + user[1] = {} + for localpart, domainpart in string.gmatch(uname, "(.+)@(.+)") do + user[1]["user"] = localpart + user[1]["domain"] = domainpart + user[1]["addr"] = uname + break + end + if not user[1]["addr"] then + user[1]["user"] = uname + user[1]["addr"] = uname + end + end -- Match rules according their order for pri = max_pri,1,-1 do if settings[pri] then for name, rule in pairs(settings[pri]) do - local rule = check_specific_setting(name, rule, ip, from, rcpt) + local rule = check_specific_setting(name, rule, ip, from, rcpt, user) if rule then rspamd_logger.info(string.format("<%s> apply settings according to rule %s", task:get_message_id(), name)) @@ -276,6 +300,12 @@ local function process_settings_table(tbl) out['rcpt'] = check_table(elt['rcpt'], rcpt) end end + if elt['user'] then + local user = process_addr(elt['user']) + if user then + out['user'] = check_table(elt['user'], user) + end + end -- Now we must process actions if elt['apply'] then |