ucl_object_t *control_obj;
gchar filepath[PATH_MAX], *fp;
gint fd, flen;
- gulong offset = 0;
+ gulong offset = 0, shmem_size = 0;
rspamd_ftok_t srch, *tok;
gpointer map;
struct stat st;
}
}
+ srch.begin = "shm-length";
+ srch.len = 10;
+ tok = g_hash_table_lookup (task->request_headers, &srch);
+ shmem_size = st.st_size;
+
+ if (tok) {
+ rspamd_strtoul (tok->begin, tok->len, &shmem_size);
+
+ if (shmem_size > (gulong)st.st_size) {
+ msg_err_task ("invalid length %ul (%ul available) for shm "
+ "segment %s", shmem_size, st.st_size, fp);
+ munmap (map, st.st_size);
+
+ return FALSE;
+ }
+ }
+
task->msg.begin = ((guchar *)map) + offset;
- task->msg.len = st.st_size - offset;
+ task->msg.len = shmem_size;
task->flags |= RSPAMD_TASK_FLAG_FILE;
m = rspamd_mempool_alloc (task->task_pool, sizeof (*m));
m->begin = map;
m->len = st.st_size;
- msg_info_task ("loaded message from shared memory %s", fp);
+ msg_info_task ("loaded message from shared memory %s (%ul size, %ul offset)",
+ fp, shmem_size, offset);
rspamd_mempool_add_destructor (task->task_pool, rspamd_task_unmapper, m);
}
new_msg->body_buf.begin = new_msg->body_buf.str;
- new_msg->body_buf.len = st.st_size;
+ new_msg->body_buf.len = msg->body_buf.len;
new_msg->body_buf.begin = new_msg->body_buf.str +
(msg->body_buf.begin - msg->body_buf.str);
}
(int)(msg->body_buf.begin - msg->body_buf.str));
rspamd_http_message_add_header (msg, "Shm-Offset",
datebuf);
+ rspamd_snprintf (datebuf, sizeof (datebuf), "%z",
+ msg->body_buf.len);
+ rspamd_http_message_add_header (msg, "Shm-Length",
+ datebuf);
}
}