unreal-engine-mcp-server 0.4.7 → 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 +267 -31
- package/CONTRIBUTING.md +140 -0
- package/README.md +166 -71
- 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 -619
- 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 +5462 -1781
- package/dist/tools/consolidated-tool-definitions.js +829 -496
- package/dist/tools/consolidated-tool-handlers.d.ts +2 -1
- package/dist/tools/consolidated-tool-handlers.js +211 -1026
- 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 +3 -3
- package/dist/tools/logs.js +5 -57
- 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 +183 -19
- 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 -663
- 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 -515
- package/src/tools/consolidated-tool-handlers.ts +272 -1139
- 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 +9 -57
- 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 +243 -21
- 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 -574
- 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,376 @@
|
|
|
1
|
+
import { cleanObject } from '../../utils/safe-json.js';
|
|
2
|
+
import { executeAutomationRequest, requireNonEmptyString } from './common-handlers.js';
|
|
3
|
+
const managedSequences = new Set();
|
|
4
|
+
const deletedSequences = new Set();
|
|
5
|
+
function normalizeSequencePath(path) {
|
|
6
|
+
if (typeof path !== 'string')
|
|
7
|
+
return undefined;
|
|
8
|
+
const trimmed = path.trim();
|
|
9
|
+
return trimmed.length > 0 ? trimmed : undefined;
|
|
10
|
+
}
|
|
11
|
+
function markSequenceCreated(path) {
|
|
12
|
+
const norm = normalizeSequencePath(path);
|
|
13
|
+
if (!norm)
|
|
14
|
+
return;
|
|
15
|
+
deletedSequences.delete(norm);
|
|
16
|
+
managedSequences.add(norm);
|
|
17
|
+
}
|
|
18
|
+
function markSequenceDeleted(path) {
|
|
19
|
+
const norm = normalizeSequencePath(path);
|
|
20
|
+
if (!norm)
|
|
21
|
+
return;
|
|
22
|
+
managedSequences.delete(norm);
|
|
23
|
+
deletedSequences.add(norm);
|
|
24
|
+
}
|
|
25
|
+
export async function handleSequenceTools(action, args, tools) {
|
|
26
|
+
const seqAction = String(action || '').trim();
|
|
27
|
+
switch (seqAction) {
|
|
28
|
+
case 'create': {
|
|
29
|
+
const name = requireNonEmptyString(args.name, 'name', 'Missing required parameter: name');
|
|
30
|
+
const res = await tools.sequenceTools.create({ name, path: args.path });
|
|
31
|
+
let sequencePath;
|
|
32
|
+
if (res && res.result && typeof res.result.sequencePath === 'string') {
|
|
33
|
+
sequencePath = res.result.sequencePath;
|
|
34
|
+
}
|
|
35
|
+
else if (typeof args.path === 'string' && args.path.trim().length > 0) {
|
|
36
|
+
const basePath = args.path.trim().replace(/\/$/, '');
|
|
37
|
+
sequencePath = `${basePath}/${name}`;
|
|
38
|
+
}
|
|
39
|
+
if (sequencePath && res && res.success !== false) {
|
|
40
|
+
markSequenceCreated(sequencePath);
|
|
41
|
+
}
|
|
42
|
+
const errorCode = String((res && res.error) || '').toUpperCase();
|
|
43
|
+
const msgLower = String((res && res.message) || '').toLowerCase();
|
|
44
|
+
if (res && res.success === false && (errorCode === 'FACTORY_NOT_AVAILABLE' || msgLower.includes('ulevelsequencefactorynew not available'))) {
|
|
45
|
+
const path = sequencePath || (typeof args.path === 'string' ? args.path : undefined);
|
|
46
|
+
return cleanObject({
|
|
47
|
+
success: false,
|
|
48
|
+
error: 'FACTORY_NOT_AVAILABLE',
|
|
49
|
+
message: res.message || 'Sequence creation failed: factory not available',
|
|
50
|
+
action: 'create',
|
|
51
|
+
name,
|
|
52
|
+
path,
|
|
53
|
+
sequencePath,
|
|
54
|
+
handled: true
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
return cleanObject(res);
|
|
58
|
+
}
|
|
59
|
+
case 'open': {
|
|
60
|
+
const path = requireNonEmptyString(args.path, 'path', 'Missing required parameter: path');
|
|
61
|
+
const res = await tools.sequenceTools.open({ path });
|
|
62
|
+
return cleanObject(res);
|
|
63
|
+
}
|
|
64
|
+
case 'add_camera': {
|
|
65
|
+
const res = await tools.sequenceTools.addCamera({ spawnable: args.spawnable, path: args.path });
|
|
66
|
+
return cleanObject(res);
|
|
67
|
+
}
|
|
68
|
+
case 'add_actor': {
|
|
69
|
+
const actorName = requireNonEmptyString(args.actorName, 'actorName', 'Missing required parameter: actorName');
|
|
70
|
+
const path = typeof args.path === 'string' ? args.path.trim() : '';
|
|
71
|
+
const payload = {
|
|
72
|
+
...args,
|
|
73
|
+
actorName,
|
|
74
|
+
path: path || args.path,
|
|
75
|
+
subAction: 'add_actor'
|
|
76
|
+
};
|
|
77
|
+
const res = await executeAutomationRequest(tools, 'manage_sequence', payload);
|
|
78
|
+
const errorCode = String((res && res.error) || '').toUpperCase();
|
|
79
|
+
const msgLower = String((res && res.message) || '').toLowerCase();
|
|
80
|
+
if (res && res.success === false && path) {
|
|
81
|
+
const isInvalidSequence = errorCode === 'INVALID_SEQUENCE' || msgLower.includes('sequence_add_actor requires a sequence path') || msgLower.includes('sequence not found');
|
|
82
|
+
if (isInvalidSequence) {
|
|
83
|
+
return cleanObject({
|
|
84
|
+
success: false,
|
|
85
|
+
error: 'NOT_FOUND',
|
|
86
|
+
message: res.message || 'Sequence not found',
|
|
87
|
+
action: 'add_actor',
|
|
88
|
+
path,
|
|
89
|
+
actorName
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
const results = res && res.result && Array.isArray(res.result.results)
|
|
94
|
+
? res.result.results
|
|
95
|
+
: undefined;
|
|
96
|
+
if (results && results.length) {
|
|
97
|
+
const failed = results.find((item) => item && item.success === false && typeof item.error === 'string');
|
|
98
|
+
if (failed) {
|
|
99
|
+
const errText = String(failed.error).toLowerCase();
|
|
100
|
+
if (errText.includes('actor not found')) {
|
|
101
|
+
return cleanObject({
|
|
102
|
+
success: false,
|
|
103
|
+
error: 'NOT_FOUND',
|
|
104
|
+
message: failed.error,
|
|
105
|
+
action: 'add_actor',
|
|
106
|
+
path: path || undefined,
|
|
107
|
+
actorName
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
return cleanObject(res);
|
|
113
|
+
}
|
|
114
|
+
case 'add_actors': {
|
|
115
|
+
const actorNames = Array.isArray(args.actorNames) ? args.actorNames : [];
|
|
116
|
+
const res = await tools.sequenceTools.addActors({ actorNames, path: args.path });
|
|
117
|
+
const errorCode = String((res && res.error) || '').toUpperCase();
|
|
118
|
+
const msgLower = String((res && res.message) || '').toLowerCase();
|
|
119
|
+
if (actorNames.length === 0 && res && res.success === false && errorCode === 'INVALID_ARGUMENT') {
|
|
120
|
+
return cleanObject({
|
|
121
|
+
success: false,
|
|
122
|
+
error: 'INVALID_ARGUMENT',
|
|
123
|
+
message: res.message || 'Invalid argument: actorNames required',
|
|
124
|
+
action: 'add_actors',
|
|
125
|
+
actorNames
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
if (res && res.success === false && msgLower.includes('actor not found')) {
|
|
129
|
+
return cleanObject({
|
|
130
|
+
success: false,
|
|
131
|
+
error: 'NOT_FOUND',
|
|
132
|
+
message: res.message || 'Actor not found',
|
|
133
|
+
action: 'add_actors',
|
|
134
|
+
actorNames
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
return cleanObject(res);
|
|
138
|
+
}
|
|
139
|
+
case 'remove_actors': {
|
|
140
|
+
const actorNames = Array.isArray(args.actorNames) ? args.actorNames : [];
|
|
141
|
+
const res = await tools.sequenceTools.removeActors({ actorNames, path: args.path });
|
|
142
|
+
return cleanObject(res);
|
|
143
|
+
}
|
|
144
|
+
case 'get_bindings': {
|
|
145
|
+
const path = typeof args.path === 'string' ? args.path : undefined;
|
|
146
|
+
const res = await tools.sequenceTools.getBindings({ path });
|
|
147
|
+
return cleanObject(res);
|
|
148
|
+
}
|
|
149
|
+
case 'add_keyframe': {
|
|
150
|
+
const path = typeof args.path === 'string' ? args.path.trim() : '';
|
|
151
|
+
const actorName = typeof args.actorName === 'string' ? args.actorName : undefined;
|
|
152
|
+
const property = typeof args.property === 'string' ? args.property : undefined;
|
|
153
|
+
const frame = typeof args.frame === 'number' ? args.frame : Number(args.frame);
|
|
154
|
+
const payload = {
|
|
155
|
+
...args,
|
|
156
|
+
path: path || args.path,
|
|
157
|
+
actorName,
|
|
158
|
+
property,
|
|
159
|
+
frame,
|
|
160
|
+
subAction: 'add_keyframe'
|
|
161
|
+
};
|
|
162
|
+
if (property === 'Location') {
|
|
163
|
+
payload.property = 'Transform';
|
|
164
|
+
payload.value = { location: args.value };
|
|
165
|
+
}
|
|
166
|
+
else if (property === 'Rotation') {
|
|
167
|
+
payload.property = 'Transform';
|
|
168
|
+
payload.value = { rotation: args.value };
|
|
169
|
+
}
|
|
170
|
+
else if (property === 'Scale') {
|
|
171
|
+
payload.property = 'Transform';
|
|
172
|
+
payload.value = { scale: args.value };
|
|
173
|
+
}
|
|
174
|
+
const res = await executeAutomationRequest(tools, 'manage_sequence', payload);
|
|
175
|
+
const errorCode = String((res && res.error) || '').toUpperCase();
|
|
176
|
+
const msgLower = String((res && res.message) || '').toLowerCase();
|
|
177
|
+
if (errorCode === 'INVALID_ARGUMENT' || msgLower.includes('frame number is required')) {
|
|
178
|
+
return cleanObject(res);
|
|
179
|
+
}
|
|
180
|
+
if (res && res.success === false) {
|
|
181
|
+
const isBindingIssue = errorCode === 'BINDING_NOT_FOUND' || msgLower.includes('binding not found');
|
|
182
|
+
const isUnsupported = errorCode === 'UNSUPPORTED_PROPERTY' || msgLower.includes('unsupported property') || msgLower.includes('invalid_sequence_type');
|
|
183
|
+
const isInvalidSeq = errorCode === 'INVALID_SEQUENCE' || msgLower.includes('sequence not found') || msgLower.includes('requires a sequence path');
|
|
184
|
+
if (path && isInvalidSeq) {
|
|
185
|
+
return cleanObject({
|
|
186
|
+
success: false,
|
|
187
|
+
error: 'NOT_FOUND',
|
|
188
|
+
message: res.message || 'Sequence not found',
|
|
189
|
+
action: 'add_keyframe',
|
|
190
|
+
path,
|
|
191
|
+
actorName,
|
|
192
|
+
property,
|
|
193
|
+
frame
|
|
194
|
+
});
|
|
195
|
+
}
|
|
196
|
+
if (path && (isBindingIssue || isUnsupported)) {
|
|
197
|
+
return cleanObject(res);
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
return cleanObject(res);
|
|
201
|
+
}
|
|
202
|
+
case 'add_spawnable_from_class': {
|
|
203
|
+
const className = requireNonEmptyString(args.className, 'className', 'Missing required parameter: className');
|
|
204
|
+
const res = await tools.sequenceTools.addSpawnableFromClass({ className, path: args.path });
|
|
205
|
+
return cleanObject(res);
|
|
206
|
+
}
|
|
207
|
+
case 'play': {
|
|
208
|
+
const res = await tools.sequenceTools.play({ path: args.path, startTime: args.startTime, loopMode: args.loopMode });
|
|
209
|
+
return cleanObject(res);
|
|
210
|
+
}
|
|
211
|
+
case 'pause': {
|
|
212
|
+
const res = await tools.sequenceTools.pause({ path: args.path });
|
|
213
|
+
return cleanObject(res);
|
|
214
|
+
}
|
|
215
|
+
case 'stop': {
|
|
216
|
+
const res = await tools.sequenceTools.stop({ path: args.path });
|
|
217
|
+
return cleanObject(res);
|
|
218
|
+
}
|
|
219
|
+
case 'set_properties': {
|
|
220
|
+
const res = await tools.sequenceTools.setSequenceProperties({
|
|
221
|
+
path: args.path,
|
|
222
|
+
frameRate: args.frameRate,
|
|
223
|
+
lengthInFrames: args.lengthInFrames,
|
|
224
|
+
playbackStart: args.playbackStart,
|
|
225
|
+
playbackEnd: args.playbackEnd
|
|
226
|
+
});
|
|
227
|
+
return cleanObject(res);
|
|
228
|
+
}
|
|
229
|
+
case 'get_properties': {
|
|
230
|
+
const path = typeof args.path === 'string' ? args.path : undefined;
|
|
231
|
+
const res = await tools.sequenceTools.getSequenceProperties({ path });
|
|
232
|
+
return cleanObject(res);
|
|
233
|
+
}
|
|
234
|
+
case 'set_playback_speed': {
|
|
235
|
+
const speed = Number(args.speed);
|
|
236
|
+
if (!Number.isFinite(speed) || speed <= 0) {
|
|
237
|
+
throw new Error('Invalid speed: must be a positive number');
|
|
238
|
+
}
|
|
239
|
+
let res = await tools.sequenceTools.setPlaybackSpeed({ speed, path: args.path });
|
|
240
|
+
const errorCode = String((res && res.error) || '').toUpperCase();
|
|
241
|
+
if ((!res || res.success === false) && errorCode === 'EDITOR_NOT_OPEN' && args.path) {
|
|
242
|
+
await tools.sequenceTools.open({ path: args.path });
|
|
243
|
+
await new Promise(resolve => setTimeout(resolve, 1000));
|
|
244
|
+
res = await tools.sequenceTools.setPlaybackSpeed({ speed, path: args.path });
|
|
245
|
+
}
|
|
246
|
+
return cleanObject(res);
|
|
247
|
+
}
|
|
248
|
+
case 'list': {
|
|
249
|
+
const res = await tools.sequenceTools.list({ path: args.path });
|
|
250
|
+
return cleanObject(res);
|
|
251
|
+
}
|
|
252
|
+
case 'duplicate': {
|
|
253
|
+
const path = requireNonEmptyString(args.path, 'path', 'Missing required parameter: path');
|
|
254
|
+
const destDir = requireNonEmptyString(args.destinationPath, 'destinationPath', 'Missing required parameter: destinationPath');
|
|
255
|
+
const newName = requireNonEmptyString(args.newName || path.split('/').pop(), 'newName', 'Missing required parameter: newName');
|
|
256
|
+
const baseDir = destDir.replace(/\/$/, '');
|
|
257
|
+
const destPath = `${baseDir}/${newName}`;
|
|
258
|
+
const res = await tools.sequenceTools.duplicate({ path, destinationPath: destPath });
|
|
259
|
+
return cleanObject(res);
|
|
260
|
+
}
|
|
261
|
+
case 'rename': {
|
|
262
|
+
const path = requireNonEmptyString(args.path, 'path', 'Missing required parameter: path');
|
|
263
|
+
const newName = requireNonEmptyString(args.newName, 'newName', 'Missing required parameter: newName');
|
|
264
|
+
const res = await tools.sequenceTools.rename({ path, newName });
|
|
265
|
+
const errorCode = String((res && res.error) || '').toUpperCase();
|
|
266
|
+
const msgLower = String((res && res.message) || '').toLowerCase();
|
|
267
|
+
if (res && res.success === false && (errorCode === 'OPERATION_FAILED' || msgLower.includes('failed to rename sequence'))) {
|
|
268
|
+
return cleanObject({
|
|
269
|
+
success: false,
|
|
270
|
+
error: 'OPERATION_FAILED',
|
|
271
|
+
message: res.message || 'Failed to rename sequence',
|
|
272
|
+
action: 'rename',
|
|
273
|
+
path,
|
|
274
|
+
newName
|
|
275
|
+
});
|
|
276
|
+
}
|
|
277
|
+
return cleanObject(res);
|
|
278
|
+
}
|
|
279
|
+
case 'delete': {
|
|
280
|
+
const path = requireNonEmptyString(args.path, 'path', 'Missing required parameter: path');
|
|
281
|
+
const res = await tools.sequenceTools.deleteSequence({ path });
|
|
282
|
+
if (res && res.success !== false) {
|
|
283
|
+
markSequenceDeleted(path);
|
|
284
|
+
}
|
|
285
|
+
return cleanObject(res);
|
|
286
|
+
}
|
|
287
|
+
case 'get_metadata': {
|
|
288
|
+
const res = await tools.sequenceTools.getMetadata({ path: args.path });
|
|
289
|
+
return cleanObject(res);
|
|
290
|
+
}
|
|
291
|
+
case 'set_metadata': {
|
|
292
|
+
const path = requireNonEmptyString(args.path, 'path', 'Missing required parameter: path');
|
|
293
|
+
const metadata = (args.metadata && typeof args.metadata === 'object') ? args.metadata : {};
|
|
294
|
+
const res = await executeAutomationRequest(tools, 'set_metadata', { assetPath: path, metadata });
|
|
295
|
+
return cleanObject(res);
|
|
296
|
+
}
|
|
297
|
+
case 'add_track': {
|
|
298
|
+
const path = typeof args.path === 'string' ? args.path.trim() : '';
|
|
299
|
+
const trackType = typeof args.trackType === 'string' ? args.trackType : '';
|
|
300
|
+
const trackName = typeof args.trackName === 'string' ? args.trackName : '';
|
|
301
|
+
const actorName = typeof args.actorName === 'string' ? args.actorName : undefined;
|
|
302
|
+
if (actorName) {
|
|
303
|
+
const bindingsRes = await tools.sequenceTools.getBindings({ path });
|
|
304
|
+
if (bindingsRes && bindingsRes.success) {
|
|
305
|
+
const bindings = bindingsRes.bindings || [];
|
|
306
|
+
const isBound = bindings.some((b) => b.name === actorName);
|
|
307
|
+
if (!isBound) {
|
|
308
|
+
return cleanObject({
|
|
309
|
+
success: false,
|
|
310
|
+
error: 'BINDING_NOT_FOUND',
|
|
311
|
+
message: `Actor '${actorName}' is not bound to this sequence. Please call 'add_actor' first.`,
|
|
312
|
+
action: 'add_track',
|
|
313
|
+
path,
|
|
314
|
+
actorName
|
|
315
|
+
});
|
|
316
|
+
}
|
|
317
|
+
}
|
|
318
|
+
}
|
|
319
|
+
const payload = {
|
|
320
|
+
...args,
|
|
321
|
+
path: path || args.path,
|
|
322
|
+
trackType,
|
|
323
|
+
trackName,
|
|
324
|
+
actorName,
|
|
325
|
+
subAction: 'add_track'
|
|
326
|
+
};
|
|
327
|
+
const res = await executeAutomationRequest(tools, 'manage_sequence', payload);
|
|
328
|
+
return cleanObject(res);
|
|
329
|
+
}
|
|
330
|
+
case 'add_section': {
|
|
331
|
+
const payload = { ...args, subAction: 'add_section' };
|
|
332
|
+
return cleanObject(await executeAutomationRequest(tools, 'manage_sequence', payload));
|
|
333
|
+
}
|
|
334
|
+
case 'remove_track': {
|
|
335
|
+
const payload = { ...args, subAction: 'remove_track' };
|
|
336
|
+
return cleanObject(await executeAutomationRequest(tools, 'manage_sequence', payload));
|
|
337
|
+
}
|
|
338
|
+
case 'set_track_muted': {
|
|
339
|
+
const payload = { ...args, subAction: 'set_track_muted' };
|
|
340
|
+
return cleanObject(await executeAutomationRequest(tools, 'manage_sequence', payload));
|
|
341
|
+
}
|
|
342
|
+
case 'set_track_solo': {
|
|
343
|
+
const payload = { ...args, subAction: 'set_track_solo' };
|
|
344
|
+
return cleanObject(await executeAutomationRequest(tools, 'manage_sequence', payload));
|
|
345
|
+
}
|
|
346
|
+
case 'set_track_locked': {
|
|
347
|
+
const payload = { ...args, subAction: 'set_track_locked' };
|
|
348
|
+
return cleanObject(await executeAutomationRequest(tools, 'manage_sequence', payload));
|
|
349
|
+
}
|
|
350
|
+
case 'list_tracks': {
|
|
351
|
+
const path = requireNonEmptyString(args.path, 'path', 'Missing required parameter: path');
|
|
352
|
+
const res = await tools.sequenceTools.listTracks({ path });
|
|
353
|
+
return cleanObject(res);
|
|
354
|
+
}
|
|
355
|
+
case 'set_work_range': {
|
|
356
|
+
const start = Number(args.start);
|
|
357
|
+
const end = Number(args.end);
|
|
358
|
+
if (!Number.isFinite(start))
|
|
359
|
+
throw new Error('Invalid start: must be a number');
|
|
360
|
+
if (!Number.isFinite(end))
|
|
361
|
+
throw new Error('Invalid end: must be a number');
|
|
362
|
+
const res = await tools.sequenceTools.setWorkRange({
|
|
363
|
+
path: args.path,
|
|
364
|
+
start,
|
|
365
|
+
end
|
|
366
|
+
});
|
|
367
|
+
return cleanObject(res);
|
|
368
|
+
}
|
|
369
|
+
default:
|
|
370
|
+
if (args.action && !args.subAction) {
|
|
371
|
+
args.subAction = args.action;
|
|
372
|
+
}
|
|
373
|
+
return await executeAutomationRequest(tools, 'manage_sequence', args);
|
|
374
|
+
}
|
|
375
|
+
}
|
|
376
|
+
//# sourceMappingURL=sequence-handlers.js.map
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { ITools } from '../../types/tool-interfaces.js';
|
|
2
|
+
export declare function handleSystemTools(action: string, args: any, tools: ITools): Promise<any>;
|
|
3
|
+
export declare function handleConsoleCommand(args: any, tools: ITools): Promise<any>;
|
|
4
|
+
//# sourceMappingURL=system-handlers.d.ts.map
|