stringray-ai 1.0.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 (635) hide show
  1. package/.mcp.json +68 -0
  2. package/LICENSE +21 -0
  3. package/README.md +618 -0
  4. package/dist/agents/architect.d.ts +3 -0
  5. package/dist/agents/architect.d.ts.map +1 -0
  6. package/dist/agents/architect.js +84 -0
  7. package/dist/agents/architect.js.map +1 -0
  8. package/dist/agents/bug-triage-specialist.d.ts +3 -0
  9. package/dist/agents/bug-triage-specialist.d.ts.map +1 -0
  10. package/dist/agents/bug-triage-specialist.js +66 -0
  11. package/dist/agents/bug-triage-specialist.js.map +1 -0
  12. package/dist/agents/code-reviewer.d.ts +3 -0
  13. package/dist/agents/code-reviewer.d.ts.map +1 -0
  14. package/dist/agents/code-reviewer.js +66 -0
  15. package/dist/agents/code-reviewer.js.map +1 -0
  16. package/dist/agents/enforcer.d.ts +3 -0
  17. package/dist/agents/enforcer.d.ts.map +1 -0
  18. package/dist/agents/enforcer.js +109 -0
  19. package/dist/agents/enforcer.js.map +1 -0
  20. package/dist/agents/index.d.ts +15 -0
  21. package/dist/agents/index.d.ts.map +1 -0
  22. package/dist/agents/index.js +26 -0
  23. package/dist/agents/index.js.map +1 -0
  24. package/dist/agents/librarian.d.ts +3 -0
  25. package/dist/agents/librarian.d.ts.map +1 -0
  26. package/dist/agents/librarian.js +70 -0
  27. package/dist/agents/librarian.js.map +1 -0
  28. package/dist/agents/log-monitor.d.ts +3 -0
  29. package/dist/agents/log-monitor.d.ts.map +1 -0
  30. package/dist/agents/log-monitor.js +102 -0
  31. package/dist/agents/log-monitor.js.map +1 -0
  32. package/dist/agents/orchestrator.d.ts +3 -0
  33. package/dist/agents/orchestrator.d.ts.map +1 -0
  34. package/dist/agents/orchestrator.js +85 -0
  35. package/dist/agents/orchestrator.js.map +1 -0
  36. package/dist/agents/refactorer.d.ts +3 -0
  37. package/dist/agents/refactorer.d.ts.map +1 -0
  38. package/dist/agents/refactorer.js +67 -0
  39. package/dist/agents/refactorer.js.map +1 -0
  40. package/dist/agents/security-auditor.d.ts +3 -0
  41. package/dist/agents/security-auditor.d.ts.map +1 -0
  42. package/dist/agents/security-auditor.js +66 -0
  43. package/dist/agents/security-auditor.js.map +1 -0
  44. package/dist/agents/sisyphus.d.ts +3 -0
  45. package/dist/agents/sisyphus.d.ts.map +1 -0
  46. package/dist/agents/sisyphus.js +53 -0
  47. package/dist/agents/sisyphus.js.map +1 -0
  48. package/dist/agents/test-architect.d.ts +3 -0
  49. package/dist/agents/test-architect.d.ts.map +1 -0
  50. package/dist/agents/test-architect.js +81 -0
  51. package/dist/agents/test-architect.js.map +1 -0
  52. package/dist/agents/types.d.ts +29 -0
  53. package/dist/agents/types.d.ts.map +1 -0
  54. package/dist/agents/types.js +2 -0
  55. package/dist/agents/types.js.map +1 -0
  56. package/dist/mcps/architect-tools.server.d.ts +40 -0
  57. package/dist/mcps/architect-tools.server.d.ts.map +1 -0
  58. package/dist/mcps/architect-tools.server.js +563 -0
  59. package/dist/mcps/architect-tools.server.js.map +1 -0
  60. package/dist/mcps/auto-format.server.d.ts +20 -0
  61. package/dist/mcps/auto-format.server.d.ts.map +1 -0
  62. package/dist/mcps/auto-format.server.js +391 -0
  63. package/dist/mcps/auto-format.server.js.map +1 -0
  64. package/dist/mcps/boot-orchestrator.server.d.ts +50 -0
  65. package/dist/mcps/boot-orchestrator.server.d.ts.map +1 -0
  66. package/dist/mcps/boot-orchestrator.server.js +871 -0
  67. package/dist/mcps/boot-orchestrator.server.js.map +1 -0
  68. package/dist/mcps/enforcer-tools.server.d.ts +26 -0
  69. package/dist/mcps/enforcer-tools.server.d.ts.map +1 -0
  70. package/dist/mcps/enforcer-tools.server.js +627 -0
  71. package/dist/mcps/enforcer-tools.server.js.map +1 -0
  72. package/dist/mcps/enhanced-orchestrator.server.d.ts +14 -0
  73. package/dist/mcps/enhanced-orchestrator.server.d.ts.map +1 -0
  74. package/dist/mcps/enhanced-orchestrator.server.js +250 -0
  75. package/dist/mcps/enhanced-orchestrator.server.js.map +1 -0
  76. package/dist/mcps/framework-compliance-audit.server.d.ts +23 -0
  77. package/dist/mcps/framework-compliance-audit.server.d.ts.map +1 -0
  78. package/dist/mcps/framework-compliance-audit.server.js +511 -0
  79. package/dist/mcps/framework-compliance-audit.server.js.map +1 -0
  80. package/dist/mcps/knowledge-skills/api-design.server.d.ts +16 -0
  81. package/dist/mcps/knowledge-skills/api-design.server.d.ts.map +1 -0
  82. package/dist/mcps/knowledge-skills/api-design.server.js +120 -0
  83. package/dist/mcps/knowledge-skills/api-design.server.js.map +1 -0
  84. package/dist/mcps/knowledge-skills/architecture-patterns.server.d.ts +16 -0
  85. package/dist/mcps/knowledge-skills/architecture-patterns.server.d.ts.map +1 -0
  86. package/dist/mcps/knowledge-skills/architecture-patterns.server.js +110 -0
  87. package/dist/mcps/knowledge-skills/architecture-patterns.server.js.map +1 -0
  88. package/dist/mcps/knowledge-skills/code-review.server.d.ts +32 -0
  89. package/dist/mcps/knowledge-skills/code-review.server.d.ts.map +1 -0
  90. package/dist/mcps/knowledge-skills/code-review.server.js +777 -0
  91. package/dist/mcps/knowledge-skills/code-review.server.js.map +1 -0
  92. package/dist/mcps/knowledge-skills/database-design.server.d.ts +44 -0
  93. package/dist/mcps/knowledge-skills/database-design.server.d.ts.map +1 -0
  94. package/dist/mcps/knowledge-skills/database-design.server.js +818 -0
  95. package/dist/mcps/knowledge-skills/database-design.server.js.map +1 -0
  96. package/dist/mcps/knowledge-skills/devops-deployment.server.d.ts +44 -0
  97. package/dist/mcps/knowledge-skills/devops-deployment.server.d.ts.map +1 -0
  98. package/dist/mcps/knowledge-skills/devops-deployment.server.js +1178 -0
  99. package/dist/mcps/knowledge-skills/devops-deployment.server.js.map +1 -0
  100. package/dist/mcps/knowledge-skills/documentation-generation.server.d.ts +48 -0
  101. package/dist/mcps/knowledge-skills/documentation-generation.server.d.ts.map +1 -0
  102. package/dist/mcps/knowledge-skills/documentation-generation.server.js +1188 -0
  103. package/dist/mcps/knowledge-skills/documentation-generation.server.js.map +1 -0
  104. package/dist/mcps/knowledge-skills/git-workflow.server.d.ts +16 -0
  105. package/dist/mcps/knowledge-skills/git-workflow.server.d.ts.map +1 -0
  106. package/dist/mcps/knowledge-skills/git-workflow.server.js +112 -0
  107. package/dist/mcps/knowledge-skills/git-workflow.server.js.map +1 -0
  108. package/dist/mcps/knowledge-skills/performance-optimization.server.d.ts +16 -0
  109. package/dist/mcps/knowledge-skills/performance-optimization.server.d.ts.map +1 -0
  110. package/dist/mcps/knowledge-skills/performance-optimization.server.js +108 -0
  111. package/dist/mcps/knowledge-skills/performance-optimization.server.js.map +1 -0
  112. package/dist/mcps/knowledge-skills/project-analysis.server.d.ts +34 -0
  113. package/dist/mcps/knowledge-skills/project-analysis.server.d.ts.map +1 -0
  114. package/dist/mcps/knowledge-skills/project-analysis.server.js +710 -0
  115. package/dist/mcps/knowledge-skills/project-analysis.server.js.map +1 -0
  116. package/dist/mcps/knowledge-skills/refactoring-strategies.server.d.ts +34 -0
  117. package/dist/mcps/knowledge-skills/refactoring-strategies.server.d.ts.map +1 -0
  118. package/dist/mcps/knowledge-skills/refactoring-strategies.server.js +794 -0
  119. package/dist/mcps/knowledge-skills/refactoring-strategies.server.js.map +1 -0
  120. package/dist/mcps/knowledge-skills/security-audit.server.d.ts +34 -0
  121. package/dist/mcps/knowledge-skills/security-audit.server.d.ts.map +1 -0
  122. package/dist/mcps/knowledge-skills/security-audit.server.js +769 -0
  123. package/dist/mcps/knowledge-skills/security-audit.server.js.map +1 -0
  124. package/dist/mcps/knowledge-skills/testing-best-practices.server.d.ts +37 -0
  125. package/dist/mcps/knowledge-skills/testing-best-practices.server.d.ts.map +1 -0
  126. package/dist/mcps/knowledge-skills/testing-best-practices.server.js +865 -0
  127. package/dist/mcps/knowledge-skills/testing-best-practices.server.js.map +1 -0
  128. package/dist/mcps/knowledge-skills/testing-strategy.server.d.ts +47 -0
  129. package/dist/mcps/knowledge-skills/testing-strategy.server.d.ts.map +1 -0
  130. package/dist/mcps/knowledge-skills/testing-strategy.server.js +672 -0
  131. package/dist/mcps/knowledge-skills/testing-strategy.server.js.map +1 -0
  132. package/dist/mcps/knowledge-skills/ui-ux-design.server.d.ts +42 -0
  133. package/dist/mcps/knowledge-skills/ui-ux-design.server.d.ts.map +1 -0
  134. package/dist/mcps/knowledge-skills/ui-ux-design.server.js +1016 -0
  135. package/dist/mcps/knowledge-skills/ui-ux-design.server.js.map +1 -0
  136. package/dist/mcps/lint.server.d.ts +18 -0
  137. package/dist/mcps/lint.server.d.ts.map +1 -0
  138. package/dist/mcps/lint.server.js +334 -0
  139. package/dist/mcps/lint.server.js.map +1 -0
  140. package/dist/mcps/model-health-check.server.d.ts +17 -0
  141. package/dist/mcps/model-health-check.server.d.ts.map +1 -0
  142. package/dist/mcps/model-health-check.server.js +226 -0
  143. package/dist/mcps/model-health-check.server.js.map +1 -0
  144. package/dist/mcps/orchestrator.server.d.ts +39 -0
  145. package/dist/mcps/orchestrator.server.d.ts.map +1 -0
  146. package/dist/mcps/orchestrator.server.js +908 -0
  147. package/dist/mcps/orchestrator.server.js.map +1 -0
  148. package/dist/mcps/performance-analysis.server.d.ts +28 -0
  149. package/dist/mcps/performance-analysis.server.d.ts.map +1 -0
  150. package/dist/mcps/performance-analysis.server.js +514 -0
  151. package/dist/mcps/performance-analysis.server.js.map +1 -0
  152. package/dist/mcps/processor-pipeline.server.d.ts +29 -0
  153. package/dist/mcps/processor-pipeline.server.d.ts.map +1 -0
  154. package/dist/mcps/processor-pipeline.server.js +520 -0
  155. package/dist/mcps/processor-pipeline.server.js.map +1 -0
  156. package/dist/mcps/security-scan.server.d.ts +20 -0
  157. package/dist/mcps/security-scan.server.d.ts.map +1 -0
  158. package/dist/mcps/security-scan.server.js +404 -0
  159. package/dist/mcps/security-scan.server.js.map +1 -0
  160. package/dist/mcps/state-manager.server.d.ts +29 -0
  161. package/dist/mcps/state-manager.server.d.ts.map +1 -0
  162. package/dist/mcps/state-manager.server.js +620 -0
  163. package/dist/mcps/state-manager.server.js.map +1 -0
  164. package/dist/orchestrator/enhanced-multi-agent-orchestrator.d.ts +109 -0
  165. package/dist/orchestrator/enhanced-multi-agent-orchestrator.d.ts.map +1 -0
  166. package/dist/orchestrator/enhanced-multi-agent-orchestrator.js +337 -0
  167. package/dist/orchestrator/enhanced-multi-agent-orchestrator.js.map +1 -0
  168. package/dist/orchestrator/intelligent-commit-batcher.d.ts +112 -0
  169. package/dist/orchestrator/intelligent-commit-batcher.d.ts.map +1 -0
  170. package/dist/orchestrator/intelligent-commit-batcher.js +330 -0
  171. package/dist/orchestrator/intelligent-commit-batcher.js.map +1 -0
  172. package/dist/plugin/agents/architect.d.ts +3 -0
  173. package/dist/plugin/agents/architect.d.ts.map +1 -0
  174. package/dist/plugin/agents/architect.js +84 -0
  175. package/dist/plugin/agents/architect.js.map +1 -0
  176. package/dist/plugin/agents/bug-triage-specialist.d.ts +3 -0
  177. package/dist/plugin/agents/bug-triage-specialist.d.ts.map +1 -0
  178. package/dist/plugin/agents/bug-triage-specialist.js +66 -0
  179. package/dist/plugin/agents/bug-triage-specialist.js.map +1 -0
  180. package/dist/plugin/agents/code-reviewer.d.ts +3 -0
  181. package/dist/plugin/agents/code-reviewer.d.ts.map +1 -0
  182. package/dist/plugin/agents/code-reviewer.js +66 -0
  183. package/dist/plugin/agents/code-reviewer.js.map +1 -0
  184. package/dist/plugin/agents/enforcer.d.ts +3 -0
  185. package/dist/plugin/agents/enforcer.d.ts.map +1 -0
  186. package/dist/plugin/agents/enforcer.js +109 -0
  187. package/dist/plugin/agents/enforcer.js.map +1 -0
  188. package/dist/plugin/agents/index.d.ts +15 -0
  189. package/dist/plugin/agents/index.d.ts.map +1 -0
  190. package/dist/plugin/agents/index.js +26 -0
  191. package/dist/plugin/agents/index.js.map +1 -0
  192. package/dist/plugin/agents/librarian.d.ts +3 -0
  193. package/dist/plugin/agents/librarian.d.ts.map +1 -0
  194. package/dist/plugin/agents/librarian.js +70 -0
  195. package/dist/plugin/agents/librarian.js.map +1 -0
  196. package/dist/plugin/agents/log-monitor.d.ts +3 -0
  197. package/dist/plugin/agents/log-monitor.d.ts.map +1 -0
  198. package/dist/plugin/agents/log-monitor.js +102 -0
  199. package/dist/plugin/agents/log-monitor.js.map +1 -0
  200. package/dist/plugin/agents/orchestrator.d.ts +3 -0
  201. package/dist/plugin/agents/orchestrator.d.ts.map +1 -0
  202. package/dist/plugin/agents/orchestrator.js +85 -0
  203. package/dist/plugin/agents/orchestrator.js.map +1 -0
  204. package/dist/plugin/agents/refactorer.d.ts +3 -0
  205. package/dist/plugin/agents/refactorer.d.ts.map +1 -0
  206. package/dist/plugin/agents/refactorer.js +67 -0
  207. package/dist/plugin/agents/refactorer.js.map +1 -0
  208. package/dist/plugin/agents/security-auditor.d.ts +3 -0
  209. package/dist/plugin/agents/security-auditor.d.ts.map +1 -0
  210. package/dist/plugin/agents/security-auditor.js +66 -0
  211. package/dist/plugin/agents/security-auditor.js.map +1 -0
  212. package/dist/plugin/agents/sisyphus.d.ts +3 -0
  213. package/dist/plugin/agents/sisyphus.d.ts.map +1 -0
  214. package/dist/plugin/agents/sisyphus.js +53 -0
  215. package/dist/plugin/agents/sisyphus.js.map +1 -0
  216. package/dist/plugin/agents/test-architect.d.ts +3 -0
  217. package/dist/plugin/agents/test-architect.d.ts.map +1 -0
  218. package/dist/plugin/agents/test-architect.js +81 -0
  219. package/dist/plugin/agents/test-architect.js.map +1 -0
  220. package/dist/plugin/agents/types.d.ts +29 -0
  221. package/dist/plugin/agents/types.d.ts.map +1 -0
  222. package/dist/plugin/agents/types.js +2 -0
  223. package/dist/plugin/agents/types.js.map +1 -0
  224. package/dist/plugin/config-loader.d.ts +67 -0
  225. package/dist/plugin/config-loader.d.ts.map +1 -0
  226. package/dist/plugin/config-loader.js +125 -0
  227. package/dist/plugin/config-loader.js.map +1 -0
  228. package/dist/plugin/context-loader.d.ts +122 -0
  229. package/dist/plugin/context-loader.d.ts.map +1 -0
  230. package/dist/plugin/context-loader.js +273 -0
  231. package/dist/plugin/context-loader.js.map +1 -0
  232. package/dist/plugin/delegation/agent-delegator.d.ts +217 -0
  233. package/dist/plugin/delegation/agent-delegator.d.ts.map +1 -0
  234. package/dist/plugin/delegation/agent-delegator.js +928 -0
  235. package/dist/plugin/delegation/agent-delegator.js.map +1 -0
  236. package/dist/plugin/delegation/codebase-context-analyzer.d.ts +157 -0
  237. package/dist/plugin/delegation/codebase-context-analyzer.d.ts.map +1 -0
  238. package/dist/plugin/delegation/codebase-context-analyzer.js +1029 -0
  239. package/dist/plugin/delegation/codebase-context-analyzer.js.map +1 -0
  240. package/dist/plugin/delegation/complexity-analyzer.d.ts +61 -0
  241. package/dist/plugin/delegation/complexity-analyzer.d.ts.map +1 -0
  242. package/dist/plugin/delegation/complexity-analyzer.js +253 -0
  243. package/dist/plugin/delegation/complexity-analyzer.js.map +1 -0
  244. package/dist/plugin/enforcement/enforcer-tools.d.ts +62 -0
  245. package/dist/plugin/enforcement/enforcer-tools.d.ts.map +1 -0
  246. package/dist/plugin/enforcement/enforcer-tools.js +407 -0
  247. package/dist/plugin/enforcement/enforcer-tools.js.map +1 -0
  248. package/dist/plugin/enforcement/rule-enforcer.d.ts +171 -0
  249. package/dist/plugin/enforcement/rule-enforcer.d.ts.map +1 -0
  250. package/dist/plugin/enforcement/rule-enforcer.js +1342 -0
  251. package/dist/plugin/enforcement/rule-enforcer.js.map +1 -0
  252. package/dist/plugin/enforcement/test-auto-healing.d.ts +78 -0
  253. package/dist/plugin/enforcement/test-auto-healing.d.ts.map +1 -0
  254. package/dist/plugin/enforcement/test-auto-healing.js +318 -0
  255. package/dist/plugin/enforcement/test-auto-healing.js.map +1 -0
  256. package/dist/plugin/framework-logger.d.ts +20 -0
  257. package/dist/plugin/framework-logger.d.ts.map +1 -0
  258. package/dist/plugin/framework-logger.js +79 -0
  259. package/dist/plugin/framework-logger.js.map +1 -0
  260. package/dist/plugin/logging-config.d.ts +11 -0
  261. package/dist/plugin/logging-config.d.ts.map +1 -0
  262. package/dist/plugin/logging-config.js +44 -0
  263. package/dist/plugin/logging-config.js.map +1 -0
  264. package/dist/plugin/mcps/architect-tools.server.d.ts +40 -0
  265. package/dist/plugin/mcps/architect-tools.server.d.ts.map +1 -0
  266. package/dist/plugin/mcps/architect-tools.server.js +563 -0
  267. package/dist/plugin/mcps/architect-tools.server.js.map +1 -0
  268. package/dist/plugin/mcps/auto-format.server.d.ts +20 -0
  269. package/dist/plugin/mcps/auto-format.server.d.ts.map +1 -0
  270. package/dist/plugin/mcps/auto-format.server.js +391 -0
  271. package/dist/plugin/mcps/auto-format.server.js.map +1 -0
  272. package/dist/plugin/mcps/boot-orchestrator.server.d.ts +50 -0
  273. package/dist/plugin/mcps/boot-orchestrator.server.d.ts.map +1 -0
  274. package/dist/plugin/mcps/boot-orchestrator.server.js +871 -0
  275. package/dist/plugin/mcps/boot-orchestrator.server.js.map +1 -0
  276. package/dist/plugin/mcps/enforcer-tools.server.d.ts +26 -0
  277. package/dist/plugin/mcps/enforcer-tools.server.d.ts.map +1 -0
  278. package/dist/plugin/mcps/enforcer-tools.server.js +627 -0
  279. package/dist/plugin/mcps/enforcer-tools.server.js.map +1 -0
  280. package/dist/plugin/mcps/enhanced-orchestrator.server.d.ts +14 -0
  281. package/dist/plugin/mcps/enhanced-orchestrator.server.d.ts.map +1 -0
  282. package/dist/plugin/mcps/enhanced-orchestrator.server.js +250 -0
  283. package/dist/plugin/mcps/enhanced-orchestrator.server.js.map +1 -0
  284. package/dist/plugin/mcps/framework-compliance-audit.server.d.ts +23 -0
  285. package/dist/plugin/mcps/framework-compliance-audit.server.d.ts.map +1 -0
  286. package/dist/plugin/mcps/framework-compliance-audit.server.js +511 -0
  287. package/dist/plugin/mcps/framework-compliance-audit.server.js.map +1 -0
  288. package/dist/plugin/mcps/knowledge-skills/api-design.server.d.ts +16 -0
  289. package/dist/plugin/mcps/knowledge-skills/api-design.server.d.ts.map +1 -0
  290. package/dist/plugin/mcps/knowledge-skills/api-design.server.js +120 -0
  291. package/dist/plugin/mcps/knowledge-skills/api-design.server.js.map +1 -0
  292. package/dist/plugin/mcps/knowledge-skills/architecture-patterns.server.d.ts +16 -0
  293. package/dist/plugin/mcps/knowledge-skills/architecture-patterns.server.d.ts.map +1 -0
  294. package/dist/plugin/mcps/knowledge-skills/architecture-patterns.server.js +110 -0
  295. package/dist/plugin/mcps/knowledge-skills/architecture-patterns.server.js.map +1 -0
  296. package/dist/plugin/mcps/knowledge-skills/code-review.server.d.ts +32 -0
  297. package/dist/plugin/mcps/knowledge-skills/code-review.server.d.ts.map +1 -0
  298. package/dist/plugin/mcps/knowledge-skills/code-review.server.js +777 -0
  299. package/dist/plugin/mcps/knowledge-skills/code-review.server.js.map +1 -0
  300. package/dist/plugin/mcps/knowledge-skills/database-design.server.d.ts +44 -0
  301. package/dist/plugin/mcps/knowledge-skills/database-design.server.d.ts.map +1 -0
  302. package/dist/plugin/mcps/knowledge-skills/database-design.server.js +818 -0
  303. package/dist/plugin/mcps/knowledge-skills/database-design.server.js.map +1 -0
  304. package/dist/plugin/mcps/knowledge-skills/devops-deployment.server.d.ts +44 -0
  305. package/dist/plugin/mcps/knowledge-skills/devops-deployment.server.d.ts.map +1 -0
  306. package/dist/plugin/mcps/knowledge-skills/devops-deployment.server.js +1178 -0
  307. package/dist/plugin/mcps/knowledge-skills/devops-deployment.server.js.map +1 -0
  308. package/dist/plugin/mcps/knowledge-skills/documentation-generation.server.d.ts +48 -0
  309. package/dist/plugin/mcps/knowledge-skills/documentation-generation.server.d.ts.map +1 -0
  310. package/dist/plugin/mcps/knowledge-skills/documentation-generation.server.js +1188 -0
  311. package/dist/plugin/mcps/knowledge-skills/documentation-generation.server.js.map +1 -0
  312. package/dist/plugin/mcps/knowledge-skills/git-workflow.server.d.ts +16 -0
  313. package/dist/plugin/mcps/knowledge-skills/git-workflow.server.d.ts.map +1 -0
  314. package/dist/plugin/mcps/knowledge-skills/git-workflow.server.js +112 -0
  315. package/dist/plugin/mcps/knowledge-skills/git-workflow.server.js.map +1 -0
  316. package/dist/plugin/mcps/knowledge-skills/performance-optimization.server.d.ts +16 -0
  317. package/dist/plugin/mcps/knowledge-skills/performance-optimization.server.d.ts.map +1 -0
  318. package/dist/plugin/mcps/knowledge-skills/performance-optimization.server.js +108 -0
  319. package/dist/plugin/mcps/knowledge-skills/performance-optimization.server.js.map +1 -0
  320. package/dist/plugin/mcps/knowledge-skills/project-analysis.server.d.ts +34 -0
  321. package/dist/plugin/mcps/knowledge-skills/project-analysis.server.d.ts.map +1 -0
  322. package/dist/plugin/mcps/knowledge-skills/project-analysis.server.js +710 -0
  323. package/dist/plugin/mcps/knowledge-skills/project-analysis.server.js.map +1 -0
  324. package/dist/plugin/mcps/knowledge-skills/refactoring-strategies.server.d.ts +34 -0
  325. package/dist/plugin/mcps/knowledge-skills/refactoring-strategies.server.d.ts.map +1 -0
  326. package/dist/plugin/mcps/knowledge-skills/refactoring-strategies.server.js +794 -0
  327. package/dist/plugin/mcps/knowledge-skills/refactoring-strategies.server.js.map +1 -0
  328. package/dist/plugin/mcps/knowledge-skills/security-audit.server.d.ts +34 -0
  329. package/dist/plugin/mcps/knowledge-skills/security-audit.server.d.ts.map +1 -0
  330. package/dist/plugin/mcps/knowledge-skills/security-audit.server.js +769 -0
  331. package/dist/plugin/mcps/knowledge-skills/security-audit.server.js.map +1 -0
  332. package/dist/plugin/mcps/knowledge-skills/testing-best-practices.server.d.ts +37 -0
  333. package/dist/plugin/mcps/knowledge-skills/testing-best-practices.server.d.ts.map +1 -0
  334. package/dist/plugin/mcps/knowledge-skills/testing-best-practices.server.js +865 -0
  335. package/dist/plugin/mcps/knowledge-skills/testing-best-practices.server.js.map +1 -0
  336. package/dist/plugin/mcps/knowledge-skills/testing-strategy.server.d.ts +47 -0
  337. package/dist/plugin/mcps/knowledge-skills/testing-strategy.server.d.ts.map +1 -0
  338. package/dist/plugin/mcps/knowledge-skills/testing-strategy.server.js +672 -0
  339. package/dist/plugin/mcps/knowledge-skills/testing-strategy.server.js.map +1 -0
  340. package/dist/plugin/mcps/knowledge-skills/ui-ux-design.server.d.ts +42 -0
  341. package/dist/plugin/mcps/knowledge-skills/ui-ux-design.server.d.ts.map +1 -0
  342. package/dist/plugin/mcps/knowledge-skills/ui-ux-design.server.js +1016 -0
  343. package/dist/plugin/mcps/knowledge-skills/ui-ux-design.server.js.map +1 -0
  344. package/dist/plugin/mcps/lint.server.d.ts +18 -0
  345. package/dist/plugin/mcps/lint.server.d.ts.map +1 -0
  346. package/dist/plugin/mcps/lint.server.js +334 -0
  347. package/dist/plugin/mcps/lint.server.js.map +1 -0
  348. package/dist/plugin/mcps/model-health-check.server.d.ts +17 -0
  349. package/dist/plugin/mcps/model-health-check.server.d.ts.map +1 -0
  350. package/dist/plugin/mcps/model-health-check.server.js +226 -0
  351. package/dist/plugin/mcps/model-health-check.server.js.map +1 -0
  352. package/dist/plugin/mcps/orchestrator.server.d.ts +39 -0
  353. package/dist/plugin/mcps/orchestrator.server.d.ts.map +1 -0
  354. package/dist/plugin/mcps/orchestrator.server.js +908 -0
  355. package/dist/plugin/mcps/orchestrator.server.js.map +1 -0
  356. package/dist/plugin/mcps/performance-analysis.server.d.ts +28 -0
  357. package/dist/plugin/mcps/performance-analysis.server.d.ts.map +1 -0
  358. package/dist/plugin/mcps/performance-analysis.server.js +514 -0
  359. package/dist/plugin/mcps/performance-analysis.server.js.map +1 -0
  360. package/dist/plugin/mcps/processor-pipeline.server.d.ts +29 -0
  361. package/dist/plugin/mcps/processor-pipeline.server.d.ts.map +1 -0
  362. package/dist/plugin/mcps/processor-pipeline.server.js +520 -0
  363. package/dist/plugin/mcps/processor-pipeline.server.js.map +1 -0
  364. package/dist/plugin/mcps/security-scan.server.d.ts +20 -0
  365. package/dist/plugin/mcps/security-scan.server.d.ts.map +1 -0
  366. package/dist/plugin/mcps/security-scan.server.js +404 -0
  367. package/dist/plugin/mcps/security-scan.server.js.map +1 -0
  368. package/dist/plugin/mcps/state-manager.server.d.ts +29 -0
  369. package/dist/plugin/mcps/state-manager.server.d.ts.map +1 -0
  370. package/dist/plugin/mcps/state-manager.server.js +620 -0
  371. package/dist/plugin/mcps/state-manager.server.js.map +1 -0
  372. package/dist/plugin/monitoring/advanced-profiler.d.ts +48 -0
  373. package/dist/plugin/monitoring/advanced-profiler.d.ts.map +1 -0
  374. package/dist/plugin/monitoring/advanced-profiler.js +216 -0
  375. package/dist/plugin/monitoring/advanced-profiler.js.map +1 -0
  376. package/dist/plugin/monitoring/enterprise-monitoring-system.d.ts +331 -0
  377. package/dist/plugin/monitoring/enterprise-monitoring-system.d.ts.map +1 -0
  378. package/dist/plugin/monitoring/enterprise-monitoring-system.js +797 -0
  379. package/dist/plugin/monitoring/enterprise-monitoring-system.js.map +1 -0
  380. package/dist/plugin/orchestrator/enhanced-multi-agent-orchestrator.d.ts +111 -0
  381. package/dist/plugin/orchestrator/enhanced-multi-agent-orchestrator.d.ts.map +1 -0
  382. package/dist/plugin/orchestrator/enhanced-multi-agent-orchestrator.js +339 -0
  383. package/dist/plugin/orchestrator/enhanced-multi-agent-orchestrator.js.map +1 -0
  384. package/dist/plugin/orchestrator/intelligent-commit-batcher.d.ts +112 -0
  385. package/dist/plugin/orchestrator/intelligent-commit-batcher.d.ts.map +1 -0
  386. package/dist/plugin/orchestrator/intelligent-commit-batcher.js +330 -0
  387. package/dist/plugin/orchestrator/intelligent-commit-batcher.js.map +1 -0
  388. package/dist/plugin/orchestrator.d.ts +91 -0
  389. package/dist/plugin/orchestrator.d.ts.map +1 -0
  390. package/dist/plugin/orchestrator.js +444 -0
  391. package/dist/plugin/orchestrator.js.map +1 -0
  392. package/dist/plugin/plugins/marketplace/marketplace-service.d.ts +108 -0
  393. package/dist/plugin/plugins/marketplace/marketplace-service.d.ts.map +1 -0
  394. package/dist/plugin/plugins/marketplace/marketplace-service.js +620 -0
  395. package/dist/plugin/plugins/marketplace/marketplace-service.js.map +1 -0
  396. package/dist/plugin/plugins/marketplace/marketplace-types.d.ts +468 -0
  397. package/dist/plugin/plugins/marketplace/marketplace-types.d.ts.map +1 -0
  398. package/dist/plugin/plugins/marketplace/marketplace-types.js +11 -0
  399. package/dist/plugin/plugins/marketplace/marketplace-types.js.map +1 -0
  400. package/dist/plugin/plugins/plugin-system.d.ts +152 -0
  401. package/dist/plugin/plugins/plugin-system.d.ts.map +1 -0
  402. package/dist/plugin/plugins/plugin-system.js +405 -0
  403. package/dist/plugin/plugins/plugin-system.js.map +1 -0
  404. package/dist/plugin/plugins/stringray-codex-injection.d.ts +68 -0
  405. package/dist/plugin/plugins/stringray-codex-injection.d.ts.map +1 -0
  406. package/dist/plugin/plugins/stringray-codex-injection.js +225 -0
  407. package/dist/plugin/plugins/stringray-codex-injection.js.map +1 -0
  408. package/dist/plugin/plugins/strray-codex-injection.d.ts +68 -0
  409. package/dist/plugin/plugins/strray-codex-injection.d.ts.map +1 -0
  410. package/dist/plugin/plugins/strray-codex-injection.js +225 -0
  411. package/dist/plugin/plugins/strray-codex-injection.js.map +1 -0
  412. package/dist/plugin/processors/index.d.ts +12 -0
  413. package/dist/plugin/processors/index.d.ts.map +1 -0
  414. package/dist/plugin/processors/index.js +12 -0
  415. package/dist/plugin/processors/index.js.map +1 -0
  416. package/dist/plugin/processors/processor-manager.d.ts +113 -0
  417. package/dist/plugin/processors/processor-manager.d.ts.map +1 -0
  418. package/dist/plugin/processors/processor-manager.js +498 -0
  419. package/dist/plugin/processors/processor-manager.js.map +1 -0
  420. package/dist/plugin/processors/processor-types.d.ts +50 -0
  421. package/dist/plugin/processors/processor-types.d.ts.map +1 -0
  422. package/dist/plugin/processors/processor-types.js +10 -0
  423. package/dist/plugin/processors/processor-types.js.map +1 -0
  424. package/dist/plugin/processors/refactoring-logging-processor.d.ts +61 -0
  425. package/dist/plugin/processors/refactoring-logging-processor.d.ts.map +1 -0
  426. package/dist/plugin/processors/refactoring-logging-processor.js +257 -0
  427. package/dist/plugin/processors/refactoring-logging-processor.js.map +1 -0
  428. package/dist/plugin/reporting/framework-reporting-system.d.ts +157 -0
  429. package/dist/plugin/reporting/framework-reporting-system.d.ts.map +1 -0
  430. package/dist/plugin/reporting/framework-reporting-system.js +783 -0
  431. package/dist/plugin/reporting/framework-reporting-system.js.map +1 -0
  432. package/dist/plugin/security/security-hardening-system.d.ts +220 -0
  433. package/dist/plugin/security/security-hardening-system.d.ts.map +1 -0
  434. package/dist/plugin/security/security-hardening-system.js +605 -0
  435. package/dist/plugin/security/security-hardening-system.js.map +1 -0
  436. package/dist/plugin/state/context-providers.d.ts +5 -0
  437. package/dist/plugin/state/context-providers.d.ts.map +1 -0
  438. package/dist/plugin/state/context-providers.js +2 -0
  439. package/dist/plugin/state/context-providers.js.map +1 -0
  440. package/dist/plugin/state/index.d.ts +5 -0
  441. package/dist/plugin/state/index.d.ts.map +1 -0
  442. package/dist/plugin/state/index.js +8 -0
  443. package/dist/plugin/state/index.js.map +1 -0
  444. package/dist/plugin/state/state-manager.d.ts +29 -0
  445. package/dist/plugin/state/state-manager.d.ts.map +1 -0
  446. package/dist/plugin/state/state-manager.js +153 -0
  447. package/dist/plugin/state/state-manager.js.map +1 -0
  448. package/dist/plugin/state/state-types.d.ts +6 -0
  449. package/dist/plugin/state/state-types.d.ts.map +1 -0
  450. package/dist/plugin/state/state-types.js +2 -0
  451. package/dist/plugin/state/state-types.js.map +1 -0
  452. package/dist/plugin/utils/codex-parser.d.ts +62 -0
  453. package/dist/plugin/utils/codex-parser.d.ts.map +1 -0
  454. package/dist/plugin/utils/codex-parser.js +396 -0
  455. package/dist/plugin/utils/codex-parser.js.map +1 -0
  456. package/dist/plugin/utils/command-runner.d.ts +24 -0
  457. package/dist/plugin/utils/command-runner.d.ts.map +1 -0
  458. package/dist/plugin/utils/command-runner.js +44 -0
  459. package/dist/plugin/utils/command-runner.js.map +1 -0
  460. package/dist/plugin/utils/import-resolver.d.ts +55 -0
  461. package/dist/plugin/utils/import-resolver.d.ts.map +1 -0
  462. package/dist/plugin/utils/import-resolver.js +198 -0
  463. package/dist/plugin/utils/import-resolver.js.map +1 -0
  464. package/dist/plugin/utils/memory-pool.d.ts +90 -0
  465. package/dist/plugin/utils/memory-pool.d.ts.map +1 -0
  466. package/dist/plugin/utils/memory-pool.js +245 -0
  467. package/dist/plugin/utils/memory-pool.js.map +1 -0
  468. package/dist/plugin/utils/path-resolver.d.ts +49 -0
  469. package/dist/plugin/utils/path-resolver.d.ts.map +1 -0
  470. package/dist/plugin/utils/path-resolver.js +126 -0
  471. package/dist/plugin/utils/path-resolver.js.map +1 -0
  472. package/dist/plugin/utils/test-template-generator.d.ts +26 -0
  473. package/dist/plugin/utils/test-template-generator.d.ts.map +1 -0
  474. package/dist/plugin/utils/test-template-generator.js +178 -0
  475. package/dist/plugin/utils/test-template-generator.js.map +1 -0
  476. package/dist/processors/index.d.ts +12 -0
  477. package/dist/processors/index.d.ts.map +1 -0
  478. package/dist/processors/index.js +12 -0
  479. package/dist/processors/index.js.map +1 -0
  480. package/dist/processors/processor-manager.d.ts +113 -0
  481. package/dist/processors/processor-manager.d.ts.map +1 -0
  482. package/dist/processors/processor-manager.js +498 -0
  483. package/dist/processors/processor-manager.js.map +1 -0
  484. package/dist/processors/processor-types.d.ts +50 -0
  485. package/dist/processors/processor-types.d.ts.map +1 -0
  486. package/dist/processors/processor-types.js +10 -0
  487. package/dist/processors/processor-types.js.map +1 -0
  488. package/dist/processors/refactoring-logging-processor.d.ts +61 -0
  489. package/dist/processors/refactoring-logging-processor.d.ts.map +1 -0
  490. package/dist/processors/refactoring-logging-processor.js +257 -0
  491. package/dist/processors/refactoring-logging-processor.js.map +1 -0
  492. package/dist/state/context-providers.d.ts +5 -0
  493. package/dist/state/context-providers.d.ts.map +1 -0
  494. package/dist/state/context-providers.js +2 -0
  495. package/dist/state/context-providers.js.map +1 -0
  496. package/dist/state/index.d.ts +5 -0
  497. package/dist/state/index.d.ts.map +1 -0
  498. package/dist/state/index.js +8 -0
  499. package/dist/state/index.js.map +1 -0
  500. package/dist/state/state-manager.d.ts +29 -0
  501. package/dist/state/state-manager.d.ts.map +1 -0
  502. package/dist/state/state-manager.js +153 -0
  503. package/dist/state/state-manager.js.map +1 -0
  504. package/dist/state/state-types.d.ts +6 -0
  505. package/dist/state/state-types.d.ts.map +1 -0
  506. package/dist/state/state-types.js +2 -0
  507. package/dist/state/state-types.js.map +1 -0
  508. package/dist/utils/codex-parser.d.ts +62 -0
  509. package/dist/utils/codex-parser.d.ts.map +1 -0
  510. package/dist/utils/codex-parser.js +396 -0
  511. package/dist/utils/codex-parser.js.map +1 -0
  512. package/dist/utils/command-runner.d.ts +24 -0
  513. package/dist/utils/command-runner.d.ts.map +1 -0
  514. package/dist/utils/command-runner.js +44 -0
  515. package/dist/utils/command-runner.js.map +1 -0
  516. package/dist/utils/import-resolver.d.ts +55 -0
  517. package/dist/utils/import-resolver.d.ts.map +1 -0
  518. package/dist/utils/import-resolver.js +198 -0
  519. package/dist/utils/import-resolver.js.map +1 -0
  520. package/dist/utils/memory-pool.d.ts +90 -0
  521. package/dist/utils/memory-pool.d.ts.map +1 -0
  522. package/dist/utils/memory-pool.js +245 -0
  523. package/dist/utils/memory-pool.js.map +1 -0
  524. package/dist/utils/path-resolver.d.ts +49 -0
  525. package/dist/utils/path-resolver.d.ts.map +1 -0
  526. package/dist/utils/path-resolver.js +126 -0
  527. package/dist/utils/path-resolver.js.map +1 -0
  528. package/dist/utils/test-template-generator.d.ts +26 -0
  529. package/dist/utils/test-template-generator.d.ts.map +1 -0
  530. package/dist/utils/test-template-generator.js +178 -0
  531. package/dist/utils/test-template-generator.js.map +1 -0
  532. package/package.json +138 -0
  533. package/scripts/analysis/analyze-context-awareness.ts +219 -0
  534. package/scripts/analysis/analyze-framework-usage.ts +208 -0
  535. package/scripts/analysis/analyzer-agent-runner.js +328 -0
  536. package/scripts/analysis/context-awareness-report.ts +250 -0
  537. package/scripts/analyze-imports.mjs +147 -0
  538. package/scripts/basic-security-audit.cjs +261 -0
  539. package/scripts/boot-check.cjs +188 -0
  540. package/scripts/build/check-syntax.sh +1 -0
  541. package/scripts/build/check-tsc.sh +1 -0
  542. package/scripts/build/check-types.sh +1 -0
  543. package/scripts/build/compile-single.sh +1 -0
  544. package/scripts/build/copy-plugin.sh +1 -0
  545. package/scripts/build/manual-build.sh +1 -0
  546. package/scripts/build/run-build-after-copy.sh +1 -0
  547. package/scripts/build/run-build-attempt.sh +1 -0
  548. package/scripts/build/run-build-errors-grep.sh +1 -0
  549. package/scripts/build/run-build-errors.sh +1 -0
  550. package/scripts/build/run-build-limited.sh +1 -0
  551. package/scripts/build/run-build-list.sh +1 -0
  552. package/scripts/build/run-build.sh +1 -0
  553. package/scripts/build/run-limited.sh +1 -0
  554. package/scripts/build/run-tsc-direct.sh +1 -0
  555. package/scripts/build/run-type-check.sh +1 -0
  556. package/scripts/build/run-typecheck.sh +1 -0
  557. package/scripts/build/test-build.sh +1 -0
  558. package/scripts/check-logs.sh +62 -0
  559. package/scripts/debug/debug-context-enhancement.ts +116 -0
  560. package/scripts/debug/debug-rules.mjs +23 -0
  561. package/scripts/demo/demo-clickable-monitoring.mjs +116 -0
  562. package/scripts/demo/profiling-demo.js +108 -0
  563. package/scripts/demo/profiling-demo.ts +126 -0
  564. package/scripts/demo/reporting-demonstration.ts +184 -0
  565. package/scripts/demo/reporting-examples.ts +105 -0
  566. package/scripts/dependency-scan.cjs +111 -0
  567. package/scripts/deploy-stringray-plugin.sh +323 -0
  568. package/scripts/disable-logging.sh +20 -0
  569. package/scripts/extract-framework.sh +405 -0
  570. package/scripts/fix-mcp-capabilities.js +83 -0
  571. package/scripts/framework/advanced-profiling-integration.sh +384 -0
  572. package/scripts/framework/check-agent-orchestration-health.sh +113 -0
  573. package/scripts/framework/enterprise-analysis-test.sh +174 -0
  574. package/scripts/framework/implement-analyzer-agent.sh +393 -0
  575. package/scripts/framework/merge-mcp-configs.sh +201 -0
  576. package/scripts/framework/validate-multi-agent-orchestration.sh +195 -0
  577. package/scripts/framework/validate-profiling.sh +64 -0
  578. package/scripts/github-actions-monitor.cjs +289 -0
  579. package/scripts/init.ts +121 -0
  580. package/scripts/monitoring/initialize-monitoring-pipeline.sh +89 -0
  581. package/scripts/monitoring/memory-dashboard.sh +52 -0
  582. package/scripts/monitoring/monitoring-daemon.mjs +67 -0
  583. package/scripts/monitoring/monitoring-daemon.sh +190 -0
  584. package/scripts/monitoring/profiling-dashboard.sh +69 -0
  585. package/scripts/performance-report.js +56 -0
  586. package/scripts/postinstall.cjs +240 -0
  587. package/scripts/profile-performance.sh +263 -0
  588. package/scripts/register-mcp-servers-fixed.sh +74 -0
  589. package/scripts/register-mcp-servers.sh +96 -0
  590. package/scripts/reporting/generate-phase1-report.js +28 -0
  591. package/scripts/reporting/run-postprocessor.js +59 -0
  592. package/scripts/reporting/trigger-report.js +15 -0
  593. package/scripts/run-simulations.mjs +29 -0
  594. package/scripts/scenario-data-processor.py +122 -0
  595. package/scripts/scenarios/scenario-security-check.ts +60 -0
  596. package/scripts/scenarios/scenario-user-management.ts +123 -0
  597. package/scripts/setup.cjs +128 -0
  598. package/scripts/simulation/run-simulations.js +84 -0
  599. package/scripts/simulation/simulate-full-orchestrator.ts +239 -0
  600. package/scripts/strray-triage.sh +349 -0
  601. package/scripts/test/run-memory-regression.sh +45 -0
  602. package/scripts/test/run-test.sh +2 -0
  603. package/scripts/test/test-deployment.sh +552 -0
  604. package/scripts/test/test-enhanced-report.ts +24 -0
  605. package/scripts/test/test-graceful-shutdown.sh +35 -0
  606. package/scripts/test/test-integration.mjs +79 -0
  607. package/scripts/test/test-manual-orchestration.sh +168 -0
  608. package/scripts/test/test-max-agents.sh +70 -0
  609. package/scripts/test/test-memory-monitor.sh +40 -0
  610. package/scripts/test/test-memory-pools.sh +58 -0
  611. package/scripts/test/test-module.ts +1 -0
  612. package/scripts/test/test-multi-agent-trigger.sh +251 -0
  613. package/scripts/test/test-orchestrator.txt +1 -0
  614. package/scripts/test/test-postinstall.js +1 -0
  615. package/scripts/test/test-security-module.ts +27 -0
  616. package/scripts/test/test-session-management.js +135 -0
  617. package/scripts/test/test-simulation.mjs +14 -0
  618. package/scripts/test/test-user-service.ts +111 -0
  619. package/scripts/test-comprehensive-path-resolution.mjs +62 -0
  620. package/scripts/test-data-processor.py +51 -0
  621. package/scripts/test-enforcement-e2e.mjs +127 -0
  622. package/scripts/test-full-plugin-no-timeout.sh +30 -0
  623. package/scripts/test-path-resolver.mjs +32 -0
  624. package/scripts/test-rules.mjs +128 -0
  625. package/scripts/test-stringray-plugin.mjs +66 -0
  626. package/scripts/test-utils/smart-test-runner.mjs +609 -0
  627. package/scripts/test-utils/test-quarantine.mjs +246 -0
  628. package/scripts/validate-codex.js +60 -0
  629. package/scripts/validate-phase1.mjs +189 -0
  630. package/scripts/validation/run-validators.js +114 -0
  631. package/scripts/validation/validate-external-processes.js +240 -0
  632. package/scripts/validation/validate-mcp-connectivity.js +165 -0
  633. package/scripts/validation/validate-oh-my-opencode-integration.js +200 -0
  634. package/scripts/validation/validate-reports.ts +114 -0
  635. package/scripts/verify-phase1.js +144 -0
@@ -0,0 +1,797 @@
1
+ /**
2
+ * StringRay Framework v1.0.0 - Enterprise Monitoring System
3
+ *
4
+ * Comprehensive enterprise-scale monitoring and health check system.
5
+ * Supports distributed deployments, auto-scaling, and production monitoring.
6
+ *
7
+ * @version 1.0.0
8
+ * @since 2026-01-08
9
+ */
10
+ import { EventEmitter } from "events";
11
+ import * as os from "os";
12
+ import { performance } from "perf_hooks";
13
+ import { advancedProfiler } from "./advanced-profiler.js";
14
+ /**
15
+ * Enterprise monitoring and health check system
16
+ */
17
+ export class EnterpriseMonitoringSystem extends EventEmitter {
18
+ config;
19
+ metrics = [];
20
+ appMetrics = [];
21
+ alerts = [];
22
+ healthResults = [];
23
+ clusterNodes = new Map();
24
+ collectionTimer;
25
+ healthCheckTimer;
26
+ cleanupTimer;
27
+ isRunning = false;
28
+ instanceId;
29
+ constructor(config) {
30
+ super();
31
+ this.instanceId = this.generateInstanceId();
32
+ const defaultConfig = {
33
+ enabled: true,
34
+ collectionInterval: 30000, // 30 seconds
35
+ retentionPeriod: 24, // 24 hours
36
+ alertRules: [],
37
+ healthChecks: {
38
+ enabled: true,
39
+ interval: 60000, // 1 minute
40
+ timeout: 5000, // 5 seconds
41
+ services: [],
42
+ },
43
+ integrations: {},
44
+ thresholds: {
45
+ cpuWarning: 70,
46
+ cpuCritical: 90,
47
+ memoryWarning: 80,
48
+ memoryCritical: 95,
49
+ diskWarning: 80,
50
+ diskCritical: 95,
51
+ responseTimeWarning: 1000, // 1 second
52
+ responseTimeCritical: 5000, // 5 seconds
53
+ },
54
+ };
55
+ this.config = { ...defaultConfig, ...config };
56
+ this.config.alertRules = this.getDefaultAlertRules();
57
+ this.setupEventHandlers();
58
+ }
59
+ /**
60
+ * Setup event handlers
61
+ */
62
+ setupEventHandlers() {
63
+ this.on("alert-triggered", this.handleAlertTriggered.bind(this));
64
+ this.on("health-check-failed", this.handleHealthCheckFailed.bind(this));
65
+ this.on("metrics-collected", this.handleMetricsCollected.bind(this));
66
+ advancedProfiler.on("profileCompleted", this.handleProfileCompleted.bind(this));
67
+ advancedProfiler.on("performanceAnomaly", this.handlePerformanceAnomaly.bind(this));
68
+ advancedProfiler.on("memoryAnomaly", this.handleMemoryAnomaly.bind(this));
69
+ advancedProfiler.on("reportGenerated", this.handleReportGenerated.bind(this));
70
+ }
71
+ /**
72
+ * Start monitoring system
73
+ */
74
+ async start() {
75
+ if (this.isRunning) {
76
+ return;
77
+ }
78
+ console.log("🚀 Starting Enterprise Monitoring System...");
79
+ console.log(` Instance ID: ${this.instanceId}`);
80
+ console.log(` Collection Interval: ${this.config.collectionInterval}ms`);
81
+ console.log(` Health Check Interval: ${this.config.healthChecks.interval}ms`);
82
+ this.isRunning = true;
83
+ // Initial data collection
84
+ await this.collectMetrics();
85
+ await this.performHealthChecks();
86
+ // Start periodic collection
87
+ this.collectionTimer = setInterval(async () => {
88
+ if (this.isRunning) {
89
+ await this.collectMetrics();
90
+ }
91
+ }, this.config.collectionInterval);
92
+ // Start health checks
93
+ if (this.config.healthChecks.enabled) {
94
+ this.healthCheckTimer = setInterval(async () => {
95
+ if (this.isRunning) {
96
+ await this.performHealthChecks();
97
+ }
98
+ }, this.config.healthChecks.interval);
99
+ }
100
+ // Start data cleanup
101
+ this.startDataCleanup();
102
+ console.log("✅ Enterprise Monitoring System started successfully");
103
+ this.emit("started");
104
+ }
105
+ /**
106
+ * Stop monitoring system
107
+ */
108
+ stop() {
109
+ if (!this.isRunning) {
110
+ return;
111
+ }
112
+ console.log("⏹️ Stopping Enterprise Monitoring System...");
113
+ this.isRunning = false;
114
+ if (this.collectionTimer) {
115
+ clearInterval(this.collectionTimer);
116
+ this.collectionTimer = undefined;
117
+ }
118
+ if (this.healthCheckTimer) {
119
+ clearInterval(this.healthCheckTimer);
120
+ this.healthCheckTimer = undefined;
121
+ }
122
+ if (this.cleanupTimer) {
123
+ clearInterval(this.cleanupTimer);
124
+ this.cleanupTimer = undefined;
125
+ }
126
+ console.log("✅ Enterprise Monitoring System stopped");
127
+ this.emit("stopped");
128
+ }
129
+ /**
130
+ * Collect system and application metrics
131
+ */
132
+ async collectMetrics() {
133
+ try {
134
+ const systemMetrics = this.collectSystemMetrics();
135
+ const appMetrics = this.collectApplicationMetrics();
136
+ this.metrics.push(systemMetrics);
137
+ this.appMetrics.push(appMetrics);
138
+ // Keep only recent metrics
139
+ const retentionMs = this.config.retentionPeriod * 60 * 60 * 1000;
140
+ const cutoffTime = Date.now() - retentionMs;
141
+ this.metrics = this.metrics.filter((m) => m.timestamp > cutoffTime);
142
+ this.appMetrics = this.appMetrics.filter((m) => m.timestamp > cutoffTime);
143
+ // Check alert rules
144
+ await this.checkAlertRules(systemMetrics, appMetrics);
145
+ this.emit("metrics-collected", {
146
+ system: systemMetrics,
147
+ application: appMetrics,
148
+ });
149
+ }
150
+ catch (error) {
151
+ console.error("❌ Failed to collect metrics:", error);
152
+ this.emit("error", error);
153
+ }
154
+ }
155
+ /**
156
+ * Collect system metrics
157
+ */
158
+ collectSystemMetrics() {
159
+ const cpus = os.cpus();
160
+ const totalMemory = os.totalmem();
161
+ const freeMemory = os.freemem();
162
+ const usedMemory = totalMemory - freeMemory;
163
+ // Calculate CPU usage (simplified)
164
+ let totalIdle = 0;
165
+ let totalTick = 0;
166
+ cpus.forEach((cpu) => {
167
+ for (const type in cpu.times) {
168
+ totalTick += cpu.times[type];
169
+ }
170
+ totalIdle += cpu.times.idle;
171
+ });
172
+ const idle = totalIdle / cpus.length;
173
+ const total = totalTick / cpus.length;
174
+ const cpuUsage = 100 - ~~((100 * idle) / total);
175
+ // Get disk usage (simplified - would use systeminformation in production)
176
+ const diskUsage = this.getDiskUsage();
177
+ // Get network stats (simplified)
178
+ const networkStats = this.getNetworkStats();
179
+ return {
180
+ timestamp: Date.now(),
181
+ cpu: {
182
+ usage: cpuUsage,
183
+ loadAverage: os.loadavg(),
184
+ cores: cpus.length,
185
+ },
186
+ memory: {
187
+ total: totalMemory,
188
+ used: usedMemory,
189
+ free: freeMemory,
190
+ usagePercent: (usedMemory / totalMemory) * 100,
191
+ },
192
+ disk: diskUsage,
193
+ network: networkStats,
194
+ process: {
195
+ pid: process.pid,
196
+ uptime: process.uptime(),
197
+ memoryUsage: process.memoryUsage(),
198
+ cpuUsage: process.cpuUsage(),
199
+ },
200
+ };
201
+ }
202
+ /**
203
+ * Collect application-specific metrics
204
+ */
205
+ collectApplicationMetrics() {
206
+ // This would integrate with the actual application metrics
207
+ // For now, return mock data
208
+ return {
209
+ timestamp: Date.now(),
210
+ requests: {
211
+ total: Math.floor(Math.random() * 1000),
212
+ active: Math.floor(Math.random() * 50),
213
+ completed: Math.floor(Math.random() * 950),
214
+ failed: Math.floor(Math.random() * 50),
215
+ averageResponseTime: Math.random() * 1000 + 100,
216
+ },
217
+ agents: {
218
+ total: 8,
219
+ active: Math.floor(Math.random() * 8),
220
+ idle: Math.floor(Math.random() * 8),
221
+ failed: Math.floor(Math.random() * 2),
222
+ },
223
+ sessions: {
224
+ total: Math.floor(Math.random() * 100),
225
+ active: Math.floor(Math.random() * 50),
226
+ expired: Math.floor(Math.random() * 25),
227
+ },
228
+ performance: {
229
+ averageLatency: Math.random() * 500 + 50,
230
+ p95Latency: Math.random() * 1000 + 200,
231
+ p99Latency: Math.random() * 2000 + 500,
232
+ throughput: Math.random() * 1000 + 500,
233
+ },
234
+ };
235
+ }
236
+ /**
237
+ * Perform health checks
238
+ */
239
+ async performHealthChecks() {
240
+ if (!this.config.healthChecks.enabled) {
241
+ return;
242
+ }
243
+ const results = [];
244
+ for (const service of this.config.healthChecks.services) {
245
+ const startTime = performance.now();
246
+ try {
247
+ let status = "unknown";
248
+ const details = {};
249
+ switch (service.type) {
250
+ case "http":
251
+ if (service.url) {
252
+ const response = await this.checkHttpHealth(service.url, service.expectedStatus);
253
+ status = response.healthy ? "healthy" : "unhealthy";
254
+ details.responseTime = response.responseTime;
255
+ details.statusCode = response.statusCode;
256
+ }
257
+ break;
258
+ case "tcp":
259
+ // TCP health check implementation would go here
260
+ status = "healthy"; // Placeholder
261
+ break;
262
+ case "command":
263
+ if (service.command) {
264
+ const result = await this.checkCommandHealth(service.command);
265
+ status = result.success ? "healthy" : "unhealthy";
266
+ details.exitCode = result.exitCode;
267
+ details.output = result.output;
268
+ }
269
+ break;
270
+ case "custom":
271
+ // Custom health check logic
272
+ status = "healthy"; // Placeholder
273
+ break;
274
+ }
275
+ const responseTime = performance.now() - startTime;
276
+ results.push({
277
+ service: service.name,
278
+ status,
279
+ timestamp: Date.now(),
280
+ responseTime,
281
+ details,
282
+ });
283
+ }
284
+ catch (error) {
285
+ const responseTime = performance.now() - startTime;
286
+ results.push({
287
+ service: service.name,
288
+ status: "unhealthy",
289
+ timestamp: Date.now(),
290
+ responseTime,
291
+ details: {},
292
+ error: error instanceof Error ? error.message : String(error),
293
+ });
294
+ }
295
+ }
296
+ // Update health results
297
+ this.healthResults.push(...results);
298
+ // Keep only recent results
299
+ const retentionMs = this.config.retentionPeriod * 60 * 60 * 1000;
300
+ const cutoffTime = Date.now() - retentionMs;
301
+ this.healthResults = this.healthResults.filter((r) => r.timestamp > cutoffTime);
302
+ // Emit events for failed health checks
303
+ results.forEach((result) => {
304
+ if (result.status !== "healthy") {
305
+ this.emit("health-check-failed", result);
306
+ }
307
+ });
308
+ this.emit("health-checks-completed", results);
309
+ }
310
+ /**
311
+ * Check HTTP health
312
+ */
313
+ async checkHttpHealth(url, expectedStatus) {
314
+ const startTime = performance.now();
315
+ try {
316
+ // In a real implementation, this would make an HTTP request
317
+ // For demo purposes, simulate a health check
318
+ await new Promise((resolve) => setTimeout(resolve, Math.random() * 100 + 50));
319
+ const responseTime = performance.now() - startTime;
320
+ const statusCode = Math.random() > 0.1 ? 200 : 500; // 90% success rate
321
+ const healthy = expectedStatus
322
+ ? statusCode === expectedStatus
323
+ : statusCode < 400;
324
+ return { healthy, responseTime, statusCode };
325
+ }
326
+ catch (error) {
327
+ const responseTime = performance.now() - startTime;
328
+ return { healthy: false, responseTime };
329
+ }
330
+ }
331
+ /**
332
+ * Check command health
333
+ */
334
+ async checkCommandHealth(command) {
335
+ try {
336
+ // In a real implementation, this would execute the command
337
+ // For demo purposes, simulate command execution
338
+ await new Promise((resolve) => setTimeout(resolve, Math.random() * 200 + 100));
339
+ const success = Math.random() > 0.2; // 80% success rate
340
+ return {
341
+ success,
342
+ exitCode: success ? 0 : 1,
343
+ output: success ? "OK" : "Command failed",
344
+ };
345
+ }
346
+ catch (error) {
347
+ return {
348
+ success: false,
349
+ exitCode: 1,
350
+ output: error instanceof Error ? error.message : String(error),
351
+ };
352
+ }
353
+ }
354
+ /**
355
+ * Check alert rules against current metrics
356
+ */
357
+ async checkAlertRules(systemMetrics, appMetrics) {
358
+ for (const rule of this.config.alertRules) {
359
+ if (!rule.enabled)
360
+ continue;
361
+ // Check cooldown
362
+ if (rule.lastTriggered &&
363
+ Date.now() - rule.lastTriggered < rule.cooldownMinutes * 60 * 1000) {
364
+ continue;
365
+ }
366
+ let value;
367
+ let triggered = false;
368
+ // Extract metric value
369
+ switch (rule.metric) {
370
+ case "cpu.usage":
371
+ value = systemMetrics.cpu.usage;
372
+ break;
373
+ case "memory.usagePercent":
374
+ value = systemMetrics.memory.usagePercent;
375
+ break;
376
+ case "disk.usagePercent":
377
+ value = systemMetrics.disk.usagePercent;
378
+ break;
379
+ case "requests.averageResponseTime":
380
+ value = appMetrics.requests.averageResponseTime;
381
+ break;
382
+ case "performance.averageLatency":
383
+ value = appMetrics.performance.averageLatency;
384
+ break;
385
+ }
386
+ if (value === undefined)
387
+ continue;
388
+ // Check condition
389
+ switch (rule.condition) {
390
+ case "gt":
391
+ triggered = value > rule.threshold;
392
+ break;
393
+ case "lt":
394
+ triggered = value < rule.threshold;
395
+ break;
396
+ case "gte":
397
+ triggered = value >= rule.threshold;
398
+ break;
399
+ case "lte":
400
+ triggered = value <= rule.threshold;
401
+ break;
402
+ case "eq":
403
+ triggered = value === rule.threshold;
404
+ break;
405
+ case "ne":
406
+ triggered = value !== rule.threshold;
407
+ break;
408
+ }
409
+ if (triggered) {
410
+ const alert = {
411
+ id: `alert-${rule.id}-${Date.now()}`,
412
+ ruleId: rule.id,
413
+ severity: rule.severity,
414
+ message: `${rule.name}: ${rule.metric} is ${value.toFixed(2)} (${rule.condition} ${rule.threshold})`,
415
+ metric: rule.metric,
416
+ value,
417
+ threshold: rule.threshold,
418
+ timestamp: Date.now(),
419
+ resolved: false,
420
+ instanceId: this.instanceId,
421
+ };
422
+ this.alerts.push(alert);
423
+ rule.lastTriggered = Date.now();
424
+ this.emit("alert-triggered", alert);
425
+ // Send to external monitoring if configured
426
+ await this.sendAlertToExternalSystems(alert);
427
+ }
428
+ }
429
+ // Keep only recent alerts
430
+ const retentionMs = this.config.retentionPeriod * 60 * 60 * 1000;
431
+ const cutoffTime = Date.now() - retentionMs;
432
+ this.alerts = this.alerts.filter((a) => !a.resolved || a.timestamp > cutoffTime);
433
+ }
434
+ /**
435
+ * Send alert to external monitoring systems
436
+ */
437
+ async sendAlertToExternalSystems(alert) {
438
+ // Prometheus integration
439
+ if (this.config.integrations.prometheus?.enabled) {
440
+ // Send metric to Prometheus pushgateway
441
+ console.log(`📊 Prometheus: ${alert.metric} = ${alert.value}`);
442
+ }
443
+ // DataDog integration
444
+ if (this.config.integrations.datadog?.enabled) {
445
+ // Send event to DataDog
446
+ console.log(`🐕 DataDog: Alert ${alert.id} - ${alert.message}`);
447
+ }
448
+ // New Relic integration
449
+ if (this.config.integrations.newRelic?.enabled) {
450
+ // Send event to New Relic
451
+ console.log(`📈 New Relic: Alert ${alert.id} - ${alert.message}`);
452
+ }
453
+ }
454
+ /**
455
+ * Get default alert rules
456
+ */
457
+ getDefaultAlertRules() {
458
+ return [
459
+ {
460
+ id: "cpu-high",
461
+ name: "High CPU Usage",
462
+ description: "CPU usage is above warning threshold",
463
+ metric: "cpu.usage",
464
+ condition: "gte",
465
+ threshold: this.config.thresholds.cpuWarning,
466
+ severity: "medium",
467
+ enabled: true,
468
+ cooldownMinutes: 5,
469
+ },
470
+ {
471
+ id: "cpu-critical",
472
+ name: "Critical CPU Usage",
473
+ description: "CPU usage is above critical threshold",
474
+ metric: "cpu.usage",
475
+ condition: "gte",
476
+ threshold: this.config.thresholds.cpuCritical,
477
+ severity: "critical",
478
+ enabled: true,
479
+ cooldownMinutes: 2,
480
+ },
481
+ {
482
+ id: "memory-high",
483
+ name: "High Memory Usage",
484
+ description: "Memory usage is above warning threshold",
485
+ metric: "memory.usagePercent",
486
+ condition: "gte",
487
+ threshold: this.config.thresholds.memoryWarning,
488
+ severity: "medium",
489
+ enabled: true,
490
+ cooldownMinutes: 5,
491
+ },
492
+ {
493
+ id: "memory-critical",
494
+ name: "Critical Memory Usage",
495
+ description: "Memory usage is above critical threshold",
496
+ metric: "memory.usagePercent",
497
+ condition: "gte",
498
+ threshold: this.config.thresholds.memoryCritical,
499
+ severity: "critical",
500
+ enabled: true,
501
+ cooldownMinutes: 2,
502
+ },
503
+ {
504
+ id: "response-time-high",
505
+ name: "High Response Time",
506
+ description: "Average response time is above warning threshold",
507
+ metric: "requests.averageResponseTime",
508
+ condition: "gte",
509
+ threshold: this.config.thresholds.responseTimeWarning,
510
+ severity: "medium",
511
+ enabled: true,
512
+ cooldownMinutes: 5,
513
+ },
514
+ {
515
+ id: "response-time-critical",
516
+ name: "Critical Response Time",
517
+ description: "Average response time is above critical threshold",
518
+ metric: "requests.averageResponseTime",
519
+ condition: "gte",
520
+ threshold: this.config.thresholds.responseTimeCritical,
521
+ severity: "critical",
522
+ enabled: true,
523
+ cooldownMinutes: 2,
524
+ },
525
+ ];
526
+ }
527
+ /**
528
+ * Get disk usage (simplified)
529
+ */
530
+ getDiskUsage() {
531
+ // In production, this would use systeminformation or similar
532
+ // For demo purposes, return mock data
533
+ const total = 100 * 1024 * 1024 * 1024; // 100GB
534
+ const used = Math.random() * 0.8 * total; // Up to 80% used
535
+ const free = total - used;
536
+ return {
537
+ total,
538
+ used,
539
+ free,
540
+ usagePercent: (used / total) * 100,
541
+ };
542
+ }
543
+ /**
544
+ * Get network stats (simplified)
545
+ */
546
+ getNetworkStats() {
547
+ // In production, this would use system network interfaces
548
+ // For demo purposes, return mock data
549
+ return {
550
+ bytesReceived: Math.floor(Math.random() * 1000000),
551
+ bytesTransmitted: Math.floor(Math.random() * 1000000),
552
+ packetsReceived: Math.floor(Math.random() * 10000),
553
+ packetsTransmitted: Math.floor(Math.random() * 10000),
554
+ };
555
+ }
556
+ /**
557
+ * Generate instance ID
558
+ */
559
+ generateInstanceId() {
560
+ return `strray-${os.hostname()}-${process.pid}-${Date.now().toString(36)}`;
561
+ }
562
+ /**
563
+ * Start data cleanup timer
564
+ */
565
+ startDataCleanup() {
566
+ // Clean up old data every hour
567
+ this.cleanupTimer = setInterval(() => {
568
+ this.cleanupOldData();
569
+ }, 60 * 60 * 1000);
570
+ }
571
+ /**
572
+ * Clean up old data
573
+ */
574
+ cleanupOldData() {
575
+ const retentionMs = this.config.retentionPeriod * 60 * 60 * 1000;
576
+ const cutoffTime = Date.now() - retentionMs;
577
+ this.metrics = this.metrics.filter((m) => m.timestamp > cutoffTime);
578
+ this.appMetrics = this.appMetrics.filter((m) => m.timestamp > cutoffTime);
579
+ this.healthResults = this.healthResults.filter((r) => r.timestamp > cutoffTime);
580
+ this.alerts = this.alerts.filter((a) => !a.resolved || a.timestamp > cutoffTime);
581
+ console.log("🧹 Cleaned up old monitoring data");
582
+ }
583
+ /**
584
+ * Event handlers
585
+ */
586
+ handleAlertTriggered(alert) {
587
+ console.log(`🚨 Alert [${alert.severity.toUpperCase()}]: ${alert.message}`);
588
+ console.log(`[SECURITY] Performance alert triggered: ${alert.message}`);
589
+ }
590
+ handleHealthCheckFailed(result) {
591
+ console.warn(`⚠️ Health check failed: ${result.service} - ${result.error || "Unknown error"}`);
592
+ }
593
+ handleMetricsCollected(data) {
594
+ // Optional: Log periodic metrics collection
595
+ if (process.env.DEBUG_MONITORING) {
596
+ console.log(`📊 Metrics collected - CPU: ${data.system.cpu.usage.toFixed(1)}%, Memory: ${data.system.memory.usagePercent.toFixed(1)}%`);
597
+ }
598
+ }
599
+ handleProfileCompleted(profileData) {
600
+ this.recordMetric("agent.profile.completed", {
601
+ agentName: profileData.agentName,
602
+ operation: profileData.operation,
603
+ duration: profileData.duration,
604
+ success: profileData.success,
605
+ }, { agent: profileData.agentName });
606
+ }
607
+ handlePerformanceAnomaly(anomaly) {
608
+ const alert = {
609
+ id: `perf-anomaly-${Date.now()}`,
610
+ ruleId: "performance-anomaly",
611
+ severity: "high",
612
+ message: `Performance anomaly detected: ${anomaly.agentName} ${anomaly.operation} is ${anomaly.deviation.toFixed(1)}x slower than average`,
613
+ metric: "agent.performance.duration",
614
+ value: anomaly.duration,
615
+ threshold: anomaly.averageDuration,
616
+ timestamp: Date.now(),
617
+ resolved: false,
618
+ instanceId: this.instanceId,
619
+ };
620
+ this.alerts.push(alert);
621
+ this.emit("alert-triggered", alert);
622
+ }
623
+ handleMemoryAnomaly(anomaly) {
624
+ const alert = {
625
+ id: `memory-anomaly-${Date.now()}`,
626
+ ruleId: "memory-anomaly",
627
+ severity: "critical",
628
+ message: `Memory anomaly detected: ${anomaly.agentName} ${anomaly.operation} used ${anomaly.memoryDelta} bytes`,
629
+ metric: "agent.memory.delta",
630
+ value: anomaly.memoryDelta,
631
+ threshold: 50 * 1024 * 1024, // 50MB
632
+ timestamp: Date.now(),
633
+ resolved: false,
634
+ instanceId: this.instanceId,
635
+ };
636
+ this.alerts.push(alert);
637
+ this.emit("alert-triggered", alert);
638
+ }
639
+ handleReportGenerated(reportPath) {
640
+ console.log(`📊 Performance report generated: ${reportPath}`);
641
+ }
642
+ /**
643
+ * Get current metrics
644
+ */
645
+ getMetrics() {
646
+ return {
647
+ system: [...this.metrics],
648
+ application: [...this.appMetrics],
649
+ };
650
+ }
651
+ /**
652
+ * Get health check results
653
+ */
654
+ getHealthResults() {
655
+ return [...this.healthResults];
656
+ }
657
+ /**
658
+ * Get active alerts
659
+ */
660
+ getAlerts(includeResolved = false) {
661
+ return includeResolved
662
+ ? [...this.alerts]
663
+ : this.alerts.filter((a) => !a.resolved);
664
+ }
665
+ /**
666
+ * Resolve alert
667
+ */
668
+ resolveAlert(alertId) {
669
+ const alert = this.alerts.find((a) => a.id === alertId);
670
+ if (alert && !alert.resolved) {
671
+ alert.resolved = true;
672
+ alert.resolvedAt = Date.now();
673
+ console.log(`✅ Alert resolved: ${alert.message}`);
674
+ return true;
675
+ }
676
+ return false;
677
+ }
678
+ /**
679
+ * Add cluster node
680
+ */
681
+ addClusterNode(node) {
682
+ const clusterNode = {
683
+ ...node,
684
+ status: "offline",
685
+ lastHeartbeat: Date.now(),
686
+ metrics: this.collectSystemMetrics(),
687
+ health: [],
688
+ };
689
+ this.clusterNodes.set(node.id, clusterNode);
690
+ console.log(`➕ Added cluster node: ${node.id} (${node.hostname})`);
691
+ }
692
+ /**
693
+ * Update cluster node heartbeat
694
+ */
695
+ updateClusterNodeHeartbeat(nodeId, metrics, health) {
696
+ const node = this.clusterNodes.get(nodeId);
697
+ if (node) {
698
+ node.lastHeartbeat = Date.now();
699
+ node.status = "online";
700
+ if (metrics) {
701
+ node.metrics = metrics;
702
+ }
703
+ if (health) {
704
+ node.health = health;
705
+ }
706
+ }
707
+ }
708
+ /**
709
+ * Get cluster metrics
710
+ */
711
+ getClusterMetrics() {
712
+ const nodes = Array.from(this.clusterNodes.values());
713
+ // Calculate cluster-wide metrics
714
+ const totalRequests = this.appMetrics.reduce((sum, m) => sum + m.requests.total, 0);
715
+ const averageLatency = this.appMetrics.length > 0
716
+ ? this.appMetrics.reduce((sum, m) => sum + m.performance.averageLatency, 0) / this.appMetrics.length
717
+ : 0;
718
+ const totalCompleted = this.appMetrics.reduce((sum, m) => sum + m.requests.completed, 0);
719
+ const totalFailed = this.appMetrics.reduce((sum, m) => sum + m.requests.failed, 0);
720
+ const errorRate = totalCompleted + totalFailed > 0
721
+ ? (totalFailed / (totalCompleted + totalFailed)) * 100
722
+ : 0;
723
+ // Load distribution
724
+ const loadDistribution = {};
725
+ nodes.forEach((node) => {
726
+ loadDistribution[node.id] = node.metrics.cpu.usage;
727
+ });
728
+ return {
729
+ nodes,
730
+ totalRequests,
731
+ averageLatency,
732
+ errorRate,
733
+ loadDistribution,
734
+ };
735
+ }
736
+ /**
737
+ * Get monitoring status
738
+ */
739
+ getMonitoringStatus() {
740
+ return {
741
+ running: this.isRunning,
742
+ instanceId: this.instanceId,
743
+ metricsCollected: this.metrics.length,
744
+ alertsActive: this.alerts.filter((a) => !a.resolved).length,
745
+ healthChecksPerformed: this.healthResults.length,
746
+ clusterNodes: this.clusterNodes.size,
747
+ uptime: this.isRunning
748
+ ? Date.now() - (this.metrics[0]?.timestamp || Date.now())
749
+ : 0,
750
+ };
751
+ }
752
+ /**
753
+ * Update configuration
754
+ */
755
+ updateConfig(newConfig) {
756
+ this.config = { ...this.config, ...newConfig };
757
+ console.log("⚙️ Monitoring system configuration updated");
758
+ }
759
+ /**
760
+ * Record a custom metric
761
+ */
762
+ recordMetric(name, value, tags) {
763
+ console.log(`📊 Metric recorded: ${name}`, {
764
+ value,
765
+ tags,
766
+ timestamp: new Date().toISOString(),
767
+ });
768
+ // In a real implementation, this would store metrics for analysis
769
+ }
770
+ /**
771
+ * Record an error for monitoring
772
+ */
773
+ recordError(operation, error) {
774
+ console.error(`❌ Error recorded: ${operation}`, {
775
+ error: error.message || error,
776
+ timestamp: new Date().toISOString(),
777
+ stack: error.stack,
778
+ });
779
+ // In a real implementation, this would store errors for analysis and alerting
780
+ }
781
+ /**
782
+ * Get comprehensive system status
783
+ */
784
+ getStatus() {
785
+ return {
786
+ config: this.config,
787
+ metrics: this.getMetrics(),
788
+ alerts: this.alerts,
789
+ healthResults: this.healthResults,
790
+ clusterMetrics: this.getClusterMetrics(),
791
+ monitoringStatus: this.getMonitoringStatus(),
792
+ };
793
+ }
794
+ }
795
+ // Export singleton instance
796
+ export const enterpriseMonitoringSystem = new EnterpriseMonitoringSystem();
797
+ //# sourceMappingURL=enterprise-monitoring-system.js.map