unreal-engine-mcp-server 0.5.4 → 0.5.6

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.
Files changed (561) hide show
  1. package/CHANGELOG.md +350 -0
  2. package/dist/automation/bridge.d.ts.map +1 -0
  3. package/dist/automation/bridge.js +5 -4
  4. package/dist/automation/bridge.js.map +1 -0
  5. package/dist/automation/connection-manager.d.ts.map +1 -0
  6. package/dist/automation/connection-manager.js.map +1 -0
  7. package/dist/automation/handshake.d.ts.map +1 -0
  8. package/dist/automation/handshake.js.map +1 -0
  9. package/dist/automation/index.d.ts.map +1 -0
  10. package/dist/automation/index.js.map +1 -0
  11. package/dist/automation/message-handler.d.ts.map +1 -0
  12. package/dist/automation/message-handler.js.map +1 -0
  13. package/dist/automation/request-tracker.d.ts.map +1 -0
  14. package/dist/automation/request-tracker.js.map +1 -0
  15. package/dist/automation/types.d.ts +7 -0
  16. package/dist/automation/types.d.ts.map +1 -0
  17. package/dist/automation/types.js.map +1 -0
  18. package/dist/cli.d.ts.map +1 -0
  19. package/dist/cli.js +6 -4
  20. package/dist/cli.js.map +1 -0
  21. package/dist/config/class-aliases.d.ts.map +1 -0
  22. package/dist/config/class-aliases.js.map +1 -0
  23. package/dist/config.d.ts.map +1 -0
  24. package/dist/config.js.map +1 -0
  25. package/dist/constants.d.ts.map +1 -0
  26. package/dist/constants.js.map +1 -0
  27. package/dist/graphql/loaders.d.ts.map +1 -0
  28. package/dist/graphql/loaders.js.map +1 -0
  29. package/dist/graphql/resolvers.d.ts +174 -69
  30. package/dist/graphql/resolvers.d.ts.map +1 -0
  31. package/dist/graphql/resolvers.js +82 -67
  32. package/dist/graphql/resolvers.js.map +1 -0
  33. package/dist/graphql/schema.d.ts.map +1 -0
  34. package/dist/graphql/schema.js.map +1 -0
  35. package/dist/graphql/server.d.ts.map +1 -0
  36. package/dist/graphql/server.js.map +1 -0
  37. package/dist/graphql/types.d.ts.map +1 -0
  38. package/dist/graphql/types.js.map +1 -0
  39. package/dist/handlers/resource-handlers.d.ts.map +1 -0
  40. package/dist/handlers/resource-handlers.js.map +1 -0
  41. package/dist/index.d.ts +2 -1
  42. package/dist/index.d.ts.map +1 -0
  43. package/dist/index.js +70 -9
  44. package/dist/index.js.map +1 -0
  45. package/dist/resources/actors.d.ts +7 -4
  46. package/dist/resources/actors.d.ts.map +1 -0
  47. package/dist/resources/actors.js +15 -12
  48. package/dist/resources/actors.js.map +1 -0
  49. package/dist/resources/assets.d.ts +43 -2
  50. package/dist/resources/assets.d.ts.map +1 -0
  51. package/dist/resources/assets.js +21 -12
  52. package/dist/resources/assets.js.map +1 -0
  53. package/dist/resources/levels.d.ts.map +1 -0
  54. package/dist/resources/levels.js +7 -5
  55. package/dist/resources/levels.js.map +1 -0
  56. package/dist/schemas/index.d.ts +4 -0
  57. package/dist/schemas/index.d.ts.map +1 -0
  58. package/dist/schemas/index.js +4 -0
  59. package/dist/schemas/index.js.map +1 -0
  60. package/dist/schemas/parser.d.ts +20 -0
  61. package/dist/schemas/parser.d.ts.map +1 -0
  62. package/dist/schemas/parser.js +61 -0
  63. package/dist/schemas/parser.js.map +1 -0
  64. package/dist/schemas/primitives.d.ts +221 -0
  65. package/dist/schemas/primitives.d.ts.map +1 -0
  66. package/dist/schemas/primitives.js +115 -0
  67. package/dist/schemas/primitives.js.map +1 -0
  68. package/dist/schemas/responses.d.ts +362 -0
  69. package/dist/schemas/responses.d.ts.map +1 -0
  70. package/dist/schemas/responses.js +252 -0
  71. package/dist/schemas/responses.js.map +1 -0
  72. package/dist/server/resource-registry.d.ts.map +1 -0
  73. package/dist/server/resource-registry.js.map +1 -0
  74. package/dist/server/tool-registry.d.ts.map +1 -0
  75. package/dist/server/tool-registry.js +22 -17
  76. package/dist/server/tool-registry.js.map +1 -0
  77. package/dist/server-setup.d.ts.map +1 -0
  78. package/dist/server-setup.js.map +1 -0
  79. package/dist/services/health-monitor.d.ts +1 -1
  80. package/dist/services/health-monitor.d.ts.map +1 -0
  81. package/dist/services/health-monitor.js +4 -3
  82. package/dist/services/health-monitor.js.map +1 -0
  83. package/dist/services/metrics-server.d.ts.map +1 -0
  84. package/dist/services/metrics-server.js.map +1 -0
  85. package/dist/tools/actors.d.ts +27 -27
  86. package/dist/tools/actors.d.ts.map +1 -0
  87. package/dist/tools/actors.js +14 -10
  88. package/dist/tools/actors.js.map +1 -0
  89. package/dist/tools/animation.d.ts +15 -23
  90. package/dist/tools/animation.d.ts.map +1 -0
  91. package/dist/tools/animation.js +17 -13
  92. package/dist/tools/animation.js.map +1 -0
  93. package/dist/tools/assets.d.ts.map +1 -0
  94. package/dist/tools/assets.js +18 -12
  95. package/dist/tools/assets.js.map +1 -0
  96. package/dist/tools/audio.d.ts +10 -10
  97. package/dist/tools/audio.d.ts.map +1 -0
  98. package/dist/tools/audio.js.map +1 -0
  99. package/dist/tools/base-tool.d.ts.map +1 -0
  100. package/dist/tools/base-tool.js.map +1 -0
  101. package/dist/tools/behavior-tree.d.ts +24 -24
  102. package/dist/tools/behavior-tree.d.ts.map +1 -0
  103. package/dist/tools/behavior-tree.js.map +1 -0
  104. package/dist/tools/blueprint.d.ts +14 -3
  105. package/dist/tools/blueprint.d.ts.map +1 -0
  106. package/dist/tools/blueprint.js +5 -3
  107. package/dist/tools/blueprint.js.map +1 -0
  108. package/dist/tools/consolidated-tool-definitions.d.ts +32 -32
  109. package/dist/tools/consolidated-tool-definitions.d.ts.map +1 -0
  110. package/dist/tools/consolidated-tool-definitions.js.map +1 -0
  111. package/dist/tools/consolidated-tool-handlers.d.ts +1 -1
  112. package/dist/tools/consolidated-tool-handlers.d.ts.map +1 -0
  113. package/dist/tools/consolidated-tool-handlers.js +26 -21
  114. package/dist/tools/consolidated-tool-handlers.js.map +1 -0
  115. package/dist/tools/debug.d.ts +25 -7
  116. package/dist/tools/debug.d.ts.map +1 -0
  117. package/dist/tools/debug.js +3 -1
  118. package/dist/tools/debug.js.map +1 -0
  119. package/dist/tools/dynamic-handler-registry.d.ts +1 -1
  120. package/dist/tools/dynamic-handler-registry.d.ts.map +1 -0
  121. package/dist/tools/dynamic-handler-registry.js +3 -1
  122. package/dist/tools/dynamic-handler-registry.js.map +1 -0
  123. package/dist/tools/editor.d.ts.map +1 -0
  124. package/dist/tools/editor.js +8 -6
  125. package/dist/tools/editor.js.map +1 -0
  126. package/dist/tools/engine.d.ts +1 -1
  127. package/dist/tools/engine.d.ts.map +1 -0
  128. package/dist/tools/engine.js +4 -2
  129. package/dist/tools/engine.js.map +1 -0
  130. package/dist/tools/environment.d.ts.map +1 -0
  131. package/dist/tools/environment.js +4 -3
  132. package/dist/tools/environment.js.map +1 -0
  133. package/dist/tools/foliage.d.ts.map +1 -0
  134. package/dist/tools/foliage.js +8 -8
  135. package/dist/tools/foliage.js.map +1 -0
  136. package/dist/tools/handlers/actor-handlers.d.ts +2 -1
  137. package/dist/tools/handlers/actor-handlers.d.ts.map +1 -0
  138. package/dist/tools/handlers/actor-handlers.js +56 -33
  139. package/dist/tools/handlers/actor-handlers.js.map +1 -0
  140. package/dist/tools/handlers/animation-handlers.d.ts +2 -1
  141. package/dist/tools/handlers/animation-handlers.d.ts.map +1 -0
  142. package/dist/tools/handlers/animation-handlers.js +74 -67
  143. package/dist/tools/handlers/animation-handlers.js.map +1 -0
  144. package/dist/tools/handlers/argument-helper.d.ts +24 -4
  145. package/dist/tools/handlers/argument-helper.d.ts.map +1 -0
  146. package/dist/tools/handlers/argument-helper.js +139 -4
  147. package/dist/tools/handlers/argument-helper.js.map +1 -0
  148. package/dist/tools/handlers/asset-handlers.d.ts +2 -1
  149. package/dist/tools/handlers/asset-handlers.d.ts.map +1 -0
  150. package/dist/tools/handlers/asset-handlers.js +155 -94
  151. package/dist/tools/handlers/asset-handlers.js.map +1 -0
  152. package/dist/tools/handlers/audio-handlers.d.ts +2 -1
  153. package/dist/tools/handlers/audio-handlers.d.ts.map +1 -0
  154. package/dist/tools/handlers/audio-handlers.js +82 -80
  155. package/dist/tools/handlers/audio-handlers.js.map +1 -0
  156. package/dist/tools/handlers/blueprint-handlers.d.ts +3 -5
  157. package/dist/tools/handlers/blueprint-handlers.d.ts.map +1 -0
  158. package/dist/tools/handlers/blueprint-handlers.js +150 -142
  159. package/dist/tools/handlers/blueprint-handlers.js.map +1 -0
  160. package/dist/tools/handlers/common-handlers.d.ts +2 -3
  161. package/dist/tools/handlers/common-handlers.d.ts.map +1 -0
  162. package/dist/tools/handlers/common-handlers.js.map +1 -0
  163. package/dist/tools/handlers/editor-handlers.d.ts.map +1 -0
  164. package/dist/tools/handlers/editor-handlers.js +12 -2
  165. package/dist/tools/handlers/editor-handlers.js.map +1 -0
  166. package/dist/tools/handlers/effect-handlers.d.ts +2 -1
  167. package/dist/tools/handlers/effect-handlers.d.ts.map +1 -0
  168. package/dist/tools/handlers/effect-handlers.js +70 -68
  169. package/dist/tools/handlers/effect-handlers.js.map +1 -0
  170. package/dist/tools/handlers/environment-handlers.d.ts +2 -1
  171. package/dist/tools/handlers/environment-handlers.d.ts.map +1 -0
  172. package/dist/tools/handlers/environment-handlers.js +86 -74
  173. package/dist/tools/handlers/environment-handlers.js.map +1 -0
  174. package/dist/tools/handlers/graph-handlers.d.ts +1 -1
  175. package/dist/tools/handlers/graph-handlers.d.ts.map +1 -0
  176. package/dist/tools/handlers/graph-handlers.js +63 -2
  177. package/dist/tools/handlers/graph-handlers.js.map +1 -0
  178. package/dist/tools/handlers/input-handlers.d.ts +2 -5
  179. package/dist/tools/handlers/input-handlers.d.ts.map +1 -0
  180. package/dist/tools/handlers/input-handlers.js +5 -4
  181. package/dist/tools/handlers/input-handlers.js.map +1 -0
  182. package/dist/tools/handlers/inspect-handlers.d.ts +2 -1
  183. package/dist/tools/handlers/inspect-handlers.d.ts.map +1 -0
  184. package/dist/tools/handlers/inspect-handlers.js +61 -37
  185. package/dist/tools/handlers/inspect-handlers.js.map +1 -0
  186. package/dist/tools/handlers/level-handlers.d.ts +2 -2
  187. package/dist/tools/handlers/level-handlers.d.ts.map +1 -0
  188. package/dist/tools/handlers/level-handlers.js +43 -39
  189. package/dist/tools/handlers/level-handlers.js.map +1 -0
  190. package/dist/tools/handlers/lighting-handlers.d.ts +12 -1
  191. package/dist/tools/handlers/lighting-handlers.d.ts.map +1 -0
  192. package/dist/tools/handlers/lighting-handlers.js +90 -47
  193. package/dist/tools/handlers/lighting-handlers.js.map +1 -0
  194. package/dist/tools/handlers/performance-handlers.d.ts +2 -1
  195. package/dist/tools/handlers/performance-handlers.d.ts.map +1 -0
  196. package/dist/tools/handlers/performance-handlers.js +55 -40
  197. package/dist/tools/handlers/performance-handlers.js.map +1 -0
  198. package/dist/tools/handlers/pipeline-handlers.d.ts.map +1 -0
  199. package/dist/tools/handlers/pipeline-handlers.js.map +1 -0
  200. package/dist/tools/handlers/sequence-handlers.d.ts.map +1 -0
  201. package/dist/tools/handlers/sequence-handlers.js.map +1 -0
  202. package/dist/tools/handlers/system-handlers.d.ts +3 -2
  203. package/dist/tools/handlers/system-handlers.d.ts.map +1 -0
  204. package/dist/tools/handlers/system-handlers.js +105 -52
  205. package/dist/tools/handlers/system-handlers.js.map +1 -0
  206. package/dist/tools/input.d.ts.map +1 -0
  207. package/dist/tools/input.js +3 -1
  208. package/dist/tools/input.js.map +1 -0
  209. package/dist/tools/introspection.d.ts +14 -14
  210. package/dist/tools/introspection.d.ts.map +1 -0
  211. package/dist/tools/introspection.js +54 -45
  212. package/dist/tools/introspection.js.map +1 -0
  213. package/dist/tools/landscape.d.ts.map +1 -0
  214. package/dist/tools/landscape.js +15 -13
  215. package/dist/tools/landscape.js.map +1 -0
  216. package/dist/tools/level.d.ts.map +1 -0
  217. package/dist/tools/level.js +3 -2
  218. package/dist/tools/level.js.map +1 -0
  219. package/dist/tools/lighting.d.ts +32 -59
  220. package/dist/tools/lighting.d.ts.map +1 -0
  221. package/dist/tools/lighting.js +56 -19
  222. package/dist/tools/lighting.js.map +1 -0
  223. package/dist/tools/logs.d.ts.map +1 -0
  224. package/dist/tools/logs.js +2 -1
  225. package/dist/tools/logs.js.map +1 -0
  226. package/dist/tools/materials.d.ts +42 -14
  227. package/dist/tools/materials.d.ts.map +1 -0
  228. package/dist/tools/materials.js +15 -9
  229. package/dist/tools/materials.js.map +1 -0
  230. package/dist/tools/niagara.d.ts +63 -39
  231. package/dist/tools/niagara.d.ts.map +1 -0
  232. package/dist/tools/niagara.js +43 -33
  233. package/dist/tools/niagara.js.map +1 -0
  234. package/dist/tools/performance.d.ts +12 -11
  235. package/dist/tools/performance.d.ts.map +1 -0
  236. package/dist/tools/performance.js +3 -2
  237. package/dist/tools/performance.js.map +1 -0
  238. package/dist/tools/physics.d.ts +37 -20
  239. package/dist/tools/physics.d.ts.map +1 -0
  240. package/dist/tools/physics.js +37 -30
  241. package/dist/tools/physics.js.map +1 -0
  242. package/dist/tools/property-dictionary.d.ts.map +1 -0
  243. package/dist/tools/property-dictionary.js.map +1 -0
  244. package/dist/tools/sequence.d.ts +1 -1
  245. package/dist/tools/sequence.d.ts.map +1 -0
  246. package/dist/tools/sequence.js +8 -4
  247. package/dist/tools/sequence.js.map +1 -0
  248. package/dist/tools/tool-definition-utils.d.ts.map +1 -0
  249. package/dist/tools/tool-definition-utils.js.map +1 -0
  250. package/dist/tools/ui.d.ts +11 -11
  251. package/dist/tools/ui.d.ts.map +1 -0
  252. package/dist/tools/ui.js +7 -3
  253. package/dist/tools/ui.js.map +1 -0
  254. package/dist/types/automation-responses.d.ts.map +1 -0
  255. package/dist/types/automation-responses.js.map +1 -0
  256. package/dist/types/env.d.ts.map +1 -0
  257. package/dist/types/env.js.map +1 -0
  258. package/dist/types/handler-types.d.ts +112 -3
  259. package/dist/types/handler-types.d.ts.map +1 -0
  260. package/dist/types/handler-types.js.map +1 -0
  261. package/dist/types/tool-interfaces.d.ts +39 -21
  262. package/dist/types/tool-interfaces.d.ts.map +1 -0
  263. package/dist/types/tool-interfaces.js.map +1 -0
  264. package/dist/types/tool-types.d.ts +8 -8
  265. package/dist/types/tool-types.d.ts.map +1 -0
  266. package/dist/types/tool-types.js.map +1 -0
  267. package/dist/unreal-bridge.d.ts +8 -6
  268. package/dist/unreal-bridge.d.ts.map +1 -0
  269. package/dist/unreal-bridge.js +16 -3
  270. package/dist/unreal-bridge.js.map +1 -0
  271. package/dist/utils/command-validator.d.ts.map +1 -0
  272. package/dist/utils/command-validator.js.map +1 -0
  273. package/dist/utils/elicitation.d.ts +2 -5
  274. package/dist/utils/elicitation.d.ts.map +1 -0
  275. package/dist/utils/elicitation.js +3 -2
  276. package/dist/utils/elicitation.js.map +1 -0
  277. package/dist/utils/error-handler.d.ts.map +1 -0
  278. package/dist/utils/error-handler.js.map +1 -0
  279. package/dist/utils/ini-reader.d.ts +1 -1
  280. package/dist/utils/ini-reader.d.ts.map +1 -0
  281. package/dist/utils/ini-reader.js.map +1 -0
  282. package/dist/utils/logger.d.ts +4 -4
  283. package/dist/utils/logger.d.ts.map +1 -0
  284. package/dist/utils/logger.js.map +1 -0
  285. package/dist/utils/normalize.d.ts +2 -2
  286. package/dist/utils/normalize.d.ts.map +1 -0
  287. package/dist/utils/normalize.js +4 -3
  288. package/dist/utils/normalize.js.map +1 -0
  289. package/dist/utils/path-security.d.ts.map +1 -0
  290. package/dist/utils/path-security.js.map +1 -0
  291. package/dist/utils/response-factory.d.ts +2 -2
  292. package/dist/utils/response-factory.d.ts.map +1 -0
  293. package/dist/utils/response-factory.js +3 -1
  294. package/dist/utils/response-factory.js.map +1 -0
  295. package/dist/utils/response-validator.d.ts +4 -4
  296. package/dist/utils/response-validator.d.ts.map +1 -0
  297. package/dist/utils/response-validator.js +31 -23
  298. package/dist/utils/response-validator.js.map +1 -0
  299. package/dist/utils/result-helpers.d.ts.map +1 -0
  300. package/dist/utils/result-helpers.js.map +1 -0
  301. package/dist/utils/safe-json.d.ts.map +1 -0
  302. package/dist/utils/safe-json.js.map +1 -0
  303. package/dist/utils/unreal-command-queue.d.ts +2 -2
  304. package/dist/utils/unreal-command-queue.d.ts.map +1 -0
  305. package/dist/utils/unreal-command-queue.js +4 -3
  306. package/dist/utils/unreal-command-queue.js.map +1 -0
  307. package/dist/utils/validation.d.ts +1 -1
  308. package/dist/utils/validation.d.ts.map +1 -0
  309. package/dist/utils/validation.js.map +1 -0
  310. package/dist/wasm/index.d.ts +2 -2
  311. package/dist/wasm/index.d.ts.map +1 -0
  312. package/dist/wasm/index.js +11 -7
  313. package/dist/wasm/index.js.map +1 -0
  314. package/package.json +12 -34
  315. package/server.json +2 -2
  316. package/.dockerignore +0 -57
  317. package/.env.example +0 -26
  318. package/.env.production +0 -61
  319. package/.eslintrc.json +0 -0
  320. package/.eslintrc.override.json +0 -8
  321. package/.github/ISSUE_TEMPLATE/bug_report.yml +0 -94
  322. package/.github/ISSUE_TEMPLATE/config.yml +0 -8
  323. package/.github/ISSUE_TEMPLATE/feature_request.yml +0 -56
  324. package/.github/copilot-instructions.md +0 -478
  325. package/.github/dependabot.yml +0 -19
  326. package/.github/labeler.yml +0 -24
  327. package/.github/labels.yml +0 -70
  328. package/.github/pull_request_template.md +0 -42
  329. package/.github/release-drafter-config.yml +0 -51
  330. package/.github/workflows/auto-merge.yml +0 -38
  331. package/.github/workflows/ci.yml +0 -38
  332. package/.github/workflows/dependency-review.yml +0 -17
  333. package/.github/workflows/gemini-issue-triage.yml +0 -172
  334. package/.github/workflows/greetings.yml +0 -27
  335. package/.github/workflows/labeler.yml +0 -17
  336. package/.github/workflows/links.yml +0 -80
  337. package/.github/workflows/pr-size-labeler.yml +0 -137
  338. package/.github/workflows/publish-mcp.yml +0 -79
  339. package/.github/workflows/release-drafter.yml +0 -24
  340. package/.github/workflows/release.yml +0 -112
  341. package/.github/workflows/semantic-pull-request.yml +0 -35
  342. package/.github/workflows/smoke-test.yml +0 -36
  343. package/.github/workflows/stale.yml +0 -28
  344. package/CONTRIBUTING.md +0 -140
  345. package/Dockerfile +0 -37
  346. package/GEMINI.md +0 -115
  347. package/Public/Plugin_setup_guide.mp4 +0 -0
  348. package/Public/icon.png +0 -0
  349. package/claude_desktop_config_example.json +0 -15
  350. package/dist/types/responses.d.ts +0 -249
  351. package/dist/types/responses.js +0 -2
  352. package/docs/GraphQL-API.md +0 -888
  353. package/docs/Migration-Guide-v0.5.0.md +0 -684
  354. package/docs/Roadmap.md +0 -53
  355. package/docs/WebAssembly-Integration.md +0 -628
  356. package/docs/editor-plugin-extension.md +0 -370
  357. package/docs/handler-mapping.md +0 -249
  358. package/docs/native-automation-progress.md +0 -128
  359. package/docs/testing-guide.md +0 -423
  360. package/eslint.config.mjs +0 -68
  361. package/mcp-config-example.json +0 -14
  362. package/plugins/McpAutomationBridge/Config/FilterPlugin.ini +0 -8
  363. package/plugins/McpAutomationBridge/McpAutomationBridge.uplugin +0 -64
  364. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/McpAutomationBridge.Build.cs +0 -189
  365. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridgeGlobals.cpp +0 -22
  366. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridgeGlobals.h +0 -30
  367. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridgeHelpers.h +0 -1983
  368. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridgeModule.cpp +0 -72
  369. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridgeSettings.cpp +0 -46
  370. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridgeSubsystem.cpp +0 -846
  371. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_AnimationHandlers.cpp +0 -2393
  372. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_AssetQueryHandlers.cpp +0 -300
  373. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_AssetWorkflowHandlers.cpp +0 -2807
  374. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_AudioHandlers.cpp +0 -1087
  375. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_BehaviorTreeHandlers.cpp +0 -488
  376. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_BlueprintCreationHandlers.cpp +0 -643
  377. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_BlueprintCreationHandlers.h +0 -31
  378. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_BlueprintGraphHandlers.cpp +0 -1094
  379. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_BlueprintHandlers.cpp +0 -5750
  380. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_BlueprintHandlers_List.cpp +0 -152
  381. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_ControlHandlers.cpp +0 -2614
  382. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_DebugHandlers.cpp +0 -42
  383. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_EditorFunctionHandlers.cpp +0 -1237
  384. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_EffectHandlers.cpp +0 -1725
  385. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_EnvironmentHandlers.cpp +0 -2265
  386. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_FoliageHandlers.cpp +0 -954
  387. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_InputHandlers.cpp +0 -209
  388. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_InsightsHandlers.cpp +0 -41
  389. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_LandscapeHandlers.cpp +0 -1164
  390. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_LevelHandlers.cpp +0 -762
  391. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_LightingHandlers.cpp +0 -663
  392. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_LogHandlers.cpp +0 -136
  393. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_MaterialGraphHandlers.cpp +0 -494
  394. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_NiagaraGraphHandlers.cpp +0 -278
  395. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_NiagaraHandlers.cpp +0 -625
  396. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_PerformanceHandlers.cpp +0 -401
  397. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_PipelineHandlers.cpp +0 -67
  398. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_ProcessRequest.cpp +0 -472
  399. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_PropertyHandlers.cpp +0 -2634
  400. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_RenderHandlers.cpp +0 -189
  401. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_SCSHandlers.cpp +0 -917
  402. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_SCSHandlers.h +0 -39
  403. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_SequenceHandlers.cpp +0 -2706
  404. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_SequencerHandlers.cpp +0 -519
  405. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_TestHandlers.cpp +0 -38
  406. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_UiHandlers.cpp +0 -668
  407. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_WorldPartitionHandlers.cpp +0 -346
  408. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpBridgeWebSocket.cpp +0 -1345
  409. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpBridgeWebSocket.h +0 -149
  410. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpConnectionManager.cpp +0 -782
  411. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Public/McpAutomationBridgeSettings.h +0 -115
  412. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Public/McpAutomationBridgeSubsystem.h +0 -796
  413. package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Public/McpConnectionManager.h +0 -117
  414. package/scripts/check-unreal-connection.mjs +0 -19
  415. package/scripts/clean-tmp.js +0 -23
  416. package/scripts/patch-wasm.js +0 -26
  417. package/scripts/run-all-tests.mjs +0 -136
  418. package/scripts/smoke-test.ts +0 -94
  419. package/scripts/sync-mcp-plugin.js +0 -143
  420. package/scripts/test-no-plugin-alternates.mjs +0 -113
  421. package/scripts/validate-server.js +0 -46
  422. package/scripts/verify-automation-bridge.js +0 -200
  423. package/src/automation/bridge.ts +0 -630
  424. package/src/automation/connection-manager.ts +0 -148
  425. package/src/automation/handshake.ts +0 -99
  426. package/src/automation/index.ts +0 -2
  427. package/src/automation/message-handler.ts +0 -192
  428. package/src/automation/request-tracker.ts +0 -155
  429. package/src/automation/types.ts +0 -108
  430. package/src/cli.ts +0 -34
  431. package/src/config/class-aliases.ts +0 -65
  432. package/src/config.ts +0 -73
  433. package/src/constants.ts +0 -29
  434. package/src/graphql/loaders.ts +0 -244
  435. package/src/graphql/resolvers.ts +0 -1008
  436. package/src/graphql/schema.ts +0 -452
  437. package/src/graphql/server.ts +0 -156
  438. package/src/graphql/types.ts +0 -10
  439. package/src/handlers/resource-handlers.ts +0 -186
  440. package/src/index.ts +0 -243
  441. package/src/resources/actors.ts +0 -127
  442. package/src/resources/assets.ts +0 -286
  443. package/src/resources/levels.ts +0 -68
  444. package/src/server/resource-registry.ts +0 -47
  445. package/src/server/tool-registry.ts +0 -354
  446. package/src/server-setup.ts +0 -114
  447. package/src/services/health-monitor.ts +0 -132
  448. package/src/services/metrics-server.ts +0 -176
  449. package/src/tools/actors.ts +0 -564
  450. package/src/tools/animation.ts +0 -941
  451. package/src/tools/assets.ts +0 -394
  452. package/src/tools/audio.ts +0 -499
  453. package/src/tools/base-tool.ts +0 -52
  454. package/src/tools/behavior-tree.ts +0 -45
  455. package/src/tools/blueprint.ts +0 -940
  456. package/src/tools/consolidated-tool-definitions.ts +0 -1256
  457. package/src/tools/consolidated-tool-handlers.ts +0 -302
  458. package/src/tools/debug.ts +0 -622
  459. package/src/tools/dynamic-handler-registry.ts +0 -33
  460. package/src/tools/editor.ts +0 -435
  461. package/src/tools/engine.ts +0 -43
  462. package/src/tools/environment.ts +0 -281
  463. package/src/tools/foliage.ts +0 -596
  464. package/src/tools/handlers/actor-handlers.ts +0 -244
  465. package/src/tools/handlers/animation-handlers.ts +0 -237
  466. package/src/tools/handlers/argument-helper.ts +0 -142
  467. package/src/tools/handlers/asset-handlers.ts +0 -550
  468. package/src/tools/handlers/audio-handlers.ts +0 -194
  469. package/src/tools/handlers/blueprint-handlers.ts +0 -380
  470. package/src/tools/handlers/common-handlers.ts +0 -108
  471. package/src/tools/handlers/editor-handlers.ts +0 -124
  472. package/src/tools/handlers/effect-handlers.ts +0 -224
  473. package/src/tools/handlers/environment-handlers.ts +0 -183
  474. package/src/tools/handlers/graph-handlers.ts +0 -117
  475. package/src/tools/handlers/input-handlers.ts +0 -28
  476. package/src/tools/handlers/inspect-handlers.ts +0 -450
  477. package/src/tools/handlers/level-handlers.ts +0 -253
  478. package/src/tools/handlers/lighting-handlers.ts +0 -151
  479. package/src/tools/handlers/performance-handlers.ts +0 -132
  480. package/src/tools/handlers/pipeline-handlers.ts +0 -194
  481. package/src/tools/handlers/sequence-handlers.ts +0 -438
  482. package/src/tools/handlers/system-handlers.ts +0 -564
  483. package/src/tools/input.ts +0 -160
  484. package/src/tools/introspection.ts +0 -689
  485. package/src/tools/landscape.ts +0 -649
  486. package/src/tools/level.ts +0 -989
  487. package/src/tools/lighting.ts +0 -1052
  488. package/src/tools/logs.ts +0 -219
  489. package/src/tools/materials.ts +0 -295
  490. package/src/tools/niagara.ts +0 -485
  491. package/src/tools/performance.ts +0 -661
  492. package/src/tools/physics.ts +0 -679
  493. package/src/tools/property-dictionary.ts +0 -98
  494. package/src/tools/sequence.ts +0 -385
  495. package/src/tools/tool-definition-utils.ts +0 -35
  496. package/src/tools/ui.ts +0 -452
  497. package/src/types/automation-responses.ts +0 -119
  498. package/src/types/env.ts +0 -17
  499. package/src/types/handler-types.ts +0 -442
  500. package/src/types/responses.ts +0 -355
  501. package/src/types/tool-interfaces.ts +0 -250
  502. package/src/types/tool-types.ts +0 -575
  503. package/src/unreal-bridge.ts +0 -693
  504. package/src/utils/command-validator.ts +0 -139
  505. package/src/utils/elicitation.ts +0 -132
  506. package/src/utils/error-handler.ts +0 -287
  507. package/src/utils/ini-reader.ts +0 -86
  508. package/src/utils/logger.ts +0 -35
  509. package/src/utils/normalize.test.ts +0 -162
  510. package/src/utils/normalize.ts +0 -146
  511. package/src/utils/path-security.ts +0 -43
  512. package/src/utils/response-factory.ts +0 -44
  513. package/src/utils/response-validator.ts +0 -395
  514. package/src/utils/result-helpers.ts +0 -195
  515. package/src/utils/safe-json.test.ts +0 -90
  516. package/src/utils/safe-json.ts +0 -70
  517. package/src/utils/unreal-command-queue.ts +0 -166
  518. package/src/utils/validation.test.ts +0 -184
  519. package/src/utils/validation.ts +0 -312
  520. package/src/wasm/index.ts +0 -838
  521. package/test-server.mjs +0 -100
  522. package/tests/test-animation.mjs +0 -369
  523. package/tests/test-asset-advanced.mjs +0 -82
  524. package/tests/test-asset-graph.mjs +0 -311
  525. package/tests/test-audio.mjs +0 -417
  526. package/tests/test-automation-timeouts.mjs +0 -98
  527. package/tests/test-behavior-tree.mjs +0 -444
  528. package/tests/test-blueprint-graph.mjs +0 -410
  529. package/tests/test-blueprint.mjs +0 -577
  530. package/tests/test-client-mode.mjs +0 -86
  531. package/tests/test-console-command.mjs +0 -56
  532. package/tests/test-control-actor.mjs +0 -425
  533. package/tests/test-control-editor.mjs +0 -112
  534. package/tests/test-graphql.mjs +0 -372
  535. package/tests/test-input.mjs +0 -349
  536. package/tests/test-inspect.mjs +0 -302
  537. package/tests/test-landscape.mjs +0 -316
  538. package/tests/test-lighting.mjs +0 -428
  539. package/tests/test-manage-asset.mjs +0 -438
  540. package/tests/test-manage-level.mjs +0 -89
  541. package/tests/test-materials.mjs +0 -356
  542. package/tests/test-niagara.mjs +0 -185
  543. package/tests/test-no-inline-python.mjs +0 -122
  544. package/tests/test-performance.mjs +0 -539
  545. package/tests/test-plugin-handshake.mjs +0 -82
  546. package/tests/test-runner.mjs +0 -993
  547. package/tests/test-sequence.mjs +0 -104
  548. package/tests/test-system.mjs +0 -96
  549. package/tests/test-wasm.mjs +0 -283
  550. package/tests/test-world-partition.mjs +0 -215
  551. package/tsconfig.json +0 -56
  552. package/vitest.config.ts +0 -35
  553. package/wasm/Cargo.lock +0 -363
  554. package/wasm/Cargo.toml +0 -42
  555. package/wasm/LICENSE +0 -21
  556. package/wasm/README.md +0 -253
  557. package/wasm/src/dependency_resolver.rs +0 -377
  558. package/wasm/src/lib.rs +0 -153
  559. package/wasm/src/property_parser.rs +0 -271
  560. package/wasm/src/transform_math.rs +0 -396
  561. package/wasm/tests/integration.rs +0 -109
@@ -1,124 +0,0 @@
1
- import { cleanObject } from '../../utils/safe-json.js';
2
- import { ITools } from '../../types/tool-interfaces.js';
3
- import type { EditorArgs } from '../../types/handler-types.js';
4
- import { executeAutomationRequest, requireNonEmptyString } from './common-handlers.js';
5
-
6
- export async function handleEditorTools(action: string, args: EditorArgs, tools: ITools) {
7
- switch (action) {
8
- case 'play': {
9
- const res = await tools.editorTools.playInEditor(args.timeoutMs);
10
- return cleanObject(res);
11
- }
12
- case 'stop':
13
- case 'stop_pie': {
14
- const res = await tools.editorTools.stopPlayInEditor();
15
- return cleanObject(res);
16
- }
17
- case 'eject': {
18
- const inPie = await tools.editorTools.isInPIE();
19
- if (!inPie) {
20
- throw new Error('Cannot eject while not in PIE');
21
- }
22
- return await executeAutomationRequest(tools, 'control_editor', { action: 'eject' });
23
- }
24
- case 'possess': {
25
- const inPie = await tools.editorTools.isInPIE();
26
- if (!inPie) {
27
- throw new Error('Cannot possess actor while not in PIE');
28
- }
29
- return await executeAutomationRequest(tools, 'control_editor', args);
30
- }
31
- case 'pause': {
32
- const res = await tools.editorTools.pausePlayInEditor();
33
- return cleanObject(res);
34
- }
35
- case 'resume': {
36
- const res = await tools.editorTools.resumePlayInEditor();
37
- return cleanObject(res);
38
- }
39
- case 'screenshot': {
40
- const res = await tools.editorTools.takeScreenshot(args.filename, args.resolution);
41
- return cleanObject(res);
42
- }
43
- case 'console_command': {
44
- const res = await tools.editorTools.executeConsoleCommand(args.command ?? '');
45
- return cleanObject(res);
46
- }
47
- case 'set_camera': {
48
- const res = await tools.editorTools.setViewportCamera(args.location, args.rotation);
49
- return cleanObject(res);
50
- }
51
- case 'start_recording': {
52
- // Use console command as fallback if bridge doesn't support it
53
- const filename = args.filename || 'TestRecording';
54
- await tools.editorTools.executeConsoleCommand(`DemoRec ${filename}`);
55
- return { success: true, message: `Started recording to ${filename}`, action: 'start_recording' };
56
- }
57
- case 'stop_recording': {
58
- await tools.editorTools.executeConsoleCommand('DemoStop');
59
- return { success: true, message: 'Stopped recording', action: 'stop_recording' };
60
- }
61
- case 'step_frame': {
62
- // Use console command for single frame advance
63
- await tools.editorTools.executeConsoleCommand('r.SingleFrameAdvance 1');
64
- return { success: true, message: 'Stepped frame', action: 'step_frame' };
65
- }
66
- case 'create_bookmark': {
67
- const idx = parseInt(args.bookmarkName ?? '0') || 0;
68
- await tools.editorTools.executeConsoleCommand(`r.SetBookmark ${idx}`);
69
- return { success: true, message: `Created bookmark ${idx}`, action: 'create_bookmark' };
70
- }
71
- case 'jump_to_bookmark': {
72
- const idx = parseInt(args.bookmarkName ?? '0') || 0;
73
- await tools.editorTools.executeConsoleCommand(`r.JumpToBookmark ${idx}`);
74
- return { success: true, message: `Jumped to bookmark ${idx}`, action: 'jump_to_bookmark' };
75
- }
76
- case 'set_preferences': {
77
- const res = await tools.editorTools.setEditorPreferences(args.category ?? '', args.preferences ?? {});
78
- return cleanObject(res);
79
- }
80
- case 'open_asset': {
81
- const assetPath = requireNonEmptyString(args.assetPath || args.path, 'assetPath');
82
- const res = await executeAutomationRequest(tools, 'control_editor', { action: 'open_asset', assetPath });
83
- return cleanObject(res);
84
- }
85
- case 'execute_command': {
86
- const command = requireNonEmptyString(args.command, 'command');
87
- const res = await tools.editorTools.executeConsoleCommand(command);
88
- return { ...cleanObject(res), action: 'execute_command' };
89
- }
90
- case 'set_camera_fov': {
91
- await tools.editorTools.executeConsoleCommand(`fov ${args.fov}`);
92
- return { success: true, message: `Set FOV to ${args.fov}`, action: 'set_camera_fov' };
93
- }
94
- case 'set_game_speed': {
95
- await tools.editorTools.executeConsoleCommand(`slomo ${args.speed}`);
96
- return { success: true, message: `Set game speed to ${args.speed}`, action: 'set_game_speed' };
97
- }
98
- case 'set_view_mode': {
99
- const viewMode = requireNonEmptyString(args.viewMode, 'viewMode');
100
- const validModes = [
101
- 'Lit', 'Unlit', 'Wireframe', 'DetailLighting', 'LightingOnly', 'Reflections',
102
- 'OptimizationViewmodes', 'ShaderComplexity', 'LightmapDensity', 'StationaryLightOverlap', 'LightComplexity',
103
- 'PathTracing', 'Visualizer', 'LODColoration', 'CollisionPawn', 'CollisionVisibility'
104
- ];
105
- if (!validModes.includes(viewMode)) {
106
- throw new Error(`unknown_viewmode: ${viewMode}. Must be one of: ${validModes.join(', ')}`);
107
- }
108
- await tools.editorTools.executeConsoleCommand(`viewmode ${viewMode}`);
109
- return { success: true, message: `Set view mode to ${viewMode}`, action: 'set_view_mode' };
110
- }
111
- case 'set_viewport_resolution': {
112
- await tools.editorTools.executeConsoleCommand(`r.SetRes ${args.width}x${args.height}`);
113
- return { success: true, message: `Set viewport resolution to ${args.width}x${args.height}`, action: 'set_viewport_resolution' };
114
- }
115
- case 'set_viewport_realtime': {
116
- const enabled = args.enabled !== undefined ? args.enabled : (args.realtime !== false);
117
- // Use console command since interface doesn't have setViewportRealtime
118
- await tools.editorTools.executeConsoleCommand(`r.ViewportRealtime ${enabled ? 1 : 0}`);
119
- return { success: true, message: `Set viewport realtime to ${enabled}`, action: 'set_viewport_realtime' };
120
- }
121
- default:
122
- return await executeAutomationRequest(tools, 'control_editor', args);
123
- }
124
- }
@@ -1,224 +0,0 @@
1
- import { cleanObject } from '../../utils/safe-json.js';
2
- import { ITools } from '../../types/tool-interfaces.js';
3
- import { executeAutomationRequest, requireNonEmptyString } from './common-handlers.js';
4
-
5
- function ensureActionAndSubAction(action: string, args: any) {
6
- if (!args || typeof args !== 'object') return;
7
- // Many callers pass the tool action as the action name (e.g. "niagara") and
8
- // omit args.action; the native handler requires subAction.
9
- if (!args.action) {
10
- args.action = action;
11
- }
12
- if (!args.subAction) {
13
- args.subAction = args.action;
14
- }
15
- }
16
-
17
- function isNonEmptyString(val: unknown): val is string {
18
- return typeof val === 'string' && val.trim().length > 0;
19
- }
20
-
21
- export async function handleEffectTools(action: string, args: any, tools: ITools) {
22
- if (!args || typeof args !== 'object') {
23
- args = {};
24
- }
25
-
26
- // Always ensure action/subAction are present before any routing.
27
- ensureActionAndSubAction(action, args);
28
-
29
- // Handle creation actions explicitly to use NiagaraTools helper
30
- if (action === 'create_niagara_system') {
31
- const res = await tools.niagaraTools.createSystem({
32
- name: args.name,
33
- savePath: args.savePath,
34
- template: args.template
35
- });
36
- return cleanObject(res);
37
- }
38
- if (action === 'create_niagara_emitter') {
39
- const res = await tools.niagaraTools.createEmitter({
40
- name: args.name,
41
- savePath: args.savePath,
42
- systemPath: args.systemPath,
43
- template: args.template
44
- });
45
- return cleanObject(res);
46
- }
47
-
48
- // Pre-process arguments for particle presets
49
- if (args.action === 'particle') {
50
- const presets: Record<string, string> = {
51
- 'Default': '/StarterContent/Particles/P_Steam_Lit.P_Steam_Lit',
52
- 'Smoke': '/StarterContent/Particles/P_Smoke.P_Smoke',
53
- 'Fire': '/StarterContent/Particles/P_Fire.P_Fire',
54
- 'Explosion': '/StarterContent/Particles/P_Explosion.P_Explosion',
55
- };
56
- // Check both preset and effectType fields
57
- const key = args.preset || args.effectType;
58
- if (key && presets[key]) {
59
- args.preset = presets[key];
60
- }
61
- }
62
-
63
- // Handle debug shapes (must happen before any automation request)
64
- if (action === 'debug_shape' || args.action === 'debug_shape') {
65
- // Map 'shape' to 'shapeType' if provided (schema uses 'shape', C++ uses 'shapeType')
66
- if (args.shape && !args.shapeType) {
67
- args.shapeType = args.shape;
68
- }
69
- requireNonEmptyString(args.shapeType, 'shapeType', 'Missing required parameter: shapeType');
70
- args.action = 'debug_shape';
71
- args.subAction = 'debug_shape';
72
- return cleanObject(await executeAutomationRequest(tools, 'create_effect', args));
73
- }
74
-
75
- // Validate Niagara-related required parameters (keep errors explicit and early)
76
- const subAction = String(args.subAction || '').trim();
77
- if (subAction === 'niagara' || subAction === 'spawn_niagara') {
78
- requireNonEmptyString(args.systemPath, 'systemPath', 'Missing required parameter: systemPath');
79
- }
80
-
81
- if (subAction === 'activate_niagara' || subAction === 'deactivate_niagara' || subAction === 'advance_simulation') {
82
- const systemName = args.systemName ?? args.actorName;
83
- requireNonEmptyString(systemName, 'systemName', 'Missing required parameter: systemName (or actorName)');
84
- args.systemName = systemName;
85
- }
86
-
87
- if (subAction === 'set_niagara_parameter') {
88
- const systemName = args.systemName ?? args.actorName;
89
- requireNonEmptyString(systemName, 'systemName', 'Missing required parameter: systemName (or actorName)');
90
- requireNonEmptyString(args.parameterName, 'parameterName', 'Missing required parameter: parameterName');
91
- // parameterType is required for unambiguous native conversion; accept common aliases.
92
- if (!isNonEmptyString(args.parameterType) && isNonEmptyString(args.type)) {
93
- args.parameterType = args.type.charAt(0).toUpperCase() + args.type.slice(1);
94
- }
95
- requireNonEmptyString(args.parameterType, 'parameterType', 'Missing required parameter: parameterType');
96
- args.systemName = systemName;
97
- }
98
-
99
- // Handle debug cleanup actions
100
- if (action === 'clear_debug_shapes') {
101
- return executeAutomationRequest(tools, action, args);
102
- }
103
- // Discovery action: list available debug shape types
104
- if (action === 'list_debug_shapes') {
105
- return executeAutomationRequest(tools, 'list_debug_shapes', args);
106
- }
107
- if (action === 'cleanup') {
108
- args.action = 'cleanup';
109
- args.subAction = 'cleanup';
110
- return executeAutomationRequest(tools, 'create_effect', args);
111
- }
112
-
113
- // Map high-level actions to create_effect with subAction
114
- const createActions = [
115
- 'create_volumetric_fog',
116
- 'create_particle_trail',
117
- 'create_environment_effect',
118
- 'create_impact_effect',
119
- 'create_niagara_ribbon'
120
- ];
121
- if (createActions.includes(action)) {
122
- args.action = action;
123
- return executeAutomationRequest(tools, 'create_effect', args);
124
- }
125
-
126
- // Map simulation control actions
127
- if (action === 'activate' || action === 'activate_effect') {
128
- args.action = 'activate_niagara';
129
- args.systemName = args.actorName || args.systemName;
130
- requireNonEmptyString(args.systemName, 'systemName', 'Missing required parameter: systemName (or actorName)');
131
- args.reset = true;
132
- return executeAutomationRequest(tools, 'create_effect', args);
133
- }
134
- if (action === 'deactivate') {
135
- args.action = 'deactivate_niagara';
136
- args.systemName = args.actorName || args.systemName;
137
- requireNonEmptyString(args.systemName, 'systemName', 'Missing required parameter: systemName (or actorName)');
138
- return executeAutomationRequest(tools, 'create_effect', args);
139
- }
140
- if (action === 'reset') {
141
- args.action = 'activate_niagara';
142
- args.systemName = args.actorName || args.systemName;
143
- requireNonEmptyString(args.systemName, 'systemName', 'Missing required parameter: systemName (or actorName)');
144
- args.reset = true;
145
- return executeAutomationRequest(tools, 'create_effect', args);
146
- }
147
- if (action === 'advance_simulation') {
148
- args.action = 'advance_simulation';
149
- args.systemName = args.actorName || args.systemName;
150
- requireNonEmptyString(args.systemName, 'systemName', 'Missing required parameter: systemName (or actorName)');
151
- return executeAutomationRequest(tools, 'create_effect', args);
152
- }
153
-
154
- // Map parameter setting
155
- if (action === 'set_niagara_parameter') {
156
- args.action = 'set_niagara_parameter';
157
- // If actorName is provided, use it as systemName (which C++ expects for actor label)
158
- if (args.actorName && !args.systemName) {
159
- args.systemName = args.actorName;
160
- }
161
- // Map 'type' to 'parameterType' if provided and parameterType is missing
162
- if (args.type && !args.parameterType) {
163
- args.parameterType = args.type.charAt(0).toUpperCase() + args.type.slice(1);
164
- }
165
- requireNonEmptyString(args.systemName, 'systemName', 'Missing required parameter: systemName (or actorName)');
166
- requireNonEmptyString(args.parameterName, 'parameterName', 'Missing required parameter: parameterName');
167
- requireNonEmptyString(args.parameterType, 'parameterType', 'Missing required parameter: parameterType');
168
- return executeAutomationRequest(tools, 'create_effect', args);
169
- }
170
-
171
- const res: any = await executeAutomationRequest(
172
- tools,
173
- 'create_effect',
174
- args,
175
- 'Automation bridge not available for effect creation operations'
176
- );
177
-
178
- const result = res?.result ?? res ?? {};
179
- const topError = typeof res?.error === 'string' ? res.error : '';
180
- const nestedError = typeof result.error === 'string' ? result.error : '';
181
- const errorCode = (topError || nestedError).toUpperCase();
182
-
183
- const topMessage = typeof res?.message === 'string' ? res.message : '';
184
- const nestedMessage = typeof result.message === 'string' ? result.message : '';
185
- const message = topMessage || nestedMessage || '';
186
-
187
- const combined = `${topError} ${nestedError} ${message}`.toLowerCase();
188
-
189
- if (
190
- action === 'niagara' &&
191
- (
192
- errorCode === 'SYSTEM_NOT_FOUND' ||
193
- combined.includes('niagara system not found') ||
194
- combined.includes('system asset not found')
195
- )
196
- ) {
197
- return cleanObject({
198
- success: false,
199
- error: 'SYSTEM_NOT_FOUND',
200
- message: message || 'Niagara system not found',
201
- systemPath: args.systemPath,
202
- handled: true
203
- });
204
- }
205
-
206
- // If we got here and it was a spawn_niagara failure, maybe try to be helpful about paths
207
- if (action === 'spawn_niagara' && errorCode === 'SYSTEM_NOT_FOUND' && args.systemPath) {
208
- // Check if path ends in .Name
209
- const path = args.systemPath;
210
- const name = path.split('/').pop();
211
- if (name && !path.endsWith(`.${name}`)) {
212
- // Retry with corrected path?
213
- // We can't easily retry here without recursion, but we can hint in the message.
214
- return cleanObject({
215
- success: false,
216
- error: 'SYSTEM_NOT_FOUND',
217
- message: `Niagara System not found at ${path}. Did you mean ${path}.${name}?`,
218
- systemPath: path
219
- });
220
- }
221
- }
222
-
223
- return cleanObject(res);
224
- }
@@ -1,183 +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 handleEnvironmentTools(action: string, args: any, tools: ITools) {
6
- const envAction = String(action || '').toLowerCase();
7
- switch (envAction) {
8
- case 'create_landscape':
9
- return cleanObject(await tools.landscapeTools.createLandscape({
10
- name: args.name,
11
- location: args.location,
12
- sizeX: args.sizeX,
13
- sizeY: args.sizeY,
14
- quadsPerSection: args.quadsPerSection,
15
- sectionsPerComponent: args.sectionsPerComponent,
16
- componentCount: args.componentCount,
17
- materialPath: args.materialPath,
18
- enableWorldPartition: args.enableWorldPartition,
19
- runtimeGrid: args.runtimeGrid,
20
- isSpatiallyLoaded: args.isSpatiallyLoaded,
21
- dataLayers: args.dataLayers
22
- }));
23
- case 'modify_heightmap':
24
- return cleanObject(await tools.landscapeTools.modifyHeightmap({
25
- landscapeName: args.landscapeName || args.name,
26
- heightData: args.heightData,
27
- minX: args.minX,
28
- minY: args.minY,
29
- maxX: args.maxX,
30
- maxY: args.maxY,
31
- updateNormals: args.updateNormals
32
- }));
33
- case 'sculpt':
34
- case 'sculpt_landscape': {
35
- // Default to 'Raise' tool if not specified
36
- const tool = args.tool || 'Raise';
37
- return cleanObject(await tools.landscapeTools.sculptLandscape({
38
- landscapeName: args.landscapeName || args.name,
39
- tool,
40
- location: args.location,
41
- radius: args.radius || 500,
42
- strength: args.strength || 0.5
43
- }));
44
- }
45
- case 'add_foliage': {
46
- // Check if this is adding a foliage TYPE (has meshPath) or INSTANCES (has locations/position)
47
- if (args.meshPath) {
48
- // Derive a better default name from mesh path if not provided
49
- const defaultName = args.meshPath.split('/').pop()?.split('.')[0] + '_Foliage_Type';
50
- return cleanObject(await tools.foliageTools.addFoliageType({
51
- name: args.foliageType || args.name || defaultName,
52
- meshPath: args.meshPath,
53
- density: args.density
54
- }));
55
- } else {
56
- // Validate foliageType is provided
57
- const foliageType = args.foliageType || args.foliageTypePath;
58
- if (!foliageType) {
59
- return cleanObject({
60
- success: false,
61
- error: 'INVALID_ARGUMENT',
62
- message: 'add_foliage requires either: (1) meshPath to create a new foliage type, or (2) foliageType/foliageTypePath to place instances of an existing type. Example foliage assets: /Game/StarterContent/Props/SM_Bush, /Engine/BasicShapes/Sphere'
63
- });
64
- }
65
-
66
- // Support location+radius to generate locations if explicit array not provided
67
- let locations = args.locations;
68
- if (!locations && args.location && args.radius) {
69
- // Generate locations around the center point within radius
70
- const center = args.location;
71
- const radius = args.radius || 500;
72
- const count = args.density || args.count || 10;
73
- locations = [];
74
- for (let i = 0; i < count; i++) {
75
- const angle = Math.random() * Math.PI * 2;
76
- const dist = Math.random() * radius;
77
- locations.push({
78
- x: (center.x || 0) + Math.cos(angle) * dist,
79
- y: (center.y || 0) + Math.sin(angle) * dist,
80
- z: center.z || 0
81
- });
82
- }
83
- } else if (!locations && args.position) {
84
- locations = [args.position];
85
- }
86
-
87
- // Validate we have locations to place
88
- if (!locations || locations.length === 0) {
89
- return cleanObject({
90
- success: false,
91
- error: 'INVALID_ARGUMENT',
92
- message: 'add_foliage requires locations to place foliage instances. Provide: locations array, or location+radius, or position'
93
- });
94
- }
95
-
96
- return cleanObject(await tools.foliageTools.addFoliage({
97
- foliageType,
98
- locations
99
- }));
100
- }
101
- }
102
-
103
- case 'add_foliage_instances':
104
- return cleanObject(await tools.foliageTools.addFoliageInstances({
105
- foliageType: args.foliageType || args.foliageTypePath || args.meshPath,
106
- transforms: args.transforms || (args.locations ? args.locations.map((l: any) => ({ location: [l.x, l.y, l.z] })) : [])
107
- }));
108
- case 'paint_foliage':
109
- return cleanObject(await tools.foliageTools.paintFoliage({
110
- foliageType: args.foliageType || args.foliageTypePath,
111
- position: args.position || args.location, // Handle both
112
- brushSize: args.brushSize || args.radius,
113
- paintDensity: args.density || args.strength, // Map strength/density
114
- eraseMode: args.eraseMode
115
- }));
116
- case 'create_procedural_terrain':
117
- return cleanObject(await tools.landscapeTools.createProceduralTerrain({
118
- name: args.name,
119
- location: args.location,
120
- subdivisions: args.subdivisions,
121
- settings: args.settings
122
- }));
123
- case 'create_procedural_foliage':
124
- return cleanObject(await tools.foliageTools.createProceduralFoliage({
125
- name: args.name,
126
- foliageTypes: args.foliageTypes,
127
- volumeName: args.volumeName,
128
- bounds: args.bounds,
129
- seed: args.seed,
130
- tileSize: args.tileSize
131
- }));
132
-
133
- case 'bake_lightmap':
134
- return cleanObject(await tools.lightingTools.buildLighting({
135
- quality: (args.quality as any) || 'Preview',
136
- buildOnlySelected: false,
137
- buildReflectionCaptures: false
138
- }));
139
- case 'create_landscape_grass_type':
140
- return cleanObject(await tools.landscapeTools.createLandscapeGrassType({
141
- name: args.name,
142
- // Prefer explicit meshPath used by tests, fall back to path/staticMesh for
143
- // compatibility with older callers.
144
- meshPath: args.meshPath || args.path || args.staticMesh,
145
- path: args.path,
146
- staticMesh: args.staticMesh
147
- }));
148
- case 'export_snapshot':
149
- return cleanObject(await tools.environmentTools.exportSnapshot({
150
- path: args.path,
151
- filename: args.filename
152
- }));
153
- case 'import_snapshot':
154
- return cleanObject(await tools.environmentTools.importSnapshot({
155
- path: args.path,
156
- filename: args.filename
157
- }));
158
- case 'set_landscape_material':
159
- return cleanObject(await tools.landscapeTools.setLandscapeMaterial({
160
- landscapeName: args.landscapeName || args.name,
161
- materialPath: args.materialPath
162
- }));
163
- case 'generate_lods':
164
- return cleanObject(await executeAutomationRequest(tools, 'build_environment', {
165
- action: 'generate_lods',
166
- assetPaths: args.assetPaths || args.assets || (args.path ? [args.path] : []),
167
- numLODs: args.numLODs
168
- }, 'Bridge unavailable'));
169
- case 'delete': {
170
- const names = Array.isArray(args.names)
171
- ? args.names
172
- : (Array.isArray(args.actors) ? args.actors : []);
173
- if (args.name) {
174
- names.push(args.name);
175
- }
176
- const res = await tools.environmentTools.cleanup({ names });
177
- return cleanObject(res);
178
- }
179
- default:
180
- const res = await executeAutomationRequest(tools, 'build_environment', args, 'Automation bridge not available for environment building operations');
181
- return cleanObject(res);
182
- }
183
- }
@@ -1,117 +0,0 @@
1
- import { cleanObject } from '../../utils/safe-json.js';
2
- import { ITools } from '../../types/tool-interfaces.js';
3
- import type { GraphArgs } from '../../types/handler-types.js';
4
- import { executeAutomationRequest } from './common-handlers.js';
5
-
6
- export async function handleGraphTools(toolName: string, action: string, args: GraphArgs, tools: ITools) {
7
- // Common validation
8
- if (!args.assetPath && !args.blueprintPath && !args.systemPath) {
9
- // Some actions might not need a path if they operate on "currently open" asset,
10
- // but generally we want an asset path.
11
- }
12
-
13
- // Dispatch based on tool name
14
- switch (toolName) {
15
- case 'manage_blueprint_graph':
16
- return handleBlueprintGraph(action, args, tools);
17
- case 'manage_niagara_graph':
18
- return handleNiagaraGraph(action, args, tools);
19
- case 'manage_material_graph':
20
- return handleMaterialGraph(action, args, tools);
21
- case 'manage_behavior_tree':
22
- return handleBehaviorTree(action, args, tools);
23
- default:
24
- throw new Error(`Unknown graph tool: ${toolName}`);
25
- }
26
- }
27
-
28
- async function handleBlueprintGraph(action: string, args: GraphArgs, tools: ITools) {
29
- const processedArgs = { ...args, subAction: action };
30
-
31
- // Default graphName
32
- if (!processedArgs.graphName) {
33
- processedArgs.graphName = 'EventGraph';
34
- }
35
-
36
- // Fix Issue 1: Map FunctionCall to CallFunction
37
- if (processedArgs.nodeType === 'FunctionCall') {
38
- processedArgs.nodeType = 'CallFunction';
39
- }
40
-
41
- // Fix Issue 2 & 3: Map memberName to specific names based on nodeType
42
- if (processedArgs.memberName) {
43
- if (processedArgs.nodeType === 'VariableGet' || processedArgs.nodeType === 'VariableSet') {
44
- if (!processedArgs.variableName) processedArgs.variableName = processedArgs.memberName;
45
- } else if (processedArgs.nodeType === 'Event' || processedArgs.nodeType === 'CustomEvent' || (processedArgs.nodeType && processedArgs.nodeType.startsWith('K2Node_Event'))) {
46
- if (!processedArgs.eventName) processedArgs.eventName = processedArgs.memberName;
47
- // CustomEvent uses eventName (mapped to CustomFunctionName) or customEventName in some contexts,
48
- // but C++ CustomEvent handler uses 'eventName' payload field.
49
- } else if (processedArgs.nodeType === 'CallFunction' || processedArgs.nodeType === 'K2Node_CallFunction') {
50
- // C++ uses 'memberName' for CallFunction, so this is fine.
51
- }
52
- }
53
-
54
- // Fix Issue 5: Map memberClass/componentClass to targetClass for Cast nodes
55
- if ((processedArgs.memberClass || processedArgs.componentClass) &&
56
- (processedArgs.nodeType === 'Cast' || (processedArgs.nodeType && processedArgs.nodeType.startsWith('CastTo')))) {
57
- if (!processedArgs.targetClass) processedArgs.targetClass = processedArgs.memberClass || processedArgs.componentClass;
58
- }
59
-
60
- // Fix Issue 6: Support connect_pins parameter mapping
61
- // Input: nodeId, pinName, linkedTo (TargetNode.Pin)
62
- if (action === 'connect_pins') {
63
- // Map source
64
- if (!processedArgs.fromNodeId && processedArgs.nodeId) {
65
- processedArgs.fromNodeId = processedArgs.nodeId;
66
- }
67
- if (!processedArgs.fromPinName && processedArgs.pinName) {
68
- processedArgs.fromPinName = processedArgs.pinName;
69
- }
70
-
71
- // Map target from linkedTo
72
- if (!processedArgs.toNodeId && processedArgs.linkedTo) {
73
- if (processedArgs.linkedTo.includes('.')) {
74
- const parts = processedArgs.linkedTo.split('.');
75
- processedArgs.toNodeId = parts[0];
76
- processedArgs.toPinName = parts.slice(1).join('.');
77
- }
78
- }
79
- }
80
-
81
- // Support Node.Pin format for connect_pins (existing logic preserved/enhanced)
82
- if (action === 'connect_pins') {
83
- if (processedArgs.fromNodeId && processedArgs.fromNodeId.includes('.') && !processedArgs.fromPinName) {
84
- const parts = processedArgs.fromNodeId.split('.');
85
- processedArgs.fromNodeId = parts[0];
86
- processedArgs.fromPinName = parts.slice(1).join('.');
87
- }
88
- if (processedArgs.toNodeId && processedArgs.toNodeId.includes('.') && !processedArgs.toPinName) {
89
- const parts = processedArgs.toNodeId.split('.');
90
- processedArgs.toNodeId = parts[0];
91
- processedArgs.toPinName = parts.slice(1).join('.');
92
- }
93
- }
94
-
95
- const res: any = await executeAutomationRequest(tools, 'manage_blueprint_graph', processedArgs, 'Automation bridge not available');
96
- return cleanObject({ ...res, ...(res.result || {}) });
97
- }
98
-
99
- async function handleNiagaraGraph(action: string, args: GraphArgs, tools: ITools) {
100
- const payload = { ...args, subAction: action };
101
- // Map systemPath to assetPath if missing
102
- if (payload.systemPath && !payload.assetPath) {
103
- payload.assetPath = payload.systemPath;
104
- }
105
- const res: any = await executeAutomationRequest(tools, 'manage_niagara_graph', payload, 'Automation bridge not available');
106
- return cleanObject({ ...res, ...(res.result || {}) });
107
- }
108
-
109
- async function handleMaterialGraph(action: string, args: GraphArgs, tools: ITools) {
110
- const res: any = await executeAutomationRequest(tools, 'manage_material_graph', { ...args, subAction: action }, 'Automation bridge not available');
111
- return cleanObject({ ...res, ...(res.result || {}) });
112
- }
113
-
114
- async function handleBehaviorTree(action: string, args: GraphArgs, tools: ITools) {
115
- const res: any = await executeAutomationRequest(tools, 'manage_behavior_tree', { ...args, subAction: action }, 'Automation bridge not available');
116
- return cleanObject({ ...res, ...(res.result || {}) });
117
- }
@@ -1,28 +0,0 @@
1
- import { ITools } from '../../types/tool-interfaces.js';
2
- import { cleanObject } from '../../utils/safe-json.js';
3
- import { ResponseFactory } from '../../utils/response-factory.js';
4
- import { InputTools } from '../input.js';
5
-
6
- export async function handleInputTools(
7
- action: string,
8
- args: any,
9
- tools: ITools
10
- ) {
11
- const inputTools = tools.inputTools as InputTools;
12
- if (!inputTools) {
13
- return ResponseFactory.error('Input tools not available');
14
- }
15
-
16
- switch (action) {
17
- case 'create_input_action':
18
- return cleanObject(await inputTools.createInputAction(args.name, args.path));
19
- case 'create_input_mapping_context':
20
- return cleanObject(await inputTools.createInputMappingContext(args.name, args.path));
21
- case 'add_mapping':
22
- return cleanObject(await inputTools.addMapping(args.contextPath, args.actionPath, args.key));
23
- case 'remove_mapping':
24
- return cleanObject(await inputTools.removeMapping(args.contextPath, args.actionPath));
25
- default:
26
- return ResponseFactory.error(`Unknown input action: ${action}`);
27
- }
28
- }