mirror of
https://github.com/langgenius/dify.git
synced 2026-03-28 01:29:55 +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
91 lines
2.6 KiB
TypeScript
91 lines
2.6 KiB
TypeScript
import {
|
|
useCallback,
|
|
useState,
|
|
} from 'react'
|
|
import { useTranslation } from 'react-i18next'
|
|
import { useStore as useAppStore } from '@/app/components/app/store'
|
|
import { useToastContext } from '@/app/components/base/toast/context'
|
|
import {
|
|
DSL_EXPORT_CHECK,
|
|
} from '@/app/components/workflow/constants'
|
|
import { useEventEmitterContextContext } from '@/context/event-emitter'
|
|
import { exportAppBundle, exportAppConfig } from '@/service/apps'
|
|
import { fetchWorkflowDraft } from '@/service/workflow'
|
|
import { downloadBlob } from '@/utils/download'
|
|
import { useNodesSyncDraft } from './use-nodes-sync-draft'
|
|
|
|
export const useDSL = () => {
|
|
const { t } = useTranslation()
|
|
const { notify } = useToastContext()
|
|
const { eventEmitter } = useEventEmitterContextContext()
|
|
const [exporting, setExporting] = useState(false)
|
|
const { doSyncWorkflowDraft } = useNodesSyncDraft()
|
|
|
|
const appDetail = useAppStore(s => s.appDetail)
|
|
|
|
const handleExportDSL = useCallback(async (include = false, workflowId?: string, sandboxed = false) => {
|
|
if (!appDetail)
|
|
return
|
|
|
|
if (exporting)
|
|
return
|
|
|
|
try {
|
|
setExporting(true)
|
|
await doSyncWorkflowDraft()
|
|
|
|
if (sandboxed) {
|
|
await exportAppBundle({
|
|
appID: appDetail.id,
|
|
include,
|
|
workflowID: workflowId,
|
|
})
|
|
}
|
|
else {
|
|
const { data } = await exportAppConfig({
|
|
appID: appDetail.id,
|
|
include,
|
|
workflowID: workflowId,
|
|
})
|
|
const file = new Blob([data], { type: 'application/yaml' })
|
|
downloadBlob({ data: file, fileName: `${appDetail.name}.yaml` })
|
|
}
|
|
}
|
|
catch {
|
|
notify({ type: 'error', message: t('exportFailed', { ns: 'app' }) })
|
|
}
|
|
finally {
|
|
setExporting(false)
|
|
}
|
|
}, [appDetail, notify, t, doSyncWorkflowDraft, exporting])
|
|
|
|
const exportCheck = useCallback(async () => {
|
|
if (!appDetail)
|
|
return
|
|
try {
|
|
const workflowDraft = await fetchWorkflowDraft(`/apps/${appDetail?.id}/workflows/draft`)
|
|
const sandboxed = workflowDraft.features?.sandbox?.enabled === true
|
|
const list = (workflowDraft.environment_variables || []).filter(env => env.value_type === 'secret')
|
|
if (list.length === 0) {
|
|
handleExportDSL(false, undefined, sandboxed)
|
|
return
|
|
}
|
|
eventEmitter?.emit({
|
|
type: DSL_EXPORT_CHECK,
|
|
payload: {
|
|
data: list,
|
|
sandboxed,
|
|
},
|
|
} as any)
|
|
}
|
|
catch {
|
|
notify({ type: 'error', message: t('exportFailed', { ns: 'app' }) })
|
|
}
|
|
}, [appDetail, eventEmitter, handleExportDSL, notify, t])
|
|
|
|
return {
|
|
exportCheck,
|
|
handleExportDSL,
|
|
}
|
|
}
|