auto_agent/backend/app/repositories/chat_repository.py
2521690 ce299cbb18 feat: 增加 Agent 演示入口与 app_metadata 驱动验证链路
- 新增 app_metadata 模型、仓储与服务
- 将默认 edge 验证步骤改为由 app_metadata 驱动生成
- 新增 chat_session / chat_message 会话层模型与 chat service
- 新增 demo chat API,支持会话创建、消息发送、任务确认
- 新增最小 Web Demo 页面,形成聊天式演示入口
- 增强任务报告,补充 audit_summary 与更细粒度 task_metrics
- 增强 edge-agent 执行器:tcp_probe、日志时间范围过滤、进程指标与更灵活健康检查
- 更新 README 与当前进度总结,MVP 进度推进到约 94%
2026-04-09 14:10:13 +08:00

44 lines
1.3 KiB
Python

from __future__ import annotations
from sqlalchemy import select
from sqlalchemy.orm import Session
from app.models.chat_message import ChatMessage
from app.models.chat_session import ChatSession
class ChatSessionRepository:
def __init__(self, db: Session) -> None:
self.db = db
def add(self, item: ChatSession) -> ChatSession:
self.db.add(item)
self.db.commit()
self.db.refresh(item)
return item
def update(self, item: ChatSession) -> ChatSession:
self.db.add(item)
self.db.commit()
self.db.refresh(item)
return item
def get_by_session_id(self, session_id: str) -> ChatSession | None:
statement = select(ChatSession).where(ChatSession.session_id == session_id)
return self.db.execute(statement).scalar_one_or_none()
class ChatMessageRepository:
def __init__(self, db: Session) -> None:
self.db = db
def add(self, item: ChatMessage) -> ChatMessage:
self.db.add(item)
self.db.commit()
self.db.refresh(item)
return item
def list_by_session_id(self, session_id: str) -> list[ChatMessage]:
statement = select(ChatMessage).where(ChatMessage.session_id == session_id).order_by(ChatMessage.created_at.asc())
return list(self.db.execute(statement).scalars())