dbmail-setup.sh 3.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. #!@l_bash@
  2. ##
  3. ## dbmail-setup.sh -- DBMail RDBMS Setup Utility
  4. ##
  5. # command line argument sanity check
  6. if [ $# -eq 0 ]; then
  7. echo "$0:ERROR: invalid command line" 1>&2
  8. echo "$0:USAGE: $0 install [<database-directory>]" 1>&2
  9. echo "$0:USAGE: $0 uninstall" 1>&2
  10. exit 1
  11. fi
  12. # package configuration
  13. db_type="@db_type@"
  14. db_script="@l_prefix@/share/dbmail/dbmail-setup.sql"
  15. # determine database details
  16. # FIXME: bail out if extracted values are empty or don't make sense
  17. db_dir="@l_prefix@/var/dbmail/db"
  18. db_name=`grep "^db" @l_prefix@/etc/dbmail/dbmail.conf | sed -e 's;^[^=]*= *;;'`
  19. db_user=`grep "^user" @l_prefix@/etc/dbmail/dbmail.conf | sed -e 's;^[^=]*= *;;'`
  20. db_pass=`grep "^pass" @l_prefix@/etc/dbmail/dbmail.conf | sed -e 's;^[^=]*= *;;'`
  21. # determine RDBMS-specific details
  22. if [ ".$db_type" = .sqlite ]; then
  23. db_sname=""
  24. db_suser="@l_rusr@"
  25. db_spass="@l_rgrp@"
  26. elif [ ".$db_type" = .mysql ]; then
  27. db_sname="mysql"
  28. db_suser=`grep "^user" @l_prefix@/etc/mysql/my.pwd |\
  29. sed -e 's;^user[^=]*= *;;' -e 's; *$;;'`
  30. db_spass=`grep "^password" @l_prefix@/etc/mysql/my.pwd |\
  31. sed -e 's;^password[^=]*= *;;' -e 's; *$;;'`
  32. elif [ ".$db_type" = .pgsql ]; then
  33. db_sname=`grep "^superuser_database" @l_prefix@/var/postgresql/db/pg_superuser.conf |\
  34. sed -e 's;^ *superuser_database="\(.*\)".*;\1;'`
  35. db_suser=`grep "^superuser_username" @l_prefix@/var/postgresql/db/pg_superuser.conf |\
  36. sed -e 's;^ *superuser_username="\(.*\)".*;\1;'`
  37. db_spass=`grep "^superuser_password" @l_prefix@/var/postgresql/db/pg_superuser.conf |\
  38. sed -e 's;^ *superuser_password="\(.*\)".*;\1;'`
  39. fi
  40. # dispatch operation
  41. cmd="$1"
  42. shift
  43. case "$cmd" in
  44. install )
  45. # create the DBMail database
  46. if [ $# -gt 0 ]; then
  47. db_dir="$1"
  48. shift
  49. fi
  50. if [ ".$db_type" = .sqlite ]; then
  51. ( umask 077
  52. @l_prefix@/bin/sqlite3 $db_name <$db_script
  53. chown $db_suser:$db_spass $db_name
  54. chmod 640 $db_name
  55. ) || exit $?
  56. elif [ ".$db_type" = .mysql ]; then
  57. # FIXME: MySQL doesn't allow easy relocation of tablespaces AFAIK --rse
  58. @l_prefix@/bin/mysqladmin --user="$db_suser" --password="$db_spass" create "$db_name"
  59. ( echo "GRANT ALL ON $db_name.* TO $db_user@localhost IDENTIFIED BY '$db_pass';"
  60. echo "FLUSH PRIVILEGES;"
  61. ) | @l_prefix@/bin/mysql --user="$db_suser" --password="$db_spass" "$db_sname"
  62. @l_prefix@/bin/mysql --user="$db_user" --password="$db_pass" "$db_name" <$db_script
  63. elif [ ".$db_type" = .pgsql ]; then
  64. ( echo "CREATE ROLE $db_user LOGIN ENCRYPTED PASSWORD '$db_pass' NOCREATEDB NOCREATEUSER;"
  65. echo "CREATE TABLESPACE $db_name OWNER $db_user LOCATION '$db_dir';"
  66. echo "CREATE DATABASE $db_name OWNER $db_user TABLESPACE $db_name ENCODING 'UTF8';"
  67. ) | PGPASSWORD="$db_spass" @l_prefix@/bin/psql -q -U "$db_suser" -d "$db_sname" -f-
  68. PGPASSWORD="$db_pass" @l_prefix@/bin/psql -q -U "$db_user" -d "$db_name" -f- <$db_script
  69. fi
  70. ;;
  71. uninstall )
  72. # remove the DBMail database
  73. if [ ".$db_type" = .sqlite ]; then
  74. rm -f $db_name >/dev/null 2>&1 || true
  75. elif [ ".$db_type" = .mysql ]; then
  76. ( echo "DROP DATABASE $db_name;"
  77. ) | @l_prefix@/bin/mysql --user="$db_suser" --password="$db_spass" "$db_sname"
  78. elif [ ".$db_type" = .pgsql ]; then
  79. ( echo "DROP DATABASE $db_name;"
  80. echo "DROP TABLESPACE $db_name;"
  81. echo "DROP ROLE $db_user;"
  82. ) | PGPASSWORD="$db_spass" @l_prefix@/bin/psql -q -U "$db_suser" -d "$db_sname" -f-
  83. fi
  84. ;;
  85. esac