mirror of
https://gitee.com/wanwujie/deer-flow
synced 2026-04-17 11:44:44 +08:00
42 lines
1.4 KiB
Python
42 lines
1.4 KiB
Python
|
|
import logging
|
||
|
|
|
||
|
|
from fastapi import APIRouter, HTTPException
|
||
|
|
from pydantic import BaseModel
|
||
|
|
|
||
|
|
from deerflow.config.paths import Paths, get_paths
|
||
|
|
|
||
|
|
logger = logging.getLogger(__name__)
|
||
|
|
router = APIRouter(prefix="/api/threads", tags=["threads"])
|
||
|
|
|
||
|
|
|
||
|
|
class ThreadDeleteResponse(BaseModel):
|
||
|
|
"""Response model for thread cleanup."""
|
||
|
|
|
||
|
|
success: bool
|
||
|
|
message: str
|
||
|
|
|
||
|
|
|
||
|
|
def _delete_thread_data(thread_id: str, paths: Paths | None = None) -> ThreadDeleteResponse:
|
||
|
|
"""Delete local persisted filesystem data for a thread."""
|
||
|
|
path_manager = paths or get_paths()
|
||
|
|
try:
|
||
|
|
path_manager.delete_thread_dir(thread_id)
|
||
|
|
except ValueError as exc:
|
||
|
|
raise HTTPException(status_code=422, detail=str(exc)) from exc
|
||
|
|
except Exception as exc:
|
||
|
|
logger.exception("Failed to delete thread data for %s", thread_id)
|
||
|
|
raise HTTPException(status_code=500, detail="Failed to delete local thread data.") from exc
|
||
|
|
|
||
|
|
logger.info("Deleted local thread data for %s", thread_id)
|
||
|
|
return ThreadDeleteResponse(success=True, message=f"Deleted local thread data for {thread_id}")
|
||
|
|
|
||
|
|
|
||
|
|
@router.delete("/{thread_id}", response_model=ThreadDeleteResponse)
|
||
|
|
async def delete_thread_data(thread_id: str) -> ThreadDeleteResponse:
|
||
|
|
"""Delete local persisted filesystem data for a thread.
|
||
|
|
|
||
|
|
This endpoint only cleans DeerFlow-managed thread directories. LangGraph
|
||
|
|
thread state deletion remains handled by the LangGraph API.
|
||
|
|
"""
|
||
|
|
return _delete_thread_data(thread_id)
|