diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2018-09-29 13:22:48 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2018-09-29 13:22:48 +0100 |
commit | b0474bae143c822e230177a08df20497bcfd98e0 (patch) | |
tree | ea217a1e1f932fe90457f9b6aaa0860f46dc0582 /lualib/lua_meta.lua | |
parent | 8f927178fd34655d45095dfde902ee2c0ce6818d (diff) | |
download | rspamd-b0474bae143c822e230177a08df20497bcfd98e0.tar.gz rspamd-b0474bae143c822e230177a08df20497bcfd98e0.zip |
[Minor] Allow to generate tokens by names
Diffstat (limited to 'lualib/lua_meta.lua')
-rw-r--r-- | lualib/lua_meta.lua | 55 |
1 files changed, 42 insertions, 13 deletions
diff --git a/lualib/lua_meta.lua b/lualib/lua_meta.lua index 530843d33..936adb141 100644 --- a/lualib/lua_meta.lua +++ b/lualib/lua_meta.lua @@ -421,28 +421,55 @@ local function fill_metatokens_by_name() end end -local function rspamd_gen_metatokens(task) +local function calculate_digest() + local cr = require "rspamd_cryptobox_hash" + + cr.create() + for _,mt in ipairs(metafunctions) do + for i=1,mt.ninputs do + local name = mt.names[i] + cr:update(name) + end + end + + exports.digest = cr:hex() +end + +local function rspamd_gen_metatokens(task, names) local lua_util = require "lua_util" local ipairs = ipairs local metatokens = {} - local cached = task:cache_get('metatokens') - if cached then - return cached - else - for _,mt in ipairs(metafunctions) do - local ct = mt.cb(task) - for i,tok in ipairs(ct) do - lua_util.debugm(N, task, "metatoken: %s = %s", mt.name[i], tok) - table.insert(metatokens, tok) + if not names then + local cached = task:cache_get('metatokens') + + if cached then + return cached + else + for _,mt in ipairs(metafunctions) do + local ct = mt.cb(task) + for i,tok in ipairs(ct) do + lua_util.debugm(N, task, "metatoken: %s = %s", mt.name[i], tok) + table.insert(metatokens, tok) + end end + + task:cache_set('metatokens', metatokens) end - task:cache_set('metatokens', metatokens) + else + local logger = require "rspamd_logger" + for _,n in ipairs(names) do + if metatokens_by_name[n] then + table.insert(metatokens, metatokens_by_name[n](task)) + else + logger.errx(task, 'unknown metatoken: %s', n) + end + end end return metatokens -end + end exports.rspamd_gen_metatokens = rspamd_gen_metatokens exports.gen_metatokens = rspamd_gen_metatokens @@ -453,7 +480,7 @@ local function rspamd_gen_metatokens_table(task) for _,mt in ipairs(metafunctions) do local ct = mt.cb(task) for i,tok in ipairs(ct) do - metatokens[mt.desc[i]] = tok + metatokens[mt.name[i]] = tok end end @@ -485,9 +512,11 @@ exports.add_metafunction = function(tbl) else table.insert(metafunctions, tbl) fill_metatokens_by_name() + calculate_digest() end end fill_metatokens_by_name() +calculate_digest() return exports |