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,194 +0,0 @@
|
|
|
1
|
-
import { ITools } from '../../types/tool-interfaces.js';
|
|
2
|
-
import { cleanObject } from '../../utils/safe-json.js';
|
|
3
|
-
import { requireNonEmptyString } from './common-handlers.js';
|
|
4
|
-
|
|
5
|
-
function toVec3Array(v: any): [number, number, number] | undefined {
|
|
6
|
-
if (!v || typeof v !== 'object') return undefined;
|
|
7
|
-
const x = Number(v.x);
|
|
8
|
-
const y = Number(v.y);
|
|
9
|
-
const z = Number(v.z);
|
|
10
|
-
if (!Number.isFinite(x) || !Number.isFinite(y) || !Number.isFinite(z)) return undefined;
|
|
11
|
-
return [x, y, z];
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
function toRotArray(r: any): [number, number, number] | undefined {
|
|
15
|
-
if (!r || typeof r !== 'object') return undefined;
|
|
16
|
-
const pitch = Number(r.pitch);
|
|
17
|
-
const yaw = Number(r.yaw);
|
|
18
|
-
const roll = Number(r.roll);
|
|
19
|
-
if (!Number.isFinite(pitch) || !Number.isFinite(yaw) || !Number.isFinite(roll)) return undefined;
|
|
20
|
-
return [pitch, yaw, roll];
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
function getTimeoutMs(): number {
|
|
24
|
-
const envDefault = Number(process.env.MCP_AUTOMATION_REQUEST_TIMEOUT_MS ?? '120000');
|
|
25
|
-
return Number.isFinite(envDefault) && envDefault > 0 ? envDefault : 120000;
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
export async function handleAudioTools(
|
|
29
|
-
action: string,
|
|
30
|
-
args: any,
|
|
31
|
-
tools: ITools
|
|
32
|
-
) {
|
|
33
|
-
switch (action) {
|
|
34
|
-
case 'create_sound_cue':
|
|
35
|
-
requireNonEmptyString(args?.name, 'name', 'Missing required parameter: name');
|
|
36
|
-
requireNonEmptyString(args?.wavePath ?? args?.soundPath, 'soundPath', 'Missing required parameter: soundPath (or wavePath)');
|
|
37
|
-
return cleanObject(await tools.audioTools.createSoundCue({
|
|
38
|
-
name: args.name,
|
|
39
|
-
// MCP schema uses soundPath; AudioTools uses wavePath.
|
|
40
|
-
wavePath: args.wavePath ?? args.soundPath,
|
|
41
|
-
savePath: args.savePath,
|
|
42
|
-
settings: args.settings
|
|
43
|
-
}));
|
|
44
|
-
|
|
45
|
-
case 'play_sound_at_location':
|
|
46
|
-
requireNonEmptyString(args?.soundPath, 'soundPath', 'Missing required parameter: soundPath');
|
|
47
|
-
return cleanObject(await tools.audioTools.playSoundAtLocation({
|
|
48
|
-
soundPath: args.soundPath,
|
|
49
|
-
location: toVec3Array(args.location) ?? [0, 0, 0],
|
|
50
|
-
rotation: toRotArray(args.rotation),
|
|
51
|
-
volume: args.volume,
|
|
52
|
-
pitch: args.pitch,
|
|
53
|
-
startTime: args.startTime,
|
|
54
|
-
attenuationPath: args.attenuationPath,
|
|
55
|
-
concurrencyPath: args.concurrencyPath
|
|
56
|
-
}));
|
|
57
|
-
|
|
58
|
-
case 'play_sound_2d':
|
|
59
|
-
requireNonEmptyString(args?.soundPath, 'soundPath', 'Missing required parameter: soundPath');
|
|
60
|
-
return cleanObject(await tools.audioTools.playSound2D({
|
|
61
|
-
soundPath: args.soundPath,
|
|
62
|
-
volume: args.volume,
|
|
63
|
-
pitch: args.pitch,
|
|
64
|
-
startTime: args.startTime
|
|
65
|
-
}));
|
|
66
|
-
|
|
67
|
-
case 'create_audio_component':
|
|
68
|
-
requireNonEmptyString(args?.actorName, 'actorName', 'Missing required parameter: actorName');
|
|
69
|
-
requireNonEmptyString(args?.componentName, 'componentName', 'Missing required parameter: componentName');
|
|
70
|
-
requireNonEmptyString(args?.soundPath, 'soundPath', 'Missing required parameter: soundPath');
|
|
71
|
-
return cleanObject(await tools.audioTools.createAudioComponent({
|
|
72
|
-
actorName: args.actorName,
|
|
73
|
-
componentName: args.componentName,
|
|
74
|
-
soundPath: args.soundPath,
|
|
75
|
-
autoPlay: args.autoPlay,
|
|
76
|
-
is3D: args.is3D
|
|
77
|
-
}));
|
|
78
|
-
|
|
79
|
-
case 'set_sound_attenuation':
|
|
80
|
-
requireNonEmptyString(args?.name, 'name', 'Missing required parameter: name');
|
|
81
|
-
return cleanObject(await tools.audioTools.setSoundAttenuation({
|
|
82
|
-
name: args.name,
|
|
83
|
-
innerRadius: args.innerRadius,
|
|
84
|
-
falloffDistance: args.falloffDistance,
|
|
85
|
-
attenuationShape: args.attenuationShape,
|
|
86
|
-
falloffMode: args.falloffMode
|
|
87
|
-
}));
|
|
88
|
-
|
|
89
|
-
case 'create_sound_class':
|
|
90
|
-
requireNonEmptyString(args?.name, 'name', 'Missing required parameter: name');
|
|
91
|
-
return cleanObject(await tools.audioTools.createSoundClass({
|
|
92
|
-
name: args.name,
|
|
93
|
-
parentClass: args.parentClass,
|
|
94
|
-
properties: args.properties
|
|
95
|
-
}));
|
|
96
|
-
|
|
97
|
-
case 'create_sound_mix':
|
|
98
|
-
requireNonEmptyString(args?.name, 'name', 'Missing required parameter: name');
|
|
99
|
-
return cleanObject(await tools.audioTools.createSoundMix({
|
|
100
|
-
name: args.name,
|
|
101
|
-
classAdjusters: args.classAdjusters
|
|
102
|
-
}));
|
|
103
|
-
|
|
104
|
-
case 'push_sound_mix':
|
|
105
|
-
requireNonEmptyString(args?.mixName ?? args?.name, 'mixName', 'Missing required parameter: mixName (or name)');
|
|
106
|
-
return cleanObject(await tools.audioTools.pushSoundMix({
|
|
107
|
-
mixName: args.mixName ?? args.name
|
|
108
|
-
}));
|
|
109
|
-
|
|
110
|
-
case 'pop_sound_mix':
|
|
111
|
-
requireNonEmptyString(args?.mixName ?? args?.name, 'mixName', 'Missing required parameter: mixName (or name)');
|
|
112
|
-
return cleanObject(await tools.audioTools.popSoundMix({
|
|
113
|
-
mixName: args.mixName ?? args.name
|
|
114
|
-
}));
|
|
115
|
-
|
|
116
|
-
case 'create_ambient_sound':
|
|
117
|
-
requireNonEmptyString(args?.soundPath, 'soundPath', 'Missing required parameter: soundPath');
|
|
118
|
-
return cleanObject(await tools.audioTools.createAmbientSound({
|
|
119
|
-
soundPath: args.soundPath,
|
|
120
|
-
location: toVec3Array(args.location) ?? [0, 0, 0],
|
|
121
|
-
volume: args.volume,
|
|
122
|
-
pitch: args.pitch,
|
|
123
|
-
startTime: args.startTime,
|
|
124
|
-
attenuationPath: args.attenuationPath,
|
|
125
|
-
concurrencyPath: args.concurrencyPath
|
|
126
|
-
}));
|
|
127
|
-
|
|
128
|
-
case 'create_reverb_zone':
|
|
129
|
-
requireNonEmptyString(args?.name, 'name', 'Missing required parameter: name');
|
|
130
|
-
return cleanObject(await tools.audioTools.createReverbZone({
|
|
131
|
-
name: args.name,
|
|
132
|
-
location: toVec3Array(args.location) ?? [0, 0, 0],
|
|
133
|
-
size: toVec3Array(args.size) ?? [0, 0, 0],
|
|
134
|
-
reverbEffect: args.reverbEffect,
|
|
135
|
-
volume: args.volume,
|
|
136
|
-
fadeTime: args.fadeTime
|
|
137
|
-
}));
|
|
138
|
-
|
|
139
|
-
case 'enable_audio_analysis':
|
|
140
|
-
return cleanObject(await tools.audioTools.enableAudioAnalysis({
|
|
141
|
-
enabled: args.enabled,
|
|
142
|
-
fftSize: args.fftSize,
|
|
143
|
-
outputType: args.outputType
|
|
144
|
-
}));
|
|
145
|
-
|
|
146
|
-
case 'fade_sound':
|
|
147
|
-
requireNonEmptyString(args?.soundName, 'soundName', 'Missing required parameter: soundName');
|
|
148
|
-
return cleanObject(await tools.audioTools.fadeSound({
|
|
149
|
-
soundName: args.soundName,
|
|
150
|
-
targetVolume: args.targetVolume,
|
|
151
|
-
fadeTime: args.fadeTime,
|
|
152
|
-
fadeType: args.fadeType
|
|
153
|
-
}));
|
|
154
|
-
|
|
155
|
-
case 'set_doppler_effect':
|
|
156
|
-
return cleanObject(await tools.audioTools.setDopplerEffect({
|
|
157
|
-
enabled: args.enabled,
|
|
158
|
-
scale: args.scale
|
|
159
|
-
}));
|
|
160
|
-
|
|
161
|
-
case 'set_audio_occlusion':
|
|
162
|
-
return cleanObject(await tools.audioTools.setAudioOcclusion({
|
|
163
|
-
enabled: args.enabled,
|
|
164
|
-
lowPassFilterFrequency: args.lowPassFilterFrequency,
|
|
165
|
-
volumeAttenuation: args.volumeAttenuation
|
|
166
|
-
}));
|
|
167
|
-
|
|
168
|
-
case 'spawn_sound_at_location':
|
|
169
|
-
// Direct pass-through to C++ handler
|
|
170
|
-
return cleanObject(await tools.automationBridge?.sendAutomationRequest('spawn_sound_at_location', args, { timeoutMs: getTimeoutMs() }));
|
|
171
|
-
|
|
172
|
-
case 'play_sound_attached':
|
|
173
|
-
return cleanObject(await tools.automationBridge?.sendAutomationRequest('play_sound_attached', args, { timeoutMs: getTimeoutMs() }));
|
|
174
|
-
|
|
175
|
-
case 'set_sound_mix_class_override':
|
|
176
|
-
return cleanObject(await tools.automationBridge?.sendAutomationRequest('set_sound_mix_class_override', args, { timeoutMs: getTimeoutMs() }));
|
|
177
|
-
|
|
178
|
-
case 'clear_sound_mix_class_override':
|
|
179
|
-
return cleanObject(await tools.automationBridge?.sendAutomationRequest('clear_sound_mix_class_override', args, { timeoutMs: getTimeoutMs() }));
|
|
180
|
-
|
|
181
|
-
case 'set_base_sound_mix':
|
|
182
|
-
return cleanObject(await tools.automationBridge?.sendAutomationRequest('set_base_sound_mix', args, { timeoutMs: getTimeoutMs() }));
|
|
183
|
-
|
|
184
|
-
case 'prime_sound':
|
|
185
|
-
return cleanObject(await tools.automationBridge?.sendAutomationRequest('prime_sound', args, { timeoutMs: getTimeoutMs() }));
|
|
186
|
-
|
|
187
|
-
case 'fade_sound_in':
|
|
188
|
-
case 'fade_sound_out':
|
|
189
|
-
return cleanObject(await tools.automationBridge?.sendAutomationRequest(action, args, { timeoutMs: getTimeoutMs() }));
|
|
190
|
-
|
|
191
|
-
default:
|
|
192
|
-
return cleanObject({ success: false, error: 'UNKNOWN_ACTION', message: `Unknown audio action: ${action}` });
|
|
193
|
-
}
|
|
194
|
-
}
|
|
@@ -1,380 +0,0 @@
|
|
|
1
|
-
import { cleanObject } from '../../utils/safe-json.js';
|
|
2
|
-
import { ITools } from '../../types/tool-interfaces.js';
|
|
3
|
-
import { executeAutomationRequest } from './common-handlers.js';
|
|
4
|
-
|
|
5
|
-
export async function handleBlueprintTools(action: string, args: any, tools: ITools) {
|
|
6
|
-
switch (action) {
|
|
7
|
-
case 'create': {
|
|
8
|
-
// Support 'path' or 'blueprintPath' argument by splitting it into name and savePath if not provided
|
|
9
|
-
let name = args.name;
|
|
10
|
-
let savePath = args.savePath;
|
|
11
|
-
const pathArg = args.path || args.blueprintPath;
|
|
12
|
-
|
|
13
|
-
if (pathArg) {
|
|
14
|
-
const parts = pathArg.split('/');
|
|
15
|
-
const extractName = parts.pop(); // The last part is the name
|
|
16
|
-
|
|
17
|
-
// If name wasn't provided, use the extracted name
|
|
18
|
-
if (!name) {
|
|
19
|
-
name = extractName;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
// If savePath wasn't provided, use the extracted path
|
|
23
|
-
if (!savePath) {
|
|
24
|
-
savePath = parts.join('/');
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
if (!savePath) savePath = '/Game';
|
|
29
|
-
|
|
30
|
-
const res = await tools.blueprintTools.createBlueprint({
|
|
31
|
-
name: name,
|
|
32
|
-
blueprintType: args.blueprintType,
|
|
33
|
-
savePath: savePath,
|
|
34
|
-
parentClass: args.parentClass,
|
|
35
|
-
properties: args.properties,
|
|
36
|
-
timeoutMs: args.timeoutMs,
|
|
37
|
-
waitForCompletion: args.waitForCompletion,
|
|
38
|
-
waitForCompletionTimeoutMs: args.waitForCompletionTimeoutMs
|
|
39
|
-
});
|
|
40
|
-
return cleanObject(res);
|
|
41
|
-
}
|
|
42
|
-
case 'ensure_exists': {
|
|
43
|
-
const res = await tools.blueprintTools.waitForBlueprint(args.name || args.blueprintPath || args.path, args.timeoutMs);
|
|
44
|
-
return cleanObject(res);
|
|
45
|
-
}
|
|
46
|
-
case 'add_variable': {
|
|
47
|
-
const res = await tools.blueprintTools.addVariable({
|
|
48
|
-
blueprintName: args.name || args.blueprintPath || args.path,
|
|
49
|
-
variableName: args.variableName,
|
|
50
|
-
variableType: args.variableType,
|
|
51
|
-
defaultValue: args.defaultValue,
|
|
52
|
-
category: args.category,
|
|
53
|
-
isReplicated: args.isReplicated,
|
|
54
|
-
isPublic: args.isPublic,
|
|
55
|
-
variablePinType: args.variablePinType,
|
|
56
|
-
timeoutMs: args.timeoutMs,
|
|
57
|
-
waitForCompletion: args.waitForCompletion,
|
|
58
|
-
waitForCompletionTimeoutMs: args.waitForCompletionTimeoutMs
|
|
59
|
-
});
|
|
60
|
-
return cleanObject(res);
|
|
61
|
-
}
|
|
62
|
-
case 'set_variable_metadata': {
|
|
63
|
-
const res = await tools.blueprintTools.setVariableMetadata({
|
|
64
|
-
blueprintName: args.name || args.blueprintPath || args.path,
|
|
65
|
-
variableName: args.variableName,
|
|
66
|
-
metadata: args.metadata,
|
|
67
|
-
timeoutMs: args.timeoutMs
|
|
68
|
-
});
|
|
69
|
-
return cleanObject(res);
|
|
70
|
-
}
|
|
71
|
-
case 'remove_variable': {
|
|
72
|
-
const res = await tools.blueprintTools.removeVariable({
|
|
73
|
-
blueprintName: args.name || args.blueprintPath || args.path,
|
|
74
|
-
variableName: args.variableName,
|
|
75
|
-
timeoutMs: args.timeoutMs,
|
|
76
|
-
waitForCompletion: args.waitForCompletion,
|
|
77
|
-
waitForCompletionTimeoutMs: args.waitForCompletionTimeoutMs
|
|
78
|
-
});
|
|
79
|
-
return cleanObject(res);
|
|
80
|
-
}
|
|
81
|
-
case 'rename_variable': {
|
|
82
|
-
const res = await tools.blueprintTools.renameVariable({
|
|
83
|
-
blueprintName: args.name || args.blueprintPath || args.path,
|
|
84
|
-
oldName: args.oldName,
|
|
85
|
-
newName: args.newName,
|
|
86
|
-
timeoutMs: args.timeoutMs,
|
|
87
|
-
waitForCompletion: args.waitForCompletion,
|
|
88
|
-
waitForCompletionTimeoutMs: args.waitForCompletionTimeoutMs
|
|
89
|
-
});
|
|
90
|
-
return cleanObject(res);
|
|
91
|
-
}
|
|
92
|
-
case 'set_metadata': {
|
|
93
|
-
const assetPathRaw = typeof args.assetPath === 'string' ? args.assetPath.trim() : '';
|
|
94
|
-
const blueprintPathRaw = typeof args.blueprintPath === 'string' ? args.blueprintPath.trim() : '';
|
|
95
|
-
const nameRaw = typeof args.name === 'string' ? args.name.trim() : '';
|
|
96
|
-
const savePathRaw = typeof args.savePath === 'string' ? args.savePath.trim() : '';
|
|
97
|
-
|
|
98
|
-
let assetPath = assetPathRaw;
|
|
99
|
-
if (!assetPath) {
|
|
100
|
-
if (blueprintPathRaw) {
|
|
101
|
-
assetPath = blueprintPathRaw;
|
|
102
|
-
} else if (nameRaw && savePathRaw) {
|
|
103
|
-
const base = savePathRaw.replace(/\/$/, '');
|
|
104
|
-
assetPath = `${base}/${nameRaw}`;
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
if (!assetPath) {
|
|
108
|
-
throw new Error('Invalid parameters: assetPath or blueprintPath or name+savePath required for set_metadata');
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
const metadata = (args.metadata && typeof args.metadata === 'object') ? args.metadata : {};
|
|
112
|
-
const res = await executeAutomationRequest(tools, 'set_metadata', { assetPath, metadata });
|
|
113
|
-
return cleanObject(res);
|
|
114
|
-
}
|
|
115
|
-
case 'add_event': {
|
|
116
|
-
const blueprintName = args.blueprintPath || args.path || args.name;
|
|
117
|
-
const usedNameForBlueprint = !args.blueprintPath && !args.path && args.name;
|
|
118
|
-
|
|
119
|
-
const res: any = await tools.blueprintTools.addEvent({
|
|
120
|
-
blueprintName: blueprintName,
|
|
121
|
-
eventType: args.eventType,
|
|
122
|
-
customEventName: args.customEventName || (!usedNameForBlueprint ? args.name : undefined),
|
|
123
|
-
parameters: args.parameters,
|
|
124
|
-
timeoutMs: args.timeoutMs,
|
|
125
|
-
waitForCompletion: args.waitForCompletion,
|
|
126
|
-
waitForCompletionTimeoutMs: args.waitForCompletionTimeoutMs
|
|
127
|
-
});
|
|
128
|
-
|
|
129
|
-
if (res && res.success === false) {
|
|
130
|
-
const msg = (res.message || '').toLowerCase();
|
|
131
|
-
if (msg.includes('already exists') || msg.includes('duplicate')) {
|
|
132
|
-
return cleanObject({
|
|
133
|
-
success: false,
|
|
134
|
-
error: 'EVENT_ALREADY_EXISTS',
|
|
135
|
-
message: res.message || 'Event already exists',
|
|
136
|
-
blueprintName
|
|
137
|
-
});
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
return cleanObject(res);
|
|
141
|
-
}
|
|
142
|
-
case 'remove_event': {
|
|
143
|
-
const res = await tools.blueprintTools.removeEvent({
|
|
144
|
-
blueprintName: args.name || args.blueprintPath || args.path,
|
|
145
|
-
eventName: args.eventName,
|
|
146
|
-
customEventName: args.customEventName,
|
|
147
|
-
timeoutMs: args.timeoutMs,
|
|
148
|
-
waitForCompletion: args.waitForCompletion,
|
|
149
|
-
waitForCompletionTimeoutMs: args.waitForCompletionTimeoutMs
|
|
150
|
-
});
|
|
151
|
-
return cleanObject(res);
|
|
152
|
-
}
|
|
153
|
-
case 'add_function': {
|
|
154
|
-
// Prioritize explicit path for blueprint, allowing 'name' to be function name
|
|
155
|
-
const blueprintName = args.blueprintPath || args.path || args.name;
|
|
156
|
-
const usedNameForBlueprint = !args.blueprintPath && !args.path && args.name;
|
|
157
|
-
|
|
158
|
-
const res = await tools.blueprintTools.addFunction({
|
|
159
|
-
blueprintName: blueprintName,
|
|
160
|
-
functionName: args.functionName || args.memberName || (!usedNameForBlueprint ? args.name : undefined),
|
|
161
|
-
inputs: args.inputs,
|
|
162
|
-
outputs: args.outputs,
|
|
163
|
-
isPublic: args.isPublic,
|
|
164
|
-
category: args.category,
|
|
165
|
-
timeoutMs: args.timeoutMs,
|
|
166
|
-
waitForCompletion: args.waitForCompletion,
|
|
167
|
-
waitForCompletionTimeoutMs: args.waitForCompletionTimeoutMs
|
|
168
|
-
});
|
|
169
|
-
return cleanObject(res);
|
|
170
|
-
}
|
|
171
|
-
case 'add_component': {
|
|
172
|
-
const res = await tools.blueprintTools.addComponent({
|
|
173
|
-
blueprintName: args.name || args.blueprintPath || args.path,
|
|
174
|
-
componentType: args.componentType || args.componentClass,
|
|
175
|
-
componentName: args.componentName,
|
|
176
|
-
attachTo: args.attachTo,
|
|
177
|
-
transform: args.transform,
|
|
178
|
-
properties: args.properties,
|
|
179
|
-
compile: args.applyAndSave,
|
|
180
|
-
save: args.applyAndSave,
|
|
181
|
-
timeoutMs: args.timeoutMs,
|
|
182
|
-
waitForCompletion: args.waitForCompletion,
|
|
183
|
-
waitForCompletionTimeoutMs: args.waitForCompletionTimeoutMs
|
|
184
|
-
});
|
|
185
|
-
return cleanObject(res);
|
|
186
|
-
}
|
|
187
|
-
case 'modify_scs': {
|
|
188
|
-
const res = await tools.blueprintTools.modifyConstructionScript({
|
|
189
|
-
blueprintPath: args.name || args.blueprintPath || args.path,
|
|
190
|
-
operations: args.operations,
|
|
191
|
-
compile: args.applyAndSave,
|
|
192
|
-
save: args.applyAndSave,
|
|
193
|
-
timeoutMs: args.timeoutMs,
|
|
194
|
-
waitForCompletion: args.waitForCompletion,
|
|
195
|
-
waitForCompletionTimeoutMs: args.waitForCompletionTimeoutMs
|
|
196
|
-
});
|
|
197
|
-
return cleanObject(res);
|
|
198
|
-
}
|
|
199
|
-
case 'set_scs_transform': {
|
|
200
|
-
const res = await tools.blueprintTools.setSCSComponentTransform({
|
|
201
|
-
blueprintPath: args.name || args.blueprintPath || args.path,
|
|
202
|
-
componentName: args.componentName,
|
|
203
|
-
location: args.location,
|
|
204
|
-
rotation: args.rotation,
|
|
205
|
-
scale: args.scale,
|
|
206
|
-
timeoutMs: args.timeoutMs
|
|
207
|
-
});
|
|
208
|
-
return cleanObject(res);
|
|
209
|
-
}
|
|
210
|
-
case 'add_construction_script': {
|
|
211
|
-
const res = await tools.blueprintTools.addConstructionScript({
|
|
212
|
-
blueprintName: args.name || args.blueprintPath || args.path,
|
|
213
|
-
scriptName: args.scriptName,
|
|
214
|
-
timeoutMs: args.timeoutMs,
|
|
215
|
-
waitForCompletion: args.waitForCompletion,
|
|
216
|
-
waitForCompletionTimeoutMs: args.waitForCompletionTimeoutMs
|
|
217
|
-
});
|
|
218
|
-
return cleanObject(res);
|
|
219
|
-
}
|
|
220
|
-
case 'add_node': {
|
|
221
|
-
if ((args.nodeType === 'CallFunction' || args.nodeType === 'K2Node_CallFunction') && !args.functionName && !args.memberName) {
|
|
222
|
-
throw new Error('CallFunction node requires functionName parameter');
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
// Map common node aliases to K2Node types
|
|
226
|
-
const nodeAliases: Record<string, string> = {
|
|
227
|
-
'CallFunction': 'K2Node_CallFunction',
|
|
228
|
-
'VariableGet': 'K2Node_VariableGet',
|
|
229
|
-
'VariableSet': 'K2Node_VariableSet',
|
|
230
|
-
'If': 'K2Node_IfThenElse',
|
|
231
|
-
'Branch': 'K2Node_IfThenElse',
|
|
232
|
-
'Switch': 'K2Node_Switch',
|
|
233
|
-
'Select': 'K2Node_Select',
|
|
234
|
-
'Cast': 'K2Node_DynamicCast',
|
|
235
|
-
'CustomEvent': 'K2Node_CustomEvent',
|
|
236
|
-
'Event': 'K2Node_Event',
|
|
237
|
-
'MakeArray': 'K2Node_MakeArray',
|
|
238
|
-
'ForEach': 'K2Node_ForEachElementInEnum' // Note: ForEachLoop is a macro, this is different
|
|
239
|
-
};
|
|
240
|
-
|
|
241
|
-
const resolvedNodeType = nodeAliases[args.nodeType] || args.nodeType;
|
|
242
|
-
|
|
243
|
-
// Validation for Event nodes
|
|
244
|
-
if ((resolvedNodeType === 'K2Node_Event' || resolvedNodeType === 'K2Node_CustomEvent') && !args.eventName && !args.customEventName && !args.name) {
|
|
245
|
-
// Allow 'name' as fallback for customEventName/eventName
|
|
246
|
-
if (!args.eventName) args.eventName = args.name;
|
|
247
|
-
|
|
248
|
-
if (!args.eventName) {
|
|
249
|
-
throw new Error(`${resolvedNodeType} requires eventName (or customEventName) parameter`);
|
|
250
|
-
}
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
const res = await tools.blueprintTools.addNode({
|
|
254
|
-
blueprintName: args.name || args.blueprintPath || args.path,
|
|
255
|
-
nodeType: resolvedNodeType,
|
|
256
|
-
graphName: args.graphName,
|
|
257
|
-
functionName: args.functionName,
|
|
258
|
-
variableName: args.variableName,
|
|
259
|
-
nodeName: args.nodeName,
|
|
260
|
-
eventName: args.eventName || args.customEventName,
|
|
261
|
-
memberClass: args.memberClass,
|
|
262
|
-
posX: args.posX,
|
|
263
|
-
posY: args.posY,
|
|
264
|
-
timeoutMs: args.timeoutMs
|
|
265
|
-
});
|
|
266
|
-
return cleanObject(res);
|
|
267
|
-
}
|
|
268
|
-
case 'add_scs_component': {
|
|
269
|
-
const res = await tools.blueprintTools.addSCSComponent({
|
|
270
|
-
blueprintPath: args.name || args.blueprintPath || args.path,
|
|
271
|
-
componentClass: args.componentClass || args.componentType,
|
|
272
|
-
componentName: args.componentName,
|
|
273
|
-
meshPath: args.meshPath,
|
|
274
|
-
materialPath: args.materialPath,
|
|
275
|
-
timeoutMs: args.timeoutMs
|
|
276
|
-
});
|
|
277
|
-
return cleanObject(res);
|
|
278
|
-
}
|
|
279
|
-
case 'reparent_scs_component': {
|
|
280
|
-
const res = await tools.blueprintTools.reparentSCSComponent({
|
|
281
|
-
blueprintPath: args.name || args.blueprintPath || args.path,
|
|
282
|
-
componentName: args.componentName,
|
|
283
|
-
newParent: args.newParent,
|
|
284
|
-
timeoutMs: args.timeoutMs
|
|
285
|
-
});
|
|
286
|
-
return cleanObject(res);
|
|
287
|
-
}
|
|
288
|
-
case 'set_scs_property': {
|
|
289
|
-
const res = await tools.blueprintTools.setSCSComponentProperty({
|
|
290
|
-
blueprintPath: args.name || args.blueprintPath || args.path,
|
|
291
|
-
componentName: args.componentName,
|
|
292
|
-
propertyName: args.propertyName,
|
|
293
|
-
propertyValue: args.propertyValue,
|
|
294
|
-
timeoutMs: args.timeoutMs
|
|
295
|
-
});
|
|
296
|
-
return cleanObject(res);
|
|
297
|
-
}
|
|
298
|
-
case 'remove_scs_component': {
|
|
299
|
-
const res = await tools.blueprintTools.removeSCSComponent({
|
|
300
|
-
blueprintPath: args.name || args.blueprintPath || args.path,
|
|
301
|
-
componentName: args.componentName,
|
|
302
|
-
timeoutMs: args.timeoutMs
|
|
303
|
-
});
|
|
304
|
-
return cleanObject(res);
|
|
305
|
-
}
|
|
306
|
-
case 'get_scs': {
|
|
307
|
-
const res = await tools.blueprintTools.getBlueprintSCS({
|
|
308
|
-
blueprintPath: args.name || args.blueprintPath || args.path,
|
|
309
|
-
timeoutMs: args.timeoutMs
|
|
310
|
-
});
|
|
311
|
-
return cleanObject(res);
|
|
312
|
-
}
|
|
313
|
-
case 'set_default': {
|
|
314
|
-
const res = await tools.blueprintTools.setBlueprintDefault({
|
|
315
|
-
blueprintName: args.name || args.blueprintPath || args.path,
|
|
316
|
-
propertyName: args.propertyName,
|
|
317
|
-
value: args.value
|
|
318
|
-
});
|
|
319
|
-
return cleanObject(res);
|
|
320
|
-
}
|
|
321
|
-
case 'compile': {
|
|
322
|
-
const res = await tools.blueprintTools.compileBlueprint({
|
|
323
|
-
blueprintName: args.name || args.blueprintPath || args.path,
|
|
324
|
-
saveAfterCompile: args.saveAfterCompile
|
|
325
|
-
});
|
|
326
|
-
return cleanObject(res);
|
|
327
|
-
}
|
|
328
|
-
case 'probe_handle': {
|
|
329
|
-
const res = await tools.blueprintTools.probeSubobjectDataHandle({
|
|
330
|
-
componentClass: args.componentClass
|
|
331
|
-
});
|
|
332
|
-
return cleanObject(res);
|
|
333
|
-
}
|
|
334
|
-
case 'get': {
|
|
335
|
-
const res = await tools.blueprintTools.getBlueprintInfo({
|
|
336
|
-
blueprintPath: args.name || args.blueprintPath || args.path,
|
|
337
|
-
timeoutMs: args.timeoutMs
|
|
338
|
-
});
|
|
339
|
-
return cleanObject(res);
|
|
340
|
-
}
|
|
341
|
-
case 'connect_pins':
|
|
342
|
-
case 'break_pin_links':
|
|
343
|
-
case 'delete_node':
|
|
344
|
-
case 'create_reroute_node':
|
|
345
|
-
case 'set_node_property':
|
|
346
|
-
case 'get_node_details':
|
|
347
|
-
case 'get_pin_details':
|
|
348
|
-
case 'get_graph_details': {
|
|
349
|
-
const processedArgs = {
|
|
350
|
-
...args,
|
|
351
|
-
subAction: action,
|
|
352
|
-
blueprintPath: args.blueprintPath || args.path || args.name
|
|
353
|
-
};
|
|
354
|
-
const res = await executeAutomationRequest(tools, 'manage_blueprint_graph', processedArgs, 'Automation bridge not available for blueprint graph operations');
|
|
355
|
-
return cleanObject(res);
|
|
356
|
-
}
|
|
357
|
-
default: {
|
|
358
|
-
// Translate applyAndSave to compile/save flags for modify_scs action
|
|
359
|
-
const processedArgs = { ...args };
|
|
360
|
-
if (args.action === 'modify_scs' && args.applyAndSave === true) {
|
|
361
|
-
processedArgs.compile = true;
|
|
362
|
-
processedArgs.save = true;
|
|
363
|
-
}
|
|
364
|
-
const res = await executeAutomationRequest(tools, 'manage_blueprint', processedArgs, 'Automation bridge not available for blueprint operations');
|
|
365
|
-
return cleanObject(res);
|
|
366
|
-
}
|
|
367
|
-
}
|
|
368
|
-
}
|
|
369
|
-
|
|
370
|
-
export async function handleBlueprintGet(args: any, tools: ITools) {
|
|
371
|
-
const res = await executeAutomationRequest(tools, 'blueprint_get', args, 'Automation bridge not available for blueprint operations') as { success?: boolean; message?: string } | null;
|
|
372
|
-
if (res && res.success) {
|
|
373
|
-
return cleanObject({
|
|
374
|
-
...res,
|
|
375
|
-
blueprint: args.blueprintPath || args.path || args.name || 'Unknown Blueprint',
|
|
376
|
-
message: res.message || 'Blueprint fetched'
|
|
377
|
-
});
|
|
378
|
-
}
|
|
379
|
-
return cleanObject(res);
|
|
380
|
-
}
|
|
@@ -1,108 +0,0 @@
|
|
|
1
|
-
import { ITools } from '../../types/tool-interfaces.js';
|
|
2
|
-
import type { HandlerArgs, Vector3, Rotator } from '../../types/handler-types.js';
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* Validates that args is not null/undefined.
|
|
6
|
-
*/
|
|
7
|
-
export function ensureArgsPresent(args: unknown): asserts args is Record<string, unknown> {
|
|
8
|
-
if (args === null || args === undefined) {
|
|
9
|
-
throw new Error('Invalid arguments: null or undefined');
|
|
10
|
-
}
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* Extracts and validates the 'action' field from args.
|
|
15
|
-
*/
|
|
16
|
-
export function requireAction(args: HandlerArgs): string {
|
|
17
|
-
ensureArgsPresent(args);
|
|
18
|
-
const action = args.action;
|
|
19
|
-
if (typeof action !== 'string' || action.trim() === '') {
|
|
20
|
-
throw new Error('Missing required parameter: action');
|
|
21
|
-
}
|
|
22
|
-
return action;
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
/**
|
|
26
|
-
* Validates that a value is a non-empty string.
|
|
27
|
-
*/
|
|
28
|
-
export function requireNonEmptyString(value: unknown, field: string, message?: string): string {
|
|
29
|
-
if (typeof value !== 'string' || value.trim() === '') {
|
|
30
|
-
throw new Error(message ?? `Invalid ${field}: must be a non-empty string`);
|
|
31
|
-
}
|
|
32
|
-
return value;
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
/**
|
|
36
|
-
* Execute a request via the automation bridge.
|
|
37
|
-
*/
|
|
38
|
-
export async function executeAutomationRequest(
|
|
39
|
-
tools: ITools,
|
|
40
|
-
toolName: string,
|
|
41
|
-
args: HandlerArgs,
|
|
42
|
-
errorMessage: string = 'Automation bridge not available',
|
|
43
|
-
options: { timeoutMs?: number } = {}
|
|
44
|
-
): Promise<unknown> {
|
|
45
|
-
const automationBridge = tools.automationBridge;
|
|
46
|
-
// If the bridge is missing or not a function, we can't proceed with automation requests
|
|
47
|
-
if (!automationBridge || typeof automationBridge.sendAutomationRequest !== 'function') {
|
|
48
|
-
throw new Error(errorMessage);
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
if (!automationBridge.isConnected()) {
|
|
52
|
-
throw new Error(`Automation bridge is not connected to Unreal Engine. Please check if the editor is running and the plugin is enabled. Action: ${toolName}`);
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
return await automationBridge.sendAutomationRequest(toolName, args, options);
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
/** Input type for location normalization */
|
|
59
|
-
type LocationInput = Vector3 | [number, number, number] | number[] | null | undefined;
|
|
60
|
-
|
|
61
|
-
/**
|
|
62
|
-
* Normalize location to [x, y, z] array format
|
|
63
|
-
* Accepts both {x,y,z} object and [x,y,z] array formats
|
|
64
|
-
*/
|
|
65
|
-
export function normalizeLocation(location: LocationInput): [number, number, number] | undefined {
|
|
66
|
-
if (!location) return undefined;
|
|
67
|
-
|
|
68
|
-
// Already array format
|
|
69
|
-
if (Array.isArray(location) && location.length >= 3) {
|
|
70
|
-
return [Number(location[0]) || 0, Number(location[1]) || 0, Number(location[2]) || 0];
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
// Object format {x, y, z}
|
|
74
|
-
if (typeof location === 'object' && ('x' in location || 'y' in location || 'z' in location)) {
|
|
75
|
-
const loc = location as Vector3;
|
|
76
|
-
return [Number(loc.x) || 0, Number(loc.y) || 0, Number(loc.z) || 0];
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
return undefined;
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
/** Input type for rotation normalization */
|
|
83
|
-
type RotationInput = Rotator | [number, number, number] | number[] | null | undefined;
|
|
84
|
-
|
|
85
|
-
/**
|
|
86
|
-
* Normalize rotation to {pitch, yaw, roll} object format
|
|
87
|
-
* Accepts both {pitch,yaw,roll} object and [pitch,yaw,roll] array formats
|
|
88
|
-
*/
|
|
89
|
-
export function normalizeRotation(rotation: RotationInput): Rotator | undefined {
|
|
90
|
-
if (!rotation) return undefined;
|
|
91
|
-
|
|
92
|
-
// Array format [pitch, yaw, roll]
|
|
93
|
-
if (Array.isArray(rotation) && rotation.length >= 3) {
|
|
94
|
-
return { pitch: Number(rotation[0]) || 0, yaw: Number(rotation[1]) || 0, roll: Number(rotation[2]) || 0 };
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
// Already object format
|
|
98
|
-
if (typeof rotation === 'object') {
|
|
99
|
-
const rot = rotation as Rotator;
|
|
100
|
-
return {
|
|
101
|
-
pitch: Number(rot.pitch) || 0,
|
|
102
|
-
yaw: Number(rot.yaw) || 0,
|
|
103
|
-
roll: Number(rot.roll) || 0
|
|
104
|
-
};
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
return undefined;
|
|
108
|
-
}
|