from agents.base_agent import BaseAgent_openai
from prompts.scorer_agent_prompts import *
import sys
import os
import pandas as pd
import subprocess
from utils.extractors import *

venv_python = sys.executable


class ScorerAPI(BaseAgent_openai):
    def get_evaluation_code(self):
        """
        Obtain code that implements the decision evaluation metric.
        The code should return a score based on the test submission and user submission,
        also issue a mod update for the best metrics, and perform a check for the correctness of the predict submission

        :return: is_error (bool), scorer_filepath, mode_scoring (big/small)
        """
        self.agent_name = 'scorer'
        with open(self.config['background_data_path'], 'r') as f:
            data_description = f.read()
        sample_submission_head = pd.read_csv(
            os.path.join(
                self.config['save_path'], "test_submit.csv")
            ).head(10)

        self.instructions = SCORER_PROMPT.format(
            data_description=data_description,
            sample_submission_head=sample_submission_head
        )

        result = self.code_generation_from_several_attempts(
            self.config['number_of_attempts_scorer'],
            filename_to_save='evaluation.py'
        )
        if result is None:
            return True, None, None
        code = extract_python_code(result)
        mode_scoring_json = extract_json(result)
        is_higher_better = mode_scoring_json['is_higher_better']
        scorer_filepath = self.save_code_to_file(code, 'evaluation.py')

        return False, scorer_filepath, is_higher_better

    def get_score(self, predict_path: str, test_path: str = ''):
        """
        Run the code to evaluate the solution and get the score/reason why the submission is incorrect.

        :param test_path: path to test submission
        :param predict_path: path to predict submission
        :return: is_error (bool), error_title, score
        """
        if test_path == '':
            test_path = os.path.join(self.config['save_path'], 'test_submit.csv')
        script_path = os.path.join(self.config['path_log'], 'code', 'evaluation.py')
        try:
            result = subprocess.run(
                [venv_python, script_path, "--test_path", test_path, "--predict_path", predict_path],
                capture_output=True,
                text=True
            )

            if result.returncode == 0:
                return True, None, result.stdout
            else:
                return False, result.stderr, -1

        except Exception as e:
            return False, str(e), -1
