ucl_object_t *top = NULL, *obj;
GHashTableIter hiter;
GString *dkim_sig;
+ const ucl_object_t *rmilter_reply;
gpointer h, v;
g_hash_table_iter_init (&hiter, task->results);
"dkim-signature", 0, false);
}
+ rmilter_reply = rspamd_mempool_get_variable (task->task_pool, "rmilter-reply");
+
+ if (rmilter_reply) {
+ ucl_object_insert_key (top, ucl_object_ref (rmilter_reply),
+ "rmilter", 0, false);
+ }
+
return top;
}
/***
* @method task:get_settings_id()
* Get numeric hash of settings id if specified for this task. 0 is returned otherwise.
- * @param {any} obj any lua object that corresponds to the settings format
+ * @return {number} settings-id hash
*/
LUA_FUNCTION_DEF (task, get_settings_id);
+/***
+ * @method task:set_rmilter_reply(obj)
+ * Set special reply for rmilter
+ * @param {any} obj any lua object that corresponds to the settings format
+ * @example
+task:set_rmilter_reply({
+ add_headers = {{'X-Lua', 'test'}},
+ remove_headers = {'DKIM-Signature},
+})
+ */
+LUA_FUNCTION_DEF (task, set_rmilter_reply);
+
/***
* @method task:process_re(params)
* Processes the specified regexp and returns number of captures (cached or new)
LUA_INTERFACE_DEF (task, set_flag),
LUA_INTERFACE_DEF (task, get_flags),
LUA_INTERFACE_DEF (task, has_flag),
+ LUA_INTERFACE_DEF (task, set_rmilter_reply),
{"__tostring", rspamd_lua_class_tostring},
{NULL, NULL}
};
return 0;
}
+static gint
+lua_task_set_rmilter_reply (lua_State *L)
+{
+ struct rspamd_task *task = lua_check_task (L, 1);
+ ucl_object_t *reply;
+
+ reply = ucl_object_lua_import (L, 2);
+
+ if (reply != NULL && task != NULL) {
+ rspamd_mempool_set_variable (task->task_pool, "rmilter-reply",
+ reply, (rspamd_mempool_destruct_t)ucl_object_unref);
+ }
+ else {
+ return luaL_error (L, "invalid arguments");
+ }
+
+ return 0;
+}
+
static gint
lua_task_get_settings (lua_State *L)
{