0xray 2.1.2 → 2.1.3

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 (250) hide show
  1. package/.opencode/codex.codex +1 -1
  2. package/.opencode/commands/dependency-audit.md +3 -3
  3. package/.opencode/enforcer-config.json +2 -2
  4. package/AGENTS.md +2 -1
  5. package/README.md +12 -11
  6. package/dist/AGENTS.md +2 -1
  7. package/dist/CHANGELOG.md +26 -0
  8. package/dist/README.md +12 -11
  9. package/dist/agents/code-reviewer.js +1 -1
  10. package/dist/analytics/routing-refiner.js +1 -1
  11. package/dist/cli/index.js +11 -1
  12. package/dist/cli/server.js +3 -3
  13. package/dist/core/activity-logger.d.ts +2 -2
  14. package/dist/core/activity-logger.js +4 -4
  15. package/dist/core/boot-orchestrator.d.ts +1 -1
  16. package/dist/core/boot-orchestrator.js +13 -28
  17. package/dist/core/bridge.mjs +3 -3
  18. package/dist/core/codex-formatter.js +2 -2
  19. package/dist/core/codex-injector.d.ts +0 -1
  20. package/dist/core/codex-injector.js +2 -3
  21. package/dist/core/config-loader.d.ts +1 -1
  22. package/dist/core/config-loader.js +1 -1
  23. package/dist/core/config-paths.d.ts +0 -2
  24. package/dist/core/config-paths.js +7 -8
  25. package/dist/core/context-loader.d.ts +1 -1
  26. package/dist/core/context-loader.js +1 -1
  27. package/dist/core/errors.d.ts +3 -0
  28. package/dist/core/errors.js +10 -0
  29. package/dist/core/features-config.js +1 -1
  30. package/dist/core/framework-logger.d.ts +3 -3
  31. package/dist/core/framework-logger.js +17 -9
  32. package/dist/core/index.d.ts +2 -2
  33. package/dist/core/index.js +4 -2
  34. package/dist/core/logging-config.d.ts +2 -1
  35. package/dist/core/logging-config.js +7 -7
  36. package/dist/enforcement/loaders/codex-loader.js +1 -1
  37. package/dist/execution/opencode-cli-invoker.js +5 -5
  38. package/dist/governance/governance-service.js +1 -1
  39. package/dist/index.d.ts +3 -3
  40. package/dist/index.js +3 -3
  41. package/dist/inference/inference-cycle.d.ts +1 -1
  42. package/dist/inference/inference-cycle.js +10 -10
  43. package/dist/integrations/base/Integration.js +1 -1
  44. package/dist/integrations/base/registry.js +19 -19
  45. package/dist/integrations/grok/grok-cli.js +17 -17
  46. package/dist/integrations/grok/hooks/pre-tool-use.js +1 -1
  47. package/dist/integrations/hermes-agent/bridge.mjs +1 -1
  48. package/dist/integrations/openclaw/api-server.d.ts +0 -1
  49. package/dist/integrations/openclaw/api-server.js +7 -10
  50. package/dist/integrations/openclaw/client.d.ts +0 -1
  51. package/dist/integrations/openclaw/client.js +22 -24
  52. package/dist/integrations/openclaw/hooks/xray-hooks.d.ts +0 -1
  53. package/dist/integrations/openclaw/hooks/xray-hooks.js +17 -18
  54. package/dist/integrations/plugins/plugin-registry.js +5 -5
  55. package/dist/mcps/architect-tools.server.d.ts +2 -4
  56. package/dist/mcps/architect-tools.server.js +112 -195
  57. package/dist/mcps/auto-format.server.d.ts +2 -4
  58. package/dist/mcps/auto-format.server.js +49 -95
  59. package/dist/mcps/boot-orchestrator.server.d.ts +2 -4
  60. package/dist/mcps/boot-orchestrator.server.js +73 -105
  61. package/dist/mcps/config/server-config-registry.js +3 -3
  62. package/dist/mcps/enforcer-tools.server.d.ts +2 -4
  63. package/dist/mcps/enforcer-tools.server.js +202 -285
  64. package/dist/mcps/estimation.server.d.ts +2 -4
  65. package/dist/mcps/estimation.server.js +63 -107
  66. package/dist/mcps/framework-compliance-audit.server.d.ts +2 -4
  67. package/dist/mcps/framework-compliance-audit.server.js +53 -82
  68. package/dist/mcps/framework-help.server.d.ts +2 -4
  69. package/dist/mcps/framework-help.server.js +63 -101
  70. package/dist/mcps/governance.server.js +2 -2
  71. package/dist/mcps/knowledge-skills/api-design.server.d.ts +2 -4
  72. package/dist/mcps/knowledge-skills/api-design.server.js +35 -67
  73. package/dist/mcps/knowledge-skills/architecture-patterns.server.d.ts +2 -10
  74. package/dist/mcps/knowledge-skills/architecture-patterns.server.js +35 -74
  75. package/dist/mcps/knowledge-skills/bug-triage-specialist.server.d.ts +2 -4
  76. package/dist/mcps/knowledge-skills/bug-triage-specialist.server.js +143 -162
  77. package/dist/mcps/knowledge-skills/code-analyzer.server.d.ts +3 -4
  78. package/dist/mcps/knowledge-skills/code-analyzer.server.js +20 -45
  79. package/dist/mcps/knowledge-skills/code-review.server.d.ts +2 -4
  80. package/dist/mcps/knowledge-skills/code-review.server.js +109 -143
  81. package/dist/mcps/knowledge-skills/content-creator.server.d.ts +2 -4
  82. package/dist/mcps/knowledge-skills/content-creator.server.js +205 -226
  83. package/dist/mcps/knowledge-skills/database-design.server.d.ts +2 -4
  84. package/dist/mcps/knowledge-skills/database-design.server.js +117 -151
  85. package/dist/mcps/knowledge-skills/devops-deployment.server.d.ts +2 -4
  86. package/dist/mcps/knowledge-skills/devops-deployment.server.js +71 -160
  87. package/dist/mcps/knowledge-skills/git-workflow.server.d.ts +2 -4
  88. package/dist/mcps/knowledge-skills/git-workflow.server.js +36 -68
  89. package/dist/mcps/knowledge-skills/growth-strategist.server.d.ts +2 -4
  90. package/dist/mcps/knowledge-skills/growth-strategist.server.js +303 -324
  91. package/dist/mcps/knowledge-skills/log-monitor.server.d.ts +2 -4
  92. package/dist/mcps/knowledge-skills/log-monitor.server.js +141 -160
  93. package/dist/mcps/knowledge-skills/mobile-development.server.d.ts +2 -4
  94. package/dist/mcps/knowledge-skills/mobile-development.server.js +92 -209
  95. package/dist/mcps/knowledge-skills/multimodal-looker.server.d.ts +2 -4
  96. package/dist/mcps/knowledge-skills/multimodal-looker.server.js +123 -159
  97. package/dist/mcps/knowledge-skills/performance-optimization.server.d.ts +2 -5
  98. package/dist/mcps/knowledge-skills/performance-optimization.server.js +155 -296
  99. package/dist/mcps/knowledge-skills/project-analysis.server.d.ts +2 -4
  100. package/dist/mcps/knowledge-skills/project-analysis.server.js +75 -226
  101. package/dist/mcps/knowledge-skills/refactoring-strategies.server.d.ts +2 -4
  102. package/dist/mcps/knowledge-skills/refactoring-strategies.server.js +63 -156
  103. package/dist/mcps/knowledge-skills/security-audit.server.d.ts +2 -4
  104. package/dist/mcps/knowledge-skills/security-audit.server.js +102 -136
  105. package/dist/mcps/knowledge-skills/seo-consultant.server.d.ts +2 -4
  106. package/dist/mcps/knowledge-skills/seo-consultant.server.js +80 -203
  107. package/dist/mcps/knowledge-skills/session-management.server.d.ts +2 -4
  108. package/dist/mcps/knowledge-skills/session-management.server.js +50 -203
  109. package/dist/mcps/knowledge-skills/skill-invocation.server.d.ts +2 -4
  110. package/dist/mcps/knowledge-skills/skill-invocation.server.js +168 -347
  111. package/dist/mcps/knowledge-skills/strategist.server.d.ts +2 -11
  112. package/dist/mcps/knowledge-skills/strategist.server.js +72 -122
  113. package/dist/mcps/knowledge-skills/tech-writer.server.d.ts +2 -4
  114. package/dist/mcps/knowledge-skills/tech-writer.server.js +87 -300
  115. package/dist/mcps/knowledge-skills/testing-best-practices.server.d.ts +2 -4
  116. package/dist/mcps/knowledge-skills/testing-best-practices.server.js +147 -182
  117. package/dist/mcps/knowledge-skills/testing-strategy.server.d.ts +2 -4
  118. package/dist/mcps/knowledge-skills/testing-strategy.server.js +78 -153
  119. package/dist/mcps/knowledge-skills/ui-ux-design.server.d.ts +2 -5
  120. package/dist/mcps/knowledge-skills/ui-ux-design.server.js +90 -399
  121. package/dist/mcps/lint.server.d.ts +2 -4
  122. package/dist/mcps/lint.server.js +51 -92
  123. package/dist/mcps/mcp-client.js +2 -2
  124. package/dist/mcps/model-health-check.server.d.ts +2 -4
  125. package/dist/mcps/model-health-check.server.js +32 -60
  126. package/dist/mcps/performance-analysis.server.d.ts +2 -4
  127. package/dist/mcps/performance-analysis.server.js +57 -88
  128. package/dist/mcps/processor-pipeline.server.d.ts +2 -4
  129. package/dist/mcps/processor-pipeline.server.js +69 -100
  130. package/dist/mcps/registry.json +1 -1
  131. package/dist/mcps/researcher.server.d.ts +3 -5
  132. package/dist/mcps/researcher.server.js +81 -154
  133. package/dist/mcps/security-scan.server.d.ts +2 -4
  134. package/dist/mcps/security-scan.server.js +54 -96
  135. package/dist/mcps/shared/knowledge-skill-base.d.ts +14 -0
  136. package/dist/mcps/shared/knowledge-skill-base.js +45 -0
  137. package/dist/{security → mcps/shared}/security-scanner.js +1 -1
  138. package/dist/mcps/state-manager.server.d.ts +2 -4
  139. package/dist/mcps/state-manager.server.js +115 -160
  140. package/dist/orchestrator/orchestrator.d.ts +1 -1
  141. package/dist/orchestrator/orchestrator.js +1 -1
  142. package/dist/orchestrator/universal-registry-bridge.js +1 -1
  143. package/dist/plugin/xray-codex-injection.d.ts +1 -1
  144. package/dist/plugin/xray-codex-injection.js +1 -1
  145. package/dist/postprocessor/PostProcessor.d.ts +4 -44
  146. package/dist/postprocessor/PostProcessor.js +39 -553
  147. package/dist/postprocessor/analysis/CodeChangeAnalyzer.d.ts +11 -0
  148. package/dist/postprocessor/analysis/CodeChangeAnalyzer.js +50 -0
  149. package/dist/postprocessor/compliance/ArchitecturalComplianceChecker.d.ts +11 -0
  150. package/dist/postprocessor/compliance/ArchitecturalComplianceChecker.js +356 -0
  151. package/dist/postprocessor/config/ProcessorConfigLoader.d.ts +44 -0
  152. package/dist/postprocessor/config/ProcessorConfigLoader.js +21 -0
  153. package/dist/postprocessor/reporting/PostProcessorReporter.d.ts +19 -0
  154. package/dist/postprocessor/reporting/PostProcessorReporter.js +96 -0
  155. package/dist/postprocessor/triggers/GitHookTrigger.js +11 -11
  156. package/dist/processors/implementations/refactoring-logging-processor-wrapper.d.ts +32 -0
  157. package/dist/processors/implementations/refactoring-logging-processor-wrapper.js +95 -1
  158. package/dist/processors/processor-manager.js +346 -314
  159. package/dist/reporting/report-formatter.js +1 -1
  160. package/dist/security/security-hardener.d.ts +69 -2
  161. package/dist/security/security-hardener.js +129 -1
  162. package/dist/skills/registry.json +1 -1
  163. package/dist/state/index.d.ts +3 -5
  164. package/dist/state/index.js +1 -7
  165. package/dist/state/state-manager.d.ts +1 -1
  166. package/dist/state/state-manager.js +2 -3
  167. package/package.json +13 -10
  168. package/scripts/node/universal-version-manager.js +11 -11
  169. package/src/mcps/architect-tools.server.ts +112 -215
  170. package/src/mcps/auto-format.server.ts +50 -110
  171. package/src/mcps/boot-orchestrator.server.ts +75 -121
  172. package/src/mcps/config/__tests__/server-config-registry.test.ts +21 -12
  173. package/src/mcps/config/server-config-registry.ts +3 -3
  174. package/src/mcps/enforcer-tools.server.ts +212 -310
  175. package/src/mcps/estimation.server.ts +62 -122
  176. package/src/mcps/framework-compliance-audit.server.ts +52 -97
  177. package/src/mcps/framework-help.server.ts +64 -114
  178. package/src/mcps/governance.server.ts +2 -2
  179. package/src/mcps/knowledge-skills/api-design.server.ts +32 -77
  180. package/src/mcps/knowledge-skills/architecture-patterns.server.ts +31 -87
  181. package/src/mcps/knowledge-skills/bug-triage-specialist.server.ts +165 -193
  182. package/src/mcps/knowledge-skills/code-analyzer.server.ts +20 -55
  183. package/src/mcps/knowledge-skills/code-review.server.ts +114 -161
  184. package/src/mcps/knowledge-skills/content-creator.server.ts +218 -255
  185. package/src/mcps/knowledge-skills/database-design.server.ts +118 -165
  186. package/src/mcps/knowledge-skills/devops-deployment.server.ts +67 -172
  187. package/src/mcps/knowledge-skills/git-workflow.server.ts +32 -77
  188. package/src/mcps/knowledge-skills/growth-strategist.server.ts +324 -361
  189. package/src/mcps/knowledge-skills/log-monitor.server.ts +160 -187
  190. package/src/mcps/knowledge-skills/mobile-development.server.ts +89 -223
  191. package/src/mcps/knowledge-skills/multimodal-looker.server.ts +128 -175
  192. package/src/mcps/knowledge-skills/performance-optimization.server.ts +156 -329
  193. package/src/mcps/knowledge-skills/project-analysis.server.ts +72 -248
  194. package/src/mcps/knowledge-skills/refactoring-strategies.server.ts +59 -171
  195. package/src/mcps/knowledge-skills/security-audit.server.ts +104 -151
  196. package/src/mcps/knowledge-skills/seo-consultant.server.ts +80 -220
  197. package/src/mcps/knowledge-skills/session-management.server.ts +51 -232
  198. package/src/mcps/knowledge-skills/skill-invocation.server.ts +165 -372
  199. package/src/mcps/knowledge-skills/strategist.server.ts +72 -143
  200. package/src/mcps/knowledge-skills/tech-writer.server.ts +85 -350
  201. package/src/mcps/knowledge-skills/testing-best-practices.server.ts +146 -195
  202. package/src/mcps/knowledge-skills/testing-strategy.server.ts +75 -161
  203. package/src/mcps/knowledge-skills/ui-ux-design.server.ts +93 -487
  204. package/src/mcps/lint.server.ts +53 -107
  205. package/src/mcps/mcp-client.ts +2 -2
  206. package/src/mcps/model-health-check.server.ts +34 -71
  207. package/src/mcps/performance-analysis.server.ts +60 -104
  208. package/src/mcps/processor-pipeline.server.ts +72 -110
  209. package/src/mcps/registry.json +1 -1
  210. package/src/mcps/researcher.server.ts +88 -177
  211. package/src/mcps/security-scan.server.ts +55 -104
  212. package/src/mcps/shared/knowledge-skill-base.ts +62 -0
  213. package/src/mcps/shared/prompt-security-validator.ts +199 -0
  214. package/src/mcps/shared/security-scanner.ts +599 -0
  215. package/src/mcps/state-manager.server.ts +117 -175
  216. package/src/opencode/codex.codex +1 -1
  217. package/src/opencode/commands/dependency-audit.md +3 -3
  218. package/src/opencode/enforcer-config.json +2 -2
  219. package/src/skills/registry.json +1 -1
  220. package/xray/codex.json +1 -1
  221. package/xray/config.json +1 -1
  222. package/xray/features.json +1 -1
  223. package/xray/integrations.json +3 -3
  224. package/dist/integrations/hermes-agent/__pycache__/__init__.cpython-313.pyc +0 -0
  225. package/dist/integrations/hermes-agent/__pycache__/conftest.cpython-313-pytest-9.0.2.pyc +0 -0
  226. package/dist/integrations/hermes-agent/__pycache__/schemas.cpython-313.pyc +0 -0
  227. package/dist/integrations/hermes-agent/__pycache__/test_plugin.cpython-313-pytest-9.0.2.pyc +0 -0
  228. package/dist/integrations/hermes-agent/__pycache__/test_plugin.cpython-313.pyc +0 -0
  229. package/dist/integrations/hermes-agent/__pycache__/tools.cpython-313.pyc +0 -0
  230. package/dist/integrations/hermes-agent/conftest.py +0 -14
  231. package/dist/integrations/hermes-agent/test_plugin.py +0 -1103
  232. package/dist/processors/implementations/refactoring-logging-processor.d.ts +0 -31
  233. package/dist/processors/implementations/refactoring-logging-processor.js +0 -96
  234. package/dist/processors/implementations/session-capture-processor.d.ts +0 -14
  235. package/dist/processors/implementations/session-capture-processor.js +0 -37
  236. package/dist/scripts/activate-kernel-pipeline.d.ts +0 -7
  237. package/dist/scripts/activate-kernel-pipeline.js +0 -101
  238. package/dist/security/index.d.ts +0 -13
  239. package/dist/security/index.js +0 -13
  240. package/dist/security/security-agent-coordinator.d.ts +0 -72
  241. package/dist/security/security-agent-coordinator.js +0 -204
  242. package/dist/security/security-auditor.d.ts +0 -56
  243. package/dist/security/security-auditor.js +0 -584
  244. package/dist/security/security-hardening-system.d.ts +0 -239
  245. package/dist/security/security-hardening-system.js +0 -727
  246. package/dist/security/security-orchestration-layer.d.ts +0 -119
  247. package/dist/security/security-orchestration-layer.js +0 -496
  248. /package/dist/{security → mcps/shared}/prompt-security-validator.d.ts +0 -0
  249. /package/dist/{security → mcps/shared}/prompt-security-validator.js +0 -0
  250. /package/dist/{security → mcps/shared}/security-scanner.d.ts +0 -0
@@ -5,409 +5,372 @@
5
5
  * Implements "Don't Make Me Think" principles for high-converting landing pages.
6
6
  */
7
7
 
8
- import { Server } from "@modelcontextprotocol/sdk/server/index.js";
9
- import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
10
- import {
11
- CallToolRequestSchema,
12
- ListToolsRequestSchema,
13
- } from "@modelcontextprotocol/sdk/types.js";
14
8
  import * as path from "path";
15
9
  import { fileURLToPath } from "url";
10
+ import { XrayKnowledgeSkillBase } from "../shared/knowledge-skill-base.js";
11
+ import { frameworkLogger } from "../../core/framework-logger.js";
16
12
 
17
- interface Tool {
18
- name: string;
19
- description: string;
20
- inputSchema: object;
21
- }
22
-
23
- class MarketingExpertServer {
24
- private server: Server;
25
- private tools: Tool[] = [
26
- {
27
- name: "campaign_strategy",
28
- description:
29
- "Develop comprehensive marketing campaign strategy with channel mix, budget allocation, and KPIs",
30
- inputSchema: {
31
- type: "object",
32
- properties: {
33
- campaignGoal: {
34
- type: "string",
35
- description: "Primary campaign objective",
13
+ class MarketingExpertServer extends XrayKnowledgeSkillBase {
14
+ constructor() {
15
+ super("growth-strategist", "2.0.1");
16
+ this.tools = [
17
+ {
18
+ name: "campaign_strategy",
19
+ description:
20
+ "Develop comprehensive marketing campaign strategy with channel mix, budget allocation, and KPIs",
21
+ inputSchema: {
22
+ type: "object",
23
+ properties: {
24
+ campaignGoal: {
25
+ type: "string",
26
+ description: "Primary campaign objective",
27
+ },
28
+ targetAudience: { type: "string", description: "Target demographic" },
29
+ budget: { type: "string", description: "Budget range" },
30
+ timeline: { type: "string", description: "Campaign duration" },
36
31
  },
37
- targetAudience: { type: "string", description: "Target demographic" },
38
- budget: { type: "string", description: "Budget range" },
39
- timeline: { type: "string", description: "Campaign duration" },
32
+ required: ["campaignGoal", "targetAudience"],
40
33
  },
41
- required: ["campaignGoal", "targetAudience"],
42
34
  },
43
- },
44
- {
45
- name: "landing_page_audit",
46
- description:
47
- "Audit landing page using 'Don't Make Me Think' principles - 3 second rule, cognitive load, CTA visibility",
48
- inputSchema: {
49
- type: "object",
50
- properties: {
51
- url: { type: "string", description: "Landing page URL" },
52
- goal: { type: "string", description: "Conversion goal" },
35
+ {
36
+ name: "landing_page_audit",
37
+ description:
38
+ "Audit landing page using 'Don't Make Me Think' principles - 3 second rule, cognitive load, CTA visibility",
39
+ inputSchema: {
40
+ type: "object",
41
+ properties: {
42
+ url: { type: "string", description: "Landing page URL" },
43
+ goal: { type: "string", description: "Conversion goal" },
44
+ },
45
+ required: ["url", "goal"],
53
46
  },
54
- required: ["url", "goal"],
55
47
  },
56
- },
57
- {
58
- name: "conversion_optimization",
59
- description:
60
- "Analyze and optimize conversion paths with A/B testing recommendations",
61
- inputSchema: {
62
- type: "object",
63
- properties: {
64
- pageType: {
65
- type: "string",
66
- enum: ["landing", "product", "checkout", "signup"],
67
- },
68
- currentConversion: {
69
- type: "number",
70
- description: "Current conversion rate %",
48
+ {
49
+ name: "conversion_optimization",
50
+ description:
51
+ "Analyze and optimize conversion paths with A/B testing recommendations",
52
+ inputSchema: {
53
+ type: "object",
54
+ properties: {
55
+ pageType: {
56
+ type: "string",
57
+ enum: ["landing", "product", "checkout", "signup"],
58
+ },
59
+ currentConversion: {
60
+ type: "number",
61
+ description: "Current conversion rate %",
62
+ },
71
63
  },
64
+ required: ["pageType"],
72
65
  },
73
- required: ["pageType"],
74
66
  },
75
- },
76
- {
77
- name: "market_analysis",
78
- description:
79
- "Conduct market analysis including competitor positioning, market size, and opportunities",
80
- inputSchema: {
81
- type: "object",
82
- properties: {
83
- industry: { type: "string", description: "Industry/niche" },
84
- competitors: {
85
- type: "array",
86
- items: { type: "string" },
87
- description: "Known competitors",
67
+ {
68
+ name: "market_analysis",
69
+ description:
70
+ "Conduct market analysis including competitor positioning, market size, and opportunities",
71
+ inputSchema: {
72
+ type: "object",
73
+ properties: {
74
+ industry: { type: "string", description: "Industry/niche" },
75
+ competitors: {
76
+ type: "array",
77
+ items: { type: "string" },
78
+ description: "Known competitors",
79
+ },
88
80
  },
81
+ required: ["industry"],
89
82
  },
90
- required: ["industry"],
91
83
  },
92
- },
93
- {
94
- name: "brand_positioning",
95
- description:
96
- "Develop brand positioning and messaging framework with unique value proposition",
97
- inputSchema: {
98
- type: "object",
99
- properties: {
100
- product: {
101
- type: "string",
102
- description: "Product/service description",
84
+ {
85
+ name: "brand_positioning",
86
+ description:
87
+ "Develop brand positioning and messaging framework with unique value proposition",
88
+ inputSchema: {
89
+ type: "object",
90
+ properties: {
91
+ product: {
92
+ type: "string",
93
+ description: "Product/service description",
94
+ },
95
+ targetMarket: { type: "string", description: "Ideal customer" },
96
+ competitors: { type: "array", items: { type: "string" } },
103
97
  },
104
- targetMarket: { type: "string", description: "Ideal customer" },
105
- competitors: { type: "array", items: { type: "string" } },
98
+ required: ["product", "targetMarket"],
106
99
  },
107
- required: ["product", "targetMarket"],
108
100
  },
109
- },
110
- ];
111
-
112
- constructor() {
113
- this.server = new Server(
114
- { name: "growth-strategist", version: "2.0.1" },
115
- { capabilities: { tools: {} } },
116
- );
117
-
118
- this.server.setRequestHandler(ListToolsRequestSchema, async () => ({
119
- tools: this.tools,
120
- }));
121
-
122
- this.server.setRequestHandler(CallToolRequestSchema, async (request) => {
123
- const { name, arguments: args = {} } = request.params;
124
-
125
- try {
126
- switch (name) {
127
- case "campaign_strategy": {
128
- const argsObj = args as Record<string, unknown>;
129
- return {
130
- content: [
101
+ ];
102
+ this.handlers = {
103
+ "campaign_strategy": async (args) => {
104
+ const argsObj = args as Record<string, unknown>;
105
+ return {
106
+ content: [
107
+ {
108
+ type: "text",
109
+ text: JSON.stringify(
131
110
  {
132
- type: "text",
133
- text: JSON.stringify(
111
+ campaignGoal: argsObj.campaignGoal,
112
+ strategy: {
113
+ channels: ["Content", "Email", "Social", "Paid"],
114
+ budgetAllocation: {
115
+ content: 30,
116
+ email: 20,
117
+ social: 25,
118
+ paid: 25,
119
+ },
120
+ timeline: argsObj.timeline || "3 months",
121
+ kpis: ["CTR", "Conversion Rate", "CAC", "LTV", "ROAS"],
122
+ },
123
+ phases: [
134
124
  {
135
- campaignGoal: argsObj.campaignGoal,
136
- strategy: {
137
- channels: ["Content", "Email", "Social", "Paid"],
138
- budgetAllocation: {
139
- content: 30,
140
- email: 20,
141
- social: 25,
142
- paid: 25,
143
- },
144
- timeline: argsObj.timeline || "3 months",
145
- kpis: ["CTR", "Conversion Rate", "CAC", "LTV", "ROAS"],
146
- },
147
- phases: [
148
- {
149
- name: "Awareness",
150
- duration: "4 weeks",
151
- goal: "Reach 100k impressions",
152
- },
153
- {
154
- name: "Consideration",
155
- duration: "6 weeks",
156
- goal: "5% conversion",
157
- },
158
- {
159
- name: "Conversion",
160
- duration: "4 weeks",
161
- goal: "2% purchase",
162
- },
163
- ],
125
+ name: "Awareness",
126
+ duration: "4 weeks",
127
+ goal: "Reach 100k impressions",
128
+ },
129
+ {
130
+ name: "Consideration",
131
+ duration: "6 weeks",
132
+ goal: "5% conversion",
164
133
  },
165
- null,
166
- 2,
167
- ),
134
+ {
135
+ name: "Conversion",
136
+ duration: "4 weeks",
137
+ goal: "2% purchase",
138
+ },
139
+ ],
168
140
  },
169
- ],
170
- };
171
- }
172
- case "landing_page_audit": {
173
- const argsObj = args as Record<string, unknown>;
174
- return {
175
- content: [
141
+ null,
142
+ 2,
143
+ ),
144
+ },
145
+ ],
146
+ };
147
+ },
148
+ "landing_page_audit": async (args) => {
149
+ const argsObj = args as Record<string, unknown>;
150
+ return {
151
+ content: [
152
+ {
153
+ type: "text",
154
+ text: JSON.stringify(
176
155
  {
177
- type: "text",
178
- text: JSON.stringify(
179
- {
180
- url: argsObj.url,
181
- goal: argsObj.goal,
182
- auditScore: 72,
183
- dontMakeMeThink: {
184
- score: 68,
185
- issues: [
186
- {
187
- priority: "high",
188
- issue: "Hero value prop not clear in 3 seconds",
189
- fix: "Above fold: headline + subhead + CTA",
190
- },
191
- {
192
- priority: "high",
193
- issue: "Navigation unclear",
194
- fix: "Max 5 nav items, use familiar labels",
195
- },
196
- {
197
- priority: "medium",
198
- issue: "Too many choices",
199
- fix: "Reduce to one primary CTA",
200
- },
201
- ],
156
+ url: argsObj.url,
157
+ goal: argsObj.goal,
158
+ auditScore: 72,
159
+ dontMakeMeThink: {
160
+ score: 68,
161
+ issues: [
162
+ {
163
+ priority: "high",
164
+ issue: "Hero value prop not clear in 3 seconds",
165
+ fix: "Above fold: headline + subhead + CTA",
166
+ },
167
+ {
168
+ priority: "high",
169
+ issue: "Navigation unclear",
170
+ fix: "Max 5 nav items, use familiar labels",
202
171
  },
203
- sections: {
204
- hero: {
205
- status: "needs-work",
206
- recommendation:
207
- "Clear H1 + benefit statement + CTA in 3 seconds",
208
- },
209
- socialProof: {
210
- status: "good",
211
- recommendation: "Add testimonials above fold",
212
- },
213
- problem: {
214
- status: "needs-work",
215
- recommendation: "Lead with customer pain point",
216
- },
217
- solution: {
218
- status: "good",
219
- recommendation: "Show product/screenshot clearly",
220
- },
221
- benefits: {
222
- status: "good",
223
- recommendation: "Use bullet points, not paragraphs",
224
- },
225
- cta: {
226
- status: "needs-work",
227
- recommendation:
228
- "Make CTA button stand out (color, size, text)",
229
- },
230
- riskReversal: {
231
- status: "missing",
232
- recommendation: "Add guarantees, testimonials",
233
- },
234
- faq: {
235
- status: "good",
236
- recommendation: "Address objections",
237
- },
172
+ {
173
+ priority: "medium",
174
+ issue: "Too many choices",
175
+ fix: "Reduce to one primary CTA",
238
176
  },
239
- cognitiveLoad: "Medium",
240
- firstImpression: "Needs improvement - value prop unclear",
177
+ ],
178
+ },
179
+ sections: {
180
+ hero: {
181
+ status: "needs-work",
182
+ recommendation:
183
+ "Clear H1 + benefit statement + CTA in 3 seconds",
184
+ },
185
+ socialProof: {
186
+ status: "good",
187
+ recommendation: "Add testimonials above fold",
188
+ },
189
+ problem: {
190
+ status: "needs-work",
191
+ recommendation: "Lead with customer pain point",
241
192
  },
242
- null,
243
- 2,
244
- ),
193
+ solution: {
194
+ status: "good",
195
+ recommendation: "Show product/screenshot clearly",
196
+ },
197
+ benefits: {
198
+ status: "good",
199
+ recommendation: "Use bullet points, not paragraphs",
200
+ },
201
+ cta: {
202
+ status: "needs-work",
203
+ recommendation:
204
+ "Make CTA button stand out (color, size, text)",
205
+ },
206
+ riskReversal: {
207
+ status: "missing",
208
+ recommendation: "Add guarantees, testimonials",
209
+ },
210
+ faq: {
211
+ status: "good",
212
+ recommendation: "Address objections",
213
+ },
214
+ },
215
+ cognitiveLoad: "Medium",
216
+ firstImpression: "Needs improvement - value prop unclear",
245
217
  },
246
- ],
247
- };
248
- }
249
- case "conversion_optimization": {
250
- const argsObj = args as Record<string, unknown>;
251
- const pageType = (argsObj.pageType as string) || "landing";
252
- const currentConversion =
253
- (argsObj.currentConversion as number) || 2;
254
- return {
255
- content: [
218
+ null,
219
+ 2,
220
+ ),
221
+ },
222
+ ],
223
+ };
224
+ },
225
+ "conversion_optimization": async (args) => {
226
+ const argsObj = args as Record<string, unknown>;
227
+ const pageType = (argsObj.pageType as string) || "landing";
228
+ const currentConversion =
229
+ (argsObj.currentConversion as number) || 2;
230
+ return {
231
+ content: [
232
+ {
233
+ type: "text",
234
+ text: JSON.stringify(
256
235
  {
257
- type: "text",
258
- text: JSON.stringify(
236
+ pageType,
237
+ currentConversion,
238
+ targetConversion: currentConversion * 1.5,
239
+ recommendations: [
259
240
  {
260
- pageType,
261
- currentConversion,
262
- targetConversion: currentConversion * 1.5,
263
- recommendations: [
264
- {
265
- priority: "high",
266
- change: "Single clear CTA",
267
- impact: "+25%",
268
- },
269
- {
270
- priority: "high",
271
- change: "Social proof near CTA",
272
- impact: "+15%",
273
- },
274
- {
275
- priority: "medium",
276
- change: "Remove navigation distractions",
277
- impact: "+10%",
278
- },
279
- {
280
- priority: "medium",
281
- change: "Add urgency indicators",
282
- impact: "+10%",
283
- },
284
- {
285
- priority: "low",
286
- change: "Reduce form fields",
287
- impact: "+5%",
288
- },
289
- ],
290
- abTests: [
291
- {
292
- name: "CTA Color Test",
293
- hypothesis: "Contrast color increases clicks",
294
- },
295
- {
296
- name: "Headline Test",
297
- hypothesis:
298
- "Benefit-driven headline outperforms feature",
299
- },
300
- {
301
- name: "Social Proof Position",
302
- hypothesis:
303
- "Testimonial placement above vs below fold",
304
- },
305
- ],
241
+ priority: "high",
242
+ change: "Single clear CTA",
243
+ impact: "+25%",
306
244
  },
307
- null,
308
- 2,
309
- ),
310
- },
311
- ],
312
- };
313
- }
314
- case "market_analysis": {
315
- const argsObj = args as Record<string, unknown>;
316
- return {
317
- content: [
318
- {
319
- type: "text",
320
- text: JSON.stringify(
321
245
  {
322
- industry: argsObj.industry,
323
- competitors: argsObj.competitors || [],
324
- analysis: {
325
- marketSize: "Estimate based on industry benchmarks",
326
- growthRate: "5-10% YoY",
327
- keyPlayers: ["Player 1", "Player 2", "Player 3"],
328
- opportunities: [
329
- "Underserved segment",
330
- "Technology gap",
331
- "Pricing optimization",
332
- ],
333
- threats: [
334
- "Market saturation",
335
- "Regulatory changes",
336
- "Economic factors",
337
- ],
338
- },
246
+ priority: "high",
247
+ change: "Social proof near CTA",
248
+ impact: "+15%",
339
249
  },
340
- null,
341
- 2,
342
- ),
343
- },
344
- ],
345
- };
346
- }
347
- case "brand_positioning": {
348
- const argsObj = args as Record<string, unknown>;
349
- return {
350
- content: [
351
- {
352
- type: "text",
353
- text: JSON.stringify(
354
250
  {
355
- product: argsObj.product,
356
- targetMarket: argsObj.targetMarket,
357
- positioning: {
358
- valueProposition:
359
- "Unique benefit statement that differentiates from competitors",
360
- brandArchetype:
361
- "Hero or Sage - choose based on audience",
362
- keyMessages: [
363
- "Primary message",
364
- "Secondary message",
365
- "Tertiary message",
366
- ],
367
- differentiators: [
368
- "Unique feature 1",
369
- "Unique feature 2",
370
- "Unique benefit",
371
- ],
372
- messagingFramework: {
373
- hero: "For [audience] who [need], [product] is [category] that [benefit]",
374
- taglines: [
375
- "Option 1: [Benefit-focused]",
376
- "Option 2: [Emotion-focused]",
377
- "Option 3: [Authority-focused]",
378
- ],
379
- },
380
- },
251
+ priority: "medium",
252
+ change: "Remove navigation distractions",
253
+ impact: "+10%",
254
+ },
255
+ {
256
+ priority: "medium",
257
+ change: "Add urgency indicators",
258
+ impact: "+10%",
259
+ },
260
+ {
261
+ priority: "low",
262
+ change: "Reduce form fields",
263
+ impact: "+5%",
264
+ },
265
+ ],
266
+ abTests: [
267
+ {
268
+ name: "CTA Color Test",
269
+ hypothesis: "Contrast color increases clicks",
270
+ },
271
+ {
272
+ name: "Headline Test",
273
+ hypothesis:
274
+ "Benefit-driven headline outperforms feature",
381
275
  },
382
- null,
383
- 2,
384
- ),
276
+ {
277
+ name: "Social Proof Position",
278
+ hypothesis:
279
+ "Testimonial placement above vs below fold",
280
+ },
281
+ ],
385
282
  },
386
- ],
387
- };
388
- }
389
- default:
390
- throw new Error(`Unknown tool: ${name}`);
391
- }
392
- } catch (error) {
283
+ null,
284
+ 2,
285
+ ),
286
+ },
287
+ ],
288
+ };
289
+ },
290
+ "market_analysis": async (args) => {
291
+ const argsObj = args as Record<string, unknown>;
393
292
  return {
394
- content: [{ type: "text", text: `Error: ${error}` }],
395
- isError: true,
293
+ content: [
294
+ {
295
+ type: "text",
296
+ text: JSON.stringify(
297
+ {
298
+ industry: argsObj.industry,
299
+ competitors: argsObj.competitors || [],
300
+ analysis: {
301
+ marketSize: "Estimate based on industry benchmarks",
302
+ growthRate: "5-10% YoY",
303
+ keyPlayers: ["Player 1", "Player 2", "Player 3"],
304
+ opportunities: [
305
+ "Underserved segment",
306
+ "Technology gap",
307
+ "Pricing optimization",
308
+ ],
309
+ threats: [
310
+ "Market saturation",
311
+ "Regulatory changes",
312
+ "Economic factors",
313
+ ],
314
+ },
315
+ },
316
+ null,
317
+ 2,
318
+ ),
319
+ },
320
+ ],
396
321
  };
397
- }
398
- });
399
- }
400
-
401
- async run() {
402
- const transport = new StdioServerTransport();
403
- await this.server.connect(transport);
322
+ },
323
+ "brand_positioning": async (args) => {
324
+ const argsObj = args as Record<string, unknown>;
325
+ return {
326
+ content: [
327
+ {
328
+ type: "text",
329
+ text: JSON.stringify(
330
+ {
331
+ product: argsObj.product,
332
+ targetMarket: argsObj.targetMarket,
333
+ positioning: {
334
+ valueProposition:
335
+ "Unique benefit statement that differentiates from competitors",
336
+ brandArchetype:
337
+ "Hero or Sage - choose based on audience",
338
+ keyMessages: [
339
+ "Primary message",
340
+ "Secondary message",
341
+ "Tertiary message",
342
+ ],
343
+ differentiators: [
344
+ "Unique feature 1",
345
+ "Unique feature 2",
346
+ "Unique benefit",
347
+ ],
348
+ messagingFramework: {
349
+ hero: "For [audience] who [need], [product] is [category] that [benefit]",
350
+ taglines: [
351
+ "Option 1: [Benefit-focused]",
352
+ "Option 2: [Emotion-focused]",
353
+ "Option 3: [Authority-focused]",
354
+ ],
355
+ },
356
+ },
357
+ },
358
+ null,
359
+ 2,
360
+ ),
361
+ },
362
+ ],
363
+ };
364
+ },
365
+ };
366
+ this.setupToolHandlers();
404
367
  }
405
368
  }
406
369
 
407
370
  const entryPoint = path.resolve(process.argv[1] ?? "");
408
371
  if (entryPoint && fileURLToPath(import.meta.url) === entryPoint) {
409
372
  const server = new MarketingExpertServer();
410
- server.run();
373
+ server.run("growth-strategist").catch((err) => { frameworkLogger.log("growth-strategist", "run", "error", { error: err instanceof Error ? err.message : String(err) }); });
411
374
  }
412
375
 
413
376
  export { MarketingExpertServer };