import argparse
import json
import logging
import os
from dataclasses import asdict

from src.data_conversion import (
    load_prediction_file,
    template_to_api_call,
    api_call_status_to_api_str,
)
from src.utility import (
    API_INVALID_RESPONSE,
    ModelResponse,
)

logger = logging.getLogger(__name__)


def parse_args():
    parser = argparse.ArgumentParser()
    parser.add_argument(
        "--input_file", required=True, type=str, help="Input intermediate result file"
    )
    parser.add_argument(
        "--output_file", required=True, type=str, help="Parsed result file"
    )

    parsed_args = parser.parse_args()
    return parsed_args


def main(args):
    """Parse the template based result and convert it to APICall string."""
    print(f"Running {os.path.basename(__file__)} with args: {args}")
    predictions = load_prediction_file(args.input_file, intermediate_result=True)
    results = []
    for key, value in predictions.items():
        id = value.id
        resps = value.response
        data_set = value.data_set
        if resps is None:
            logger.info(f"Empty response for:{id}")
            continue
        api_status = template_to_api_call(resps, data_set)
        if api_status.api_call_status == API_INVALID_RESPONSE:
            continue
        line = api_call_status_to_api_str(data_set, api_status)
        results.append(
            ModelResponse(
                id=id,
                data_set=data_set,
                response=line,
            )
        )
    logger.info(f"total:{len(predictions.keys())}, parsed:{len(results)}")
    with open(args.output_file, "w") as fout:
        for result in results:
            fout.write(f"{json.dumps(asdict(result), ensure_ascii=False)}\n")


if __name__ == "__main__":
    logging.basicConfig(
        level=logging.INFO,
        format="[%(asctime)s][%(levelname)s][%(name)s] %(message)s",
        datefmt="%Y%m%d %H:%M:%S",
    )
    args = parse_args()
    main(args)
