gnu-social/scripts/delete_status_network.sh

49 lines
1.3 KiB
Bash
Raw Normal View History

2009-06-24 03:40:23 +09:00
#!/bin/bash
2010-01-30 05:33:35 +09:00
# live fast! die young!
set -e
source /etc/statusnet/setup.cfg || (echo "Failed to read /etc/statusnet/setup.cfg"; exit -1)
2009-06-24 03:40:23 +09:00
export nickname=$1
if [ "x" == "x$nickname" ]
then
echo "Usage: delete_status_network.sh <site-nickname>"
exit 1
fi
2009-06-24 03:40:23 +09:00
export database=$nickname$DBBASE
# Pull the status_network record so we know which DB server to drop from...
TARGET_DBHOST=`mysql -h $DBHOST -u $ADMIN --password=$ADMINPASS $SITEDB --batch --skip-column-names -e \
"select dbhost from status_network where nickname='$nickname'"`
2009-06-24 03:40:23 +09:00
if [ "x" == "x$TARGET_DBHOST" ]
then
echo "Aborting: Could not find status_network record for site $nickname"
exit 1
fi
2009-06-24 03:40:23 +09:00
# Drop the database
echo "Dropping $database from $TARGET_DBHOST..."
mysqladmin -h $TARGET_DBHOST -u $ADMIN --password=$ADMINPASS -f drop $database || exit 1
2009-06-24 03:40:23 +09:00
# Remove the status_network entry
echo "Removing status_network entry for $nickname..."
mysql -h $DBHOST -u $ADMIN --password=$ADMINPASS $SITEDB -e \
"delete from status_network where nickname = '$nickname'" || exit 1
2009-06-24 03:40:23 +09:00
# Remove uploaded file areas
2009-06-24 03:40:23 +09:00
for top in $AVATARBASE $FILEBASE $BACKGROUNDBASE; do
if [ "x" == "x$top" ]
then
echo "Skipping deletion due to broken config"
else
echo "Deleting $top/$nickname"
rm -Rf "$top/$nickname"
fi
2009-06-24 03:40:23 +09:00
done
echo "Done."