Skip to content
Snippets Groups Projects
Forked from DM / dm-docs
261 commits behind, 782 commits ahead of the upstream repository.
Code owners
Assign users and groups as approvers for specific file changes. Learn more.
dm_destroy_all_databases.sh 1.57 KiB
#!/bin/sh

#
# Script used for destroying all DM databases
#
# Usage:
#
# $0 
#

CURRENT_DIR=`pwd`
MY_DIR=`dirname $0` && cd $MY_DIR && MY_DIR=`pwd`
cd $CURRENT_DIR

if [ -z "${DM_ROOT_DIR}" ]; then
    DM_ROOT_DIR=$MY_DIR/..
fi
if [ -z "${DM_INSTALL_DIR}" ]; then
    DM_INSTALL_DIR=$DM_ROOT_DIR/..
fi

DM_RUN_DIR=${DM_INSTALL_DIR}/var/run
DM_ENV_FILE=${DM_ROOT_DIR}/setup.sh
if [ ! -f ${DM_ENV_FILE} ]; then
    echo "Environment file ${DM_ENV_FILE} does not exist." 
    exit 1
fi
. ${DM_ENV_FILE} > /dev/null 

# DM_SUPPORT_DIR should now be defined.
if [ -z "$DM_SUPPORT_DIR" ]; then
    echo "Invalid environment file ${DM_ENV_FILE}: DM_SUPPORT_DIR is not defined."
    exit 1
fi
PG_DIR=$DM_SUPPORT_DIR/postgresql/$DM_HOST_ARCH
PG_CONTROL_SCRIPT=$DM_ROOT_DIR/etc/init.d/dm-postgresql
PG_DATA_DIR=$PG_DIR/data

# Ask user to verify this action
cd $DM_RUN_DIR
lockFileList=`ls -c1 *.db.lock 2> /dev/null`

if [ -z $lockFileList ]; then
    echo "There are no active databases"
else
    dbNamelist=""
    for lockFile in $lockFileList; do
        dbName=`echo $lockFile | cut -f1 -d'.'`
        dbNameList="$dbNameList $dbName"
    done
    echo "Found active databases: $dbNameList"
    read -p "Proceed [y/N]? " proceedFlag
    if [ "$proceedFlag" != "y" ]; then
        echo "Active databases were not destroyed."
        exit 1
    fi
fi

# Stop db.
$PG_CONTROL_SCRIPT stop

# Remove db data directory
echo "Removing database directory"
rm -rf $PG_DATA_DIR

# Remove lock files.
if [ ! -z "$lockFileList" ]; then
    echo "Removing lock files"
    rm -f $lockFileList
fi

echo "Cleanup done"
echo