import os

from src.data_utils import load_standard_data
from evaluation.tasks.generation.base import AdversarialTaskBase


class WildJailbreakValidation(AdversarialTaskBase):
    def load(self) -> list[dict]:
        current_dir = os.path.abspath(os.path.dirname(__file__))
        task_file = os.path.join(current_dir, f"harmful.jsonl")
        data = load_standard_data(task_file)
        for item in data:
            item['instruction'] = item['adversarial']
        return data


class WildJailbreakValidationBenign(AdversarialTaskBase):
    def load(self) -> list[dict]:
        current_dir = os.path.abspath(os.path.dirname(__file__))
        task_file = os.path.join(current_dir, f"benign.jsonl")
        data = load_standard_data(task_file)
        for item in data:
            item['instruction'] = item['adversarial']
            # Delete 'vanilla' field, so we use the 'instruction' field for classifier judge input
            del item['vanilla']
        return data
