2000-01-01 00:54:12 -05:00
|
|
|
#!/bin/sh
|
2000-04-08 02:06:25 -04:00
|
|
|
# $OpenBSD: INSTALL,v 1.5 2000/04/08 06:06:25 brad Exp $
|
2000-01-01 00:54:12 -05:00
|
|
|
#
|
|
|
|
# Pre/post-installation setup of MySQL
|
|
|
|
|
|
|
|
# exit on errors, use a sane path and install prefix
|
|
|
|
#
|
|
|
|
set -e
|
|
|
|
PATH=/bin:/usr/bin:/sbin:/usr/sbin
|
|
|
|
PREFIX=${PKG_PREFIX:-/usr/local}
|
2000-01-04 12:39:42 -05:00
|
|
|
DB_DIR=${PKG_DB_DIR:-/var/mysql}
|
2000-04-08 02:06:25 -04:00
|
|
|
|
2000-01-01 00:54:12 -05:00
|
|
|
MYSQLGID=40
|
|
|
|
MYSQLUID=40
|
|
|
|
|
2000-04-07 15:07:20 -04:00
|
|
|
# Function: tell the user that an existing database directory was
|
|
|
|
# found on their system
|
|
|
|
do_notice_pre_install()
|
|
|
|
{
|
|
|
|
echo
|
|
|
|
echo "+---------------"
|
|
|
|
echo "| You appear to already have a MySQL database directory in ${DB_DIR}"
|
|
|
|
echo "|"
|
|
|
|
echo "| In order to preserve your existing data, you should:"
|
|
|
|
echo "| - dump all your databases"
|
|
|
|
echo "| - kill MySQL if it's running"
|
|
|
|
echo "| - delete the ${DB_DIR} directory"
|
|
|
|
echo "| - install MySQL"
|
|
|
|
echo "| - start up MySQL"
|
|
|
|
echo "| - re-create all of your database"
|
|
|
|
echo "| - re-load your data"
|
|
|
|
echo "+---------------"
|
|
|
|
echo
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
|
|
|
# Function: install the MySQL user account and group
|
2000-01-01 00:54:12 -05:00
|
|
|
#
|
|
|
|
do_pre_install()
|
|
|
|
{
|
|
|
|
# Add group 'mysql' to /etc/group
|
2000-01-04 12:39:42 -05:00
|
|
|
if [ "`egrep '^mysql:' /etc/group`" = "" ]; then
|
2000-01-01 00:54:12 -05:00
|
|
|
echo "===> Creating mysql group, gid $MYSQLGID"
|
2000-04-08 02:06:25 -04:00
|
|
|
echo "mysql:*:${MYSQLGID}:" 2>/dev/null >> /etc/group || {
|
|
|
|
echo "===> Problem creating group mysql" >&2
|
|
|
|
exit 1
|
|
|
|
}
|
2000-01-01 00:54:12 -05:00
|
|
|
fi
|
|
|
|
|
|
|
|
# Add user 'mysql' in /etc/passwd
|
2000-01-04 12:39:42 -05:00
|
|
|
if [ "`egrep '^mysql:' /etc/passwd`" = "" ]; then
|
2000-02-06 18:32:38 -05:00
|
|
|
echo "===> Creating mysql user, uid $MYSQLUID"
|
2000-04-08 02:06:25 -04:00
|
|
|
adduser -batch mysql mysql "MySQL Account" "" -uid_start ${MYSQLUID} > /dev/null 2>&1 /dev/null
|
2000-01-01 00:54:12 -05:00
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
echo "===> Using account mysql for MySQL, uid $MYSQLUID, gid $MYSQLGID"
|
|
|
|
else
|
|
|
|
echo "===> Problem creating account mysql"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2000-04-07 15:07:20 -04:00
|
|
|
# Function: create database directory and the initial database
|
2000-01-01 00:54:12 -05:00
|
|
|
#
|
|
|
|
do_post_install()
|
|
|
|
{
|
2000-04-07 15:07:20 -04:00
|
|
|
install -d -o mysql -g mysql -m 775 ${DB_DIR}
|
|
|
|
|
|
|
|
# The shell is switched back to /bin/sh to ensure that the database
|
|
|
|
# creation can proceed successfully
|
|
|
|
chpass -s /bin/sh mysql
|
2000-01-04 12:39:42 -05:00
|
|
|
su mysql -c ${PREFIX}/bin/mysql_install_db
|
2000-04-07 15:07:20 -04:00
|
|
|
chpass -s /sbin/nologin mysql
|
2000-01-01 00:54:12 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
# Verify/process the command
|
|
|
|
#
|
|
|
|
case $2 in
|
|
|
|
PRE-INSTALL)
|
2000-04-07 15:07:20 -04:00
|
|
|
if [ -d $DB_DIR ]; then
|
|
|
|
do_notice_pre_install $1
|
|
|
|
fi
|
|
|
|
do_pre_install
|
2000-01-01 00:54:12 -05:00
|
|
|
;;
|
|
|
|
POST-INSTALL)
|
2000-04-07 15:07:20 -04:00
|
|
|
do_post_install
|
2000-01-01 00:54:12 -05:00
|
|
|
;;
|
|
|
|
*)
|
|
|
|
echo "usage: $0 distname { PRE-INSTALL | POST-INSTALL }" >&2
|
|
|
|
exit 1
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
exit 0
|