0xray 2.1.1 → 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 (254) 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 +3 -2
  5. package/README.md +12 -11
  6. package/dist/AGENTS.md +3 -2
  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 +14 -10
  168. package/scripts/node/setup.cjs +32 -0
  169. package/scripts/node/universal-version-manager.js +11 -11
  170. package/src/mcps/architect-tools.server.ts +112 -215
  171. package/src/mcps/auto-format.server.ts +50 -110
  172. package/src/mcps/boot-orchestrator.server.ts +75 -121
  173. package/src/mcps/config/__tests__/server-config-registry.test.ts +21 -12
  174. package/src/mcps/config/server-config-registry.ts +3 -3
  175. package/src/mcps/enforcer-tools.server.ts +212 -310
  176. package/src/mcps/estimation.server.ts +62 -122
  177. package/src/mcps/framework-compliance-audit.server.ts +52 -97
  178. package/src/mcps/framework-help.server.ts +64 -114
  179. package/src/mcps/governance.server.ts +2 -2
  180. package/src/mcps/knowledge-skills/api-design.server.ts +32 -77
  181. package/src/mcps/knowledge-skills/architecture-patterns.server.ts +31 -87
  182. package/src/mcps/knowledge-skills/bug-triage-specialist.server.ts +165 -193
  183. package/src/mcps/knowledge-skills/code-analyzer.server.ts +20 -55
  184. package/src/mcps/knowledge-skills/code-review.server.ts +114 -161
  185. package/src/mcps/knowledge-skills/content-creator.server.ts +218 -255
  186. package/src/mcps/knowledge-skills/database-design.server.ts +118 -165
  187. package/src/mcps/knowledge-skills/devops-deployment.server.ts +67 -172
  188. package/src/mcps/knowledge-skills/git-workflow.server.ts +32 -77
  189. package/src/mcps/knowledge-skills/growth-strategist.server.ts +324 -361
  190. package/src/mcps/knowledge-skills/log-monitor.server.ts +160 -187
  191. package/src/mcps/knowledge-skills/mobile-development.server.ts +89 -223
  192. package/src/mcps/knowledge-skills/multimodal-looker.server.ts +128 -175
  193. package/src/mcps/knowledge-skills/performance-optimization.server.ts +156 -329
  194. package/src/mcps/knowledge-skills/project-analysis.server.ts +72 -248
  195. package/src/mcps/knowledge-skills/refactoring-strategies.server.ts +59 -171
  196. package/src/mcps/knowledge-skills/security-audit.server.ts +104 -151
  197. package/src/mcps/knowledge-skills/seo-consultant.server.ts +80 -220
  198. package/src/mcps/knowledge-skills/session-management.server.ts +51 -232
  199. package/src/mcps/knowledge-skills/skill-invocation.server.ts +165 -372
  200. package/src/mcps/knowledge-skills/strategist.server.ts +72 -143
  201. package/src/mcps/knowledge-skills/tech-writer.server.ts +85 -350
  202. package/src/mcps/knowledge-skills/testing-best-practices.server.ts +146 -195
  203. package/src/mcps/knowledge-skills/testing-strategy.server.ts +75 -161
  204. package/src/mcps/knowledge-skills/ui-ux-design.server.ts +93 -487
  205. package/src/mcps/lint.server.ts +53 -107
  206. package/src/mcps/mcp-client.ts +2 -2
  207. package/src/mcps/model-health-check.server.ts +34 -71
  208. package/src/mcps/performance-analysis.server.ts +60 -104
  209. package/src/mcps/processor-pipeline.server.ts +72 -110
  210. package/src/mcps/registry.json +1 -1
  211. package/src/mcps/researcher.server.ts +88 -177
  212. package/src/mcps/security-scan.server.ts +55 -104
  213. package/src/mcps/shared/knowledge-skill-base.ts +62 -0
  214. package/src/mcps/shared/prompt-security-validator.ts +199 -0
  215. package/src/mcps/shared/security-scanner.ts +599 -0
  216. package/src/mcps/state-manager.server.ts +117 -175
  217. package/src/opencode/codex.codex +1 -1
  218. package/src/opencode/commands/dependency-audit.md +3 -3
  219. package/src/opencode/enforcer-config.json +2 -2
  220. package/src/skills/registry.json +1 -1
  221. package/xray/agents_template.md +109 -0
  222. package/xray/codex.json +598 -0
  223. package/xray/config.json +26 -0
  224. package/xray/features.json +132 -0
  225. package/xray/integrations.json +23 -0
  226. package/xray/routing-mappings.json +752 -0
  227. package/xray/workflow_state.json +28 -0
  228. package/dist/integrations/hermes-agent/__pycache__/__init__.cpython-313.pyc +0 -0
  229. package/dist/integrations/hermes-agent/__pycache__/conftest.cpython-313-pytest-9.0.2.pyc +0 -0
  230. package/dist/integrations/hermes-agent/__pycache__/schemas.cpython-313.pyc +0 -0
  231. package/dist/integrations/hermes-agent/__pycache__/test_plugin.cpython-313-pytest-9.0.2.pyc +0 -0
  232. package/dist/integrations/hermes-agent/__pycache__/test_plugin.cpython-313.pyc +0 -0
  233. package/dist/integrations/hermes-agent/__pycache__/tools.cpython-313.pyc +0 -0
  234. package/dist/integrations/hermes-agent/conftest.py +0 -14
  235. package/dist/integrations/hermes-agent/test_plugin.py +0 -1103
  236. package/dist/processors/implementations/refactoring-logging-processor.d.ts +0 -31
  237. package/dist/processors/implementations/refactoring-logging-processor.js +0 -96
  238. package/dist/processors/implementations/session-capture-processor.d.ts +0 -14
  239. package/dist/processors/implementations/session-capture-processor.js +0 -37
  240. package/dist/scripts/activate-kernel-pipeline.d.ts +0 -7
  241. package/dist/scripts/activate-kernel-pipeline.js +0 -101
  242. package/dist/security/index.d.ts +0 -13
  243. package/dist/security/index.js +0 -13
  244. package/dist/security/security-agent-coordinator.d.ts +0 -72
  245. package/dist/security/security-agent-coordinator.js +0 -204
  246. package/dist/security/security-auditor.d.ts +0 -56
  247. package/dist/security/security-auditor.js +0 -584
  248. package/dist/security/security-hardening-system.d.ts +0 -239
  249. package/dist/security/security-hardening-system.js +0 -727
  250. package/dist/security/security-orchestration-layer.d.ts +0 -119
  251. package/dist/security/security-orchestration-layer.js +0 -496
  252. /package/dist/{security → mcps/shared}/prompt-security-validator.d.ts +0 -0
  253. /package/dist/{security → mcps/shared}/prompt-security-validator.js +0 -0
  254. /package/dist/{security → mcps/shared}/security-scanner.d.ts +0 -0
@@ -3,118 +3,81 @@
3
3
  *
4
4
  * Provides tools for tracking and validating estimates
5
5
  */
6
- import { Server } from "@modelcontextprotocol/sdk/server/index.js";
7
- import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
8
- import { CallToolRequestSchema, ListToolsRequestSchema, } from "@modelcontextprotocol/sdk/types.js";
9
6
  import { frameworkLogger } from "../core/framework-logger.js";
10
7
  import { getEstimationValidator } from "../validation/estimation-validator.js";
8
+ import { XrayKnowledgeSkillBase } from "./shared/knowledge-skill-base.js";
11
9
  /**
12
10
  * Estimation MCP Server
13
11
  * Tracks estimates vs actuals and provides calibrated predictions
14
12
  */
15
- class EstimationServer {
16
- server;
13
+ class EstimationServer extends XrayKnowledgeSkillBase {
17
14
  validator = getEstimationValidator();
18
15
  constructor() {
19
- this.server = new Server({
20
- name: "estimation-validator", version: "2.0.1",
21
- }, {
22
- capabilities: { tools: {} },
23
- });
24
- this.setupToolHandlers();
25
- }
26
- setupToolHandlers() {
27
- // List available tools
28
- this.server.setRequestHandler(ListToolsRequestSchema, async () => {
29
- return {
30
- tools: [
31
- {
32
- name: "validate-estimate",
33
- description: "Validate an estimate against historical data",
34
- inputSchema: {
35
- type: "object",
36
- properties: {
37
- category: {
38
- type: "string",
39
- description: "Task category (e.g., 'refactoring', 'testing', 'documentation')",
40
- },
41
- estimate: {
42
- type: "number",
43
- description: "Estimated time in minutes",
44
- },
45
- description: {
46
- type: "string",
47
- description: "Brief description of the task",
48
- },
49
- },
50
- required: ["category", "estimate"],
16
+ super("estimation-validator", "2.0.1");
17
+ this.tools = [
18
+ {
19
+ name: "validate-estimate",
20
+ description: "Validate an estimate against historical data",
21
+ inputSchema: {
22
+ type: "object",
23
+ properties: {
24
+ category: {
25
+ type: "string",
26
+ description: "Task category (e.g., 'refactoring', 'testing', 'documentation')",
51
27
  },
52
- },
53
- {
54
- name: "start-tracking",
55
- description: "Start tracking time for a task",
56
- inputSchema: {
57
- type: "object",
58
- properties: {
59
- taskId: { type: "string" },
60
- category: { type: "string" },
61
- estimate: { type: "number" },
62
- description: { type: "string" },
63
- },
64
- required: ["taskId", "category", "estimate"],
28
+ estimate: {
29
+ type: "number",
30
+ description: "Estimated time in minutes",
65
31
  },
66
- },
67
- {
68
- name: "complete-tracking",
69
- description: "Complete tracking for a task",
70
- inputSchema: {
71
- type: "object",
72
- properties: {
73
- taskId: { type: "string" },
74
- },
75
- required: ["taskId"],
32
+ description: {
33
+ type: "string",
34
+ description: "Brief description of the task",
76
35
  },
77
36
  },
78
- {
79
- name: "get-accuracy-report",
80
- description: "Get estimation accuracy report",
81
- inputSchema: {
82
- type: "object",
83
- properties: {},
84
- },
37
+ required: ["category", "estimate"],
38
+ },
39
+ },
40
+ {
41
+ name: "start-tracking",
42
+ description: "Start tracking time for a task",
43
+ inputSchema: {
44
+ type: "object",
45
+ properties: {
46
+ taskId: { type: "string" },
47
+ category: { type: "string" },
48
+ estimate: { type: "number" },
49
+ description: { type: "string" },
85
50
  },
86
- ],
87
- };
88
- });
89
- // Handle tool calls
90
- this.server.setRequestHandler(CallToolRequestSchema, async (request) => {
91
- try {
92
- const { name, arguments: args } = request.params;
93
- if (args == null) {
94
- throw new Error(`Tool '${name}' called with no arguments`);
95
- }
96
- switch (name) {
97
- case "validate-estimate":
98
- return this.handleValidateEstimate(args);
99
- case "start-tracking":
100
- return this.handleStartTracking(args);
101
- case "complete-tracking":
102
- return this.handleCompleteTracking(args);
103
- case "get-accuracy-report":
104
- return this.handleGetReport();
105
- default:
106
- throw new Error(`Unknown tool: ${name}`);
107
- }
108
- }
109
- catch (error) {
110
- return {
111
- content: [{
112
- type: "text",
113
- text: `Error handling tool '${request.params.name}': ${error instanceof Error ? error.message : String(error)}`,
114
- }],
115
- };
116
- }
117
- });
51
+ required: ["taskId", "category", "estimate"],
52
+ },
53
+ },
54
+ {
55
+ name: "complete-tracking",
56
+ description: "Complete tracking for a task",
57
+ inputSchema: {
58
+ type: "object",
59
+ properties: {
60
+ taskId: { type: "string" },
61
+ },
62
+ required: ["taskId"],
63
+ },
64
+ },
65
+ {
66
+ name: "get-accuracy-report",
67
+ description: "Get estimation accuracy report",
68
+ inputSchema: {
69
+ type: "object",
70
+ properties: {},
71
+ },
72
+ },
73
+ ];
74
+ this.handlers = {
75
+ "validate-estimate": async (args) => this.handleValidateEstimate(args),
76
+ "start-tracking": async (args) => this.handleStartTracking(args),
77
+ "complete-tracking": async (args) => this.handleCompleteTracking(args),
78
+ "get-accuracy-report": async (args) => this.handleGetReport(),
79
+ };
80
+ this.setupToolHandlers();
118
81
  }
119
82
  handleValidateEstimate(args) {
120
83
  const validation = this.validator.validateEstimate(args.category, args.estimate);
@@ -176,17 +139,10 @@ class EstimationServer {
176
139
  }
177
140
  return { content: [{ type: "text", text: response }] };
178
141
  }
179
- async start() {
180
- const transport = new StdioServerTransport();
181
- await this.server.connect(transport);
182
- frameworkLogger.log("estimation-server", "start", "info", {
183
- message: "Estimation Validator Server started",
184
- });
185
- }
186
142
  }
187
143
  // Run if called directly
188
144
  if (import.meta.url === `file://${process.argv[1]}`) {
189
145
  const server = new EstimationServer();
190
- server.start().catch((error) => frameworkLogger.log("mcps/estimation", "run", "error", { error: String(error) }));
146
+ server.run("estimation-validator").catch((error) => frameworkLogger.log("mcps/estimation", "run", "error", { error: String(error) }));
191
147
  }
192
148
  export { EstimationServer };
@@ -3,10 +3,9 @@
3
3
  *
4
4
  * Comprehensive validation of all framework components and Universal Development Codex compliance
5
5
  */
6
- declare class XrayFrameworkComplianceAuditServer {
7
- private server;
6
+ import { XrayKnowledgeSkillBase } from "./shared/knowledge-skill-base.js";
7
+ declare class XrayFrameworkComplianceAuditServer extends XrayKnowledgeSkillBase {
8
8
  constructor();
9
- private setupToolHandlers;
10
9
  private handleFrameworkComplianceAudit;
11
10
  private handleCodexValidation;
12
11
  private auditConfigurationIntegrity;
@@ -17,6 +16,5 @@ declare class XrayFrameworkComplianceAuditServer {
17
16
  private checkTermImplementation;
18
17
  private generateAuditSummary;
19
18
  private getDetailedFindings;
20
- run(): Promise<void>;
21
19
  }
22
20
  export { XrayFrameworkComplianceAuditServer };
@@ -3,89 +3,65 @@
3
3
  *
4
4
  * Comprehensive validation of all framework components and Universal Development Codex compliance
5
5
  */
6
- import { Server } from "@modelcontextprotocol/sdk/server/index.js";
7
- import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
8
- import { CallToolRequestSchema, ListToolsRequestSchema, } from "@modelcontextprotocol/sdk/types.js";
9
6
  import fs from "fs";
10
7
  import { frameworkLogger } from "../core/framework-logger.js";
11
- class XrayFrameworkComplianceAuditServer {
12
- server;
8
+ import { XrayKnowledgeSkillBase } from "./shared/knowledge-skill-base.js";
9
+ class XrayFrameworkComplianceAuditServer extends XrayKnowledgeSkillBase {
13
10
  constructor() {
14
- this.server = new Server({
15
- name: "framework-compliance-audit", version: "2.0.1",
16
- }, {
17
- capabilities: {
18
- tools: {},
19
- },
20
- });
21
- this.setupToolHandlers();
22
- void frameworkLogger.log("framework-compliance-audit.server", "compliance-audit-init", "info", { message: "0xRay Framework Compliance Audit MCP Server initialized" });
23
- }
24
- setupToolHandlers() {
25
- // List available tools
26
- this.server.setRequestHandler(ListToolsRequestSchema, async () => {
27
- return {
28
- tools: [
29
- {
30
- name: "framework-compliance-audit",
31
- description: "Comprehensive validation of all framework components and Universal Development Codex compliance",
32
- inputSchema: {
33
- type: "object",
34
- properties: {
35
- scope: {
36
- type: "string",
37
- enum: [
38
- "full",
39
- "codex",
40
- "configuration",
41
- "agents",
42
- "performance",
43
- ],
44
- default: "full",
45
- description: "Scope of compliance audit",
46
- },
47
- detailed: {
48
- type: "boolean",
49
- default: false,
50
- description: "Include detailed findings and recommendations",
51
- },
52
- },
11
+ super("framework-compliance-audit", "2.0.1");
12
+ this.tools = [
13
+ {
14
+ name: "framework-compliance-audit",
15
+ description: "Comprehensive validation of all framework components and Universal Development Codex compliance",
16
+ inputSchema: {
17
+ type: "object",
18
+ properties: {
19
+ scope: {
20
+ type: "string",
21
+ enum: [
22
+ "full",
23
+ "codex",
24
+ "configuration",
25
+ "agents",
26
+ "performance",
27
+ ],
28
+ default: "full",
29
+ description: "Scope of compliance audit",
30
+ },
31
+ detailed: {
32
+ type: "boolean",
33
+ default: false,
34
+ description: "Include detailed findings and recommendations",
53
35
  },
54
36
  },
55
- {
56
- name: "codex-validation",
57
- description: "Validate compliance with Universal Development Codex v1.2.0",
58
- inputSchema: {
59
- type: "object",
60
- properties: {
61
- terms: {
62
- type: "array",
63
- items: { type: "number", minimum: 1, maximum: 43 },
64
- description: "Specific codex terms to validate (1-43)",
65
- },
66
- strict: {
67
- type: "boolean",
68
- default: true,
69
- description: "Enforce strict compliance",
70
- },
71
- },
37
+ },
38
+ },
39
+ {
40
+ name: "codex-validation",
41
+ description: "Validate compliance with Universal Development Codex v1.2.0",
42
+ inputSchema: {
43
+ type: "object",
44
+ properties: {
45
+ terms: {
46
+ type: "array",
47
+ items: { type: "number", minimum: 1, maximum: 43 },
48
+ description: "Specific codex terms to validate (1-43)",
49
+ },
50
+ strict: {
51
+ type: "boolean",
52
+ default: true,
53
+ description: "Enforce strict compliance",
72
54
  },
73
55
  },
74
- ],
75
- };
76
- });
77
- // Handle tool calls
78
- this.server.setRequestHandler(CallToolRequestSchema, async (request) => {
79
- const { name, arguments: args } = request.params;
80
- switch (name) {
81
- case "framework-compliance-audit":
82
- return await this.handleFrameworkComplianceAudit(args);
83
- case "codex-validation":
84
- return await this.handleCodexValidation(args);
85
- default:
86
- throw new Error(`Unknown tool: ${name}`);
87
- }
88
- });
56
+ },
57
+ },
58
+ ];
59
+ this.handlers = {
60
+ "framework-compliance-audit": async (args) => this.handleFrameworkComplianceAudit(args),
61
+ "codex-validation": async (args) => this.handleCodexValidation(args),
62
+ };
63
+ this.setupToolHandlers();
64
+ void frameworkLogger.log("framework-compliance-audit.server", "compliance-audit-init", "info", { message: "0xRay Framework Compliance Audit MCP Server initialized" });
89
65
  }
90
66
  async handleFrameworkComplianceAudit(args) {
91
67
  const scope = args.scope || "full";
@@ -486,15 +462,10 @@ ${results.recommendations.map((r) => `• 💡 ${r}`).join("\n")}
486
462
  details += `- Status: ${results.complianceScores.performance_thresholds || "Not checked"}\n\n`;
487
463
  return details;
488
464
  }
489
- async run() {
490
- const transport = new StdioServerTransport();
491
- await this.server.connect(transport);
492
- void frameworkLogger.log("framework-compliance-audit.server", "compliance-audit-startup", "info", { message: "0xRay Framework Compliance Audit MCP Server started" });
493
- }
494
465
  }
495
466
  // Start the server if run directly
496
467
  if (import.meta.url === `file://${process.argv[1]}`) {
497
468
  const server = new XrayFrameworkComplianceAuditServer();
498
- server.run().catch((error) => frameworkLogger.log("mcps/framework-compliance-audit", "run", "error", { error: String(error) }));
469
+ server.run("framework-compliance-audit").catch((error) => frameworkLogger.log("mcps/framework-compliance-audit", "run", "error", { error: String(error) }));
499
470
  }
500
471
  export { XrayFrameworkComplianceAuditServer };
@@ -1,7 +1,6 @@
1
- declare class FrameworkHelpServer {
2
- private server;
1
+ import { XrayKnowledgeSkillBase } from "./shared/knowledge-skill-base.js";
2
+ declare class FrameworkHelpServer extends XrayKnowledgeSkillBase {
3
3
  constructor();
4
- private setupToolHandlers;
5
4
  private getActiveAgentEntries;
6
5
  private handleGetCapabilities;
7
6
  private handleGetCommands;
@@ -9,6 +8,5 @@ declare class FrameworkHelpServer {
9
8
  private generateCommandList;
10
9
  private generateFullCapabilities;
11
10
  private generateCategoryCapabilities;
12
- start(): Promise<void>;
13
11
  }
14
12
  export { FrameworkHelpServer };
@@ -1,107 +1,74 @@
1
- import { Server } from "@modelcontextprotocol/sdk/server/index.js";
2
- import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
3
- import { CallToolRequestSchema, ErrorCode, ListToolsRequestSchema, McpError, } from "@modelcontextprotocol/sdk/types.js";
1
+ import { ErrorCode, McpError, } from "@modelcontextprotocol/sdk/types.js";
4
2
  import { frameworkLogger } from "../core/framework-logger.js";
5
3
  import { AGENT_REGISTRY } from "../agents/registry.js";
6
- class FrameworkHelpServer {
7
- server;
4
+ import { XrayKnowledgeSkillBase } from "./shared/knowledge-skill-base.js";
5
+ class FrameworkHelpServer extends XrayKnowledgeSkillBase {
8
6
  constructor() {
9
- this.server = new Server({
10
- name: "xray/framework-help", version: "2.0.1",
11
- }, {
12
- capabilities: {
13
- tools: {},
14
- },
15
- });
16
- this.setupToolHandlers();
17
- }
18
- setupToolHandlers() {
19
- // List available tools - required MCP protocol handler for tool discovery
20
- this.server.setRequestHandler(ListToolsRequestSchema, async () => {
21
- return {
22
- tools: [
23
- {
24
- name: "xray_get_capabilities",
25
- description: "Get comprehensive list of all 0xRay framework capabilities, commands, and available tools",
26
- inputSchema: {
27
- type: "object",
28
- properties: {
29
- category: {
30
- type: "string",
31
- enum: ["all", "agents", "skills", "commands", "reporting"],
32
- description: "Filter capabilities by category",
33
- default: "all",
34
- },
35
- format: {
36
- type: "string",
37
- enum: ["summary", "detailed", "commands"],
38
- description: "Output format",
39
- default: "summary",
40
- },
41
- },
42
- required: [],
7
+ super("xray/framework-help", "2.0.1");
8
+ this.tools = [
9
+ {
10
+ name: "xray_get_capabilities",
11
+ description: "Get comprehensive list of all 0xRay framework capabilities, commands, and available tools",
12
+ inputSchema: {
13
+ type: "object",
14
+ properties: {
15
+ category: {
16
+ type: "string",
17
+ enum: ["all", "agents", "skills", "commands", "reporting"],
18
+ description: "Filter capabilities by category",
19
+ default: "all",
20
+ },
21
+ format: {
22
+ type: "string",
23
+ enum: ["summary", "detailed", "commands"],
24
+ description: "Output format",
25
+ default: "summary",
43
26
  },
44
27
  },
45
- {
46
- name: "xray_get_commands",
47
- description: "Get list of available 0xRay commands and their usage",
48
- inputSchema: {
49
- type: "object",
50
- properties: {
51
- type: {
52
- type: "string",
53
- enum: [
54
- "agent-commands",
55
- "system-commands",
56
- "reporting-commands",
57
- ],
58
- description: "Type of commands to list",
59
- default: "agent-commands",
60
- },
61
- },
62
- required: [],
28
+ required: [],
29
+ },
30
+ },
31
+ {
32
+ name: "xray_get_commands",
33
+ description: "Get list of available 0xRay commands and their usage",
34
+ inputSchema: {
35
+ type: "object",
36
+ properties: {
37
+ type: {
38
+ type: "string",
39
+ enum: [
40
+ "agent-commands",
41
+ "system-commands",
42
+ "reporting-commands",
43
+ ],
44
+ description: "Type of commands to list",
45
+ default: "agent-commands",
63
46
  },
64
47
  },
65
- {
66
- name: "xray_explain_capability",
67
- description: "Get detailed explanation of a specific 0xRay capability",
68
- inputSchema: {
69
- type: "object",
70
- properties: {
71
- capability: {
72
- type: "string",
73
- description: "Name of the capability to explain",
74
- },
75
- },
76
- required: ["capability"],
48
+ required: [],
49
+ },
50
+ },
51
+ {
52
+ name: "xray_explain_capability",
53
+ description: "Get detailed explanation of a specific 0xRay capability",
54
+ inputSchema: {
55
+ type: "object",
56
+ properties: {
57
+ capability: {
58
+ type: "string",
59
+ description: "Name of the capability to explain",
77
60
  },
78
61
  },
79
- ],
80
- };
81
- });
82
- // Handle tool calls - required MCP protocol handler for tool execution
83
- this.server.setRequestHandler(CallToolRequestSchema, async (request) => {
84
- const { name, arguments: args } = request.params;
85
- try {
86
- switch (name) {
87
- case "xray_get_capabilities":
88
- return this.handleGetCapabilities(args);
89
- case "xray_get_commands":
90
- return this.handleGetCommands(args);
91
- case "xray_explain_capability":
92
- return this.handleExplainCapability(args);
93
- default:
94
- throw new McpError(ErrorCode.MethodNotFound, `Unknown tool: ${name}`);
95
- }
96
- }
97
- catch (error) {
98
- if (error instanceof McpError) {
99
- throw error;
100
- }
101
- frameworkLogger.log("mcps/framework-help", "tool-call", "error", { tool: name, error: String(error) });
102
- throw new McpError(ErrorCode.InternalError, `Tool "${name}" execution failed: ${error instanceof Error ? error.message : String(error)}`);
103
- }
104
- });
62
+ required: ["capability"],
63
+ },
64
+ },
65
+ ];
66
+ this.handlers = {
67
+ "xray_get_capabilities": async (args) => this.handleGetCapabilities(args),
68
+ "xray_get_commands": async (args) => this.handleGetCommands(args),
69
+ "xray_explain_capability": async (args) => this.handleExplainCapability(args),
70
+ };
71
+ this.setupToolHandlers();
105
72
  }
106
73
  getActiveAgentEntries() {
107
74
  return Object.values(AGENT_REGISTRY).filter((e) => e.status === "active");
@@ -386,15 +353,10 @@ ${items.map(([name, desc]) => `- **${name}**: ${desc}`).join("\n")}
386
353
  **Total:** ${items.length} ${category}
387
354
  `.trim();
388
355
  }
389
- async start() {
390
- const transport = new StdioServerTransport();
391
- await this.server.connect(transport);
392
- frameworkLogger.log("mcps/framework-help", "start", "info", { message: "0xRay Framework Help Server started" });
393
- }
394
356
  }
395
357
  // Auto-start if this file is run directly - conditional server initialization for development/testing
396
358
  if (import.meta.url === `file://${process.argv[1]}`) {
397
359
  const server = new FrameworkHelpServer();
398
- server.start().catch((error) => frameworkLogger.log("mcps/framework-help", "run", "error", { error: String(error) }));
360
+ server.run("xray/framework-help").catch((error) => frameworkLogger.log("mcps/framework-help", "run", "error", { error: String(error) }));
399
361
  }
400
362
  export { FrameworkHelpServer };
@@ -29,7 +29,7 @@ class GovernanceServer {
29
29
  server;
30
30
  constructor() {
31
31
  this.server = new Server({
32
- name: "governance", version: "2.0.1",
32
+ name: "governance", version: "2.1.1",
33
33
  }, {
34
34
  capabilities: {
35
35
  tools: {},
@@ -205,7 +205,7 @@ class GovernanceServer {
205
205
  })),
206
206
  context: args.context || {},
207
207
  options: {
208
- requireExternalDynamo: args.options?.require_external ?? true,
208
+ requireExternalDynamo: args.options?.require_external ?? !process.env.XRAY_LOCAL_MODE,
209
209
  },
210
210
  };
211
211
  frameworkLogger.log("governance-mcp", "delegating-to-governance-service", "info", {
@@ -4,12 +4,10 @@
4
4
  * Knowledge skill for API design patterns, RESTful conventions,
5
5
  * GraphQL schema design, and API documentation standards
6
6
  */
7
- declare class XrayApiDesignServer {
8
- private server;
7
+ import { XrayKnowledgeSkillBase } from "../shared/knowledge-skill-base.js";
8
+ declare class XrayApiDesignServer extends XrayKnowledgeSkillBase {
9
9
  constructor();
10
- private setupToolHandlers;
11
10
  private designApiEndpoints;
12
11
  private validateApiDesign;
13
- run(): Promise<void>;
14
12
  }
15
13
  export default XrayApiDesignServer;