summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/rcl/rcl_util.c140
-rw-r--r--test/rspamd_memcached_test.c2
2 files changed, 93 insertions, 49 deletions
diff --git a/src/rcl/rcl_util.c b/src/rcl/rcl_util.c
index cd8e558e9..acf8bcd6d 100644
--- a/src/rcl/rcl_util.c
+++ b/src/rcl/rcl_util.c
@@ -260,62 +260,59 @@ rspamd_cl_curl_write_callback (gpointer contents, gsize size, gsize nmemb, gpoin
#endif
/**
- * Include an url to configuration
- * @param data
- * @param len
- * @param parser
- * @param err
+ * Fetch a url and save results to the memory buffer
+ * @param url url to fetch
+ * @param len length of url
+ * @param buf target buffer
+ * @param buflen target length
* @return
*/
static gboolean
-rspamd_cl_include_url (const guchar *data, gsize len, struct rspamd_cl_parser *parser, GError **err)
+rspamd_cl_fetch_url (const guchar *url, gsize len, guchar **buf, gsize *buflen, GError **err)
{
char urlbuf[PATH_MAX];
- gboolean res;
- guchar *buf = NULL;
- gsize buflen = 0;
- struct rspamd_cl_chunk *chunk;
- rspamd_snprintf (urlbuf, sizeof (urlbuf), "%*s", len, data);
+ rspamd_snprintf (urlbuf, sizeof (urlbuf), "%*s", len, url);
#ifdef HAVE_FETCH_H
- struct url *url;
+ struct url *fetch_url;
struct url_stat us;
FILE *in;
guchar *buf;
- url = fetchParseURL (urlbuf);
- if (url == NULL) {
+ fetch_url = fetchParseURL (urlbuf);
+ if (fetch_url == NULL) {
g_set_error (err, RCL_ERROR, RSPAMD_CL_EIO, "invalid URL %s: %s",
urlbuf, strerror (errno));
return FALSE;
}
- if ((in = fetchXGet (url, &us, "")) == NULL) {
+ if ((in = fetchXGet (fetch_url, &us, "")) == NULL) {
g_set_error (err, RCL_ERROR, RSPAMD_CL_EIO, "cannot fetch URL %s: %s",
urlbuf, strerror (errno));
- fetchFreeURL (url);
+ fetchFreeURL (fetch_url);
return FALSE;
}
- buflen = us.size;
- buf = g_malloc (buflen);
+ *buflen = us.size;
+ *buf = g_malloc (*buflen);
if (buf == NULL) {
g_set_error (err, RCL_ERROR, RSPAMD_CL_EIO, "cannot allocate buffer for URL %s: %s",
urlbuf, strerror (errno));
fclose (in);
- fetchFreeURL (url);
+ fetchFreeURL (fetch_url);
return FALSE;
}
- if (fread (buf, buflen, 1, in) != 1) {
+ if (fread (*buf, *buflen, 1, in) != 1) {
g_set_error (err, RCL_ERROR, RSPAMD_CL_EIO, "cannot read URL %s: %s",
urlbuf, strerror (errno));
fclose (in);
- fetchFreeURL (url);
+ fetchFreeURL (fetch_url);
return FALSE;
}
- fetchFreeURL (url);
+ fetchFreeURL (fetch_url);
+ return TRUE;
#elif defined(CURL_FOUND)
CURL *curl;
gint r;
@@ -332,9 +329,9 @@ rspamd_cl_include_url (const guchar *data, gsize len, struct rspamd_cl_parser *p
curl_easy_cleanup (curl);
return FALSE;
}
- curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, rspamd_cl_curl_write_callback);
- cbdata.buf = buf;
- cbdata.buflen = buflen;
+ curl_easy_setopt (curl, CURLOPT_WRITEFUNCTION, rspamd_cl_curl_write_callback);
+ cbdata.buf = *buf;
+ cbdata.buflen = *buflen;
curl_easy_setopt (curl, CURLOPT_WRITEDATA, &cbdata);
if ((r = curl_easy_perform (curl)) != CURLE_OK) {
@@ -346,10 +343,75 @@ rspamd_cl_include_url (const guchar *data, gsize len, struct rspamd_cl_parser *p
}
return FALSE;
}
+ *buf = cbdata.buf;
+ *buflen = cbdata.buflen;
+
+ return TRUE;
#else
g_set_error (err, RCL_ERROR, RSPAMD_CL_EINTERNAL, "URL support is disabled");
return FALSE;
#endif
+}
+
+/**
+ * Fetch a file and save results to the memory buffer
+ * @param filename filename to fetch
+ * @param len length of filename
+ * @param buf target buffer
+ * @param buflen target length
+ * @return
+ */
+static gboolean
+rspamd_cl_fetch_file (const guchar *filename, gsize len, guchar **buf, gsize *buflen, GError **err)
+{
+ gint fd;
+ struct stat st;
+ char filebuf[PATH_MAX];
+
+ rspamd_snprintf (filebuf, sizeof (filebuf), "%*s", len, filename);
+ if (stat (filebuf, &st) == -1) {
+ g_set_error (err, RCL_ERROR, RSPAMD_CL_EIO, "cannot stat file %s: %s",
+ filebuf, strerror (errno));
+ return FALSE;
+ }
+ if ((fd = open (filebuf, O_RDONLY)) == -1) {
+ g_set_error (err, RCL_ERROR, RSPAMD_CL_EIO, "cannot open file %s: %s",
+ filebuf, strerror (errno));
+ return FALSE;
+ }
+ if ((*buf = mmap (NULL, st.st_size, PROT_READ, MAP_SHARED, fd, 0)) == MAP_FAILED) {
+ close (fd);
+ g_set_error (err, RCL_ERROR, RSPAMD_CL_EIO, "cannot mmap file %s: %s",
+ filebuf, strerror (errno));
+ return FALSE;
+ }
+ *buflen = st.st_size;
+ close (fd);
+
+ return TRUE;
+}
+
+/**
+ * Include an url to configuration
+ * @param data
+ * @param len
+ * @param parser
+ * @param err
+ * @return
+ */
+static gboolean
+rspamd_cl_include_url (const guchar *data, gsize len, struct rspamd_cl_parser *parser, GError **err)
+{
+
+ gboolean res;
+ guchar *buf = NULL;
+ gsize buflen = 0;
+ struct rspamd_cl_chunk *chunk;
+
+
+ if (!rspamd_cl_fetch_url (data, len, &buf, &buflen, err)) {
+ return FALSE;
+ }
res = rspamd_cl_parser_add_chunk (parser, buf, buflen, err);
if (res == TRUE) {
@@ -376,34 +438,16 @@ rspamd_cl_include_url (const guchar *data, gsize len, struct rspamd_cl_parser *p
static gboolean
rspamd_cl_include_file (const guchar *data, gsize len, struct rspamd_cl_parser *parser, GError **err)
{
- gint fd;
- struct stat st;
- char filebuf[PATH_MAX];
- gpointer map;
gboolean res;
struct rspamd_cl_chunk *chunk;
+ guchar *buf = NULL;
+ gsize buflen;
- rspamd_snprintf (filebuf, sizeof (filebuf), "%*s", len, data);
- if (stat (filebuf, &st) == -1) {
- g_set_error (err, RCL_ERROR, RSPAMD_CL_EIO, "cannot stat file %s: %s",
- filebuf, strerror (errno));
- return FALSE;
- }
- if ((fd = open (filebuf, O_RDONLY)) == -1) {
- g_set_error (err, RCL_ERROR, RSPAMD_CL_EIO, "cannot open file %s: %s",
- filebuf, strerror (errno));
- return FALSE;
- }
- if ((map = mmap (NULL, st.st_size, PROT_READ, MAP_SHARED, fd, 0)) == MAP_FAILED) {
- close (fd);
- g_set_error (err, RCL_ERROR, RSPAMD_CL_EIO, "cannot mmap file %s: %s",
- filebuf, strerror (errno));
+ if (!rspamd_cl_fetch_file (data, len, &buf, &buflen, err)) {
return FALSE;
}
- close (fd);
-
- res = rspamd_cl_parser_add_chunk (parser, map, st.st_size, err);
+ res = rspamd_cl_parser_add_chunk (parser, buf, buflen, err);
if (res == TRUE) {
/* Remove chunk from the stack */
chunk = parser->chunks;
@@ -412,7 +456,7 @@ rspamd_cl_include_file (const guchar *data, gsize len, struct rspamd_cl_parser *
g_slice_free1 (sizeof (struct rspamd_cl_chunk), chunk);
}
}
- munmap (map, st.st_size);
+ munmap (buf, buflen);
return res;
}
diff --git a/test/rspamd_memcached_test.c b/test/rspamd_memcached_test.c
index 3ab62e7e7..0cd42c594 100644
--- a/test/rspamd_memcached_test.c
+++ b/test/rspamd_memcached_test.c
@@ -4,7 +4,7 @@
#include "../src/memcached.h"
#include "tests.h"
-u_char *buf = "test";
+static const u_char *buf = "test";
static void
memcached_callback (memcached_ctx_t *ctx, memc_error_t error, void *data)