0xray 2.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 (739) hide show
  1. package/.opencode/agents/api-design.yml +31 -0
  2. package/.opencode/agents/architect.yml +15 -0
  3. package/.opencode/agents/architecture-patterns.yml +14 -0
  4. package/.opencode/agents/auto-format.yml +14 -0
  5. package/.opencode/agents/backend-engineer.yml +12 -0
  6. package/.opencode/agents/boot-orchestrator.yml +14 -0
  7. package/.opencode/agents/bug-triage-specialist.yml +15 -0
  8. package/.opencode/agents/code-analyzer.yml +12 -0
  9. package/.opencode/agents/code-reviewer.yml +14 -0
  10. package/.opencode/agents/content-creator.yml +12 -0
  11. package/.opencode/agents/database-engineer.yml +12 -0
  12. package/.opencode/agents/devops-engineer.yml +12 -0
  13. package/.opencode/agents/framework-compliance-audit.yml +14 -0
  14. package/.opencode/agents/frontend-engineer.yml +12 -0
  15. package/.opencode/agents/frontend-ui-ux-engineer.yml +12 -0
  16. package/.opencode/agents/git-workflow.yml +15 -0
  17. package/.opencode/agents/growth-strategist.yml +12 -0
  18. package/.opencode/agents/hermes-agent.yml +12 -0
  19. package/.opencode/agents/inference-improve.yml +12 -0
  20. package/.opencode/agents/lint.yml +14 -0
  21. package/.opencode/agents/log-monitor.yml +12 -0
  22. package/.opencode/agents/mobile-developer.yml +12 -0
  23. package/.opencode/agents/model-health-check.yml +12 -0
  24. package/.opencode/agents/multimodal-looker.yml +12 -0
  25. package/.opencode/agents/performance-analysis.yml +12 -0
  26. package/.opencode/agents/performance-engineer.yml +12 -0
  27. package/.opencode/agents/performance-optimization.yml +12 -0
  28. package/.opencode/agents/processor-pipeline.yml +14 -0
  29. package/.opencode/agents/project-analysis.yml +12 -0
  30. package/.opencode/agents/refactorer.yml +12 -0
  31. package/.opencode/agents/researcher.yml +12 -0
  32. package/.opencode/agents/security-auditor.yml +12 -0
  33. package/.opencode/agents/security-scan.yml +12 -0
  34. package/.opencode/agents/seo-consultant.yml +12 -0
  35. package/.opencode/agents/session-management.yml +12 -0
  36. package/.opencode/agents/state-manager.yml +12 -0
  37. package/.opencode/agents/storyteller.yml +12 -0
  38. package/.opencode/agents/strategist.yml +12 -0
  39. package/.opencode/agents/tech-writer.yml +12 -0
  40. package/.opencode/agents/testing-best-practices.yml +12 -0
  41. package/.opencode/agents/testing-lead.yml +12 -0
  42. package/.opencode/agents/ui-ux-design.yml +12 -0
  43. package/.opencode/codex.codex +8 -0
  44. package/.opencode/commands/auto-format.md +99 -0
  45. package/.opencode/commands/auto-summary-capture.md +90 -0
  46. package/.opencode/commands/dependency-audit.md +184 -0
  47. package/.opencode/commands/enforcer-daily-scan.md +137 -0
  48. package/.opencode/commands/framework-compliance-audit.md +205 -0
  49. package/.opencode/commands/interactive-validator.md +75 -0
  50. package/.opencode/commands/job-summary-logger.md +68 -0
  51. package/.opencode/commands/lint.md +11 -0
  52. package/.opencode/commands/mode-switch.md +95 -0
  53. package/.opencode/commands/model-health-check.md +186 -0
  54. package/.opencode/commands/performance-analysis.md +144 -0
  55. package/.opencode/commands/pre-commit-introspection.md +185 -0
  56. package/.opencode/commands/pre-commit-introspection.sh +133 -0
  57. package/.opencode/commands/security-scan.md +157 -0
  58. package/.opencode/commands/sisyphus-validation.md +128 -0
  59. package/.opencode/commands/summary-logger.md +83 -0
  60. package/.opencode/enforcer-config.json +285 -0
  61. package/.opencode/hooks/hook-metrics.json +380 -0
  62. package/.opencode/hooks/post-commit +114 -0
  63. package/.opencode/hooks/post-push +34 -0
  64. package/.opencode/init.sh +151 -0
  65. package/.opencode/skills/api-design/SKILL.md +37 -0
  66. package/.opencode/skills/architect-tools/SKILL.md +37 -0
  67. package/.opencode/skills/architecture-patterns/SKILL.md +37 -0
  68. package/.opencode/skills/auto-format/SKILL.md +37 -0
  69. package/.opencode/skills/backend-engineer/SKILL.md +49 -0
  70. package/.opencode/skills/boot-orchestrator/SKILL.md +37 -0
  71. package/.opencode/skills/bug-triage/SKILL.md +43 -0
  72. package/.opencode/skills/code-analyzer/SKILL.md +45 -0
  73. package/.opencode/skills/code-review/SKILL.md +52 -0
  74. package/.opencode/skills/content-creator/SKILL.md +38 -0
  75. package/.opencode/skills/database-engineer/SKILL.md +46 -0
  76. package/.opencode/skills/devops-engineer/SKILL.md +49 -0
  77. package/.opencode/skills/enforcer/SKILL.md +37 -0
  78. package/.opencode/skills/framework-compliance-audit/SKILL.md +37 -0
  79. package/.opencode/skills/frontend-engineer/SKILL.md +49 -0
  80. package/.opencode/skills/frontend-ui-ux-engineer/SKILL.md +41 -0
  81. package/.opencode/skills/git-workflow/SKILL.md +37 -0
  82. package/.opencode/skills/growth-strategist/SKILL.md +48 -0
  83. package/.opencode/skills/hermes-agent/SKILL.md +212 -0
  84. package/.opencode/skills/inference-improve/SKILL.md +97 -0
  85. package/.opencode/skills/lint/SKILL.md +37 -0
  86. package/.opencode/skills/log-monitor/SKILL.md +44 -0
  87. package/.opencode/skills/mobile-developer/SKILL.md +42 -0
  88. package/.opencode/skills/model-health-check/SKILL.md +37 -0
  89. package/.opencode/skills/multimodal-looker/SKILL.md +45 -0
  90. package/.opencode/skills/orchestrator/SKILL.md +37 -0
  91. package/.opencode/skills/performance-analysis/SKILL.md +37 -0
  92. package/.opencode/skills/performance-engineer/SKILL.md +41 -0
  93. package/.opencode/skills/performance-optimization/SKILL.md +37 -0
  94. package/.opencode/skills/processor-pipeline/SKILL.md +37 -0
  95. package/.opencode/skills/project-analysis/SKILL.md +42 -0
  96. package/.opencode/skills/refactoring-strategies/SKILL.md +37 -0
  97. package/.opencode/skills/registry.json +66 -0
  98. package/.opencode/skills/researcher/SKILL.md +37 -0
  99. package/.opencode/skills/security-audit/SKILL.md +47 -0
  100. package/.opencode/skills/security-scan/SKILL.md +37 -0
  101. package/.opencode/skills/seo-consultant/SKILL.md +43 -0
  102. package/.opencode/skills/session-management/SKILL.md +36 -0
  103. package/.opencode/skills/state-manager/SKILL.md +37 -0
  104. package/.opencode/skills/storyteller/SKILL.md +130 -0
  105. package/.opencode/skills/strategist/SKILL.md +32 -0
  106. package/.opencode/skills/tech-writer/SKILL.md +37 -0
  107. package/.opencode/skills/testing-best-practices/SKILL.md +37 -0
  108. package/.opencode/skills/testing-strategy/SKILL.md +43 -0
  109. package/.opencode/skills/ui-ux-design/SKILL.md +603 -0
  110. package/.opencode/workflows/post-deployment-audit.yml +123 -0
  111. package/AGENTS.md +110 -0
  112. package/LICENSE +21 -0
  113. package/README.md +131 -0
  114. package/dist/AGENTS.md +110 -0
  115. package/dist/CHANGELOG.md +2182 -0
  116. package/dist/LICENSE +21 -0
  117. package/dist/README.md +131 -0
  118. package/dist/agents/architect.js +56 -0
  119. package/dist/agents/backend-engineer.js +81 -0
  120. package/dist/agents/bug-triage-specialist.js +74 -0
  121. package/dist/agents/code-analyzer.js +150 -0
  122. package/dist/agents/code-reviewer.js +69 -0
  123. package/dist/agents/content-creator.js +72 -0
  124. package/dist/agents/database-engineer.js +76 -0
  125. package/dist/agents/devops-engineer.js +84 -0
  126. package/dist/agents/frontend-engineer.js +78 -0
  127. package/dist/agents/frontend-ui-ux-engineer.js +64 -0
  128. package/dist/agents/growth-strategist.js +111 -0
  129. package/dist/agents/index.js +45 -0
  130. package/dist/agents/librarian-agents-updater.js +333 -0
  131. package/dist/agents/log-monitor.js +109 -0
  132. package/dist/agents/mobile-developer.js +102 -0
  133. package/dist/agents/multimodal-looker.js +93 -0
  134. package/dist/agents/performance-engineer.js +86 -0
  135. package/dist/agents/refactorer.js +80 -0
  136. package/dist/agents/registry.js +340 -0
  137. package/dist/agents/researcher.js +83 -0
  138. package/dist/agents/security-auditor.js +158 -0
  139. package/dist/agents/seo-consultant.js +53 -0
  140. package/dist/agents/strategist.js +47 -0
  141. package/dist/agents/tech-writer.js +84 -0
  142. package/dist/agents/testing-lead.js +95 -0
  143. package/dist/agents/types.js +1 -0
  144. package/dist/analytics/consent-manager.js +258 -0
  145. package/dist/analytics/emerging-pattern-detector.js +260 -0
  146. package/dist/analytics/pattern-learning-engine.js +278 -0
  147. package/dist/analytics/pattern-performance-tracker.js +336 -0
  148. package/dist/analytics/predictive-analytics.js +248 -0
  149. package/dist/analytics/prompt-pattern-analyzer.js +371 -0
  150. package/dist/analytics/routing-performance-analyzer.js +356 -0
  151. package/dist/analytics/routing-refiner.js +380 -0
  152. package/dist/analytics/simple-pattern-analyzer.js +297 -0
  153. package/dist/architect/architect-tools.js +437 -0
  154. package/dist/architect/architectural-integrity.js +78 -0
  155. package/dist/benchmark/performance-benchmark.js +372 -0
  156. package/dist/cli/commands/analytics-disable.js +72 -0
  157. package/dist/cli/commands/analytics-enable-action.js +82 -0
  158. package/dist/cli/commands/analytics-preview.js +106 -0
  159. package/dist/cli/commands/analytics-status.js +68 -0
  160. package/dist/cli/commands/antigravity-status.js +106 -0
  161. package/dist/cli/commands/archive-logs.js +161 -0
  162. package/dist/cli/commands/credible-init.js +82 -0
  163. package/dist/cli/commands/grok-install.js +16 -0
  164. package/dist/cli/commands/hermes-install.js +66 -0
  165. package/dist/cli/commands/mcp-install.js +253 -0
  166. package/dist/cli/commands/openclaw-install.js +44 -0
  167. package/dist/cli/commands/opencode-install.js +99 -0
  168. package/dist/cli/commands/plugin-commands.js +246 -0
  169. package/dist/cli/commands/publish-agent.js +184 -0
  170. package/dist/cli/commands/security-audit.js +219 -0
  171. package/dist/cli/commands/skill-install.js +481 -0
  172. package/dist/cli/commands/status.js +196 -0
  173. package/dist/cli/commands/storyteller.js +230 -0
  174. package/dist/cli/index.js +986 -0
  175. package/dist/cli/server.js +147 -0
  176. package/dist/config/default-agents.js +16 -0
  177. package/dist/core/activity-logger.js +260 -0
  178. package/dist/core/adaptive-kernel.js +192 -0
  179. package/dist/core/agent-spawn-gate.js +120 -0
  180. package/dist/core/boot-orchestrator.js +812 -0
  181. package/dist/core/bridge.mjs +945 -0
  182. package/dist/core/codex-formatter.js +220 -0
  183. package/dist/core/codex-injector.js +424 -0
  184. package/dist/core/config-loader.js +148 -0
  185. package/dist/core/config-paths.js +162 -0
  186. package/dist/core/context-loader.js +269 -0
  187. package/dist/core/context-validator.js +212 -0
  188. package/dist/core/features-config.js +457 -0
  189. package/dist/core/framework-logger.js +275 -0
  190. package/dist/core/index.js +6 -0
  191. package/dist/core/kernel-patterns.js +302 -0
  192. package/dist/core/logging-config.js +43 -0
  193. package/dist/core/model-router.js +175 -0
  194. package/dist/core/orchestrator.js +408 -0
  195. package/dist/core/system-prompt-generator.js +265 -0
  196. package/dist/core/trace-context.js +33 -0
  197. package/dist/core/xray-activation.js +134 -0
  198. package/dist/delegation/agent-delegator.js +769 -0
  199. package/dist/delegation/agent-expertise.js +156 -0
  200. package/dist/delegation/analytics/index.js +12 -0
  201. package/dist/delegation/analytics/learning-engine.js +277 -0
  202. package/dist/delegation/analytics/outcome-tracker.js +279 -0
  203. package/dist/delegation/analytics/routing-analytics.js +193 -0
  204. package/dist/delegation/ast-code-parser.js +878 -0
  205. package/dist/delegation/codebase-context-analyzer.js +1040 -0
  206. package/dist/delegation/complexity-analyzer.js +282 -0
  207. package/dist/delegation/complexity-core.js +219 -0
  208. package/dist/delegation/config/types.js +6 -0
  209. package/dist/delegation/dependency-graph-builder.js +409 -0
  210. package/dist/delegation/index.js +20 -0
  211. package/dist/delegation/metrics-aggregator.js +335 -0
  212. package/dist/delegation/session-coordinator.js +352 -0
  213. package/dist/delegation/strategy-selector.js +108 -0
  214. package/dist/delegation/voting-coordinator.js +375 -0
  215. package/dist/delegation/voting-types.js +10 -0
  216. package/dist/delegation/weighted-voting-aggregator.js +194 -0
  217. package/dist/enforcement/core/index.js +19 -0
  218. package/dist/enforcement/core/rule-executor.js +365 -0
  219. package/dist/enforcement/core/rule-hierarchy.js +259 -0
  220. package/dist/enforcement/core/rule-registry.js +240 -0
  221. package/dist/enforcement/core/violation-fixer.js +651 -0
  222. package/dist/enforcement/enforcer-tools.js +909 -0
  223. package/dist/enforcement/index.js +41 -0
  224. package/dist/enforcement/loaders/agent-triage-loader.js +222 -0
  225. package/dist/enforcement/loaders/agents-md-validation-loader.js +252 -0
  226. package/dist/enforcement/loaders/base-loader.js +86 -0
  227. package/dist/enforcement/loaders/codex-loader.js +396 -0
  228. package/dist/enforcement/loaders/index.js +40 -0
  229. package/dist/enforcement/loaders/loader-orchestrator.js +168 -0
  230. package/dist/enforcement/loaders/processor-loader.js +113 -0
  231. package/dist/enforcement/rule-enforcer.js +298 -0
  232. package/dist/enforcement/test-auto-healing.js +325 -0
  233. package/dist/enforcement/types.js +30 -0
  234. package/dist/enforcement/validators/architecture-validators.js +600 -0
  235. package/dist/enforcement/validators/base-validator.js +108 -0
  236. package/dist/enforcement/validators/code-quality-validators.js +336 -0
  237. package/dist/enforcement/validators/index.js +21 -0
  238. package/dist/enforcement/validators/security-validators.js +220 -0
  239. package/dist/enforcement/validators/testing-validators.js +253 -0
  240. package/dist/enforcement/validators/validator-registry.js +150 -0
  241. package/dist/execution/opencode-cli-invoker.js +173 -0
  242. package/dist/execution/proposal-applier.js +254 -0
  243. package/dist/governance/codex-policy.service.js +167 -0
  244. package/dist/governance/governance-core.js +152 -0
  245. package/dist/governance/governance-service.js +274 -0
  246. package/dist/governance/governance-types.js +6 -0
  247. package/dist/index.js +24 -0
  248. package/dist/inference/deploy-verifier.js +161 -0
  249. package/dist/inference/index.js +5 -0
  250. package/dist/inference/inference-accumulator.js +126 -0
  251. package/dist/inference/inference-cycle.js +1168 -0
  252. package/dist/inference/semantic-patterns.js +310 -0
  253. package/dist/inference/session-capture.js +308 -0
  254. package/dist/integrations/base/ExampleIntegration.js +181 -0
  255. package/dist/integrations/base/Integration.js +395 -0
  256. package/dist/integrations/base/README.md +446 -0
  257. package/dist/integrations/base/index.js +16 -0
  258. package/dist/integrations/base/registry.js +606 -0
  259. package/dist/integrations/base/types.js +118 -0
  260. package/dist/integrations/governance/governance-client.js +316 -0
  261. package/dist/integrations/governance/index.js +373 -0
  262. package/dist/integrations/governance/types.js +97 -0
  263. package/dist/integrations/grok/grok-cli.js +83 -0
  264. package/dist/integrations/grok/hooks/pre-tool-use.js +134 -0
  265. package/dist/integrations/grok/plugin/0xray/.mcp.json +15 -0
  266. package/dist/integrations/grok/plugin/0xray/hooks/hooks.json +30 -0
  267. package/dist/integrations/hermes-agent/__init__.py +718 -0
  268. package/dist/integrations/hermes-agent/after-install.md +71 -0
  269. package/dist/integrations/hermes-agent/bridge.mjs +861 -0
  270. package/dist/integrations/hermes-agent/conftest.py +14 -0
  271. package/dist/integrations/hermes-agent/plugin.yaml +12 -0
  272. package/dist/integrations/hermes-agent/schemas.py +100 -0
  273. package/dist/integrations/hermes-agent/test_plugin.py +1100 -0
  274. package/dist/integrations/hermes-agent/tools.py +253 -0
  275. package/dist/integrations/openclaw/README.md +134 -0
  276. package/dist/integrations/openclaw/api-server.js +389 -0
  277. package/dist/integrations/openclaw/client.js +492 -0
  278. package/dist/integrations/openclaw/config.js +374 -0
  279. package/dist/integrations/openclaw/hooks/strray-hooks.js +280 -0
  280. package/dist/integrations/openclaw/index.js +351 -0
  281. package/dist/integrations/openclaw/types.js +153 -0
  282. package/dist/integrations/plugins/index.js +10 -0
  283. package/dist/integrations/plugins/plugin-integration.js +606 -0
  284. package/dist/integrations/plugins/plugin-registry.js +580 -0
  285. package/dist/mcps/agent-resolver.js +106 -0
  286. package/dist/mcps/architect-tools.server.js +277 -0
  287. package/dist/mcps/auto-format.server.js +413 -0
  288. package/dist/mcps/boot-orchestrator.server.js +853 -0
  289. package/dist/mcps/config/config-loader.js +103 -0
  290. package/dist/mcps/config/config-validator.js +101 -0
  291. package/dist/mcps/config/index.js +30 -0
  292. package/dist/mcps/config/plugin-server-registry.js +223 -0
  293. package/dist/mcps/config/server-config-registry.js +348 -0
  294. package/dist/mcps/connection/connection-manager.js +79 -0
  295. package/dist/mcps/connection/connection-pool.js +164 -0
  296. package/dist/mcps/connection/mcp-connection.js +233 -0
  297. package/dist/mcps/connection/process-spawner.js +34 -0
  298. package/dist/mcps/enforcer-tools.server.js +778 -0
  299. package/dist/mcps/estimation.server.js +192 -0
  300. package/dist/mcps/framework-compliance-audit.server.js +500 -0
  301. package/dist/mcps/framework-help.server.js +400 -0
  302. package/dist/mcps/governance.server.js +464 -0
  303. package/dist/mcps/in-process-skill-registry.js +48 -0
  304. package/dist/mcps/knowledge-skills/api-design.server.js +123 -0
  305. package/dist/mcps/knowledge-skills/architecture-patterns.server.js +113 -0
  306. package/dist/mcps/knowledge-skills/bug-triage-specialist.server.js +474 -0
  307. package/dist/mcps/knowledge-skills/code-analyzer.server.js +605 -0
  308. package/dist/mcps/knowledge-skills/code-review.server.js +847 -0
  309. package/dist/mcps/knowledge-skills/content-creator.server.js +256 -0
  310. package/dist/mcps/knowledge-skills/database-design.server.js +822 -0
  311. package/dist/mcps/knowledge-skills/devops-deployment.server.js +1180 -0
  312. package/dist/mcps/knowledge-skills/git-workflow.server.js +115 -0
  313. package/dist/mcps/knowledge-skills/growth-strategist.server.js +361 -0
  314. package/dist/mcps/knowledge-skills/log-monitor.server.js +451 -0
  315. package/dist/mcps/knowledge-skills/mobile-development.server.js +525 -0
  316. package/dist/mcps/knowledge-skills/multimodal-looker.server.js +1063 -0
  317. package/dist/mcps/knowledge-skills/performance-optimization.server.js +1587 -0
  318. package/dist/mcps/knowledge-skills/project-analysis.server.js +811 -0
  319. package/dist/mcps/knowledge-skills/refactoring-strategies.server.js +796 -0
  320. package/dist/mcps/knowledge-skills/security-audit.server.js +846 -0
  321. package/dist/mcps/knowledge-skills/seo-consultant.server.js +937 -0
  322. package/dist/mcps/knowledge-skills/session-management.server.js +470 -0
  323. package/dist/mcps/knowledge-skills/skill-invocation.server.js +729 -0
  324. package/dist/mcps/knowledge-skills/strategist.server.js +217 -0
  325. package/dist/mcps/knowledge-skills/tech-writer.server.js +1191 -0
  326. package/dist/mcps/knowledge-skills/testing-best-practices.server.js +866 -0
  327. package/dist/mcps/knowledge-skills/testing-strategy.server.js +827 -0
  328. package/dist/mcps/knowledge-skills/ui-ux-design.server.js +1538 -0
  329. package/dist/mcps/lint.server.js +381 -0
  330. package/dist/mcps/mcp-client.js +574 -0
  331. package/dist/mcps/model-health-check.server.js +228 -0
  332. package/dist/mcps/orchestrator/config/agent-capabilities.js +87 -0
  333. package/dist/mcps/orchestrator/execution/execution-planner.js +279 -0
  334. package/dist/mcps/orchestrator/handlers/complexity-handler.js +94 -0
  335. package/dist/mcps/orchestrator/handlers/status-handler.js +232 -0
  336. package/dist/mcps/orchestrator/handlers/task-handler.js +197 -0
  337. package/dist/mcps/orchestrator/server.js +305 -0
  338. package/dist/mcps/orchestrator/types.js +6 -0
  339. package/dist/mcps/orchestrator.server.js +19 -0
  340. package/dist/mcps/performance-analysis.server.js +519 -0
  341. package/dist/mcps/processor-pipeline.server.js +561 -0
  342. package/dist/mcps/protocol/protocol-constants.js +46 -0
  343. package/dist/mcps/registry.json +110 -0
  344. package/dist/mcps/researcher.server.js +504 -0
  345. package/dist/mcps/security-scan.server.js +531 -0
  346. package/dist/mcps/simulation/index.js +12 -0
  347. package/dist/mcps/simulation/server-simulations.js +219 -0
  348. package/dist/mcps/simulation/simulation-engine.js +96 -0
  349. package/dist/mcps/state-manager.server.js +637 -0
  350. package/dist/mcps/tools/index.js +14 -0
  351. package/dist/mcps/tools/tool-cache.js +112 -0
  352. package/dist/mcps/tools/tool-discovery.js +65 -0
  353. package/dist/mcps/tools/tool-executor.js +75 -0
  354. package/dist/mcps/tools/tool-registry.js +67 -0
  355. package/dist/mcps/types/index.js +15 -0
  356. package/dist/mcps/types/json-rpc.types.js +7 -0
  357. package/dist/mcps/types/mcp.types.js +7 -0
  358. package/dist/metrics/agent-metrics.js +574 -0
  359. package/dist/metrics/index.js +6 -0
  360. package/dist/monitoring/advanced-profiler.js +232 -0
  361. package/dist/monitoring/memory-monitor.js +315 -0
  362. package/dist/monitoring/nudge-watchdog.js +356 -0
  363. package/dist/monitoring/test-auto-generation-monitor.js +157 -0
  364. package/dist/orchestrator/agent-spawn-governor.js +559 -0
  365. package/dist/orchestrator/enhanced-multi-agent-orchestrator.js +399 -0
  366. package/dist/orchestrator/intelligent-commit-batcher.js +353 -0
  367. package/dist/orchestrator/multi-agent-orchestration-coordinator.js +456 -0
  368. package/dist/orchestrator/orchestrator.js +657 -0
  369. package/dist/orchestrator/self-direction-activation.js +245 -0
  370. package/dist/orchestrator/universal-librarian-consultation.js +216 -0
  371. package/dist/orchestrator/universal-registry-bridge.js +247 -0
  372. package/dist/performance/performance-budget-enforcer.js +434 -0
  373. package/dist/performance/performance-regression-tester.js +342 -0
  374. package/dist/plugin/xray-codex-injection.js +857 -0
  375. package/dist/postprocessor/PostProcessor.js +1048 -0
  376. package/dist/postprocessor/analysis/FailureAnalysisEngine.js +245 -0
  377. package/dist/postprocessor/autofix/AutoFixEngine.js +254 -0
  378. package/dist/postprocessor/autofix/FixValidator.js +56 -0
  379. package/dist/postprocessor/config.js +65 -0
  380. package/dist/postprocessor/escalation/EscalationEngine.js +492 -0
  381. package/dist/postprocessor/monitoring/MonitoringEngine.js +125 -0
  382. package/dist/postprocessor/redeploy/RedeployCoordinator.js +342 -0
  383. package/dist/postprocessor/services/RegressionAnalysisService.js +131 -0
  384. package/dist/postprocessor/success/SuccessHandler.js +134 -0
  385. package/dist/postprocessor/triggers/APITrigger.js +115 -0
  386. package/dist/postprocessor/triggers/GitHookTrigger.js +551 -0
  387. package/dist/postprocessor/triggers/WebhookTrigger.js +211 -0
  388. package/dist/postprocessor/types.js +4 -0
  389. package/dist/processors/doc-write-guard.js +46 -0
  390. package/dist/processors/implementations/agents-md-validation-processor.js +286 -0
  391. package/dist/processors/implementations/async-pattern-processor.js +158 -0
  392. package/dist/processors/implementations/codex-compliance-processor.js +57 -0
  393. package/dist/processors/implementations/commit-batcher-processor.js +71 -0
  394. package/dist/processors/implementations/console-log-guard-processor.js +163 -0
  395. package/dist/processors/implementations/coverage-analysis-processor.js +138 -0
  396. package/dist/processors/implementations/error-boundary-processor.js +44 -0
  397. package/dist/processors/implementations/inference-improvement-processor.js +270 -0
  398. package/dist/processors/implementations/log-protection-processor.js +118 -0
  399. package/dist/processors/implementations/nudge-processor.js +130 -0
  400. package/dist/processors/implementations/performance-budget-processor.js +217 -0
  401. package/dist/processors/implementations/postprocessor-chain-validator.js +149 -0
  402. package/dist/processors/implementations/pre-validate-processor.js +18 -0
  403. package/dist/processors/implementations/publish-preflight-processor.js +249 -0
  404. package/dist/processors/implementations/refactoring-logging-processor-wrapper.js +33 -0
  405. package/dist/processors/implementations/refactoring-logging-processor.js +96 -0
  406. package/dist/processors/implementations/regression-testing-processor.js +59 -0
  407. package/dist/processors/implementations/session-capture-processor.js +37 -0
  408. package/dist/processors/implementations/session-summary-processor.js +130 -0
  409. package/dist/processors/implementations/spawn-governance-processor.js +219 -0
  410. package/dist/processors/implementations/state-validation-processor.js +15 -0
  411. package/dist/processors/implementations/storytelling-trigger-processor.js +589 -0
  412. package/dist/processors/implementations/test-auto-creation-processor.js +484 -0
  413. package/dist/processors/implementations/test-execution-processor.js +132 -0
  414. package/dist/processors/implementations/typescript-compilation-processor.js +87 -0
  415. package/dist/processors/implementations/version-compliance-processor.js +350 -0
  416. package/dist/processors/processor-interfaces.js +126 -0
  417. package/dist/processors/processor-manager.js +826 -0
  418. package/dist/processors/processor-types.js +12 -0
  419. package/dist/public/about.html +228 -0
  420. package/dist/public/enterprise.html +27 -0
  421. package/dist/public/features.html +102 -0
  422. package/dist/public/index.html +145 -0
  423. package/dist/reporting/framework-reporting-system.js +187 -0
  424. package/dist/reporting/log-parser.js +281 -0
  425. package/dist/reporting/metrics.js +202 -0
  426. package/dist/reporting/report-formatter.js +146 -0
  427. package/dist/reporting/types.js +1 -0
  428. package/dist/scripts/activate-kernel-pipeline.js +101 -0
  429. package/dist/scripts/integration.js +234 -0
  430. package/dist/scripts/pre-command +26 -0
  431. package/dist/scripts/pre-command.mjs +358 -0
  432. package/dist/security/comprehensive-security-audit.js +1005 -0
  433. package/dist/security/index.js +13 -0
  434. package/dist/security/prompt-security-validator.js +148 -0
  435. package/dist/security/security-agent-coordinator.js +204 -0
  436. package/dist/security/security-auditor.js +584 -0
  437. package/dist/security/security-hardener.js +170 -0
  438. package/dist/security/security-hardening-system.js +727 -0
  439. package/dist/security/security-headers.js +118 -0
  440. package/dist/security/security-orchestration-layer.js +496 -0
  441. package/dist/security/security-scanner.js +429 -0
  442. package/dist/services/inference-tuner.js +301 -0
  443. package/dist/session/index.js +3 -0
  444. package/dist/session/session-cleanup-manager.js +366 -0
  445. package/dist/session/session-monitor.js +503 -0
  446. package/dist/session/session-state-manager.js +522 -0
  447. package/dist/skills/api-design/SKILL.md +37 -0
  448. package/dist/skills/architect-tools/SKILL.md +37 -0
  449. package/dist/skills/architecture-patterns/SKILL.md +37 -0
  450. package/dist/skills/auto-format/SKILL.md +37 -0
  451. package/dist/skills/backend-engineer/SKILL.md +49 -0
  452. package/dist/skills/boot-orchestrator/SKILL.md +37 -0
  453. package/dist/skills/bug-triage/SKILL.md +43 -0
  454. package/dist/skills/code-analyzer/SKILL.md +45 -0
  455. package/dist/skills/code-review/SKILL.md +52 -0
  456. package/dist/skills/content-creator/SKILL.md +38 -0
  457. package/dist/skills/database-engineer/SKILL.md +46 -0
  458. package/dist/skills/devops-engineer/SKILL.md +49 -0
  459. package/dist/skills/enforcer/SKILL.md +37 -0
  460. package/dist/skills/framework-compliance-audit/SKILL.md +37 -0
  461. package/dist/skills/frontend-engineer/SKILL.md +49 -0
  462. package/dist/skills/frontend-ui-ux-engineer/SKILL.md +41 -0
  463. package/dist/skills/git-workflow/SKILL.md +37 -0
  464. package/dist/skills/growth-strategist/SKILL.md +48 -0
  465. package/dist/skills/hermes-agent/SKILL.md +212 -0
  466. package/dist/skills/inference-improve/SKILL.md +97 -0
  467. package/dist/skills/lint/SKILL.md +37 -0
  468. package/dist/skills/log-monitor/SKILL.md +44 -0
  469. package/dist/skills/mobile-developer/SKILL.md +42 -0
  470. package/dist/skills/model-health-check/SKILL.md +37 -0
  471. package/dist/skills/multimodal-looker/SKILL.md +45 -0
  472. package/dist/skills/orchestrator/SKILL.md +37 -0
  473. package/dist/skills/performance-analysis/SKILL.md +37 -0
  474. package/dist/skills/performance-engineer/SKILL.md +41 -0
  475. package/dist/skills/performance-optimization/SKILL.md +37 -0
  476. package/dist/skills/processor-pipeline/SKILL.md +37 -0
  477. package/dist/skills/project-analysis/SKILL.md +42 -0
  478. package/dist/skills/refactoring-strategies/SKILL.md +37 -0
  479. package/dist/skills/registry.json +66 -0
  480. package/dist/skills/researcher/SKILL.md +37 -0
  481. package/dist/skills/security-audit/SKILL.md +48 -0
  482. package/dist/skills/security-scan/SKILL.md +37 -0
  483. package/dist/skills/seo-consultant/SKILL.md +43 -0
  484. package/dist/skills/session-management/SKILL.md +36 -0
  485. package/dist/skills/state-manager/SKILL.md +37 -0
  486. package/dist/skills/storyteller/SKILL.md +130 -0
  487. package/dist/skills/strategist/SKILL.md +32 -0
  488. package/dist/skills/tech-writer/SKILL.md +37 -0
  489. package/dist/skills/testing-best-practices/SKILL.md +37 -0
  490. package/dist/skills/testing-strategy/SKILL.md +43 -0
  491. package/dist/skills/ui-ux-design/SKILL.md +603 -0
  492. package/dist/state/context-providers.js +1 -0
  493. package/dist/state/index.js +7 -0
  494. package/dist/state/state-manager.js +208 -0
  495. package/dist/state/state-types.js +1 -0
  496. package/dist/testing/memory-regression-suite.js +258 -0
  497. package/dist/utils/batch-operations.js +292 -0
  498. package/dist/utils/codex-parser.js +445 -0
  499. package/dist/utils/command-runner.js +96 -0
  500. package/dist/utils/import-resolver.js +189 -0
  501. package/dist/utils/language-detector.js +383 -0
  502. package/dist/utils/path-resolver.js +112 -0
  503. package/dist/utils/shutdown-handler.js +75 -0
  504. package/dist/utils/test-template-generator.js +178 -0
  505. package/dist/utils/token-manager.js +163 -0
  506. package/dist/validation/estimation-validator.js +241 -0
  507. package/dist/validation/report-content-validator.js +218 -0
  508. package/opencode.json +153 -0
  509. package/package.json +170 -0
  510. package/scripts/helpers/resolve-config-path.cjs +57 -0
  511. package/scripts/helpers/resolve-config-path.mjs +73 -0
  512. package/scripts/hooks/pre-command +26 -0
  513. package/scripts/hooks/pre-command.mjs +358 -0
  514. package/scripts/hooks/run-hook.js +570 -0
  515. package/scripts/mjs/test-consumer-readiness.mjs +273 -0
  516. package/scripts/mjs/test-mcp-functionality.mjs +507 -0
  517. package/scripts/mjs/validate-mcp-connectivity.cjs +75 -0
  518. package/scripts/mjs/validate-postinstall-config.mjs +308 -0
  519. package/scripts/node/auto-reflection-generator.mjs +496 -0
  520. package/scripts/node/basic-security-audit.cjs +338 -0
  521. package/scripts/node/ci-cd-auto-fix.cjs +263 -0
  522. package/scripts/node/ci-report-generator.mjs +227 -0
  523. package/scripts/node/enforce-agents-md.mjs +420 -0
  524. package/scripts/node/enforce-version-compliance.sh +22 -0
  525. package/scripts/node/enforce-version-compliance.ts +126 -0
  526. package/scripts/node/github-actions-monitor.cjs +23 -0
  527. package/scripts/node/govern-reflection.mjs +160 -0
  528. package/scripts/node/postinstall.cjs +78 -0
  529. package/scripts/node/pre-publish-guard.js +267 -0
  530. package/scripts/node/prepare-consumer.cjs +143 -0
  531. package/scripts/node/reflection-processor.cjs +213 -0
  532. package/scripts/node/reflection-validate.sh +194 -0
  533. package/scripts/node/release-tweet.mjs +39 -0
  534. package/scripts/node/release.js +159 -0
  535. package/scripts/node/release.mjs +213 -0
  536. package/scripts/node/setup-dev.cjs +83 -0
  537. package/scripts/node/setup.cjs +214 -0
  538. package/scripts/node/sync-versions.mjs +140 -0
  539. package/scripts/node/universal-version-manager.js +1025 -0
  540. package/scripts/node/validate-external-processes.js +265 -0
  541. package/scripts/node/validate-mcp-connectivity.js +258 -0
  542. package/scripts/node/version-manager.mjs +524 -0
  543. package/scripts/validate-stringray-comprehensive.js +636 -0
  544. package/src/integrations/grok/plugin/0xray/.mcp.json +15 -0
  545. package/src/integrations/grok/plugin/0xray/hooks/hooks.json +30 -0
  546. package/src/mcps/agent-resolver.ts +168 -0
  547. package/src/mcps/architect-tools.server.ts +343 -0
  548. package/src/mcps/auto-format.server.ts +529 -0
  549. package/src/mcps/boot-orchestrator.server.ts +1082 -0
  550. package/src/mcps/config/__tests__/config-loader.test.ts +338 -0
  551. package/src/mcps/config/__tests__/config-validator.test.ts +646 -0
  552. package/src/mcps/config/__tests__/server-config-registry.test.ts +257 -0
  553. package/src/mcps/config/config-loader.ts +127 -0
  554. package/src/mcps/config/config-validator.ts +127 -0
  555. package/src/mcps/config/index.ts +32 -0
  556. package/src/mcps/config/plugin-server-registry.ts +335 -0
  557. package/src/mcps/config/server-config-registry.ts +395 -0
  558. package/src/mcps/connection/connection-manager.ts +91 -0
  559. package/src/mcps/connection/connection-pool.ts +216 -0
  560. package/src/mcps/connection/mcp-connection.ts +327 -0
  561. package/src/mcps/connection/process-spawner.ts +47 -0
  562. package/src/mcps/enforcer-tools.server.ts +1106 -0
  563. package/src/mcps/estimation.server.ts +229 -0
  564. package/src/mcps/framework-compliance-audit.server.ts +635 -0
  565. package/src/mcps/framework-help.server.ts +467 -0
  566. package/src/mcps/governance.server.ts +551 -0
  567. package/src/mcps/in-process-skill-registry.ts +79 -0
  568. package/src/mcps/knowledge-skills/api-design.server.test.ts +41 -0
  569. package/src/mcps/knowledge-skills/api-design.server.ts +160 -0
  570. package/src/mcps/knowledge-skills/architecture-patterns.server.ts +152 -0
  571. package/src/mcps/knowledge-skills/bug-triage-specialist.server.ts +624 -0
  572. package/src/mcps/knowledge-skills/code-analyzer.server.test.ts +129 -0
  573. package/src/mcps/knowledge-skills/code-analyzer.server.ts +591 -0
  574. package/src/mcps/knowledge-skills/code-review.server.ts +1132 -0
  575. package/src/mcps/knowledge-skills/content-creator.server.ts +300 -0
  576. package/src/mcps/knowledge-skills/database-design.server.ts +1200 -0
  577. package/src/mcps/knowledge-skills/devops-deployment.server.ts +1622 -0
  578. package/src/mcps/knowledge-skills/git-workflow.server.ts +152 -0
  579. package/src/mcps/knowledge-skills/growth-strategist.server.ts +413 -0
  580. package/src/mcps/knowledge-skills/log-monitor.server.ts +619 -0
  581. package/src/mcps/knowledge-skills/mobile-development.server.ts +672 -0
  582. package/src/mcps/knowledge-skills/multimodal-looker.server.ts +1500 -0
  583. package/src/mcps/knowledge-skills/performance-optimization.server.ts +2065 -0
  584. package/src/mcps/knowledge-skills/project-analysis.server.ts +1111 -0
  585. package/src/mcps/knowledge-skills/refactoring-strategies.server.ts +1092 -0
  586. package/src/mcps/knowledge-skills/security-audit.server.test.ts +112 -0
  587. package/src/mcps/knowledge-skills/security-audit.server.ts +1193 -0
  588. package/src/mcps/knowledge-skills/seo-consultant.server.ts +1160 -0
  589. package/src/mcps/knowledge-skills/session-management.server.ts +576 -0
  590. package/src/mcps/knowledge-skills/skill-invocation.server.ts +941 -0
  591. package/src/mcps/knowledge-skills/strategist.server.ts +267 -0
  592. package/src/mcps/knowledge-skills/tech-writer.server.ts +1638 -0
  593. package/src/mcps/knowledge-skills/testing-best-practices.server.test.ts +136 -0
  594. package/src/mcps/knowledge-skills/testing-best-practices.server.ts +1232 -0
  595. package/src/mcps/knowledge-skills/testing-strategy.server.test.ts +100 -0
  596. package/src/mcps/knowledge-skills/testing-strategy.server.ts +1172 -0
  597. package/src/mcps/knowledge-skills/ui-ux-design.server.ts +2076 -0
  598. package/src/mcps/lint.server.ts +483 -0
  599. package/src/mcps/mcp-client.ts +706 -0
  600. package/src/mcps/model-health-check.server.ts +292 -0
  601. package/src/mcps/orchestrator/config/agent-capabilities.ts +108 -0
  602. package/src/mcps/orchestrator/execution/execution-planner.ts +353 -0
  603. package/src/mcps/orchestrator/handlers/complexity-handler.ts +125 -0
  604. package/src/mcps/orchestrator/handlers/status-handler.ts +295 -0
  605. package/src/mcps/orchestrator/handlers/task-handler.ts +268 -0
  606. package/src/mcps/orchestrator/server.ts +388 -0
  607. package/src/mcps/orchestrator/types.ts +81 -0
  608. package/src/mcps/orchestrator.server.ts +34 -0
  609. package/src/mcps/performance-analysis.server.ts +715 -0
  610. package/src/mcps/processor-pipeline.server.ts +778 -0
  611. package/src/mcps/protocol/protocol-constants.ts +51 -0
  612. package/src/mcps/registry.json +110 -0
  613. package/src/mcps/researcher.server.ts +595 -0
  614. package/src/mcps/security-scan.server.ts +651 -0
  615. package/src/mcps/simulation/__tests__/simulation-engine.test.ts +275 -0
  616. package/src/mcps/simulation/index.ts +23 -0
  617. package/src/mcps/simulation/server-simulations.ts +241 -0
  618. package/src/mcps/simulation/simulation-engine.ts +126 -0
  619. package/src/mcps/state-manager.server.ts +777 -0
  620. package/src/mcps/tools/__tests__/tool-cache.test.ts +205 -0
  621. package/src/mcps/tools/__tests__/tool-discovery.test.ts +189 -0
  622. package/src/mcps/tools/__tests__/tool-executor.test.ts +215 -0
  623. package/src/mcps/tools/__tests__/tool-registry.test.ts +230 -0
  624. package/src/mcps/tools/index.ts +15 -0
  625. package/src/mcps/tools/tool-cache.ts +145 -0
  626. package/src/mcps/tools/tool-discovery.ts +83 -0
  627. package/src/mcps/tools/tool-executor.ts +106 -0
  628. package/src/mcps/tools/tool-registry.ts +78 -0
  629. package/src/mcps/types/__tests__/types.test.ts +341 -0
  630. package/src/mcps/types/index.ts +17 -0
  631. package/src/mcps/types/json-rpc.types.ts +38 -0
  632. package/src/mcps/types/mcp.types.ts +115 -0
  633. package/src/opencode/agents/api-design.yml +31 -0
  634. package/src/opencode/agents/architect.yml +15 -0
  635. package/src/opencode/agents/architecture-patterns.yml +14 -0
  636. package/src/opencode/agents/auto-format.yml +14 -0
  637. package/src/opencode/agents/backend-engineer.yml +12 -0
  638. package/src/opencode/agents/boot-orchestrator.yml +14 -0
  639. package/src/opencode/agents/bug-triage-specialist.yml +15 -0
  640. package/src/opencode/agents/code-analyzer.yml +12 -0
  641. package/src/opencode/agents/code-reviewer.yml +14 -0
  642. package/src/opencode/agents/content-creator.yml +12 -0
  643. package/src/opencode/agents/database-engineer.yml +12 -0
  644. package/src/opencode/agents/devops-engineer.yml +12 -0
  645. package/src/opencode/agents/framework-compliance-audit.yml +14 -0
  646. package/src/opencode/agents/frontend-engineer.yml +12 -0
  647. package/src/opencode/agents/frontend-ui-ux-engineer.yml +12 -0
  648. package/src/opencode/agents/git-workflow.yml +15 -0
  649. package/src/opencode/agents/growth-strategist.yml +12 -0
  650. package/src/opencode/agents/hermes-agent.yml +12 -0
  651. package/src/opencode/agents/inference-improve.yml +12 -0
  652. package/src/opencode/agents/lint.yml +14 -0
  653. package/src/opencode/agents/log-monitor.yml +12 -0
  654. package/src/opencode/agents/mobile-developer.yml +12 -0
  655. package/src/opencode/agents/model-health-check.yml +12 -0
  656. package/src/opencode/agents/multimodal-looker.yml +12 -0
  657. package/src/opencode/agents/performance-analysis.yml +12 -0
  658. package/src/opencode/agents/performance-engineer.yml +12 -0
  659. package/src/opencode/agents/performance-optimization.yml +12 -0
  660. package/src/opencode/agents/processor-pipeline.yml +14 -0
  661. package/src/opencode/agents/project-analysis.yml +12 -0
  662. package/src/opencode/agents/refactorer.yml +12 -0
  663. package/src/opencode/agents/researcher.yml +12 -0
  664. package/src/opencode/agents/security-auditor.yml +12 -0
  665. package/src/opencode/agents/security-scan.yml +12 -0
  666. package/src/opencode/agents/seo-consultant.yml +12 -0
  667. package/src/opencode/agents/session-management.yml +12 -0
  668. package/src/opencode/agents/state-manager.yml +12 -0
  669. package/src/opencode/agents/storyteller.yml +12 -0
  670. package/src/opencode/agents/strategist.yml +12 -0
  671. package/src/opencode/agents/tech-writer.yml +12 -0
  672. package/src/opencode/agents/testing-best-practices.yml +12 -0
  673. package/src/opencode/agents/testing-lead.yml +12 -0
  674. package/src/opencode/agents/ui-ux-design.yml +12 -0
  675. package/src/opencode/codex.codex +8 -0
  676. package/src/opencode/commands/auto-format.md +99 -0
  677. package/src/opencode/commands/auto-summary-capture.md +90 -0
  678. package/src/opencode/commands/dependency-audit.md +184 -0
  679. package/src/opencode/commands/enforcer-daily-scan.md +137 -0
  680. package/src/opencode/commands/framework-compliance-audit.md +205 -0
  681. package/src/opencode/commands/interactive-validator.md +75 -0
  682. package/src/opencode/commands/job-summary-logger.md +68 -0
  683. package/src/opencode/commands/lint.md +11 -0
  684. package/src/opencode/commands/mode-switch.md +95 -0
  685. package/src/opencode/commands/model-health-check.md +186 -0
  686. package/src/opencode/commands/performance-analysis.md +144 -0
  687. package/src/opencode/commands/pre-commit-introspection.md +185 -0
  688. package/src/opencode/commands/pre-commit-introspection.sh +133 -0
  689. package/src/opencode/commands/security-scan.md +157 -0
  690. package/src/opencode/commands/sisyphus-validation.md +128 -0
  691. package/src/opencode/commands/summary-logger.md +83 -0
  692. package/src/opencode/enforcer-config.json +285 -0
  693. package/src/opencode/openclaw/config.json +25 -0
  694. package/src/opencode/workflows/post-deployment-audit.yml +123 -0
  695. package/src/skills/api-design/SKILL.md +37 -0
  696. package/src/skills/architect-tools/SKILL.md +37 -0
  697. package/src/skills/architecture-patterns/SKILL.md +37 -0
  698. package/src/skills/auto-format/SKILL.md +37 -0
  699. package/src/skills/backend-engineer/SKILL.md +49 -0
  700. package/src/skills/boot-orchestrator/SKILL.md +37 -0
  701. package/src/skills/bug-triage/SKILL.md +43 -0
  702. package/src/skills/code-analyzer/SKILL.md +45 -0
  703. package/src/skills/code-review/SKILL.md +52 -0
  704. package/src/skills/content-creator/SKILL.md +38 -0
  705. package/src/skills/database-engineer/SKILL.md +46 -0
  706. package/src/skills/devops-engineer/SKILL.md +49 -0
  707. package/src/skills/enforcer/SKILL.md +37 -0
  708. package/src/skills/framework-compliance-audit/SKILL.md +37 -0
  709. package/src/skills/frontend-engineer/SKILL.md +49 -0
  710. package/src/skills/frontend-ui-ux-engineer/SKILL.md +41 -0
  711. package/src/skills/git-workflow/SKILL.md +37 -0
  712. package/src/skills/growth-strategist/SKILL.md +48 -0
  713. package/src/skills/hermes-agent/SKILL.md +212 -0
  714. package/src/skills/inference-improve/SKILL.md +97 -0
  715. package/src/skills/lint/SKILL.md +37 -0
  716. package/src/skills/log-monitor/SKILL.md +44 -0
  717. package/src/skills/mobile-developer/SKILL.md +42 -0
  718. package/src/skills/model-health-check/SKILL.md +37 -0
  719. package/src/skills/multimodal-looker/SKILL.md +45 -0
  720. package/src/skills/orchestrator/SKILL.md +37 -0
  721. package/src/skills/performance-analysis/SKILL.md +37 -0
  722. package/src/skills/performance-engineer/SKILL.md +41 -0
  723. package/src/skills/performance-optimization/SKILL.md +37 -0
  724. package/src/skills/processor-pipeline/SKILL.md +37 -0
  725. package/src/skills/project-analysis/SKILL.md +42 -0
  726. package/src/skills/refactoring-strategies/SKILL.md +37 -0
  727. package/src/skills/registry.json +66 -0
  728. package/src/skills/researcher/SKILL.md +37 -0
  729. package/src/skills/security-audit/SKILL.md +48 -0
  730. package/src/skills/security-scan/SKILL.md +37 -0
  731. package/src/skills/seo-consultant/SKILL.md +43 -0
  732. package/src/skills/session-management/SKILL.md +36 -0
  733. package/src/skills/state-manager/SKILL.md +37 -0
  734. package/src/skills/storyteller/SKILL.md +130 -0
  735. package/src/skills/strategist/SKILL.md +32 -0
  736. package/src/skills/tech-writer/SKILL.md +37 -0
  737. package/src/skills/testing-best-practices/SKILL.md +37 -0
  738. package/src/skills/testing-strategy/SKILL.md +43 -0
  739. package/src/skills/ui-ux-design/SKILL.md +603 -0
@@ -0,0 +1,1040 @@
1
+ import * as fs from "fs";
2
+ import * as path from "path";
3
+ import { frameworkLogger } from "../core/framework-logger.js";
4
+ export class CodebaseContextAnalyzer {
5
+ projectRoot;
6
+ memoryConfig;
7
+ analysisCache = new Map();
8
+ ignorePatterns = [
9
+ /node_modules/,
10
+ /\.git/,
11
+ /dist/,
12
+ /build/,
13
+ /\.next/,
14
+ /\.nuxt/,
15
+ /\.vuepress/,
16
+ /\.cache/,
17
+ /\.temp/,
18
+ /coverage/,
19
+ /\.nyc_output/,
20
+ /logs/,
21
+ /\.DS_Store/,
22
+ /Thumbs\.db/,
23
+ ];
24
+ supportedLanguages = {
25
+ ".ts": "typescript",
26
+ ".tsx": "typescript",
27
+ ".js": "javascript",
28
+ ".jsx": "javascript",
29
+ ".py": "python",
30
+ ".java": "java",
31
+ ".cpp": "cpp",
32
+ ".c": "c",
33
+ ".cs": "csharp",
34
+ ".php": "php",
35
+ ".rb": "ruby",
36
+ ".go": "go",
37
+ ".rs": "rust",
38
+ ".swift": "swift",
39
+ ".kt": "kotlin",
40
+ ".scala": "scala",
41
+ ".clj": "clojure",
42
+ ".hs": "haskell",
43
+ ".ml": "ocaml",
44
+ ".fs": "fsharp",
45
+ ".elm": "elm",
46
+ ".dart": "dart",
47
+ ".vue": "vue",
48
+ ".svelte": "svelte",
49
+ ".astro": "astro",
50
+ };
51
+ constructor(projectRoot, memoryConfig) {
52
+ this.projectRoot = projectRoot || process.cwd();
53
+ // Default memory configuration for performance optimization
54
+ this.memoryConfig = {
55
+ maxFilesInMemory: 100, // Process max 100 files simultaneously
56
+ maxFileSizeBytes: 1024 * 1024, // 1MB max file size to load
57
+ enableStreaming: true, // Enable streaming for large files
58
+ batchSize: 20, // Process 20 files per batch
59
+ enableCaching: true, // Enable result caching
60
+ cacheTtlMs: 5 * 60 * 1000, // 5 minute cache TTL
61
+ enableConcurrentProcessing: true, // Enable concurrent processing
62
+ concurrencyLimit: 10, // Max 10 concurrent file operations
63
+ ...memoryConfig, // Override with user config
64
+ };
65
+ }
66
+ /**
67
+ * Perform comprehensive codebase analysis with memory optimization
68
+ */
69
+ async analyzeCodebase() {
70
+ const jobId = `codebase-analysis-${Date.now()}-${Math.random().toString(36).substring(2, 11)}`;
71
+ await frameworkLogger.log("codebase-context-analyzer", "analysis-start", "info", {
72
+ jobId,
73
+ message: "Starting comprehensive codebase analysis",
74
+ memoryConfig: this.memoryConfig,
75
+ });
76
+ const startTime = Date.now();
77
+ const initialMemoryUsage = process.memoryUsage().heapUsed;
78
+ try {
79
+ const structure = await this.buildCodebaseStructure(jobId);
80
+ const metrics = this.calculateContextMetrics(structure);
81
+ const insights = this.generateInsights(structure, metrics);
82
+ const recommendations = this.generateRecommendations(structure, metrics);
83
+ const risks = this.identifyRisks(structure, metrics);
84
+ const analysis = {
85
+ structure,
86
+ metrics,
87
+ insights,
88
+ recommendations,
89
+ risks,
90
+ scannedAt: new Date(),
91
+ };
92
+ const endTime = Date.now();
93
+ const finalMemoryUsage = process.memoryUsage().heapUsed;
94
+ const memoryDelta = finalMemoryUsage - initialMemoryUsage;
95
+ await frameworkLogger.log("codebase-context-analyzer", "analysis-complete", "success", {
96
+ jobId,
97
+ files: structure.totalFiles,
98
+ loc: structure.totalLinesOfCode,
99
+ languages: Array.from(structure.languages.keys()),
100
+ qualityScore: metrics.qualityScore,
101
+ duration: endTime - startTime,
102
+ memoryDeltaMB: Math.round((memoryDelta / 1024 / 1024) * 100) / 100,
103
+ cacheHits: this.analysisCache.size,
104
+ });
105
+ return analysis;
106
+ }
107
+ catch (error) {
108
+ const endTime = Date.now();
109
+ const finalMemoryUsage = process.memoryUsage().heapUsed;
110
+ await frameworkLogger.log("codebase-context-analyzer", "analysis-failed", "error", {
111
+ jobId,
112
+ error: error instanceof Error ? error.message : String(error),
113
+ duration: endTime - startTime,
114
+ finalMemoryMB: Math.round((finalMemoryUsage / 1024 / 1024) * 100) / 100,
115
+ });
116
+ throw error;
117
+ }
118
+ }
119
+ /**
120
+ * Get cached analysis result with intelligent invalidation
121
+ */
122
+ getCachedAnalysis(cacheKey) {
123
+ if (!this.memoryConfig.enableCaching)
124
+ return null;
125
+ const cached = this.analysisCache.get(cacheKey);
126
+ if (!cached)
127
+ return null;
128
+ // Check TTL
129
+ if (Date.now() - cached.timestamp > this.memoryConfig.cacheTtlMs) {
130
+ this.analysisCache.delete(cacheKey);
131
+ return null;
132
+ }
133
+ // Intelligent cache validation - check if file still exists and hasn't changed
134
+ const filePath = this.extractFilePathFromCacheKey(cacheKey);
135
+ if (filePath) {
136
+ try {
137
+ const currentStats = fs.statSync(filePath);
138
+ const cachedMtime = cached.lastModified?.getTime() || 0;
139
+ if (currentStats.mtime.getTime() !== cachedMtime) {
140
+ // File has changed, invalidate cache
141
+ this.analysisCache.delete(cacheKey);
142
+ return null;
143
+ }
144
+ }
145
+ catch (error) {
146
+ // File no longer exists or inaccessible, remove from cache
147
+ this.analysisCache.delete(cacheKey);
148
+ return null;
149
+ }
150
+ }
151
+ return cached;
152
+ }
153
+ /**
154
+ * Set cached analysis result with size limits
155
+ */
156
+ setCachedAnalysis(cacheKey, data) {
157
+ if (!this.memoryConfig.enableCaching)
158
+ return;
159
+ // Prevent cache from growing too large (keep last 1000 entries)
160
+ if (this.analysisCache.size >= 1000) {
161
+ const oldestKey = Array.from(this.analysisCache.keys())[0];
162
+ if (oldestKey) {
163
+ this.analysisCache.delete(oldestKey);
164
+ }
165
+ }
166
+ this.analysisCache.set(cacheKey, {
167
+ ...data,
168
+ timestamp: Date.now(),
169
+ });
170
+ }
171
+ /**
172
+ * Extract file path from cache key for validation
173
+ */
174
+ extractFilePathFromCacheKey(cacheKey) {
175
+ const match = cacheKey.match(/^file:(.+?:\d+)$/);
176
+ if (match && match[1]) {
177
+ const parts = match[1].split(":");
178
+ return parts[0] || null;
179
+ }
180
+ return null;
181
+ }
182
+ /**
183
+ * Stream file content for large files to reduce memory usage
184
+ */
185
+ async streamFileContent(filePath) {
186
+ return new Promise((resolve, reject) => {
187
+ let content = "";
188
+ const stream = fs.createReadStream(filePath, { encoding: "utf8" });
189
+ stream.on("data", (chunk) => {
190
+ content += chunk;
191
+ // Prevent excessive memory usage during streaming
192
+ if (content.length > this.memoryConfig.maxFileSizeBytes) {
193
+ stream.destroy();
194
+ reject(new Error("File too large for streaming"));
195
+ }
196
+ });
197
+ stream.on("end", () => resolve(content));
198
+ stream.on("error", reject);
199
+ });
200
+ }
201
+ /**
202
+ * Build complete codebase structure map with batching for memory efficiency
203
+ */
204
+ async buildCodebaseStructure(jobId) {
205
+ const fileGraph = new Map();
206
+ const modules = new Map();
207
+ const dependencyGraph = new Map();
208
+ const languages = new Map();
209
+ const scanDirectory = async (dirPath, relativePath = "") => {
210
+ try {
211
+ const entries = fs.readdirSync(dirPath, { withFileTypes: true });
212
+ // Process files in batches to control memory usage
213
+ const fileEntries = [];
214
+ const dirEntries = [];
215
+ // Separate files and directories for batch processing
216
+ for (const entry of entries) {
217
+ const entryPath = path.join(dirPath, entry.name);
218
+ const entryRelativePath = path.join(relativePath, entry.name);
219
+ // Skip ignored patterns
220
+ if (this.ignorePatterns.some((pattern) => pattern.test(entryPath))) {
221
+ continue;
222
+ }
223
+ if (entry.isDirectory()) {
224
+ const isModule = this.isModuleDirectory(entryPath);
225
+ dirEntries.push({
226
+ path: entryPath,
227
+ relativePath: entryRelativePath,
228
+ isModule,
229
+ });
230
+ }
231
+ else if (entry.isFile()) {
232
+ fileEntries.push({
233
+ path: entryPath,
234
+ relativePath: entryRelativePath,
235
+ });
236
+ }
237
+ }
238
+ // Process directories first (may contain modules)
239
+ for (const dirEntry of dirEntries) {
240
+ if (dirEntry.isModule) {
241
+ const moduleInfo = await this.analyzeModule(dirEntry.path, dirEntry.relativePath, jobId);
242
+ modules.set(dirEntry.relativePath, moduleInfo);
243
+ }
244
+ else {
245
+ await scanDirectory(dirEntry.path, dirEntry.relativePath);
246
+ }
247
+ }
248
+ // Process files with concurrent processing for better performance
249
+ const concurrencyLimit = this.memoryConfig.enableConcurrentProcessing
250
+ ? Math.min(this.memoryConfig.concurrencyLimit || 10, this.memoryConfig.maxFilesInMemory)
251
+ : 1; // Sequential processing if concurrent disabled
252
+ for (let i = 0; i < fileEntries.length; i += concurrencyLimit) {
253
+ const batch = fileEntries.slice(i, i + concurrencyLimit);
254
+ // Process batch concurrently with controlled parallelism
255
+ const batchPromises = batch.map(async ({ path: filePath, relativePath: fileRelativePath }) => {
256
+ try {
257
+ const fileInfo = await this.analyzeFile(filePath, fileRelativePath, jobId);
258
+ if (fileInfo) {
259
+ fileGraph.set(fileRelativePath, fileInfo);
260
+ // Update language counts
261
+ const lang = fileInfo.language;
262
+ languages.set(lang, (languages.get(lang) || 0) + 1);
263
+ }
264
+ }
265
+ catch (error) {
266
+ await frameworkLogger.log("codebase-context-analyzer", "batch-file-processing-error", "info", {
267
+ jobId,
268
+ filePath,
269
+ error: error instanceof Error ? error.message : String(error),
270
+ });
271
+ }
272
+ });
273
+ await Promise.all(batchPromises);
274
+ // Yield control periodically to prevent blocking the event loop
275
+ if (i + concurrencyLimit < fileEntries.length) {
276
+ await new Promise((resolve) => setImmediate(resolve));
277
+ }
278
+ }
279
+ }
280
+ catch (error) {
281
+ await frameworkLogger.log("codebase-context-analyzer", "scan-directory-failed", "error", {
282
+ jobId,
283
+ dirPath,
284
+ error: error instanceof Error ? error.message : String(error),
285
+ });
286
+ }
287
+ };
288
+ await scanDirectory(this.projectRoot);
289
+ // Build dependency relationships
290
+ await this.buildDependencyGraph(fileGraph, dependencyGraph);
291
+ const architecture = this.detectArchitecture(fileGraph, modules);
292
+ return {
293
+ rootPath: this.projectRoot,
294
+ totalFiles: fileGraph.size,
295
+ totalLinesOfCode: Array.from(fileGraph.values()).reduce((sum, file) => sum + file.linesOfCode, 0),
296
+ languages,
297
+ modules,
298
+ fileGraph,
299
+ dependencyGraph,
300
+ architecture,
301
+ };
302
+ }
303
+ /**
304
+ * Analyze individual file for structure and dependencies with memory optimization
305
+ */
306
+ async analyzeFile(filePath, relativePath, jobId) {
307
+ try {
308
+ const stats = fs.statSync(filePath);
309
+ const extension = path.extname(filePath).toLowerCase();
310
+ const language = this.supportedLanguages[extension] || "other";
311
+ const isSourceCode = language !== "other";
312
+ if (!isSourceCode && !this.isConfigFile(relativePath)) {
313
+ return null;
314
+ }
315
+ // Memory optimization: Check file size before loading
316
+ if (stats.size > this.memoryConfig.maxFileSizeBytes) {
317
+ await frameworkLogger.log("codebase-context-analyzer", "large-file-skipped", "info", {
318
+ jobId,
319
+ filePath,
320
+ size: stats.size,
321
+ maxSize: this.memoryConfig.maxFileSizeBytes,
322
+ });
323
+ // For large files, analyze metadata only (no content loading)
324
+ return {
325
+ path: filePath,
326
+ relativePath,
327
+ size: stats.size,
328
+ extension,
329
+ language,
330
+ isSourceCode,
331
+ linesOfCode: Math.floor(stats.size / 50), // Rough estimate
332
+ imports: [],
333
+ exports: [],
334
+ dependencies: [],
335
+ lastModified: stats.mtime,
336
+ };
337
+ }
338
+ // Lazy load content only when needed and within memory limits
339
+ let content;
340
+ let linesOfCode = 0;
341
+ let imports = [];
342
+ let exports = [];
343
+ try {
344
+ // Check cache first for performance
345
+ const cacheKey = `file:${relativePath}:${stats.mtime.getTime()}`;
346
+ const cached = this.getCachedAnalysis(cacheKey);
347
+ if (cached) {
348
+ return {
349
+ path: filePath,
350
+ relativePath,
351
+ size: stats.size,
352
+ extension,
353
+ language,
354
+ isSourceCode,
355
+ linesOfCode: cached.linesOfCode,
356
+ imports: cached.imports,
357
+ exports: cached.exports,
358
+ dependencies: cached.imports,
359
+ lastModified: stats.mtime,
360
+ content: cached.content ?? undefined,
361
+ };
362
+ }
363
+ // Load content with streaming for large files if enabled
364
+ content =
365
+ this.memoryConfig.enableStreaming && stats.size > 100 * 1024
366
+ ? await this.streamFileContent(filePath)
367
+ : fs.readFileSync(filePath, "utf8");
368
+ linesOfCode = content.split("\n").length;
369
+ const importExportData = await this.extractImportsExports(content, language, jobId);
370
+ imports = importExportData.imports;
371
+ exports = importExportData.exports;
372
+ // Cache the analysis result
373
+ if (this.memoryConfig.enableCaching) {
374
+ this.setCachedAnalysis(cacheKey, {
375
+ linesOfCode,
376
+ imports,
377
+ exports,
378
+ content,
379
+ timestamp: Date.now(),
380
+ });
381
+ }
382
+ }
383
+ catch (contentError) {
384
+ await frameworkLogger.log("codebase-context-analyzer", "content-loading-failed", "info", {
385
+ jobId,
386
+ filePath,
387
+ error: contentError instanceof Error
388
+ ? contentError.message
389
+ : String(contentError),
390
+ });
391
+ // Continue with metadata-only analysis
392
+ }
393
+ const result = {
394
+ path: filePath,
395
+ relativePath,
396
+ size: stats.size,
397
+ extension,
398
+ language,
399
+ isSourceCode,
400
+ linesOfCode,
401
+ imports,
402
+ exports,
403
+ dependencies: imports, // For now, imports are dependencies
404
+ lastModified: stats.mtime,
405
+ };
406
+ // Only set content if it was successfully loaded
407
+ if (content !== undefined) {
408
+ result.content = content;
409
+ }
410
+ return result;
411
+ }
412
+ catch (error) {
413
+ await frameworkLogger.log("codebase-context-analyzer", "file-analysis-failed", "error", {
414
+ jobId,
415
+ filePath,
416
+ error: error instanceof Error ? error.message : String(error),
417
+ });
418
+ return null;
419
+ }
420
+ }
421
+ /**
422
+ * Analyze module directory structure
423
+ */
424
+ async analyzeModule(dirPath, relativePath, jobId) {
425
+ const files = [];
426
+ const dependencies = new Set();
427
+ const dependents = new Set();
428
+ const scanModuleFiles = async (modulePath, moduleRelativePath) => {
429
+ try {
430
+ const entries = fs.readdirSync(modulePath, { withFileTypes: true });
431
+ for (const entry of entries) {
432
+ const entryPath = path.join(modulePath, entry.name);
433
+ const entryRelativePath = path.join(moduleRelativePath, entry.name);
434
+ if (entry.isFile()) {
435
+ const fileInfo = await this.analyzeFile(entryPath, entryRelativePath, jobId);
436
+ if (fileInfo) {
437
+ files.push(fileInfo);
438
+ fileInfo.imports.forEach((dep) => dependencies.add(dep));
439
+ fileInfo.exports.forEach((exp) => dependents.add(exp));
440
+ }
441
+ }
442
+ else if (entry.isDirectory() &&
443
+ !this.ignorePatterns.some((pattern) => pattern.test(entry.name))) {
444
+ await scanModuleFiles(entryPath, entryRelativePath);
445
+ }
446
+ }
447
+ }
448
+ catch (error) {
449
+ await frameworkLogger.log("codebase-context-analyzer", "module-scan-failed", "error", {
450
+ jobId,
451
+ modulePath,
452
+ error: error instanceof Error ? error.message : String(error),
453
+ });
454
+ }
455
+ };
456
+ await scanModuleFiles(dirPath, relativePath);
457
+ // Determine module type
458
+ const moduleType = this.classifyModule(relativePath, files);
459
+ // Find entry point
460
+ const entryPoint = this.findEntryPoint(files);
461
+ return {
462
+ name: path.basename(relativePath),
463
+ path: dirPath,
464
+ files,
465
+ entryPoint,
466
+ dependencies: Array.from(dependencies),
467
+ dependents: Array.from(dependents),
468
+ type: moduleType,
469
+ };
470
+ }
471
+ /**
472
+ * Extract imports and exports from source code
473
+ */
474
+ async extractImportsExports(content, language, jobId) {
475
+ const imports = [];
476
+ const exports = [];
477
+ try {
478
+ switch (language) {
479
+ case "typescript":
480
+ case "javascript":
481
+ return this.extractJsTsImportsExports(content);
482
+ case "python":
483
+ return this.extractPythonImportsExports(content);
484
+ case "java":
485
+ return this.extractJavaImportsExports(content);
486
+ default:
487
+ return { imports: [], exports: [] };
488
+ }
489
+ }
490
+ catch (error) {
491
+ await frameworkLogger.log("codebase-context-analyzer", "import-export-extraction-failed", "error", {
492
+ jobId,
493
+ language,
494
+ error: error instanceof Error ? error.message : String(error),
495
+ });
496
+ return { imports: [], exports: [] };
497
+ }
498
+ }
499
+ extractJsTsImportsExports(content) {
500
+ const imports = [];
501
+ const exports = [];
502
+ // Import patterns
503
+ const importPatterns = [
504
+ /import\s+.*?\s+from\s+['"]([^'"]+)['"]/g,
505
+ /import\s*\(\s*['"]([^'"]+)['"]\s*\)/g,
506
+ /require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,
507
+ ];
508
+ importPatterns.forEach((pattern) => {
509
+ let match;
510
+ while ((match = pattern.exec(content)) !== null) {
511
+ if (match[1]) {
512
+ imports.push(match[1]);
513
+ }
514
+ }
515
+ });
516
+ // Export patterns
517
+ const exportPatterns = [
518
+ /export\s+(?:const|let|var|function|class|interface|type)\s+(\w+)/g,
519
+ /export\s+{\s*([^}]+)\s*}/g,
520
+ /export\s+default/g,
521
+ ];
522
+ exportPatterns.forEach((pattern) => {
523
+ let match;
524
+ while ((match = pattern.exec(content)) !== null) {
525
+ if (match[1]) {
526
+ const exportsList = match[1]
527
+ .split(",")
528
+ .map((e) => {
529
+ const trimmed = e.trim();
530
+ const asSplit = trimmed.split(" as ");
531
+ return asSplit[0] || trimmed;
532
+ })
533
+ .filter(Boolean);
534
+ exports.push(...exportsList);
535
+ }
536
+ else {
537
+ exports.push("default");
538
+ }
539
+ }
540
+ });
541
+ return {
542
+ imports: Array.from(new Set(imports)),
543
+ exports: Array.from(new Set(exports)),
544
+ };
545
+ }
546
+ extractPythonImportsExports(content) {
547
+ const imports = [];
548
+ const exports = [];
549
+ // Import patterns
550
+ const importPatterns = [/from\s+([^\s]+)\s+import/g, /import\s+([^\s]+)/g];
551
+ importPatterns.forEach((pattern) => {
552
+ let match;
553
+ while ((match = pattern.exec(content)) !== null) {
554
+ if (match[1]) {
555
+ imports.push(match[1]);
556
+ }
557
+ }
558
+ });
559
+ // Export patterns (Python doesn't have explicit exports, but __all__ can indicate public API)
560
+ const allMatch = content.match(/__all__\s*=\s*\[([^\]]+)\]/);
561
+ if (allMatch && allMatch[1]) {
562
+ const exportsList = allMatch[1]
563
+ .split(",")
564
+ .map((e) => e.trim().replace(/['"]/g, ""))
565
+ .filter(Boolean);
566
+ exports.push(...exportsList);
567
+ }
568
+ return {
569
+ imports: Array.from(new Set(imports)),
570
+ exports: Array.from(new Set(exports)),
571
+ };
572
+ }
573
+ extractJavaImportsExports(content) {
574
+ const imports = [];
575
+ const exports = [];
576
+ // Import patterns
577
+ const importPattern = /^import\s+([^;]+);/gm;
578
+ let match;
579
+ while ((match = importPattern.exec(content)) !== null) {
580
+ if (match[1]) {
581
+ imports.push(match[1]);
582
+ }
583
+ }
584
+ // Export patterns (public classes/interfaces)
585
+ const exportPattern = /(?:public\s+)?(?:class|interface|enum)\s+(\w+)/g;
586
+ while ((match = exportPattern.exec(content)) !== null) {
587
+ if (match[1]) {
588
+ exports.push(match[1]);
589
+ }
590
+ }
591
+ return {
592
+ imports: Array.from(new Set(imports)),
593
+ exports: Array.from(new Set(exports)),
594
+ };
595
+ }
596
+ /**
597
+ * Build dependency graph between files
598
+ */
599
+ async buildDependencyGraph(fileGraph, dependencyGraph) {
600
+ for (const [filePath, fileInfo] of Array.from(fileGraph)) {
601
+ const dependencies = new Set();
602
+ for (const importPath of fileInfo.imports) {
603
+ // Resolve relative imports
604
+ if (importPath.startsWith("./") || importPath.startsWith("../")) {
605
+ try {
606
+ const resolvedPath = path.resolve(path.dirname(fileInfo.path), importPath);
607
+ const resolvedRelative = path.relative(this.projectRoot, resolvedPath);
608
+ // Check for file extensions
609
+ const possibleExtensions = [
610
+ "",
611
+ ".ts",
612
+ ".tsx",
613
+ ".js",
614
+ ".jsx",
615
+ ".py",
616
+ ".java",
617
+ ];
618
+ let foundFile = null;
619
+ for (const ext of possibleExtensions) {
620
+ const testPath = resolvedRelative + ext;
621
+ if (fileGraph.has(testPath) ||
622
+ fs.existsSync(path.join(this.projectRoot, testPath))) {
623
+ foundFile = testPath;
624
+ break;
625
+ }
626
+ }
627
+ if (foundFile) {
628
+ dependencies.add(foundFile);
629
+ }
630
+ }
631
+ catch (error) {
632
+ // Import resolution failed, skip
633
+ }
634
+ }
635
+ else {
636
+ // External dependency, add to graph for tracking
637
+ dependencies.add(importPath);
638
+ }
639
+ }
640
+ dependencyGraph.set(filePath, dependencies);
641
+ }
642
+ }
643
+ /**
644
+ * Detect architectural patterns and framework usage
645
+ */
646
+ detectArchitecture(fileGraph, modules) {
647
+ const frameworks = [];
648
+ const patterns = [];
649
+ let structure = "monolithic";
650
+ const entryPoints = [];
651
+ // Framework detection
652
+ if (this.hasFramework(fileGraph, "react"))
653
+ frameworks.push("React");
654
+ if (this.hasFramework(fileGraph, "vue"))
655
+ frameworks.push("Vue.js");
656
+ if (this.hasFramework(fileGraph, "angular"))
657
+ frameworks.push("Angular");
658
+ if (this.hasFramework(fileGraph, "svelte"))
659
+ frameworks.push("Svelte");
660
+ if (this.hasFramework(fileGraph, "express"))
661
+ frameworks.push("Express.js");
662
+ if (this.hasFramework(fileGraph, "nestjs"))
663
+ frameworks.push("NestJS");
664
+ if (this.hasFramework(fileGraph, "nextjs"))
665
+ frameworks.push("Next.js");
666
+ if (this.hasFramework(fileGraph, "nuxt"))
667
+ frameworks.push("Nuxt.js");
668
+ // Pattern detection
669
+ if (this.detectMVCPattern(fileGraph))
670
+ patterns.push("MVC");
671
+ if (this.detectRepositoryPattern(fileGraph))
672
+ patterns.push("Repository");
673
+ if (this.detectObserverPattern(fileGraph))
674
+ patterns.push("Observer");
675
+ if (this.detectFactoryPattern(fileGraph))
676
+ patterns.push("Factory");
677
+ // Structure detection
678
+ if (modules.size > 5 && this.hasMicroservicesIndicators(fileGraph)) {
679
+ structure = "microservices";
680
+ }
681
+ else if (modules.size > 0) {
682
+ structure = "modular";
683
+ }
684
+ // Entry points detection
685
+ for (const [filePath, fileInfo] of Array.from(fileGraph)) {
686
+ if (this.isEntryPoint(filePath, fileInfo)) {
687
+ entryPoints.push(filePath);
688
+ }
689
+ }
690
+ return {
691
+ framework: frameworks,
692
+ patterns,
693
+ structure,
694
+ entryPoints,
695
+ };
696
+ }
697
+ /**
698
+ * Calculate comprehensive context metrics
699
+ */
700
+ calculateContextMetrics(structure) {
701
+ const fileCount = structure.totalFiles;
702
+ const linesOfCode = structure.totalLinesOfCode;
703
+ const languages = Array.from(structure.languages.keys());
704
+ // Calculate complexity based on various factors
705
+ const complexity = this.calculateComplexityScore(structure);
706
+ // Calculate coupling (interdependencies)
707
+ const coupling = this.calculateCouplingScore(structure);
708
+ // Calculate cohesion (internal dependencies within modules)
709
+ const cohesion = this.calculateCohesionScore(structure);
710
+ // Estimate test coverage (rough heuristic)
711
+ const testCoverage = this.estimateTestCoverage(structure);
712
+ // Architectural patterns
713
+ const architecturalPatterns = structure.architecture.patterns;
714
+ // Overall quality score
715
+ const qualityScore = this.calculateQualityScore({
716
+ fileCount,
717
+ linesOfCode,
718
+ complexity,
719
+ coupling,
720
+ cohesion,
721
+ testCoverage,
722
+ patterns: architecturalPatterns.length,
723
+ });
724
+ return {
725
+ fileCount,
726
+ linesOfCode,
727
+ languages,
728
+ complexity,
729
+ coupling,
730
+ cohesion,
731
+ testCoverage,
732
+ architecturalPatterns,
733
+ qualityScore,
734
+ };
735
+ }
736
+ calculateComplexityScore(structure) {
737
+ let score = 0;
738
+ // File count factor
739
+ score += Math.min(structure.totalFiles / 10, 20);
740
+ // Language diversity factor
741
+ score += Math.min(structure.languages.size * 5, 15);
742
+ // Module complexity
743
+ score += Math.min(structure.modules.size * 2, 20);
744
+ // Dependency complexity
745
+ const totalDeps = Array.from(structure.dependencyGraph.values()).reduce((sum, deps) => sum + deps.size, 0);
746
+ score += Math.min(totalDeps / 20, 25);
747
+ // Framework complexity
748
+ score += Math.min(structure.architecture.framework.length * 10, 20);
749
+ return Math.min(Math.max(score, 0), 100);
750
+ }
751
+ calculateCouplingScore(structure) {
752
+ const totalDeps = Array.from(structure.dependencyGraph.values()).reduce((sum, deps) => sum + deps.size, 0);
753
+ const avgDeps = totalDeps / structure.totalFiles;
754
+ // Normalize to 0-100 scale (higher coupling = higher score)
755
+ return Math.min(avgDeps * 20, 100);
756
+ }
757
+ calculateCohesionScore(structure) {
758
+ let totalCohesion = 0;
759
+ let moduleCount = 0;
760
+ for (const module of Array.from(structure.modules.values())) {
761
+ if (module.files.length > 1) {
762
+ // Calculate internal dependencies within module
763
+ const internalDeps = module.files.reduce((sum, file) => {
764
+ const fileDeps = structure.dependencyGraph.get(file.relativePath) || new Set();
765
+ const internalCount = Array.from(fileDeps).filter((dep) => module.files.some((f) => f.relativePath === dep)).length;
766
+ return sum + internalCount;
767
+ }, 0);
768
+ const cohesion = internalDeps / (module.files.length * (module.files.length - 1));
769
+ totalCohesion += Math.min(cohesion, 1);
770
+ moduleCount++;
771
+ }
772
+ }
773
+ return moduleCount > 0 ? (totalCohesion / moduleCount) * 100 : 50;
774
+ }
775
+ estimateTestCoverage(structure) {
776
+ const testFiles = Array.from(structure.fileGraph.values()).filter((file) => file.relativePath.includes("test") ||
777
+ file.relativePath.includes("spec")).length;
778
+ const srcFiles = Array.from(structure.fileGraph.values()).filter((file) => file.isSourceCode &&
779
+ !file.relativePath.includes("test") &&
780
+ !file.relativePath.includes("spec")).length;
781
+ if (srcFiles === 0)
782
+ return 0;
783
+ // Rough heuristic: assume 1 test file covers 3-5 source files
784
+ const estimatedCoverage = Math.min(((testFiles * 4) / srcFiles) * 100, 100);
785
+ return Math.round(estimatedCoverage);
786
+ }
787
+ calculateQualityScore(metrics) {
788
+ // Weighted scoring system
789
+ const weights = {
790
+ complexity: -0.2, // Lower complexity is better
791
+ coupling: -0.25, // Lower coupling is better
792
+ cohesion: 0.2, // Higher cohesion is better
793
+ testCoverage: 0.25, // Higher coverage is better
794
+ patterns: 0.1, // More patterns is better
795
+ };
796
+ let score = 50; // Base score
797
+ score += weights.complexity * Math.min(metrics.complexity, 50);
798
+ score += weights.coupling * (100 - metrics.coupling);
799
+ score += weights.cohesion * metrics.cohesion;
800
+ score += weights.testCoverage * metrics.testCoverage;
801
+ score += weights.patterns * Math.min(metrics.patterns * 10, 20);
802
+ return Math.min(Math.max(Math.round(score), 0), 100);
803
+ }
804
+ /**
805
+ * Generate insights based on analysis
806
+ */
807
+ generateInsights(structure, metrics) {
808
+ const insights = [];
809
+ // Size insights
810
+ if (structure.totalFiles > 1000) {
811
+ insights.push(`Large codebase with ${structure.totalFiles} files - consider modularization`);
812
+ }
813
+ else if (structure.totalFiles < 10) {
814
+ insights.push("Small codebase - good candidate for rapid development");
815
+ }
816
+ // Language insights
817
+ if (structure.languages.size > 3) {
818
+ insights.push(`Polyglot codebase with ${structure.languages.size} languages`);
819
+ }
820
+ else if (structure.languages.size === 1) {
821
+ insights.push("Single-language codebase - easier maintenance but potential skill limitations");
822
+ }
823
+ // Architecture insights
824
+ if (structure.architecture.framework.length > 0) {
825
+ insights.push(`Uses ${structure.architecture.framework.join(", ")} framework(s)`);
826
+ }
827
+ if (structure.architecture.patterns.length > 0) {
828
+ insights.push(`Follows ${structure.architecture.patterns.join(", ")} architectural pattern(s)`);
829
+ }
830
+ // Quality insights
831
+ if (metrics.qualityScore > 80) {
832
+ insights.push("High-quality codebase with strong architectural foundations");
833
+ }
834
+ else if (metrics.qualityScore < 40) {
835
+ insights.push("Codebase may benefit from refactoring and quality improvements");
836
+ }
837
+ if (metrics.testCoverage > 80) {
838
+ insights.push("Excellent test coverage provides strong confidence in changes");
839
+ }
840
+ else if (metrics.testCoverage < 20) {
841
+ insights.push("Low test coverage increases risk of undetected regressions");
842
+ }
843
+ return insights;
844
+ }
845
+ /**
846
+ * Generate recommendations for improvement
847
+ */
848
+ generateRecommendations(structure, metrics) {
849
+ const recommendations = [];
850
+ if (metrics.testCoverage < 70) {
851
+ recommendations.push("Increase test coverage to reduce regression risk");
852
+ }
853
+ if (metrics.coupling > 70) {
854
+ recommendations.push("Reduce coupling through better separation of concerns");
855
+ }
856
+ if (metrics.cohesion < 30) {
857
+ recommendations.push("Improve cohesion by grouping related functionality");
858
+ }
859
+ if (structure.modules.size === 0 && structure.totalFiles > 50) {
860
+ recommendations.push("Consider modularizing the codebase for better maintainability");
861
+ }
862
+ if (structure.architecture.framework.length === 0 &&
863
+ structure.totalFiles > 20) {
864
+ recommendations.push("Consider adopting a framework to standardize development patterns");
865
+ }
866
+ if (metrics.complexity > 80) {
867
+ recommendations.push("Consider breaking down complex components into smaller, focused units");
868
+ }
869
+ return recommendations;
870
+ }
871
+ /**
872
+ * Identify potential risks and issues
873
+ */
874
+ identifyRisks(structure, metrics) {
875
+ const risks = [];
876
+ if (metrics.coupling > 80) {
877
+ risks.push("High coupling increases change risk and maintenance complexity");
878
+ }
879
+ if (metrics.testCoverage < 30) {
880
+ risks.push("Low test coverage poses significant risk for safe refactoring");
881
+ }
882
+ if (structure.dependencyGraph.size > 0) {
883
+ // Check for circular dependencies (simplified check)
884
+ const circularDeps = this.detectCircularDependencies(structure.dependencyGraph);
885
+ if (circularDeps.length > 0) {
886
+ risks.push(`${circularDeps.length} potential circular dependencies detected`);
887
+ }
888
+ }
889
+ if (structure.languages.size > 5) {
890
+ risks.push("High language diversity may complicate team composition and maintenance");
891
+ }
892
+ if (metrics.complexity > 90) {
893
+ risks.push("Very high complexity indicates potential maintainability issues");
894
+ }
895
+ return risks;
896
+ }
897
+ // Helper methods
898
+ isModuleDirectory(dirPath) {
899
+ try {
900
+ const entries = fs.readdirSync(dirPath);
901
+ return (entries.some((entry) => {
902
+ const ext = path.extname(entry);
903
+ return this.supportedLanguages[ext];
904
+ }) &&
905
+ entries.some((entry) => entry === "package.json" ||
906
+ entry === "index.ts" ||
907
+ entry === "index.js"));
908
+ }
909
+ catch {
910
+ return false;
911
+ }
912
+ }
913
+ isConfigFile(filePath) {
914
+ const configPatterns = [
915
+ /package\.json$/,
916
+ /tsconfig\.json$/,
917
+ /webpack\.config\./,
918
+ /\.eslintrc/,
919
+ /\.prettierrc/,
920
+ /Dockerfile/,
921
+ /docker-compose\.yml/,
922
+ /\.env/,
923
+ ];
924
+ return configPatterns.some((pattern) => pattern.test(filePath));
925
+ }
926
+ classifyModule(relativePath, files) {
927
+ if (relativePath.includes("test") || relativePath.includes("spec")) {
928
+ return "test";
929
+ }
930
+ if (relativePath.includes("docs") ||
931
+ files.some((f) => f.extension === ".md")) {
932
+ return "docs";
933
+ }
934
+ if (files.some((f) => ["package.json", "Dockerfile", "docker-compose.yml"].includes(path.basename(f.relativePath)))) {
935
+ return "infrastructure";
936
+ }
937
+ if (files.some((f) => f.relativePath.includes("config") || f.relativePath.includes(".env"))) {
938
+ return "config";
939
+ }
940
+ return "source";
941
+ }
942
+ findEntryPoint(files) {
943
+ const entryCandidates = [
944
+ "index.ts",
945
+ "index.js",
946
+ "main.ts",
947
+ "main.js",
948
+ "app.ts",
949
+ "app.js",
950
+ ];
951
+ for (const candidate of entryCandidates) {
952
+ const file = files.find((f) => path.basename(f.relativePath) === candidate);
953
+ if (file)
954
+ return file.relativePath;
955
+ }
956
+ // Fallback to first source file
957
+ const sourceFile = files.find((f) => f.isSourceCode);
958
+ return sourceFile?.relativePath;
959
+ }
960
+ hasFramework(fileGraph, framework) {
961
+ for (const file of Array.from(fileGraph.values())) {
962
+ if (file.content?.toLowerCase().includes(framework.toLowerCase())) {
963
+ return true;
964
+ }
965
+ }
966
+ return false;
967
+ }
968
+ detectMVCPattern(fileGraph) {
969
+ const hasControllers = Array.from(fileGraph.keys()).some((path) => path.includes("controller"));
970
+ const hasModels = Array.from(fileGraph.keys()).some((path) => path.includes("model"));
971
+ const hasViews = Array.from(fileGraph.keys()).some((path) => path.includes("view"));
972
+ return hasControllers && hasModels && hasViews;
973
+ }
974
+ detectRepositoryPattern(fileGraph) {
975
+ return Array.from(fileGraph.keys()).some((path) => path.includes("repository"));
976
+ }
977
+ detectObserverPattern(fileGraph) {
978
+ return Array.from(fileGraph.values()).some((file) => file.content?.includes("subscribe") ||
979
+ file.content?.includes("observe"));
980
+ }
981
+ detectFactoryPattern(fileGraph) {
982
+ return Array.from(fileGraph.keys()).some((path) => path.includes("factory"));
983
+ }
984
+ hasMicroservicesIndicators(fileGraph) {
985
+ return Array.from(fileGraph.keys()).some((path) => path.includes("docker") ||
986
+ path.includes("kubernetes") ||
987
+ path.includes("service"));
988
+ }
989
+ isEntryPoint(filePath, fileInfo) {
990
+ const entryIndicators = [
991
+ "index.ts",
992
+ "index.js",
993
+ "main.ts",
994
+ "main.js",
995
+ "app.ts",
996
+ "app.js",
997
+ "server.ts",
998
+ "server.js",
999
+ "cli.ts",
1000
+ "cli.js",
1001
+ ];
1002
+ return (entryIndicators.includes(path.basename(filePath)) ||
1003
+ Boolean(fileInfo.content?.includes("#!/usr/bin/env")) ||
1004
+ Boolean(fileInfo.content?.includes("process.argv")));
1005
+ }
1006
+ detectCircularDependencies(dependencyGraph) {
1007
+ const circularDeps = [];
1008
+ const visited = new Set();
1009
+ const recursionStack = new Set();
1010
+ const dfs = (node) => {
1011
+ visited.add(node);
1012
+ recursionStack.add(node);
1013
+ const dependencies = dependencyGraph.get(node) || new Set();
1014
+ for (const dep of Array.from(dependencies)) {
1015
+ if (!visited.has(dep)) {
1016
+ if (dfs(dep)) {
1017
+ circularDeps.push(`${node} -> ${dep}`);
1018
+ return true;
1019
+ }
1020
+ }
1021
+ else if (recursionStack.has(dep)) {
1022
+ circularDeps.push(`${node} -> ${dep}`);
1023
+ return true;
1024
+ }
1025
+ }
1026
+ recursionStack.delete(node);
1027
+ return false;
1028
+ };
1029
+ for (const node of Array.from(dependencyGraph.keys())) {
1030
+ if (!visited.has(node)) {
1031
+ dfs(node);
1032
+ }
1033
+ }
1034
+ return circularDeps;
1035
+ }
1036
+ }
1037
+ // Export factory function for optimized analyzers
1038
+ export const createCodebaseContextAnalyzer = (projectRoot, memoryConfig) => {
1039
+ return new CodebaseContextAnalyzer(projectRoot, memoryConfig);
1040
+ };