#!/bin/bash
[ "$1" == "" ] && exec echo "Usage: $0 <action>"

source ~/.gamerc

SCRIPT_NAME=$(basename "$0")
LOCK_FILE="/home/n1admin/www/promotion_upload/.${SCRIPT_NAME}.lock"

exec 200>"${LOCK_FILE}"
flock -n 200 || {
        echo "${SCRIPT_NAME} is running. Exiting."
    exit 1
}

MAIN_COMMAND="Ctrl time1"
LIVE_GAMEDB_NAME="N1DB20_LIVE_20250630"
LIVE_WORLDDB_NAME="N1World2005_LIVE_20250630"
ACTION=$1
PATCH_VERSION=$(ls -hld ~/patch/20* | awk -F" " '{print $(NF)}' | awk -F"/" '{print $(NF)}' | tail -n 1)

DATE=$(date +"%Y%m%d")
LOG_DIR="/home/n1admin/www/promotion_upload/time1_sync_log/${DATE}"
[ -d "${LOG_DIR}" ] || { mkdir -p "${LOG_DIR}"; chmod 777 -R "${LOG_DIR}"; }

NOW=$(date +"%Y%m%dT%H%M%S")
LOG_FILE="${PATCH_VERSION}_${ACTION}_${NOW}.log"
MONITOR_FILE="/tmp/time1_sync_monitor.log"

#if [ "${CHECK_DIR_EXIST}" -eq 0 ]; then
#    check_filename="/tmp/test_patch_check_monitor.log"
#    echo "測試機版本更新失敗,\n出版機沒有不存在這個版本 ${PN},\n麻煩請找研發確認看看!" > $check_filename
#    echo -e "測試機版本更新失敗,\n出版機沒有不存在這個版本 ${PN},\n麻煩請找研發確認看看!" > ${LOG_DIR}/${LOG_FILE}
#    exec $HOME/bin/send_messages_with_pic_failed INFO test_patch_check  "測試機版本更新" 1> /dev/null 2> /dev/null
#else
#    mkdir ~/patch/${PN}
#    cd ~/patch/${PN}
#    lftp http://${REMOTE_PATCH_SERVER}/${REMOTE_PATCH_DIRS}/${PN} -e "mget *;exit"
#    echo y | TestCtrl patch TEST ${PN} noftp | tee -a ${LOG_DIR}/${LOG_FILE}
#fi

case ${ACTION} in
    status)
        CMD="yes | ${MAIN_COMMAND}_status";;
    stop)
        CMD="yes | ${MAIN_COMMAND}_stop;
            echo \"TIME1 Game Server 關閉\" > $MONITOR_FILE;
            ~/bin/send_messages_test
        ";;
    start)
        CMD="yes | ${MAIN_COMMAND}_start;
            echo \"TIME1 Game Server 啟動\" > $MONITOR_FILE;
        ";;
    restart)
        CMD="yes | ${MAIN_COMMAND}_restart;
            echo \"TIME1 Game Server 關閉重新啟動\" > $MONITOR_FILE;
        ";;
    dbbackup)
        CMD="yes | ${MAIN_COMMAND}_dbbackup";;
    sync)
        CMD="yes | ${MAIN_COMMAND}_sync;
            cd $HOME/servers1/; rsync -avz config00.ini TIME1:~/servers1/.;
        ";;
    dbpatch)
        CMD="
            yes | ${MAIN_COMMAND}_dbpatch;
            ssh TIME1 \"perl ~/common-TEST/db/db_game_alter :${LIVE_GAMEDB_NAME}; perl ~/common-TEST/db/db_world_alter :${LIVE_WORLDDB_NAME};\";
        ";;
    itemmall)
        CMD="yes | ${MAIN_COMMAND}_itemmall";;
    sync_translate)
        CMD="yes | ${MAIN_COMMAND}_sync_translate";;
    all)
        CMD="
            yes | ${MAIN_COMMAND}_stop;
            yes | ${MAIN_COMMAND}_dbbackup;
            yes | ${MAIN_COMMAND}_sync;
            cd $HOME/servers1/; rsync -avz config00.ini TIME1:~/servers1/.;
            yes | ${MAIN_COMMAND}_dbpatch;
            yes | ${MAIN_COMMAND}_itemmall;
            ssh TIME1 \"perl ~/common-TEST/db/db_game_alter :${LIVE_GAMEDB_NAME}; perl ~/common-TEST/db/db_world_alter :${LIVE_WORLDDB_NAME};\";
            yes | ${MAIN_COMMAND}_start;
        ";;
    *)
        echo "Unknown command for sync";;
esac

echo ${CMD}
bash -c "${CMD}"

[ -f "${LOCK_FILE}" ] && rm -rf ${LOCK_FILE}
