| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177 |
- #!@l_bash@
- ##
- ## drupal-setup.sh -- Drupal RDBMS Setup Utility
- ##
- # command line argument sanity check
- prg="$0"
- if [ $# -eq 0 ]; then
- echo "$prg:ERROR: invalid command line" 1>&2
- echo "$prg:USAGE: $prg install [<database-directory>]" 1>&2
- echo "$prg:USAGE: $prg uninstall" 1>&2
- echo "$prg:USAGE: $prg backup [<dump-file>]" 1>&2
- echo "$prg:USAGE: $prg restore [<dump-file>|<dump-number>]" 1>&2
- exit 1
- fi
- # database configuration
- db_dir="@l_prefix@/var/drupal/db"
- db_dump="@l_prefix@/var/drupal/dump"
- db_type="@l_dbtype@"
- db_name="drupal"
- db_user="drupal"
- db_pass="drupal"
- # determine RDBMS-specific details
- if [ ".$db_type" = .mysql ]; then
- db_sname="mysql"
- 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_sname=`grep "^superuser_database" @l_prefix@/var/postgresql/db/pg_superuser.conf |\
- sed -e 's;^ *superuser_database="\(.*\)".*;\1;'`
- db_suser=`grep "^superuser_username" @l_prefix@/var/postgresql/db/pg_superuser.conf |\
- sed -e 's;^ *superuser_username="\(.*\)".*;\1;'`
- db_spass=`grep "^superuser_password" @l_prefix@/var/postgresql/db/pg_superuser.conf |\
- sed -e 's;^ *superuser_password="\(.*\)".*;\1;'`
- fi
- # dispatch operation
- cmd="${1:-"install"}"
- shift
- case "$cmd" in
- install )
- ##
- ## create the database
- ##
- if [ $# -gt 0 ]; then
- db_dir="$1"
- shift
- fi
- if [ ".$db_type" = .mysql ]; then
- # FIXME: MySQL 5.0 still doesn't allow easy relocation of tablespaces
- @l_prefix@/bin/mysqladmin --user="$db_suser" --password="$db_spass" create "$db_name"
- ( echo "GRANT ALL PRIVILEGES ON $db_name.* TO $db_user@localhost IDENTIFIED BY '$db_pass';"
- echo "FLUSH PRIVILEGES;"
- ) | @l_prefix@/bin/mysql --user="$db_suser" --password="$db_spass" "$db_sname"
- 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 ENCODING 'UTF8';"
- ) | PGPASSWORD="$db_spass" @l_prefix@/bin/psql -q -U "$db_suser" -d "$db_sname" -f-
- fi
- # activate configuration directory
- # (is automatically deactivated by installer afterwards)
- if [ ".$DRUPAL_SETUP_RESTORE" = . ]; then
- chmod 777 @l_prefix@/share/drupal/sites/default
- fi
- ;;
- uninstall )
- ##
- ## remove the database
- ##
- if [ ".$db_type" = .mysql ]; then
- ( echo "DROP DATABASE $db_name;"
- ) | @l_prefix@/bin/mysql --user="$db_suser" --password="$db_spass" "$db_sname"
- elif [ ".$db_type" = .pgsql ]; then
- ( echo "DROP DATABASE $db_name;"
- echo "DROP TABLESPACE $db_name;"
- echo "DROP ROLE $db_user;"
- ) | PGPASSWORD="$db_spass" @l_prefix@/bin/psql -q -U "$db_suser" -d "$db_sname" -f-
- fi
- # remove the generated configuration
- if [ ".$DRUPAL_SETUP_RESTORE" = . ]; then
- rm -f @l_prefix@/share/drupal/sites/default/settings.php
- fi
- ;;
- backup )
- ##
- ## backup the database
- ##
- # determine dumpfile
- if [ $# -gt 0 ]; then
- # manually managed dumpfile
- dumpfile="$1"
- else
- # automatically managed (rotated) dumpfile
- rm -f $db_dump/drupal-dump-9.sql.gz >/dev/null 2>&1 || true
- i=8
- while [ $i -ge 0 ]; do
- if [ -f $db_dump/drupal-dump-$i.sql.bz2 ]; then
- mv $db_dump/drupal-dump-$i.sql.bz2 $db_dump/drupal-dump-`expr $i + 1`.sql.bz2
- fi
- i=`expr $i - 1`
- done
- dumpfile="$db_dump/drupal-dump-0.sql.bz2"
- fi
- # dump database content to dumpfile (compressed plain SQL format)
- umask 007
- if [ ".$db_type" = .mysql ]; then
- @l_prefix@/bin/mysqldump --user="$db_suser" --password="$db_spass" "$db_name" | \
- @l_prefix@/lib/openpkg/bzip2 -9 >$dumpfile
- elif [ ".$db_type" = .pgsql ]; then
- PGPASSWORD="$db_spass" @l_prefix@/bin/pg_dump -U "$db_suser" -S "$db_suser" "$db_name" | \
- @l_prefix@/lib/openpkg/bzip2 -9 >$dumpfile
- fi
- chown @l_rusr@:@l_rgrp@ $dumpfile >/dev/null 2>&1 || true
- chmod 640 $dumpfile >/dev/null 2>&1 || true
- ;;
- restore )
- ##
- ## restore the database
- ##
- # determine dumpfile
- if [ $# -gt 0 ]; then
- dumpfile="$1"
- else
- dumpfile="0"
- fi
- case "$dumpfile" in
- [0-9] ) dumpfile="$db_dump/drupal-dump-$dumpfile.sql.bz2" ;;
- esac
- if [ ! -f $dumpfile ]; then
- echo "drupal-setup:restore:ERROR: no such dump file: $dumpfile" 1>&2
- exit 1
- fi
- # optionally stop Drupal
- eval `@l_prefix@/bin/openpkg rc drupal status 2>/dev/null || true`
- if [ ".$drupal_active" = .yes ]; then
- @l_prefix@/bin/openpkg rc drupal stop >/dev/null 2>&1 || true
- fi
- # drop old and initialize new database
- DRUPAL_SETUP_RESTORE=1
- export DRUPAL_SETUP_RESTORE
- $prg uninstall || exit $?
- $prg install || exit $?
- # restore database content from dumpfile (compressed plain SQL format)
- if [ ".$db_type" = .mysql ]; then
- @l_prefix@/lib/openpkg/bzip2 -d -c $dumpfile | \
- @l_prefix@/bin/mysql --user="$db_suser" --password="$db_spass" "$db_name" >/dev/null
- elif [ ".$db_type" = .pgsql ]; then
- @l_prefix@/lib/openpkg/bzip2 -d -c $dumpfile | \
- PGPASSWORD="$db_spass" @l_prefix@/bin/psql -q -U "$db_suser" -d "$db_name" -f- >/dev/null
- fi
- # optionally restart Drupal
- if [ ".$drupal_active" = .yes ]; then
- @l_prefix@/bin/openpkg rc drupal start >/dev/null 2>&1 || true
- fi
- ;;
- esac
|