| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443 | #!/bin/bash## $Id$## SER MySQL Database Administration Tool## Copyright (C) 2006-2008 iptelorg GmbH################################################################### configuration variables#################################################################DEFAULT_DBHOST="localhost"   # Default hostname of the database serverDEFAULT_SQLUSER="root"       # Database username with admin privilegesDEFAULT_DBNAME="ser"         # Default name of SER databaseDEFAULT_ROUSER="serro"       # Default read-only username to SER databaseDEFAULT_ROPASS="47serro11"   # Default password of read-only userDEFAULT_RWUSER="ser"         # Default username of read-write userDEFAULT_RWPASS="heslo"       # Default password of read-write userDEFAULT_MYSQL="mysql"DEFAULT_MYSQLDUMP="mysqldump"# The default directory which contains SQL scripts. If empty then the# directory which contains this shell script will be used. If relative then# the pathname will be made absolute with respect to the location of this# shell script.DEFAULT_SCRIPT_DIR=""DEFAULT_CREATE_SCRIPT="my_create.sql"DEFAULT_DATA_SCRIPT="my_data.sql"DEFAULT_DROP_SCRIPT="my_drop.sql"CMD="$MYSQL -f -h$DBHOST -u$SQLUSER"DEFAULT_DUMP_OPTS="-c -a -e --add-locks --all"usage() {cat <<EOFNAME  $COMMAND - SER MySQL Database Administration ToolSYNOPSIS  $COMMAND [options] create  $COMMAND [options] drop  $COMMAND [options] backup [filename]   $COMMAND [options] restore [filename]  $COMMAND [options] update-dataDESCRIPTION  This tool is a simple shell wrapper over mysql client utility that can be  used to create, drop, or backup SER database stored on a MySQL server.  See  section COMMANDS for brief overview of supported actions.  The SQL definition of tables and initial data within SER database is stored  in a separate files which can be usualy found under /usr/local/share/ser  (depending on installation). You can use those files to create SER database  manually if you cannot or do not want to use this shell wrapper.  This tool requires mysql client utility to create or drop SER database.  Additionally backup and restore commands require mysqldump. Both tools can  be found in mysql-client package.COMMANDS  create    Create a new SER database from scratch. The database must not exist.  This    command creates the database, the default name of the database is    '${DEFAULT_DBNAME}' (the default name can be changed using a command line    parameter, see below). Furthemore the script will load table definitions    from an external SQL file and create users with access to the newly    created database. You can use command line options to change the default    database name, usernames and passwords. Note that you need to change SER    and SERWeb configuration if you change the database name or usernames    because SER and SERWeb are pre-configured to use the default names.  drop    This command can be used to delete SER database and corresponding database    users. WARNING: This command will delete all data in the database and this    action cannot be undone! Make sure that you have backups if you want to    keep the data from the database.  The command also deletes the database    users by default. You can change that behavior using -k command line    options, see below.  backup <filename>    Backup the contents of SER database. If you specify a filename then the    contents of the database will be saved in that file, otherwise the tool    will dumps the contents to the standard output. By default the backup SQL    data contains CREATE TABLE statements that will drop and recreate database    tables being loaded. This ensures that the tables are empty and have    correct structure. You can change this behavior using -t command line    option.  restore <filename>    Load the contents of SER database from a file (if you specify one) or from    the standard input. Make sure that the database exists before you load the    data. Make sure that the database is empty if you have backups without    create table statements (i.e. created with -t command line option) and    that the tables are empty.  update-data    Update initial data in the database. This command deletes vendor-controled    rows from the database and replaces them with new data.OPTIONS  -h, --help      Display this help text.  -n NAME, --name=NAME      Database name of SER database.      (Default value is '$DEFAULT_DBNAME')  -r USERNAME, --ro-username=USERNAME      Username of user with read-only permissions to SER database.      (Default value is '$DEFAULT_ROUSER')  -w USERNAME, --rw-username=USERNAME      Username of user with read-write permissions to SER database.      (Default value is '$DEFAULT_RWUSER')  -p PASSWORD, --ro-password=PASSWORD      Password of user with read-only permissions to SER database.      (Default value is '$DEFAULT_ROPASS')  -P PASSWORD, --rw-password=PASSWORD      Password of user with read-write permissions to SER database.      (Default value is '$DEFAULT_RWPASS')  -t, --tables      Do not write CREATE TABLE statements that recreate tables when      restoring data from backup.        -s HOST, --server=HOST      Hostname or IP address of database server.      (Default value is '$DEFAULT_DBHOST')  -u USERNAME, --username=USERNAME      Username of database administrator.      (Default value is '$DEFAULT_SQLUSER')  -q[PASSWORD], --sql-password[=PASSWORD]      Database administrator password. If you specify this option without      value then the script will assume that no password for database      administrator is needed and will not ask for it.      (No default value)  -d DIRECTORY, --script-dir=DIRECTORY  	  Directory containing the SQL scripts with database schema and initial  	  data definition.  	  (Default value is '$DEFAULT_SCRIPT_DIR')  -k, --keep-users      Do not delete database users when removing the database. This is useful      if you have multiple databases and use the same users to access them.  -v, --verbose      Enable verbose mode. This option can be given multiple times to produce      more and more output.ENVIRONMENT VARIABLES  MYSQL     Path to mysql command (Currently ${MYSQL})  MYSQLDUMP Path to mysqldump command (Currently ${MYSQLDUMP})AUTHOR  Written by Jan Janak <[email protected]>COPYRIGHT  Copyright (C) 2006-2008 iptelorg GmbH  This is free software. You may redistribute copies of it under the termp of  the GNU General Public License. There is NO WARRANTY, to the extent  permitted by law.FILES  ${SCRIPT_DIR}/${CREATE_SCRIPT}  ${SCRIPT_DIR}/${DATA_SCRIPT}  ${SCRIPT_DIR}/${DROP_SCRIPT}    REPORTING BUGS  Report bugs to <[email protected]>             EOF} #usage# Read password from userprompt_pw(){    export PW    if [ ! -z $DONT_ASK ] ; then	unset PW	return 0    elif [ -z "$PW" ] ; then	savetty=`stty -g`	printf "Enter password for MySQL user ${SQLUSER} (Hit enter for no password): "	stty -echo	read PW	stty $savetty	echo    fi    if [ -z "$PW" ]; then	unset PW    else	PW="-p$PW"    fi}# Convert relative path to the script directory to absolute if necessary by# extracting the directory of this script and prefixing the relative path with# it.abs_script_dir(){	my_dir=`dirname $0`;	if [ "${SCRIPT_DIR:0:1}" != "/" ] ; then		SCRIPT_DIR="${my_dir}/${SCRIPT_DIR}"	fi}# Execute an SQL commandsql_query(){	if [ $# -gt 1 ] ; then		if [ -n "$1" ]; then			DB=\"$1\"		else			DB=""		fi		shift		if [ -n "$PW" ]; then			$CMD "$PW" $MYSQL_OPTS $DB -e "$@"		else			$CMD $MYSQL_OPTS $DB -e "$@"		fi	else		if [ -n "$PW" ]; then			$CMD "$PW" $MYSQL_OPTS "$@"		else			$CMD $MYSQL_OPTS "$@"		fi	fi}# Drop SER databasedrop_db(){    # Drop the database if it exists    sql_query "" "DROP DATABASE IF EXISTS ${DBNAME}"    # Revoke permissions to both RW and RO users    sql_query "" "REVOKE ALL PRIVILEGES ON ${DBNAME}.* FROM '${RWUSER}'@'%'"    sql_query "" "REVOKE ALL PRIVILEGES ON ${DBNAME}.* FROM '${RWUSER}'@'localhost'"    sql_query "" "REVOKE ALL PRIVILEGES ON ${DBNAME}.* FROM '${ROUSER}'@'%'"    sql_query "" "REVOKE ALL PRIVILEGES ON ${DBNAME}.* FROM '${ROUSER}'@'localhost'"    if [ ! -z "$KEEP_USERS" ] ; then	    # Works only with MySQL 4.1.1 and higher		#sql_query "" "DROP USER '${RWUSER}'@'%'"		#sql_query "" "DROP USER '${RWUSER}'@'localhost'"		#sql_query "" "DROP USER '${ROUSER}'@'%'"		#sql_query "" "DROP USER '${ROUSER}'@'localhost'"				# Works with older MySQL versions		sql_query "" "DELETE FROM mysql.user WHERE User='${RWUSER}' and Host='%'"		sql_query "" "DELETE FROM mysql.user WHERE User='${RWUSER}' and Host='localhost'"		sql_query "" "DELETE FROM mysql.user WHERE User='${ROUSER}' and Host='%'"		sql_query "" "DELETE FROM mysql.user WHERE User='${ROUSER}' and Host='localhost'"    fi    sql_query "" "FLUSH PRIVILEGES"} # drop_db# Create SER databasecreate_db (){    # Create the database    sql_query "" "CREATE DATABASE IF NOT EXISTS ${DBNAME}"    # Add read/write access to RWUSER    sql_query "" "GRANT ALL ON ${DBNAME}.* TO '${RWUSER}'@'%' IDENTIFIED BY '${RWPASS}'"    sql_query "" "GRANT ALL ON ${DBNAME}.* TO '${RWUSER}'@'localhost' IDENTIFIED BY '${RWPASS}'"        # Add read-only access to ROUSER    sql_query "" "GRANT ALL ON ${DBNAME}.* TO '${ROUSER}'@'%' IDENTIFIED BY '${ROPASS}'"    sql_query "" "GRANT ALL ON ${DBNAME}.* TO '${ROUSER}'@'localhost' IDENTIFIED BY '${ROPASS}'"        # Activate changes    sql_query "" "FLUSH PRIVILEGES"    # Load table definitions    sql_query $DBNAME < ${SCRIPT_DIR}/${CREATE_SCRIPT}    # Load initial data    sql_query $DBNAME < ${SCRIPT_DIR}/${DATA_SCRIPT}} # create_db# Update initial dataupdate_db_data (){    sql_query $DBNAME < ${SCRIPT_DIR}/${DATA_SCRIPT}} # update_db_data# Main programCOMMAND=`basename $0`if [ -z "$DBNAME" ] ; then DBNAME="$DEFAULT_DBNAME"; fi;if [ -z "$ROUSER" ] ; then ROUSER="$DEFAULT_ROUSER"; fi;if [ -z "$RWUSER" ] ; then RWUSER="$DEFAULT_RWUSER"; fi;if [ -z "$ROPASS" ] ; then ROPASS="$DEFAULT_ROPASS"; fi;if [ -z "$RWPASS" ] ; then RWPASS="$DEFAULT_RWPASS"; fi;if [ -z "$DBHOST" ] ; then DBHOST="$DEFAULT_DBHOST"; fi;if [ -z "$SQLUSER" ] ; then SQLUSER="$DEFAULT_SQLUSER"; fi;if [ -z "$MYSQL" ] ; then MYSQL="$DEFAULT_MYSQL"; fiif [ -z "$MYSQLDUMP" ] ; then MYSQLDUMP="$DEFAULT_MYSQLDUMP"; fiif [ -z "$DUMP_OPTS" ] ; then DUMP_OPTS="$DEFAULT_DUMP_OPTS"; fi if [ -z "$SCRIPT_DIR" ] ; then SCRIPT_DIR="$DEFAULT_SCRIPT_DIR"; fiif [ -z "$CREATE_SCRIPT" ] ; then CREATE_SCRIPT="$DEFAULT_CREATE_SCRIPT"; fiif [ -z "$DATA_SCRIPT" ] ; then DATA_SCRIPT="$DEFAULT_DATA_SCRIPT"; fiif [ -z "$DROP_SCRIPT" ] ; then DROP_SCRIPT="$DEFAULT_DROP_SCRIPT"; fi# Make the path to the script directory absoluteabs_script_dirTEMP=`getopt -o hn:r:w:p:P:ts:u:vkq::d: --long help,name:,ro-username:,rw-username:,\ro-password:,rw-password:,tables,server:,username:,verbose,keep-users],\sql-password::,script-dir: -n $COMMAND -- "$@"`if [ $? != 0 ] ; then exit 1; fieval set -- "$TEMP"while true ; do    case "$1" in	-h|--help)         usage; exit 0 ;;	-n|--name)         DBNAME=$2; shift 2 ;;	-r|--ro-username)  ROUSER=$2; shift 2 ;;	-w|--rw-username)  RWUSER=$2; shift 2 ;;	-p|--ro-password)  ROPASS=$2; shift 2 ;;	-P|--rw-password)  RWPASS=$2; shift 2 ;;	-t|--tables)       DUMP_OPTS="$DUMP_OPTS -t "; shift ;;	-s|--server)       DBHOST=$2; shift 2 ;;	-u|--username)     SQLUSER=$2; shift 2 ;;    -v|--verbose)      MYSQL_OPTS="$MYSQL_OPTS -v "; shift ;;	-k|--keep-users)   KEEP_USERS=1; shift ;;    -d|--script-dir)        SCRIPT_DIR=$2;  	    # The script directory changed, make it absolute again  	    abs_script_dir  	    shift 2  	    ;;     -q|--sql-password)	    case "$2" in		"") DONT_ASK=1; shift 2 ;;		*)  PW=$2; shift 2 ;;	    esac 	    ;;	--)               shift; break ;;	*)                echo "Internal error"; exit 1 ;;    esacdoneif [ $# -eq 0 ]; then    usage    exit 1fi# Make sure we can execute mysql commandTEMP=`which $MYSQL`if [ $? != 0 ] ; then    echo "Could not find mysql client utility"    echo "Set MYSQL environment variable properly (see -h for more info)"    exit 1fi# Make sure we can execute mysqldump commandTEMP=`which $MYSQLDUMP`if [ $? != 0 ] ; then    echo "Could not find mysqldump utility"    echo "Set MYSQLDUMP environment variable properly (see -h for more info)"    exit 1fiCMD="$MYSQL -h$DBHOST -u$SQLUSER"DUMP_CMD="${MYSQLDUMP} -h$DBHOST -u$SQLUSER $DUMP_OPTS"case $1 in    create) # Create SER database and users	prompt_pw	create_db	exit $?	;;        drop) # Drop SER database and users	prompt_pw	drop_db	exit $?	;;    update-data) # Update initial data	prompt_pw	update_db_data	exit $?	;;        backup) # backup SER database	shift	if [ $# -eq 1 ] ; then	    prompt_pw	    $DUMP_CMD "$PW" $MYSQL_OPTS ${DBNAME} > $1	elif [ $# -eq 0 ] ; then	    prompt_pw	    $DUMP_CMD "$PW" $MYSQL_OPTS ${DBNAME}	else	    usage	    exit 1	fi	exit $?	;;    restore) # restore SER database	shift	if [ $# -eq 1 ]; then	    prompt_pw	    sql_query $DBNAME < $1	elif [ $# -eq 0 ] ; then	    prompt_pw	    cat | sql_query $DBNAME	else	    usage	    exit 1	fi	exit $?	;;            *)	echo "Unknown command '$1'"	usage	exit 1;	;;esac
 |