#!/usr/bin/env bash
# =====================================================================
# 
# GPT-4 Evaluation Script
#
# Example:
# bash gpt4-evaluation.sh \
#   --prompt harmlessness \
#    --api-key-file  \
#    --output_dir [the output path] \
# =====================================================================

# --- Strict Bash Settings (Error Handling) ---
set -x

# --- Check Environment ---
if [ -z "${BASH_VERSION}" ]; then
	echo "ERROR: Please use bash to run this script." >&2
	exit 1
fi

# --- Directories and Paths ---
SCRIPT_DIR="$(cd "$(dirname "$0")" &>/dev/null && pwd)" # The directory containing this script
ROOT_DIR="$(dirname "${SCRIPT_DIR}")"                    # The project root directory
export PYTHONPATH="${ROOT_DIR}${PYTHONPATH:+:${PYTHONPATH}}"

# =====================================================================
#                      DEFAULT CONFIGURATION
# =====================================================================
# These values are used if no command-line flags are provided.
RED_CORNER_MODEL_NAME_OR_PATH=""
BLUE_CORNER_MODEL_NAME_OR_PATH=""
OUTPUT_DIR="${ROOT_DIR}/output/gpt4-evaluation-default-$(date +%Y%m%d-%H%M%S)"
API_KEY_FILE="" # Default is empty


export PYTHONPATH="${ROOT_DIR}${PYTHONPATH:+:${PYTHONPATH}}" # Keep correct path
# --- Argument Parsing Loop ---
while [[ "$#" -gt 0 ]]; do
	arg="$1"
	shift
	case "${arg}" in
		--red_corner_model_name_or_path)
			RED_CORNER_MODEL_NAME_OR_PATH="$1"
			shift
			;;
		--red_corner_model_name_or_path=*)
			RED_CORNER_MODEL_NAME_OR_PATH="${arg#*=}"
			;;
		--blue_corner_model_name_or_path)
			BLUE_CORNER_MODEL_NAME_OR_PATH="$1"
			shift
			;;
		--blue_corner_model_name_or_path=*)
			BLUE_CORNER_MODEL_NAME_OR_PATH="${arg#*=}"
			;;
		--output_dir)
			OUTPUT_DIR="$1"
			shift
			;;
		--output_dir=*)
			OUTPUT_DIR="${arg#*=}"
			;;
        ### NEW SECTION: Added a flag for the API key file ###
		--api-key-file)
			API_KEY_FILE="$1"
			shift
			;;
		--api-key-file=*)
			API_KEY_FILE="${arg#*=}"
			;;
		*)
			echo "ERROR: Unknown parameter passed: '${arg}'" >&2
			exit 1
			;;
	esac
done

# --- Load API Key from File ---
if [ -z "${API_KEY_FILE}" ]; then
    echo "ERROR: You must specify the path to your API key file using --api-key-file" >&2
    exit 1
elif [ -f "${API_KEY_FILE}" ]; then
    echo "Sourcing API key from ${API_KEY_FILE}"
    # The `source` command executes the file in the current shell, loading the environment variable.
    source "${API_KEY_FILE}"
else
    echo "ERROR: API key file not found at: ${API_KEY_FILE}" >&2
    exit 1
fi



# --- Check the Models
if [ -z "${RED_CORNER_MODEL_NAME_OR_PATH}" ] || [ -z "${BLUE_CORNER_MODEL_NAME_OR_PATH}" ]; then
  echo "ERROR: You must specify BOTH red_corner_model_name_or_path and blue_corner_model_name_or_path." >&2
  exit 1
fi

# --- Create Directories ---
mkdir -p "${OUTPUT_DIR}"
OUTPUT_DIR="$(cd "${OUTPUT_DIR}" &>/dev/null && pwd)" # Robust path
if [[ ! -f "${OUTPUT_DIR}/.gitignore" ]]; then
	echo '*' >"${OUTPUT_DIR}/.gitignore"
fi

# --- Save Script ---
cp -f "$0" "${OUTPUT_DIR}/script.sh" # Save this script for reproducibility

# --- Execute GPT-4 Evaluation ---
echo "====================================================================="
echo "Starting GPT-4 Evaluation"
echo " > Red Corner Model: ${RED_CORNER_MODEL_NAME_OR_PATH}"
echo " > Blue Corner Model: ${BLUE_CORNER_MODEL_NAME_OR_PATH}"
echo " > Output Directory: ${OUTPUT_DIR}"
echo "====================================================================="

exec 1> >(tee "${OUTPUT_DIR}/stdout.log" >&1) 2> >(tee "${OUTPUT_DIR}/stderr.log" >&2)

# We run the `safe_rlhf.evaluate.gpt4` module using `python -m`.
# This is the standard way to execute Python packages.
python -m safe_rlhf.evaluate.gpt4 \
    --red_corner_model_name_or_path "${RED_CORNER_MODEL_NAME_OR_PATH}" \
    --blue_corner_model_name_or_path "${BLUE_CORNER_MODEL_NAME_OR_PATH}" \
    --output_dir "${OUTPUT_DIR}"