File: //volume1/@appstore/MailPlus-Server/hook/AliasUserDelete.sh
#!/bin/bash
###############################################################
# This script should be hooked when invoking user delete
# Usable environment variable:
# NITEMS, USER_NAME_X, USER_OP_RESULT_X, RESULT
###############################################################
#Include common scripts
. /var/packages/MailPlus-Server/target/scripts/MailPlusServerCommon
. /var/packages/MailPlus-Server/target/backend_hook/hookUtils.conf
#At begining, acquire package settings
PackageInfoGet;
MAIL_SERVER_PKG="/var/packages/MailPlus-Server"
ALIAS_DB="${MAIL_SERVER_PKG}/etc/alias.db"
ConfigGen="${MAIL_SERVER_PKG}/target/bin/syno_set_config"
case $1 in
--sdk-mod-ver)
#Print SDK support version
echo "${SDK_MOD_VER}";
;;
--name)
#Print package name
echo "${MAIL_SERVER_PKG_NAME}";
;;
--pkg-ver)
#Print package version
echo "${MAIL_SERVER_PKG_VERSION}";
;;
--vendor)
#Print package vendor
echo "${MAIL_SERVER_PKG_VENDOR}";
;;
--pre)
#noop
;;
--post)
if [ ! -e $ALIAS_DB ]; then
exit 1;
fi
usr_idx=1;
usr_cnt=$(($NITEMS + 1));
(
if flock -w 30 -x 100; then
chown MailPlus-Server:MailPlus-Server ${ALIAS_DB_FILE_LOCK}
chmod 644 ${ALIAS_DB_FILE_LOCK}
while [ "$usr_idx" != "$usr_cnt" ]
do
eval "usr_name=\$USER_NAME_$usr_idx"
if [ ! -z "$usr_name" ]; then
sqlite3 $ALIAS_DB "DELETE FROM alias_info_table WHERE member='$usr_name' and type=0;"
if [ 0 != $? ]; then
err_log "[Alias User Delete]: failed to delete $usr_name from alias db"
fi
fi
usr_idx=$(($usr_idx + 1));
done
flock -u 100
rm ${ALIAS_DB_FILE_LOCK}
else
err_log "[Alias User Delete]: failed to get lock [${ALIAS_DB_FILE_LOCK}]"
fi
)100> ${ALIAS_DB_FILE_LOCK}
$ConfigGen virtual_alias
;;
*)
echo "Usage: $0 --sdk-mod-ver|--name|--pkg-ver|--vendor|--pre|--post"
;;
esac