aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@rambler-co.ru>2010-08-25 20:15:29 +0400
committerVsevolod Stakhov <vsevolod@rambler-co.ru>2010-08-25 20:15:29 +0400
commit59822ebf58a3bf9f0a3bb97150206013be3b43d7 (patch)
treed08236df32ec8742c3ca2b6097de0977aa893ace
parent671bbfa9cc85a625df33d6384a3179ce076765b9 (diff)
downloadrspamd-59822ebf58a3bf9f0a3bb97150206013be3b43d7.tar.gz
rspamd-59822ebf58a3bf9f0a3bb97150206013be3b43d7.zip
* Add ability to extract filename and size of images from lua
-rw-r--r--src/images.c1
-rw-r--r--src/images.h1
-rw-r--r--src/lua/lua_task.c34
-rw-r--r--src/message.c1
-rw-r--r--src/message.h1
5 files changed, 38 insertions, 0 deletions
diff --git a/src/images.c b/src/images.c
index 00c9599c0..d071c38e7 100644
--- a/src/images.c
+++ b/src/images.c
@@ -226,6 +226,7 @@ process_image (struct worker_task *task, struct mime_part *part)
image_type_str (img->type),
img->width, img->height,
task->message_id);
+ img->filename = part->filename;
task->images = g_list_prepend (task->images, img);
}
}
diff --git a/src/images.h b/src/images.h
index 2a79e4edd..f7616a680 100644
--- a/src/images.h
+++ b/src/images.h
@@ -17,6 +17,7 @@ struct rspamd_image {
GByteArray *data;
guint32 width;
guint32 height;
+ const char *filename;
};
void process_images (struct worker_task *task);
diff --git a/src/lua/lua_task.c b/src/lua/lua_task.c
index b18cfc21f..cb9433d5e 100644
--- a/src/lua/lua_task.c
+++ b/src/lua/lua_task.c
@@ -109,11 +109,15 @@ static const struct luaL_reg textpartlib_m[] = {
LUA_FUNCTION_DEF (image, get_width);
LUA_FUNCTION_DEF (image, get_height);
LUA_FUNCTION_DEF (image, get_type);
+LUA_FUNCTION_DEF (image, get_filename);
+LUA_FUNCTION_DEF (image, get_size);
static const struct luaL_reg imagelib_m[] = {
LUA_INTERFACE_DEF (image, get_width),
LUA_INTERFACE_DEF (image, get_height),
LUA_INTERFACE_DEF (image, get_type),
+ LUA_INTERFACE_DEF (image, get_filename),
+ LUA_INTERFACE_DEF (image, get_size),
{"__tostring", lua_class_tostring},
{NULL, NULL}
};
@@ -885,6 +889,36 @@ lua_image_get_type (lua_State *L)
return 1;
}
+static int
+lua_image_get_size (lua_State *L)
+{
+ struct rspamd_image *img = lua_check_image (L);
+
+ if (img != NULL) {
+ lua_pushinteger (L, img->data->len);
+ }
+ else {
+ lua_pushnil (L);
+ }
+
+ return 1;
+}
+
+static int
+lua_image_get_filename (lua_State *L)
+{
+ struct rspamd_image *img = lua_check_image (L);
+
+ if (img != NULL && img->filename != NULL) {
+ lua_pushstring (L, img->filename);
+ }
+ else {
+ lua_pushnil (L);
+ }
+
+ return 1;
+}
+
/* Init part */
int
luaopen_task (lua_State * L)
diff --git a/src/message.c b/src/message.c
index ad730d360..2491ddfc0 100644
--- a/src/message.c
+++ b/src/message.c
@@ -709,6 +709,7 @@ mime_foreach_callback (GMimeObject * part, gpointer user_data)
mime_part->type = type;
mime_part->content = part_content;
mime_part->parent = task->parser_parent_part;
+ mime_part->filename = g_mime_part_get_filename (GMIME_PART (part));
/* Extract checksums for some types */
if (g_mime_content_type_is_type (type, "image", "*") && part_content->len > 0) {
mime_part->checksum = g_compute_checksum_for_data (G_CHECKSUM_MD5, part_content->data, part_content->len);
diff --git a/src/message.h b/src/message.h
index 3bdb0285d..4b51064ab 100644
--- a/src/message.h
+++ b/src/message.h
@@ -17,6 +17,7 @@ struct mime_part {
GByteArray *content;
GMimeObject *parent;
gchar *checksum;
+ const char *filename;
};
struct mime_text_part {