#!/usr/bin/python3
"""
Adversarial knowledge ablation, where plausible but facually incorect,
adversarially generated knowledge is provided to the language model.

Author(s):
    Anonymized Authors @anonymized-authors

Licensed under the Apache License, Version 2.0. Copyright Anonymized, Inc. 2025.
"""
import json
import os
from typing import Any, Dict

from .base import KnowledgeBase


class AdversarialKnowledgeBase(KnowledgeBase):
    def __init__(self, **kwargs: Dict[str, Any]):
        """
        Args:
            None.
        """
        del kwargs
        super(AdversarialKnowledgeBase, self).__init__(1)

    def retrieve(self, query: str) -> str:
        """
        Retrieves the adversarial knowledge for the task.
        Input:
            query: a string query.
        Returns:
            A string of the retrieved information.
        """
        adversarial_knowledge_dirname = os.path.join(
            os.path.dirname(os.path.dirname(__file__)),
            "adversarial"
        )
        query = f"{query}.txt"
        if query not in os.listdir(adversarial_knowledge_dirname):
            raise NotImplementedError
        with open(os.path.join(adversarial_knowledge_dirname, query)) as f:
            knowledge = f.read()
        return knowledge.strip()

    @classmethod
    def knowledge_description(
        cls, *args: Any, **kwargs: Dict[str, Any]
    ) -> str:
        """
        Returns a description of the knowledge.
        Input:
            None.
        Returns:
            The description of the knowledge base.
        """
        del args, kwargs
        return "Retrieves adversarially generated biomedical knowledge."

    @classmethod
    def query_description(cls) -> str:
        """
        Returns a description of the expected query type.
        Input:
            None.
        Returns:
            The description of the expected query type.
        """
        return "The name of the task to return the knowledge for."

    @property
    def metadata(self) -> Dict[str, Any]:
        """
        Returns metadata for the adversarially generated knowledge.
        Input:
            None.
        Returns:
            Metadata of the adversarially generated knowledge.
        """
        metadata_fn = os.path.join(
            os.path.dirname(os.path.dirname(__file__)), "metadata.json"
        )
        with open(metadata_fn) as f:
            metadata = json.load(f)
        return metadata
