from src.providers.llm import LLMOutput, OpenAILLM, AzureLLM
from src.configs.verify import VerifyConfig
from src.configs.provider import BaseLLMConfig
from src.verification.rules_checker import filter_code_result_all
from src.prompts.verifer_prompt import get_model_checker_prompt
from src.models.verify_models import VerifyType
import logging

logger = logging.getLogger(__name__)

class Checker:
    def __init__(self, verify_config: VerifyConfig):
        self.verify_config = verify_config
        llm_config: BaseLLMConfig = verify_config.llm_config
        if hasattr(llm_config, 'api_version'):
            self.llm = AzureLLM(llm_config)
        else:
            self.llm = OpenAILLM(llm_config)
    
    def model_checker(self, op: str, ref_src: str, code: str) -> tuple[bool, str]:
        query = get_model_checker_prompt(
            op=op,
            ref_src=ref_src,
            code=code,
        )
        logger.info(f"model_checker query for {op}:\n {query}")
        llm_output: LLMOutput = self.llm.generate_single(query, extract_first_block=True, language_type="json")
        logger.info(f"model_checker response for {op}:\n {llm_output.response_txt}")
        return (llm_output.response_txt['valid'], llm_output.response_txt['reason'])

    def rule_checker(self, code: str) -> tuple[bool, str]:
        return filter_code_result_all(code)

    def run(self, op: str, ref_src: str, code: str) -> tuple[bool, str]:
        verified_result = (True, "With no verification on this code")
        if VerifyType.RULE.value in self.verify_config.enable_verify_types:
            verified_result =  self.rule_checker(code)
        if verified_result[0] and VerifyType.MODEL.value in self.verify_config.enable_verify_types:
            verified_result = self.model_checker(op, ref_src, code)
        logger.info(f"Verification result for {op}: {verified_result}")
        return verified_result
