2015-08-18 23:57:56 +08:00
#! /bin/sh
set -e
if [ "$1" = "configure" ]; then
2016-04-07 01:03:24 +08:00
2017-06-20 21:44:18 +08:00
. /etc/zm/zm.conf
2018-02-23 22:30:47 +08:00
for i in /etc/zm/conf.d/*.conf; do
. $i
done;
2017-06-20 21:44:18 +08:00
# The logs can contain passwords, etc... so by setting group root, only www-data can read them, not people in the www-data group
chown www-data:root /var/log/zm
chown www-data:www-data /var/lib/zm
if [ -z "$2" ]; then
chown www-data:www-data /var/cache/zoneminder /var/cache/zoneminder/*
fi
# Do this every time the package is installed or upgraded
# Ensure zoneminder is stopped
invoke-rc.d zoneminder stop || true
if [ "$ZM_DB_HOST" = "localhost" ]; then
if [ -e "/etc/init.d/mysql" ]; then
#
# Get mysql started if it isn't
#
if ! $(/etc/init.d/mysql status >/dev/null 2>&1); then
invoke-rc.d mysql start
fi
if $(/etc/init.d/mysql status >/dev/null 2>&1); then
mysqladmin --defaults-file=/etc/mysql/debian.cnf -f reload
# test if database if already present...
if ! $(echo quit | mysql --defaults-file=/etc/mysql/debian.cnf zm > /dev/null 2> /dev/null) ; then
cat /usr/share/zoneminder/db/zm_create.sql | mysql --defaults-file=/etc/mysql/debian.cnf
2019-05-17 20:34:19 +08:00
if [ $? -ne 0 ]; then
echo "Error creating db."
exit 1;
fi
2017-06-20 21:44:18 +08:00
# This creates the user.
2018-01-30 00:44:29 +08:00
echo "grant lock tables, alter,drop,select,insert,update,delete,create,index,alter routine,create routine, trigger,execute on ${ZM_DB_NAME}.* to '${ZM_DB_USER}'@localhost identified by \"${ZM_DB_PASS}\";" | mysql --defaults-file=/etc/mysql/debian.cnf mysql
2017-06-20 21:44:18 +08:00
else
2018-01-30 00:44:29 +08:00
echo "grant lock tables, alter,drop,select,insert,update,delete,create,index,alter routine,create routine, trigger,execute on ${ZM_DB_NAME}.* to '${ZM_DB_USER}'@localhost;" | mysql --defaults-file=/etc/mysql/debian.cnf mysql
2016-04-07 01:45:46 +08:00
fi
2017-06-20 21:44:18 +08:00
zmupdate.pl --nointeractive
zmupdate.pl --nointeractive -f
2017-12-11 03:14:39 +08:00
# Add any new PTZ control configurations to the database (will not overwrite)
zmcamtool.pl --import >/dev/null 2>&1
2017-06-20 21:44:18 +08:00
else
echo 'NOTE: mysql not running, please start mysql and run dpkg-reconfigure zoneminder when it is running.'
fi
2016-04-07 01:45:46 +08:00
else
2017-06-20 21:44:18 +08:00
echo 'mysql not found, assuming remote server.'
2016-04-07 01:45:46 +08:00
fi
2017-06-20 21:44:18 +08:00
else
echo "Not doing database upgrade due to remote db server ($ZM_DB_HOST)"
fi
echo "Done Updating, starting ZoneMinder"
invoke-rc.d zoneminder start || true
2015-08-18 23:57:56 +08:00
fi
#DEBHELPER#