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,871 @@
1
+ /**
2
+ * StrRay Boot Orchestrator MCP Server
3
+ *
4
+ * Advanced initialization orchestration with dependency management and health monitoring
5
+ */
6
+ import { Server } from "@modelcontextprotocol/sdk/server/index.js";
7
+ import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
8
+ import { CallToolRequestSchema, ListToolsRequestSchema, } from "@modelcontextprotocol/sdk/types.js";
9
+ import { execSync } from "child_process";
10
+ import fs from "fs";
11
+ import path from "path";
12
+ class StrRayBootOrchestratorServer {
13
+ server;
14
+ bootStatus;
15
+ // Boot sequence in dependency order
16
+ bootSequence = [
17
+ "configuration",
18
+ "logging",
19
+ "state-management",
20
+ "security",
21
+ "codex-loader",
22
+ "context-loader",
23
+ "processor-pipeline",
24
+ "agent-registry",
25
+ "orchestrator",
26
+ "mcp-servers",
27
+ "framework-hooks",
28
+ ];
29
+ constructor() {
30
+ this.server = new Server({
31
+ name: "strray-boot-orchestrator",
32
+ version: "1.0.0",
33
+ }, {
34
+ capabilities: {
35
+ tools: {},
36
+ },
37
+ });
38
+ this.bootStatus = {
39
+ initialized: false,
40
+ startTime: Date.now(),
41
+ components: new Map(),
42
+ dependencies: new Map(),
43
+ health: new Map(),
44
+ };
45
+ // Initialize dependency map
46
+ this.initializeDependencies();
47
+ this.setupToolHandlers();
48
+ console.log("StrRay Boot Orchestrator MCP Server initialized");
49
+ }
50
+ initializeDependencies() {
51
+ // Define component dependencies
52
+ this.bootStatus.dependencies.set("configuration", []);
53
+ this.bootStatus.dependencies.set("logging", ["configuration"]);
54
+ this.bootStatus.dependencies.set("state-management", [
55
+ "configuration",
56
+ "logging",
57
+ ]);
58
+ this.bootStatus.dependencies.set("security", ["configuration"]);
59
+ this.bootStatus.dependencies.set("codex-loader", [
60
+ "configuration",
61
+ "logging",
62
+ ]);
63
+ this.bootStatus.dependencies.set("context-loader", [
64
+ "configuration",
65
+ "codex-loader",
66
+ ]);
67
+ this.bootStatus.dependencies.set("processor-pipeline", [
68
+ "state-management",
69
+ "security",
70
+ "codex-loader",
71
+ ]);
72
+ this.bootStatus.dependencies.set("agent-registry", [
73
+ "configuration",
74
+ "state-management",
75
+ "processor-pipeline",
76
+ ]);
77
+ this.bootStatus.dependencies.set("orchestrator", [
78
+ "agent-registry",
79
+ "processor-pipeline",
80
+ ]);
81
+ this.bootStatus.dependencies.set("mcp-servers", [
82
+ "orchestrator",
83
+ "agent-registry",
84
+ ]);
85
+ this.bootStatus.dependencies.set("framework-hooks", [
86
+ "mcp-servers",
87
+ "orchestrator",
88
+ ]);
89
+ }
90
+ setupToolHandlers() {
91
+ // List available tools
92
+ this.server.setRequestHandler(ListToolsRequestSchema, async () => {
93
+ return {
94
+ tools: [
95
+ {
96
+ name: "execute-boot-sequence",
97
+ description: "Execute the complete StrRay boot sequence with dependency resolution",
98
+ inputSchema: {
99
+ type: "object",
100
+ properties: {
101
+ config: { type: "object" },
102
+ skipHealthChecks: { type: "boolean", default: false },
103
+ parallelInit: { type: "boolean", default: true },
104
+ },
105
+ },
106
+ },
107
+ {
108
+ name: "get-boot-status",
109
+ description: "Get comprehensive boot orchestrator status and health",
110
+ inputSchema: {
111
+ type: "object",
112
+ properties: {
113
+ detailed: { type: "boolean", default: false },
114
+ component: { type: "string" },
115
+ },
116
+ },
117
+ },
118
+ {
119
+ name: "initialize-component",
120
+ description: "Initialize a specific framework component",
121
+ inputSchema: {
122
+ type: "object",
123
+ properties: {
124
+ component: {
125
+ type: "string",
126
+ enum: this.bootSequence,
127
+ },
128
+ force: { type: "boolean", default: false },
129
+ },
130
+ required: ["component"],
131
+ },
132
+ },
133
+ {
134
+ name: "validate-boot-dependencies",
135
+ description: "Validate all boot dependencies and prerequisites",
136
+ inputSchema: {
137
+ type: "object",
138
+ properties: {
139
+ fix: { type: "boolean", default: false },
140
+ verbose: { type: "boolean", default: false },
141
+ },
142
+ },
143
+ },
144
+ {
145
+ name: "shutdown-framework",
146
+ description: "Gracefully shutdown framework components",
147
+ inputSchema: {
148
+ type: "object",
149
+ properties: {
150
+ force: { type: "boolean", default: false },
151
+ saveState: { type: "boolean", default: true },
152
+ },
153
+ },
154
+ },
155
+ ],
156
+ };
157
+ });
158
+ // Handle tool calls
159
+ this.server.setRequestHandler(CallToolRequestSchema, async (request) => {
160
+ const { name, arguments: args } = request.params;
161
+ switch (name) {
162
+ case "execute-boot-sequence":
163
+ return await this.handleExecuteBootSequence(args);
164
+ case "get-boot-status":
165
+ return await this.handleGetBootStatus(args);
166
+ case "initialize-component":
167
+ return await this.handleInitializeComponent(args);
168
+ case "validate-boot-dependencies":
169
+ return await this.handleValidateBootDependencies(args);
170
+ case "shutdown-framework":
171
+ return await this.handleShutdownFramework(args);
172
+ default:
173
+ throw new Error(`Unknown tool: ${name}`);
174
+ }
175
+ });
176
+ }
177
+ async handleExecuteBootSequence(args) {
178
+ const config = args.config || {};
179
+ const skipHealthChecks = args.skipHealthChecks || false;
180
+ const parallelInit = args.parallelInit !== false;
181
+ console.log("šŸš€ MCP: Executing boot sequence:", {
182
+ skipHealthChecks,
183
+ parallelInit,
184
+ });
185
+ const results = {
186
+ success: true,
187
+ initializedComponents: [],
188
+ failedComponents: [],
189
+ duration: 0,
190
+ errors: [],
191
+ warnings: [],
192
+ };
193
+ const startTime = Date.now();
194
+ try {
195
+ // Validate prerequisites
196
+ const validationResults = await this.validatePrerequisites();
197
+ if (!validationResults.valid) {
198
+ results.success = false;
199
+ results.errors.push(...validationResults.errors);
200
+ return this.formatBootResults(results);
201
+ }
202
+ // Execute boot sequence
203
+ if (parallelInit) {
204
+ await this.executeParallelBoot(skipHealthChecks, results);
205
+ }
206
+ else {
207
+ await this.executeSequentialBoot(skipHealthChecks, results);
208
+ }
209
+ results.duration = Date.now() - startTime;
210
+ this.bootStatus.initialized = results.success;
211
+ return this.formatBootResults(results);
212
+ }
213
+ catch (error) {
214
+ results.success = false;
215
+ results.duration = Date.now() - startTime;
216
+ results.errors.push(`Boot sequence failed: ${error instanceof Error ? error.message : String(error)}`);
217
+ return this.formatBootResults(results);
218
+ }
219
+ }
220
+ async handleGetBootStatus(args) {
221
+ const detailed = args.detailed || false;
222
+ const component = args.component;
223
+ console.log("šŸ“Š MCP: Getting boot status:", { detailed, component });
224
+ try {
225
+ if (component) {
226
+ // Get specific component status
227
+ const status = await this.getComponentStatus(component);
228
+ return {
229
+ content: [
230
+ {
231
+ type: "text",
232
+ text: `šŸ“Š Component Status: ${component}\n${this.formatComponentStatus(component, status, detailed)}`,
233
+ },
234
+ ],
235
+ };
236
+ }
237
+ else {
238
+ // Get overall boot status
239
+ const status = this.getOverallBootStatus();
240
+ return {
241
+ content: [
242
+ {
243
+ type: "text",
244
+ text: `šŸ“Š Framework Boot Status\n${this.formatOverallStatus(status, detailed)}`,
245
+ },
246
+ ],
247
+ };
248
+ }
249
+ }
250
+ catch (error) {
251
+ return {
252
+ content: [
253
+ {
254
+ type: "text",
255
+ text: `āŒ Status check failed: ${error instanceof Error ? error.message : String(error)}`,
256
+ },
257
+ ],
258
+ };
259
+ }
260
+ }
261
+ async handleInitializeComponent(args) {
262
+ const component = args.component;
263
+ const force = args.force || false;
264
+ console.log("šŸ”§ MCP: Initializing component:", { component, force });
265
+ try {
266
+ if (!this.bootSequence.includes(component)) {
267
+ return {
268
+ content: [
269
+ {
270
+ type: "text",
271
+ text: `āŒ Unknown component: ${component}\nAvailable: ${this.bootSequence.join(", ")}`,
272
+ },
273
+ ],
274
+ };
275
+ }
276
+ // Check if already initialized
277
+ if (this.bootStatus.components.has(component) && !force) {
278
+ return {
279
+ content: [
280
+ {
281
+ type: "text",
282
+ text: `āš ļø Component already initialized: ${component}\nUse force=true to re-initialize`,
283
+ },
284
+ ],
285
+ };
286
+ }
287
+ // Check dependencies
288
+ const deps = this.bootStatus.dependencies.get(component) || [];
289
+ for (const dep of deps) {
290
+ if (!this.bootStatus.components.has(dep)) {
291
+ return {
292
+ content: [
293
+ {
294
+ type: "text",
295
+ text: `āŒ Dependency not met: ${component} requires ${dep}\nInitialize dependencies first`,
296
+ },
297
+ ],
298
+ };
299
+ }
300
+ }
301
+ // Initialize component
302
+ const result = await this.initializeComponent(component);
303
+ this.bootStatus.components.set(component, result);
304
+ this.bootStatus.health.set(component, result.success);
305
+ return {
306
+ content: [
307
+ {
308
+ type: "text",
309
+ text: `šŸ”§ Component Initialized: ${component}\n**Status:** ${result.success ? "āœ… SUCCESS" : "āŒ FAILED"}\n**Duration:** ${result.duration}ms\n${result.message || ""}`,
310
+ },
311
+ ],
312
+ };
313
+ }
314
+ catch (error) {
315
+ return {
316
+ content: [
317
+ {
318
+ type: "text",
319
+ text: `āŒ Component initialization failed: ${error instanceof Error ? error.message : String(error)}`,
320
+ },
321
+ ],
322
+ };
323
+ }
324
+ }
325
+ async handleValidateBootDependencies(args) {
326
+ const fix = args.fix || false;
327
+ const verbose = args.verbose || false;
328
+ console.log("šŸ” MCP: Validating boot dependencies:", { fix, verbose });
329
+ try {
330
+ const results = await this.validateAllDependencies(fix, verbose);
331
+ const response = `šŸ” Dependency Validation Results
332
+
333
+ **Total Components:** ${results.total}
334
+ **Valid Dependencies:** ${results.valid}
335
+ **Missing Dependencies:** ${results.missing}
336
+ **Circular Dependencies:** ${results.circular}
337
+
338
+ ${results.issues.length > 0 ? `**Issues Found:**\n${results.issues.map((issue) => `• ${issue}`).join("\n")}\n` : ""}
339
+ ${results.fixes.length > 0 ? `**Fixes Applied:**\n${results.fixes.map((fix) => `• ${fix}`).join("\n")}\n` : ""}
340
+
341
+ **Status:** ${results.valid === results.total ? "āœ… ALL VALID" : "āŒ ISSUES DETECTED"}`;
342
+ return {
343
+ content: [{ type: "text", text: response }],
344
+ };
345
+ }
346
+ catch (error) {
347
+ return {
348
+ content: [
349
+ {
350
+ type: "text",
351
+ text: `āŒ Dependency validation failed: ${error instanceof Error ? error.message : String(error)}`,
352
+ },
353
+ ],
354
+ };
355
+ }
356
+ }
357
+ async handleShutdownFramework(args) {
358
+ const force = args.force || false;
359
+ const saveState = args.saveState !== false;
360
+ console.log("šŸ›‘ MCP: Shutting down framework:", { force, saveState });
361
+ try {
362
+ const results = await this.executeShutdownSequence(force, saveState);
363
+ return {
364
+ content: [
365
+ {
366
+ type: "text",
367
+ text: `šŸ›‘ Framework Shutdown Complete
368
+
369
+ **Components Shut Down:** ${results.shutDown}
370
+ **State Saved:** ${results.stateSaved}
371
+ **Errors:** ${results.errors.length}
372
+ **Duration:** ${results.duration}ms
373
+
374
+ ${results.errors.length > 0 ? `**Errors:**\n${results.errors.map((e) => `• ${e}`).join("\n")}` : ""}
375
+
376
+ **Status:** ${results.success ? "āœ… SHUTDOWN COMPLETE" : "āŒ SHUTDOWN ISSUES"}`,
377
+ },
378
+ ],
379
+ };
380
+ }
381
+ catch (error) {
382
+ return {
383
+ content: [
384
+ {
385
+ type: "text",
386
+ text: `āŒ Shutdown failed: ${error instanceof Error ? error.message : String(error)}`,
387
+ },
388
+ ],
389
+ };
390
+ }
391
+ }
392
+ async validatePrerequisites() {
393
+ const errors = [];
394
+ // Check Node.js version
395
+ try {
396
+ const nodeVersionOutput = execSync("node --version", { encoding: "utf8" })?.toString().trim() ||
397
+ "";
398
+ const nodeVersion = nodeVersionOutput || "v0.0.0";
399
+ const versionParts = nodeVersion.split(".");
400
+ const majorVersion = versionParts.length > 0 && versionParts[0]
401
+ ? parseInt(versionParts[0].substring(1))
402
+ : 0;
403
+ if (majorVersion < 18) {
404
+ errors.push(`Node.js version ${nodeVersion} is too old. Requires 18+`);
405
+ }
406
+ }
407
+ catch (error) {
408
+ errors.push("Cannot determine Node.js version");
409
+ }
410
+ // Check required directories
411
+ const requiredDirs = ["src", "src/agents", "src/mcps"];
412
+ for (const dir of requiredDirs) {
413
+ if (!fs.existsSync(dir)) {
414
+ errors.push(`Required directory missing: ${dir}`);
415
+ }
416
+ }
417
+ // Check package.json
418
+ if (!fs.existsSync("package.json")) {
419
+ errors.push("package.json not found");
420
+ }
421
+ return {
422
+ valid: errors.length === 0,
423
+ errors,
424
+ };
425
+ }
426
+ async executeParallelBoot(skipHealthChecks, results) {
427
+ const componentPromises = this.bootSequence.map((component) => this.initializeComponent(component, skipHealthChecks));
428
+ const componentResults = await Promise.allSettled(componentPromises);
429
+ for (let i = 0; i < componentResults.length; i++) {
430
+ const component = this.bootSequence[i];
431
+ if (!component)
432
+ continue;
433
+ const result = componentResults[i];
434
+ if (!result)
435
+ continue;
436
+ if (result.status === "fulfilled") {
437
+ const fulfilledResult = result;
438
+ if (fulfilledResult.value.success) {
439
+ results.initializedComponents.push(component);
440
+ this.bootStatus.components.set(component, fulfilledResult.value);
441
+ this.bootStatus.health.set(component, true);
442
+ }
443
+ else {
444
+ results.failedComponents.push(component);
445
+ results.errors.push(`${component}: ${fulfilledResult.value.error || "Unknown error"}`);
446
+ }
447
+ }
448
+ else {
449
+ results.failedComponents.push(component);
450
+ results.errors.push(`${component}: ${result.reason}`);
451
+ }
452
+ }
453
+ results.success = results.failedComponents.length === 0;
454
+ }
455
+ async executeSequentialBoot(skipHealthChecks, results) {
456
+ for (const component of this.bootSequence) {
457
+ try {
458
+ const result = await this.initializeComponent(component, skipHealthChecks);
459
+ if (result.success) {
460
+ results.initializedComponents.push(component);
461
+ this.bootStatus.components.set(component, result);
462
+ this.bootStatus.health.set(component, true);
463
+ }
464
+ else {
465
+ results.failedComponents.push(component);
466
+ results.errors.push(`${component}: ${result.error}`);
467
+ break; // Stop on first failure in sequential mode
468
+ }
469
+ }
470
+ catch (error) {
471
+ results.failedComponents.push(component);
472
+ results.errors.push(`${component}: ${error instanceof Error ? error.message : String(error)}`);
473
+ break;
474
+ }
475
+ }
476
+ results.success = results.failedComponents.length === 0;
477
+ }
478
+ async initializeComponent(component, skipHealthChecks = false) {
479
+ const startTime = Date.now();
480
+ try {
481
+ switch (component) {
482
+ case "configuration":
483
+ return await this.initConfiguration();
484
+ case "logging":
485
+ return await this.initLogging();
486
+ case "state-management":
487
+ return await this.initStateManagement();
488
+ case "security":
489
+ return await this.initSecurity();
490
+ case "codex-loader":
491
+ return await this.initCodexLoader();
492
+ case "context-loader":
493
+ return await this.initContextLoader();
494
+ case "processor-pipeline":
495
+ return await this.initProcessorPipeline();
496
+ case "agent-registry":
497
+ return await this.initAgentRegistry();
498
+ case "orchestrator":
499
+ return await this.initOrchestrator();
500
+ case "mcp-servers":
501
+ return await this.initMCPServers();
502
+ case "framework-hooks":
503
+ return await this.initFrameworkHooks();
504
+ default:
505
+ throw new Error(`Unknown component: ${component}`);
506
+ }
507
+ }
508
+ catch (error) {
509
+ return {
510
+ success: false,
511
+ duration: Date.now() - startTime,
512
+ error: error instanceof Error ? error.message : String(error),
513
+ };
514
+ }
515
+ }
516
+ async initConfiguration() {
517
+ // Check for configuration files
518
+ const configFiles = [
519
+ ".opencode/oh-my-opencode.json",
520
+ "src/strray/config/manager.py",
521
+ ];
522
+ for (const file of configFiles) {
523
+ if (!fs.existsSync(file)) {
524
+ throw new Error(`Configuration file missing: ${file}`);
525
+ }
526
+ }
527
+ return {
528
+ success: true,
529
+ duration: 10,
530
+ message: "Configuration files validated",
531
+ };
532
+ }
533
+ async initLogging() {
534
+ // Initialize logging system
535
+ const logDir = ".opencode/logs";
536
+ if (!fs.existsSync(logDir)) {
537
+ fs.mkdirSync(logDir, { recursive: true });
538
+ }
539
+ return {
540
+ success: true,
541
+ duration: 5,
542
+ message: "Logging system initialized",
543
+ };
544
+ }
545
+ async initStateManagement() {
546
+ // Validate state management setup
547
+ const stateDir = ".opencode/state";
548
+ if (!fs.existsSync(stateDir)) {
549
+ fs.mkdirSync(stateDir, { recursive: true });
550
+ }
551
+ return {
552
+ success: true,
553
+ duration: 8,
554
+ message: "State management initialized",
555
+ };
556
+ }
557
+ async initSecurity() {
558
+ // Basic security initialization
559
+ return {
560
+ success: true,
561
+ duration: 3,
562
+ message: "Security framework initialized",
563
+ };
564
+ }
565
+ async initCodexLoader() {
566
+ // Check for codex files
567
+ if (!fs.existsSync("src/strray/core/codex_loader.py")) {
568
+ throw new Error("Codex loader not found");
569
+ }
570
+ return {
571
+ success: true,
572
+ duration: 12,
573
+ message: "Codex loader initialized",
574
+ };
575
+ }
576
+ async initContextLoader() {
577
+ // Check for context loading
578
+ if (!fs.existsSync("src/strray/core/context_loader.py")) {
579
+ throw new Error("Context loader not found");
580
+ }
581
+ return {
582
+ success: true,
583
+ duration: 8,
584
+ message: "Context loader initialized",
585
+ };
586
+ }
587
+ async initProcessorPipeline() {
588
+ // Validate processor pipeline
589
+ return {
590
+ success: true,
591
+ duration: 15,
592
+ message: "Processor pipeline initialized",
593
+ };
594
+ }
595
+ async initAgentRegistry() {
596
+ // Check agent files exist
597
+ const agentCount = this.countAgentFiles();
598
+ if (agentCount < 5) {
599
+ throw new Error(`Insufficient agents found: ${agentCount}`);
600
+ }
601
+ return {
602
+ success: true,
603
+ duration: 10,
604
+ message: `Agent registry initialized with ${agentCount} agents`,
605
+ };
606
+ }
607
+ async initOrchestrator() {
608
+ // Validate orchestrator setup
609
+ return {
610
+ success: true,
611
+ duration: 20,
612
+ message: "Orchestrator initialized",
613
+ };
614
+ }
615
+ async initMCPServers() {
616
+ // Check MCP servers
617
+ const mcpCount = this.countMCPFiles();
618
+ if (mcpCount < 3) {
619
+ throw new Error(`Insufficient MCP servers found: ${mcpCount}`);
620
+ }
621
+ return {
622
+ success: true,
623
+ duration: 15,
624
+ message: `MCP servers initialized (${mcpCount} servers)`,
625
+ };
626
+ }
627
+ async initFrameworkHooks() {
628
+ // Initialize framework hooks
629
+ return {
630
+ success: true,
631
+ duration: 5,
632
+ message: "Framework hooks initialized",
633
+ };
634
+ }
635
+ countAgentFiles() {
636
+ try {
637
+ const files = fs.readdirSync("src/agents");
638
+ return files.filter((f) => f.endsWith(".ts") && f !== "types.ts" && f !== "index.ts").length;
639
+ }
640
+ catch (error) {
641
+ return 0;
642
+ }
643
+ }
644
+ countMCPFiles() {
645
+ try {
646
+ const files = fs.readdirSync("src/mcps");
647
+ return files.filter((f) => f.endsWith(".server.ts")).length;
648
+ }
649
+ catch (error) {
650
+ return 0;
651
+ }
652
+ }
653
+ async getComponentStatus(component) {
654
+ const initialized = this.bootStatus.components.has(component);
655
+ const healthy = this.bootStatus.health.get(component) || false;
656
+ const info = this.bootStatus.components.get(component);
657
+ return {
658
+ initialized,
659
+ healthy,
660
+ info,
661
+ dependencies: this.bootStatus.dependencies.get(component) || [],
662
+ };
663
+ }
664
+ getOverallBootStatus() {
665
+ const totalComponents = this.bootSequence.length;
666
+ const initializedComponents = Array.from(this.bootStatus.components.keys());
667
+ const healthyComponents = Array.from(this.bootStatus.health.values()).filter((h) => h).length;
668
+ return {
669
+ initialized: this.bootStatus.initialized,
670
+ uptime: Date.now() - this.bootStatus.startTime,
671
+ totalComponents,
672
+ initializedComponents: initializedComponents.length,
673
+ healthyComponents,
674
+ failedComponents: initializedComponents.length - healthyComponents,
675
+ };
676
+ }
677
+ async validateAllDependencies(fix, verbose) {
678
+ const results = {
679
+ total: this.bootSequence.length,
680
+ valid: 0,
681
+ missing: 0,
682
+ circular: 0,
683
+ issues: [],
684
+ fixes: [],
685
+ };
686
+ // Check for missing dependencies
687
+ for (const component of this.bootSequence) {
688
+ const deps = this.bootStatus.dependencies.get(component) || [];
689
+ const missingDeps = deps.filter((dep) => !this.checkComponentExists(dep));
690
+ if (missingDeps.length > 0) {
691
+ results.missing++;
692
+ results.issues.push(`${component} missing dependencies: ${missingDeps.join(", ")}`);
693
+ }
694
+ else {
695
+ results.valid++;
696
+ }
697
+ }
698
+ // Check for circular dependencies (simplified)
699
+ const circularDeps = this.detectCircularDependencies();
700
+ if (circularDeps.length > 0) {
701
+ results.circular = circularDeps.length;
702
+ results.issues.push(`Circular dependencies detected: ${circularDeps.join(", ")}`);
703
+ }
704
+ // Apply fixes if requested
705
+ if (fix && results.issues.length > 0) {
706
+ results.fixes = await this.applyDependencyFixes(results.issues);
707
+ }
708
+ return results;
709
+ }
710
+ checkComponentExists(component) {
711
+ // Simplified check - in real implementation this would be more thorough
712
+ switch (component) {
713
+ case "configuration":
714
+ return fs.existsSync(".opencode/oh-my-opencode.json");
715
+ case "logging":
716
+ return fs.existsSync("src/framework-logger.ts");
717
+ case "state-management":
718
+ return fs.existsSync("src/state/state-manager.ts");
719
+ case "security":
720
+ return fs.existsSync("src/strray/security.py");
721
+ case "codex-loader":
722
+ return fs.existsSync("src/strray/core/codex_loader.py");
723
+ case "context-loader":
724
+ return fs.existsSync("src/strray/core/context_loader.py");
725
+ case "processor-pipeline":
726
+ return fs.existsSync("src/processors/processor-manager.ts");
727
+ case "agent-registry":
728
+ return fs.existsSync("src/agents");
729
+ case "orchestrator":
730
+ return fs.existsSync("src/delegation/agent-delegator.ts");
731
+ case "mcp-servers":
732
+ return fs.existsSync("src/mcps");
733
+ case "framework-hooks":
734
+ return fs.existsSync("src/strray-activation.ts");
735
+ default:
736
+ return false;
737
+ }
738
+ }
739
+ detectCircularDependencies() {
740
+ // Simplified circular dependency detection
741
+ const circular = [];
742
+ for (const [component, deps] of this.bootStatus.dependencies) {
743
+ for (const dep of deps) {
744
+ const depDeps = this.bootStatus.dependencies.get(dep) || [];
745
+ if (depDeps.includes(component)) {
746
+ circular.push(`${component} ↔ ${dep}`);
747
+ }
748
+ }
749
+ }
750
+ return [...new Set(circular)]; // Remove duplicates
751
+ }
752
+ async applyDependencyFixes(issues) {
753
+ const fixes = [];
754
+ // Simplified fix application
755
+ for (const issue of issues) {
756
+ if (issue.includes("missing dependencies")) {
757
+ fixes.push("Dependency validation completed - manual fixes may be required");
758
+ }
759
+ }
760
+ return fixes;
761
+ }
762
+ async executeShutdownSequence(force, saveState) {
763
+ const results = {
764
+ success: true,
765
+ shutDown: 0,
766
+ stateSaved: saveState,
767
+ errors: [],
768
+ duration: 0,
769
+ };
770
+ const startTime = Date.now();
771
+ try {
772
+ // Shutdown in reverse order
773
+ const reverseSequence = [...this.bootSequence].reverse();
774
+ for (const component of reverseSequence) {
775
+ try {
776
+ await this.shutdownComponent(component, force);
777
+ results.shutDown++;
778
+ }
779
+ catch (error) {
780
+ results.errors.push(`${component}: ${error instanceof Error ? error.message : String(error)}`);
781
+ if (!force) {
782
+ results.success = false;
783
+ }
784
+ }
785
+ }
786
+ // Save state if requested
787
+ if (saveState) {
788
+ await this.saveShutdownState();
789
+ }
790
+ }
791
+ catch (error) {
792
+ results.success = false;
793
+ results.errors.push(`Shutdown error: ${error instanceof Error ? error.message : String(error)}`);
794
+ }
795
+ results.duration = Date.now() - startTime;
796
+ return results;
797
+ }
798
+ async shutdownComponent(component, force) {
799
+ // Simplified shutdown logic
800
+ console.log(`Shutting down ${component}...`);
801
+ // In real implementation, this would properly shut down each component
802
+ await new Promise((resolve) => setTimeout(resolve, 10));
803
+ }
804
+ async saveShutdownState() {
805
+ // Save shutdown state
806
+ const shutdownState = {
807
+ timestamp: Date.now(),
808
+ components: Array.from(this.bootStatus.components.keys()),
809
+ health: Object.fromEntries(this.bootStatus.health),
810
+ };
811
+ const stateFile = path.join(".opencode", "state", "shutdown-state.json");
812
+ fs.writeFileSync(stateFile, JSON.stringify(shutdownState, null, 2));
813
+ }
814
+ formatBootResults(results) {
815
+ const response = `šŸš€ Boot Sequence Results
816
+
817
+ **Success:** ${results.success ? "āœ… COMPLETE" : "āŒ FAILED"}
818
+ **Duration:** ${results.duration}ms
819
+ **Components Initialized:** ${results.initializedComponents.length}/${this.bootSequence.length}
820
+ **Components Failed:** ${results.failedComponents.length}
821
+
822
+ **Initialized Components:**
823
+ ${results.initializedComponents.map((c) => `• āœ… ${c}`).join("\n")}
824
+
825
+ ${results.failedComponents.length > 0 ? `**Failed Components:**\n${results.failedComponents.map((c) => `• āŒ ${c}`).join("\n")}\n` : ""}
826
+ ${results.errors.length > 0 ? `**Errors:**\n${results.errors.map((e) => `• šŸ’„ ${e}`).join("\n")}\n` : ""}
827
+ ${results.warnings.length > 0 ? `**Warnings:**\n${results.warnings.map((w) => `• āš ļø ${w}`).join("\n")}\n` : ""}
828
+
829
+ **Framework Status:** ${results.success ? "🟢 OPERATIONAL" : "šŸ”“ INITIALIZATION FAILED"}`;
830
+ return {
831
+ content: [{ type: "text", text: response }],
832
+ };
833
+ }
834
+ formatComponentStatus(component, status, detailed) {
835
+ let response = `**Component:** ${component}
836
+ **Initialized:** ${status.initialized ? "āœ… Yes" : "āŒ No"}
837
+ **Healthy:** ${status.healthy ? "āœ… Yes" : "āŒ No"}
838
+ **Dependencies:** ${status.dependencies.join(", ") || "None"}`;
839
+ if (detailed && status.info) {
840
+ response += `\n**Info:** ${JSON.stringify(status.info, null, 2)}`;
841
+ }
842
+ return response;
843
+ }
844
+ formatOverallStatus(status, detailed) {
845
+ let response = `**Initialized:** ${status.initialized ? "āœ… Yes" : "āŒ No"}
846
+ **Uptime:** ${Math.round(status.uptime / 1000)}s
847
+ **Components:** ${status.initializedComponents}/${status.totalComponents} initialized
848
+ **Healthy:** ${status.healthyComponents}/${status.initializedComponents} healthy
849
+ **Failed:** ${status.failedComponents} failed`;
850
+ if (detailed) {
851
+ response += `\n\n**Component Details:**`;
852
+ for (const component of this.bootSequence) {
853
+ const compStatus = this.bootStatus.health.get(component);
854
+ response += `\n• ${component}: ${compStatus ? "āœ…" : "āŒ"}`;
855
+ }
856
+ }
857
+ return response;
858
+ }
859
+ async run() {
860
+ const transport = new StdioServerTransport();
861
+ await this.server.connect(transport);
862
+ console.log("StrRay Boot Orchestrator MCP Server started");
863
+ }
864
+ }
865
+ // Start the server if run directly
866
+ if (import.meta.url === `file://${process.argv[1]}`) {
867
+ const server = new StrRayBootOrchestratorServer();
868
+ server.run().catch(console.error);
869
+ }
870
+ export { StrRayBootOrchestratorServer };
871
+ //# sourceMappingURL=boot-orchestrator.server.js.map