31 lines
1.5 KiB
Python
31 lines
1.5 KiB
Python
|
|
from typing import Optional
|
|||
|
|
from sqlmodel import Field, SQLModel
|
|||
|
|
from datetime import datetime
|
|||
|
|
|
|||
|
|
class BotInstance(SQLModel, table=True):
|
|||
|
|
id: str = Field(primary_key=True)
|
|||
|
|
name: str
|
|||
|
|
workspace_dir: str = Field(unique=True)
|
|||
|
|
docker_status: str = Field(default="STOPPED", index=True)
|
|||
|
|
current_state: Optional[str] = Field(default="IDLE")
|
|||
|
|
last_action: Optional[str] = Field(default=None)
|
|||
|
|
image_tag: str = Field(default="nanobot-base:v0.1.4") # 记录该机器人使用的镜像版本
|
|||
|
|
created_at: datetime = Field(default_factory=datetime.utcnow)
|
|||
|
|
updated_at: datetime = Field(default_factory=datetime.utcnow)
|
|||
|
|
|
|||
|
|
class BotMessage(SQLModel, table=True):
|
|||
|
|
id: Optional[int] = Field(default=None, primary_key=True)
|
|||
|
|
bot_id: str = Field(foreign_key="botinstance.id", index=True)
|
|||
|
|
role: str = Field(index=True) # user | assistant | system
|
|||
|
|
text: str
|
|||
|
|
media_json: Optional[str] = Field(default=None) # JSON string list of workspace-relative file paths
|
|||
|
|
created_at: datetime = Field(default_factory=datetime.utcnow, index=True)
|
|||
|
|
|
|||
|
|
class NanobotImage(SQLModel, table=True):
|
|||
|
|
tag: str = Field(primary_key=True) # e.g., nanobot-base:v0.1.4
|
|||
|
|
image_id: Optional[str] = Field(default=None) # Docker 内部的 Image ID
|
|||
|
|
version: str # e.g., 0.1.4
|
|||
|
|
status: str = Field(default="READY") # READY, BUILDING, ERROR
|
|||
|
|
source_dir: Optional[str] = Field(default=None) # 本地来源标识(如 manual)
|
|||
|
|
created_at: datetime = Field(default_factory=datetime.utcnow)
|