summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2014-09-20 22:50:18 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2014-09-20 22:50:18 +0100
commit460f7a6230c3aaf7c4835230ef5e5adf2098299c (patch)
tree381f1add02673ba3010448ba7989a08f5858b272
parente8b03a8f21b170a26a0d3451265fd326d8c85501 (diff)
downloadrspamd-460f7a6230c3aaf7c4835230ef5e5adf2098299c.tar.gz
rspamd-460f7a6230c3aaf7c4835230ef5e5adf2098299c.zip
Document textpart API.
-rw-r--r--src/lua/lua_task.c62
1 files changed, 61 insertions, 1 deletions
diff --git a/src/lua/lua_task.c b/src/lua/lua_task.c
index 127e6af4a..aa080792b 100644
--- a/src/lua/lua_task.c
+++ b/src/lua/lua_task.c
@@ -1829,6 +1829,33 @@ lua_task_get_metric_action (lua_State *L)
/**** Textpart implementation *****/
+/***
+ * @module mime_textpart
+ * This module provides different methods to manipulate text parts data. Text parts
+ * could be obtained from the `rspamd_task` by using of method `task:get_text_parts()`
+@example
+rspamd_config.R_EMPTY_IMAGE = function (task)
+ parts = task:get_text_parts()
+ if parts then
+ for _,part in ipairs(parts) do
+ if part:is_empty() then
+ images = task:get_images()
+ if images then
+ return true
+ end
+ return false
+ end
+ end
+ end
+ return false
+end
+ */
+
+/***
+ * @method text_part:get_content()
+ * Get the text of the part
+ * @return {string} `UTF8` encoded content of the part
+ */
static gint
lua_textpart_get_content (lua_State * L)
{
@@ -1844,6 +1871,11 @@ lua_textpart_get_content (lua_State * L)
return 1;
}
+/***
+ * @method text_part:get_length()
+ * Get length of the text of the part
+ * @return {integer} length of part in **bytes**
+ */
static gint
lua_textpart_get_length (lua_State * L)
{
@@ -1864,6 +1896,11 @@ lua_textpart_get_length (lua_State * L)
return 1;
}
+/***
+ * @method text_part:is_empty()
+ * Returns `true` if the specified part is empty
+ * @return {bool} whether a part is empty
+ */
static gint
lua_textpart_is_empty (lua_State * L)
{
@@ -1878,7 +1915,11 @@ lua_textpart_is_empty (lua_State * L)
return 1;
}
-
+/***
+ * @method text_part:is_html()
+ * Returns `true` if the specified part has HTML content
+ * @return {bool} whether a part is HTML part
+ */
static gint
lua_textpart_is_html (lua_State * L)
{
@@ -1894,6 +1935,11 @@ lua_textpart_is_html (lua_State * L)
return 1;
}
+/***
+ * @method text_part:get_fuzzy()
+ * Returns base32 encoded value of fuzzy hash of the specified part
+ * @return {string} fuzzy hash value
+ */
static gint
lua_textpart_get_fuzzy (lua_State * L)
{
@@ -1913,6 +1959,11 @@ lua_textpart_get_fuzzy (lua_State * L)
return 1;
}
+/***
+ * @method text_part:is_language()
+ * Returns the code of the most used unicode script in the text part. Does not work with raw parts
+ * @return {string} short abbreviation (such as `ru`) for the script's language
+ */
static gint
lua_textpart_get_language (lua_State * L)
{
@@ -2014,6 +2065,15 @@ lua_textpart_get_language (lua_State * L)
return 1;
}
+/***
+ * @method text_part:compare_distance(other)
+ * Calculates the difference to another text part. This function is intended to work with
+ * the parts of `multipart/alternative` container only. If the two parts are not the parts of the
+ * same `multipart/alternative` container, then they are considered as unrelated and
+ * `-1` is returned.
+ * @param {text_part} other text part to compare
+ * @return {integer} commodity percentage (e.g. the same strings give `100`, different give `0` and unrelated give `-1`)
+ */
static gint
lua_textpart_compare_distance (lua_State * L)
{