You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
72 lines
2.9 KiB
72 lines
2.9 KiB
#!/bin/sh |
|
## |
|
## dbmail-setup.sh -- DBMail RDBMS Setup Utility |
|
## |
|
|
|
# package configuration |
|
db_type="@db_type@" |
|
db_script="@l_prefix@/share/dbmail/dbmail-setup.sql" |
|
|
|
# determine database details |
|
# FIXME: bail out if extracted values are empty or don't make sense |
|
db_dir="@l_prefix@/var/dbmail/db" |
|
db_name=`grep "^db" @l_prefix@/etc/dbmail/dbmail.conf | sed -e 's;^[^=]*= *;;'` |
|
db_user=`grep "^user" @l_prefix@/etc/dbmail/dbmail.conf | sed -e 's;^[^=]*= *;;'` |
|
db_pass=`grep "^pass" @l_prefix@/etc/dbmail/dbmail.conf | sed -e 's;^[^=]*= *;;'` |
|
|
|
# determine RDBMS-specific details |
|
if [ ".$db_type" = .sqlite ]; then |
|
db_suser="@l_rusr@" |
|
db_spass="@l_rgrp@" |
|
elif [ ".$db_type" = .mysql ]; then |
|
db_suser=`grep "^user" @l_prefix@/etc/mysql/my.pwd |\ |
|
sed -e 's;^user[^=]*= *;;' -e 's; *$;;'` |
|
db_spass=`grep "^password" @l_prefix@/etc/mysql/my.pwd |\ |
|
sed -e 's;^password[^=]*= *;;' -e 's; *$;;'` |
|
elif [ ".$db_type" = .pgsql ]; then |
|
db_suser="postgresql" |
|
db_spass="" # has to be interactive |
|
fi |
|
|
|
# dispatch operation |
|
cmd="${1:-"install"}" |
|
case "$cmd" in |
|
install ) |
|
# create the DBMail database |
|
if [ ".$db_type" = .sqlite ]; then |
|
( umask 077 |
|
@l_prefix@/bin/sqlite3 $db_name <$db_script |
|
chown $db_suser:$db_spass $db_name |
|
chmod 640 $db_name |
|
) || exit $? |
|
elif [ ".$db_type" = .mysql ]; then |
|
# FIXME: MySQL doesn't allow easy relocation of tablespaces AFAIK --rse |
|
@l_prefix@/bin/mysqladmin --user="$db_suser" --password="$db_spass" create "$db_name" |
|
( echo "GRANT ALL ON $db_name.* TO $db_user@localhost IDENTIFIED BY '$db_pass';" |
|
echo "FLUSH PRIVILEGES;" |
|
) | @l_prefix@/bin/mysql --user="$db_suser" --password="$db_spass" mysql |
|
@l_prefix@/bin/mysql --user="$db_suser" --password="$db_spass" "$db_name" <$db_script |
|
elif [ ".$db_type" = .pgsql ]; then |
|
( echo "CREATE ROLE $db_user LOGIN ENCRYPTED PASSWORD '$db_pass' NOCREATEDB NOCREATEUSER;" |
|
echo "CREATE TABLESPACE $db_name OWNER $db_user LOCATION '$db_dir';" |
|
echo "CREATE DATABASE $db_name OWNER $db_user TABLESPACE $db_name;" |
|
) | @l_prefix@/bin/psql -U "$db_suser" -d template1 -f- |
|
@l_prefix@/bin/psql -U "$db_suser" -d "$db_name" -f- <$db_script |
|
fi |
|
;; |
|
uninstall ) |
|
# remove the DBMail database |
|
if [ ".$db_type" = .sqlite ]; then |
|
rm -f $db_name >/dev/null 2>&1 || true |
|
elif [ ".$db_type" = .mysql ]; then |
|
( echo "DROP DATABASE $db_name;" |
|
) | @l_prefix@/bin/mysql --user="$db_suser" --password="$db_spass" mysql |
|
elif [ ".$db_type" = .pgsql ]; then |
|
( echo "DROP DATABASE $db_name;" |
|
echo "DROP TABLESPACE $db_name;" |
|
echo "DROP ROLE $db_user;" |
|
) | @l_prefix@/bin/psql -U "$db_suser" -d template1 -f- |
|
fi |
|
;; |
|
esac |
|
|
|
|