mirror of
https://github.com/novatiq/packages.git
synced 2026-04-30 07:28:39 +01:00
emailrelay: added configuration options
- moved from net to mail category - removed no-ssl package and added ssl support as configuration option (default enabled) - added configuration option to support extended logging (default disabled) - disabled build of test tools - added LEDE compatibility (support for openssl without SSL3) Signed-off-by: Federico Di Marco <fededim@gmail.com>
This commit is contained in:
@@ -0,0 +1,114 @@
|
||||
#
|
||||
# Copyright (C) 2006-2014 OpenWrt.org
|
||||
#
|
||||
# This is free software, licensed under the GNU General Public License v2.
|
||||
# See /LICENSE for more information.
|
||||
#
|
||||
|
||||
include $(TOPDIR)/rules.mk
|
||||
|
||||
PKG_NAME:=emailrelay
|
||||
PKG_VERSION:=1.9
|
||||
PKG_RELEASE:=3
|
||||
|
||||
PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION)-src.tar.gz
|
||||
PKG_SOURCE_URL:=@SF/emailrelay/$(PKG_VERSION)
|
||||
PKG_MD5SUM:=0892fbf993407c6b5a16f96e23299b62
|
||||
|
||||
PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_NAME)-$(PKG_VERSION)
|
||||
|
||||
PKG_CONFIG_DEPENDS:=CONFIG_EMAILRELAY_SUPPORT_VERBOSE_DBG CONFIG_EMAILRELAY_SSL
|
||||
|
||||
|
||||
include $(INCLUDE_DIR)/uclibc++.mk
|
||||
include $(INCLUDE_DIR)/package.mk
|
||||
|
||||
define Package/emailrelay
|
||||
SECTION:=mail
|
||||
CATEGORY:=Mail
|
||||
DEPENDS:=$(CXX_DEPENDS) +EMAILRELAY_SSL:libopenssl
|
||||
TITLE:=A simple SMTP proxy and MTA
|
||||
URL:=http://emailrelay.sourceforge.net/
|
||||
MAINTAINER:=Federico Di Marco <fededim@gmail.com>
|
||||
MENU:=1
|
||||
endef
|
||||
|
||||
|
||||
define Package/emailrelay/config
|
||||
config EMAILRELAY_SUPPORT_VERBOSE_DBG
|
||||
bool "Enable support for extended logging"
|
||||
depends on PACKAGE_emailrelay
|
||||
default n
|
||||
help
|
||||
Enables support for extended logging (must also be explicitely enabled by using command line switch --debug when starting emailrelay)
|
||||
|
||||
config EMAILRELAY_SSL
|
||||
bool "Enable support for OpenSSL"
|
||||
depends on PACKAGE_emailrelay
|
||||
default y
|
||||
select PACKAGE_libopenssl
|
||||
help
|
||||
Builds the package with OpenSSL support (SSMTP is supported).
|
||||
endef
|
||||
|
||||
|
||||
|
||||
define Package/emailrelay/description
|
||||
Emailrelay is a simple SMTP proxy and store-and-forward message transfer agent (MTA).
|
||||
|
||||
When running as a proxy all e-mail messages can be passed through
|
||||
a user-defined program, such as a spam filter, which can drop,
|
||||
re-address or edit messages as they pass through. When running
|
||||
as a store-and-forward MTA incoming messages are stored in a
|
||||
local spool directory, and then forwarded to the next SMTP
|
||||
server on request.
|
||||
endef
|
||||
|
||||
|
||||
define Package/emailrelay/conffiles
|
||||
/etc/emailrelay.auth
|
||||
endef
|
||||
|
||||
|
||||
CONFIGURE_ARGS += \
|
||||
--with-pam=no \
|
||||
--enable-testing=no
|
||||
|
||||
CONFIGURE_VARS += \
|
||||
CXXFLAGS="$$$$CXXFLAGS -fno-rtti"
|
||||
|
||||
|
||||
ifeq ($(CONFIG_EMAILRELAY_SSL),y)
|
||||
CONFIGURE_ARGS += \
|
||||
--with-openssl
|
||||
else
|
||||
CONFIGURE_ARGS += \
|
||||
--with-openssl=no
|
||||
endif
|
||||
|
||||
|
||||
ifeq ($(CONFIG_EMAILRELAY_SUPPORT_VERBOSE_DBG),y)
|
||||
CONFIGURE_ARGS += \
|
||||
--enable-debug=yes
|
||||
endif
|
||||
|
||||
ifeq ($(CONFIG_OPENSSL_WITH_SSL3),y)
|
||||
CONFIGURE_VARS += \
|
||||
CXXFLAGS="$$$$CXXFLAGS -DSSL3_SUPPORT"
|
||||
endif
|
||||
|
||||
define Package/emailrelay/install
|
||||
$(INSTALL_DIR) $(1)/usr/bin
|
||||
$(INSTALL_BIN) $(PKG_BUILD_DIR)/src/main/emailrelay $(1)/usr/bin/
|
||||
$(INSTALL_BIN) $(PKG_BUILD_DIR)/src/main/emailrelay-filter-copy $(1)/usr/bin/
|
||||
$(INSTALL_BIN) $(PKG_BUILD_DIR)/src/main/emailrelay-passwd $(1)/usr/bin/
|
||||
$(INSTALL_BIN) $(PKG_BUILD_DIR)/src/main/emailrelay-poke $(1)/usr/bin/
|
||||
$(INSTALL_BIN) $(PKG_BUILD_DIR)/src/main/emailrelay-submit $(1)/usr/bin/
|
||||
$(INSTALL_DIR) $(1)/etc
|
||||
$(INSTALL_DATA) files/$(PKG_NAME).auth $(1)/etc/
|
||||
$(INSTALL_DIR) $(1)/etc/init.d
|
||||
$(INSTALL_BIN) files/$(PKG_NAME).init $(1)/etc/init.d/$(PKG_NAME)
|
||||
endef
|
||||
|
||||
|
||||
$(eval $(call BuildPackage,emailrelay))
|
||||
@@ -0,0 +1,16 @@
|
||||
#
|
||||
# emailrelay secrets file
|
||||
#
|
||||
#see http://emailrelay.sourceforge.net/reference.html for reference
|
||||
|
||||
#Mostly used options:
|
||||
#
|
||||
#NONE server specifies ip address range allowed to connect to emailrelay SMTP server
|
||||
#LOGIN client specifies the credentials to be used when forwarding emails to another SMTP server
|
||||
#LOGIN server specifies the credentials to be needed to authenticate with the emailrelay SMTP server
|
||||
|
||||
#Examples:
|
||||
#
|
||||
#NONE server 192.168.1.* keyword
|
||||
#LOGIN client smtpuser@smtpserver smtppassword
|
||||
#LOGIN server user1 secret
|
||||
@@ -0,0 +1,15 @@
|
||||
#!/bin/sh /etc/rc.common
|
||||
#see http://emailrelay.sourceforge.net/reference.html for command line reference
|
||||
|
||||
START=90
|
||||
|
||||
|
||||
start() {
|
||||
logger -t 'emailrelay' "Starting emailrelay service."
|
||||
service_start /usr/bin/emailrelay --as-server --poll 60 --forward-to smtpserver:smtpport --spool-dir /tmp --client-tls --client-auth /etc/emailrelay.auth --server-auth /etc/emailrelay.auth --log
|
||||
}
|
||||
|
||||
stop() {
|
||||
logger -t 'emailrelay' "Stopping emailrelay service."
|
||||
service_stop /usr/bin/emailrelay
|
||||
}
|
||||
@@ -0,0 +1,13 @@
|
||||
--- a/src/gssl/gssl_openssl.cpp
|
||||
+++ b/src/gssl/gssl_openssl.cpp
|
||||
@@ -292,8 +292,10 @@ GSsl::Context::Context( const std::strin
|
||||
{
|
||||
if( (flags&3U) == 2U )
|
||||
m_ssl_ctx = SSL_CTX_new(SSLv23_method()) ;
|
||||
+#ifdef SSL3_SUPPORT
|
||||
else if( (flags&3U) == 3U )
|
||||
m_ssl_ctx = SSL_CTX_new(SSLv3_method()) ;
|
||||
+#endif
|
||||
else
|
||||
m_ssl_ctx = SSL_CTX_new(TLSv1_method()) ;
|
||||
|
||||
Reference in New Issue
Block a user