import os
import sys
import yaml
import argparse
import logging
import pandas as pd
from datetime import datetime

project_root = os.path.abspath(os.path.join(os.path.dirname(__file__), ".."))
if project_root not in sys.path:
    sys.path.insert(0, project_root)

from generators.vanilla_endowment_generator import EndowmentGenerator
from modules.token_tracker import MultiAxisTokenTracker
from scripts.run_plugin_pipeline import setup_logger, run_plugin_pipeline


def load_config(path: str) -> dict:
    with open(path, "r") as f:
        return yaml.safe_load(f)

def run_vanilla_pipeline(config_path: str):
    # === Load config
    cfg = load_config(config_path)
    meta = cfg.get("metadata", {"name": "vanilla_pipeline"})

    # === Output dir
    timestamp = datetime.now().strftime("%Y%m%d_%H%M%S")
    output_dir = os.path.join("outputs", f"{meta['name']}_{timestamp}")
    os.makedirs(output_dir, exist_ok=True)


    # === Logger (reuse plugin's setup for identical format)
    # --- Logging setup ---
    vanilla_log = os.path.join(output_dir, "vanilla_generation.log")
    logger = logging.getLogger("vanilla_pipeline_logger")
    logger.setLevel(logging.INFO)
    logger.handlers = []  # Clear existing handlers

    formatter = logging.Formatter("%(asctime)s [%(levelname)s] %(message)s")

    # File handler
    file_handler = logging.FileHandler(vanilla_log)
    file_handler.setFormatter(formatter)
    logger.addHandler(file_handler)

    # Console handler
    console_handler = logging.StreamHandler(sys.stdout)
    console_handler.setFormatter(formatter)
    logger.addHandler(console_handler)

    logger.info(f"[Pipeline] Output directory: {output_dir}")


    # === Shared tracker
    tracker = MultiAxisTokenTracker()

    # === Generate endowments
    gen_cfg = cfg.get("endowment_generator", {})
    generator = EndowmentGenerator(
        backend_type=gen_cfg.get("backend", "openai"),
        model_name=gen_cfg.get("model_name", "gpt-4o-mini"),
        temperature=gen_cfg.get("temperature", 0.9),
        max_tokens=gen_cfg.get("max_tokens", 1024),
        batch_size=gen_cfg.get("batch_size", 10),
        delay=gen_cfg.get("delay", 0.5),
        retry_failed=gen_cfg.get("retry_failed", True),
        clear_after_run=False,
        token_tracker=tracker,
        verbose=True,
    )

    n_endowments = gen_cfg.get("n_endowments", 20)
    topic = gen_cfg.get("topic_description")
    logger.info(f"[Vanilla] Generating {n_endowments} endowments...")
    endowments = generator.generate(n_endowments, topic_description=topic)

    # Save JSONL
    endowments_jsonl = os.path.join(output_dir, "endowments.jsonl")
    generator.save(endowments_jsonl)
    logger.info(f"[Vanilla] Saved {len(endowments)} endowments to {endowments_jsonl}")

    # Save CSV (for ActiveEndowments)

    df = pd.DataFrame(endowments)
    endowments_csv = os.path.join(output_dir, "endowments.csv")
    df.to_csv(endowments_csv, index=False)
    logger.info(f"[Vanilla] Saved endowments CSV to {endowments_csv}")

    # === Patch config with generated endowments.csv
    cfg["paths"]["endowments_csv"] = endowments_csv

    patched_config = os.path.join(output_dir, "vanilla_config.yaml")
    with open(patched_config, "w") as f:
        yaml.safe_dump(cfg, f)
    logger.info(f"[Vanilla] Patched config saved to {patched_config}")

    # === Hand off to plugin pipeline
    logger.info("[Vanilla] Handing off to plugin pipeline...")
    run_plugin_pipeline(patched_config, token_tracker=tracker, output_dir=output_dir)

    # === Save combined token usage
    tracker_csv = os.path.join(output_dir, "token_usage_combined.csv")
    tracker.save(tracker_csv)
    with open(os.path.join(output_dir, "token_report_combined.md"), "w") as f:
        f.write(tracker.report())
    logger.info(f"[Vanilla] Combined token usage saved to {tracker_csv}")

if __name__ == "__main__":
    parser = argparse.ArgumentParser(description="Vanilla Endowment → Plugin Pipeline")
    parser.add_argument("--config", type=str, required=True, help="Path to YAML config file")
    args = parser.parse_args()
    run_vanilla_pipeline(args.config)