unreal-engine-mcp-server 0.4.6 → 0.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.env.example +26 -0
- package/.env.production +38 -7
- package/.eslintrc.json +0 -54
- package/.eslintrc.override.json +8 -0
- package/.github/ISSUE_TEMPLATE/bug_report.yml +94 -0
- package/.github/ISSUE_TEMPLATE/config.yml +8 -0
- package/.github/ISSUE_TEMPLATE/feature_request.yml +56 -0
- package/.github/copilot-instructions.md +478 -45
- package/.github/dependabot.yml +19 -0
- package/.github/labeler.yml +24 -0
- package/.github/labels.yml +70 -0
- package/.github/pull_request_template.md +42 -0
- package/.github/release-drafter.yml +148 -0
- package/.github/workflows/auto-merge.yml +38 -0
- package/.github/workflows/ci.yml +38 -0
- package/.github/workflows/dependency-review.yml +17 -0
- package/.github/workflows/gemini-issue-triage.yml +172 -0
- package/.github/workflows/greetings.yml +23 -0
- package/.github/workflows/labeler.yml +16 -0
- package/.github/workflows/links.yml +80 -0
- package/.github/workflows/pr-size-labeler.yml +137 -0
- package/.github/workflows/publish-mcp.yml +12 -7
- package/.github/workflows/release-drafter.yml +23 -0
- package/.github/workflows/release.yml +112 -0
- package/.github/workflows/semantic-pull-request.yml +35 -0
- package/.github/workflows/smoke-test.yml +36 -0
- package/.github/workflows/stale.yml +28 -0
- package/CHANGELOG.md +269 -22
- package/CONTRIBUTING.md +140 -0
- package/README.md +166 -72
- package/claude_desktop_config_example.json +7 -6
- package/dist/automation/bridge.d.ts +50 -0
- package/dist/automation/bridge.js +452 -0
- package/dist/automation/connection-manager.d.ts +23 -0
- package/dist/automation/connection-manager.js +107 -0
- package/dist/automation/handshake.d.ts +11 -0
- package/dist/automation/handshake.js +89 -0
- package/dist/automation/index.d.ts +3 -0
- package/dist/automation/index.js +3 -0
- package/dist/automation/message-handler.d.ts +12 -0
- package/dist/automation/message-handler.js +149 -0
- package/dist/automation/request-tracker.d.ts +25 -0
- package/dist/automation/request-tracker.js +98 -0
- package/dist/automation/types.d.ts +130 -0
- package/dist/automation/types.js +2 -0
- package/dist/cli.js +32 -5
- package/dist/config.d.ts +27 -0
- package/dist/config.js +60 -0
- package/dist/constants.d.ts +12 -0
- package/dist/constants.js +12 -0
- package/dist/graphql/resolvers.d.ts +268 -0
- package/dist/graphql/resolvers.js +743 -0
- package/dist/graphql/schema.d.ts +5 -0
- package/dist/graphql/schema.js +437 -0
- package/dist/graphql/server.d.ts +26 -0
- package/dist/graphql/server.js +115 -0
- package/dist/graphql/types.d.ts +7 -0
- package/dist/graphql/types.js +2 -0
- package/dist/handlers/resource-handlers.d.ts +20 -0
- package/dist/handlers/resource-handlers.js +180 -0
- package/dist/index.d.ts +31 -18
- package/dist/index.js +119 -604
- package/dist/prompts/index.js +4 -4
- package/dist/resources/actors.d.ts +17 -12
- package/dist/resources/actors.js +56 -76
- package/dist/resources/assets.d.ts +6 -14
- package/dist/resources/assets.js +115 -147
- package/dist/resources/levels.d.ts +13 -13
- package/dist/resources/levels.js +25 -34
- package/dist/server/resource-registry.d.ts +20 -0
- package/dist/server/resource-registry.js +37 -0
- package/dist/server/tool-registry.d.ts +23 -0
- package/dist/server/tool-registry.js +322 -0
- package/dist/server-setup.d.ts +21 -0
- package/dist/server-setup.js +111 -0
- package/dist/services/health-monitor.d.ts +34 -0
- package/dist/services/health-monitor.js +105 -0
- package/dist/services/metrics-server.d.ts +11 -0
- package/dist/services/metrics-server.js +105 -0
- package/dist/tools/actors.d.ts +147 -9
- package/dist/tools/actors.js +350 -311
- package/dist/tools/animation.d.ts +135 -4
- package/dist/tools/animation.js +510 -411
- package/dist/tools/assets.d.ts +117 -19
- package/dist/tools/assets.js +259 -284
- package/dist/tools/audio.d.ts +102 -42
- package/dist/tools/audio.js +272 -685
- package/dist/tools/base-tool.d.ts +17 -0
- package/dist/tools/base-tool.js +46 -0
- package/dist/tools/behavior-tree.d.ts +94 -0
- package/dist/tools/behavior-tree.js +39 -0
- package/dist/tools/blueprint/helpers.d.ts +29 -0
- package/dist/tools/blueprint/helpers.js +182 -0
- package/dist/tools/blueprint.d.ts +228 -118
- package/dist/tools/blueprint.js +685 -832
- package/dist/tools/consolidated-tool-definitions.d.ts +5475 -1627
- package/dist/tools/consolidated-tool-definitions.js +829 -482
- package/dist/tools/consolidated-tool-handlers.d.ts +2 -1
- package/dist/tools/consolidated-tool-handlers.js +211 -1009
- package/dist/tools/debug.d.ts +143 -85
- package/dist/tools/debug.js +234 -180
- package/dist/tools/dynamic-handler-registry.d.ts +11 -0
- package/dist/tools/dynamic-handler-registry.js +101 -0
- package/dist/tools/editor.d.ts +139 -18
- package/dist/tools/editor.js +239 -244
- package/dist/tools/engine.d.ts +10 -4
- package/dist/tools/engine.js +13 -5
- package/dist/tools/environment.d.ts +36 -0
- package/dist/tools/environment.js +267 -0
- package/dist/tools/foliage.d.ts +105 -14
- package/dist/tools/foliage.js +219 -331
- package/dist/tools/handlers/actor-handlers.d.ts +3 -0
- package/dist/tools/handlers/actor-handlers.js +232 -0
- package/dist/tools/handlers/animation-handlers.d.ts +3 -0
- package/dist/tools/handlers/animation-handlers.js +185 -0
- package/dist/tools/handlers/argument-helper.d.ts +16 -0
- package/dist/tools/handlers/argument-helper.js +80 -0
- package/dist/tools/handlers/asset-handlers.d.ts +3 -0
- package/dist/tools/handlers/asset-handlers.js +496 -0
- package/dist/tools/handlers/audio-handlers.d.ts +3 -0
- package/dist/tools/handlers/audio-handlers.js +166 -0
- package/dist/tools/handlers/blueprint-handlers.d.ts +4 -0
- package/dist/tools/handlers/blueprint-handlers.js +358 -0
- package/dist/tools/handlers/common-handlers.d.ts +14 -0
- package/dist/tools/handlers/common-handlers.js +56 -0
- package/dist/tools/handlers/editor-handlers.d.ts +3 -0
- package/dist/tools/handlers/editor-handlers.js +119 -0
- package/dist/tools/handlers/effect-handlers.d.ts +3 -0
- package/dist/tools/handlers/effect-handlers.js +171 -0
- package/dist/tools/handlers/environment-handlers.d.ts +3 -0
- package/dist/tools/handlers/environment-handlers.js +170 -0
- package/dist/tools/handlers/graph-handlers.d.ts +3 -0
- package/dist/tools/handlers/graph-handlers.js +90 -0
- package/dist/tools/handlers/input-handlers.d.ts +3 -0
- package/dist/tools/handlers/input-handlers.js +21 -0
- package/dist/tools/handlers/inspect-handlers.d.ts +3 -0
- package/dist/tools/handlers/inspect-handlers.js +383 -0
- package/dist/tools/handlers/level-handlers.d.ts +3 -0
- package/dist/tools/handlers/level-handlers.js +237 -0
- package/dist/tools/handlers/lighting-handlers.d.ts +3 -0
- package/dist/tools/handlers/lighting-handlers.js +144 -0
- package/dist/tools/handlers/performance-handlers.d.ts +3 -0
- package/dist/tools/handlers/performance-handlers.js +130 -0
- package/dist/tools/handlers/pipeline-handlers.d.ts +3 -0
- package/dist/tools/handlers/pipeline-handlers.js +110 -0
- package/dist/tools/handlers/sequence-handlers.d.ts +3 -0
- package/dist/tools/handlers/sequence-handlers.js +376 -0
- package/dist/tools/handlers/system-handlers.d.ts +4 -0
- package/dist/tools/handlers/system-handlers.js +506 -0
- package/dist/tools/input.d.ts +19 -0
- package/dist/tools/input.js +89 -0
- package/dist/tools/introspection.d.ts +103 -40
- package/dist/tools/introspection.js +425 -568
- package/dist/tools/landscape.d.ts +97 -36
- package/dist/tools/landscape.js +280 -409
- package/dist/tools/level.d.ts +130 -10
- package/dist/tools/level.js +639 -675
- package/dist/tools/lighting.d.ts +77 -38
- package/dist/tools/lighting.js +441 -943
- package/dist/tools/logs.d.ts +45 -0
- package/dist/tools/logs.js +210 -0
- package/dist/tools/materials.d.ts +91 -24
- package/dist/tools/materials.js +190 -118
- package/dist/tools/niagara.d.ts +149 -39
- package/dist/tools/niagara.js +232 -182
- package/dist/tools/performance.d.ts +27 -12
- package/dist/tools/performance.js +204 -122
- package/dist/tools/physics.d.ts +32 -77
- package/dist/tools/physics.js +171 -582
- package/dist/tools/property-dictionary.d.ts +13 -0
- package/dist/tools/property-dictionary.js +82 -0
- package/dist/tools/sequence.d.ts +73 -48
- package/dist/tools/sequence.js +196 -748
- package/dist/tools/tool-definition-utils.d.ts +59 -0
- package/dist/tools/tool-definition-utils.js +35 -0
- package/dist/tools/ui.d.ts +66 -34
- package/dist/tools/ui.js +134 -214
- package/dist/types/env.d.ts +0 -3
- package/dist/types/env.js +0 -7
- package/dist/types/tool-interfaces.d.ts +898 -0
- package/dist/types/tool-interfaces.js +2 -0
- package/dist/types/tool-types.d.ts +195 -11
- package/dist/types/tool-types.js +0 -4
- package/dist/unreal-bridge.d.ts +24 -131
- package/dist/unreal-bridge.js +364 -1506
- package/dist/utils/command-validator.d.ts +9 -0
- package/dist/utils/command-validator.js +67 -0
- package/dist/utils/elicitation.d.ts +1 -1
- package/dist/utils/elicitation.js +12 -15
- package/dist/utils/error-handler.d.ts +2 -51
- package/dist/utils/error-handler.js +11 -87
- package/dist/utils/ini-reader.d.ts +3 -0
- package/dist/utils/ini-reader.js +69 -0
- package/dist/utils/logger.js +9 -6
- package/dist/utils/normalize.d.ts +3 -0
- package/dist/utils/normalize.js +56 -0
- package/dist/utils/response-factory.d.ts +7 -0
- package/dist/utils/response-factory.js +33 -0
- package/dist/utils/response-validator.d.ts +3 -24
- package/dist/utils/response-validator.js +130 -81
- package/dist/utils/result-helpers.d.ts +4 -5
- package/dist/utils/result-helpers.js +15 -16
- package/dist/utils/safe-json.js +5 -11
- package/dist/utils/unreal-command-queue.d.ts +24 -0
- package/dist/utils/unreal-command-queue.js +120 -0
- package/dist/utils/validation.d.ts +0 -40
- package/dist/utils/validation.js +1 -78
- package/dist/wasm/index.d.ts +70 -0
- package/dist/wasm/index.js +535 -0
- package/docs/GraphQL-API.md +888 -0
- package/docs/Migration-Guide-v0.5.0.md +692 -0
- package/docs/Roadmap.md +53 -0
- package/docs/WebAssembly-Integration.md +628 -0
- package/docs/editor-plugin-extension.md +370 -0
- package/docs/handler-mapping.md +242 -0
- package/docs/native-automation-progress.md +128 -0
- package/docs/testing-guide.md +423 -0
- package/mcp-config-example.json +6 -6
- package/package.json +60 -27
- package/plugins/McpAutomationBridge/Config/FilterPlugin.ini +8 -0
- package/plugins/McpAutomationBridge/McpAutomationBridge.uplugin +64 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/McpAutomationBridge.Build.cs +189 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridgeGlobals.cpp +22 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridgeGlobals.h +30 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridgeHelpers.h +1983 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridgeModule.cpp +72 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridgeSettings.cpp +46 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridgeSubsystem.cpp +581 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_AnimationHandlers.cpp +2394 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_AssetQueryHandlers.cpp +300 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_AssetWorkflowHandlers.cpp +2807 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_AudioHandlers.cpp +1087 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_BehaviorTreeHandlers.cpp +488 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_BlueprintCreationHandlers.cpp +643 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_BlueprintCreationHandlers.h +31 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_BlueprintGraphHandlers.cpp +1184 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_BlueprintHandlers.cpp +5652 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_BlueprintHandlers_List.cpp +152 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_ControlHandlers.cpp +2614 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_DebugHandlers.cpp +42 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_EditorFunctionHandlers.cpp +1237 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_EffectHandlers.cpp +1701 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_EnvironmentHandlers.cpp +2145 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_FoliageHandlers.cpp +954 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_InputHandlers.cpp +209 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_InsightsHandlers.cpp +41 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_LandscapeHandlers.cpp +1164 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_LevelHandlers.cpp +762 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_LightingHandlers.cpp +634 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_LogHandlers.cpp +136 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_MaterialGraphHandlers.cpp +494 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_NiagaraGraphHandlers.cpp +278 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_NiagaraHandlers.cpp +625 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_PerformanceHandlers.cpp +401 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_PipelineHandlers.cpp +67 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_ProcessRequest.cpp +735 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_PropertyHandlers.cpp +2634 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_RenderHandlers.cpp +189 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_SCSHandlers.cpp +917 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_SCSHandlers.h +39 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_SequenceHandlers.cpp +2670 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_SequencerHandlers.cpp +519 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_TestHandlers.cpp +38 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_UiHandlers.cpp +668 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_WorldPartitionHandlers.cpp +346 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpBridgeWebSocket.cpp +1330 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpBridgeWebSocket.h +149 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpConnectionManager.cpp +783 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Public/McpAutomationBridgeSettings.h +115 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Public/McpAutomationBridgeSubsystem.h +796 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Public/McpConnectionManager.h +117 -0
- package/scripts/check-unreal-connection.mjs +19 -0
- package/scripts/clean-tmp.js +23 -0
- package/scripts/patch-wasm.js +26 -0
- package/scripts/run-all-tests.mjs +131 -0
- package/scripts/smoke-test.ts +94 -0
- package/scripts/sync-mcp-plugin.js +143 -0
- package/scripts/test-no-plugin-alternates.mjs +113 -0
- package/scripts/validate-server.js +46 -0
- package/scripts/verify-automation-bridge.js +200 -0
- package/server.json +57 -21
- package/src/automation/bridge.ts +558 -0
- package/src/automation/connection-manager.ts +130 -0
- package/src/automation/handshake.ts +99 -0
- package/src/automation/index.ts +2 -0
- package/src/automation/message-handler.ts +167 -0
- package/src/automation/request-tracker.ts +123 -0
- package/src/automation/types.ts +107 -0
- package/src/cli.ts +33 -6
- package/src/config.ts +73 -0
- package/src/constants.ts +12 -0
- package/src/graphql/resolvers.ts +1010 -0
- package/src/graphql/schema.ts +452 -0
- package/src/graphql/server.ts +154 -0
- package/src/graphql/types.ts +7 -0
- package/src/handlers/resource-handlers.ts +186 -0
- package/src/index.ts +152 -649
- package/src/prompts/index.ts +4 -4
- package/src/resources/actors.ts +58 -76
- package/src/resources/assets.ts +147 -134
- package/src/resources/levels.ts +28 -33
- package/src/server/resource-registry.ts +47 -0
- package/src/server/tool-registry.ts +354 -0
- package/src/server-setup.ts +148 -0
- package/src/services/health-monitor.ts +132 -0
- package/src/services/metrics-server.ts +142 -0
- package/src/tools/actors.ts +417 -322
- package/src/tools/animation.ts +671 -461
- package/src/tools/assets.ts +353 -289
- package/src/tools/audio.ts +323 -766
- package/src/tools/base-tool.ts +52 -0
- package/src/tools/behavior-tree.ts +45 -0
- package/src/tools/blueprint/helpers.ts +189 -0
- package/src/tools/blueprint.ts +787 -965
- package/src/tools/consolidated-tool-definitions.ts +993 -500
- package/src/tools/consolidated-tool-handlers.ts +272 -1122
- package/src/tools/debug.ts +292 -187
- package/src/tools/dynamic-handler-registry.ts +151 -0
- package/src/tools/editor.ts +309 -246
- package/src/tools/engine.ts +14 -3
- package/src/tools/environment.ts +287 -0
- package/src/tools/foliage.ts +314 -379
- package/src/tools/handlers/actor-handlers.ts +271 -0
- package/src/tools/handlers/animation-handlers.ts +237 -0
- package/src/tools/handlers/argument-helper.ts +142 -0
- package/src/tools/handlers/asset-handlers.ts +532 -0
- package/src/tools/handlers/audio-handlers.ts +194 -0
- package/src/tools/handlers/blueprint-handlers.ts +380 -0
- package/src/tools/handlers/common-handlers.ts +87 -0
- package/src/tools/handlers/editor-handlers.ts +123 -0
- package/src/tools/handlers/effect-handlers.ts +220 -0
- package/src/tools/handlers/environment-handlers.ts +183 -0
- package/src/tools/handlers/graph-handlers.ts +116 -0
- package/src/tools/handlers/input-handlers.ts +28 -0
- package/src/tools/handlers/inspect-handlers.ts +450 -0
- package/src/tools/handlers/level-handlers.ts +252 -0
- package/src/tools/handlers/lighting-handlers.ts +147 -0
- package/src/tools/handlers/performance-handlers.ts +132 -0
- package/src/tools/handlers/pipeline-handlers.ts +127 -0
- package/src/tools/handlers/sequence-handlers.ts +415 -0
- package/src/tools/handlers/system-handlers.ts +564 -0
- package/src/tools/input.ts +101 -0
- package/src/tools/introspection.ts +493 -584
- package/src/tools/landscape.ts +394 -489
- package/src/tools/level.ts +752 -694
- package/src/tools/lighting.ts +583 -984
- package/src/tools/logs.ts +219 -0
- package/src/tools/materials.ts +231 -121
- package/src/tools/niagara.ts +293 -168
- package/src/tools/performance.ts +320 -168
- package/src/tools/physics.ts +268 -613
- package/src/tools/property-dictionary.ts +98 -0
- package/src/tools/sequence.ts +255 -815
- package/src/tools/tool-definition-utils.ts +35 -0
- package/src/tools/ui.ts +207 -283
- package/src/types/env.ts +0 -10
- package/src/types/tool-interfaces.ts +250 -0
- package/src/types/tool-types.ts +250 -13
- package/src/unreal-bridge.ts +460 -1550
- package/src/utils/command-validator.ts +75 -0
- package/src/utils/elicitation.ts +10 -7
- package/src/utils/error-handler.ts +14 -90
- package/src/utils/ini-reader.ts +86 -0
- package/src/utils/logger.ts +8 -3
- package/src/utils/normalize.ts +60 -0
- package/src/utils/response-factory.ts +39 -0
- package/src/utils/response-validator.ts +176 -56
- package/src/utils/result-helpers.ts +21 -19
- package/src/utils/safe-json.ts +14 -11
- package/src/utils/unreal-command-queue.ts +152 -0
- package/src/utils/validation.ts +4 -1
- package/src/wasm/index.ts +838 -0
- package/test-server.mjs +100 -0
- package/tests/run-unreal-tool-tests.mjs +242 -14
- package/tests/test-animation.mjs +44 -0
- package/tests/test-asset-advanced.mjs +82 -0
- package/tests/test-asset-errors.mjs +35 -0
- package/tests/test-audio.mjs +219 -0
- package/tests/test-automation-timeouts.mjs +98 -0
- package/tests/test-behavior-tree.mjs +261 -0
- package/tests/test-blueprint-events.mjs +35 -0
- package/tests/test-blueprint-graph.mjs +79 -0
- package/tests/test-blueprint.mjs +577 -0
- package/tests/test-client-mode.mjs +86 -0
- package/tests/test-console-command.mjs +56 -0
- package/tests/test-control-actor.mjs +425 -0
- package/tests/test-control-editor.mjs +80 -0
- package/tests/test-extra-tools.mjs +38 -0
- package/tests/test-graphql.mjs +322 -0
- package/tests/test-inspect.mjs +72 -0
- package/tests/test-landscape.mjs +60 -0
- package/tests/test-manage-asset.mjs +438 -0
- package/tests/test-manage-level.mjs +70 -0
- package/tests/test-materials.mjs +356 -0
- package/tests/test-niagara.mjs +185 -0
- package/tests/test-no-inline-python.mjs +122 -0
- package/tests/test-plugin-handshake.mjs +82 -0
- package/tests/test-render.mjs +33 -0
- package/tests/test-runner.mjs +933 -0
- package/tests/test-search-assets.mjs +66 -0
- package/tests/test-sequence.mjs +68 -0
- package/tests/test-system.mjs +57 -0
- package/tests/test-wasm.mjs +193 -0
- package/tests/test-world-partition.mjs +215 -0
- package/tsconfig.json +3 -3
- package/wasm/Cargo.lock +363 -0
- package/wasm/Cargo.toml +42 -0
- package/wasm/LICENSE +21 -0
- package/wasm/README.md +253 -0
- package/wasm/src/dependency_resolver.rs +377 -0
- package/wasm/src/lib.rs +153 -0
- package/wasm/src/property_parser.rs +271 -0
- package/wasm/src/transform_math.rs +396 -0
- package/wasm/tests/integration.rs +109 -0
- package/.github/workflows/smithery-build.yml +0 -29
- package/dist/tools/build_environment_advanced.d.ts +0 -65
- package/dist/tools/build_environment_advanced.js +0 -633
- package/dist/tools/rc.d.ts +0 -110
- package/dist/tools/rc.js +0 -437
- package/dist/tools/visual.d.ts +0 -40
- package/dist/tools/visual.js +0 -282
- package/dist/utils/http.d.ts +0 -6
- package/dist/utils/http.js +0 -151
- package/dist/utils/python-output.d.ts +0 -18
- package/dist/utils/python-output.js +0 -290
- package/dist/utils/python.d.ts +0 -2
- package/dist/utils/python.js +0 -4
- package/dist/utils/stdio-redirect.d.ts +0 -2
- package/dist/utils/stdio-redirect.js +0 -20
- package/docs/unreal-tool-test-cases.md +0 -572
- package/smithery.yaml +0 -29
- package/src/tools/build_environment_advanced.ts +0 -732
- package/src/tools/rc.ts +0 -515
- package/src/tools/visual.ts +0 -281
- package/src/utils/http.ts +0 -187
- package/src/utils/python-output.ts +0 -351
- package/src/utils/python.ts +0 -3
- package/src/utils/stdio-redirect.ts +0 -18
|
@@ -0,0 +1,415 @@
|
|
|
1
|
+
import { cleanObject } from '../../utils/safe-json.js';
|
|
2
|
+
import { ITools } from '../../types/tool-interfaces.js';
|
|
3
|
+
import { executeAutomationRequest, requireNonEmptyString } from './common-handlers.js';
|
|
4
|
+
|
|
5
|
+
const managedSequences = new Set<string>();
|
|
6
|
+
const deletedSequences = new Set<string>();
|
|
7
|
+
|
|
8
|
+
function normalizeSequencePath(path: unknown): string | undefined {
|
|
9
|
+
if (typeof path !== 'string') return undefined;
|
|
10
|
+
const trimmed = path.trim();
|
|
11
|
+
return trimmed.length > 0 ? trimmed : undefined;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
function markSequenceCreated(path: unknown) {
|
|
15
|
+
const norm = normalizeSequencePath(path);
|
|
16
|
+
if (!norm) return;
|
|
17
|
+
deletedSequences.delete(norm);
|
|
18
|
+
managedSequences.add(norm);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
function markSequenceDeleted(path: unknown) {
|
|
22
|
+
const norm = normalizeSequencePath(path);
|
|
23
|
+
if (!norm) return;
|
|
24
|
+
managedSequences.delete(norm);
|
|
25
|
+
deletedSequences.add(norm);
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
export async function handleSequenceTools(action: string, args: any, tools: ITools) {
|
|
31
|
+
const seqAction = String(action || '').trim();
|
|
32
|
+
switch (seqAction) {
|
|
33
|
+
case 'create': {
|
|
34
|
+
const name = requireNonEmptyString(args.name, 'name', 'Missing required parameter: name');
|
|
35
|
+
const res = await tools.sequenceTools.create({ name, path: args.path });
|
|
36
|
+
|
|
37
|
+
let sequencePath: string | undefined;
|
|
38
|
+
if (res && (res as any).result && typeof (res as any).result.sequencePath === 'string') {
|
|
39
|
+
sequencePath = (res as any).result.sequencePath;
|
|
40
|
+
} else if (typeof args.path === 'string' && args.path.trim().length > 0) {
|
|
41
|
+
const basePath = args.path.trim().replace(/\/$/, '');
|
|
42
|
+
sequencePath = `${basePath}/${name}`;
|
|
43
|
+
}
|
|
44
|
+
if (sequencePath && res && (res as any).success !== false) {
|
|
45
|
+
markSequenceCreated(sequencePath);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
const errorCode = String((res && (res as any).error) || '').toUpperCase();
|
|
49
|
+
const msgLower = String((res && (res as any).message) || '').toLowerCase();
|
|
50
|
+
if (res && (res as any).success === false && (errorCode === 'FACTORY_NOT_AVAILABLE' || msgLower.includes('ulevelsequencefactorynew not available'))) {
|
|
51
|
+
const path = sequencePath || (typeof args.path === 'string' ? args.path : undefined);
|
|
52
|
+
return cleanObject({
|
|
53
|
+
success: false,
|
|
54
|
+
error: 'FACTORY_NOT_AVAILABLE',
|
|
55
|
+
message: (res as any).message || 'Sequence creation failed: factory not available',
|
|
56
|
+
action: 'create',
|
|
57
|
+
name,
|
|
58
|
+
path,
|
|
59
|
+
sequencePath,
|
|
60
|
+
handled: true
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
return cleanObject(res);
|
|
65
|
+
}
|
|
66
|
+
case 'open': {
|
|
67
|
+
const path = requireNonEmptyString(args.path, 'path', 'Missing required parameter: path');
|
|
68
|
+
const res = await tools.sequenceTools.open({ path });
|
|
69
|
+
return cleanObject(res);
|
|
70
|
+
}
|
|
71
|
+
case 'add_camera': {
|
|
72
|
+
const res = await tools.sequenceTools.addCamera({ spawnable: args.spawnable, path: args.path });
|
|
73
|
+
return cleanObject(res);
|
|
74
|
+
}
|
|
75
|
+
case 'add_actor': {
|
|
76
|
+
const actorName = requireNonEmptyString(args.actorName, 'actorName', 'Missing required parameter: actorName');
|
|
77
|
+
const path = typeof args.path === 'string' ? args.path.trim() : '';
|
|
78
|
+
const payload = {
|
|
79
|
+
...args,
|
|
80
|
+
actorName,
|
|
81
|
+
path: path || args.path,
|
|
82
|
+
subAction: 'add_actor'
|
|
83
|
+
};
|
|
84
|
+
|
|
85
|
+
const res = await executeAutomationRequest(tools, 'manage_sequence', payload);
|
|
86
|
+
|
|
87
|
+
const errorCode = String((res && (res as any).error) || '').toUpperCase();
|
|
88
|
+
const msgLower = String((res && (res as any).message) || '').toLowerCase();
|
|
89
|
+
|
|
90
|
+
if (res && (res as any).success === false && path) {
|
|
91
|
+
const isInvalidSequence = errorCode === 'INVALID_SEQUENCE' || msgLower.includes('sequence_add_actor requires a sequence path') || msgLower.includes('sequence not found');
|
|
92
|
+
if (isInvalidSequence) {
|
|
93
|
+
return cleanObject({
|
|
94
|
+
success: false,
|
|
95
|
+
error: 'NOT_FOUND',
|
|
96
|
+
message: (res as any).message || 'Sequence not found',
|
|
97
|
+
action: 'add_actor',
|
|
98
|
+
path,
|
|
99
|
+
actorName
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
const results = res && (res as any).result && Array.isArray((res as any).result.results)
|
|
105
|
+
? (res as any).result.results as any[]
|
|
106
|
+
: undefined;
|
|
107
|
+
if (results && results.length) {
|
|
108
|
+
const failed = results.find((item) => item && item.success === false && typeof item.error === 'string');
|
|
109
|
+
if (failed) {
|
|
110
|
+
const errText = String(failed.error).toLowerCase();
|
|
111
|
+
if (errText.includes('actor not found')) {
|
|
112
|
+
return cleanObject({
|
|
113
|
+
success: false,
|
|
114
|
+
error: 'NOT_FOUND',
|
|
115
|
+
message: failed.error,
|
|
116
|
+
action: 'add_actor',
|
|
117
|
+
path: path || undefined,
|
|
118
|
+
actorName
|
|
119
|
+
});
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
return cleanObject(res);
|
|
125
|
+
}
|
|
126
|
+
case 'add_actors': {
|
|
127
|
+
const actorNames: string[] = Array.isArray(args.actorNames) ? args.actorNames : [];
|
|
128
|
+
const res = await tools.sequenceTools.addActors({ actorNames, path: args.path });
|
|
129
|
+
const errorCode = String((res && (res as any).error) || '').toUpperCase();
|
|
130
|
+
const msgLower = String((res && (res as any).message) || '').toLowerCase();
|
|
131
|
+
if (actorNames.length === 0 && res && (res as any).success === false && errorCode === 'INVALID_ARGUMENT') {
|
|
132
|
+
return cleanObject({
|
|
133
|
+
success: false,
|
|
134
|
+
error: 'INVALID_ARGUMENT',
|
|
135
|
+
message: (res as any).message || 'Invalid argument: actorNames required',
|
|
136
|
+
action: 'add_actors',
|
|
137
|
+
actorNames
|
|
138
|
+
});
|
|
139
|
+
}
|
|
140
|
+
if (res && (res as any).success === false && msgLower.includes('actor not found')) {
|
|
141
|
+
return cleanObject({
|
|
142
|
+
success: false,
|
|
143
|
+
error: 'NOT_FOUND',
|
|
144
|
+
message: (res as any).message || 'Actor not found',
|
|
145
|
+
action: 'add_actors',
|
|
146
|
+
actorNames
|
|
147
|
+
});
|
|
148
|
+
}
|
|
149
|
+
return cleanObject(res);
|
|
150
|
+
}
|
|
151
|
+
case 'remove_actors': {
|
|
152
|
+
const actorNames: string[] = Array.isArray(args.actorNames) ? args.actorNames : [];
|
|
153
|
+
const res = await tools.sequenceTools.removeActors({ actorNames, path: args.path });
|
|
154
|
+
return cleanObject(res);
|
|
155
|
+
}
|
|
156
|
+
case 'get_bindings': {
|
|
157
|
+
const path = typeof args.path === 'string' ? args.path : undefined;
|
|
158
|
+
const res = await tools.sequenceTools.getBindings({ path });
|
|
159
|
+
return cleanObject(res);
|
|
160
|
+
}
|
|
161
|
+
case 'add_keyframe': {
|
|
162
|
+
const path = typeof args.path === 'string' ? args.path.trim() : '';
|
|
163
|
+
const actorName = typeof args.actorName === 'string' ? args.actorName : undefined;
|
|
164
|
+
const property = typeof args.property === 'string' ? args.property : undefined;
|
|
165
|
+
const frame = typeof args.frame === 'number' ? args.frame : Number(args.frame);
|
|
166
|
+
|
|
167
|
+
const payload = {
|
|
168
|
+
...args,
|
|
169
|
+
path: path || args.path,
|
|
170
|
+
actorName,
|
|
171
|
+
property,
|
|
172
|
+
frame,
|
|
173
|
+
subAction: 'add_keyframe'
|
|
174
|
+
};
|
|
175
|
+
|
|
176
|
+
// Fix: Map common property names to internal names
|
|
177
|
+
if (property === 'Location') {
|
|
178
|
+
payload.property = 'Transform';
|
|
179
|
+
payload.value = { location: args.value };
|
|
180
|
+
} else if (property === 'Rotation') {
|
|
181
|
+
payload.property = 'Transform';
|
|
182
|
+
payload.value = { rotation: args.value };
|
|
183
|
+
} else if (property === 'Scale') {
|
|
184
|
+
payload.property = 'Transform';
|
|
185
|
+
payload.value = { scale: args.value };
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
const res = await executeAutomationRequest(tools, 'manage_sequence', payload);
|
|
189
|
+
const errorCode = String((res && (res as any).error) || '').toUpperCase();
|
|
190
|
+
const msgLower = String((res && (res as any).message) || '').toLowerCase();
|
|
191
|
+
|
|
192
|
+
// Keep explicit INVALID_ARGUMENT for missing frame as a real error
|
|
193
|
+
if (errorCode === 'INVALID_ARGUMENT' || msgLower.includes('frame number is required')) {
|
|
194
|
+
return cleanObject(res);
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
if (res && (res as any).success === false) {
|
|
198
|
+
const isBindingIssue = errorCode === 'BINDING_NOT_FOUND' || msgLower.includes('binding not found');
|
|
199
|
+
const isUnsupported = errorCode === 'UNSUPPORTED_PROPERTY' || msgLower.includes('unsupported property') || msgLower.includes('invalid_sequence_type');
|
|
200
|
+
const isInvalidSeq = errorCode === 'INVALID_SEQUENCE' || msgLower.includes('sequence not found') || msgLower.includes('requires a sequence path');
|
|
201
|
+
|
|
202
|
+
if (path && isInvalidSeq) {
|
|
203
|
+
return cleanObject({
|
|
204
|
+
success: false,
|
|
205
|
+
error: 'NOT_FOUND',
|
|
206
|
+
message: (res as any).message || 'Sequence not found',
|
|
207
|
+
action: 'add_keyframe',
|
|
208
|
+
path,
|
|
209
|
+
actorName,
|
|
210
|
+
property,
|
|
211
|
+
frame
|
|
212
|
+
});
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
// Preserve plugin-provided failure for binding / unsupported-property cases
|
|
216
|
+
if (path && (isBindingIssue || isUnsupported)) {
|
|
217
|
+
return cleanObject(res);
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
return cleanObject(res);
|
|
222
|
+
}
|
|
223
|
+
case 'add_spawnable_from_class': {
|
|
224
|
+
const className = requireNonEmptyString(args.className, 'className', 'Missing required parameter: className');
|
|
225
|
+
const res = await tools.sequenceTools.addSpawnableFromClass({ className, path: args.path });
|
|
226
|
+
return cleanObject(res);
|
|
227
|
+
}
|
|
228
|
+
case 'play': {
|
|
229
|
+
const res = await tools.sequenceTools.play({ path: args.path, startTime: args.startTime, loopMode: args.loopMode });
|
|
230
|
+
return cleanObject(res);
|
|
231
|
+
}
|
|
232
|
+
case 'pause': {
|
|
233
|
+
const res = await tools.sequenceTools.pause({ path: args.path });
|
|
234
|
+
return cleanObject(res);
|
|
235
|
+
}
|
|
236
|
+
case 'stop': {
|
|
237
|
+
const res = await tools.sequenceTools.stop({ path: args.path });
|
|
238
|
+
return cleanObject(res);
|
|
239
|
+
}
|
|
240
|
+
case 'set_properties': {
|
|
241
|
+
const res = await tools.sequenceTools.setSequenceProperties({
|
|
242
|
+
path: args.path,
|
|
243
|
+
frameRate: args.frameRate,
|
|
244
|
+
lengthInFrames: args.lengthInFrames,
|
|
245
|
+
playbackStart: args.playbackStart,
|
|
246
|
+
playbackEnd: args.playbackEnd
|
|
247
|
+
});
|
|
248
|
+
return cleanObject(res);
|
|
249
|
+
}
|
|
250
|
+
case 'get_properties': {
|
|
251
|
+
const path = typeof args.path === 'string' ? args.path : undefined;
|
|
252
|
+
const res = await tools.sequenceTools.getSequenceProperties({ path });
|
|
253
|
+
return cleanObject(res);
|
|
254
|
+
}
|
|
255
|
+
case 'set_playback_speed': {
|
|
256
|
+
const speed = Number(args.speed);
|
|
257
|
+
if (!Number.isFinite(speed) || speed <= 0) {
|
|
258
|
+
throw new Error('Invalid speed: must be a positive number');
|
|
259
|
+
}
|
|
260
|
+
// Try setting speed
|
|
261
|
+
let res = await tools.sequenceTools.setPlaybackSpeed({ speed, path: args.path });
|
|
262
|
+
|
|
263
|
+
// Fix: Auto-open if editor not open
|
|
264
|
+
const errorCode = String((res && (res as any).error) || '').toUpperCase();
|
|
265
|
+
if ((!res || res.success === false) && errorCode === 'EDITOR_NOT_OPEN' && args.path) {
|
|
266
|
+
// Attempt to open the sequence
|
|
267
|
+
await tools.sequenceTools.open({ path: args.path });
|
|
268
|
+
|
|
269
|
+
// Wait a short moment for editor to initialize on game thread
|
|
270
|
+
await new Promise(resolve => setTimeout(resolve, 1000));
|
|
271
|
+
|
|
272
|
+
// Retry
|
|
273
|
+
res = await tools.sequenceTools.setPlaybackSpeed({ speed, path: args.path });
|
|
274
|
+
}
|
|
275
|
+
|
|
276
|
+
return cleanObject(res);
|
|
277
|
+
}
|
|
278
|
+
case 'list': {
|
|
279
|
+
const res = await tools.sequenceTools.list({ path: args.path });
|
|
280
|
+
return cleanObject(res);
|
|
281
|
+
}
|
|
282
|
+
case 'duplicate': {
|
|
283
|
+
const path = requireNonEmptyString(args.path, 'path', 'Missing required parameter: path');
|
|
284
|
+
const destDir = requireNonEmptyString(args.destinationPath, 'destinationPath', 'Missing required parameter: destinationPath');
|
|
285
|
+
const newName = requireNonEmptyString(args.newName || path.split('/').pop(), 'newName', 'Missing required parameter: newName');
|
|
286
|
+
const baseDir = destDir.replace(/\/$/, '');
|
|
287
|
+
const destPath = `${baseDir}/${newName}`;
|
|
288
|
+
const res = await tools.sequenceTools.duplicate({ path, destinationPath: destPath });
|
|
289
|
+
return cleanObject(res);
|
|
290
|
+
}
|
|
291
|
+
case 'rename': {
|
|
292
|
+
const path = requireNonEmptyString(args.path, 'path', 'Missing required parameter: path');
|
|
293
|
+
const newName = requireNonEmptyString(args.newName, 'newName', 'Missing required parameter: newName');
|
|
294
|
+
const res = await tools.sequenceTools.rename({ path, newName });
|
|
295
|
+
const errorCode = String((res && (res as any).error) || '').toUpperCase();
|
|
296
|
+
const msgLower = String((res && (res as any).message) || '').toLowerCase();
|
|
297
|
+
if (res && (res as any).success === false && (errorCode === 'OPERATION_FAILED' || msgLower.includes('failed to rename sequence'))) {
|
|
298
|
+
// Return actual failure, not best-effort success - rename is a destructive operation
|
|
299
|
+
return cleanObject({
|
|
300
|
+
success: false,
|
|
301
|
+
error: 'OPERATION_FAILED',
|
|
302
|
+
message: (res as any).message || 'Failed to rename sequence',
|
|
303
|
+
action: 'rename',
|
|
304
|
+
path,
|
|
305
|
+
newName
|
|
306
|
+
});
|
|
307
|
+
}
|
|
308
|
+
return cleanObject(res);
|
|
309
|
+
}
|
|
310
|
+
case 'delete': {
|
|
311
|
+
const path = requireNonEmptyString(args.path, 'path', 'Missing required parameter: path');
|
|
312
|
+
const res = await tools.sequenceTools.deleteSequence({ path });
|
|
313
|
+
|
|
314
|
+
if (res && (res as any).success !== false) {
|
|
315
|
+
markSequenceDeleted(path);
|
|
316
|
+
}
|
|
317
|
+
return cleanObject(res);
|
|
318
|
+
}
|
|
319
|
+
case 'get_metadata': {
|
|
320
|
+
const res = await tools.sequenceTools.getMetadata({ path: args.path });
|
|
321
|
+
return cleanObject(res);
|
|
322
|
+
}
|
|
323
|
+
case 'set_metadata': {
|
|
324
|
+
const path = requireNonEmptyString(args.path, 'path', 'Missing required parameter: path');
|
|
325
|
+
const metadata = (args.metadata && typeof args.metadata === 'object') ? args.metadata : {};
|
|
326
|
+
const res = await executeAutomationRequest(tools, 'set_metadata', { assetPath: path, metadata });
|
|
327
|
+
return cleanObject(res);
|
|
328
|
+
}
|
|
329
|
+
case 'add_track': {
|
|
330
|
+
// Forward add_track to the C++ plugin - it requires MovieScene API
|
|
331
|
+
const path = typeof args.path === 'string' ? args.path.trim() : '';
|
|
332
|
+
const trackType = typeof args.trackType === 'string' ? args.trackType : '';
|
|
333
|
+
const trackName = typeof args.trackName === 'string' ? args.trackName : '';
|
|
334
|
+
const actorName = typeof args.actorName === 'string' ? args.actorName : undefined;
|
|
335
|
+
|
|
336
|
+
// Fix: Check if actor is bound before adding track
|
|
337
|
+
if (actorName) {
|
|
338
|
+
const bindingsRes = await tools.sequenceTools.getBindings({ path });
|
|
339
|
+
if (bindingsRes && bindingsRes.success) {
|
|
340
|
+
const bindings = bindingsRes.bindings || [];
|
|
341
|
+
const isBound = bindings.some((b: any) => b.name === actorName);
|
|
342
|
+
if (!isBound) {
|
|
343
|
+
return cleanObject({
|
|
344
|
+
success: false,
|
|
345
|
+
error: 'BINDING_NOT_FOUND',
|
|
346
|
+
message: `Actor '${actorName}' is not bound to this sequence. Please call 'add_actor' first.`,
|
|
347
|
+
action: 'add_track',
|
|
348
|
+
path,
|
|
349
|
+
actorName
|
|
350
|
+
});
|
|
351
|
+
}
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
|
|
355
|
+
const payload = {
|
|
356
|
+
...args,
|
|
357
|
+
path: path || args.path,
|
|
358
|
+
trackType,
|
|
359
|
+
trackName,
|
|
360
|
+
actorName,
|
|
361
|
+
subAction: 'add_track'
|
|
362
|
+
};
|
|
363
|
+
|
|
364
|
+
const res = await executeAutomationRequest(tools, 'manage_sequence', payload);
|
|
365
|
+
return cleanObject(res);
|
|
366
|
+
}
|
|
367
|
+
case 'add_section': {
|
|
368
|
+
// Forward add_section to C++
|
|
369
|
+
const payload = { ...args, subAction: 'add_section' };
|
|
370
|
+
return cleanObject(await executeAutomationRequest(tools, 'manage_sequence', payload));
|
|
371
|
+
}
|
|
372
|
+
case 'remove_track': {
|
|
373
|
+
// Forward remove_track to C++
|
|
374
|
+
const payload = { ...args, subAction: 'remove_track' };
|
|
375
|
+
return cleanObject(await executeAutomationRequest(tools, 'manage_sequence', payload));
|
|
376
|
+
}
|
|
377
|
+
case 'set_track_muted': {
|
|
378
|
+
const payload = { ...args, subAction: 'set_track_muted' };
|
|
379
|
+
return cleanObject(await executeAutomationRequest(tools, 'manage_sequence', payload));
|
|
380
|
+
}
|
|
381
|
+
case 'set_track_solo': {
|
|
382
|
+
const payload = { ...args, subAction: 'set_track_solo' };
|
|
383
|
+
return cleanObject(await executeAutomationRequest(tools, 'manage_sequence', payload));
|
|
384
|
+
}
|
|
385
|
+
case 'set_track_locked': {
|
|
386
|
+
const payload = { ...args, subAction: 'set_track_locked' };
|
|
387
|
+
return cleanObject(await executeAutomationRequest(tools, 'manage_sequence', payload));
|
|
388
|
+
}
|
|
389
|
+
case 'list_tracks': {
|
|
390
|
+
const path = requireNonEmptyString(args.path, 'path', 'Missing required parameter: path');
|
|
391
|
+
const res = await tools.sequenceTools.listTracks({ path });
|
|
392
|
+
return cleanObject(res);
|
|
393
|
+
}
|
|
394
|
+
case 'set_work_range': {
|
|
395
|
+
const start = Number(args.start);
|
|
396
|
+
const end = Number(args.end);
|
|
397
|
+
// Validate start/end are numbers
|
|
398
|
+
if (!Number.isFinite(start)) throw new Error('Invalid start: must be a number');
|
|
399
|
+
if (!Number.isFinite(end)) throw new Error('Invalid end: must be a number');
|
|
400
|
+
|
|
401
|
+
const res = await tools.sequenceTools.setWorkRange({
|
|
402
|
+
path: args.path,
|
|
403
|
+
start,
|
|
404
|
+
end
|
|
405
|
+
});
|
|
406
|
+
return cleanObject(res);
|
|
407
|
+
}
|
|
408
|
+
default:
|
|
409
|
+
// Ensure subAction is set for compatibility with C++ handler expectations
|
|
410
|
+
if (args.action && !args.subAction) {
|
|
411
|
+
args.subAction = args.action;
|
|
412
|
+
}
|
|
413
|
+
return await executeAutomationRequest(tools, 'manage_sequence', args);
|
|
414
|
+
}
|
|
415
|
+
}
|