
import json
import os
import re
import base64
import json
import mimetypes
import os
import requests
import re
from tqdm import tqdm
EVAL_MODEL = 'gemini-2.5-pro'
GITHUB_BASE_URL = ''

EVAL_PROMPT_FOR_OVERALL_EVENTS = (
    "These are several events that may happened in the video."
    "Please sort them in the order in which they occurred. "
    "If an event does not occur, the letter corresponding to the event is ignored."
    "Only output the corresponding letters in order, use commas to separate, and wrap your response with <output></output>. Such as <output>B,D</output> or <output>A,B,C</output>"
    "{}"
)
EVAL_PROMPT_FOR_SINGLE_EVENT_EXISTING = (
    "This is a Generated Video. Does the following event existing in this video?"
    "\n{}\n"
    "Answer with Yes or No."
)
EVAL_PROMPT_FOR_STATISTIC_QUESTION = (
    "In this video."
    "\n{}\n"
    "Answer with Yes or No."
)

def filter_and_join_letters(input_string: str) -> str:
  
  filtered_chars = [char for char in input_string if 'A' <= char <= 'Z']
  

  return "".join(filtered_chars)


def extract_first_yes_or_no(text: str):

  match = re.search(r'yes|no', text, re.IGNORECASE)

  if match:

    return match.group(0).lower()
  else:

    return 'wrong'

if __name__ == '__main__':

    eval_json_path = ''
    prompt_version = ''
    model_name = ''
    val_version = ''
    video_root = ''

    eval_content = json.load(open(eval_json_path, "r"))
    output_root = ''
    output_dir = os.path.join(output_root, prompt_version, model_name)
    if not os.path.exists(output_dir):
        os.mkdir(output_dir)


    output_path = os.path.join(output_dir, '')
    if os.path.exists(output_path):
        
        res_dict = json.load(open(output_path, "r"))
    else:
        res_dict = {}

    eval_keys = list(eval_content.keys())
    
    eval_number_mapping = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H']
    for eval_key in tqdm(eval_keys):
        if eval_key in res_dict:
            print('skip:', eval_key)
            continue
        try:
            video_path = GITHUB_BASE_URL.format(val_version,model_name, eval_key)
            video_path_check = os.path.join(video_root, prompt_version, model_name, eval_key+'.mp4')
            if not os.path.exists(video_path_check):
                continue


            if 't2v_eval_event_info' not in eval_content[eval_key]:
                continue
            verification_plan = eval_content[eval_key]['t2v_eval_event_info']['verification_plan']
            idx = 0
            overall_check = ''
            for v_plan in verification_plan:
                overall_check += '\n' + eval_number_mapping[idx] + ': ' + v_plan['event_description'] 
                idx += 1
            wrong_output_flag = True
            idx = 0
            while wrong_output_flag:
                idx += 1
                if idx==4:
                    break
                overall_prompt = EVAL_PROMPT_FOR_OVERALL_EVENTS.format(overall_check)
                print('+'*10)
                print('Overall Prompt:', overall_prompt)
                print('-'*10)
                output_response = request_api_openai_video(
                    prompt=overall_prompt,
                    model_name=EVAL_MODEL,
                    video_path=video_path
                )
                print('res:', output_response, 'res type:', type(output_response))
                if '<output>' not in output_response or '</output>' not in output_response:
                    continue
                match = re.search(r'<output>(.*?)</output>', output_response, re.DOTALL)


                geted_output = match.group(1)

                res = geted_output


                eval_content[eval_key]['t2v_eval_event_info']['overall_event_res'] = res
                print('filter res:', filter_and_join_letters(res))
                eval_content[eval_key]['t2v_eval_event_info']['overall_event_processed_res'] = filter_and_join_letters(res)
                wrong_output_flag = False


            verification_checks = eval_content[eval_key]['verification_checks']
            for v_check in verification_checks:
                if 'check' in v_check:
                    if v_check['check'] == False:
                        continue
                wrong_output_flag = True
                idx = 0
                while wrong_output_flag:
                    single_verification_check = EVAL_PROMPT_FOR_STATISTIC_QUESTION.format(v_check['question'])
                    print('+'*10)
                    print('Single Verification Check:', single_verification_check)
                    print('-'*10)
                    
                    res = request_api_openai_video(
                        prompt=single_verification_check,
                        model_name=EVAL_MODEL,
                        video_path=video_path
                    )

                    print('res:', res, 'res type:', type(res))
                    v_check['res'] = extract_first_yes_or_no(res)
                    idx += 1
                    if v_check['res'] != 'wrong' or idx==3:
                        wrong_output_flag=False
                

            res_dict[eval_key] = eval_content[eval_key]
            if len(list(res_dict.keys())) % 3 == 0:
                json.dump(res_dict, open(output_path, "w"))
        except Exception as e:
            print('Error:', e)

    json.dump(res_dict, open(output_path, "w"))
    pass