# check for root
user=`/bin/id | /usr/bin/grep root | /usr/bin/wc -l`
if [ $user -eq 0 ]; then
        echo "You must be root to execute this script."
        exit 1
fi


# setup 
ESM_BASE=`/usr/bin/pkgparam SUNWstm ESM_BASE`
if [ $? -ne 0 ]; then
    echo "Could not determine ESM location!"
    exit 1
fi

SM_BASE=/usr/share/webconsole
US_BASE=/usr/sbin
SM_ETC=/etc/opt/webconsole
COMPONENT_DIR=$ESM_BASE/component/tr_mgmt/bin

# helper function to restart database (for making db changes)
start_db () {
    /usr/bin/su - $SSTR_DBOWNER -c ". $SSTR_DBBIN/postgres.env; $SSTR_DBSTART"
    this_try=1
    until /usr/bin/su $SSTR_DBOWNER  -c ". $SSTR_DBBIN/postgres.env; $SSTR_PSQL -l" > /dev/null 2>&1
    do
        if [ $this_try -ge 12 ]; then
            echo "Database still not up - giving up"
            exit 1
        fi
        echo "Wait and try connecting to database again..."
        this_try=`/usr/bin/expr $this_try + 1`
        sleep 10
    done
}


# UI changes
# Copy the esm.war file to lockhart webconsole directory
/bin/cp $ESM_BASE/sssm/lib/esm.war $SM_BASE/esm

# should be java install for lockhart, so use its jar tool (something
# very wrong if not there)
JAVA_HOME=`/usr/bin/grep java.home $SM_ETC/webconsole | /bin/sed -e 's/java.home=//'`
JAR=$JAVA_HOME/bin/jar
if [ ! -x $JAR ] ; then
    echo "Could not find jar tool!"
    exit 1
fi

# Expand the esm.war file in $SM_BASE/esm
cd $SM_BASE/esm
$JAR -xf esm.war > /dev/null

# copy component files over there too (see tr_mgmt/bin/postinstall)
/bin/cp $ESM_BASE/sssm/util/cre/components/esm-jade.car $SM_BASE/esm/WEB-INF/lib/esm-jade.jar
/bin/cp $ESM_BASE/sssm/util/cre/components/idresolver.car $SM_BASE/esm/WEB-INF/lib/idresolver.jar
/bin/cp $ESM_BASE/sssm/util/cre/components/services-api.jar $SM_BASE/esm/WEB-INF/lib
/bin/cp $ESM_BASE/sssm/util/cre/components/serack.jar $SM_BASE/esm/WEB-INF/lib
/bin/cp $ESM_BASE/sssm/util/cre/components/t3.jar $SM_BASE/esm/WEB-INF/lib
/bin/cp $ESM_BASE/sssm/lib/esm-topology.jar $SM_BASE/esm/WEB-INF/lib
/bin/cp $ESM_BASE/sssm/util/cre/components/switch.jar $SM_BASE/esm/WEB-INF/lib
/bin/cp $ESM_BASE/sssm/util/cre/components/hds.jar $SM_BASE/esm/WEB-INF/lib
/bin/cp $ESM_BASE/sssm/util/cre/components/oob_util.jar $SM_BASE/esm/WEB-INF/lib
/bin/cp $ESM_BASE/sssm/util/cre/components/esm-common.jar $SM_BASE/esm/WEB-INF/lib
/bin/cp $ESM_BASE/sssm/util/cre/components/asset.jar $SM_BASE/esm/WEB-INF/lib

# Change file permissions
cd $SM_BASE/esm
/bin/chmod -R 755 .

# make port change for 4925674 if not there
/usr/bin/grep 'port=\"8443\"' $SM_ETC/server.xml > /dev/null 2>&1
if [ $? -ne 0 ]; then
    /usr/bin/mv -f $SM_ETC/server.xml $SM_ETC/.server.xml.bak
    /usr/bin/awk -f $COMPONENT_DIR/svrxmlupd.awk $SM_ETC/.server.xml.bak > $SM_ETC/server.xml
fi

# for 4935652, fix storade.conf if it already got changed
CONF_FILE=/var/opt/SUNWstm/sssm/config/storade.conf
if [ -f $CONF_FILE ]; then
    /bin/cp $CONF_FILE $CONF_FILE.bak
    CHANGEFROM="ESM-standard location: cannot be edited"
    CHANGETO="EsmStandardLocation"
    /usr/bin/grep "$CHANGEFROM" $CONF_FILE > /dev/null 2>&1
    if [ $? -eq 0 ]; then
        /bin/sed -e "s/$CHANGEFROM/$CHANGETO/g" $CONF_FILE > $CONF_FILE.tmp
        /bin/mv $CONF_FILE.tmp $CONF_FILE
    fi

    CHANGEFROM="SANbox Manager"
    CHANGETO="sanboxmanager"
    /usr/bin/grep "$CHANGEFROM" $CONF_FILE > /dev/null 2>&1
    if [ $? -eq 0 ]; then
	/bin/sed -e "s/ASSIGNED_TO.\*=$CHANGEFROM/ASSIGNED_TO.\*=$CHANGETO/" \
		 -e "s/SAP.$CHANGEFROM=/SAP.$CHANGETO=/" \
		 -e "s/SapName=$CHANGEFROM/SapName=$CHANGETO/" \
		 $CONF_FILE > $CONF_FILE.tmp
	/bin/mv $CONF_FILE.tmp $CONF_FILE
    fi

    CHANGEFROM="McData EFC Manager"
    CHANGETO="efcm"
    /usr/bin/grep "$CHANGEFROM" $CONF_FILE > /dev/null 2>&1
    if [ $? -eq 0 ]; then
	/bin/sed -e "s/ASSIGNED_TO.\*=$CHANGEFROM/ASSIGNED_TO.\*=$CHANGETO/" \
		 -e "s/SAP.$CHANGEFROM=/SAP.$CHANGETO=/" \
		 -e "s/SapName=$CHANGEFROM/SapName=$CHANGETO/" \
		 $CONF_FILE > $CONF_FILE.tmp
	/bin/mv $CONF_FILE.tmp $CONF_FILE
    fi

    CHANGEFROM="SANSurfer"
    CHANGETO="sansurfer"
    /usr/bin/grep "$CHANGEFROM" $CONF_FILE > /dev/null 2>&1
    if [ $? -eq 0 ]; then
	/bin/sed -e "s/ASSIGNED_TO.\*=$CHANGEFROM/ASSIGNED_TO.\*=$CHANGETO/" \
		 -e "s/SAP.$CHANGEFROM=/SAP.$CHANGETO=/" \
		 -e "s/SapName=$CHANGEFROM/SapName=$CHANGETO/" \
		 $CONF_FILE > $CONF_FILE.tmp
	/bin/mv $CONF_FILE.tmp $CONF_FILE
    fi
fi

# make database changes
SSTR_HOME=$ESM_BASE/sssm
SSTR_DBHOME=$SSTR_HOME/util/pgsql
SSTR_DBBIN=$SSTR_DBHOME/nsm1/bin
SSTR_DBSTART=$SSTR_DBBIN/dbstart.sh
SSTR_DBOWNER=sstr001
SSTR_PSQL=$SSTR_DBHOME/bin/psql
start_db

/usr/bin/su - $SSTR_DBOWNER -c ". $SSTR_DBBIN/postgres.env; $SSTR_PSQL -f $SSTR_DBHOME/nsm1/ddl/patchadd-01.sql" > /dev/null
/usr/bin/su - $SSTR_DBOWNER -c ". $SSTR_DBBIN/postgres.env; $SSTR_PSQL -f $SSTR_DBHOME/nsm1/ddl/LocalizePropsPopulate.ddl" > /dev/null


# re-register esm app 
SMREG=$US_BASE/smreg
if [ -f "$SMREG" ]; then
    $SMREG add -a /usr/share/webconsole/esm
else
    echo "Unable to register ESM with the console"
    exit 1
fi


# restart ESM and smicc if not running as part of esmpatch
if [ "$ESM_CONTEXT" != "patch" ]; then
    SMSERVER=$US_BASE/smcwebserver
    if [ -f "$SMSERVER" ]; then
        $SMSERVER start 
    else
        echo "Unable to start $SMSERVER"
        exit 1
    fi

    $ESM_BASE/bin/esmcontrol -m start 
fi
