summaryrefslogtreecommitdiffstats
path: root/src/rspamd.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/rspamd.h')
-rw-r--r--src/rspamd.h74
1 files changed, 47 insertions, 27 deletions
diff --git a/src/rspamd.h b/src/rspamd.h
index a56fab2b4..0a0fb45fc 100644
--- a/src/rspamd.h
+++ b/src/rspamd.h
@@ -25,11 +25,13 @@
#include "libutil/http_connection.h"
#include "libutil/upstream.h"
#include "libutil/radix.h"
+#include "libserver/cfg_file.h"
#include "libserver/url.h"
#include "libserver/protocol.h"
#include "libserver/async_session.h"
#include "libserver/roll_history.h"
#include "libserver/task.h"
+
#include <openssl/ssl.h>
#include <magic.h>
@@ -52,6 +54,10 @@
#define CR '\r'
#define LF '\n'
+#ifdef __cplusplus
+extern "C" {
+#endif
+
enum rspamd_worker_flags {
RSPAMD_WORKER_HAS_SOCKET = (1 << 0),
RSPAMD_WORKER_UNIQUE = (1 << 1),
@@ -69,8 +75,8 @@ struct rspamd_worker_accept_event {
struct rspamd_worker_accept_event *prev, *next;
};
-typedef void (*rspamd_worker_term_cb)(EV_P_ ev_child *, struct rspamd_main *,
- struct rspamd_worker *);
+typedef void (*rspamd_worker_term_cb) (EV_P_ ev_child *, struct rspamd_main *,
+ struct rspamd_worker *);
/**
* Worker process structure
@@ -114,6 +120,7 @@ struct rspamd_abstract_worker_ctx {
};
struct rspamd_worker_signal_handler;
+
typedef gboolean (*rspamd_worker_signal_cb_t) (
struct rspamd_worker_signal_handler *, void *ud);
@@ -147,10 +154,11 @@ struct rspamd_controller_pbkdf {
* Common structure representing C module context
*/
struct module_s;
+
struct module_ctx {
- gint (*filter)(struct rspamd_task *task); /**< pointer to headers process function */
- struct module_s *mod; /**< module pointer */
- gboolean enabled; /**< true if module is enabled in configuration */
+ gint (*filter) (struct rspamd_task *task); /**< pointer to headers process function */
+ struct module_s *mod; /**< module pointer */
+ gboolean enabled; /**< true if module is enabled in configuration */
};
#ifndef WITH_HYPERSCAN
@@ -178,28 +186,33 @@ struct module_ctx {
#define RSPAMD_CUR_WORKER_VERSION 0x2
#define RSPAMD_FEATURES \
- RSPAMD_FEATURE_HYPERSCAN RSPAMD_FEATURE_PCRE2 \
- RSPAMD_FEATURE_FANN RSPAMD_FEATURE_SNOWBALL
+ RSPAMD_FEATURE_HYPERSCAN RSPAMD_FEATURE_PCRE2 \
+ RSPAMD_FEATURE_FANN RSPAMD_FEATURE_SNOWBALL
#define RSPAMD_MODULE_VER \
- RSPAMD_CUR_MODULE_VERSION, /* Module version */ \
- RSPAMD_VERSION_NUM, /* Rspamd version */ \
- RSPAMD_FEATURES /* Compilation features */ \
+ RSPAMD_CUR_MODULE_VERSION, /* Module version */ \
+ RSPAMD_VERSION_NUM, /* Rspamd version */ \
+ RSPAMD_FEATURES /* Compilation features */ \
#define RSPAMD_WORKER_VER \
- RSPAMD_CUR_WORKER_VERSION, /* Worker version */ \
- RSPAMD_VERSION_NUM, /* Rspamd version */ \
- RSPAMD_FEATURES /* Compilation features */ \
+ RSPAMD_CUR_WORKER_VERSION, /* Worker version */ \
+ RSPAMD_VERSION_NUM, /* Rspamd version */ \
+ RSPAMD_FEATURES /* Compilation features */ \
/**
* Module
*/
typedef struct module_s {
const gchar *name;
- int (*module_init_func)(struct rspamd_config *cfg, struct module_ctx **ctx);
- int (*module_config_func)(struct rspamd_config *cfg);
- int (*module_reconfig_func)(struct rspamd_config *cfg);
- int (*module_attach_controller_func)(struct module_ctx *ctx,
- GHashTable *custom_commands);
+
+ int (*module_init_func) (struct rspamd_config *cfg, struct module_ctx **ctx);
+
+ int (*module_config_func) (struct rspamd_config *cfg);
+
+ int (*module_reconfig_func) (struct rspamd_config *cfg);
+
+ int (*module_attach_controller_func) (struct module_ctx *ctx,
+ GHashTable *custom_commands);
+
guint module_version;
guint64 rspamd_version;
const gchar *rspamd_features;
@@ -220,8 +233,11 @@ struct rspamd_worker_listen_socket {
typedef struct worker_s {
const gchar *name;
- gpointer (*worker_init_func)(struct rspamd_config *cfg);
- void (*worker_start_func)(struct rspamd_worker *worker);
+
+ gpointer (*worker_init_func) (struct rspamd_config *cfg);
+
+ void (*worker_start_func) (struct rspamd_worker *worker);
+
int flags;
int listen_type;
guint worker_version;
@@ -313,8 +329,9 @@ struct rspamd_process_exception {
*/
struct controller_command;
struct controller_session;
-typedef gboolean (*controller_func_t)(gchar **args,
- struct controller_session *session);
+
+typedef gboolean (*controller_func_t) (gchar **args,
+ struct controller_session *session);
struct controller_session {
struct rspamd_worker *worker; /**< pointer to worker structure (controller in fact) */
@@ -322,7 +339,7 @@ struct controller_session {
struct controller_command *cmd; /**< real command */
struct rspamd_config *cfg; /**< pointer to config file */
GList *parts; /**< extracted mime parts */
- struct rspamd_async_session * s; /**< async session object */
+ struct rspamd_async_session *s; /**< async session object */
struct rspamd_dns_resolver *resolver; /**< DNS resolver */
struct ev_loop *ev_base; /**< Event base */
};
@@ -354,17 +371,20 @@ struct rspamd_external_libs_ctx {
* Register custom controller function
*/
void register_custom_controller_command (const gchar *name,
- controller_func_t handler,
- gboolean privilleged,
- gboolean require_message);
+ controller_func_t handler,
+ gboolean privilleged,
+ gboolean require_message);
enum rspamd_pbkdf_version_id {
RSPAMD_PBKDF_ID_V1 = 1,
- RSPAMD_PBKDF_ID_V2= 2,
+ RSPAMD_PBKDF_ID_V2 = 2,
RSPAMD_PBKDF_ID_MAX
};
extern const struct rspamd_controller_pbkdf pbkdf_list[];
+#ifdef __cplusplus
+}
+#endif
#endif \ No newline at end of file