aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/lua/lua_task.c36
-rw-r--r--src/main.h1
-rw-r--r--src/protocol.c5
-rw-r--r--src/worker.c3
4 files changed, 42 insertions, 3 deletions
diff --git a/src/lua/lua_task.c b/src/lua/lua_task.c
index 3980220e2..e653e25d1 100644
--- a/src/lua/lua_task.c
+++ b/src/lua/lua_task.c
@@ -79,6 +79,8 @@ LUA_FUNCTION_DEF (task, get_from_ip_num);
LUA_FUNCTION_DEF (task, get_client_ip_num);
LUA_FUNCTION_DEF (task, get_helo);
LUA_FUNCTION_DEF (task, set_helo);
+LUA_FUNCTION_DEF (task, get_hostname);
+LUA_FUNCTION_DEF (task, set_hostname);
LUA_FUNCTION_DEF (task, get_images);
LUA_FUNCTION_DEF (task, get_symbol);
LUA_FUNCTION_DEF (task, get_date);
@@ -128,6 +130,8 @@ static const struct luaL_reg tasklib_m[] = {
LUA_INTERFACE_DEF (task, get_client_ip_num),
LUA_INTERFACE_DEF (task, get_helo),
LUA_INTERFACE_DEF (task, set_helo),
+ LUA_INTERFACE_DEF (task, get_hostname),
+ LUA_INTERFACE_DEF (task, set_hostname),
LUA_INTERFACE_DEF (task, get_images),
LUA_INTERFACE_DEF (task, get_symbol),
LUA_INTERFACE_DEF (task, get_date),
@@ -1060,6 +1064,38 @@ lua_task_set_helo (lua_State *L)
}
static gint
+lua_task_get_hostname (lua_State *L)
+{
+ struct worker_task *task = lua_check_task (L);
+
+ if (task) {
+ if (task->hostname != NULL) {
+ lua_pushstring (L, (gchar *)task->hostname);
+ return 1;
+ }
+ }
+
+ lua_pushnil (L);
+ return 1;
+}
+
+static gint
+lua_task_set_hostname (lua_State *L)
+{
+ struct worker_task *task = lua_check_task (L);
+ const gchar *new_hostname;
+
+ if (task) {
+ new_hostname = luaL_checkstring (L, 2);
+ if (new_hostname) {
+ task->hostname = memory_pool_strdup (task->task_pool, new_hostname);
+ }
+ }
+
+ return 0;
+}
+
+static gint
lua_task_get_images (lua_State *L)
{
struct worker_task *task = lua_check_task (L);
diff --git a/src/main.h b/src/main.h
index e3a13ee65..ab8146cc4 100644
--- a/src/main.h
+++ b/src/main.h
@@ -220,6 +220,7 @@ struct worker_task {
gchar *deliver_to; /**< address to deliver */
gchar *user; /**< user to deliver */
gchar *subject; /**< subject (for non-mime) */
+ gchar *hostname; /**< hostname reported by MTA */
gchar *statfile; /**< statfile for learning */
f_str_t *msg; /**< message buffer */
rspamd_io_dispatcher_t *dispatcher; /**< IO dispatcher object */
diff --git a/src/protocol.c b/src/protocol.c
index 8b16dca7f..6cb0ce677 100644
--- a/src/protocol.c
+++ b/src/protocol.c
@@ -92,6 +92,7 @@
#define USER_HEADER "User"
#define PASS_HEADER "Pass"
#define JSON_HEADER "Json"
+#define HOSTNAME_HEADER "Hostname"
#define DELIVER_TO_HEADER "Deliver-To"
static GList *custom_commands = NULL;
@@ -509,6 +510,10 @@ parse_header (struct worker_task *task, f_str_t * line)
task->helo = memory_pool_fstrdup (task->task_pool, line);
debug_task ("read helo header, value: %s", task->helo);
}
+ else if (g_ascii_strncasecmp (headern, HOSTNAME_HEADER, sizeof (HOSTNAME_HEADER) - 1) == 0) {
+ task->hostname = memory_pool_fstrdup (task->task_pool, line);
+ debug_task ("read hostname header, value: %s", task->hostname);
+ }
else {
msg_info ("wrong header: %s", headern);
res = FALSE;
diff --git a/src/worker.c b/src/worker.c
index 95355bdd3..3eb91a289 100644
--- a/src/worker.c
+++ b/src/worker.c
@@ -383,9 +383,6 @@ static void
err_socket (GError * err, void *arg)
{
struct worker_task *task = (struct worker_task *) arg;
- struct rspamd_worker_ctx *ctx;
-
- ctx = task->worker->ctx;
msg_info ("abnormally closing connection from: %s, error: %s", inet_ntoa (task->client_addr), err->message);
/* Free buffers */