mirror of
https://github.com/langgenius/dify.git
synced 2026-05-28 21:03:22 +08:00
Signed-off-by: dependabot[bot] <support@github.com> Signed-off-by: EvanYao826 <155432245+EvanYao826@users.noreply.github.com> Co-authored-by: yyh <92089059+lyzno1@users.noreply.github.com> Co-authored-by: 盐粒 Yanli <yanli@dify.ai> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: Tianle <40735546+Tianlel@users.noreply.github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Yunlu Wen <yunlu.wen@dify.ai> Co-authored-by: zyssyz123 <916125788@qq.com> Co-authored-by: Claude Opus 4.7 (1M context) <noreply@anthropic.com> Co-authored-by: chariri <w@chariri.moe> Co-authored-by: Asuka Minato <i@asukaminato.eu.org> Co-authored-by: Copilot Autofix powered by AI <175728472+Copilot@users.noreply.github.com> Co-authored-by: Nian <11332799+Lillian68@users.noreply.github.com> Co-authored-by: 非法操作 <hjlarry@163.com> Co-authored-by: Carmen Fernández Ruiz <279459669+zeus1959@users.noreply.github.com> Co-authored-by: wangxiaolei <fatelei@gmail.com> Co-authored-by: QuantumGhost <obelisk.reg+git@gmail.com> Co-authored-by: L1nSn0w <l1nsn0w@qq.com> Co-authored-by: Evan <2869018789@qq.com> Co-authored-by: Escape0707 <tothesong@gmail.com> Co-authored-by: Jingyi <jingyi.qi@dify.ai> Co-authored-by: Amr Sherif <140330826+amr-sheriff@users.noreply.github.com> Co-authored-by: ZHOU ZHICHEN <118870511+zhuiguangzhe2003@users.noreply.github.com> Co-authored-by: unknown <EI05187@apwx.com> Co-authored-by: JzoNg <jzongcode@gmail.com> Co-authored-by: Xiyuan Chen <52963600+GareArc@users.noreply.github.com>
154 lines
6.2 KiB
Python
154 lines
6.2 KiB
Python
from flask_restx import Resource
|
|
|
|
from controllers.common.schema import register_schema_models
|
|
from controllers.console import console_ns
|
|
from controllers.console.app.wraps import get_app_model
|
|
from controllers.console.wraps import account_initialization_required, edit_permission_required, setup_required
|
|
from libs.login import current_account_with_tenant, login_required
|
|
from models.model import App, AppMode
|
|
from services.agent.composer_service import AgentComposerService
|
|
from services.agent.composer_validator import ComposerConfigValidator
|
|
from services.entities.agent_entities import ComposerSavePayload
|
|
|
|
register_schema_models(console_ns, ComposerSavePayload)
|
|
|
|
|
|
@console_ns.route("/apps/<uuid:app_id>/workflows/draft/nodes/<string:node_id>/agent-composer")
|
|
class WorkflowAgentComposerApi(Resource):
|
|
@setup_required
|
|
@login_required
|
|
@account_initialization_required
|
|
@get_app_model(mode=[AppMode.WORKFLOW, AppMode.ADVANCED_CHAT])
|
|
def get(self, app_model: App, node_id: str):
|
|
_, tenant_id = current_account_with_tenant()
|
|
return AgentComposerService.load_workflow_composer(
|
|
tenant_id=tenant_id,
|
|
app_id=app_model.id,
|
|
node_id=node_id,
|
|
)
|
|
|
|
@console_ns.expect(console_ns.models[ComposerSavePayload.__name__])
|
|
@setup_required
|
|
@login_required
|
|
@account_initialization_required
|
|
@edit_permission_required
|
|
@get_app_model(mode=[AppMode.WORKFLOW, AppMode.ADVANCED_CHAT])
|
|
def put(self, app_model: App, node_id: str):
|
|
account, tenant_id = current_account_with_tenant()
|
|
payload = ComposerSavePayload.model_validate(console_ns.payload or {})
|
|
return AgentComposerService.save_workflow_composer(
|
|
tenant_id=tenant_id,
|
|
app_id=app_model.id,
|
|
node_id=node_id,
|
|
account_id=account.id,
|
|
payload=payload,
|
|
)
|
|
|
|
|
|
@console_ns.route("/apps/<uuid:app_id>/workflows/draft/nodes/<string:node_id>/agent-composer/validate")
|
|
class WorkflowAgentComposerValidateApi(Resource):
|
|
@console_ns.expect(console_ns.models[ComposerSavePayload.__name__])
|
|
@setup_required
|
|
@login_required
|
|
@account_initialization_required
|
|
@get_app_model(mode=[AppMode.WORKFLOW, AppMode.ADVANCED_CHAT])
|
|
def post(self, app_model: App, node_id: str):
|
|
payload = ComposerSavePayload.model_validate(console_ns.payload or {})
|
|
ComposerConfigValidator.validate_save_payload(payload)
|
|
return {"result": "success", "errors": []}
|
|
|
|
|
|
@console_ns.route("/apps/<uuid:app_id>/workflows/draft/nodes/<string:node_id>/agent-composer/candidates")
|
|
class WorkflowAgentComposerCandidatesApi(Resource):
|
|
@setup_required
|
|
@login_required
|
|
@account_initialization_required
|
|
@get_app_model(mode=[AppMode.WORKFLOW, AppMode.ADVANCED_CHAT])
|
|
def get(self, app_model: App, node_id: str):
|
|
return AgentComposerService.get_workflow_candidates(app_id=app_model.id)
|
|
|
|
|
|
@console_ns.route("/apps/<uuid:app_id>/workflows/draft/nodes/<string:node_id>/agent-composer/impact")
|
|
class WorkflowAgentComposerImpactApi(Resource):
|
|
@setup_required
|
|
@login_required
|
|
@account_initialization_required
|
|
@get_app_model(mode=[AppMode.WORKFLOW, AppMode.ADVANCED_CHAT])
|
|
def post(self, app_model: App, node_id: str):
|
|
_, tenant_id = current_account_with_tenant()
|
|
payload = ComposerSavePayload.model_validate(console_ns.payload or {})
|
|
current_snapshot_id = payload.binding.current_snapshot_id if payload.binding else None
|
|
if not current_snapshot_id:
|
|
return {"current_snapshot_id": None, "workflow_node_count": 0, "bindings": []}
|
|
return AgentComposerService.calculate_impact(tenant_id=tenant_id, current_snapshot_id=current_snapshot_id)
|
|
|
|
|
|
@console_ns.route("/apps/<uuid:app_id>/workflows/draft/nodes/<string:node_id>/agent-composer/save-to-roster")
|
|
class WorkflowAgentComposerSaveToRosterApi(Resource):
|
|
@console_ns.expect(console_ns.models[ComposerSavePayload.__name__])
|
|
@setup_required
|
|
@login_required
|
|
@account_initialization_required
|
|
@edit_permission_required
|
|
@get_app_model(mode=[AppMode.WORKFLOW, AppMode.ADVANCED_CHAT])
|
|
def post(self, app_model: App, node_id: str):
|
|
account, tenant_id = current_account_with_tenant()
|
|
payload = ComposerSavePayload.model_validate(console_ns.payload or {})
|
|
return AgentComposerService.save_workflow_composer(
|
|
tenant_id=tenant_id,
|
|
app_id=app_model.id,
|
|
node_id=node_id,
|
|
account_id=account.id,
|
|
payload=payload,
|
|
)
|
|
|
|
|
|
@console_ns.route("/apps/<uuid:app_id>/agent-composer")
|
|
class AgentAppComposerApi(Resource):
|
|
@setup_required
|
|
@login_required
|
|
@account_initialization_required
|
|
@get_app_model()
|
|
def get(self, app_model: App):
|
|
_, tenant_id = current_account_with_tenant()
|
|
return AgentComposerService.load_agent_app_composer(tenant_id=tenant_id, app_id=app_model.id)
|
|
|
|
@console_ns.expect(console_ns.models[ComposerSavePayload.__name__])
|
|
@setup_required
|
|
@login_required
|
|
@account_initialization_required
|
|
@edit_permission_required
|
|
@get_app_model()
|
|
def put(self, app_model: App):
|
|
account, tenant_id = current_account_with_tenant()
|
|
payload = ComposerSavePayload.model_validate(console_ns.payload or {})
|
|
return AgentComposerService.save_agent_app_composer(
|
|
tenant_id=tenant_id,
|
|
app_id=app_model.id,
|
|
account_id=account.id,
|
|
payload=payload,
|
|
)
|
|
|
|
|
|
@console_ns.route("/apps/<uuid:app_id>/agent-composer/validate")
|
|
class AgentAppComposerValidateApi(Resource):
|
|
@console_ns.expect(console_ns.models[ComposerSavePayload.__name__])
|
|
@setup_required
|
|
@login_required
|
|
@account_initialization_required
|
|
@get_app_model()
|
|
def post(self, app_model: App):
|
|
payload = ComposerSavePayload.model_validate(console_ns.payload or {})
|
|
ComposerConfigValidator.validate_save_payload(payload)
|
|
return {"result": "success", "errors": []}
|
|
|
|
|
|
@console_ns.route("/apps/<uuid:app_id>/agent-composer/candidates")
|
|
class AgentAppComposerCandidatesApi(Resource):
|
|
@setup_required
|
|
@login_required
|
|
@account_initialization_required
|
|
@get_app_model()
|
|
def get(self, app_model: App):
|
|
return AgentComposerService.get_agent_app_candidates(app_id=app_model.id)
|