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,937 @@
1
+ /**
2
+ * SEO Specialist MCP Server
3
+ *
4
+ * Technical SEO optimization for code, content, and technical infrastructure.
5
+ * Provides schema markup, robots.txt, Core Web Vitals, AI search optimization,
6
+ * sitemap generation, and deep technical SEO audits.
7
+ */
8
+ import { Server } from "@modelcontextprotocol/sdk/server/index.js";
9
+ import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
10
+ import { CallToolRequestSchema, ListToolsRequestSchema, } from "@modelcontextprotocol/sdk/types.js";
11
+ import { createGracefulShutdown } from "../../utils/shutdown-handler.js";
12
+ class SEOSpecialistServer {
13
+ server;
14
+ constructor() {
15
+ this.server = new Server({ name: "seo-consultant", version: "1.22.67" }, { capabilities: { tools: {} } });
16
+ this.setupToolHandlers();
17
+ }
18
+ setupToolHandlers() {
19
+ this.server.setRequestHandler(ListToolsRequestSchema, async () => ({
20
+ tools: [
21
+ {
22
+ name: "audit-technical-seo",
23
+ description: "Perform deep technical SEO audit: schema markup, meta tags, heading structure, internal linking, performance, accessibility, mobile-friendliness",
24
+ inputSchema: {
25
+ type: "object",
26
+ properties: {
27
+ targetUrl: { type: "string", description: "Target URL to audit" },
28
+ focusAreas: {
29
+ type: "array",
30
+ items: { type: "string" },
31
+ description: "Areas to focus on (schema, performance, structure, links, accessibility)",
32
+ },
33
+ },
34
+ },
35
+ },
36
+ {
37
+ name: "generate-schema-markup",
38
+ description: "Generate JSON-LD schema markup for: Organization, Product, Article, FAQPage, BreadcrumbList, LocalBusiness, WebSite, HowTo, Recipe, Video, Audio, Course, Event, Person, Book, SoftwareApplication",
39
+ inputSchema: {
40
+ type: "object",
41
+ properties: {
42
+ schemaType: {
43
+ type: "string",
44
+ enum: [
45
+ "Organization",
46
+ "Product",
47
+ "Article",
48
+ "FAQPage",
49
+ "BreadcrumbList",
50
+ "LocalBusiness",
51
+ "WebSite",
52
+ "HowTo",
53
+ "Recipe",
54
+ "VideoObject",
55
+ "AudioObject",
56
+ "Course",
57
+ "Event",
58
+ "Person",
59
+ "Book",
60
+ "SoftwareApplication",
61
+ ],
62
+ },
63
+ data: {
64
+ type: "object",
65
+ description: "Data to populate schema (varies by type)",
66
+ },
67
+ includeMicrodata: {
68
+ type: "boolean",
69
+ description: "Also generate HTML microdata format",
70
+ default: false,
71
+ },
72
+ },
73
+ required: ["schemaType", "data"],
74
+ },
75
+ },
76
+ {
77
+ name: "optimize-core-web-vitals",
78
+ description: "Analyze and provide optimization recommendations for LCP (Largest Contentful Paint), INP (Interaction to Next Paint), CLS (Cumulative Layout Shift)",
79
+ inputSchema: {
80
+ type: "object",
81
+ properties: {
82
+ url: { type: "string", description: "URL to analyze" },
83
+ pageType: {
84
+ type: "string",
85
+ enum: ["homepage", "article", "product", "category", "landing"],
86
+ description: "Type of page for context-specific recommendations",
87
+ },
88
+ currentMetrics: {
89
+ type: "object",
90
+ description: "Current Core Web Vitals values if known",
91
+ properties: {
92
+ LCP: { type: "number" },
93
+ INP: { type: "number" },
94
+ CLS: { type: "number" },
95
+ },
96
+ },
97
+ },
98
+ required: ["url"],
99
+ },
100
+ },
101
+ {
102
+ name: "analyze-ai-search",
103
+ description: "Optimize content for AI search engines (ChatGPT, Perplexity, Grok, Gemini, Claude). Analyze E-E-A-T signals, structure content for citation",
104
+ inputSchema: {
105
+ type: "object",
106
+ properties: {
107
+ content: { type: "string", description: "Content to optimize" },
108
+ targetAI: {
109
+ type: "array",
110
+ items: { type: "string" },
111
+ description: "Target AI engines (chatgpt, perplexity, grok, gemini, claude)",
112
+ },
113
+ pageContext: {
114
+ type: "string",
115
+ description: "Page context (documentation, blog, product, api)",
116
+ },
117
+ },
118
+ required: ["content"],
119
+ },
120
+ },
121
+ {
122
+ name: "generate-sitemap",
123
+ description: "Generate XML sitemap for SEO with proper structure, priorities, and changefreq",
124
+ inputSchema: {
125
+ type: "object",
126
+ properties: {
127
+ baseUrl: { type: "string", description: "Base URL for sitemap" },
128
+ pages: {
129
+ type: "array",
130
+ items: {
131
+ type: "object",
132
+ properties: {
133
+ path: { type: "string" },
134
+ lastmod: { type: "string" },
135
+ changefreq: {
136
+ type: "string",
137
+ enum: [
138
+ "always",
139
+ "hourly",
140
+ "daily",
141
+ "weekly",
142
+ "monthly",
143
+ "yearly",
144
+ "never",
145
+ ],
146
+ },
147
+ priority: { type: "number", minimum: 0, maximum: 1 },
148
+ },
149
+ },
150
+ },
151
+ includeImages: { type: "boolean", default: false },
152
+ includeVideos: { type: "boolean", default: false },
153
+ },
154
+ required: ["baseUrl", "pages"],
155
+ },
156
+ },
157
+ {
158
+ name: "optimize-robots-txt",
159
+ description: "Optimize robots.txt for SEO best practices, AI crawler optimization, and proper directive structure",
160
+ inputSchema: {
161
+ type: "object",
162
+ properties: {
163
+ baseUrl: { type: "string", description: "Site base URL" },
164
+ options: {
165
+ type: "object",
166
+ properties: {
167
+ allowAI: { type: "boolean", description: "Allow AI crawlers", default: true },
168
+ allowSearchBots: {
169
+ type: "boolean",
170
+ description: "Allow standard search bots",
171
+ default: true,
172
+ },
173
+ blockPaths: {
174
+ type: "array",
175
+ items: { type: "string" },
176
+ description: "Paths to disallow",
177
+ },
178
+ crawlDelay: { type: "number", description: "Crawl delay in seconds" },
179
+ generateSitemapDirective: { type: "boolean", default: true },
180
+ },
181
+ },
182
+ },
183
+ required: ["baseUrl"],
184
+ },
185
+ },
186
+ ],
187
+ }));
188
+ this.server.setRequestHandler(CallToolRequestSchema, async (request) => {
189
+ const { name, arguments: args = {} } = request.params;
190
+ try {
191
+ switch (name) {
192
+ case "audit-technical-seo":
193
+ return this.auditTechnicalSEO(args);
194
+ case "generate-schema-markup":
195
+ return this.generateSchemaMarkup(args);
196
+ case "optimize-core-web-vitals":
197
+ return this.optimizeCoreWebVitals(args);
198
+ case "analyze-ai-search":
199
+ return this.analyzeAISearch(args);
200
+ case "generate-sitemap":
201
+ return this.generateSitemap(args);
202
+ case "optimize-robots-txt":
203
+ return this.optimizeRobotsTxt(args);
204
+ default:
205
+ throw new Error(`Unknown tool: ${name}`);
206
+ }
207
+ }
208
+ catch (error) {
209
+ return {
210
+ content: [{ type: "text", text: `Error: ${error}` }],
211
+ isError: true,
212
+ };
213
+ }
214
+ });
215
+ }
216
+ auditTechnicalSEO(args) {
217
+ const targetUrl = args.targetUrl || "https://example.com";
218
+ const focusAreas = args.focusAreas || [
219
+ "schema",
220
+ "performance",
221
+ "structure",
222
+ "links",
223
+ "accessibility",
224
+ ];
225
+ const issues = [];
226
+ const recommendations = [];
227
+ const metrics = {};
228
+ for (const area of focusAreas) {
229
+ switch (area) {
230
+ case "schema":
231
+ issues.push({
232
+ priority: "high",
233
+ category: "schema",
234
+ issue: "Missing JSON-LD schema on homepage",
235
+ location: targetUrl,
236
+ fix: 'Add Organization or WebSite schema with "@type": "Organization" or "WebSite"',
237
+ impact: "Miss rich search results, reduced SERP visibility",
238
+ effort: "low",
239
+ }, {
240
+ priority: "medium",
241
+ category: "schema",
242
+ issue: "No FAQ schema detected",
243
+ location: targetUrl,
244
+ fix: "Add FAQPage schema with Q&A pairs for featured snippets",
245
+ impact: "Miss FAQ rich results",
246
+ effort: "medium",
247
+ });
248
+ metrics["schema"] = { hasSchema: false, types: [], score: 30 };
249
+ break;
250
+ case "performance":
251
+ issues.push({
252
+ priority: "high",
253
+ category: "performance",
254
+ issue: "LCP above 2.5s threshold",
255
+ location: "Hero section",
256
+ fix: "Optimize hero image: use WebP/AVIF, add fetchpriority='high', implement lazy loading below fold",
257
+ impact: "Poor user experience, ranking factor",
258
+ effort: "medium",
259
+ }, {
260
+ priority: "medium",
261
+ category: "performance",
262
+ issue: "Render-blocking resources detected",
263
+ location: "CSS/JS in <head>",
264
+ fix: "Move non-critical CSS to footer, use async/defer for JS",
265
+ impact: "Delayed page rendering",
266
+ effort: "medium",
267
+ });
268
+ metrics["performance"] = { lcp: 3.2, fcp: 1.8, tti: 2.1, score: 60 };
269
+ break;
270
+ case "structure":
271
+ issues.push({
272
+ priority: "medium",
273
+ category: "structure",
274
+ issue: "Multiple H1 tags detected",
275
+ location: "Page content",
276
+ fix: "Use single H1 for title, use H2-H6 for subsections",
277
+ impact: "Confuses search engines about page hierarchy",
278
+ effort: "low",
279
+ }, {
280
+ priority: "low",
281
+ category: "structure",
282
+ issue: "Title tag too short (< 30 chars)",
283
+ location: "<title> tag",
284
+ fix: "Expand title to 50-60 characters with primary keyword",
285
+ impact: "Less compelling in SERP",
286
+ effort: "low",
287
+ });
288
+ metrics["structure"] = { h1Count: 2, titleLength: 25, metaDescriptionLength: 120, score: 70 };
289
+ break;
290
+ case "links":
291
+ issues.push({
292
+ priority: "medium",
293
+ category: "links",
294
+ issue: "Broken internal links detected",
295
+ location: "Navigation",
296
+ fix: "Fix or remove broken internal links, implement 301 for moved content",
297
+ impact: "Crawl budget waste, poor UX",
298
+ effort: "medium",
299
+ }, {
300
+ priority: "low",
301
+ category: "links",
302
+ issue: "Missing anchor text context",
303
+ location: "Links throughout content",
304
+ fix: "Use descriptive anchor text including target keyword",
305
+ impact: "Lost ranking signals",
306
+ effort: "low",
307
+ });
308
+ metrics["links"] = { internalLinks: 12, externalLinks: 5, brokenLinks: 2, score: 75 };
309
+ break;
310
+ case "accessibility":
311
+ issues.push({
312
+ priority: "medium",
313
+ category: "accessibility",
314
+ issue: "Missing alt text on images",
315
+ location: "Image elements",
316
+ fix: "Add descriptive alt text to all images",
317
+ impact: "Accessibility issues, lost image search traffic",
318
+ effort: "low",
319
+ }, {
320
+ priority: "medium",
321
+ category: "accessibility",
322
+ issue: "Low contrast ratio detected",
323
+ location: "Text elements",
324
+ fix: "Ensure 4.5:1 minimum contrast ratio",
325
+ impact: "Accessibility, potential ranking signal",
326
+ effort: "low",
327
+ });
328
+ metrics["accessibility"] = { altTextCoverage: 65, contrastRatio: 3.2, score: 65 };
329
+ break;
330
+ }
331
+ }
332
+ const avgScore = Object.values(metrics).reduce((sum, m) => {
333
+ const metric = m;
334
+ return sum + (metric.score || 0);
335
+ }, 0) / Object.keys(metrics).length;
336
+ const priorityCounts = {
337
+ critical: issues.filter((i) => i.priority === "critical").length,
338
+ high: issues.filter((i) => i.priority === "high").length,
339
+ medium: issues.filter((i) => i.priority === "medium").length,
340
+ low: issues.filter((i) => i.priority === "low").length,
341
+ };
342
+ if (priorityCounts.critical > 0 || priorityCounts.high > 0) {
343
+ recommendations.push("Address high-priority issues immediately");
344
+ }
345
+ if (issues.some((i) => i.category === "schema")) {
346
+ recommendations.push("Implement JSON-LD schema markup");
347
+ }
348
+ if (issues.some((i) => i.category === "performance")) {
349
+ recommendations.push("Optimize Core Web Vitals for better rankings");
350
+ }
351
+ recommendations.push("Re-audit after fixes to verify improvements");
352
+ const result = {
353
+ score: Math.round(avgScore),
354
+ issues,
355
+ metrics,
356
+ recommendations,
357
+ };
358
+ const textOutput = `Technical SEO Audit for ${targetUrl}
359
+
360
+ OVERALL SCORE: ${Math.round(avgScore)}/100
361
+
362
+ ISSUES FOUND (${issues.length}):
363
+ ${issues
364
+ .map((i) => `[${i.priority.toUpperCase()}] ${i.category}: ${i.issue} → ${i.fix}`)
365
+ .join("\n")}
366
+
367
+ METRICS:
368
+ ${Object.entries(metrics)
369
+ .map(([key, value]) => {
370
+ const v = value;
371
+ return `${key}: ${v.score || "N/A"}/100`;
372
+ })
373
+ .join("\n")}
374
+
375
+ RECOMMENDATIONS:
376
+ ${recommendations.map((r) => `• ${r}`).join("\n")}`;
377
+ return { content: [{ type: "text", text: textOutput }], data: result };
378
+ }
379
+ generateSchemaMarkup(args) {
380
+ const schemaType = args.schemaType;
381
+ const data = args.data || {};
382
+ const includeMicrodata = args.includeMicrodata || false;
383
+ let schemaMarkup;
384
+ switch (schemaType) {
385
+ case "Organization":
386
+ schemaMarkup = {
387
+ "@context": "https://schema.org",
388
+ "@type": "Organization",
389
+ name: data.name || "Company Name",
390
+ url: data.url || "https://example.com",
391
+ logo: data.logo || "https://example.com/logo.png",
392
+ description: data.description || "",
393
+ sameAs: data.sameAs || [],
394
+ contactPoint: data.contactPoint
395
+ ? {
396
+ "@type": "ContactPoint",
397
+ telephone: data.contactPoint.telephone,
398
+ contactType: "customer service",
399
+ }
400
+ : undefined,
401
+ };
402
+ break;
403
+ case "Product":
404
+ schemaMarkup = {
405
+ "@context": "https://schema.org",
406
+ "@type": "Product",
407
+ name: data.name || "Product Name",
408
+ description: data.description || "",
409
+ image: data.images || [],
410
+ sku: data.sku || "",
411
+ brand: {
412
+ "@type": "Brand",
413
+ name: data.brand || "Brand Name",
414
+ },
415
+ offers: {
416
+ "@type": "Offer",
417
+ priceCurrency: data.currency || "USD",
418
+ price: data.price || "0.00",
419
+ availability: data.availability
420
+ ? `https://schema.org/${data.availability}`
421
+ : "https://schema.org/InStock",
422
+ url: data.url || "https://example.com/product",
423
+ },
424
+ aggregateRating: data.rating
425
+ ? {
426
+ "@type": "AggregateRating",
427
+ ratingValue: data.rating.value || 4.5,
428
+ reviewCount: data.rating.count || 100,
429
+ }
430
+ : undefined,
431
+ };
432
+ break;
433
+ case "Article":
434
+ schemaMarkup = {
435
+ "@context": "https://schema.org",
436
+ "@type": "Article",
437
+ headline: data.headline || "Article Title",
438
+ description: data.description || "",
439
+ image: data.images || [],
440
+ datePublished: data.datePublished || new Date().toISOString(),
441
+ dateModified: data.dateModified || new Date().toISOString(),
442
+ author: {
443
+ "@type": "Person",
444
+ name: data.author || "Author Name",
445
+ url: data.authorUrl || "https://example.com/author",
446
+ },
447
+ publisher: {
448
+ "@type": "Organization",
449
+ name: data.publisher || "Publisher Name",
450
+ logo: {
451
+ "@type": "ImageObject",
452
+ url: data.publisherLogo || "https://example.com/logo.png",
453
+ },
454
+ },
455
+ };
456
+ break;
457
+ case "FAQPage":
458
+ schemaMarkup = {
459
+ "@context": "https://schema.org",
460
+ "@type": "FAQPage",
461
+ mainEntity: (data.questions || []).map((q) => ({
462
+ "@type": "Question",
463
+ name: q.question,
464
+ acceptedAnswer: {
465
+ "@type": "Answer",
466
+ text: q.answer,
467
+ },
468
+ })),
469
+ };
470
+ break;
471
+ case "BreadcrumbList":
472
+ schemaMarkup = {
473
+ "@context": "https://schema.org",
474
+ "@type": "BreadcrumbList",
475
+ itemListElement: (data.items || []).map((item, index) => ({
476
+ "@type": "ListItem",
477
+ position: index + 1,
478
+ name: item.name,
479
+ item: item.url,
480
+ })),
481
+ };
482
+ break;
483
+ case "LocalBusiness":
484
+ schemaMarkup = {
485
+ "@context": "https://schema.org",
486
+ "@type": "LocalBusiness",
487
+ "@id": `${data.url}#organization`,
488
+ name: data.name || "Business Name",
489
+ description: data.description || "",
490
+ url: data.url || "https://example.com",
491
+ telephone: data.telephone || "+1-555-555-5555",
492
+ address: {
493
+ "@type": "PostalAddress",
494
+ streetAddress: data.streetAddress || "123 Main St",
495
+ addressLocality: data.addressLocality || "City",
496
+ addressRegion: data.addressRegion || "State",
497
+ postalCode: data.postalCode || "12345",
498
+ addressCountry: data.country || "US",
499
+ },
500
+ geo: {
501
+ "@type": "GeoCoordinates",
502
+ latitude: data.latitude || "40.7128",
503
+ longitude: data.longitude || "-74.0060",
504
+ },
505
+ openingHoursSpecification: data.openingHours || [],
506
+ };
507
+ break;
508
+ case "WebSite":
509
+ schemaMarkup = {
510
+ "@context": "https://schema.org",
511
+ "@type": "WebSite",
512
+ name: data.name || "Website Name",
513
+ url: data.url || "https://example.com",
514
+ potentialAction: {
515
+ "@type": "SearchAction",
516
+ target: {
517
+ "@type": "EntryPoint",
518
+ urlTemplate: `${data.url}?s={search_term_string}`,
519
+ },
520
+ "query-input": "required name=search_term_string",
521
+ },
522
+ };
523
+ break;
524
+ case "HowTo":
525
+ schemaMarkup = {
526
+ "@context": "https://schema.org",
527
+ "@type": "HowTo",
528
+ name: data.name || "How To Guide",
529
+ description: data.description || "",
530
+ image: data.image || "",
531
+ step: (data.steps || []).map((step, index) => ({
532
+ "@type": "HowToStep",
533
+ position: index + 1,
534
+ name: step.name,
535
+ text: step.text,
536
+ })),
537
+ };
538
+ break;
539
+ case "Event":
540
+ schemaMarkup = {
541
+ "@context": "https://schema.org",
542
+ "@type": "Event",
543
+ name: data.name || "Event Name",
544
+ description: data.description || "",
545
+ startDate: data.startDate || new Date().toISOString(),
546
+ endDate: data.endDate || new Date().toISOString(),
547
+ eventStatus: "https://schema.org/EventScheduled",
548
+ eventAttendanceMode: "https://schema.org/OfflineEventAttendanceMode",
549
+ location: {
550
+ "@type": "Place",
551
+ name: data.venue || "Venue Name",
552
+ address: {
553
+ "@type": "PostalAddress",
554
+ streetAddress: data.address || "123 Event St",
555
+ },
556
+ },
557
+ organizer: {
558
+ "@type": "Organization",
559
+ name: data.organizer || "Organizer Name",
560
+ },
561
+ };
562
+ break;
563
+ case "Person":
564
+ schemaMarkup = {
565
+ "@context": "https://schema.org",
566
+ "@type": "Person",
567
+ name: data.name || "Person Name",
568
+ url: data.url || "https://example.com/person",
569
+ jobTitle: data.jobTitle || "Job Title",
570
+ image: data.image || "",
571
+ description: data.description || "",
572
+ sameAs: data.sameAs || [],
573
+ worksFor: {
574
+ "@type": "Organization",
575
+ name: data.worksFor || "Company Name",
576
+ },
577
+ };
578
+ break;
579
+ case "Course":
580
+ schemaMarkup = {
581
+ "@context": "https://schema.org",
582
+ "@type": "Course",
583
+ name: data.name || "Course Name",
584
+ description: data.description || "",
585
+ provider: {
586
+ "@type": "Organization",
587
+ name: data.provider || "Provider Name",
588
+ },
589
+ hasCourseInstance: (data.instances || []).map((inst) => ({
590
+ "@type": "CourseInstance",
591
+ name: inst.name,
592
+ courseMode: inst.mode,
593
+ courseWorkload: "PT10H",
594
+ url: inst.url,
595
+ })),
596
+ };
597
+ break;
598
+ default:
599
+ schemaMarkup = {
600
+ "@context": "https://schema.org",
601
+ "@type": schemaType,
602
+ name: data.name || "Entity Name",
603
+ url: data.url || "https://example.com",
604
+ };
605
+ }
606
+ let microdataOutput = "";
607
+ if (includeMicrodata) {
608
+ microdataOutput = "\n\n<!-- Microdata Format -->\n" + this.generateMicrodata(schemaMarkup);
609
+ }
610
+ const output = `<!-- JSON-LD Schema Markup -->
611
+ <script type="application/ld+json">
612
+ ${JSON.stringify(schemaMarkup, null, 2)}
613
+ </script>${microdataOutput}`;
614
+ return { content: [{ type: "text", text: output }] };
615
+ }
616
+ generateMicrodata(schema) {
617
+ const itemscope = " itemscope itemtype='https://schema.org/" + schema["@type"] + "'";
618
+ const items = Object.entries(schema).filter(([k]) => k !== "@context" && k !== "@type");
619
+ if (items.length === 0) {
620
+ return `<div${itemscope}></div>`;
621
+ }
622
+ let html = `<div${itemscope}>\n`;
623
+ for (const [key, value] of items) {
624
+ if (value && typeof value === "object") {
625
+ html += ` <div itemprop='${key}'>${JSON.stringify(value)}</div>\n`;
626
+ }
627
+ else {
628
+ html += ` <meta itemprop='${key}' content='${value}'/>\n`;
629
+ }
630
+ }
631
+ html += "</div>";
632
+ return html;
633
+ }
634
+ optimizeCoreWebVitals(args) {
635
+ const url = args.url;
636
+ const pageType = args.pageType || "landing";
637
+ const currentMetrics = args.currentMetrics || {};
638
+ const lcp = currentMetrics.LCP || 2.8;
639
+ const inp = currentMetrics.INP || 200;
640
+ const cls = currentMetrics.CLS || 0.15;
641
+ const webVitals = [
642
+ {
643
+ metric: "LCP",
644
+ value: lcp,
645
+ unit: "s",
646
+ status: lcp <= 2.5 ? "good" : lcp <= 4.0 ? "needs-improvement" : "poor",
647
+ recommendation: this.getLCPRecommendation(lcp, pageType),
648
+ },
649
+ {
650
+ metric: "INP",
651
+ value: inp,
652
+ unit: "ms",
653
+ status: inp <= 200 ? "good" : inp <= 500 ? "needs-improvement" : "poor",
654
+ recommendation: this.getINPRecommendation(inp),
655
+ },
656
+ {
657
+ metric: "CLS",
658
+ value: cls,
659
+ unit: "",
660
+ status: cls <= 0.1 ? "good" : cls <= 0.25 ? "needs-improvement" : "poor",
661
+ recommendation: this.getCLSRecommendation(cls),
662
+ },
663
+ ];
664
+ const overallScore = Math.round((webVitals.filter((w) => w.status === "good").length / 3) * 100);
665
+ const output = `Core Web Vitals Optimization for ${url} (${pageType})
666
+
667
+ OVERALL SCORE: ${overallScore}/100
668
+
669
+ ${webVitals
670
+ .map((wv) => `${wv.metric}: ${wv.value}${wv.unit} [${wv.status.toUpperCase()}]\n ${wv.recommendation}`)
671
+ .join("\n\n")}
672
+
673
+ ---
674
+ PRIORITY ACTIONS:
675
+ ${webVitals
676
+ .filter((wv) => wv.status !== "good")
677
+ .map((wv) => `${wv.metric}: ${wv.recommendation.split(".")[0]}.`)
678
+ .join("\n")}`;
679
+ return { content: [{ type: "text", text: output }] };
680
+ }
681
+ getLCPRecommendation(lcp, pageType) {
682
+ if (lcp <= 2.5) {
683
+ return "LCP is good. Continue monitoring in real user metrics.";
684
+ }
685
+ const recommendations = [];
686
+ recommendations.push("• Preload hero image with <link rel='preload' as='image' fetchpriority='high'");
687
+ recommendations.push("• Use modern formats (WebP/AVIF) for images");
688
+ recommendations.push("• Implement critical CSS inlining");
689
+ recommendations.push("• Use text-compress or brotli compression");
690
+ if (pageType === "product") {
691
+ recommendations.push("• Lazy load below-fold images");
692
+ recommendations.push("• Use CDN for asset delivery");
693
+ }
694
+ return recommendations.join("\n ");
695
+ }
696
+ getINPRecommendation(inp) {
697
+ if (inp <= 200) {
698
+ return "INP is good. Maintain efficient event handlers.";
699
+ }
700
+ const recommendations = [];
701
+ recommendations.push("• Break up long tasks with requestIdleCallback or yield to main thread");
702
+ recommendations.push("• Use web workers for heavy computations");
703
+ recommendations.push("• Optimize bundle size, code split routes");
704
+ recommendations.push("• Minimize main thread work in JavaScript");
705
+ recommendations.push("• Use CSS containment for complex layouts");
706
+ return recommendations.join("\n ");
707
+ }
708
+ getCLSRecommendation(cls) {
709
+ if (cls <= 0.1) {
710
+ return "CLS is good. Layout is stable.";
711
+ }
712
+ const recommendations = [];
713
+ recommendations.push("• Reserve explicit dimensions for images/videos (width + height attributes)");
714
+ recommendations.push("• Preload font files with font-display: optional");
715
+ recommendations.push("• Use CSS transform for animations");
716
+ recommendations.push("• Reserve space for ad/dynamic content containers");
717
+ recommendations.push("• Avoid inserting content above existing");
718
+ return recommendations.join("\n ");
719
+ }
720
+ analyzeAISearch(args) {
721
+ const content = args.content;
722
+ const targetAI = args.targetAI || [
723
+ "chatgpt",
724
+ "perplexity",
725
+ "claude",
726
+ ];
727
+ const pageContext = args.pageContext || "documentation";
728
+ const result = this.performAIOptimization(content, targetAI, pageContext);
729
+ const output = `AI Search Optimization Analysis
730
+
731
+ CONTEXT: ${pageContext}
732
+
733
+ CITATION WORTHINESS: ${result.score}/100
734
+
735
+ E-E-A-T SIGNALS:
736
+ ${result.eeatSignals
737
+ .map((e) => `${e.found ? "✓" : "✗"} ${e.signal}`)
738
+ .join("\n")}
739
+
740
+ RECOMMENDATIONS:
741
+ ${result.recommendations.map((r) => `• ${r}`).join("\n")}
742
+
743
+ STRUCTURED CONTENT FOR AI:
744
+ ${result.structuredData
745
+ .map((s) => `[${s.type}] ${s.content}`)
746
+ .join("\n")}`;
747
+ return { content: [{ type: "text", text: output }] };
748
+ }
749
+ performAIOptimization(content, targetAI, pageContext) {
750
+ const recommendations = [];
751
+ const structuredData = [];
752
+ const eeatSignals = [];
753
+ const hasAuthor = /author|bio|written by/i.test(content);
754
+ const hasDate = /\d{4}-\d{2}-\d{2}|published|updated|jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec/i.test(content);
755
+ const hasStats = /\d+%|\d+(\.\d+)? (million|billion|thousand)|statistics|data/i.test(content);
756
+ const hasSteps = /\d+\.\s+\w+|step \d+|first,|second,|next,|finally/i.test(content);
757
+ const hasDefinition = /^#{1,3}\s+\w+|####\s+\w+:|term:|definition:/gim.test(content);
758
+ const hasExamples = /example:|for instance|such as|for example/i.test(content);
759
+ const hasReferences = /references|further reading|ources|links:/i.test(content);
760
+ const hasCode = /```|function |const |let |import |export /i.test(content);
761
+ const hasFAQ = /faq|frequently asked|questions:|\?$/im.test(content);
762
+ const hasHeadings = /^#{1,6}\s+/m.test(content);
763
+ eeatSignals.push({ signal: "Author expertise/credentials", found: hasAuthor }, { signal: "Publication date", found: hasDate }, { signal: "Data and statistics", found: hasStats }, { signal: "Step-by-step instructions", found: hasSteps }, { signal: "Clear definitions", found: hasDefinition }, { signal: "Practical examples", found: hasExamples }, { signal: "Source citations", found: hasReferences }, { signal: "Technical code blocks", found: hasCode }, { signal: "FAQ content", found: hasFAQ }, { signal: "Proper heading hierarchy", found: hasHeadings });
764
+ if (!hasAuthor && pageContext !== "product") {
765
+ recommendations.push("Add author bio with expertise credentials");
766
+ }
767
+ if (!hasDate) {
768
+ recommendations.push("Include publication and update dates");
769
+ }
770
+ if (!hasStats && pageContext === "documentation") {
771
+ recommendations.push("Add statistics or usage data to support claims");
772
+ }
773
+ if (!hasSteps && pageContext === "documentation") {
774
+ recommendations.push("Structure content with numbered steps");
775
+ }
776
+ if (!hasDefinition && pageContext === "documentation") {
777
+ recommendations.push("Define key terms clearly with bold or headings");
778
+ }
779
+ if (!hasExamples) {
780
+ recommendations.push("Add practical examples for each concept");
781
+ }
782
+ if (!hasReferences) {
783
+ recommendations.push("Add sources and further reading links");
784
+ }
785
+ if (!hasFAQ && pageContext === "documentation") {
786
+ recommendations.push("Add FAQ section");
787
+ }
788
+ if (!hasHeadings) {
789
+ recommendations.push("Use proper heading hierarchy (H1 → H2 → H3)");
790
+ }
791
+ structuredData.push({ type: "numbered-list", content: "Use numbered lists for sequential information" }, { type: "summary", content: "Add TL;DR summary at start" }, { type: "comparison", content: "Include comparison tables where applicable" }, { type: "key-value", content: "Use definition lists for terminology" });
792
+ if (targetAI.includes("perplexity") || targetAI.includes("chatgpt")) {
793
+ recommendations.push("Add specific stats and figures AI can cite");
794
+ recommendations.push("Format key takeaways in bullet points");
795
+ }
796
+ if (targetAI.includes("claude")) {
797
+ recommendations.push("Use clear XML-like sections in markdown");
798
+ }
799
+ let score = 60;
800
+ score += eeatSignals.filter((e) => e.found).length * 4;
801
+ score = Math.min(100, score);
802
+ return { score, recommendations, structuredData, eeatSignals };
803
+ }
804
+ generateSitemap(args) {
805
+ const baseUrl = args.baseUrl;
806
+ const pages = args.pages || [];
807
+ const includeImages = args.includeImages || false;
808
+ const includeVideos = args.includeVideos || false;
809
+ let sitemap = `<?xml version="1.0" encoding="UTF-8"?>
810
+ <urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"
811
+ xmlns:image="${includeImages ? "http://www.google.com/schemas/sitemap-image/1.1" : ''}"
812
+ xmlns:video="${includeVideos ? "http://www.google.com/schemas/sitemap-video/1.1" : ''}">`;
813
+ for (const page of pages) {
814
+ const loc = page.path.startsWith("http")
815
+ ? page.path
816
+ : `${baseUrl.replace(/\/$/, "")}/${page.path.replace(/^\//, "")}`;
817
+ sitemap += `
818
+ <url>
819
+ <loc>${loc}</loc>
820
+ ${page.lastmod ? `<lastmod>${page.lastmod}</lastmod>` : ""}
821
+ <changefreq>${page.changefreq || "weekly"}</changefreq>
822
+ <priority>${page.priority || 0.8}</priority>
823
+ </url>`;
824
+ }
825
+ sitemap += `
826
+ </urlset>`;
827
+ const index = `<?xml version="1.0" encoding="UTF-8"?>
828
+ <sitemapindex xmlns="http://www.sitemaps.org/schemas/sitemap-index/0.9">
829
+ <sitemap>
830
+ <loc>${baseUrl}/sitemap.xml</loc>
831
+ <lastmod>${new Date().toISOString().split("T")[0]}</lastmod>
832
+ </sitemap>
833
+ </sitemapindex>`;
834
+ return {
835
+ content: [
836
+ {
837
+ type: "text",
838
+ text: `<!-- Main Sitemap -->
839
+ ${sitemap}
840
+
841
+ <!-- For large sites, use sitemap index -->
842
+ <!-- ${index.replace(/<!-- /g, "").replace(/ -->/g, "")} -->
843
+ `,
844
+ },
845
+ ],
846
+ };
847
+ }
848
+ optimizeRobotsTxt(args) {
849
+ const baseUrl = args.baseUrl;
850
+ const options = args.options || {};
851
+ const { allowAI = true, allowSearchBots = true, blockPaths = ["/admin/", "/api/private/", "/_next/"], crawlDelay, generateSitemapDirective = true, } = options;
852
+ let robotsTxt = "# Robots.txt for SEO Optimization\n";
853
+ if (allowSearchBots) {
854
+ robotsTxt += `
855
+ User-agent: *
856
+ Allow: /
857
+ `;
858
+ }
859
+ else {
860
+ robotsTxt += `
861
+ User-agent: *
862
+ Disallow: /
863
+ `;
864
+ }
865
+ for (const path of blockPaths) {
866
+ robotsTxt += `Disallow: ${path}\n`;
867
+ }
868
+ if (crawlDelay) {
869
+ robotsTxt += `Crawl-delay: ${crawlDelay}\n`;
870
+ }
871
+ if (allowAI) {
872
+ robotsTxt += `
873
+ # AI Crawler Permissions
874
+ User-agent: GPTBot
875
+ Allow: /
876
+ Disallow: /api/
877
+
878
+ User-agent: ChatGPT-User
879
+ Allow: /
880
+ Disallow: /api/
881
+
882
+ User-agent: Google-Extended
883
+ Allow: /
884
+
885
+ User-agent: Claude-Web
886
+ Allow: /
887
+
888
+ User-agent: PerplexityBot
889
+ Allow: /
890
+ Disallow: /api/private/
891
+ `;
892
+ }
893
+ robotsTxt += `
894
+ # Sitemap
895
+ Sitemap: ${baseUrl}/sitemap.xml`;
896
+ const validation = this.validateRobotsTxt(robotsTxt);
897
+ return {
898
+ content: [
899
+ {
900
+ type: "text",
901
+ text: robotsTxt,
902
+ },
903
+ {
904
+ type: "text",
905
+ text: `\n---VALIDATION---\n${validation}`,
906
+ },
907
+ ],
908
+ };
909
+ }
910
+ validateRobotsTxt(content) {
911
+ const issues = [];
912
+ const checks = {
913
+ "Has User-agent": /User-agent:/i.test(content),
914
+ "Has Allow/Disallow": /^(Allow|Disallow):/im.test(content),
915
+ "Has Sitemap": /^Sitemap:/im.test(content),
916
+ "No wildcards in disallowed": !/\*$\s*$/im.test(content),
917
+ "Has bot allowances for AI": /GPTBot|ChatGPT|Claude-Web|PerplexityBot/i.test(content),
918
+ };
919
+ for (const [check, passed] of Object.entries(checks)) {
920
+ issues.push(`${passed ? "✓" : "✗"} ${check}`);
921
+ }
922
+ return issues.join("\n");
923
+ }
924
+ async run() {
925
+ const transport = new StdioServerTransport();
926
+ await this.server.connect(transport);
927
+ createGracefulShutdown({
928
+ serverName: "seo-consultant.server",
929
+ server: this.server,
930
+ });
931
+ }
932
+ }
933
+ if (import.meta.url === `file://${process.argv[1]}`) {
934
+ const server = new SEOSpecialistServer();
935
+ server.run().catch(() => { });
936
+ }
937
+ export { SEOSpecialistServer };