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,100 +3,64 @@
3
3
  *
4
4
  * Comprehensive ESLint validation and automated code quality checking
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 { execFileSync } from "child_process";
10
7
  import fs from "fs";
11
8
  import { frameworkLogger } from "../core/framework-logger.js";
12
- class XrayLintServer {
13
- server;
9
+ import { XrayKnowledgeSkillBase } from "./shared/knowledge-skill-base.js";
10
+ class XrayLintServer extends XrayKnowledgeSkillBase {
14
11
  constructor() {
15
- this.server = new Server({
16
- name: "lint", version: "2.0.1",
17
- }, {
18
- capabilities: {
19
- tools: {},
20
- },
21
- });
22
- this.setupToolHandlers();
23
- void frameworkLogger.log("lint.server", "-xray-lint-mcp-server-initialized-", "info", { message: "0xRay Lint MCP Server initialized" });
24
- }
25
- setupToolHandlers() {
26
- // List available tools
27
- this.server.setRequestHandler(ListToolsRequestSchema, async () => {
28
- return {
29
- tools: [
30
- {
31
- name: "lint",
32
- description: "Comprehensive ESLint validation and automated code quality checking",
33
- inputSchema: {
34
- type: "object",
35
- properties: {
36
- files: {
37
- type: "array",
38
- items: { type: "string" },
39
- description: "Specific files to lint (optional - lints all if empty)",
40
- },
41
- fix: {
42
- type: "boolean",
43
- default: false,
44
- description: "Automatically fix linting issues where possible",
45
- },
46
- strict: {
47
- type: "boolean",
48
- default: false,
49
- description: "Use strict linting rules",
50
- },
51
- },
12
+ super("lint", "2.0.1");
13
+ this.tools = [
14
+ {
15
+ name: "lint",
16
+ description: "Comprehensive ESLint validation and automated code quality checking",
17
+ inputSchema: {
18
+ type: "object",
19
+ properties: {
20
+ files: {
21
+ type: "array",
22
+ items: { type: "string" },
23
+ description: "Specific files to lint (optional - lints all if empty)",
52
24
  },
53
- },
54
- {
55
- name: "lint-check",
56
- description: "Check code quality without making changes",
57
- inputSchema: {
58
- type: "object",
59
- properties: {
60
- files: {
61
- type: "array",
62
- items: { type: "string" },
63
- description: "Files to check",
64
- },
65
- rules: {
66
- type: "array",
67
- items: { type: "string" },
68
- description: "Specific ESLint rules to check",
69
- },
70
- },
25
+ fix: {
26
+ type: "boolean",
27
+ default: false,
28
+ description: "Automatically fix linting issues where possible",
29
+ },
30
+ strict: {
31
+ type: "boolean",
32
+ default: false,
33
+ description: "Use strict linting rules",
71
34
  },
72
35
  },
73
- ],
74
- };
75
- });
76
- // Handle tool calls
77
- this.server.setRequestHandler(CallToolRequestSchema, async (request) => {
78
- const { name, arguments: args } = request.params;
79
- try {
80
- switch (name) {
81
- case "lint":
82
- return await this.handleLint(args);
83
- case "lint-check":
84
- return await this.handleLintCheck(args);
85
- default:
86
- throw new Error(`Unknown tool: ${name}`);
87
- }
88
- }
89
- catch (error) {
90
- return {
91
- content: [
92
- {
93
- type: "text",
94
- text: `❌ Tool execution failed: ${error instanceof Error ? error.message : String(error)}`,
36
+ },
37
+ },
38
+ {
39
+ name: "lint-check",
40
+ description: "Check code quality without making changes",
41
+ inputSchema: {
42
+ type: "object",
43
+ properties: {
44
+ files: {
45
+ type: "array",
46
+ items: { type: "string" },
47
+ description: "Files to check",
95
48
  },
96
- ],
97
- };
98
- }
99
- });
49
+ rules: {
50
+ type: "array",
51
+ items: { type: "string" },
52
+ description: "Specific ESLint rules to check",
53
+ },
54
+ },
55
+ },
56
+ },
57
+ ];
58
+ this.handlers = {
59
+ "lint": async (args) => this.handleLint(args),
60
+ "lint-check": async (args) => this.handleLintCheck(args),
61
+ };
62
+ this.setupToolHandlers();
63
+ void frameworkLogger.log("lint.server", "-xray-lint-mcp-server-initialized-", "info", { message: "0xRay Lint MCP Server initialized" });
100
64
  }
101
65
  async handleLint(args) {
102
66
  const files = args.files || [];
@@ -367,15 +331,10 @@ ${checkResults.details.map((d) => `• ${d}`).join("\n")}
367
331
  - Warnings: ${results.issues.warnings}
368
332
  - Fixed: ${results.issues.fixed}`;
369
333
  }
370
- async run() {
371
- const transport = new StdioServerTransport();
372
- await this.server.connect(transport);
373
- await frameworkLogger.log("lint.server", "-xray-lint-mcp-server-started-", "info", { message: "0xRay Lint MCP Server started" });
374
- }
375
334
  }
376
335
  // Start the server if run directly
377
336
  if (import.meta.url === `file://${process.argv[1]}`) {
378
337
  const server = new XrayLintServer();
379
- server.run().catch((error) => frameworkLogger.log("mcps/lint", "run", "error", { error: String(error) }));
338
+ server.run("lint").catch((error) => frameworkLogger.log("mcps/lint", "run", "error", { error: String(error) }));
380
339
  }
381
340
  export { XrayLintServer };
@@ -98,7 +98,7 @@ export class MCPClient extends EventEmitter {
98
98
  * Pure MCP mode — simulation and generic fallbacks are disabled.
99
99
  */
100
100
  get isPureMcpMode() {
101
- return process.env.STRRAY_FORCE_MCP_GOVERNANCE === 'true';
101
+ return (process.env.XRAY_FORCE_MCP_GOVERNANCE) === 'true';
102
102
  }
103
103
  /**
104
104
  * Register default simulation implementations
@@ -375,7 +375,7 @@ export class MCPClient extends EventEmitter {
375
375
  // === LAST RESORT: Generic fallback (disabled in pure mode) ===
376
376
  if (this.isPureMcpMode) {
377
377
  throw new Error(`[PURE MCP] No real response for ${serverName}/${toolName}. ` +
378
- `All fallbacks are disabled when STRRAY_FORCE_MCP_GOVERNANCE=true.`);
378
+ `All fallbacks are disabled when XRAY_FORCE_MCP_GOVERNANCE=true.`);
379
379
  }
380
380
  const fallbackResult = {
381
381
  content: [
@@ -3,14 +3,12 @@
3
3
  *
4
4
  * Advanced model compatibility validation and dynamic health assessment
5
5
  */
6
- declare class XrayModelHealthCheckServer {
7
- private server;
6
+ import { XrayKnowledgeSkillBase } from "./shared/knowledge-skill-base.js";
7
+ declare class XrayModelHealthCheckServer extends XrayKnowledgeSkillBase {
8
8
  constructor();
9
- private setupToolHandlers;
10
9
  private handleModelHealthCheck;
11
10
  private checkModelHealth;
12
11
  private generateCompatibilityMatrix;
13
12
  private generateHealthReport;
14
- start(): Promise<void>;
15
13
  }
16
14
  export default XrayModelHealthCheckServer;
@@ -3,67 +3,44 @@
3
3
  *
4
4
  * Advanced model compatibility validation and dynamic health assessment
5
5
  */
6
- import { Server } from "@modelcontextprotocol/sdk/server/index.js";
7
- import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
8
6
  import { modelRouter } from "../core/model-router.js";
9
- import { CallToolRequestSchema, ListToolsRequestSchema, } from "@modelcontextprotocol/sdk/types.js";
10
7
  import { frameworkLogger } from "../core/framework-logger.js";
11
- class XrayModelHealthCheckServer {
12
- server;
8
+ import { XrayKnowledgeSkillBase } from "./shared/knowledge-skill-base.js";
9
+ class XrayModelHealthCheckServer extends XrayKnowledgeSkillBase {
13
10
  constructor() {
14
- this.server = new Server({
15
- name: "model-health-check", version: "2.0.1",
16
- }, {
17
- capabilities: {
18
- tools: {},
11
+ super("model-health-check", "2.0.1");
12
+ this.tools = [
13
+ {
14
+ name: "model-health-check",
15
+ description: "Advanced model compatibility validation and dynamic health assessment",
16
+ inputSchema: {
17
+ type: "object",
18
+ properties: {
19
+ models: {
20
+ type: "array",
21
+ items: { type: "string" },
22
+ description: "Specific models to check (optional - checks all configured if empty)",
23
+ },
24
+ compatibility: {
25
+ type: "boolean",
26
+ default: true,
27
+ description: "Include compatibility matrix in results",
28
+ },
29
+ performance: {
30
+ type: "boolean",
31
+ default: true,
32
+ description: "Include performance metrics in results",
33
+ },
34
+ },
35
+ },
19
36
  },
20
- });
37
+ ];
38
+ this.handlers = {
39
+ "model-health-check": async (args) => this.handleModelHealthCheck((args || {})),
40
+ };
21
41
  this.setupToolHandlers();
22
42
  frameworkLogger.log("mcps/model-health-check", "initialize", "info");
23
43
  }
24
- setupToolHandlers() {
25
- // List available tools
26
- this.server.setRequestHandler(ListToolsRequestSchema, async () => {
27
- return {
28
- tools: [
29
- {
30
- name: "model-health-check",
31
- description: "Advanced model compatibility validation and dynamic health assessment",
32
- inputSchema: {
33
- type: "object",
34
- properties: {
35
- models: {
36
- type: "array",
37
- items: { type: "string" },
38
- description: "Specific models to check (optional - checks all configured if empty)",
39
- },
40
- compatibility: {
41
- type: "boolean",
42
- default: true,
43
- description: "Include compatibility matrix in results",
44
- },
45
- performance: {
46
- type: "boolean",
47
- default: true,
48
- description: "Include performance metrics in results",
49
- },
50
- },
51
- },
52
- },
53
- ],
54
- };
55
- });
56
- // Handle tool calls
57
- this.server.setRequestHandler(CallToolRequestSchema, async (request) => {
58
- const { name, arguments: args } = request.params;
59
- switch (name) {
60
- case "model-health-check":
61
- return await this.handleModelHealthCheck((args || {}));
62
- default:
63
- throw new Error(`Unknown tool: ${name}`);
64
- }
65
- });
66
- }
67
44
  async handleModelHealthCheck(args) {
68
45
  const models = args.models || [modelRouter.getValidatedModel()];
69
46
  const includeCompatibility = args.compatibility !== false;
@@ -214,15 +191,10 @@ class XrayModelHealthCheckServer {
214
191
  }
215
192
  return report;
216
193
  }
217
- async start() {
218
- const transport = new StdioServerTransport();
219
- await this.server.connect(transport);
220
- frameworkLogger.log("mcps/model-health-check", "start", "info");
221
- }
222
194
  }
223
195
  // Start the server if this file is run directly
224
196
  if (import.meta.url === `file://${process.argv[1]}`) {
225
197
  const server = new XrayModelHealthCheckServer();
226
- server.start().catch((error) => frameworkLogger.log("mcps/model-health-check", "run", "error", { error: String(error) }));
198
+ server.run("model-health-check").catch((error) => frameworkLogger.log("mcps/model-health-check", "run", "error", { error: String(error) }));
227
199
  }
228
200
  export default XrayModelHealthCheckServer;
@@ -3,11 +3,10 @@
3
3
  *
4
4
  * Comprehensive metrics analysis for framework integration and optimization
5
5
  */
6
- declare class XrayPerformanceAnalysisServer {
7
- private server;
6
+ import { XrayKnowledgeSkillBase } from "./shared/knowledge-skill-base.js";
7
+ declare class XrayPerformanceAnalysisServer extends XrayKnowledgeSkillBase {
8
8
  private startTime;
9
9
  constructor();
10
- private setupToolHandlers;
11
10
  private handlePerformanceAnalysis;
12
11
  private handleBottleneckDetection;
13
12
  private analyzeRuntimePerformance;
@@ -22,6 +21,5 @@ declare class XrayPerformanceAnalysisServer {
22
21
  private generatePerformanceSummary;
23
22
  private formatMetrics;
24
23
  private generateDetailedReport;
25
- run(): Promise<void>;
26
24
  }
27
25
  export { XrayPerformanceAnalysisServer };
@@ -3,98 +3,74 @@
3
3
  *
4
4
  * Comprehensive metrics analysis for framework integration and optimization
5
5
  */
6
- import { Server } from "@modelcontextprotocol/sdk/server/index.js";
7
6
  import { frameworkLogger, generateJobId } from "../core/framework-logger.js";
8
- import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
9
- import { CallToolRequestSchema, ListToolsRequestSchema, } from "@modelcontextprotocol/sdk/types.js";
10
7
  import { execSync } from "child_process";
11
8
  import fs from "fs";
12
9
  import os from "os";
13
10
  import path from "path";
14
- class XrayPerformanceAnalysisServer {
15
- server;
11
+ import { XrayKnowledgeSkillBase } from "./shared/knowledge-skill-base.js";
12
+ class XrayPerformanceAnalysisServer extends XrayKnowledgeSkillBase {
16
13
  startTime;
17
14
  constructor() {
18
- this.server = new Server({
19
- name: "performance-analysis", version: "2.0.1",
20
- }, {
21
- capabilities: {
22
- tools: {},
23
- },
24
- });
15
+ super("performance-analysis", "2.0.1");
25
16
  this.startTime = Date.now();
26
- this.setupToolHandlers();
27
- frameworkLogger.log("mcp-performance-analysis", "server-initialized", "info");
28
- }
29
- setupToolHandlers() {
30
- // List available tools
31
- this.server.setRequestHandler(ListToolsRequestSchema, async () => {
32
- return {
33
- tools: [
34
- {
35
- name: "performance-analysis",
36
- description: "Comprehensive metrics analysis for framework integration and optimization",
37
- inputSchema: {
38
- type: "object",
39
- properties: {
40
- scope: {
41
- type: "string",
42
- enum: [
43
- "full",
44
- "runtime",
45
- "build",
46
- "resources",
47
- "bottlenecks",
48
- ],
49
- default: "full",
50
- description: "Scope of performance analysis",
51
- },
52
- duration: {
53
- type: "number",
54
- default: 30,
55
- description: "Analysis duration in seconds",
56
- },
57
- detailed: {
58
- type: "boolean",
59
- default: false,
60
- description: "Include detailed metrics and recommendations",
61
- },
62
- },
17
+ this.tools = [
18
+ {
19
+ name: "performance-analysis",
20
+ description: "Comprehensive metrics analysis for framework integration and optimization",
21
+ inputSchema: {
22
+ type: "object",
23
+ properties: {
24
+ scope: {
25
+ type: "string",
26
+ enum: [
27
+ "full",
28
+ "runtime",
29
+ "build",
30
+ "resources",
31
+ "bottlenecks",
32
+ ],
33
+ default: "full",
34
+ description: "Scope of performance analysis",
35
+ },
36
+ duration: {
37
+ type: "number",
38
+ default: 30,
39
+ description: "Analysis duration in seconds",
40
+ },
41
+ detailed: {
42
+ type: "boolean",
43
+ default: false,
44
+ description: "Include detailed metrics and recommendations",
63
45
  },
64
46
  },
65
- {
66
- name: "bottleneck-detection",
67
- description: "Identify performance bottlenecks in framework operations",
68
- inputSchema: {
69
- type: "object",
70
- properties: {
71
- operation: {
72
- type: "string",
73
- description: "Specific operation to analyze",
74
- },
75
- threshold: {
76
- type: "number",
77
- default: 1000,
78
- description: "Performance threshold in milliseconds",
79
- },
80
- },
47
+ },
48
+ },
49
+ {
50
+ name: "bottleneck-detection",
51
+ description: "Identify performance bottlenecks in framework operations",
52
+ inputSchema: {
53
+ type: "object",
54
+ properties: {
55
+ operation: {
56
+ type: "string",
57
+ description: "Specific operation to analyze",
58
+ },
59
+ threshold: {
60
+ type: "number",
61
+ default: 1000,
62
+ description: "Performance threshold in milliseconds",
81
63
  },
82
64
  },
83
- ],
84
- };
85
- });
86
- // Handle tool calls
87
- this.server.setRequestHandler(CallToolRequestSchema, async (request) => {
88
- const { name, arguments: args } = request.params;
89
- switch (name) {
90
- case "performance-analysis":
91
- return await this.handlePerformanceAnalysis(args);
92
- case "bottleneck-detection":
93
- return await this.handleBottleneckDetection(args);
94
- default:
95
- throw new Error(`Unknown tool: ${name}`);
96
- }
97
- });
65
+ },
66
+ },
67
+ ];
68
+ this.handlers = {
69
+ "performance-analysis": async (args) => this.handlePerformanceAnalysis(args),
70
+ "bottleneck-detection": async (args) => this.handleBottleneckDetection(args),
71
+ };
72
+ this.setupToolHandlers();
73
+ frameworkLogger.log("mcp-performance-analysis", "server-initialized", "info");
98
74
  }
99
75
  async handlePerformanceAnalysis(args) {
100
76
  const scope = args?.scope || "full";
@@ -503,17 +479,10 @@ ${results.recommendations.map((r) => `• 💡 ${r}`).join("\n") || "No recommen
503
479
  }
504
480
  return report;
505
481
  }
506
- async run() {
507
- const transport = new StdioServerTransport();
508
- await this.server.connect(transport);
509
- const jobId = generateJobId("mcp-performance-analysis-server");
510
- await frameworkLogger.log("mcp-performance-analysis", "server-started", "success", {}, undefined, // sessionId
511
- jobId);
512
- }
513
482
  }
514
483
  // Start the server if run directly
515
484
  if (import.meta.url === `file://${process.argv[1]}`) {
516
485
  const server = new XrayPerformanceAnalysisServer();
517
- server.run().catch((error) => frameworkLogger.log("mcps/performance-analysis", "run", "error", { error: String(error) }));
486
+ server.run("performance-analysis").catch((error) => frameworkLogger.log("mcps/performance-analysis", "run", "error", { error: String(error) }));
518
487
  }
519
488
  export { XrayPerformanceAnalysisServer };
@@ -3,14 +3,13 @@
3
3
  *
4
4
  * Advanced processor pipeline with codex validation, compliance monitoring, and framework enforcement
5
5
  */
6
- declare class XrayProcessorPipelineServer {
7
- private server;
6
+ import { XrayKnowledgeSkillBase } from "./shared/knowledge-skill-base.js";
7
+ declare class XrayProcessorPipelineServer extends XrayKnowledgeSkillBase {
8
8
  private codexLoader;
9
9
  private codexRules;
10
10
  private codexTerms;
11
11
  constructor();
12
12
  private loadCodexRules;
13
- private setupToolHandlers;
14
13
  private handlePreProcessors;
15
14
  private handlePostProcessors;
16
15
  private handleCodexValidation;
@@ -26,6 +25,5 @@ declare class XrayProcessorPipelineServer {
26
25
  private performQualityAssurance;
27
26
  private detectContentType;
28
27
  private checkFrameworkCompliance;
29
- run(): Promise<void>;
30
28
  }
31
29
  export { XrayProcessorPipelineServer };