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