diff options
Diffstat (limited to 'bin/db_pendings/import.sh')
-rwxr-xr-x | bin/db_pendings/import.sh | 114 |
1 files changed, 0 insertions, 114 deletions
diff --git a/bin/db_pendings/import.sh b/bin/db_pendings/import.sh deleted file mode 100755 index 970d762838..0000000000 --- a/bin/db_pendings/import.sh +++ /dev/null @@ -1,114 +0,0 @@ -#!/usr/bin/env bash - -CURRENT_PATH="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" - -source "$CURRENT_PATH/../bash_shared/includes.sh" - -UPDATES_PATH="$AC_PATH_ROOT/data/sql/updates/" - -function import() { - db=$1 - folder="db_"$db - pendingPath="$AC_PATH_ROOT/data/sql/updates/pending_$folder" - updPath="$UPDATES_PATH/$folder" - - latestUpd=`ls -1 $updPath/ | tail -n 1` - - if [ -z $latestUpd ]; then - echo "FIRST UPDATE FILE MISSING!! DID YOU ARCHIVED IT?"; - exit; - fi - - dateToday=`date +%Y_%m_%d` - counter=0 - - dateLast=$latestUpd - tmp=${dateLast#*_*_*_} - oldCnt=${tmp%.sql} - oldDate=${dateLast%_$tmp} - - if [ "$oldDate" = "$dateToday" ]; then - ((counter=$oldCnt+1)) - fi; - - for entry in "$pendingPath"/*.sql - do - if [[ -e $entry ]]; then - oldVer=$oldDate"_"$oldCnt - - cnt=$(printf -v counter "%02d" $counter ; echo $counter) - - newVer=$dateToday"_"$cnt - - startTransaction="START TRANSACTION;"; - updHeader="ALTER TABLE version_db_"$db" CHANGE COLUMN "$oldVer" "$newVer" bit;"; - endTransaction="COMMIT;"; - - newFile="$updPath/"$dateToday"_"$cnt".sql" - - oldFile=$(basename "$entry") - prefix=${oldFile%_*.sql} - suffix=${oldFile#rev_} - rev=${suffix%.sql} - - isRev=0 - if [[ $prefix = "rev" && $rev =~ ^-?[0-9]+$ ]]; then - isRev=1 - fi - - echo "-- DB update $oldVer -> $newVer" > "$newFile"; - - if [[ $isRev -eq 1 ]]; then - echo "DROP PROCEDURE IF EXISTS \`updateDb\`;" >> "$newFile"; - echo "DELIMITER //" >> "$newFile"; - echo "CREATE PROCEDURE updateDb ()" >> "$newFile"; - echo "proc:BEGIN DECLARE OK VARCHAR(100) DEFAULT 'FALSE';" >> "$newFile"; - echo "SELECT COUNT(*) INTO @COLEXISTS" >> "$newFile"; - echo "FROM information_schema.COLUMNS" >> "$newFile"; - echo "WHERE TABLE_SCHEMA = DATABASE() AND TABLE_NAME = 'version_db_"$db"' AND COLUMN_NAME = '"$oldVer"';" >> "$newFile"; - echo "IF @COLEXISTS = 0 THEN LEAVE proc; END IF;" >> "$newFile"; - fi - - echo "$startTransaction" >> "$newFile"; - echo "$updHeader" >> "$newFile"; - - if [[ $isRev -eq 1 ]]; then - echo "SELECT sql_rev INTO OK FROM version_db_"$db" WHERE sql_rev = '$rev'; IF OK <> 'FALSE' THEN LEAVE proc; END IF;" >> "$newFile"; - fi; - - echo "--" >> "$newFile"; - echo "-- START UPDATING QUERIES" >> "$newFile"; - echo "--" >> "$newFile"; - - cat $entry >> "$newFile"; - - echo "--" >> "$newFile"; - echo "-- END UPDATING QUERIES" >> "$newFile"; - echo "--" >> "$newFile"; - - echo "$endTransaction" >> "$newFile"; - - if [[ $isRev -eq 1 ]]; then - echo "END;" >> "$newFile"; - echo "//" >> "$newFile"; - echo "DELIMITER ;" >> "$newFile"; - echo "CALL updateDb();" >> "$newFile"; - echo "DROP PROCEDURE IF EXISTS \`updateDb\`;" >> "$newFile"; - fi; - - rm $entry; - - oldDate=$dateToday - oldCnt=$cnt - - ((counter+=1)) - fi - done - -} - -import "world" -import "characters" -import "auth" - -echo "Done." |