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,622 +0,0 @@
1
- // Debug visualization tools for Unreal Engine
2
- // Uses Automation Bridge and console commands for all operations
3
-
4
- import { UnrealBridge } from '../unreal-bridge.js';
5
- import { AutomationBridge } from '../automation/index.js';
6
-
7
- export class DebugVisualizationTools {
8
- private bridge: UnrealBridge;
9
- private automationBridge?: AutomationBridge;
10
-
11
- constructor(bridge: UnrealBridge) {
12
- this.bridge = bridge;
13
- }
14
-
15
- setAutomationBridge(automationBridge: AutomationBridge) {
16
- this.automationBridge = automationBridge;
17
- }
18
-
19
- // Helper to use Automation Bridge for debug operations
20
- private async useAutomationBridge(action: string, params: any) {
21
- if (!this.automationBridge) {
22
- return { success: false, error: 'AUTOMATION_BRIDGE_NOT_AVAILABLE', message: 'Automation Bridge not available for debug operations' };
23
- }
24
-
25
- try {
26
- const response = await this.automationBridge.sendAutomationRequest('create_effect', {
27
- action: 'debug_shape',
28
- shapeType: action,
29
- ...params
30
- });
31
- return response;
32
- } catch (error) {
33
- return { success: false, error: 'AUTOMATION_BRIDGE_ERROR', message: String(error) };
34
- }
35
- }
36
-
37
- // Draw debug line using Automation Bridge
38
- async drawDebugLine(params: {
39
- start: [number, number, number];
40
- end: [number, number, number];
41
- color?: [number, number, number, number];
42
- duration?: number;
43
- thickness?: number;
44
- }) {
45
- const color = params.color || [255, 0, 0, 255];
46
- const duration = params.duration ?? 5.0;
47
- const thickness = params.thickness ?? 1.0;
48
-
49
- // Try Automation Bridge first
50
- const result = await this.useAutomationBridge('line', {
51
- start: params.start,
52
- end: params.end,
53
- color,
54
- duration,
55
- thickness
56
- });
57
-
58
- if (result.success) {
59
- return result;
60
- }
61
-
62
- return {
63
- success: false,
64
- error: result.error || 'AUTOMATION_BRIDGE_REQUIRED',
65
- message: result.message || 'Drawing debug lines requires Automation Bridge debug_shape handler',
66
- params: {
67
- start: params.start,
68
- end: params.end,
69
- color,
70
- duration,
71
- thickness
72
- }
73
- };
74
- }
75
-
76
- // Draw debug box using Automation Bridge
77
- async drawDebugBox(params: {
78
- center: [number, number, number];
79
- extent: [number, number, number];
80
- color?: [number, number, number, number];
81
- rotation?: [number, number, number];
82
- duration?: number;
83
- thickness?: number;
84
- }) {
85
- const color = params.color || [0, 255, 0, 255];
86
- const rotation = params.rotation || [0, 0, 0];
87
- const duration = params.duration ?? 5.0;
88
- const thickness = params.thickness ?? 1.0;
89
-
90
- const result = await this.useAutomationBridge('box', {
91
- center: params.center,
92
- extent: params.extent,
93
- rotation,
94
- color,
95
- duration,
96
- thickness
97
- });
98
-
99
- if (result.success) {
100
- return result;
101
- }
102
-
103
- return {
104
- success: false,
105
- error: result.error || 'AUTOMATION_BRIDGE_REQUIRED',
106
- message: result.message || 'Drawing debug boxes requires Automation Bridge debug_shape handler',
107
- params: {
108
- center: params.center,
109
- extent: params.extent,
110
- rotation,
111
- color,
112
- duration,
113
- thickness
114
- }
115
- };
116
- }
117
-
118
- // Draw debug sphere using Automation Bridge
119
- async drawDebugSphere(params: {
120
- center: [number, number, number];
121
- radius: number;
122
- segments?: number;
123
- color?: [number, number, number, number];
124
- duration?: number;
125
- thickness?: number;
126
- }) {
127
- const segments = params.segments ?? 12;
128
- const color = params.color || [0, 0, 255, 255];
129
- const duration = params.duration ?? 5.0;
130
- const thickness = params.thickness ?? 1.0;
131
-
132
- const result = await this.useAutomationBridge('sphere', {
133
- center: params.center,
134
- radius: params.radius,
135
- segments,
136
- color,
137
- duration,
138
- thickness
139
- });
140
-
141
- if (result.success) {
142
- return result;
143
- }
144
-
145
- return {
146
- success: false,
147
- error: result.error || 'AUTOMATION_BRIDGE_REQUIRED',
148
- message: result.message || 'Drawing debug spheres requires Automation Bridge debug_shape handler',
149
- params: {
150
- center: params.center,
151
- radius: params.radius,
152
- segments,
153
- color,
154
- duration,
155
- thickness
156
- }
157
- };
158
- }
159
-
160
- async drawDebugCapsule(params: {
161
- center: [number, number, number];
162
- halfHeight: number;
163
- radius: number;
164
- rotation?: [number, number, number];
165
- color?: [number, number, number, number];
166
- duration?: number;
167
- }) {
168
- const rotation = params.rotation || [0, 0, 0];
169
- const color = params.color || [255, 255, 0, 255];
170
- const duration = params.duration || 5.0;
171
-
172
- const result = await this.useAutomationBridge('capsule', {
173
- center: params.center,
174
- halfHeight: params.halfHeight,
175
- radius: params.radius,
176
- rotation,
177
- color,
178
- duration
179
- });
180
-
181
- if (result.success) {
182
- return result;
183
- }
184
-
185
- return {
186
- success: false,
187
- error: result.error || 'AUTOMATION_BRIDGE_REQUIRED',
188
- message: result.message || 'Drawing debug capsules requires Automation Bridge debug_shape handler',
189
- params: {
190
- center: params.center,
191
- halfHeight: params.halfHeight,
192
- radius: params.radius,
193
- rotation,
194
- color,
195
- duration
196
- }
197
- };
198
- }
199
-
200
- async drawDebugCone(params: {
201
- origin: [number, number, number];
202
- direction: [number, number, number];
203
- length: number;
204
- angleWidth: number;
205
- angleHeight: number;
206
- numSides?: number;
207
- color?: [number, number, number, number];
208
- duration?: number;
209
- }) {
210
- const color = params.color || [255, 0, 255, 255];
211
- const duration = params.duration || 5.0;
212
-
213
- const result = await this.useAutomationBridge('cone', {
214
- origin: params.origin,
215
- direction: params.direction,
216
- length: params.length,
217
- angleWidth: params.angleWidth,
218
- angleHeight: params.angleHeight,
219
- numSides: params.numSides || 12,
220
- color,
221
- duration
222
- });
223
-
224
- if (result.success) {
225
- return result;
226
- }
227
-
228
- return {
229
- success: false,
230
- error: result.error || 'AUTOMATION_BRIDGE_REQUIRED',
231
- message: result.message || 'Drawing debug cones requires Automation Bridge debug_shape handler',
232
- params: {
233
- origin: params.origin,
234
- direction: params.direction,
235
- length: params.length,
236
- angleWidth: params.angleWidth,
237
- angleHeight: params.angleHeight,
238
- numSides: params.numSides || 12,
239
- color,
240
- duration
241
- }
242
- };
243
- }
244
-
245
- async drawDebugString(params: {
246
- location: [number, number, number];
247
- text: string;
248
- color?: [number, number, number, number];
249
- duration?: number;
250
- fontSize?: number;
251
- }) {
252
- const color = params.color || [255, 255, 255, 255];
253
- const duration = params.duration || 5.0;
254
-
255
- const result = await this.useAutomationBridge('string', {
256
- location: params.location,
257
- text: params.text,
258
- color,
259
- duration,
260
- fontSize: params.fontSize
261
- });
262
-
263
- if (result.success) {
264
- return result;
265
- }
266
-
267
- return {
268
- success: false,
269
- error: result.error || 'AUTOMATION_BRIDGE_REQUIRED',
270
- message: result.message || 'Drawing debug strings requires Automation Bridge debug_shape handler',
271
- params: {
272
- location: params.location,
273
- text: params.text,
274
- color,
275
- duration,
276
- fontSize: params.fontSize
277
- }
278
- };
279
- }
280
-
281
- async drawDebugArrow(params: {
282
- start: [number, number, number];
283
- end: [number, number, number];
284
- arrowSize?: number;
285
- color?: [number, number, number, number];
286
- duration?: number;
287
- thickness?: number;
288
- }) {
289
- const color = params.color || [0, 255, 255, 255];
290
- const duration = params.duration || 5.0;
291
- const thickness = params.thickness || 2.0;
292
-
293
- const result = await this.useAutomationBridge('arrow', {
294
- start: params.start,
295
- end: params.end,
296
- arrowSize: params.arrowSize || 10.0,
297
- color,
298
- duration,
299
- thickness
300
- });
301
-
302
- if (result.success) {
303
- return result;
304
- }
305
-
306
- return {
307
- success: false,
308
- error: result.error || 'AUTOMATION_BRIDGE_REQUIRED',
309
- message: result.message || 'Drawing debug arrows requires Automation Bridge debug_shape handler',
310
- params: {
311
- start: params.start,
312
- end: params.end,
313
- arrowSize: params.arrowSize || 10.0,
314
- color,
315
- duration,
316
- thickness
317
- }
318
- };
319
- }
320
-
321
- async drawDebugPoint(params: {
322
- location: [number, number, number];
323
- size?: number;
324
- color?: [number, number, number, number];
325
- duration?: number;
326
- }) {
327
- const size = params.size || 10.0;
328
- const color = params.color || [255, 255, 255, 255];
329
- const duration = params.duration || 5.0;
330
-
331
- const result = await this.useAutomationBridge('point', {
332
- location: params.location,
333
- size,
334
- color,
335
- duration
336
- });
337
-
338
- if (result.success) {
339
- return result;
340
- }
341
-
342
- return {
343
- success: false,
344
- error: result.error || 'AUTOMATION_BRIDGE_REQUIRED',
345
- message: result.message || 'Drawing debug points requires Automation Bridge debug_shape handler',
346
- params: {
347
- location: params.location,
348
- size,
349
- color,
350
- duration
351
- }
352
- };
353
- }
354
-
355
- async drawDebugCoordinateSystem(params: {
356
- location: [number, number, number];
357
- rotation?: [number, number, number];
358
- scale?: number;
359
- duration?: number;
360
- thickness?: number;
361
- }) {
362
- const result = await this.useAutomationBridge('coordinate_system', {
363
- location: params.location,
364
- rotation: params.rotation || [0, 0, 0],
365
- scale: params.scale || 1.0,
366
- duration: params.duration || 5.0,
367
- thickness: params.thickness || 1.0
368
- });
369
-
370
- return result;
371
- }
372
-
373
- async drawDebugFrustum(params: {
374
- origin: [number, number, number];
375
- rotation: [number, number, number];
376
- fov: number;
377
- aspectRatio?: number;
378
- nearPlane?: number;
379
- farPlane?: number;
380
- color?: [number, number, number, number];
381
- duration?: number;
382
- }) {
383
- const aspectRatio = params.aspectRatio || 1.77;
384
- const nearPlane = params.nearPlane || 10.0;
385
- const farPlane = params.farPlane || 1000.0;
386
- const color = params.color || [128, 128, 255, 255];
387
- const duration = params.duration || 5.0;
388
-
389
- const result = await this.useAutomationBridge('frustum', {
390
- origin: params.origin,
391
- rotation: params.rotation,
392
- fov: params.fov,
393
- aspectRatio,
394
- nearPlane,
395
- farPlane,
396
- color,
397
- duration
398
- });
399
-
400
- if (result.success) {
401
- return result;
402
- }
403
-
404
- return {
405
- success: false,
406
- error: result.error || 'AUTOMATION_BRIDGE_REQUIRED',
407
- message: result.message || 'Drawing debug frustums requires Automation Bridge debug_shape handler',
408
- params: {
409
- origin: params.origin,
410
- rotation: params.rotation,
411
- fov: params.fov,
412
- aspectRatio,
413
- nearPlane,
414
- farPlane,
415
- color,
416
- duration
417
- }
418
- };
419
- }
420
-
421
- async clearDebugDrawings() {
422
- if (this.automationBridge) {
423
- const response = await this.automationBridge.sendAutomationRequest('clear_debug_shapes', {});
424
- if (response.success) {
425
- return response;
426
- }
427
- }
428
-
429
- return this.bridge.executeConsoleCommand('FlushPersistentDebugLines');
430
- }
431
-
432
- async showCollision(params: {
433
- enabled: boolean;
434
- type?: 'Simple' | 'Complex' | 'Both';
435
- }) {
436
- const commands: string[] = [];
437
- if (params.enabled) {
438
- const typeCmd = params.type === 'Simple' ? '1' : params.type === 'Complex' ? '2' : '3';
439
- commands.push(`show Collision ${typeCmd}`);
440
- } else {
441
- commands.push('show Collision 0');
442
- }
443
- await this.bridge.executeConsoleCommands(commands);
444
- return { success: true, message: `Collision visualization ${params.enabled ? 'enabled' : 'disabled'}` };
445
- }
446
-
447
- async showBounds(params: { enabled: boolean; }) {
448
- const command = params.enabled ? 'show Bounds' : 'show Bounds 0';
449
- return this.bridge.executeConsoleCommand(command);
450
- }
451
-
452
- async setViewMode(params: {
453
- mode: 'Lit' | 'Unlit' | 'Wireframe' | 'DetailLighting' | 'LightingOnly' | 'LightComplexity' | 'ShaderComplexity' | 'LightmapDensity' | 'StationaryLightOverlap' | 'ReflectionOverride' | 'CollisionPawn' | 'CollisionVisibility';
454
- }) {
455
- // Map non-viewmode requests to appropriate show flags for safety
456
- if (params.mode === 'CollisionPawn' || params.mode === 'CollisionVisibility') {
457
- // Use collision visualization instead of viewmode (UE doesn't have these as view modes)
458
- await this.showCollision({ enabled: true, type: 'Both' });
459
- return { success: true, message: 'Collision visualization enabled (use show flags, not viewmode)' } as any;
460
- }
461
-
462
- const VALID_VIEWMODES = new Set([
463
- 'Lit', 'Unlit', 'Wireframe', 'DetailLighting', 'LightingOnly', 'LightComplexity', 'ShaderComplexity', 'LightmapDensity', 'StationaryLightOverlap', 'ReflectionOverride'
464
- ]);
465
-
466
- if (!VALID_VIEWMODES.has(params.mode)) {
467
- // Fallback to Lit if unknown
468
- await this.bridge.executeConsoleCommand('viewmode Lit');
469
- return { success: false, warning: `Unknown or unsupported viewmode '${params.mode}'. Reverted to Lit.` } as any;
470
- }
471
-
472
- const UNSAFE_VIEWMODES = [
473
- 'LightComplexity', 'ShaderComplexity', 'LightmapDensity', 'StationaryLightOverlap'
474
- ];
475
- if (UNSAFE_VIEWMODES.includes(params.mode)) {
476
- console.error(`⚠️ Viewmode '${params.mode}' may be unstable in some UE configurations.`);
477
- try { await this.bridge.executeConsoleCommand('stop'); } catch { }
478
- await new Promise(resolve => setTimeout(resolve, 100));
479
- }
480
-
481
- try {
482
- const command = `viewmode ${params.mode}`;
483
- const result = await this.bridge.executeConsoleCommand(command);
484
- if (UNSAFE_VIEWMODES.includes(params.mode)) {
485
- setTimeout(async () => {
486
- try { await this.bridge.executeConsoleCommand('stat unit'); }
487
- catch { await this.bridge.executeConsoleCommand('viewmode Lit'); }
488
- }, 2000);
489
- }
490
- return { ...result, warning: UNSAFE_VIEWMODES.includes(params.mode) ? `Viewmode '${params.mode}' applied. This mode may be unstable.` : undefined };
491
- } catch (error) {
492
- await this.bridge.executeConsoleCommand('viewmode Lit');
493
- throw new Error(`Failed to set viewmode '${params.mode}': ${error}. Reverted to Lit mode.`);
494
- }
495
- }
496
-
497
- async showDebugInfo(params: {
498
- category: 'AI' | 'Animation' | 'Audio' | 'Collision' | 'Camera' | 'Game' | 'Hitboxes' | 'Input' | 'Net' | 'Physics' | 'Slate' | 'Streaming' | 'Particles' | 'Navigation';
499
- enabled: boolean;
500
- }) {
501
- const command = `showdebug ${params.enabled ? params.category : 'None'}`;
502
- return this.bridge.executeConsoleCommand(command);
503
- }
504
-
505
- async showActorNames(params: { enabled: boolean; }) {
506
- const command = params.enabled ? 'show ActorNames' : 'show ActorNames 0';
507
- return this.bridge.executeConsoleCommand(command);
508
- }
509
-
510
- async drawDebugPath(params: {
511
- points: Array<[number, number, number]>;
512
- color?: [number, number, number, number];
513
- duration?: number;
514
- thickness?: number;
515
- }) {
516
- const color = params.color || [255, 128, 0, 255];
517
- const duration = params.duration || 5.0;
518
- const thickness = params.thickness || 2.0;
519
-
520
- // Try Automation Bridge for path drawing
521
- const result = await this.useAutomationBridge('path', {
522
- points: params.points,
523
- color,
524
- duration,
525
- thickness
526
- });
527
-
528
- if (result.success) {
529
- return result;
530
- }
531
-
532
- // If Automation Bridge is unavailable or fails, do not claim success
533
- return {
534
- success: false,
535
- error: result.error || 'AUTOMATION_BRIDGE_REQUIRED',
536
- message: result.message || 'Drawing debug paths requires Automation Bridge debug_shape handler',
537
- params: {
538
- points: params.points,
539
- color,
540
- duration,
541
- thickness
542
- }
543
- };
544
- }
545
-
546
- async showNavigationMesh(params: { enabled: boolean; }) {
547
- const command = params.enabled ? 'show Navigation' : 'show Navigation 0';
548
- return this.bridge.executeConsoleCommand(command);
549
- }
550
-
551
- async enableOnScreenMessages(params: {
552
- enabled: boolean;
553
- key?: number;
554
- message?: string;
555
- duration?: number;
556
- color?: [number, number, number, number];
557
- }) {
558
- if (params.enabled && params.message) {
559
- // Use Automation Bridge for on-screen messages
560
- const result = await this.useAutomationBridge('message', {
561
- message: params.message,
562
- duration: params.duration || 5.0,
563
- color: params.color || [255, 255, 255, 255]
564
- });
565
-
566
- if (result.success) {
567
- return result;
568
- }
569
-
570
- return {
571
- success: false,
572
- error: 'AUTOMATION_BRIDGE_REQUIRED',
573
- message: 'Showing on-screen messages requires Automation Bridge'
574
- };
575
- }
576
-
577
- const command = params.enabled ? 'EnableAllScreenMessages' : 'DisableAllScreenMessages';
578
- return this.bridge.executeConsoleCommand(command);
579
- }
580
-
581
- async showSkeletalMeshBones(params: { actorName: string; enabled: boolean; }) {
582
- // Use Automation Bridge for skeletal mesh visualization
583
- const result = await this.useAutomationBridge('skeletal_meshes', {
584
- actorName: params.actorName,
585
- enabled: params.enabled
586
- });
587
-
588
- if (result.success) {
589
- return result;
590
- }
591
-
592
- return {
593
- success: false,
594
- error: 'AUTOMATION_BRIDGE_REQUIRED',
595
- message: 'Showing skeletal mesh bones requires Automation Bridge'
596
- };
597
- }
598
-
599
- async clearDebugShapes() {
600
- if (this.automationBridge) {
601
- const response = await this.automationBridge.sendAutomationRequest('clear_debug_shapes', {});
602
- if (response.success) {
603
- return response;
604
- }
605
- }
606
-
607
- try {
608
- await this.bridge.executeConsoleCommand('FlushPersistentDebugLines');
609
- return { success: true, message: 'Debug shapes cleared' };
610
- } catch (err) {
611
- return { success: false, error: `Failed to clear debug shapes: ${err}` };
612
- }
613
- }
614
-
615
- async listDebugShapes() {
616
- if (this.automationBridge) {
617
- const response = await this.automationBridge.sendAutomationRequest('list_debug_shapes', {});
618
- return response;
619
- }
620
- return { success: false, error: 'AUTOMATION_BRIDGE_REQUIRED', message: 'Listing debug shapes requires Automation Bridge' };
621
- }
622
- }
@@ -1,33 +0,0 @@
1
- import { ITools } from '../types/tool-interfaces.js';
2
-
3
- type ToolHandler = (args: any, tools: ITools) => Promise<any>;
4
-
5
- export class DynamicHandlerRegistry {
6
- private handlers = new Map<string, ToolHandler>();
7
-
8
- register(toolName: string, handler: ToolHandler) {
9
- if (this.handlers.has(toolName)) {
10
- console.warn(`Handler for tool '${toolName}' is being overwritten.`);
11
- }
12
- this.handlers.set(toolName, handler);
13
- }
14
-
15
- getHandler(toolName: string): ToolHandler | undefined {
16
- return this.handlers.get(toolName);
17
- }
18
-
19
- hasHandler(toolName: string): boolean {
20
- return this.handlers.has(toolName);
21
- }
22
-
23
- removeHandler(toolName: string): boolean {
24
- return this.handlers.delete(toolName);
25
- }
26
-
27
- getAllRegisteredTools(): string[] {
28
- return Array.from(this.handlers.keys());
29
- }
30
- }
31
-
32
- // Global registry instance
33
- export const toolRegistry = new DynamicHandlerRegistry();