diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-11-09 18:08:55 +0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-11-09 18:08:55 +0400 |
commit | 1e72217a5a79451247bcd33aa2d04d43b48b22e2 (patch) | |
tree | 56050de25900fe5e6ce7b2f6bd0dbab9a96554ea | |
parent | 8067edf7cc504a81cfdf2fa534a618c2dc592357 (diff) | |
parent | 53d3e104ba94150dc3702f6df3c5b53e3afb0d73 (diff) | |
download | rspamd-1e72217a5a79451247bcd33aa2d04d43b48b22e2.tar.gz rspamd-1e72217a5a79451247bcd33aa2d04d43b48b22e2.zip |
Merge pull request #1112 from fatalbanana/pubsub
[Feature] Module to push messages/metadata to redis pubsub
-rw-r--r-- | src/plugins/lua/metadata_exporter.lua | 78 |
1 files changed, 78 insertions, 0 deletions
diff --git a/src/plugins/lua/metadata_exporter.lua b/src/plugins/lua/metadata_exporter.lua new file mode 100644 index 000000000..462748ba2 --- /dev/null +++ b/src/plugins/lua/metadata_exporter.lua @@ -0,0 +1,78 @@ +--[[ +Copyright (c) 2016, Andrew Lewis <nerf@judo.za.org> +Copyright (c) 2016, Vsevolod Stakhov <vsevolod@highsecure.ru> + +Licensed under the Apache License, Version 2.0 (the "License"); +you may not use this file except in compliance with the License. +You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + +Unless required by applicable law or agreed to in writing, software +distributed under the License is distributed on an "AS IS" BASIS, +WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +See the License for the specific language governing permissions and +limitations under the License. +]]-- + +-- A plugin that pushes metadata (or whole messages) to external services + +local rspamd_logger = require "rspamd_logger" + +local settings = { + select = function(task) + return true + end, + format = function(task) + return task:get_content() + end, +} + +local opts = rspamd_config:get_all_opt('metadata_exporter') +if not opts then return end +local redis_params = rspamd_parse_redis_server('metadata_exporter') +if not redis_params then + rspamd_logger.errx(rspamd_config, 'no servers are specified, disabling module') + return +end +local channel = opts['channel'] +if not channel then + rspamd_logger.errx(rspamd_config, 'no channel is specified, disabling module') + return +end +if opts['select'] then + settings.select = assert(loadstring(opts['select']))() +end +if opts['format'] then + settings.format = assert(loadstring(opts['format']))() +end + +local function metadata_exporter(task) + local ret,conn,upstream + local function redis_set_cb(err, data) + if err then + rspamd_logger.errx(task, 'got error %s when publishing record on server %s', + err, upstream:get_addr()) + upstream:fail() + else + upstream:ok() + end + end + if not settings.select(task) then return end + rspamd_logger.debugx(task, 'Message selected for processing') + ret,conn,upstream = rspamd_redis_make_request(task, + redis_params, -- connect params + nil, -- hash key + true, -- is write + redis_set_cb, --callback + 'PUBLISH', -- command + {channel, settings.format(task)} -- arguments + ) +end + +rspamd_config:register_symbol({ + name = 'EXPORT_METADATA', + type = 'postfilter', + callback = metadata_exporter, + priority = 10 +}) |