feat: update persistence models

This commit is contained in:
Junyan Qin
2025-03-16 21:14:55 +08:00
parent b9d46d9972
commit a89a20a374
5 changed files with 8 additions and 9 deletions

View File

@@ -35,6 +35,7 @@ required_deps = {
"telegram": "python-telegram-bot",
"certifi": "certifi",
"mcp": "mcp",
"sqlmodel": "sqlmodel",
}

View File

@@ -1,4 +1,5 @@
import sqlalchemy
import datetime
from .base import Base
@@ -15,5 +16,5 @@ class LLMModel(Base):
api_keys = sqlalchemy.Column(sqlalchemy.JSON, nullable=False)
abilities = sqlalchemy.Column(sqlalchemy.JSON, nullable=False, default=[])
extra_args = sqlalchemy.Column(sqlalchemy.JSON, nullable=False, default={})
updated_at = sqlalchemy.Column(sqlalchemy.DateTime, nullable=False)
created_at = sqlalchemy.Column(sqlalchemy.DateTime, nullable=False)
created_at = sqlalchemy.Column(sqlalchemy.DateTime, nullable=False, server_default=sqlalchemy.func.now())
updated_at = sqlalchemy.Column(sqlalchemy.DateTime, nullable=False, server_default=sqlalchemy.func.now(), onupdate=sqlalchemy.func.now())

View File

@@ -1,4 +1,5 @@
import sqlalchemy
import sqlmodel
from .base import Base
@@ -9,5 +10,5 @@ class User(Base):
id = sqlalchemy.Column(sqlalchemy.Integer, primary_key=True)
user = sqlalchemy.Column(sqlalchemy.String(255), nullable=False)
password = sqlalchemy.Column(sqlalchemy.String(255), nullable=False)
created_at = sqlalchemy.Column(sqlalchemy.DateTime, nullable=False)
updated_at = sqlalchemy.Column(sqlalchemy.DateTime, nullable=False)
created_at = sqlalchemy.Column(sqlalchemy.DateTime, nullable=False, server_default=sqlalchemy.func.now())
updated_at = sqlalchemy.Column(sqlalchemy.DateTime, nullable=False, server_default=sqlalchemy.func.now(), onupdate=sqlalchemy.func.now())

View File

@@ -34,11 +34,6 @@ class PersistenceManager:
await self.create_tables()
# auto migrate
async with self.get_db_engine().connect() as conn:
await conn.run_sync(self.meta.drop_all)
await conn.run_sync(self.meta.create_all)
async def create_tables(self):
# TODO: 对扩展友好

View File

@@ -34,6 +34,7 @@ dashscope
python-telegram-bot
certifi
mcp
sqlmodel
# indirect
taskgroup==0.0.0a4