#!/bin/sh # $Id: ImportAdempiere.sh,v 1.10 2005/12/20 07:12:17 jjanke Exp $ echo idempiere Database Import $Revision: 1.10 $ echo Importing idempiere DB from $IDEMPIERE_HOME/data/seed/Adempiere$5.dmp if [ $# -le 2 ] then echo "Usage: $0 " echo "Example: $0 postgres idempiere idempiere postgresPwd" exit 1 fi if [ "$IDEMPIERE_HOME" = "" -o "$ADEMPIERE_DB_NAME" = "" -o "$ADEMPIERE_DB_SERVER" = "" -o "$ADEMPIERE_DB_PORT" = "" ] then echo "Please make sure that the environment variables are set correctly:" echo " IDEMPIERE_HOME e.g. /idempiere" echo " ADEMPIERE_DB_NAME e.g. idempiere" echo " ADEMPIERE_DB_SERVER e.g. dbserver.idempiere.org" echo " ADEMPIERE_DB_PORT e.g. 5432" exit 1 fi ISAMAZONRDS=N if echo "$ADEMPIERE_DB_SERVER" | grep 'rds.amazonaws.com$' > /dev/null then ISAMAZONRDS=Y fi PGPASSWORD=$4 export PGPASSWORD if [ "x$4" = "x^TryLocalConnection^" ] then LOCALPG=true # Allow to run this command with user postgres (just useful running configure as root) else LOCALPG=false fi echo ------------------------------------- echo Recreate user and database echo ------------------------------------- if [ $ISAMAZONRDS = Y ] then # modified for amazon RDS - doesn't allow SUPERUSER ROOT_ROLE="CREATEDB IN ROLE rds_superuser, adempiere" else ROOT_ROLE="SUPERUSER" fi ADEMPIERE_CREATE_ROLE_SQL="CREATE ROLE $2 $ROOT_ROLE LOGIN PASSWORD '$3'" if [ $LOCALPG = "true" ] then # Assuming that adempiere role already exists (it was created out there) PGPASSWORD=$3 export PGPASSWORD dropdb -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -U $2 $ADEMPIERE_DB_NAME else if [ "x$2" != xadempiere ] then psql -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -U postgres -c "CREATE ROLE adempiere" fi if [ $ISAMAZONRDS = Y ] then PGPASSWORD=$3 dropdb -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -U $2 $ADEMPIERE_DB_NAME PGPASSWORD=$4 else dropdb -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -U postgres $ADEMPIERE_DB_NAME fi dropuser -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -U postgres $2 psql -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -U postgres -c "$ADEMPIERE_CREATE_ROLE_SQL" fi ADEMPIERE_CREATE_ROLE_SQL= PGPASSWORD=$3 export PGPASSWORD createdb -T template0 -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -E UNICODE -O $2 -U $2 $ADEMPIERE_DB_NAME echo ------------------------------------- echo Import Adempiere$5.dmp echo ------------------------------------- ADEMPIERE_ALTER_ROLE_SQL="ALTER ROLE $2 SET search_path TO adempiere, pg_catalog" psql -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -d $ADEMPIERE_DB_NAME -U $2 -c "$ADEMPIERE_ALTER_ROLE_SQL" psql -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -d $ADEMPIERE_DB_NAME -U $2 -f $IDEMPIERE_HOME/data/seed/Adempiere$5.dmp ADEMPIERE_ALTER_ROLE_SQL= PGPASSWORD= export PGPASSWORD