add plugin agent management tools

This commit is contained in:
jxxghp
2026-04-29 08:29:04 +08:00
parent 2ff1cd1045
commit bcc321eb70
10 changed files with 752 additions and 2 deletions

View File

@@ -1,7 +1,14 @@
from sqlalchemy import Column, String, JSON
from sqlalchemy import Column, String, JSON, select
from sqlalchemy.ext.asyncio import AsyncSession
from sqlalchemy.orm import Session
from app.db import db_query, db_update, get_id_column, Base
from app.db import (
db_query,
db_update,
async_db_query,
get_id_column,
Base,
)
class PluginData(Base):
@@ -18,11 +25,27 @@ class PluginData(Base):
def get_plugin_data(cls, db: Session, plugin_id: str):
return db.query(cls).filter(cls.plugin_id == plugin_id).all()
@classmethod
@async_db_query
async def async_get_plugin_data(cls, db: AsyncSession, plugin_id: str):
result = await db.execute(select(cls).where(cls.plugin_id == plugin_id))
return result.scalars().all()
@classmethod
@db_query
def get_plugin_data_by_key(cls, db: Session, plugin_id: str, key: str):
return db.query(cls).filter(cls.plugin_id == plugin_id, cls.key == key).first()
@classmethod
@async_db_query
async def async_get_plugin_data_by_key(
cls, db: AsyncSession, plugin_id: str, key: str
):
result = await db.execute(
select(cls).where(cls.plugin_id == plugin_id, cls.key == key)
)
return result.scalar_one_or_none()
@classmethod
@db_update
def del_plugin_data_by_key(cls, db: Session, plugin_id: str, key: str):
@@ -37,3 +60,11 @@ class PluginData(Base):
@db_query
def get_plugin_data_by_plugin_id(cls, db: Session, plugin_id: str):
return db.query(cls).filter(cls.plugin_id == plugin_id).all()
@classmethod
@async_db_query
async def async_get_plugin_data_by_plugin_id(
cls, db: AsyncSession, plugin_id: str
):
result = await db.execute(select(cls).where(cls.plugin_id == plugin_id))
return result.scalars().all()