import os, json
from fastapi import FastAPI
import argparse
import logging

from patient import PatientService, CreateSessionRequest, ExecuteActionsRequest

LOG_DIR = os.getenv('LOG_DIR', 'server_logs')
os.makedirs(LOG_DIR, exist_ok=True)

# Initialize FastAPI
app = FastAPI()

# Setup logging
logging.basicConfig(level=logging.INFO, format="%(asctime)s [%(levelname)s] [Session: %(session)s] %(message)s")

def log_message(session_id, message):
    logging.info(message, extra={"session": session_id})


def read_cli():
    parser = argparse.ArgumentParser()
    parser.add_argument("--dialog_path", type=str, help="Path to dialogs file")
    parser.add_argument("--port", type=int, default=8001, help="Port to run the server on")
    parser.add_argument("--dst_key", type=str, default=None, help="dst_key to use for the patient")
    parser.add_argument("--ddx_key", type=str, default=None, help="ddx_key to use for the patient")
    args = parser.parse_args()
    return args


args = read_cli()
app = FastAPI()
patient_service = PatientService(args.dialog_path, args.dst_key, args.ddx_key)


@app.post("/patient/create_session")
def create_session(request: CreateSessionRequest):
    session_id = patient_service.create_session(request.did, request.mode)
    return {"session_id": session_id}


@app.post("/patient/{session_id}/reset")
def reset_session(session_id: str):
    patient = patient_service.get_patient(session_id)
    patient.reset()
    print(session_id, "Session reset.")
    return {"detail": "Session reset successfully"}


@app.post("/patient/{session_id}/close")
def close_session(session_id: str):
    patient_service.close(session_id)
    print(session_id, "Session closed.")
    return {"detail": "Session closed successfully"}


@app.post("/patient/{session_id}/execute_and_commit")
def execute_and_commit(session_id: str, request: ExecuteActionsRequest):
    patient = patient_service.get_patient(session_id)
    response, status = patient.execute_and_commit(actions=request.actions, doctor_uttr=request.doctor_uttr)
    log_message(session_id, f"Actions executed: {request.actions}")

    logfile = os.path.join(LOG_DIR, f"{session_id}.json")
    logs = patient.get_logs()
    with open(logfile, 'w') as fp:
        json.dump(logs, fp)

    return {"patient_uttr": response, "status": status}


@app.post("/patient/{session_id}/get_dialog")
def get_dialog(session_id: str):
    patient = patient_service.get_patient(session_id)
    dialog = patient.get_dialog()

    return {"dialog": dialog}


@app.post("/patient/{session_id}/get_dialog_state")
def get_dialog_state(session_id: str):
    patient = patient_service.get_patient(session_id)
    dialog_state = patient.get_covered_state()

    return {"dialog_state": dialog_state}


if __name__ == "__main__":
    import uvicorn
    uvicorn.run(app, host="0.0.0.0", port=args.port)
