summaryrefslogtreecommitdiffstats
path: root/src/smtp.h
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2016-10-17 15:28:38 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2016-10-17 15:28:38 +0100
commit463d6092aabb1b4721833f884d04dbb67570fa0e (patch)
tree05e083c47f4ccdfe77676f2ffd6ea1394e95575e /src/smtp.h
parent9ecc5ea5e15a44f830aff1e1b1ad92b683bca53a (diff)
downloadrspamd-463d6092aabb1b4721833f884d04dbb67570fa0e.tar.gz
rspamd-463d6092aabb1b4721833f884d04dbb67570fa0e.zip
[Rework] Massive removal of legacy code
Diffstat (limited to 'src/smtp.h')
-rw-r--r--src/smtp.h126
1 files changed, 0 insertions, 126 deletions
diff --git a/src/smtp.h b/src/smtp.h
deleted file mode 100644
index 798e87a30..000000000
--- a/src/smtp.h
+++ /dev/null
@@ -1,126 +0,0 @@
-#ifndef RSPAMD_SMTP_H
-#define RSPAMD_SMTP_H
-
-#include "config.h"
-#include "libutil/upstream.h"
-#include "libmime/smtp_utils.h"
-#include "libmime/smtp_proto.h"
-#include "rspamd.h"
-
-struct rspamd_dns_resolver;
-
-#define DEFAULT_MAX_ERRORS 10
-
-enum rspamd_smtp_stage {
- SMTP_STAGE_CONNECT = 0,
- SMTP_STAGE_HELO,
- SMTP_STAGE_MAIL,
- SMTP_STAGE_RCPT,
- SMTP_STAGE_DATA,
- SMTP_STAGE_MAX
-};
-
-struct smtp_worker_ctx {
- struct upstream_list *upstreams;
- gsize upstream_num;
- gchar *upstreams_str;
-
- rspamd_mempool_t *pool;
- gchar *smtp_banner;
- gchar *smtp_banner_str;
- guint32 smtp_delay;
- guint32 delay_jitter;
- guint32 smtp_timeout_raw;
- struct timeval smtp_timeout;
-
- gboolean use_xclient;
- gboolean helo_required;
- gchar *smtp_capabilities;
- gchar *smtp_capabilities_str;
- gchar *reject_message;
- gsize max_size;
- guint32 max_errors;
- gchar *metric;
- GList *smtp_filters[SMTP_STAGE_MAX];
- struct rspamd_dns_resolver *resolver;
- struct event_base *ev_base;
-};
-
-enum rspamd_smtp_state {
- SMTP_STATE_RESOLVE_REVERSE = 0,
- SMTP_STATE_RESOLVE_NORMAL,
- SMTP_STATE_DELAY,
- SMTP_STATE_GREETING,
- SMTP_STATE_HELO,
- SMTP_STATE_FROM,
- SMTP_STATE_RCPT,
- SMTP_STATE_BEFORE_DATA,
- SMTP_STATE_DATA,
- SMTP_STATE_AFTER_DATA,
- SMTP_STATE_END,
- SMTP_STATE_QUIT,
- SMTP_STATE_WAIT_UPSTREAM,
- SMTP_STATE_IN_SENDFILE,
- SMTP_STATE_ERROR,
- SMTP_STATE_CRITICAL_ERROR,
- SMTP_STATE_WRITE_ERROR
-};
-
-struct smtp_session {
- struct smtp_worker_ctx *ctx;
- struct rspamd_config *cfg;
- rspamd_mempool_t *pool;
-
- enum rspamd_smtp_state state;
- enum rspamd_smtp_state upstream_state;
- struct rspamd_worker *worker;
- struct rspamd_task *task;
- struct in_addr client_addr;
- gchar *hostname;
- gchar *error;
- gchar *temp_name;
- gint sock;
- gint upstream_sock;
- gint temp_fd;
- size_t temp_size;
- time_t session_time;
-
- gchar *helo;
- GList *from;
- GList *rcpt;
- GList *cur_rcpt;
-
- guint errors;
-
- struct rspamd_async_session *s;
- rspamd_io_dispatcher_t *dispatcher;
- rspamd_io_dispatcher_t *upstream_dispatcher;
-
- struct upstream *upstream;
-
- struct event *delay_timer;
-
- gboolean resolved;
- gboolean esmtp;
- struct rspamd_dns_resolver *resolver;
- struct event_base *ev_base;
-};
-
-typedef gboolean (*smtp_filter_t)(struct smtp_session *session,
- gpointer filter_data);
-
-struct smtp_filter {
- smtp_filter_t filter;
- gpointer filter_data;
-};
-
-/*
- * Register new SMTP filter
- * XXX: work is still in progress
- */
-void register_smtp_filter (struct smtp_worker_ctx *ctx,
- enum rspamd_smtp_stage stage,
- smtp_filter_t filter,
- gpointer filter_data);
-
-#endif