mirror of
https://github.com/langbot-app/LangBot.git
synced 2025-11-25 19:37:36 +08:00
45 lines
1.6 KiB
Python
45 lines
1.6 KiB
Python
import sqlalchemy
|
||
from .. import migration
|
||
|
||
|
||
@migration.migration_class(6)
|
||
class DBMigratePluginInstallSource(migration.DBMigration):
|
||
"""插件安装来源"""
|
||
|
||
async def upgrade(self):
|
||
"""升级"""
|
||
# 查询表结构获取所有列名(异步执行 SQL)
|
||
|
||
columns = []
|
||
|
||
if self.ap.persistence_mgr.db.name == 'postgresql':
|
||
result = await self.ap.persistence_mgr.execute_async(
|
||
sqlalchemy.text(
|
||
"SELECT column_name FROM information_schema.columns WHERE table_name = 'plugin_settings';"
|
||
)
|
||
)
|
||
all_result = result.fetchall()
|
||
columns = [row[0] for row in all_result]
|
||
else:
|
||
result = await self.ap.persistence_mgr.execute_async(sqlalchemy.text('PRAGMA table_info(plugin_settings);'))
|
||
all_result = result.fetchall()
|
||
columns = [row[1] for row in all_result]
|
||
|
||
# 检查并添加 install_source 列
|
||
if 'install_source' not in columns:
|
||
await self.ap.persistence_mgr.execute_async(
|
||
sqlalchemy.text(
|
||
"ALTER TABLE plugin_settings ADD COLUMN install_source VARCHAR(255) NOT NULL DEFAULT 'github'"
|
||
)
|
||
)
|
||
|
||
# 检查并添加 install_info 列
|
||
if 'install_info' not in columns:
|
||
await self.ap.persistence_mgr.execute_async(
|
||
sqlalchemy.text("ALTER TABLE plugin_settings ADD COLUMN install_info JSON NOT NULL DEFAULT '{}'")
|
||
)
|
||
|
||
async def downgrade(self):
|
||
"""降级"""
|
||
pass
|