blockmine 1.24.0 → 1.27.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (476) hide show
  1. package/CHANGELOG.md +76 -1
  2. package/README.en.md +427 -0
  3. package/README.md +40 -0
  4. package/backend/package.json +2 -2
  5. package/backend/prisma/migrations/20260328173000_add_plugin_source_ref/migration.sql +2 -0
  6. package/backend/prisma/migrations/migration_lock.toml +2 -2
  7. package/backend/prisma/schema.prisma +2 -0
  8. package/backend/src/ai/plugin-assistant-system-prompt.md +664 -5
  9. package/backend/src/api/routes/apiKeys.js +8 -0
  10. package/backend/src/api/routes/bots.js +271 -9
  11. package/backend/src/api/routes/eventGraphs.js +151 -1
  12. package/backend/src/api/routes/health.js +38 -0
  13. package/backend/src/api/routes/nodeRegistry.js +63 -0
  14. package/backend/src/api/routes/plugins.js +254 -29
  15. package/backend/src/api/routes/servers.js +14 -2
  16. package/backend/src/container.js +11 -8
  17. package/backend/src/core/BotCommandLoader.js +161 -0
  18. package/backend/src/core/BotConnection.js +125 -0
  19. package/backend/src/core/BotEventHandlers.js +234 -0
  20. package/backend/src/core/BotIPCHandler.js +445 -0
  21. package/backend/src/core/BotManager.js +15 -7
  22. package/backend/src/core/BotProcess.js +169 -140
  23. package/backend/src/core/EventGraphManager.js +7 -3
  24. package/backend/src/core/GraphDebugHandler.js +229 -0
  25. package/backend/src/core/GraphDebugIPC.js +117 -0
  26. package/backend/src/core/GraphExecutionEngine.js +545 -978
  27. package/backend/src/core/GraphTraversal.js +80 -0
  28. package/backend/src/core/GraphValidation.js +73 -0
  29. package/backend/src/core/NodeDefinition.js +138 -0
  30. package/backend/src/core/NodeRegistry.js +153 -141
  31. package/backend/src/core/PluginLoader.js +83 -3
  32. package/backend/src/core/PluginManager.js +346 -35
  33. package/backend/src/core/RewindSignal.js +9 -0
  34. package/backend/src/core/config/ConfigValidator.js +72 -0
  35. package/backend/src/core/config/FeatureFlags.js +52 -0
  36. package/backend/src/core/config/__tests__/ConfigValidator.test.js +232 -0
  37. package/backend/src/core/domain/entities/Bot.js +39 -0
  38. package/backend/src/core/domain/entities/Command.js +41 -0
  39. package/backend/src/core/domain/entities/EventGraph.js +39 -0
  40. package/backend/src/core/domain/entities/Plugin.js +45 -0
  41. package/backend/src/core/domain/entities/User.js +40 -0
  42. package/backend/src/core/domain/services/DependencyResolver.js +168 -0
  43. package/backend/src/core/domain/services/GraphValidator.js +117 -0
  44. package/backend/src/core/domain/services/PermissionChecker.js +34 -0
  45. package/backend/src/core/domain/services/__tests__/DependencyResolver.test.js +126 -0
  46. package/backend/src/core/domain/valueObjects/BotConfig.js +27 -0
  47. package/backend/src/core/domain/valueObjects/DependencyGraph.js +86 -0
  48. package/backend/src/core/domain/valueObjects/PluginManifest.js +36 -0
  49. package/backend/src/core/errors/BaseError.js +29 -0
  50. package/backend/src/core/errors/ErrorHandler.js +81 -0
  51. package/backend/src/core/errors/__tests__/ErrorHandler.test.js +188 -0
  52. package/backend/src/core/errors/index.js +68 -0
  53. package/backend/src/core/infrastructure/BatchingUtility.js +66 -0
  54. package/backend/src/core/infrastructure/CircuitBreaker.js +103 -0
  55. package/backend/src/core/infrastructure/ConnectionPool.js +81 -0
  56. package/backend/src/core/infrastructure/RateLimiter.js +64 -0
  57. package/backend/src/core/infrastructure/__tests__/BatchingUtility.test.js +86 -0
  58. package/backend/src/core/infrastructure/__tests__/CircuitBreaker.test.js +156 -0
  59. package/backend/src/core/infrastructure/__tests__/ConnectionPool.test.js +146 -0
  60. package/backend/src/core/infrastructure/__tests__/RateLimiter.test.js +171 -0
  61. package/backend/src/core/ipc/botApiFactory.js +72 -0
  62. package/backend/src/core/ipc/ipcMessageTypes.js +115 -0
  63. package/backend/src/core/logging/AuditLogger.js +61 -0
  64. package/backend/src/core/logging/StructuredLogger.js +80 -0
  65. package/backend/src/core/logging/__tests__/StructuredLogger.test.js +213 -0
  66. package/backend/src/core/logging/index.js +7 -0
  67. package/backend/src/core/metrics/MetricsCollector.js +104 -0
  68. package/backend/src/core/metrics/__tests__/MetricsCollector.test.js +131 -0
  69. package/backend/src/core/node-registries/actionsNodes.js +191 -0
  70. package/backend/src/core/node-registries/arraysNodes.js +152 -0
  71. package/backend/src/core/node-registries/botNodes.js +48 -0
  72. package/backend/src/core/node-registries/containerNodes.js +141 -0
  73. package/backend/src/core/node-registries/dataNodes.js +284 -0
  74. package/backend/src/core/node-registries/debugNodes.js +23 -0
  75. package/backend/src/core/node-registries/eventsNodes.js +223 -0
  76. package/backend/src/core/node-registries/flowNodes.js +151 -0
  77. package/backend/src/core/node-registries/furnaceNodes.js +123 -0
  78. package/backend/src/core/node-registries/index.js +108 -0
  79. package/backend/src/core/node-registries/inventory.js +102 -106
  80. package/backend/src/core/node-registries/logicNodes.js +54 -0
  81. package/backend/src/core/node-registries/mathNodes.js +38 -0
  82. package/backend/src/core/node-registries/navigationNodes.js +109 -0
  83. package/backend/src/core/node-registries/objectsNodes.js +90 -0
  84. package/backend/src/core/node-registries/stringsNodes.js +165 -0
  85. package/backend/src/core/node-registries/timeNodes.js +105 -0
  86. package/backend/src/core/node-registries/typeNodes.js +22 -0
  87. package/backend/src/core/node-registries/usersNodes.js +126 -0
  88. package/backend/src/core/nodes/arrays/shuffle.js +14 -0
  89. package/backend/src/core/nodes/bot/get_name.js +8 -0
  90. package/backend/src/core/nodes/bot/stop_bot.js +5 -0
  91. package/backend/src/core/nodes/container/open.js +101 -111
  92. package/backend/src/core/nodes/data/store_read.js +26 -0
  93. package/backend/src/core/nodes/data/store_write.js +23 -0
  94. package/backend/src/core/nodes/event/call_event.js +31 -0
  95. package/backend/src/core/nodes/event/custom_event.js +8 -0
  96. package/backend/src/core/nodes/flow/timer.js +35 -0
  97. package/backend/src/core/nodes/inventory/drop.js +73 -65
  98. package/backend/src/core/nodes/inventory/equip.js +54 -45
  99. package/backend/src/core/nodes/inventory/select_slot.js +48 -46
  100. package/backend/src/core/nodes/navigation/follow.js +54 -51
  101. package/backend/src/core/nodes/navigation/go_to.js +41 -53
  102. package/backend/src/core/nodes/navigation/go_to_entity.js +65 -69
  103. package/backend/src/core/nodes/navigation/go_to_player.js +65 -70
  104. package/backend/src/core/nodes/navigation/stop.js +17 -26
  105. package/backend/src/core/nodes/users/add_to_group.js +24 -0
  106. package/backend/src/core/nodes/users/check_permission.js +26 -0
  107. package/backend/src/core/nodes/users/remove_from_group.js +24 -0
  108. package/backend/src/core/services/BotIPCMessageRouter.js +337 -0
  109. package/backend/src/core/services/BotLifecycleService.js +43 -450
  110. package/backend/src/core/services/CacheManager.js +83 -23
  111. package/backend/src/core/services/CrashRestartManager.js +42 -0
  112. package/backend/src/core/services/DebugSessionManager.js +114 -12
  113. package/backend/src/core/services/EventGraphService.js +69 -0
  114. package/backend/src/core/services/MinecraftBotManager.js +9 -1
  115. package/backend/src/core/services/PluginManagementService.js +84 -0
  116. package/backend/src/core/services/TestModeContext.js +65 -0
  117. package/backend/src/core/services/__tests__/CacheManager.test.js +168 -0
  118. package/backend/src/core/services.js +1 -11
  119. package/backend/src/core/validation/InputValidator.js +167 -0
  120. package/backend/src/core/validation/__tests__/InputValidator.test.js +296 -0
  121. package/backend/src/real-time/botApi/index.js +1 -1
  122. package/backend/src/real-time/socketHandler.js +26 -0
  123. package/backend/src/server.js +21 -6
  124. package/frontend/dist/assets/browser-ponyfill-D8y0Ty7C.js +2 -0
  125. package/frontend/dist/assets/index-CFJLS0dk.css +32 -0
  126. package/frontend/dist/assets/index-D91UGNMG.js +11260 -0
  127. package/frontend/dist/flags/en.svg +32 -0
  128. package/frontend/dist/flags/ru.svg +5 -0
  129. package/frontend/dist/index.html +2 -2
  130. package/frontend/dist/locales/en/admin.json +100 -0
  131. package/frontend/dist/locales/en/api-keys.json +58 -0
  132. package/frontend/dist/locales/en/bots.json +113 -0
  133. package/frontend/dist/locales/en/common.json +53 -0
  134. package/frontend/dist/locales/en/configuration.json +22 -0
  135. package/frontend/dist/locales/en/console.json +10 -0
  136. package/frontend/dist/locales/en/dashboard.json +85 -0
  137. package/frontend/dist/locales/en/dialogs.json +70 -0
  138. package/frontend/dist/locales/en/event-graphs.json +50 -0
  139. package/frontend/dist/locales/en/graph-store.json +70 -0
  140. package/frontend/dist/locales/en/login.json +36 -0
  141. package/frontend/dist/locales/en/management.json +192 -0
  142. package/frontend/dist/locales/en/minecraft-viewer.json +27 -0
  143. package/frontend/dist/locales/en/nodes.json +1132 -0
  144. package/frontend/dist/locales/en/permissions.json +50 -0
  145. package/frontend/dist/locales/en/plugin-detail.json +69 -0
  146. package/frontend/dist/locales/en/plugins.json +329 -0
  147. package/frontend/dist/locales/en/proxies.json +81 -0
  148. package/frontend/dist/locales/en/servers.json +39 -0
  149. package/frontend/dist/locales/en/setup.json +19 -0
  150. package/frontend/dist/locales/en/sidebar.json +195 -0
  151. package/frontend/dist/locales/en/tasks.json +62 -0
  152. package/frontend/dist/locales/en/visual-editor.json +418 -0
  153. package/frontend/dist/locales/en/websocket.json +86 -0
  154. package/frontend/dist/locales/ru/admin.json +100 -0
  155. package/frontend/dist/locales/ru/api-keys.json +58 -0
  156. package/frontend/dist/locales/ru/bots.json +113 -0
  157. package/frontend/dist/locales/ru/common.json +49 -0
  158. package/frontend/dist/locales/ru/configuration.json +22 -0
  159. package/frontend/dist/locales/ru/console.json +10 -0
  160. package/frontend/dist/locales/ru/dashboard.json +85 -0
  161. package/frontend/dist/locales/ru/dialogs.json +70 -0
  162. package/frontend/dist/locales/ru/event-graphs.json +50 -0
  163. package/frontend/dist/locales/ru/graph-store.json +70 -0
  164. package/frontend/dist/locales/ru/login.json +36 -0
  165. package/frontend/dist/locales/ru/management.json +192 -0
  166. package/frontend/dist/locales/ru/minecraft-viewer.json +30 -0
  167. package/frontend/dist/locales/ru/nodes.json +1131 -0
  168. package/frontend/dist/locales/ru/permissions.json +50 -0
  169. package/frontend/dist/locales/ru/plugin-detail.json +49 -0
  170. package/frontend/dist/locales/ru/plugins.json +209 -0
  171. package/frontend/dist/locales/ru/proxies.json +81 -0
  172. package/frontend/dist/locales/ru/servers.json +39 -0
  173. package/frontend/dist/locales/ru/setup.json +19 -0
  174. package/frontend/dist/locales/ru/sidebar.json +195 -0
  175. package/frontend/dist/locales/ru/tasks.json +62 -0
  176. package/frontend/dist/locales/ru/visual-editor.json +420 -0
  177. package/frontend/dist/locales/ru/websocket.json +86 -0
  178. package/frontend/dist/monacoeditorwork/css.worker.bundle.js +7 -7
  179. package/frontend/dist/monacoeditorwork/html.worker.bundle.js +7 -7
  180. package/frontend/dist/monacoeditorwork/json.worker.bundle.js +7 -7
  181. package/frontend/dist/monacoeditorwork/ts.worker.bundle.js +3 -3
  182. package/frontend/package.json +6 -0
  183. package/nul +12 -0
  184. package/package.json +3 -3
  185. package/screen/3dviewer.png +0 -0
  186. package/screen/console.png +0 -0
  187. package/screen/dashboard.png +0 -0
  188. package/screen/graph_collabe.png +0 -0
  189. package/screen/graph_live_debug.png +0 -0
  190. package/screen/language_selector.png +0 -0
  191. package/screen/management_command.png +0 -0
  192. package/screen/node_debug_trace.png +0 -0
  193. package/screen/plugin_/320/276/320/261/320/267/320/276/321/200.png +0 -0
  194. package/screen/websocket.png +0 -0
  195. package/screen//320/275/320/260/321/201/321/202/321/200/320/276/320/271/320/272/320/270_/320/276/321/202/320/264/320/265/320/273/321/214/320/275/321/213/321/205_/320/272/320/276/320/274/320/260/320/275/320/264_/320/272/320/260/320/266/320/264/321/203_/320/272/320/276/320/274/320/260/320/275/320/273/320/264/321/203_/320/274/320/276/320/266/320/275/320/276_/320/275/320/260/321/201/321/202/321/200/320/260/320/270/320/262/320/260/321/202/321/214.png +0 -0
  196. package/screen//320/277/320/273/320/260/320/275/320/270/321/200/320/276/320/262/321/211/320/270/320/272_/320/274/320/276/320/266/320/275/320/276_/320/267/320/260/320/264/320/260/320/262/320/260/321/202/321/214_/320/264/320/265/320/271/321/201/321/202/320/262/320/270/321/217_/320/277/320/276_/320/262/321/200/320/265/320/274/320/265/320/275/320/270.png +0 -0
  197. package/.claude/agents/README.md +0 -469
  198. package/.claude/agents/auth-route-debugger.md +0 -118
  199. package/.claude/agents/auth-route-tester.md +0 -93
  200. package/.claude/agents/auto-error-resolver.md +0 -97
  201. package/.claude/agents/build-optimizer.md +0 -236
  202. package/.claude/agents/code-architect.md +0 -34
  203. package/.claude/agents/code-architecture-reviewer.md +0 -83
  204. package/.claude/agents/code-explorer.md +0 -51
  205. package/.claude/agents/code-refactor-master.md +0 -94
  206. package/.claude/agents/code-reviewer.md +0 -46
  207. package/.claude/agents/cost-optimizer.md +0 -134
  208. package/.claude/agents/deployment-orchestrator.md +0 -113
  209. package/.claude/agents/documentation-architect.md +0 -82
  210. package/.claude/agents/frontend-error-fixer.md +0 -77
  211. package/.claude/agents/iac-code-generator.md +0 -71
  212. package/.claude/agents/incident-responder.md +0 -346
  213. package/.claude/agents/infrastructure-architect.md +0 -31
  214. package/.claude/agents/kubernetes-specialist.md +0 -56
  215. package/.claude/agents/migration-planner.md +0 -181
  216. package/.claude/agents/network-architect.md +0 -196
  217. package/.claude/agents/plan-reviewer.md +0 -52
  218. package/.claude/agents/refactor-planner.md +0 -63
  219. package/.claude/agents/security-scanner.md +0 -102
  220. package/.claude/agents/web-research-specialist.md +0 -78
  221. package/.claude/commands/cost-analysis.md +0 -315
  222. package/.claude/commands/dev-docs-update.md +0 -55
  223. package/.claude/commands/dev-docs.md +0 -51
  224. package/.claude/commands/feature-dev.md +0 -125
  225. package/.claude/commands/incident-debug.md +0 -247
  226. package/.claude/commands/infra-plan.md +0 -81
  227. package/.claude/commands/migration-plan.md +0 -478
  228. package/.claude/commands/route-research-for-testing.md +0 -37
  229. package/.claude/commands/security-review.md +0 -66
  230. package/.claude/hooks/CONFIG.md +0 -448
  231. package/.claude/hooks/README.md +0 -163
  232. package/.claude/hooks/SKILL_ACTIVATION_COMPLETE.md +0 -226
  233. package/.claude/hooks/WINDOWS_HOOKS_README.md +0 -151
  234. package/.claude/hooks/add-skill-activation-banners.ts +0 -132
  235. package/.claude/hooks/comprehensive-skill-test.ts +0 -1315
  236. package/.claude/hooks/error-handling-reminder.sh +0 -12
  237. package/.claude/hooks/error-handling-reminder.ts +0 -222
  238. package/.claude/hooks/k8s-manifest-validator.sh +0 -56
  239. package/.claude/hooks/package-lock.json +0 -556
  240. package/.claude/hooks/package.json +0 -16
  241. package/.claude/hooks/post-tool-use-tracker.ps1 +0 -174
  242. package/.claude/hooks/post-tool-use-tracker.sh +0 -183
  243. package/.claude/hooks/security-policy-check.sh +0 -247
  244. package/.claude/hooks/skill-activation-prompt.ps1 +0 -10
  245. package/.claude/hooks/skill-activation-prompt.sh +0 -10
  246. package/.claude/hooks/skill-activation-prompt.ts +0 -141
  247. package/.claude/hooks/stop-build-check-enhanced.sh +0 -130
  248. package/.claude/hooks/terraform-validator.sh +0 -53
  249. package/.claude/hooks/test-input.json +0 -7
  250. package/.claude/hooks/test-skill-activation.ts +0 -427
  251. package/.claude/hooks/trigger-build-resolver.sh +0 -79
  252. package/.claude/hooks/tsc-check.sh +0 -173
  253. package/.claude/hooks/tsconfig.json +0 -19
  254. package/.claude/settings.json +0 -59
  255. package/.claude/settings.local.json +0 -67
  256. package/.claude/skills/README.md +0 -507
  257. package/.claude/skills/api-engineering/SKILL.md +0 -63
  258. package/.claude/skills/api-engineering/resources/api-versioning.md +0 -88
  259. package/.claude/skills/api-engineering/resources/graphql-patterns.md +0 -106
  260. package/.claude/skills/api-engineering/resources/rate-limiting.md +0 -118
  261. package/.claude/skills/api-engineering/resources/rest-api-design.md +0 -105
  262. package/.claude/skills/backend-dev-guidelines/SKILL.md +0 -306
  263. package/.claude/skills/backend-dev-guidelines/resources/architecture-overview.md +0 -451
  264. package/.claude/skills/backend-dev-guidelines/resources/async-and-errors.md +0 -307
  265. package/.claude/skills/backend-dev-guidelines/resources/complete-examples.md +0 -638
  266. package/.claude/skills/backend-dev-guidelines/resources/configuration.md +0 -275
  267. package/.claude/skills/backend-dev-guidelines/resources/database-patterns.md +0 -224
  268. package/.claude/skills/backend-dev-guidelines/resources/middleware-guide.md +0 -213
  269. package/.claude/skills/backend-dev-guidelines/resources/routing-and-controllers.md +0 -756
  270. package/.claude/skills/backend-dev-guidelines/resources/sentry-and-monitoring.md +0 -336
  271. package/.claude/skills/backend-dev-guidelines/resources/services-and-repositories.md +0 -789
  272. package/.claude/skills/backend-dev-guidelines/resources/testing-guide.md +0 -235
  273. package/.claude/skills/backend-dev-guidelines/resources/validation-patterns.md +0 -754
  274. package/.claude/skills/budget-and-cost-management/SKILL.md +0 -850
  275. package/.claude/skills/build-engineering/SKILL.md +0 -431
  276. package/.claude/skills/build-engineering/resources/artifact-repositories.md +0 -72
  277. package/.claude/skills/build-engineering/resources/build-caching.md +0 -96
  278. package/.claude/skills/build-engineering/resources/build-pipelines.md +0 -105
  279. package/.claude/skills/build-engineering/resources/build-security.md +0 -95
  280. package/.claude/skills/build-engineering/resources/build-systems.md +0 -389
  281. package/.claude/skills/build-engineering/resources/compilation-optimization.md +0 -201
  282. package/.claude/skills/build-engineering/resources/dependency-management.md +0 -73
  283. package/.claude/skills/build-engineering/resources/monorepo-builds.md +0 -110
  284. package/.claude/skills/build-engineering/resources/performance-optimization.md +0 -113
  285. package/.claude/skills/build-engineering/resources/reproducible-builds.md +0 -82
  286. package/.claude/skills/cloud-engineering/SKILL.md +0 -675
  287. package/.claude/skills/cloud-engineering/resources/aws-patterns.md +0 -742
  288. package/.claude/skills/cloud-engineering/resources/azure-patterns.md +0 -714
  289. package/.claude/skills/cloud-engineering/resources/cleared-cloud-environments.md +0 -987
  290. package/.claude/skills/cloud-engineering/resources/cloud-cost-optimization.md +0 -757
  291. package/.claude/skills/cloud-engineering/resources/cloud-networking.md +0 -1058
  292. package/.claude/skills/cloud-engineering/resources/cloud-security-tools.md +0 -1530
  293. package/.claude/skills/cloud-engineering/resources/cloud-security.md +0 -990
  294. package/.claude/skills/cloud-engineering/resources/gcp-patterns.md +0 -758
  295. package/.claude/skills/cloud-engineering/resources/migration-strategies.md +0 -820
  296. package/.claude/skills/cloud-engineering/resources/multi-cloud-strategies.md +0 -670
  297. package/.claude/skills/cloud-engineering/resources/oci-patterns.md +0 -1198
  298. package/.claude/skills/cloud-engineering/resources/serverless-patterns.md +0 -795
  299. package/.claude/skills/cloud-engineering/resources/well-architected-frameworks.md +0 -966
  300. package/.claude/skills/cybersecurity/SKILL.md +0 -409
  301. package/.claude/skills/cybersecurity/resources/security-architecture.md +0 -266
  302. package/.claude/skills/database-engineering/SKILL.md +0 -61
  303. package/.claude/skills/database-engineering/resources/backup-and-recovery.md +0 -72
  304. package/.claude/skills/database-engineering/resources/database-replication.md +0 -63
  305. package/.claude/skills/database-engineering/resources/postgresql-fundamentals.md +0 -70
  306. package/.claude/skills/database-engineering/resources/query-optimization.md +0 -68
  307. package/.claude/skills/devsecops/SKILL.md +0 -374
  308. package/.claude/skills/devsecops/resources/ci-cd-security.md +0 -204
  309. package/.claude/skills/devsecops/resources/compliance-automation.md +0 -530
  310. package/.claude/skills/devsecops/resources/compliance-frameworks.md +0 -2322
  311. package/.claude/skills/devsecops/resources/container-security.md +0 -915
  312. package/.claude/skills/devsecops/resources/cspm-integration.md +0 -1440
  313. package/.claude/skills/devsecops/resources/policy-enforcement.md +0 -619
  314. package/.claude/skills/devsecops/resources/secrets-management.md +0 -755
  315. package/.claude/skills/devsecops/resources/security-monitoring.md +0 -146
  316. package/.claude/skills/devsecops/resources/security-scanning.md +0 -887
  317. package/.claude/skills/devsecops/resources/security-testing.md +0 -203
  318. package/.claude/skills/devsecops/resources/supply-chain-security.md +0 -518
  319. package/.claude/skills/devsecops/resources/vulnerability-management.md +0 -481
  320. package/.claude/skills/devsecops/resources/zero-trust-architecture.md +0 -177
  321. package/.claude/skills/documentation-as-code/SKILL.md +0 -323
  322. package/.claude/skills/documentation-as-code/resources/api-documentation.md +0 -90
  323. package/.claude/skills/documentation-as-code/resources/changelog-management.md +0 -79
  324. package/.claude/skills/documentation-as-code/resources/diagram-generation.md +0 -44
  325. package/.claude/skills/documentation-as-code/resources/docs-as-code-workflow.md +0 -99
  326. package/.claude/skills/documentation-as-code/resources/documentation-automation.md +0 -68
  327. package/.claude/skills/documentation-as-code/resources/documentation-sites.md +0 -79
  328. package/.claude/skills/documentation-as-code/resources/markdown-best-practices.md +0 -162
  329. package/.claude/skills/documentation-as-code/resources/openapi-specification.md +0 -77
  330. package/.claude/skills/documentation-as-code/resources/readme-engineering.md +0 -60
  331. package/.claude/skills/documentation-as-code/resources/technical-writing-guide.md +0 -202
  332. package/.claude/skills/engineering-management/SKILL.md +0 -356
  333. package/.claude/skills/engineering-management/resources/career-ladders.md +0 -609
  334. package/.claude/skills/engineering-management/resources/hiring-and-assessment.md +0 -555
  335. package/.claude/skills/engineering-management/resources/one-on-one-guides.md +0 -609
  336. package/.claude/skills/engineering-management/resources/resource-planning.md +0 -557
  337. package/.claude/skills/engineering-management/resources/team-organization-patterns.md +0 -491
  338. package/.claude/skills/engineering-management/resources/technical-interviews.md +0 -474
  339. package/.claude/skills/engineering-operations-management/SKILL.md +0 -817
  340. package/.claude/skills/error-tracking/SKILL.md +0 -379
  341. package/.claude/skills/frontend-design/SKILL.md +0 -42
  342. package/.claude/skills/frontend-dev-guidelines/SKILL.md +0 -403
  343. package/.claude/skills/frontend-dev-guidelines/resources/common-patterns.md +0 -331
  344. package/.claude/skills/frontend-dev-guidelines/resources/complete-examples.md +0 -872
  345. package/.claude/skills/frontend-dev-guidelines/resources/component-patterns.md +0 -502
  346. package/.claude/skills/frontend-dev-guidelines/resources/data-fetching.md +0 -767
  347. package/.claude/skills/frontend-dev-guidelines/resources/file-organization.md +0 -502
  348. package/.claude/skills/frontend-dev-guidelines/resources/loading-and-error-states.md +0 -501
  349. package/.claude/skills/frontend-dev-guidelines/resources/performance.md +0 -406
  350. package/.claude/skills/frontend-dev-guidelines/resources/routing-guide.md +0 -364
  351. package/.claude/skills/frontend-dev-guidelines/resources/styling-guide.md +0 -428
  352. package/.claude/skills/frontend-dev-guidelines/resources/typescript-standards.md +0 -418
  353. package/.claude/skills/general-it-engineering/SKILL.md +0 -393
  354. package/.claude/skills/general-it-engineering/resources/asset-management.md +0 -712
  355. package/.claude/skills/general-it-engineering/resources/automation-orchestration.md +0 -817
  356. package/.claude/skills/general-it-engineering/resources/business-continuity.md +0 -786
  357. package/.claude/skills/general-it-engineering/resources/change-management.md +0 -715
  358. package/.claude/skills/general-it-engineering/resources/enterprise-monitoring.md +0 -729
  359. package/.claude/skills/general-it-engineering/resources/help-desk-operations.md +0 -738
  360. package/.claude/skills/general-it-engineering/resources/incident-service-management.md +0 -834
  361. package/.claude/skills/general-it-engineering/resources/it-governance.md +0 -753
  362. package/.claude/skills/general-it-engineering/resources/itil-framework.md +0 -503
  363. package/.claude/skills/general-it-engineering/resources/service-management.md +0 -669
  364. package/.claude/skills/infrastructure-architecture/SKILL.md +0 -328
  365. package/.claude/skills/infrastructure-architecture/resources/architecture-decision-records.md +0 -505
  366. package/.claude/skills/infrastructure-architecture/resources/architecture-patterns.md +0 -528
  367. package/.claude/skills/infrastructure-architecture/resources/capacity-planning.md +0 -453
  368. package/.claude/skills/infrastructure-architecture/resources/cleared-environment-architecture.md +0 -773
  369. package/.claude/skills/infrastructure-architecture/resources/cost-architecture.md +0 -499
  370. package/.claude/skills/infrastructure-architecture/resources/data-architecture.md +0 -501
  371. package/.claude/skills/infrastructure-architecture/resources/disaster-recovery.md +0 -535
  372. package/.claude/skills/infrastructure-architecture/resources/migration-architecture.md +0 -512
  373. package/.claude/skills/infrastructure-architecture/resources/multi-region-design.md +0 -608
  374. package/.claude/skills/infrastructure-architecture/resources/reference-architectures.md +0 -562
  375. package/.claude/skills/infrastructure-architecture/resources/security-architecture.md +0 -538
  376. package/.claude/skills/infrastructure-architecture/resources/system-design-principles.md +0 -489
  377. package/.claude/skills/infrastructure-architecture/resources/workload-classification.md +0 -1000
  378. package/.claude/skills/infrastructure-strategy/SKILL.md +0 -924
  379. package/.claude/skills/network-engineering/SKILL.md +0 -385
  380. package/.claude/skills/network-engineering/resources/dns-management.md +0 -738
  381. package/.claude/skills/network-engineering/resources/load-balancing.md +0 -820
  382. package/.claude/skills/network-engineering/resources/network-architecture.md +0 -546
  383. package/.claude/skills/network-engineering/resources/network-security.md +0 -921
  384. package/.claude/skills/network-engineering/resources/network-troubleshooting.md +0 -749
  385. package/.claude/skills/network-engineering/resources/routing-switching.md +0 -373
  386. package/.claude/skills/network-engineering/resources/sdn-networking.md +0 -695
  387. package/.claude/skills/network-engineering/resources/service-mesh-networking.md +0 -777
  388. package/.claude/skills/network-engineering/resources/tcp-ip-protocols.md +0 -444
  389. package/.claude/skills/network-engineering/resources/vpn-connectivity.md +0 -672
  390. package/.claude/skills/node-development/SKILL.md +0 -317
  391. package/.claude/skills/observability-engineering/SKILL.md +0 -101
  392. package/.claude/skills/observability-engineering/resources/apm-tools.md +0 -97
  393. package/.claude/skills/observability-engineering/resources/correlation-strategies.md +0 -87
  394. package/.claude/skills/observability-engineering/resources/distributed-tracing.md +0 -98
  395. package/.claude/skills/observability-engineering/resources/logs-aggregation.md +0 -118
  396. package/.claude/skills/observability-engineering/resources/observability-cost-optimization.md +0 -141
  397. package/.claude/skills/observability-engineering/resources/opentelemetry.md +0 -110
  398. package/.claude/skills/platform-engineering/SKILL.md +0 -555
  399. package/.claude/skills/platform-engineering/resources/architecture-overview.md +0 -600
  400. package/.claude/skills/platform-engineering/resources/container-orchestration.md +0 -916
  401. package/.claude/skills/platform-engineering/resources/cost-optimization.md +0 -634
  402. package/.claude/skills/platform-engineering/resources/developer-platforms.md +0 -670
  403. package/.claude/skills/platform-engineering/resources/gitops-automation.md +0 -650
  404. package/.claude/skills/platform-engineering/resources/infrastructure-as-code.md +0 -778
  405. package/.claude/skills/platform-engineering/resources/infrastructure-standards.md +0 -708
  406. package/.claude/skills/platform-engineering/resources/multi-tenancy.md +0 -602
  407. package/.claude/skills/platform-engineering/resources/platform-security.md +0 -711
  408. package/.claude/skills/platform-engineering/resources/resource-management.md +0 -592
  409. package/.claude/skills/platform-engineering/resources/service-mesh.md +0 -628
  410. package/.claude/skills/release-engineering/SKILL.md +0 -393
  411. package/.claude/skills/release-engineering/resources/artifact-management.md +0 -108
  412. package/.claude/skills/release-engineering/resources/build-optimization.md +0 -84
  413. package/.claude/skills/release-engineering/resources/ci-cd-pipelines.md +0 -411
  414. package/.claude/skills/release-engineering/resources/deployment-strategies.md +0 -197
  415. package/.claude/skills/release-engineering/resources/pipeline-security.md +0 -62
  416. package/.claude/skills/release-engineering/resources/progressive-delivery.md +0 -83
  417. package/.claude/skills/release-engineering/resources/release-automation.md +0 -68
  418. package/.claude/skills/release-engineering/resources/release-orchestration.md +0 -77
  419. package/.claude/skills/release-engineering/resources/rollback-strategies.md +0 -66
  420. package/.claude/skills/release-engineering/resources/versioning-strategies.md +0 -59
  421. package/.claude/skills/route-tester/SKILL.md +0 -392
  422. package/.claude/skills/skill-developer/ADVANCED.md +0 -197
  423. package/.claude/skills/skill-developer/HOOK_MECHANISMS.md +0 -306
  424. package/.claude/skills/skill-developer/PATTERNS_LIBRARY.md +0 -152
  425. package/.claude/skills/skill-developer/SKILL.md +0 -430
  426. package/.claude/skills/skill-developer/SKILL_RULES_REFERENCE.md +0 -315
  427. package/.claude/skills/skill-developer/TRIGGER_TYPES.md +0 -305
  428. package/.claude/skills/skill-developer/TROUBLESHOOTING.md +0 -514
  429. package/.claude/skills/skill-rules.json +0 -2989
  430. package/.claude/skills/sre/SKILL.md +0 -464
  431. package/.claude/skills/sre/resources/alerting-best-practices.md +0 -282
  432. package/.claude/skills/sre/resources/capacity-planning.md +0 -226
  433. package/.claude/skills/sre/resources/chaos-engineering.md +0 -193
  434. package/.claude/skills/sre/resources/disaster-recovery.md +0 -232
  435. package/.claude/skills/sre/resources/incident-management.md +0 -436
  436. package/.claude/skills/sre/resources/observability-stack.md +0 -240
  437. package/.claude/skills/sre/resources/on-call-runbooks.md +0 -167
  438. package/.claude/skills/sre/resources/performance-optimization.md +0 -108
  439. package/.claude/skills/sre/resources/reliability-patterns.md +0 -183
  440. package/.claude/skills/sre/resources/slo-sli-sla.md +0 -464
  441. package/.claude/skills/sre/resources/toil-reduction.md +0 -145
  442. package/.claude/skills/systems-engineering/SKILL.md +0 -648
  443. package/.claude/skills/systems-engineering/resources/automation-patterns.md +0 -771
  444. package/.claude/skills/systems-engineering/resources/configuration-management.md +0 -998
  445. package/.claude/skills/systems-engineering/resources/linux-administration.md +0 -672
  446. package/.claude/skills/systems-engineering/resources/networking-fundamentals.md +0 -982
  447. package/.claude/skills/systems-engineering/resources/performance-tuning.md +0 -871
  448. package/.claude/skills/systems-engineering/resources/powershell-scripting.md +0 -482
  449. package/.claude/skills/systems-engineering/resources/security-hardening.md +0 -739
  450. package/.claude/skills/systems-engineering/resources/shell-scripting.md +0 -915
  451. package/.claude/skills/systems-engineering/resources/storage-management.md +0 -628
  452. package/.claude/skills/systems-engineering/resources/system-monitoring.md +0 -787
  453. package/.claude/skills/systems-engineering/resources/troubleshooting-guide.md +0 -753
  454. package/.claude/skills/systems-engineering/resources/windows-administration.md +0 -738
  455. package/.claude/skills/technical-leadership/SKILL.md +0 -728
  456. package/backend/docs/SECRETS_DOCUMENTATION.md +0 -327
  457. package/backend/package-lock.json +0 -6801
  458. package/backend/src/core/node-registries/actions.js +0 -202
  459. package/backend/src/core/node-registries/arrays.js +0 -155
  460. package/backend/src/core/node-registries/bot.js +0 -23
  461. package/backend/src/core/node-registries/container.js +0 -162
  462. package/backend/src/core/node-registries/data.js +0 -290
  463. package/backend/src/core/node-registries/debug.js +0 -26
  464. package/backend/src/core/node-registries/events.js +0 -201
  465. package/backend/src/core/node-registries/flow.js +0 -139
  466. package/backend/src/core/node-registries/furnace.js +0 -143
  467. package/backend/src/core/node-registries/logic.js +0 -62
  468. package/backend/src/core/node-registries/math.js +0 -42
  469. package/backend/src/core/node-registries/navigation.js +0 -111
  470. package/backend/src/core/node-registries/objects.js +0 -98
  471. package/backend/src/core/node-registries/strings.js +0 -187
  472. package/backend/src/core/node-registries/time.js +0 -113
  473. package/backend/src/core/node-registries/type.js +0 -25
  474. package/backend/src/core/node-registries/users.js +0 -79
  475. package/frontend/dist/assets/index-BC-NbKXi.css +0 -32
  476. package/frontend/dist/assets/index-DqJXZMHY.js +0 -11266
@@ -1,7 +1,13 @@
1
- const DependencyService = require('../DependencyService');
1
+ const DependencyResolver = require('../domain/services/DependencyResolver');
2
2
  const { decrypt } = require('../utils/crypto');
3
3
  const UserService = require('../UserService');
4
4
  const PermissionManager = require('../PermissionManager');
5
+ const CrashRestartManager = require('./CrashRestartManager');
6
+ const BotIPCMessageRouter = require('./BotIPCMessageRouter');
7
+ const ErrorHandler = require('../errors/ErrorHandler');
8
+
9
+ const dependencyResolver = new DependencyResolver();
10
+ const errorHandler = new ErrorHandler({ logger: console });
5
11
 
6
12
  class BotLifecycleService {
7
13
  constructor({
@@ -30,7 +36,20 @@ class BotLifecycleService {
30
36
  this.logger = logger;
31
37
 
32
38
  this.logCache = new Map();
33
- this.crashCounters = new Map();
39
+ this.crashRestartManager = new CrashRestartManager(5, 60000);
40
+
41
+ this.ipcRouter = new BotIPCMessageRouter({
42
+ eventGraphManager: this.eventGraphManager,
43
+ commandExecutionService: this.commandExecutionService,
44
+ processManager: this.processManager,
45
+ logger: this.logger,
46
+ crashRestartManager: this.crashRestartManager,
47
+ appendLog: this.appendLog.bind(this),
48
+ emitStatusUpdate: this.emitStatusUpdate.bind(this),
49
+ restartBot: this.restartBot.bind(this),
50
+ stopBot: this.stopBot.bind(this),
51
+ getBotConfig: (botId) => this.processManager.getProcess(botId)?.botConfig,
52
+ });
34
53
  }
35
54
 
36
55
  async startBot(botConfig) {
@@ -47,7 +66,7 @@ class BotLifecycleService {
47
66
  this.emitStatusUpdate(botId, 'starting', '');
48
67
 
49
68
  const allPluginsForBot = await this.pluginRepository.findEnabledByBotId(botId);
50
- const { sortedPlugins, hasCriticalIssues, pluginInfo } = DependencyService.resolveDependencies(allPluginsForBot, allPluginsForBot);
69
+ const { sortedPlugins, hasCriticalIssues, pluginInfo } = dependencyResolver.resolve(allPluginsForBot, allPluginsForBot);
51
70
 
52
71
  if (hasCriticalIssues) {
53
72
  this.appendLog(botId, '[DependencyManager] Обнаружены критические проблемы с зависимостями, запуск отменен.');
@@ -63,7 +82,8 @@ class BotLifecycleService {
63
82
  if (criticalIssues.length > 0) {
64
83
  this.appendLog(botId, `* Плагин "${info.name}":`);
65
84
  for (const issue of criticalIssues) {
66
- this.appendLog(botId, ` - ${issue.message}`);
85
+ const msg = issue.message || `${issue.messageKey} ${JSON.stringify(issue.context || {})}`;
86
+ this.appendLog(botId, ` - ${msg}`);
67
87
  }
68
88
  }
69
89
  }
@@ -100,8 +120,7 @@ class BotLifecycleService {
100
120
  }
101
121
  };
102
122
 
103
- // Регистрируем обработчики сообщений от child process
104
- this._setupChildProcessHandlers(child, botConfig);
123
+ this.ipcRouter.attachToChild(child, botConfig);
105
124
 
106
125
  child.send({ type: 'start', config: fullBotConfig });
107
126
 
@@ -118,14 +137,12 @@ class BotLifecycleService {
118
137
  if (child) {
119
138
  this.eventGraphManager.unloadGraphsForBot(botId);
120
139
 
121
- // Очищаем traces для этого бота
122
140
  const { getTraceCollector } = require('./TraceCollectorService');
123
141
  const traceCollector = getTraceCollector();
124
142
  traceCollector.clearForBot(botId);
125
143
 
126
144
  child.send({ type: 'stop' });
127
145
 
128
- // Принудительное завершение через 5 секунд
129
146
  setTimeout(() => {
130
147
  if (!child.killed) {
131
148
  this.logger.warn({ botId }, 'Принудительное завершение процесса');
@@ -147,307 +164,18 @@ class BotLifecycleService {
147
164
  return this.processManager.getProcess(botId);
148
165
  }
149
166
 
150
- async restartBot(botId) {
151
- const botConfig = this.processManager.getProcess(botId)?.botConfig;
167
+ async restartBot(botId, providedBotConfig = null) {
168
+ const botConfig = providedBotConfig || this.processManager.getProcess(botId)?.botConfig;
152
169
  if (!botConfig) {
153
170
  throw new Error('Bot configuration not found');
154
171
  }
155
172
 
156
173
  await this.stopBot(botId);
157
-
158
- // Ждём завершения процесса
159
174
  await new Promise(resolve => setTimeout(resolve, 1000));
160
175
 
161
176
  return this.startBot(botConfig);
162
177
  }
163
178
 
164
- _setupChildProcessHandlers(child, botConfig) {
165
- const botId = botConfig.id;
166
-
167
- child.on('message', async (message) => {
168
- try {
169
- switch (message.type) {
170
- case 'event':
171
- await this._handleEventMessage(botId, message);
172
- break;
173
- case 'plugin:data':
174
- this._handlePluginDataMessage(botId, message);
175
- break;
176
- case 'send_websocket_message':
177
- this._handleWebSocketMessage(message);
178
- break;
179
- case 'log':
180
- this.appendLog(botId, message.content);
181
- break;
182
- case 'plugin-log':
183
- this._handlePluginLog(message.log);
184
- break;
185
- case 'status':
186
- this.emitStatusUpdate(botId, message.status);
187
- break;
188
- case 'bot_ready':
189
- this._handleBotReady(botId);
190
- break;
191
- case 'validate_and_run_command':
192
- if (this.commandExecutionService) {
193
- const botConfig = child.botConfig;
194
- if (botConfig) {
195
- await this.commandExecutionService.handleCommandValidation(botConfig, message);
196
- }
197
- }
198
- break;
199
- case 'request_user_action':
200
- await this._handleUserAction(botId, child, message);
201
- break;
202
- case 'get_player_list_response':
203
- this.processManager.resolvePlayerListRequest(message.requestId, message.payload.players);
204
- break;
205
- case 'get_nearby_entities_response':
206
- this.processManager.resolveNearbyEntitiesRequest(message.requestId, message.payload.entities);
207
- break;
208
- case 'execute_command_response':
209
- this.processManager.resolveCommandRequest(message.requestId, message.result, message.error);
210
- break;
211
- case 'register_command':
212
- await this._handleCommandRegistration(botId, message.commandConfig);
213
- break;
214
- case 'register_permissions':
215
- await this._handlePermissionsRegistration(botId, message);
216
- break;
217
- case 'register_group':
218
- await this._handleGroupRegistration(botId, message);
219
- break;
220
- case 'add_permissions_to_group':
221
- await this._handleAddPermissionsToGroup(botId, message);
222
- break;
223
- case 'trace:completed':
224
- await this._handleTraceCompleted(botId, message.trace);
225
- break;
226
- case 'debug:check_breakpoint':
227
- await this._handleDebugBreakpointCheck(botId, child, message);
228
- break;
229
- case 'debug:check_step_mode':
230
- await this._handleDebugStepModeCheck(botId, child, message);
231
- break;
232
- }
233
- } catch (error) {
234
- this.appendLog(botId, `[SYSTEM-ERROR] Критическая ошибка в обработчике: ${error.stack}`);
235
- this.logger.error({ botId, error }, 'Критическая ошибка в обработчике сообщений');
236
- }
237
- });
238
-
239
- child.on('error', (err) => this.appendLog(botId, `[PROCESS FATAL] ${err.stack}`));
240
- child.stdout.on('data', (data) => console.log(data.toString()));
241
- child.stderr.on('data', (data) => this.appendLog(botId, `[STDERR] ${data.toString()}`));
242
-
243
- child.on('exit', (code, signal) => {
244
- this._handleProcessExit(botId, botConfig, code, signal);
245
- });
246
- }
247
-
248
- async _handleEventMessage(botId, message) {
249
- if (message.eventType === 'raw_message') {
250
- try {
251
- const { getIOSafe } = require('../../real-time/socketHandler');
252
- const { broadcastToApiClients } = require('../../real-time/botApi');
253
- broadcastToApiClients(getIOSafe(), botId, 'chat:raw_message', {
254
- raw_message: message.args.rawText || message.args.raw_message,
255
- json: message.args.json
256
- });
257
- } catch (e) { /* Socket.IO может быть не инициализирован */ }
258
- }
259
-
260
- try {
261
- const { broadcastToPanelNamespace } = require('../../real-time/panelNamespace');
262
- broadcastToPanelNamespace(botId, 'bot:event', {
263
- botId,
264
- eventType: message.eventType,
265
- data: message.args || {},
266
- timestamp: new Date().toISOString()
267
- });
268
- } catch (e) { /* Socket.IO может быть не инициализирован */ }
269
-
270
- if (this.eventGraphManager) {
271
- this.eventGraphManager.handleEvent(botId, message.eventType, message.args);
272
- }
273
- }
274
-
275
- _handlePluginDataMessage(botId, message) {
276
- const { plugin: pluginName, payload } = message;
277
- const pluginSubscribers = this.processManager.getPluginSubscribers(botId, pluginName);
278
-
279
- if (pluginSubscribers && pluginSubscribers.size > 0) {
280
- pluginSubscribers.forEach(socket => {
281
- socket.emit('plugin:ui:dataUpdate', payload);
282
- });
283
- }
284
- }
285
-
286
- _handlePluginLog(logData) {
287
- const { getIOSafe, addPluginLogToBuffer } = require('../../real-time/socketHandler');
288
- const { botId, pluginName } = logData;
289
-
290
- // Добавляем лог в буфер
291
- addPluginLogToBuffer(botId, pluginName, logData);
292
-
293
- // Отправляем через Socket.IO в комнату плагина
294
- const io = getIOSafe();
295
- if (io) {
296
- const room = `plugin-logs:${botId}:${pluginName}`;
297
- io.to(room).emit('plugin-log', logData);
298
- }
299
- }
300
-
301
- _handleWebSocketMessage(message) {
302
- const { getIOSafe } = require('../../real-time/socketHandler');
303
- const { botId, message: msg } = message.payload;
304
- getIOSafe().to(`bot_${botId}`).emit('bot:message', { message: msg });
305
- }
306
-
307
- _handleBotReady(botId) {
308
- this.emitStatusUpdate(botId, 'running', 'Бот успешно подключился к серверу.');
309
- this.crashCounters.delete(botId);
310
-
311
- try {
312
- const { getIOSafe } = require('../../real-time/socketHandler');
313
- const { broadcastBotStatus } = require('../../real-time/botApi');
314
- broadcastBotStatus(getIOSafe(), botId, true);
315
- } catch (e) { /* Socket.IO может быть не инициализирован */ }
316
-
317
- // Триггерим событие запуска бота
318
- if (this.eventGraphManager) {
319
- this.eventGraphManager.handleEvent(botId, 'botStartup', {});
320
- }
321
- }
322
-
323
- async _handleCommandRegistration(botId, commandConfig) {
324
- if (this.commandExecutionService) {
325
- await this.commandExecutionService.handleCommandRegistration(botId, commandConfig);
326
- // this.logger.debug({ botId, commandName: commandConfig.name }, 'Команда зарегистрирована');
327
- } else {
328
- this.logger.warn({ botId }, 'CommandExecutionService не доступен для регистрации команды');
329
- }
330
- }
331
-
332
- async _handlePermissionsRegistration(botId, message) {
333
- try {
334
- await PermissionManager.registerPermissions(botId, message.permissions);
335
- this.logger.debug({ botId, count: message.permissions.length }, 'Права зарегистрированы');
336
- } catch (error) {
337
- this.logger.error({ botId, error }, 'Ошибка регистрации прав');
338
- }
339
- }
340
-
341
- async _handleGroupRegistration(botId, message) {
342
- try {
343
- await PermissionManager.registerGroup(botId, message.groupConfig);
344
- this.logger.debug({ botId, groupName: message.groupConfig.name }, 'Группа зарегистрирована');
345
- } catch (error) {
346
- this.logger.error({ botId, error }, 'Ошибка регистрации группы');
347
- }
348
- }
349
-
350
- async _handleAddPermissionsToGroup(botId, message) {
351
- try {
352
- await PermissionManager.addPermissionsToGroup(botId, message.groupName, message.permissionNames);
353
- this.logger.debug({ botId, groupName: message.groupName, count: message.permissionNames.length }, 'Права добавлены в группу');
354
- } catch (error) {
355
- this.logger.error({ botId, error }, 'Ошибка добавления прав в группу');
356
- }
357
- }
358
-
359
- async _handleUserAction(botId, child, message) {
360
- const { requestId, payload } = message;
361
- const { targetUsername, action, data } = payload;
362
-
363
- try {
364
- const botConfig = child.botConfig;
365
- const user = await UserService.getUser(targetUsername, botId, botConfig);
366
- if (!user) throw new Error(`Пользователь ${targetUsername} не найден.`);
367
-
368
- let result;
369
-
370
- switch (action) {
371
- case 'addGroup':
372
- result = await user.addGroup(data.group);
373
- break;
374
- case 'removeGroup':
375
- result = await user.removeGroup(data.group);
376
- break;
377
- case 'getGroups':
378
- result = user.groups ? user.groups.map(g => g.group.name) : [];
379
- break;
380
- case 'getPermissions':
381
- result = Array.from(user.permissionsSet);
382
- break;
383
- case 'isBlacklisted':
384
- result = user.isBlacklisted;
385
- break;
386
- case 'setBlacklisted':
387
- result = await user.setBlacklist(data.value);
388
- break;
389
- default:
390
- throw new Error(`Неизвестное действие: ${action}`);
391
- }
392
-
393
- child.send({ type: 'user_action_response', requestId, payload: result });
394
- } catch (error) {
395
- this.logger.error({ botId, action, username: targetUsername, error }, 'Ошибка действия пользователя');
396
- child.send({ type: 'user_action_response', requestId, error: error.message });
397
- }
398
- }
399
-
400
- _handleProcessExit(botId, botConfig, code, signal) {
401
- this.processManager.remove(botId);
402
- this.resourceMonitor.clearResourceUsage(botId);
403
- this.cache.clearBotCache(botId);
404
-
405
- this.emitStatusUpdate(botId, 'stopped', `Процесс завершился с кодом ${code} (сигнал: ${signal || 'none'}).`);
406
-
407
- try {
408
- const { getIOSafe } = require('../../real-time/socketHandler');
409
- const { broadcastBotStatus } = require('../../real-time/botApi');
410
- broadcastBotStatus(getIOSafe(), botId, false);
411
- } catch (e) { /* Socket.IO может быть не инициализирован */ }
412
-
413
- // Автоперезапуск при критических ошибках
414
- if (code === 1) {
415
- this._handleCrashRestart(botId, botConfig);
416
- }
417
- }
418
-
419
- _handleCrashRestart(botId, botConfig) {
420
- const MAX_RESTART_ATTEMPTS = 5;
421
- const RESTART_COOLDOWN = 60000;
422
-
423
- const counter = this.crashCounters.get(botId) || { count: 0, firstCrash: Date.now() };
424
- const timeSinceFirstCrash = Date.now() - counter.firstCrash;
425
-
426
- if (timeSinceFirstCrash > RESTART_COOLDOWN) {
427
- counter.count = 0;
428
- counter.firstCrash = Date.now();
429
- }
430
-
431
- counter.count++;
432
- this.crashCounters.set(botId, counter);
433
-
434
- if (counter.count >= MAX_RESTART_ATTEMPTS) {
435
- this.logger.warn({ botId, attempts: counter.count }, 'Автоперезапуск остановлен');
436
- this.appendLog(botId, `[SYSTEM] Обнаружено ${counter.count} критических ошибок подряд.`);
437
- this.appendLog(botId, `[SYSTEM] Исправьте проблему и запустите бота вручную.`);
438
- this.crashCounters.delete(botId);
439
- return;
440
- }
441
-
442
- this.logger.info({ botId, attempt: counter.count, max: MAX_RESTART_ATTEMPTS }, 'Перезапуск через 5 секунд');
443
- this.appendLog(botId, `[SYSTEM] Обнаружена критическая ошибка, перезапуск через 5 секунд... (попытка ${counter.count}/${MAX_RESTART_ATTEMPTS})`);
444
-
445
- setTimeout(() => {
446
- this.logger.info({ botId }, 'Выполняется перезапуск');
447
- this.startBot(botConfig);
448
- }, 5000);
449
- }
450
-
451
179
  async loadConfigForBot(botId) {
452
180
  this.logger.info({ botId }, 'Загрузка конфигурации');
453
181
 
@@ -475,6 +203,7 @@ class BotLifecycleService {
475
203
  return config;
476
204
  } catch (error) {
477
205
  this.logger.error({ botId, error }, 'Ошибка загрузки конфигурации');
206
+ const handled = errorHandler.handle(error, { botId });
478
207
  throw new Error(`Failed to load/cache bot configuration for botId ${botId}: ${error.message}`);
479
208
  }
480
209
  }
@@ -511,14 +240,12 @@ class BotLifecycleService {
511
240
  for (const perm of systemPermissions) {
512
241
  const existing = await this.permissionRepository.findByName(botId, perm.name);
513
242
  if (existing) {
514
- // Обновляем описание если изменилось
515
243
  if (existing.description !== perm.description) {
516
244
  await this.permissionRepository.update(existing.id, {
517
245
  description: perm.description
518
246
  });
519
247
  }
520
248
  } else {
521
- // Создаем новое системное право
522
249
  await this.permissionRepository.create({
523
250
  botId,
524
251
  name: perm.name,
@@ -544,7 +271,9 @@ class BotLifecycleService {
544
271
  const newLogs = [...currentLogs.slice(-199), logEntry];
545
272
  this.logCache.set(botId, newLogs);
546
273
 
547
- getIOSafe().emit('bot:log', { botId, log: logEntry });
274
+ try {
275
+ getIOSafe().emit('bot:log', { botId, log: logEntry });
276
+ } catch (e) {}
548
277
  }
549
278
 
550
279
  getBotLogs(botId) {
@@ -555,14 +284,15 @@ class BotLifecycleService {
555
284
  const { getIOSafe, broadcastToPanelNamespace } = require('../../real-time/socketHandler');
556
285
  if (message) this.appendLog(botId, `[SYSTEM] ${message}`);
557
286
 
558
- getIOSafe().emit('bot:status', { botId, status, message });
559
-
560
- broadcastToPanelNamespace(getIOSafe(), 'bots:status', {
561
- botId,
562
- status,
563
- message,
564
- timestamp: new Date().toISOString()
565
- });
287
+ try {
288
+ getIOSafe().emit('bot:status', { botId, status, message });
289
+ broadcastToPanelNamespace(getIOSafe(), 'bots:status', {
290
+ botId,
291
+ status,
292
+ message,
293
+ timestamp: new Date().toISOString()
294
+ });
295
+ } catch (e) {}
566
296
  }
567
297
 
568
298
  getFullState() {
@@ -616,8 +346,6 @@ class BotLifecycleService {
616
346
  }
617
347
 
618
348
  async getPlayerList(botId) {
619
- const PLAYER_LIST_CACHE_TTL = 2000;
620
-
621
349
  if (!this.processManager.isRunning(botId)) {
622
350
  return [];
623
351
  }
@@ -669,8 +397,8 @@ class BotLifecycleService {
669
397
  timeout
670
398
  });
671
399
 
672
- this.processManager.sendMessage(botId, {
673
- type: 'system:get_nearby_entities',
400
+ this.processManager.sendMessage(botId, {
401
+ type: 'system:get_nearby_entities',
674
402
  requestId,
675
403
  payload: { position, radius }
676
404
  });
@@ -695,141 +423,6 @@ class BotLifecycleService {
695
423
 
696
424
  return { success: true };
697
425
  }
698
-
699
- async _handleTraceCompleted(botId, trace) {
700
- try {
701
- const { getTraceCollector } = require('../services/TraceCollectorService');
702
- const traceCollector = getTraceCollector();
703
-
704
- // Сохраняем трассировку в главном TraceCollectorService
705
- await traceCollector._storeCompletedTrace(trace);
706
- } catch (error) {
707
- this.logger.error({ botId, error }, 'Ошибка обработки завершённой трассировки');
708
- }
709
- }
710
-
711
- async _handleDebugBreakpointCheck(botId, child, message) {
712
- const { requestId, payload } = message;
713
- const { graphId, nodeId, nodeType, inputs, executedSteps, context } = payload;
714
-
715
- try {
716
- const { getGlobalDebugManager } = require('../services/DebugSessionManager');
717
- const debugManager = getGlobalDebugManager();
718
-
719
- const debugState = debugManager.get(graphId);
720
- if (!debugState) {
721
- // Нет debug сессии для этого графа - просто продолжаем выполнение
722
- child.send({
723
- type: 'debug:breakpoint_response',
724
- requestId,
725
- overrides: null
726
- });
727
- return;
728
- }
729
-
730
- const breakpoint = debugState.breakpoints.get(nodeId);
731
- if (!breakpoint || !breakpoint.enabled) {
732
- // Нет брейкпоинта для этой ноды или он отключен
733
- child.send({
734
- type: 'debug:breakpoint_response',
735
- requestId,
736
- overrides: null
737
- });
738
- return;
739
- }
740
-
741
- // Проверяем условие брейкпоинта (пока всегда срабатывает)
742
- // TODO: добавить evaluateBreakpointCondition
743
-
744
- breakpoint.hitCount++;
745
-
746
- // Приостанавливаем выполнение и ждём действий от пользователя
747
- const overrides = await debugState.pause({
748
- nodeId,
749
- nodeType,
750
- inputs,
751
- executedSteps,
752
- context,
753
- breakpoint: {
754
- condition: breakpoint.condition,
755
- hitCount: breakpoint.hitCount
756
- }
757
- });
758
-
759
- // Отправляем результат обратно в дочерний процесс
760
- child.send({
761
- type: 'debug:breakpoint_response',
762
- requestId,
763
- overrides: overrides || null
764
- });
765
-
766
- } catch (error) {
767
- this.logger.error({ botId, error }, 'Ошибка обработки debug breakpoint check');
768
- // В случае ошибки отправляем null чтобы продолжить выполнение
769
- child.send({
770
- type: 'debug:breakpoint_response',
771
- requestId,
772
- overrides: null
773
- });
774
- }
775
- }
776
-
777
- async _handleDebugStepModeCheck(botId, child, message) {
778
- const { requestId, payload } = message;
779
- const { graphId, nodeId, nodeType, inputs, executedSteps, context } = payload;
780
-
781
- try {
782
- const { getGlobalDebugManager } = require('../services/DebugSessionManager');
783
- const debugManager = getGlobalDebugManager();
784
-
785
- const debugState = debugManager.get(graphId);
786
- if (!debugState) {
787
- // Нет debug сессии - продолжаем выполнение
788
- child.send({
789
- type: 'debug:breakpoint_response', // Используем тот же тип ответа
790
- requestId,
791
- overrides: null
792
- });
793
- return;
794
- }
795
-
796
- // Проверяем, нужно ли остановиться в step mode
797
- if (!debugState.shouldStepPause(nodeId)) {
798
- // Step mode не активен или не нужно останавливаться на этой ноде
799
- child.send({
800
- type: 'debug:breakpoint_response',
801
- requestId,
802
- overrides: null
803
- });
804
- return;
805
- }
806
-
807
- // Приостанавливаем выполнение и ждём действий от пользователя
808
- const overrides = await debugState.pause({
809
- nodeId,
810
- nodeType,
811
- inputs,
812
- executedSteps,
813
- context
814
- });
815
-
816
- // Отправляем результат обратно в дочерний процесс
817
- child.send({
818
- type: 'debug:breakpoint_response',
819
- requestId,
820
- overrides: overrides || null
821
- });
822
-
823
- } catch (error) {
824
- this.logger.error({ botId, error }, 'Ошибка обработки debug step mode check');
825
- // В случае ошибки отправляем null чтобы продолжить выполнение
826
- child.send({
827
- type: 'debug:breakpoint_response',
828
- requestId,
829
- overrides: null
830
- });
831
- }
832
- }
833
426
  }
834
427
 
835
- module.exports = BotLifecycleService;
428
+ module.exports = BotLifecycleService;