Skip to content
Snippets Groups Projects
mailsrvr.h 9.26 KiB
Newer Older
/* Synchronet Mail (SMTP/POP3/SendMail) server */

/****************************************************************************
 * @format.tab-size 4		(Plain Text/Source Code File Header)			*
 * @format.use-tabs true	(see http://www.synchro.net/ptsc_hdr.html)		*
 *																			*
rswindell's avatar
rswindell committed
 * Copyright Rob Swindell - http://www.synchro.net/copyright.html			*
 *																			*
 * This program is free software; you can redistribute it and/or			*
 * modify it under the terms of the GNU General Public License				*
 * as published by the Free Software Foundation; either version 2			*
 * of the License, or (at your option) any later version.					*
 * See the GNU General Public License for more details: gpl.txt or			*
 * http://www.fsf.org/copyleft/gpl.html										*
 *																			*
 * For Synchronet coding style and modification guidelines, see				*
 * http://www.synchro.net/source.html										*
 *																			*
 * Note: If this box doesn't appear square, then you need to fix your tabs.	*
 ****************************************************************************/

#ifndef _MAILSRVR_H_
#define _MAILSRVR_H_

#include "startup.h"
#include "sockwrap.h"           /* SOCKET */
	uint16_t smtp_port;
	uint16_t pop3_port;
	uint16_t pop3s_port;
	uint16_t submission_port;
	uint16_t submissions_port;
	uint16_t max_clients;
#define MAIL_DEFAULT_MAX_CLIENTS            100
	uint16_t max_inactivity;
#define MAIL_DEFAULT_MAX_INACTIVITY         120
	uint16_t max_delivery_attempts;
#define MAIL_DEFAULT_MAX_DELIVERY_ATTEMPTS  50
	uint16_t rescan_frequency;      /* In seconds */
#define MAIL_DEFAULT_RESCAN_FREQUENCY       3600
	uint16_t relay_port;
	uint16_t lines_per_yield;       /* 0=none */
#define MAIL_DEFAULT_LINES_PER_YIELD        10
	uint16_t max_recipients;
#define MAIL_DEFAULT_MAX_RECIPIENTS         100
deuce's avatar
deuce committed
	struct in_addr outgoing4;
	struct in6_addr outgoing6;
	str_list_t interfaces;
	str_list_t pop3_interfaces;
	uint32_t max_msg_size;          /* Max msg size in bytes (0=unlimited) */
#define MAIL_DEFAULT_MAX_MSG_SIZE           (20 * 1024 * 1024)  /* 20MB */
	uint32_t max_msgs_waiting;      /* Max msgs in user's inbox (0=unlimited) */
#define MAIL_DEFAULT_MAX_MSGS_WAITING       100
	uint32_t connect_timeout;       /* in seconds, for non-blocking connect (0=blocking socket) */
#define MAIL_DEFAULT_CONNECT_TIMEOUT        30      /* seconds */

	/* Strings */
	char dns_server[128];
	char default_user[128];
	char dnsbl_tag[32];         // Tag to add to blacklisted subject
	char dnsbl_hdr[32];         // Header field to add to msg header
	char post_to[64];           // Recipient of messages imported into sub-boards (e.g. "All")
	char inbound_sound[INI_MAX_VALUE_LEN];
	char outbound_sound[INI_MAX_VALUE_LEN];
	char pop3_sound[INI_MAX_VALUE_LEN];
	int tls_error_level;            /* Cap the severity of TLS error log messages */
	bool notify_offline_users;
	char relay_server[128];
	/* Relay authentication required */
	char relay_user[128];
	char relay_pass[128];
	/* JavaScript operating parameters */
	js_startup_t js;

	uint max_concurrent_connections;
	uint spam_block_duration;
} mail_startup_t;

/* startup options that requires re-initialization/recycle when changed */
#if defined(STARTUP_INIT_FIELD_TABLES)
static struct init_field mail_init_fields[] = {
	OFFSET_AND_SIZE(mail_startup_t, smtp_port)
	, OFFSET_AND_SIZE(mail_startup_t, pop3_port)
	, OFFSET_AND_SIZE(mail_startup_t, pop3s_port)
	, OFFSET_AND_SIZE(mail_startup_t, submission_port)
	, OFFSET_AND_SIZE(mail_startup_t, submissions_port)
	, OFFSET_AND_SIZE(mail_startup_t, interfaces)
	, OFFSET_AND_SIZE(mail_startup_t, ctrl_dir)
	, { 0, 0 }    /* terminator */
#define MAIL_OPT_DEBUG_RX_HEADER        (1 << 0)
#define MAIL_OPT_DEBUG_RX_BODY          (1 << 1)
#define MAIL_OPT_ALLOW_POP3             (1 << 2)
#define MAIL_OPT_DEBUG_TX               (1 << 3)
#define MAIL_OPT_DEBUG_RX_RSP           (1 << 4)
#define MAIL_OPT_RELAY_TX               (1 << 5)  /* Use SMTP relay server */
#define MAIL_OPT_DEBUG_POP3             (1 << 6)
#define MAIL_OPT_ALLOW_RX_BY_NUMBER     (1 << 7)  /* Receive mail sent to user # */
#define MAIL_OPT_NO_NOTIFY              (1 << 8)  /* Don't notify local recipients */
#define MAIL_OPT_ALLOW_SYSOP_ALIASES    (1 << 9)  /* Receive mail sent to built-in sysop aliases (i.e. "sysop" and "postmaster") */
#define MAIL_OPT_USE_SUBMISSION_PORT    (1 << 10) /* Listen on the "MSA" service port for mail submissions */
#define MAIL_OPT_NO_HOST_LOOKUP         (1 << 11) /* Don't look-up hostnames */
#define MAIL_OPT_USE_TCP_DNS            (1 << 12) /* Use TCP vs UDP for DNS req */
#define MAIL_OPT_NO_SENDMAIL            (1 << 13) /* Don't run SendMail thread */
#define MAIL_OPT_ALLOW_RELAY            (1 << 14) /* Allow relays from stored user IPs */
#define MAIL_OPT_DNSBL_REFUSE           (1 << 15) /* Refuse session, return error */
#define MAIL_OPT_DNSBL_IGNORE           (1 << 16) /* Dump mail, return success */
#define MAIL_OPT_DNSBL_BADUSER          (1 << 17) /* Refuse mail (bad user name) */
#define MAIL_OPT_DNSBL_CHKRECVHDRS      (1 << 18) /* Check all Recieved: from addresses */
#define MAIL_OPT_DNSBL_THROTTLE         (1 << 19) /* Throttle receive from blacklisted servers */
#define MAIL_OPT_DNSBL_SPAMHASH         (1 << 20) /* Store hashes of ignored or tagged messages in spam.hash */
#define MAIL_OPT_SMTP_AUTH_VIA_IP       (1 << 21) /* Allow SMTP authentication via IP */
#define MAIL_OPT_SEND_INTRANSIT         (1 << 22) /* Send mail, even if already "in transit" */
#define MAIL_OPT_RELAY_AUTH_PLAIN       (1 << 23)
#define MAIL_OPT_RELAY_AUTH_LOGIN       (1 << 24)
#define MAIL_OPT_RELAY_AUTH_CRAM_MD5    (1 << 25)
#define MAIL_OPT_NO_AUTO_EXEMPT         (1 << 26) /* Do not auto DNSBL-exempt recipient e-mail addresses */
#define MAIL_OPT_NO_RECYCLE             (1 << 27) /* Disable recycling of server		*/
#define MAIL_OPT_KILL_READ_SPAM         (1 << 28) /* Set the KILLREAD flag on SPAM msgs */
#define MAIL_OPT_TLS_SUBMISSION         (1 << 29) /* Listen on the TLS "MSA" service port for mail submissions */
#define MAIL_OPT_TLS_POP3               (1 << 30) /* POP3S */
#define MAIL_OPT_MUTE                   (1U << 31)

#define MAIL_OPT_RELAY_AUTH_MASK        (MAIL_OPT_RELAY_AUTH_PLAIN | MAIL_OPT_RELAY_AUTH_LOGIN | MAIL_OPT_RELAY_AUTH_CRAM_MD5)
/* mail_startup_t.options bits that require re-init/recycle when changed */
#define MAIL_INIT_OPTS  (MAIL_OPT_ALLOW_POP3 | MAIL_OPT_NO_SENDMAIL)
#if defined(STARTUP_INI_BITDESC_TABLES)
static ini_bitdesc_t mail_options[] = {

	{ MAIL_OPT_DEBUG_RX_HEADER, "DEBUG_RX_HEADER"      },
	{ MAIL_OPT_DEBUG_RX_BODY, "DEBUG_RX_BODY"        },
	{ MAIL_OPT_ALLOW_POP3, "ALLOW_POP3"           },
	{ MAIL_OPT_DEBUG_TX, "DEBUG_TX"             },
	{ MAIL_OPT_DEBUG_RX_RSP, "DEBUG_RX_RSP"         },
	{ MAIL_OPT_RELAY_TX, "RELAY_TX"             },
	{ MAIL_OPT_DEBUG_POP3, "DEBUG_POP3"           },
	{ MAIL_OPT_ALLOW_RX_BY_NUMBER, "ALLOW_RX_BY_NUMBER"   },
	{ MAIL_OPT_ALLOW_SYSOP_ALIASES, "ALLOW_SYSOP_ALIASES"  },
	{ MAIL_OPT_USE_SUBMISSION_PORT, "USE_SUBMISSION_PORT"  },
	{ MAIL_OPT_NO_NOTIFY, "NO_NOTIFY"            },
	{ MAIL_OPT_NO_HOST_LOOKUP, "NO_HOST_LOOKUP"       },
	{ MAIL_OPT_USE_TCP_DNS, "USE_TCP_DNS"          },
	{ MAIL_OPT_NO_SENDMAIL, "NO_SENDMAIL"          },
	{ MAIL_OPT_ALLOW_RELAY, "ALLOW_RELAY"          },
	{ MAIL_OPT_SMTP_AUTH_VIA_IP, "SMTP_AUTH_VIA_IP"     },
	{ MAIL_OPT_DNSBL_REFUSE, "DNSBL_REFUSE"         },
	{ MAIL_OPT_DNSBL_IGNORE, "DNSBL_IGNORE"         },
	{ MAIL_OPT_DNSBL_BADUSER, "DNSBL_BADUSER"        },
	{ MAIL_OPT_DNSBL_CHKRECVHDRS, "DNSBL_CHKRECVHDRS"    },
	{ MAIL_OPT_DNSBL_THROTTLE, "DNSBL_THROTTLE"       },
	{ MAIL_OPT_DNSBL_SPAMHASH, "DNSBL_SPAMHASH"       },
	{ MAIL_OPT_SEND_INTRANSIT, "SEND_INTRANSIT"       },
	{ MAIL_OPT_RELAY_AUTH_PLAIN, "RELAY_AUTH_PLAIN"     },
	{ MAIL_OPT_RELAY_AUTH_LOGIN, "RELAY_AUTH_LOGIN"     },
	{ MAIL_OPT_RELAY_AUTH_CRAM_MD5, "RELAY_AUTH_CRAM_MD5"  },
	{ MAIL_OPT_NO_AUTO_EXEMPT, "NO_AUTO_EXEMPT"       },
	{ MAIL_OPT_NO_RECYCLE, "NO_RECYCLE"           },
	{ MAIL_OPT_KILL_READ_SPAM, "KILL_READ_SPAM"       },
	{ MAIL_OPT_TLS_SUBMISSION, "TLS_SUBMISSION"       },
	{ MAIL_OPT_TLS_POP3, "TLS_POP3"             },
	{ MAIL_OPT_MUTE, "MUTE"                 },
	/* terminator */
#ifdef DLLEXPORT
#undef DLLEXPORT
#endif
#ifdef DLLCALL
#undef DLLCALL
#endif

#ifdef _WIN32
	#ifdef MAILSRVR_EXPORTS
		#define DLLEXPORT __declspec(dllexport)
	#else
		#define DLLEXPORT __declspec(dllimport)
	#endif
	#ifdef __BORLANDC__
#endif

#ifdef __cplusplus
extern "C" {
#endif
/* arg is pointer to static mail_startup_t* */
DLLEXPORT void DLLCALL mail_server(void* arg);
DLLEXPORT void DLLCALL mail_terminate(void);
DLLEXPORT const char*   DLLCALL mail_ver(void);

/* for mxlookup.c: */
void mail_open_socket(SOCKET sock, void* cb_protocol);
int mail_close_socket(SOCKET *sock, int *sess);
#ifdef __cplusplus
}
#if defined(__GNUC__)   // passing an empty string to sockprintf() is expected/valid
#pragma GCC diagnostic ignored "-Wformat-zero-length"
#endif

int sockprintf(SOCKET sock, const char* prot, int sess, char *fmt, ...)
#if defined(__GNUC__)   // Catch printf-format errors
__attribute__ ((format (printf, 4, 5)));
#endif /* Don't add anything after this line */