2021-02-16 13:27:27 -08:00
#!/bin/bash
#
# vmail-stack
# https://git.stack-source.com/msb/vmail-stack
# MIT License Copyright (c) 2021 Matthew Saunders Brown
2021-04-02 12:02:50 -07:00
# load include file
source $( dirname $0 ) /vmail.sh
2021-02-16 13:27:27 -08:00
help( )
{
thisfilename = $( basename -- " $0 " )
echo " $thisfilename "
echo "Add email forward to vmail system"
echo ""
2021-10-15 15:17:29 -07:00
echo " usage: $thisfilename -e <email> -f <forward> [-k <0|1>] [-h] "
2021-02-16 13:27:27 -08:00
echo ""
2021-10-15 15:17:29 -07:00
echo " -h Print this help."
echo " -e <email> Email address to forward."
echo " -f <forward> Email address to forward to."
echo " -k <0|1> Save Local (forward & Keep local copy). 0 = no/off, 1 = yes/on. Default is 0."
2021-02-16 13:27:27 -08:00
echo ""
2021-10-15 15:17:29 -07:00
echo " Forwarding is for delivering an email to another domain. Use aliases"
echo " for directing emails to another address in the same domain."
echo " 'email' and 'forward' should both be in full email address format."
echo " .e.g to have info@example.org delivered (forwarded) to joe@example.com do:"
echo " $thisfilename info@example.org joe@example.com "
2021-02-16 13:27:27 -08:00
exit
}
2021-10-15 15:17:29 -07:00
vmail:getoptions " $@ "
# check for email
if [ [ -z $email ] ] ; then
echo "email is required"
exit
2021-02-16 13:27:27 -08:00
fi
2021-10-15 15:17:29 -07:00
# check for forward
if [ [ -z $forward ] ] ; then
echo "forward is required"
exit
fi
2021-02-16 13:27:27 -08:00
# build query
dbcmd = " mysql --defaults-extra-file= $MYSQL_CONNECTION_INFO_FILE "
dbcmdopts = "-s -r -N -e"
# get mbox id, which also verfies that email address exists
dbquery = " SELECT vm_mboxes.id FROM vm_mboxes, vm_domains WHERE vm_mboxes.mbox=' $mbox ' AND vm_mboxes.domain_id=vm_domains.id AND vm_domains.domain=' $domain '; "
mbox_id = ` eval $dbcmd $dbcmdopts \" $dbquery \" `
if [ -z $mbox_id ] ; then
# mbox does not exist, can't create forward
echo " ERROR: Address to Forward ( $email ) does not exist. "
exit 1
elif [ " $mbox_id " -gt '0' ] ; then
# verified mbox, check for existing forward
dbquery = " SELECT id FROM vm_forwards WHERE mbox_id=' $mbox_id '; "
vm_forwards_id = ` eval $dbcmd $dbcmdopts \" $dbquery \" `
if [ -z $vm_forwards_id ] ; then
# existing forward does not exist, add it now
2021-10-15 15:17:29 -07:00
dbquery = " INSERT INTO vm_forwards SET mbox_id=' $mbox_id ', forward_to=' $forward ' "
if [ ! -z $keep ] ; then
dbquery = " $dbquery , save_local=' $keep ' "
2021-02-16 13:27:27 -08:00
fi
2021-02-16 13:36:46 -08:00
eval $dbcmd $dbcmdopts \" $dbquery \; \"
2021-02-16 13:27:27 -08:00
else
echo " ERROR: Forward for $email already exists. To change either del then add or use mod script. "
exit 1
fi
else
# db query error
echo "ERROR: System error querying vmail database."
exit 1
fi