Refactor workflow sharing with independent config and improved data access

Co-authored-by: jxxghp <jxxghp@163.com>
This commit is contained in:
Cursor Agent
2025-07-08 15:33:43 +00:00
parent a2fd3a8d90
commit b8ee777fd2
6 changed files with 61 additions and 33 deletions

View File

@@ -18,7 +18,10 @@
- `app/helper/workflow.py` - 新增工作流分享helper类
### 修改文件
- `app/api/endpoints/workflow.py` - 新增工作流分享相关API接口
- `app/api/endpoints/workflow.py` - 新增工作流分享相关API接口使用WorkflowOper进行数据库操作
- `app/db/workflow_oper.py` - 新增list方法
- `app/db/models/workflow.py` - 新增list静态方法
- `app/core/config.py` - 新增WORKFLOW_STATISTIC_SHARE配置项
## API接口
@@ -112,7 +115,10 @@ GET /api/v1/workflow/shares?name=关键词&page=1&count=30
## 配置说明
工作流分享功能复用了订阅分享的配置项 `SUBSCRIBE_STATISTIC_SHARE`,当该配置为 `true` 时,工作流分享功能才会启用。
工作流分享功能使用独立的配置项 `WORKFLOW_STATISTIC_SHARE`,当该配置为 `true` 时,工作流分享功能才会启用。
### 配置项
- `WORKFLOW_STATISTIC_SHARE`: 工作流数据共享开关,默认为 `true`
## 服务器接口
@@ -153,12 +159,19 @@ def workflow_fork(shareid: int, db: Session = Depends(get_db)):
## 使用说明
1. **启用功能**: 确保 `SUBSCRIBE_STATISTIC_SHARE` 配置为 `true`
1. **启用功能**: 确保 `WORKFLOW_STATISTIC_SHARE` 配置为 `true`
2. **分享工作流**: 通过API接口分享本地工作流到公共服务器
3. **查看分享**: 查询公共服务器上的工作流分享
4. **复用工作流**: 将其他用户分享的工作流复制到本地使用
5. **管理分享**: 删除自己分享的工作流
## 技术改进
1. **独立配置**: 工作流分享功能使用独立的配置开关,不再依赖订阅分享配置
2. **数据访问层**: 使用WorkflowOper进行数据库操作提高代码的可维护性和一致性
3. **错误处理**: 完善的错误处理和参数验证
4. **类型安全**: 修复了所有类型相关的linter错误
## 注意事项
1. 工作流分享功能需要网络连接才能访问公共服务器

View File

@@ -26,8 +26,8 @@ def list_workflows(db: Session = Depends(get_db),
"""
获取工作流列表
"""
from app.db.models.workflow import Workflow as WorkflowModel
return WorkflowModel.list(db)
from app.db.workflow_oper import WorkflowOper
return WorkflowOper().list()
@router.post("/", summary="创建工作流", response_model=schemas.Response)
@@ -37,13 +37,14 @@ def create_workflow(workflow: schemas.Workflow,
"""
创建工作流
"""
from app.db.models.workflow import Workflow as WorkflowModel
if workflow.name and WorkflowModel.get_by_name(db, workflow.name):
from app.db.workflow_oper import WorkflowOper
if workflow.name and WorkflowOper().get_by_name(workflow.name):
return schemas.Response(success=False, message="已存在相同名称的工作流")
if not workflow.add_time:
workflow.add_time = datetime.strftime(datetime.now(), "%Y-%m-%d %H:%M:%S")
if not workflow.state:
workflow.state = "P"
from app.db.models.workflow import Workflow as WorkflowModel
WorkflowModel(**workflow.dict()).create(db)
return schemas.Response(success=True, message="创建工作流成功")
@@ -71,8 +72,8 @@ def get_workflow(workflow_id: int,
"""
获取工作流详情
"""
from app.db.models.workflow import Workflow as WorkflowModel
return WorkflowModel.get(db, workflow_id)
from app.db.workflow_oper import WorkflowOper
return WorkflowOper().get(workflow_id)
@router.put("/{workflow_id}", summary="更新工作流", response_model=schemas.Response)
@@ -82,10 +83,10 @@ def update_workflow(workflow: schemas.Workflow,
"""
更新工作流
"""
from app.db.models.workflow import Workflow as WorkflowModel
from app.db.workflow_oper import WorkflowOper
if not workflow.id:
return schemas.Response(success=False, message="工作流ID不能为空")
wf = WorkflowModel.get(db, workflow.id)
wf = WorkflowOper().get(workflow.id)
if not wf:
return schemas.Response(success=False, message="工作流不存在")
wf.update(db, workflow.dict())
@@ -99,13 +100,14 @@ def delete_workflow(workflow_id: int,
"""
删除工作流
"""
from app.db.models.workflow import Workflow as WorkflowModel
workflow = WorkflowModel.get(db, workflow_id)
from app.db.workflow_oper import WorkflowOper
workflow = WorkflowOper().get(workflow_id)
if not workflow:
return schemas.Response(success=False, message="工作流不存在")
# 删除定时任务
Scheduler().remove_workflow_job(workflow)
# 删除工作流
from app.db.models.workflow import Workflow as WorkflowModel
WorkflowModel.delete(db, workflow_id)
# 删除缓存
SystemConfigOper().delete(f"WorkflowCache-{workflow_id}")
@@ -162,12 +164,14 @@ def workflow_fork(
}
# 检查名称是否重复
db = next(get_db())
from app.db.models.workflow import Workflow as WorkflowModel
if WorkflowModel.get_by_name(db, workflow_dict["name"]):
from app.db.workflow_oper import WorkflowOper
if WorkflowOper().get_by_name(workflow_dict["name"]):
return schemas.Response(success=False, message="已存在相同名称的工作流")
# 创建新工作流
from app.db.models.workflow import Workflow as WorkflowModel
from app.db import get_db
db = next(get_db())
workflow = WorkflowModel(**workflow_dict)
workflow.create(db)
@@ -210,8 +214,8 @@ def start_workflow(workflow_id: int,
"""
启用工作流
"""
from app.db.models.workflow import Workflow as WorkflowModel
workflow = WorkflowModel.get(db, workflow_id)
from app.db.workflow_oper import WorkflowOper
workflow = WorkflowOper().get(workflow_id)
if not workflow:
return schemas.Response(success=False, message="工作流不存在")
# 添加定时任务
@@ -228,8 +232,8 @@ def pause_workflow(workflow_id: int,
"""
停用工作流
"""
from app.db.models.workflow import Workflow as WorkflowModel
workflow = WorkflowModel.get(db, workflow_id)
from app.db.workflow_oper import WorkflowOper
workflow = WorkflowOper().get(workflow_id)
if not workflow:
return schemas.Response(success=False, message="工作流不存在")
# 删除定时任务
@@ -248,8 +252,8 @@ def reset_workflow(workflow_id: int,
"""
重置工作流
"""
from app.db.models.workflow import Workflow as WorkflowModel
workflow = WorkflowModel.get(db, workflow_id)
from app.db.workflow_oper import WorkflowOper
workflow = WorkflowOper().get(workflow_id)
if not workflow:
return schemas.Response(success=False, message="工作流不存在")
# 停止工作流

View File

@@ -201,6 +201,8 @@ class ConfigModel(BaseModel):
SUBSCRIBE_RSS_INTERVAL: int = 30
# 订阅数据共享
SUBSCRIBE_STATISTIC_SHARE: bool = True
# 工作流数据共享
WORKFLOW_STATISTIC_SHARE: bool = True
# 订阅搜索开关
SUBSCRIBE_SEARCH: bool = False
# 检查本地媒体库是否存在资源开关

View File

@@ -37,6 +37,11 @@ class Workflow(Base):
# 最后执行时间
last_time = Column(String)
@staticmethod
@db_query
def list(db):
return db.query(Workflow).all()
@staticmethod
@db_query
def get_enabled_workflows(db):

View File

@@ -25,6 +25,12 @@ class WorkflowOper(DbOper):
"""
return Workflow.get(self._db, wid)
def list(self) -> List[Workflow]:
"""
获取所有工作流列表
"""
return Workflow.list(self._db)
def list_enabled(self) -> List[Workflow]:
"""
获取启用的工作流列表

View File

@@ -4,7 +4,7 @@ import json
from app.core.cache import cached, cache_backend
from app.core.config import settings
from app.db.models.workflow import Workflow as WorkflowModel
from app.db.workflow_oper import WorkflowOper
from app.db.systemconfig_oper import SystemConfigOper
from app.log import logger
from app.schemas.types import SystemConfigKey
@@ -36,13 +36,11 @@ class WorkflowHelper(metaclass=WeakSingleton):
"""
分享工作流
"""
if not settings.SUBSCRIBE_STATISTIC_SHARE: # 复用订阅分享的配置
return False, "当前没有开启数据共享功能"
if not settings.WORKFLOW_STATISTIC_SHARE: # 使用独立的工作流分享开关
return False, "当前没有开启工作流数据共享功能"
# 获取工作流信息
from app.db import get_db
db = next(get_db())
workflow = WorkflowModel.get(db, workflow_id)
workflow = WorkflowOper().get(workflow_id)
if not workflow:
return False, "工作流不存在"
@@ -75,8 +73,8 @@ class WorkflowHelper(metaclass=WeakSingleton):
"""
删除分享
"""
if not settings.SUBSCRIBE_STATISTIC_SHARE: # 复用订阅分享的配置
return False, "当前没有开启数据共享功能"
if not settings.WORKFLOW_STATISTIC_SHARE: # 使用独立的工作流分享开关
return False, "当前没有开启工作流数据共享功能"
res = RequestUtils(proxies=settings.PROXY or {},
timeout=5).delete_res(f"{self._workflow_share}/{share_id}",
@@ -94,8 +92,8 @@ class WorkflowHelper(metaclass=WeakSingleton):
"""
复用分享的工作流
"""
if not settings.SUBSCRIBE_STATISTIC_SHARE: # 复用订阅分享的配置
return False, "当前没有开启数据共享功能"
if not settings.WORKFLOW_STATISTIC_SHARE: # 使用独立的工作流分享开关
return False, "当前没有开启工作流数据共享功能"
res = RequestUtils(proxies=settings.PROXY or {}, timeout=5, headers={
"Content-Type": "application/json"
@@ -112,7 +110,7 @@ class WorkflowHelper(metaclass=WeakSingleton):
"""
获取工作流分享数据
"""
if not settings.SUBSCRIBE_STATISTIC_SHARE: # 复用订阅分享的配置
if not settings.WORKFLOW_STATISTIC_SHARE: # 使用独立的工作流分享开关
return []
res = RequestUtils(proxies=settings.PROXY or {}, timeout=15).get_res(self._workflow_shares, params={