aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@rspamd.com>2022-07-10 10:42:55 +0100
committerVsevolod Stakhov <vsevolod@rspamd.com>2022-07-10 10:42:55 +0100
commit312c615323107e00101534be69197271e14d4e5e (patch)
tree3e810f2aefc4fc1f0d664f51bda743ab868a0b0d
parentcebd539c1759036d4edc6a6682fbea95a6220cf5 (diff)
downloadrspamd-312c615323107e00101534be69197271e14d4e5e.tar.gz
rspamd-312c615323107e00101534be69197271e14d4e5e.zip
[Fix] Fix reading of the cached maps
Issue: #4213
-rw-r--r--src/libserver/maps/map.c28
1 files changed, 18 insertions, 10 deletions
diff --git a/src/libserver/maps/map.c b/src/libserver/maps/map.c
index 995509ded..f9933cee6 100644
--- a/src/libserver/maps/map.c
+++ b/src/libserver/maps/map.c
@@ -1319,13 +1319,13 @@ static gboolean
rspamd_map_read_cached (struct rspamd_map *map, struct rspamd_map_backend *bk,
struct map_periodic_cbdata *periodic, const gchar *host)
{
- gsize len;
+ gsize mmap_len, len;
gpointer in;
struct http_map_data *data;
data = bk->data.hd;
- in = rspamd_shmem_xmap (data->cache->shmem_name, PROT_READ, &len);
+ in = rspamd_shmem_xmap (data->cache->shmem_name, PROT_READ, &mmap_len);
if (in == NULL) {
msg_err ("cannot map cache from %s: %s", data->cache->shmem_name,
@@ -1333,15 +1333,24 @@ rspamd_map_read_cached (struct rspamd_map *map, struct rspamd_map_backend *bk,
return FALSE;
}
- if (len < data->cache->len) {
- msg_err ("cannot map cache from %s: bad length %z, %z expected",
+ if (mmap_len < data->cache->len) {
+ msg_err ("cannot map cache from %s: truncated length %z, %z expected",
data->cache->shmem_name,
- len, data->cache->len);
- munmap (in, len);
+ mmap_len, data->cache->len);
+ munmap (in, mmap_len);
return FALSE;
}
+ /*
+ * Len is taken from the shmem file size that can be larger than the
+ * actual data length, as we use shared memory as a growing buffer for the
+ * HTTP input.
+ * Hence, we need to use len from the saved cache data, counting that it is
+ * at least not more than the cached file length (this is checked above).
+ */
+ len = data->cache->len;
+
if (bk->is_compressed) {
ZSTD_DStream *zstream;
ZSTD_inBuffer zin;
@@ -1375,7 +1384,7 @@ rspamd_map_read_cached (struct rspamd_map *map, struct rspamd_map_backend *bk,
ZSTD_getErrorName (r));
ZSTD_freeDStream (zstream);
g_free (out);
- munmap (in, len);
+ munmap (in, mmap_len);
return FALSE;
}
@@ -1395,12 +1404,11 @@ rspamd_map_read_cached (struct rspamd_map *map, struct rspamd_map_backend *bk,
g_free (out);
}
else {
- msg_info_map ("%s: read map data cached %z bytes", bk->uri,
- len);
+ msg_info_map ("%s: read map data cached %z bytes", bk->uri, len);
map->read_callback (in, len, &periodic->cbdata, TRUE);
}
- munmap (in, len);
+ munmap (in, mmap_len);
return TRUE;
}