mirror of
https://github.com/langgenius/dify.git
synced 2026-04-29 15:08:06 +08:00
Made-with: Cursor # Conflicts: # api/controllers/console/app/workflow_draft_variable.py # api/core/agent/cot_agent_runner.py # api/core/agent/cot_chat_agent_runner.py # api/core/agent/cot_completion_agent_runner.py # api/core/agent/fc_agent_runner.py # api/core/app/apps/advanced_chat/app_generator.py # api/core/app/apps/advanced_chat/app_runner.py # api/core/app/apps/agent_chat/app_runner.py # api/core/app/apps/workflow/app_generator.py # api/core/app/apps/workflow/app_runner.py # api/core/app/entities/app_invoke_entities.py # api/core/app/entities/queue_entities.py # api/core/llm_generator/output_parser/structured_output.py # api/core/workflow/workflow_entry.py # api/dify_graph/context/__init__.py # api/dify_graph/entities/tool_entities.py # api/dify_graph/file/file_manager.py # api/dify_graph/graph_engine/response_coordinator/coordinator.py # api/dify_graph/graph_events/node.py # api/dify_graph/node_events/node.py # api/dify_graph/nodes/agent/agent_node.py # api/dify_graph/nodes/llm/entities.py # api/dify_graph/nodes/llm/llm_utils.py # api/dify_graph/nodes/llm/node.py # api/dify_graph/nodes/question_classifier/question_classifier_node.py # api/dify_graph/runtime/graph_runtime_state.py # api/dify_graph/variables/segments.py # api/factories/variable_factory.py # api/services/variable_truncator.py # api/tests/unit_tests/utils/structured_output_parser/test_structured_output_parser.py # api/uv.lock # web/app/components/app-sidebar/app-info.tsx # web/app/components/app-sidebar/app-sidebar-dropdown.tsx # web/app/components/app/create-app-modal/index.spec.tsx # web/app/components/apps/__tests__/list.spec.tsx # web/app/components/apps/app-card.tsx # web/app/components/apps/list.tsx # web/app/components/header/account-dropdown/compliance.tsx # web/app/components/header/account-dropdown/index.tsx # web/app/components/header/account-dropdown/support.tsx # web/app/components/workflow-app/components/workflow-onboarding-modal/index.tsx # web/app/components/workflow/panel/debug-and-preview/hooks.ts # web/contract/console/apps.ts # web/contract/router.ts # web/eslint-suppressions.json # web/next.config.ts # web/pnpm-lock.yaml
105 lines
3.8 KiB
Python
105 lines
3.8 KiB
Python
import logging
|
|
|
|
from core.model_runtime.utils.encoders import jsonable_encoder
|
|
from flask import request
|
|
from flask_restx import Resource, fields
|
|
from pydantic import BaseModel
|
|
|
|
from controllers.console import console_ns
|
|
from controllers.console.wraps import account_initialization_required, setup_required
|
|
from libs.login import current_account_with_tenant, login_required
|
|
from services.sandbox.sandbox_provider_service import SandboxProviderService
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
class SandboxProviderConfigRequest(BaseModel):
|
|
config: dict
|
|
activate: bool = False
|
|
|
|
|
|
class SandboxProviderActivateRequest(BaseModel):
|
|
type: str
|
|
|
|
|
|
@console_ns.route("/workspaces/current/sandbox-providers")
|
|
class SandboxProviderListApi(Resource):
|
|
@console_ns.doc("list_sandbox_providers")
|
|
@console_ns.doc(description="Get list of available sandbox providers with configuration status")
|
|
@console_ns.response(200, "Success", fields.List(fields.Raw(description="Sandbox provider information")))
|
|
@setup_required
|
|
@login_required
|
|
@account_initialization_required
|
|
def get(self):
|
|
_, current_tenant_id = current_account_with_tenant()
|
|
providers = SandboxProviderService.list_providers(current_tenant_id)
|
|
return jsonable_encoder([p.model_dump() for p in providers])
|
|
|
|
|
|
@console_ns.route("/workspaces/current/sandbox-provider/<string:provider_type>/config")
|
|
class SandboxProviderConfigApi(Resource):
|
|
@console_ns.doc("save_sandbox_provider_config")
|
|
@console_ns.doc(description="Save or update configuration for a sandbox provider")
|
|
@console_ns.response(200, "Success")
|
|
@setup_required
|
|
@login_required
|
|
@account_initialization_required
|
|
def post(self, provider_type: str):
|
|
_, current_tenant_id = current_account_with_tenant()
|
|
args = SandboxProviderConfigRequest.model_validate(request.get_json())
|
|
|
|
try:
|
|
result = SandboxProviderService.save_config(
|
|
tenant_id=current_tenant_id,
|
|
provider_type=provider_type,
|
|
config=args.config,
|
|
activate=args.activate,
|
|
)
|
|
return result
|
|
except ValueError as e:
|
|
return {"message": str(e)}, 400
|
|
|
|
@console_ns.doc("delete_sandbox_provider_config")
|
|
@console_ns.doc(description="Delete configuration for a sandbox provider")
|
|
@console_ns.response(200, "Success")
|
|
@setup_required
|
|
@login_required
|
|
@account_initialization_required
|
|
def delete(self, provider_type: str):
|
|
_, current_tenant_id = current_account_with_tenant()
|
|
|
|
try:
|
|
result = SandboxProviderService.delete_config(
|
|
tenant_id=current_tenant_id,
|
|
provider_type=provider_type,
|
|
)
|
|
return result
|
|
except ValueError as e:
|
|
return {"message": str(e)}, 400
|
|
|
|
|
|
@console_ns.route("/workspaces/current/sandbox-provider/<string:provider_type>/activate")
|
|
class SandboxProviderActivateApi(Resource):
|
|
"""Activate a sandbox provider."""
|
|
|
|
@console_ns.doc("activate_sandbox_provider")
|
|
@console_ns.doc(description="Activate a sandbox provider for the current workspace")
|
|
@console_ns.response(200, "Success")
|
|
@setup_required
|
|
@login_required
|
|
@account_initialization_required
|
|
def post(self, provider_type: str):
|
|
"""Activate a sandbox provider."""
|
|
_, current_tenant_id = current_account_with_tenant()
|
|
|
|
try:
|
|
args = SandboxProviderActivateRequest.model_validate(request.get_json())
|
|
result = SandboxProviderService.activate_provider(
|
|
tenant_id=current_tenant_id,
|
|
provider_type=provider_type,
|
|
type=args.type,
|
|
)
|
|
return result
|
|
except ValueError as e:
|
|
return {"message": str(e)}, 400
|