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
@@ -0,0 +1,115 @@
1
+ const MessageTypes = {
2
+ PLUGIN: {
3
+ UI_START_UPDATES: 'plugin:ui:start-updates',
4
+ UI_DATA: 'plugin:data',
5
+ },
6
+
7
+ SYSTEM: {
8
+ GET_PLAYER_LIST: 'system:get_player_list',
9
+ GET_PLAYER_LIST_RESPONSE: 'get_player_list_response',
10
+ GET_NEARBY_ENTITIES: 'system:get_nearby_entities',
11
+ GET_NEARBY_ENTITIES_RESPONSE: 'get_nearby_entities_response',
12
+ },
13
+
14
+ VIEWER: {
15
+ GET_STATE: 'viewer:get_state',
16
+ STATE_RESPONSE: 'viewer:state_response',
17
+ CONTROL: 'viewer:control',
18
+ CHAT: 'viewer:chat',
19
+ SPAWN: 'viewer:spawn',
20
+ HEALTH: 'viewer:health',
21
+ MOVE: 'viewer:move',
22
+ BLOCK_UPDATE: 'viewer:blockUpdate',
23
+ },
24
+
25
+ BOT: {
26
+ READY: 'bot_ready',
27
+ STATUS: 'status',
28
+ LOG: 'log',
29
+ STOP: 'stop',
30
+ START: 'start',
31
+ RESTART: 'restart_bot',
32
+ CHANGE_CREDENTIALS: 'change_credentials',
33
+ UPDATE_CREDENTIALS: 'update_credentials',
34
+ EVENT: 'event',
35
+ },
36
+
37
+ GRAPH: {
38
+ EXECUTE_EVENT_GRAPH: 'execute_event_graph',
39
+ EXECUTE_HANDLER: 'execute_handler',
40
+ EXECUTE_COMMAND_REQUEST: 'execute_command_request',
41
+ EXECUTE_COMMAND_RESPONSE: 'execute_command_response',
42
+ TRACE_COMPLETED: 'trace:completed',
43
+ },
44
+
45
+ DEBUG: {
46
+ CHECK_BREAKPOINT: 'debug:check_breakpoint',
47
+ BREAKPOINT_RESPONSE: 'debug:breakpoint_response',
48
+ CHECK_STEP_MODE: 'debug:check_step_mode',
49
+ STEP_RESPONSE: 'debug:step_response',
50
+ },
51
+
52
+ COMMAND: {
53
+ REGISTER: 'register_command',
54
+ REGISTER_TEMP: 'register_temp_command',
55
+ UNREGISTER_TEMP: 'unregister_temp_command',
56
+ VALIDATE_AND_RUN: 'validate_and_run_command',
57
+ HANDLE_PERMISSION_ERROR: 'handle_permission_error',
58
+ HANDLE_WRONG_CHAT: 'handle_wrong_chat',
59
+ HANDLE_COOLDOWN: 'handle_cooldown',
60
+ HANDLE_BLACKLIST: 'handle_blacklist',
61
+ },
62
+
63
+ CONFIG: {
64
+ RELOAD: 'config:reload',
65
+ },
66
+
67
+ CHAT: {
68
+ SEND_MESSAGE: 'send_message',
69
+ CHAT: 'chat',
70
+ ACTION: 'action',
71
+ },
72
+
73
+ SERVER: {
74
+ COMMAND: 'server_command',
75
+ },
76
+
77
+ PLUGINS: {
78
+ RELOAD: 'plugins:reload',
79
+ },
80
+
81
+ USER: {
82
+ ACTION_RESPONSE: 'user_action_response',
83
+ REQUEST_ACTION: 'request_user_action',
84
+ INVALIDATE_USER_CACHE: 'invalidate_user_cache',
85
+ INVALIDATE_ALL_USER_CACHE: 'invalidate_all_user_cache',
86
+ CREDENTIALS_OPERATION_RESPONSE: 'credentials_operation_response',
87
+ },
88
+
89
+ WEBSOCKET: {
90
+ SEND_MESSAGE: 'send_websocket_message',
91
+ },
92
+ };
93
+
94
+ const EventTypes = {
95
+ LOG: 'log',
96
+ EVENT: 'event',
97
+ BOT_READY: 'bot_ready',
98
+ STATUS: 'status',
99
+ CHAT: 'chat',
100
+ WHISPER: 'whisper',
101
+ RAW_MESSAGE: 'raw_message',
102
+ PLAYER_JOINED: 'playerJoined',
103
+ PLAYER_LEFT: 'playerLeft',
104
+ ENTITY_SPAWN: 'entitySpawn',
105
+ ENTITY_MOVED: 'entityMoved',
106
+ ENTITY_GONE: 'entityGone',
107
+ BOT_DIED: 'botDied',
108
+ HEALTH: 'health',
109
+ KICKED: 'kicked',
110
+ ERROR: 'error',
111
+ END: 'end',
112
+ SPAWN: 'spawn',
113
+ };
114
+
115
+ module.exports = { MessageTypes, EventTypes };
@@ -0,0 +1,61 @@
1
+ const fs = require('fs');
2
+ const path = require('path');
3
+ const os = require('os');
4
+ const crypto = require('crypto');
5
+
6
+ const AUDIT_LOG_DIR = path.join(os.homedir(), '.blockmine', 'logs');
7
+ const AUDIT_LOG_FILE = path.join(AUDIT_LOG_DIR, 'audit.log');
8
+
9
+ class AuditLogger {
10
+ constructor({ logFile = AUDIT_LOG_FILE } = {}) {
11
+ this.logFile = logFile;
12
+ this._ensureDir();
13
+ }
14
+
15
+ _ensureDir() {
16
+ const dir = path.dirname(this.logFile);
17
+ if (!fs.existsSync(dir)) {
18
+ fs.mkdirSync(dir, { recursive: true });
19
+ }
20
+ }
21
+
22
+ log(event) {
23
+ const entry = {
24
+ timestamp: new Date().toISOString(),
25
+ ...event,
26
+ };
27
+
28
+ const line = JSON.stringify(entry);
29
+ const hash = crypto.createHash('sha256').update(line).digest('hex');
30
+ const record = JSON.stringify({ ...entry, _hash: hash }) + '\n';
31
+
32
+ try {
33
+ fs.appendFileSync(this.logFile, record, 'utf8');
34
+ } catch {}
35
+ }
36
+
37
+ authFailure({ userId, username, ip, reason }) {
38
+ this.log({ type: 'auth.failure', userId, username, ip, reason });
39
+ }
40
+
41
+ authSuccess({ userId, username, ip }) {
42
+ this.log({ type: 'auth.success', userId, username, ip });
43
+ }
44
+
45
+ authorizationFailure({ userId, username, resource, action, ip }) {
46
+ this.log({ type: 'authorization.failure', userId, username, resource, action, ip });
47
+ }
48
+
49
+ sensitiveAction({ userId, username, action, resource, ip }) {
50
+ this.log({ type: 'sensitive.action', userId, username, action, resource, ip });
51
+ }
52
+ }
53
+
54
+ let instance = null;
55
+
56
+ function getAuditLogger() {
57
+ if (!instance) instance = new AuditLogger();
58
+ return instance;
59
+ }
60
+
61
+ module.exports = { AuditLogger, getAuditLogger };
@@ -0,0 +1,80 @@
1
+ const ErrorHandler = require('../errors/ErrorHandler');
2
+
3
+ const LOG_LEVELS = {
4
+ debug: 0,
5
+ info: 1,
6
+ warn: 2,
7
+ error: 3,
8
+ fatal: 4,
9
+ };
10
+
11
+ class StructuredLogger {
12
+ constructor({ minLevel = 'info', context = {} } = {}) {
13
+ this.minLevel = minLevel;
14
+ this.context = context;
15
+ }
16
+
17
+ _log(level, dataOrMessage, message) {
18
+ if (LOG_LEVELS[level] < LOG_LEVELS[this.minLevel]) return;
19
+
20
+ let data = {};
21
+ let msg;
22
+
23
+ if (message !== undefined) {
24
+ data = typeof dataOrMessage === 'object' && dataOrMessage !== null ? dataOrMessage : {};
25
+ msg = message;
26
+ } else {
27
+ msg = dataOrMessage;
28
+ }
29
+
30
+ const sanitized = ErrorHandler.sanitize({ ...this.context, ...data });
31
+
32
+ const entry = {
33
+ timestamp: new Date().toISOString(),
34
+ level,
35
+ message: msg,
36
+ ...sanitized,
37
+ };
38
+
39
+ const output = JSON.stringify(entry);
40
+
41
+ if (level === 'fatal' || level === 'error') {
42
+ console.error(output);
43
+ } else if (level === 'warn') {
44
+ console.warn(output);
45
+ } else if (level === 'debug') {
46
+ console.debug(output);
47
+ } else {
48
+ console.info(output);
49
+ }
50
+ }
51
+
52
+ debug(dataOrMessage, message) {
53
+ this._log('debug', dataOrMessage, message);
54
+ }
55
+
56
+ info(dataOrMessage, message) {
57
+ this._log('info', dataOrMessage, message);
58
+ }
59
+
60
+ warn(dataOrMessage, message) {
61
+ this._log('warn', dataOrMessage, message);
62
+ }
63
+
64
+ error(dataOrMessage, message) {
65
+ this._log('error', dataOrMessage, message);
66
+ }
67
+
68
+ fatal(dataOrMessage, message) {
69
+ this._log('fatal', dataOrMessage, message);
70
+ }
71
+
72
+ child(context) {
73
+ return new StructuredLogger({
74
+ minLevel: this.minLevel,
75
+ context: ErrorHandler.sanitize({ ...this.context, ...context }),
76
+ });
77
+ }
78
+ }
79
+
80
+ module.exports = StructuredLogger;
@@ -0,0 +1,213 @@
1
+ const StructuredLogger = require('../StructuredLogger');
2
+
3
+ describe('StructuredLogger', () => {
4
+ let logger;
5
+
6
+ beforeEach(() => {
7
+ logger = new StructuredLogger({ minLevel: 'debug' });
8
+ });
9
+
10
+ describe('log output structure', () => {
11
+ it('includes timestamp, level, and message in every log entry', () => {
12
+ const output = [];
13
+ jest.spyOn(console, 'info').mockImplementation((msg) => output.push(JSON.parse(msg)));
14
+
15
+ logger.info('test message');
16
+
17
+ expect(output).toHaveLength(1);
18
+ expect(output[0]).toMatchObject({
19
+ level: 'info',
20
+ message: 'test message',
21
+ });
22
+ expect(output[0].timestamp).toMatch(/^\d{4}-\d{2}-\d{2}T/);
23
+ });
24
+
25
+ it('accepts (data, message) signature and merges data into entry', () => {
26
+ const output = [];
27
+ jest.spyOn(console, 'info').mockImplementation((msg) => output.push(JSON.parse(msg)));
28
+
29
+ logger.info({ botId: 'bot-1', userId: 'user-1', requestId: 'req-1' }, 'with context');
30
+
31
+ expect(output[0]).toMatchObject({
32
+ level: 'info',
33
+ message: 'with context',
34
+ botId: 'bot-1',
35
+ userId: 'user-1',
36
+ requestId: 'req-1',
37
+ });
38
+ });
39
+
40
+ it('accepts (message) signature without data', () => {
41
+ const output = [];
42
+ jest.spyOn(console, 'info').mockImplementation((msg) => output.push(JSON.parse(msg)));
43
+
44
+ logger.info('simple message');
45
+
46
+ expect(output[0].message).toBe('simple message');
47
+ });
48
+ });
49
+
50
+ describe('log levels', () => {
51
+ it('calls console.debug for debug level', () => {
52
+ const spy = jest.spyOn(console, 'debug').mockImplementation(() => {});
53
+ logger.debug('debug msg');
54
+ expect(spy).toHaveBeenCalled();
55
+ });
56
+
57
+ it('calls console.info for info level', () => {
58
+ const spy = jest.spyOn(console, 'info').mockImplementation(() => {});
59
+ logger.info('info msg');
60
+ expect(spy).toHaveBeenCalled();
61
+ });
62
+
63
+ it('calls console.warn for warn level', () => {
64
+ const spy = jest.spyOn(console, 'warn').mockImplementation(() => {});
65
+ logger.warn('warn msg');
66
+ expect(spy).toHaveBeenCalled();
67
+ });
68
+
69
+ it('calls console.error for error level', () => {
70
+ const spy = jest.spyOn(console, 'error').mockImplementation(() => {});
71
+ logger.error('error msg');
72
+ expect(spy).toHaveBeenCalled();
73
+ });
74
+
75
+ it('calls console.error for fatal level', () => {
76
+ const spy = jest.spyOn(console, 'error').mockImplementation(() => {});
77
+ logger.fatal('fatal msg');
78
+ expect(spy).toHaveBeenCalled();
79
+ });
80
+ });
81
+
82
+ describe('minimum log level filtering', () => {
83
+ it('suppresses messages below the configured minimum level', () => {
84
+ const warnLogger = new StructuredLogger({ minLevel: 'warn' });
85
+ const spy = jest.spyOn(console, 'info').mockImplementation(() => {});
86
+ const debugSpy = jest.spyOn(console, 'debug').mockImplementation(() => {});
87
+
88
+ warnLogger.info('should be suppressed');
89
+ warnLogger.debug('should be suppressed');
90
+
91
+ expect(spy).not.toHaveBeenCalled();
92
+ expect(debugSpy).not.toHaveBeenCalled();
93
+ });
94
+
95
+ it('outputs messages at or above the minimum level', () => {
96
+ const warnLogger = new StructuredLogger({ minLevel: 'warn' });
97
+ const warnSpy = jest.spyOn(console, 'warn').mockImplementation(() => {});
98
+ const errorSpy = jest.spyOn(console, 'error').mockImplementation(() => {});
99
+
100
+ warnLogger.warn('warn passes');
101
+ warnLogger.error('error passes');
102
+ warnLogger.fatal('fatal passes');
103
+
104
+ expect(warnSpy).toHaveBeenCalledTimes(1);
105
+ expect(errorSpy).toHaveBeenCalledTimes(2);
106
+ });
107
+
108
+ it('defaults to info level', () => {
109
+ const defaultLogger = new StructuredLogger();
110
+ const debugSpy = jest.spyOn(console, 'debug').mockImplementation(() => {});
111
+ const infoSpy = jest.spyOn(console, 'info').mockImplementation(() => {});
112
+
113
+ defaultLogger.debug('suppressed');
114
+ defaultLogger.info('passes');
115
+
116
+ expect(debugSpy).not.toHaveBeenCalled();
117
+ expect(infoSpy).toHaveBeenCalledTimes(1);
118
+ });
119
+ });
120
+
121
+ describe('sensitive data redaction', () => {
122
+ it('redacts password fields', () => {
123
+ const output = [];
124
+ jest.spyOn(console, 'info').mockImplementation((msg) => output.push(JSON.parse(msg)));
125
+
126
+ logger.info({ password: 'secret123', userId: 'u1' }, 'login attempt');
127
+
128
+ expect(output[0].password).toBe('[REDACTED]');
129
+ expect(output[0].userId).toBe('u1');
130
+ });
131
+
132
+ it('redacts token fields', () => {
133
+ const output = [];
134
+ jest.spyOn(console, 'info').mockImplementation((msg) => output.push(JSON.parse(msg)));
135
+
136
+ logger.info({ token: 'abc123', botId: 'b1' }, 'token check');
137
+
138
+ expect(output[0].token).toBe('[REDACTED]');
139
+ expect(output[0].botId).toBe('b1');
140
+ });
141
+
142
+ it('redacts apiKey fields', () => {
143
+ const output = [];
144
+ jest.spyOn(console, 'info').mockImplementation((msg) => output.push(JSON.parse(msg)));
145
+
146
+ logger.info({ apiKey: 'key-xyz' }, 'api call');
147
+
148
+ expect(output[0].apiKey).toBe('[REDACTED]');
149
+ });
150
+ });
151
+
152
+ describe('child logger', () => {
153
+ it('creates a child logger with pre-bound context', () => {
154
+ const output = [];
155
+ jest.spyOn(console, 'info').mockImplementation((msg) => output.push(JSON.parse(msg)));
156
+
157
+ const child = logger.child({ botId: 'bot-42', requestId: 'req-99' });
158
+ child.info('child message');
159
+
160
+ expect(output[0]).toMatchObject({
161
+ botId: 'bot-42',
162
+ requestId: 'req-99',
163
+ message: 'child message',
164
+ });
165
+ });
166
+
167
+ it('child context is merged with per-call data', () => {
168
+ const output = [];
169
+ jest.spyOn(console, 'info').mockImplementation((msg) => output.push(JSON.parse(msg)));
170
+
171
+ const child = logger.child({ botId: 'bot-1' });
172
+ child.info({ userId: 'user-5' }, 'merged');
173
+
174
+ expect(output[0]).toMatchObject({
175
+ botId: 'bot-1',
176
+ userId: 'user-5',
177
+ message: 'merged',
178
+ });
179
+ });
180
+
181
+ it('child inherits parent minLevel', () => {
182
+ const parent = new StructuredLogger({ minLevel: 'error' });
183
+ const child = parent.child({ botId: 'b1' });
184
+ const spy = jest.spyOn(console, 'info').mockImplementation(() => {});
185
+
186
+ child.info('should be suppressed');
187
+
188
+ expect(spy).not.toHaveBeenCalled();
189
+ });
190
+
191
+ it('redacts sensitive fields in child context', () => {
192
+ const child = logger.child({ token: 'secret-token', botId: 'b1' });
193
+ const output = [];
194
+ jest.spyOn(console, 'info').mockImplementation((msg) => output.push(JSON.parse(msg)));
195
+
196
+ child.info('check redaction');
197
+
198
+ expect(output[0].token).toBe('[REDACTED]');
199
+ expect(output[0].botId).toBe('b1');
200
+ });
201
+ });
202
+
203
+ describe('output format', () => {
204
+ it('outputs valid JSON', () => {
205
+ const rawOutput = [];
206
+ jest.spyOn(console, 'info').mockImplementation((msg) => rawOutput.push(msg));
207
+
208
+ logger.info({ botId: 'b1' }, 'json check');
209
+
210
+ expect(() => JSON.parse(rawOutput[0])).not.toThrow();
211
+ });
212
+ });
213
+ });
@@ -0,0 +1,7 @@
1
+ const StructuredLogger = require('./StructuredLogger');
2
+
3
+ const defaultLogger = new StructuredLogger({
4
+ minLevel: process.env.LOG_LEVEL || 'info',
5
+ });
6
+
7
+ module.exports = { StructuredLogger, defaultLogger };
@@ -0,0 +1,104 @@
1
+ class MetricsCollector {
2
+ constructor() {
3
+ this._counters = new Map();
4
+ this._histograms = new Map();
5
+ this._gauges = new Map();
6
+ }
7
+
8
+ incrementCounter(name, labels = {}, value = 1) {
9
+ const key = this._key(name, labels);
10
+ this._counters.set(key, { name, labels, value: (this._counters.get(key)?.value || 0) + value });
11
+ }
12
+
13
+ recordDuration(name, durationMs, labels = {}) {
14
+ const key = this._key(name, labels);
15
+ const existing = this._histograms.get(key) || { name, labels, count: 0, sum: 0, min: Infinity, max: -Infinity, buckets: [] };
16
+ existing.count++;
17
+ existing.sum += durationMs;
18
+ existing.min = Math.min(existing.min, durationMs);
19
+ existing.max = Math.max(existing.max, durationMs);
20
+ existing.buckets.push(durationMs);
21
+ this._histograms.set(key, existing);
22
+ }
23
+
24
+ setGauge(name, value, labels = {}) {
25
+ const key = this._key(name, labels);
26
+ this._gauges.set(key, { name, labels, value });
27
+ }
28
+
29
+ getCounter(name, labels = {}) {
30
+ return this._counters.get(this._key(name, labels))?.value || 0;
31
+ }
32
+
33
+ getHistogram(name, labels = {}) {
34
+ const h = this._histograms.get(this._key(name, labels));
35
+ if (!h) return null;
36
+ const avg = h.count > 0 ? h.sum / h.count : 0;
37
+ const p50 = this._percentile(h.buckets, 50);
38
+ const p95 = this._percentile(h.buckets, 95);
39
+ const p99 = this._percentile(h.buckets, 99);
40
+ return { count: h.count, sum: h.sum, min: h.min, max: h.max, avg, p50, p95, p99 };
41
+ }
42
+
43
+ getGauge(name, labels = {}) {
44
+ return this._gauges.get(this._key(name, labels))?.value ?? null;
45
+ }
46
+
47
+ reset() {
48
+ this._counters.clear();
49
+ this._histograms.clear();
50
+ this._gauges.clear();
51
+ }
52
+
53
+ toPrometheus() {
54
+ const lines = [];
55
+
56
+ for (const { name, labels, value } of this._counters.values()) {
57
+ lines.push(`# TYPE ${name} counter`);
58
+ lines.push(`${name}${this._labelsStr(labels)} ${value}`);
59
+ }
60
+
61
+ for (const { name, labels, count, sum, min, max } of this._histograms.values()) {
62
+ lines.push(`# TYPE ${name} histogram`);
63
+ lines.push(`${name}_count${this._labelsStr(labels)} ${count}`);
64
+ lines.push(`${name}_sum${this._labelsStr(labels)} ${sum}`);
65
+ lines.push(`${name}_min${this._labelsStr(labels)} ${min}`);
66
+ lines.push(`${name}_max${this._labelsStr(labels)} ${max}`);
67
+ }
68
+
69
+ for (const { name, labels, value } of this._gauges.values()) {
70
+ lines.push(`# TYPE ${name} gauge`);
71
+ lines.push(`${name}${this._labelsStr(labels)} ${value}`);
72
+ }
73
+
74
+ return lines.join('\n');
75
+ }
76
+
77
+ _key(name, labels) {
78
+ const labelStr = Object.entries(labels).sort(([a], [b]) => a.localeCompare(b)).map(([k, v]) => `${k}="${v}"`).join(',');
79
+ return labelStr ? `${name}{${labelStr}}` : name;
80
+ }
81
+
82
+ _labelsStr(labels) {
83
+ const entries = Object.entries(labels);
84
+ if (entries.length === 0) return '';
85
+ const parts = entries.map(([k, v]) => `${k}="${v}"`).join(',');
86
+ return `{${parts}}`;
87
+ }
88
+
89
+ _percentile(values, p) {
90
+ if (values.length === 0) return 0;
91
+ const sorted = [...values].sort((a, b) => a - b);
92
+ const idx = Math.ceil((p / 100) * sorted.length) - 1;
93
+ return sorted[Math.max(0, idx)];
94
+ }
95
+ }
96
+
97
+ let instance = null;
98
+
99
+ function getMetricsCollector() {
100
+ if (!instance) instance = new MetricsCollector();
101
+ return instance;
102
+ }
103
+
104
+ module.exports = { MetricsCollector, getMetricsCollector };