#!@RCD_SCRIPTS_SHELL@ # # $NetBSD: qmailpop3d.sh,v 1.24 2018/11/08 20:57:28 schmonz Exp $ # # @PKGNAME@ script to control qmail-pop3d (POP3 server for Maildirs). # # PROVIDE: qmailpop3d mail name="qmailpop3d" # User-settable rc.conf variables and their default values: : ${qmailpop3d_postenv:="SSL_UID=$(@ID@ -u @UCSPI_SSL_USER@) SSL_GID=$(@ID@ -g @UCSPI_SSL_GROUP@)"} : ${qmailpop3d_tcpflags:="-ne -vRl0"} : ${qmailpop3d_tcphost:="0.0.0.0"} : ${qmailpop3d_tcpport:="110"} : ${qmailpop3d_datalimit:="180000000"} : ${qmailpop3d_pretcpserver:=""} : ${qmailpop3d_tcpserver:="@PREFIX@/bin/sslserver"} : ${qmailpop3d_prepop3d:=""} : ${qmailpop3d_pop3dcmd:="@PREFIX@/bin/qmail-pop3d"} : ${qmailpop3d_checkpassword:="@PREFIX@/bin/nbcheckpassword"} : ${qmailpop3d_maildirname:="Maildir"} : ${qmailpop3d_log:="YES"} : ${qmailpop3d_logcmd:="logger -t nbqmail/pop3d -p mail.info"} : ${qmailpop3d_nologcmd:="@PREFIX@/bin/multilog -*"} : ${qmailpop3d_tls:="auto"} : ${qmailpop3pd_tls_dhparams:="@PKG_SYSCONFDIR@/control/dh2048.pem"} : ${qmailpop3pd_tls_cert:="@PKG_SYSCONFDIR@/control/servercert.pem"} if [ -f /etc/rc.subr ]; then . /etc/rc.subr fi rcvar=${name} required_files="@PKG_SYSCONFDIR@/control/me" required_files="${required_files} @PKG_SYSCONFDIR@/control/concurrencypop3" required_files="${required_files} @PKG_SYSCONFDIR@/control/pop3capabilities" required_files="${required_files} @PKG_SYSCONFDIR@/tcp.pop3.cdb" command="${qmailpop3d_tcpserver}" procname=nb${name} start_precmd="qmailpop3d_precmd" extra_commands="stat pause cont cdb reload" stat_cmd="qmailpop3d_stat" pause_cmd="qmailpop3d_pause" cont_cmd="qmailpop3d_cont" cdb_cmd="qmailpop3d_cdb" reload_cmd=${cdb_cmd} qmailpop3d_configure_tls() { if [ "auto" = "${qmailpop3d_tls}" ]; then if [ -f "${qmailpop3d_tls_dhparams}" ] && [ -f "${qmailpop3d_tls_cert}" ]; then qmailpop3d_enable_tls else qmailpop3d_disable_tls fi elif [ -f /etc/rc.subr ] && checkyesno qmailpop3d_tls; then qmailpop3d_enable_tls else qmailpop3d_disable_tls fi } qmailpop3d_disable_tls() { qmailpop3d_postenv="${qmailpop3d_postenv} DISABLETLS=1" } qmailpop3d_enable_tls() { qmailpop3d_postenv="${qmailpop3d_postenv} DHFILE=${qmailpop3d_tls_dhparams}" qmailpop3d_postenv="${qmailpop3d_postenv} CERTFILE=${qmailpop3d_tls_cert}" } qmailpop3d_precmd() { if [ -f /etc/rc.subr ] && ! checkyesno qmailpop3d_log; then qmailpop3d_logcmd=${qmailpop3d_nologcmd} fi qmailpop3d_configure_tls # tcpserver(1) is akin to inetd(8), but runs one service per process. # We want to signal only the tcpserver process responsible for this # service. Use argv0(1) to set procname to "nbqmailpop3d". command="@PREFIX@/bin/pgrphack @SETENV@ - ${qmailpop3d_postenv} @PREFIX@/bin/softlimit -m ${qmailpop3d_datalimit} ${qmailpop3d_pretcpserver} @PREFIX@/bin/argv0 ${qmailpop3d_tcpserver} ${procname} ${qmailpop3d_tcpflags} -x @PKG_SYSCONFDIR@/tcp.pop3.cdb -c `@HEAD@ -1 @PKG_SYSCONFDIR@/control/concurrencypop3` ${qmailpop3d_tcphost} ${qmailpop3d_tcpport} @PREFIX@/bin/authup pop3 ${qmailpop3d_checkpassword} @PREFIX@/bin/checknotroot ${qmailpop3d_prepop3d} ${qmailpop3d_pop3dcmd} ${qmailpop3d_maildirname} 2>&1 | @PREFIX@/bin/pgrphack @PREFIX@/bin/setuidgid @QMAIL_LOG_USER@ ${qmailpop3d_logcmd}" command_args="&" rc_flags="" } qmailpop3d_stat() { run_rc_command status } qmailpop3d_pause() { if ! statusmsg=`run_rc_command status`; then @ECHO@ $statusmsg return 1 fi @ECHO@ "Pausing ${name}." kill -STOP $rc_pid } qmailpop3d_cont() { if ! statusmsg=`run_rc_command status`; then @ECHO@ $statusmsg return 1 fi @ECHO@ "Continuing ${name}." kill -CONT $rc_pid } qmailpop3d_cdb() { @ECHO@ "Reloading @PKG_SYSCONFDIR@/tcp.pop3." cd @PKG_SYSCONFDIR@ @PREFIX@/bin/tcprules tcp.pop3.cdb tcp.pop3.tmp < tcp.pop3 @CHMOD@ 644 tcp.pop3.cdb } if [ -f /etc/rc.subr ]; then load_rc_config $name run_rc_command "$1" else @ECHO_N@ " ${name}" qmailpop3d_precmd eval ${command} ${qmailpop3d_flags} ${command_args} fi