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
@@ -4,161 +4,136 @@
4
4
  * Knowledge skill for database architecture, schema optimization,
5
5
  * query performance analysis, and data modeling best practices
6
6
  */
7
- import { Server } from "@modelcontextprotocol/sdk/server/index.js";
8
- import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
9
- import { CallToolRequestSchema, ListToolsRequestSchema, } from "@modelcontextprotocol/sdk/types.js";
7
+ import { XrayKnowledgeSkillBase } from "../shared/knowledge-skill-base.js";
8
+ import { frameworkLogger } from "../../core/framework-logger.js";
10
9
  import * as fs from "fs";
11
10
  import * as path from "path";
12
- import { createGracefulShutdown } from "../../utils/shutdown-handler.js";
13
- class XrayDatabaseDesignServer {
14
- server;
11
+ class XrayDatabaseDesignServer extends XrayKnowledgeSkillBase {
15
12
  constructor() {
16
- this.server = new Server({
17
- name: "database-design", version: "2.0.1",
18
- }, {
19
- capabilities: {
20
- tools: {},
21
- },
22
- });
23
- this.setupToolHandlers();
24
- // Server initialization - removed unnecessary startup logging
25
- }
26
- setupToolHandlers() {
27
- this.server.setRequestHandler(ListToolsRequestSchema, async () => {
28
- return {
29
- tools: [
30
- {
31
- name: "analyze_schema",
32
- description: "Analyze database schema for optimization opportunities and best practices",
33
- inputSchema: {
34
- type: "object",
35
- properties: {
36
- schemaFile: {
37
- type: "string",
38
- description: "Path to schema definition file (SQL, migration, or ORM model)",
39
- },
40
- databaseType: {
41
- type: "string",
42
- enum: ["postgresql", "mysql", "sqlite", "mongodb", "redis"],
43
- description: "Database type for specific optimizations",
44
- },
45
- includeIndexes: {
46
- type: "boolean",
47
- description: "Include index recommendations in analysis",
48
- default: true,
49
- },
50
- },
51
- required: ["schemaFile"],
13
+ super("database-design", "2.0.1");
14
+ this.tools = [
15
+ {
16
+ name: "analyze_schema",
17
+ description: "Analyze database schema for optimization opportunities and best practices",
18
+ inputSchema: {
19
+ type: "object",
20
+ properties: {
21
+ schemaFile: {
22
+ type: "string",
23
+ description: "Path to schema definition file (SQL, migration, or ORM model)",
24
+ },
25
+ databaseType: {
26
+ type: "string",
27
+ enum: ["postgresql", "mysql", "sqlite", "mongodb", "redis"],
28
+ description: "Database type for specific optimizations",
29
+ },
30
+ includeIndexes: {
31
+ type: "boolean",
32
+ description: "Include index recommendations in analysis",
33
+ default: true,
52
34
  },
53
35
  },
54
- {
55
- name: "optimize_query",
56
- description: "Analyze and optimize SQL queries for better performance",
57
- inputSchema: {
58
- type: "object",
59
- properties: {
60
- query: {
61
- type: "string",
62
- description: "SQL query to analyze and optimize",
63
- },
64
- schemaContext: {
65
- type: "string",
66
- description: "Schema context or file path for better analysis",
67
- },
68
- databaseType: {
69
- type: "string",
70
- enum: ["postgresql", "mysql", "sqlite"],
71
- description: "Database type for query optimization",
72
- },
73
- },
74
- required: ["query"],
36
+ required: ["schemaFile"],
37
+ },
38
+ },
39
+ {
40
+ name: "optimize_query",
41
+ description: "Analyze and optimize SQL queries for better performance",
42
+ inputSchema: {
43
+ type: "object",
44
+ properties: {
45
+ query: {
46
+ type: "string",
47
+ description: "SQL query to analyze and optimize",
48
+ },
49
+ schemaContext: {
50
+ type: "string",
51
+ description: "Schema context or file path for better analysis",
52
+ },
53
+ databaseType: {
54
+ type: "string",
55
+ enum: ["postgresql", "mysql", "sqlite"],
56
+ description: "Database type for query optimization",
75
57
  },
76
58
  },
77
- {
78
- name: "design_data_model",
79
- description: "Design optimal data model for given requirements",
80
- inputSchema: {
81
- type: "object",
82
- properties: {
83
- requirements: {
84
- type: "string",
85
- description: "Business requirements and data access patterns",
86
- },
87
- entities: {
88
- type: "array",
89
- items: { type: "string" },
90
- description: "List of main entities/business objects",
91
- },
92
- relationships: {
93
- type: "array",
94
- items: {
95
- type: "object",
96
- properties: {
97
- from: { type: "string" },
98
- to: { type: "string" },
99
- type: {
100
- type: "string",
101
- enum: ["one-to-one", "one-to-many", "many-to-many"],
102
- },
103
- },
59
+ required: ["query"],
60
+ },
61
+ },
62
+ {
63
+ name: "design_data_model",
64
+ description: "Design optimal data model for given requirements",
65
+ inputSchema: {
66
+ type: "object",
67
+ properties: {
68
+ requirements: {
69
+ type: "string",
70
+ description: "Business requirements and data access patterns",
71
+ },
72
+ entities: {
73
+ type: "array",
74
+ items: { type: "string" },
75
+ description: "List of main entities/business objects",
76
+ },
77
+ relationships: {
78
+ type: "array",
79
+ items: {
80
+ type: "object",
81
+ properties: {
82
+ from: { type: "string" },
83
+ to: { type: "string" },
84
+ type: {
85
+ type: "string",
86
+ enum: ["one-to-one", "one-to-many", "many-to-many"],
104
87
  },
105
- description: "Entity relationships",
106
- },
107
- databaseType: {
108
- type: "string",
109
- enum: ["postgresql", "mysql", "mongodb", "redis"],
110
- description: "Target database type",
111
88
  },
112
89
  },
113
- required: ["requirements", "entities"],
90
+ description: "Entity relationships",
91
+ },
92
+ databaseType: {
93
+ type: "string",
94
+ enum: ["postgresql", "mysql", "mongodb", "redis"],
95
+ description: "Target database type",
114
96
  },
115
97
  },
116
- {
117
- name: "migrate_schema",
118
- description: "Generate migration scripts for schema changes",
119
- inputSchema: {
120
- type: "object",
121
- properties: {
122
- currentSchema: {
123
- type: "string",
124
- description: "Current schema definition",
125
- },
126
- targetSchema: {
127
- type: "string",
128
- description: "Target schema definition",
129
- },
130
- databaseType: {
131
- type: "string",
132
- enum: ["postgresql", "mysql", "sqlite"],
133
- description: "Database type for migration",
134
- },
135
- safeMode: {
136
- type: "boolean",
137
- description: "Generate rollback scripts and safety checks",
138
- default: true,
139
- },
140
- },
141
- required: ["currentSchema", "targetSchema"],
98
+ required: ["requirements", "entities"],
99
+ },
100
+ },
101
+ {
102
+ name: "migrate_schema",
103
+ description: "Generate migration scripts for schema changes",
104
+ inputSchema: {
105
+ type: "object",
106
+ properties: {
107
+ currentSchema: {
108
+ type: "string",
109
+ description: "Current schema definition",
110
+ },
111
+ targetSchema: {
112
+ type: "string",
113
+ description: "Target schema definition",
114
+ },
115
+ databaseType: {
116
+ type: "string",
117
+ enum: ["postgresql", "mysql", "sqlite"],
118
+ description: "Database type for migration",
119
+ },
120
+ safeMode: {
121
+ type: "boolean",
122
+ description: "Generate rollback scripts and safety checks",
123
+ default: true,
142
124
  },
143
125
  },
144
- ],
145
- };
146
- });
147
- this.server.setRequestHandler(CallToolRequestSchema, async (request) => {
148
- const { name, arguments: args } = request.params;
149
- switch (name) {
150
- case "analyze_schema":
151
- return await this.analyzeSchema(args);
152
- case "optimize_query":
153
- return await this.optimizeQuery(args);
154
- case "design_data_model":
155
- return await this.designDataModel(args);
156
- case "migrate_schema":
157
- return await this.migrateSchema(args);
158
- default:
159
- throw new Error(`Unknown tool: ${name}`);
160
- }
161
- });
126
+ required: ["currentSchema", "targetSchema"],
127
+ },
128
+ },
129
+ ];
130
+ this.handlers = {
131
+ "analyze_schema": async (args) => this.analyzeSchema(args),
132
+ "optimize_query": async (args) => this.optimizeQuery(args),
133
+ "design_data_model": async (args) => this.designDataModel(args),
134
+ "migrate_schema": async (args) => this.migrateSchema(args),
135
+ };
136
+ this.setupToolHandlers();
162
137
  }
163
138
  async analyzeSchema(args) {
164
139
  const { schemaFile, databaseType = "postgresql", includeIndexes = true, } = args;
@@ -804,19 +779,10 @@ class XrayDatabaseDesignServer {
804
779
  };
805
780
  return icons[severity] || "❓";
806
781
  }
807
- async run() {
808
- const transport = new StdioServerTransport();
809
- await this.server.connect(transport);
810
- // Use centralized shutdown handler
811
- createGracefulShutdown({
812
- serverName: "database-design.server",
813
- server: this.server,
814
- });
815
- }
816
782
  }
817
783
  // Run the server if this file is executed directly
818
784
  if (import.meta.url === `file://${process.argv[1]}`) {
819
785
  const server = new XrayDatabaseDesignServer();
820
- server.run().catch(() => { });
786
+ server.run("database-design").catch((err) => { frameworkLogger.log("database-design", "run", "error", { error: err instanceof Error ? err.message : String(err) }); });
821
787
  }
822
788
  export { XrayDatabaseDesignServer };
@@ -4,10 +4,9 @@
4
4
  * Knowledge skill for DevOps practices, deployment strategies,
5
5
  * CI/CD pipeline design, and infrastructure automation
6
6
  */
7
- declare class XrayDevOpsDeploymentServer {
8
- private server;
7
+ import { XrayKnowledgeSkillBase } from "../shared/knowledge-skill-base.js";
8
+ declare class XrayDevOpsDeploymentServer extends XrayKnowledgeSkillBase {
9
9
  constructor();
10
- private setupToolHandlers;
11
10
  private analyzeCICDPipeline;
12
11
  private designDeploymentStrategy;
13
12
  private generateInfrastructureCode;
@@ -38,6 +37,5 @@ declare class XrayDevOpsDeploymentServer {
38
37
  private analyzeStageDistribution;
39
38
  private identifyPipelineOptimizations;
40
39
  private getInfrastructureLanguage;
41
- run(): Promise<void>;
42
40
  }
43
41
  export { XrayDevOpsDeploymentServer };
@@ -4,169 +4,89 @@
4
4
  * Knowledge skill for DevOps practices, deployment strategies,
5
5
  * CI/CD pipeline design, and infrastructure automation
6
6
  */
7
- import { Server } from "@modelcontextprotocol/sdk/server/index.js";
8
- import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
9
- import { createGracefulShutdown } from "../../utils/shutdown-handler.js";
10
- import { CallToolRequestSchema, ListToolsRequestSchema, } from "@modelcontextprotocol/sdk/types.js";
11
- class XrayDevOpsDeploymentServer {
12
- server;
7
+ import { XrayKnowledgeSkillBase } from "../shared/knowledge-skill-base.js";
8
+ import { frameworkLogger } from "../../core/framework-logger.js";
9
+ class XrayDevOpsDeploymentServer extends XrayKnowledgeSkillBase {
13
10
  constructor() {
14
- this.server = new Server({
15
- name: "devops-deployment", version: "2.0.1",
16
- }, {
17
- capabilities: {
18
- tools: {},
11
+ super("devops-deployment", "2.0.1");
12
+ this.tools = [
13
+ {
14
+ name: "analyze_ci_cd_pipeline",
15
+ description: "Analyze CI/CD pipeline configuration and suggest optimizations",
16
+ inputSchema: {
17
+ type: "object",
18
+ properties: {
19
+ pipelineConfig: { type: "string", description: "CI/CD pipeline configuration (YAML/JSON)" },
20
+ platform: { type: "string", enum: ["github-actions", "gitlab-ci", "jenkins", "circle-ci", "azure-devops"], description: "CI/CD platform being used" },
21
+ includeSecurity: { type: "boolean", description: "Include security gate analysis", default: true },
22
+ },
23
+ required: ["pipelineConfig", "platform"],
24
+ },
19
25
  },
20
- });
21
- this.setupToolHandlers();
22
- // Server initialization - removed unnecessary startup logging
23
- }
24
- setupToolHandlers() {
25
- this.server.setRequestHandler(ListToolsRequestSchema, async () => {
26
- return {
27
- tools: [
28
- {
29
- name: "analyze_ci_cd_pipeline",
30
- description: "Analyze CI/CD pipeline configuration and suggest optimizations",
31
- inputSchema: {
32
- type: "object",
33
- properties: {
34
- pipelineConfig: {
35
- type: "string",
36
- description: "CI/CD pipeline configuration (YAML/JSON)",
37
- },
38
- platform: {
39
- type: "string",
40
- enum: [
41
- "github-actions",
42
- "gitlab-ci",
43
- "jenkins",
44
- "circle-ci",
45
- "azure-devops",
46
- ],
47
- description: "CI/CD platform being used",
48
- },
49
- includeSecurity: {
50
- type: "boolean",
51
- description: "Include security gate analysis",
52
- default: true,
53
- },
54
- },
55
- required: ["pipelineConfig", "platform"],
56
- },
26
+ {
27
+ name: "design_deployment_strategy",
28
+ description: "Design optimal deployment strategy for application requirements",
29
+ inputSchema: {
30
+ type: "object",
31
+ properties: {
32
+ applicationType: { type: "string", enum: ["web-app", "api", "mobile", "microservices", "monolith"], description: "Type of application" },
33
+ scale: { type: "string", enum: ["small", "medium", "large", "enterprise"], description: "Expected scale/traffic" },
34
+ availability: { type: "string", enum: ["basic", "high", "critical"], description: "Required availability level" },
35
+ budget: { type: "string", enum: ["cost-optimized", "balanced", "performance-optimized"], description: "Budget considerations" },
57
36
  },
58
- {
59
- name: "design_deployment_strategy",
60
- description: "Design optimal deployment strategy for application requirements",
61
- inputSchema: {
62
- type: "object",
63
- properties: {
64
- applicationType: {
65
- type: "string",
66
- enum: [
67
- "web-app",
68
- "api",
69
- "mobile",
70
- "microservices",
71
- "monolith",
72
- ],
73
- description: "Type of application",
74
- },
75
- scale: {
76
- type: "string",
77
- enum: ["small", "medium", "large", "enterprise"],
78
- description: "Expected scale/traffic",
79
- },
80
- availability: {
81
- type: "string",
82
- enum: ["basic", "high", "critical"],
83
- description: "Required availability level",
84
- },
85
- budget: {
86
- type: "string",
87
- enum: ["cost-optimized", "balanced", "performance-optimized"],
88
- description: "Budget considerations",
89
- },
90
- },
91
- required: ["applicationType", "scale"],
92
- },
37
+ required: ["applicationType", "scale"],
38
+ },
39
+ },
40
+ {
41
+ name: "generate_infrastructure_code",
42
+ description: "Generate infrastructure as code for deployment",
43
+ inputSchema: {
44
+ type: "object",
45
+ properties: {
46
+ platform: { type: "string", enum: ["aws", "azure", "gcp", "kubernetes"], description: "Target cloud platform" },
47
+ services: { type: "array", items: { type: "string" }, description: "Required services (database, cache, storage, etc.)" },
48
+ environment: { type: "string", enum: ["development", "staging", "production"], description: "Deployment environment" },
49
+ scaling: { type: "boolean", description: "Include auto-scaling configuration", default: true },
93
50
  },
94
- {
95
- name: "generate_infrastructure_code",
96
- description: "Generate infrastructure as code for deployment",
97
- inputSchema: {
51
+ required: ["platform", "services"],
52
+ },
53
+ },
54
+ {
55
+ name: "optimize_deployment_performance",
56
+ description: "Analyze and optimize deployment performance and reliability",
57
+ inputSchema: {
58
+ type: "object",
59
+ properties: {
60
+ currentMetrics: {
98
61
  type: "object",
99
62
  properties: {
100
- platform: {
101
- type: "string",
102
- enum: ["aws", "azure", "gcp", "kubernetes"],
103
- description: "Target cloud platform",
104
- },
105
- services: {
106
- type: "array",
107
- items: { type: "string" },
108
- description: "Required services (database, cache, storage, etc.)",
109
- },
110
- environment: {
111
- type: "string",
112
- enum: ["development", "staging", "production"],
113
- description: "Deployment environment",
114
- },
115
- scaling: {
116
- type: "boolean",
117
- description: "Include auto-scaling configuration",
118
- default: true,
119
- },
63
+ deployTime: { type: "number" },
64
+ failureRate: { type: "number" },
65
+ rollbackTime: { type: "number" },
120
66
  },
121
- required: ["platform", "services"],
67
+ description: "Current deployment metrics",
122
68
  },
123
- },
124
- {
125
- name: "optimize_deployment_performance",
126
- description: "Analyze and optimize deployment performance and reliability",
127
- inputSchema: {
69
+ constraints: {
128
70
  type: "object",
129
71
  properties: {
130
- currentMetrics: {
131
- type: "object",
132
- properties: {
133
- deployTime: { type: "number" },
134
- failureRate: { type: "number" },
135
- rollbackTime: { type: "number" },
136
- },
137
- description: "Current deployment metrics",
138
- },
139
- constraints: {
140
- type: "object",
141
- properties: {
142
- maxDowntime: { type: "number" },
143
- budget: { type: "number" },
144
- teamSize: { type: "number" },
145
- },
146
- description: "Business and technical constraints",
147
- },
72
+ maxDowntime: { type: "number" },
73
+ budget: { type: "number" },
74
+ teamSize: { type: "number" },
148
75
  },
149
- required: ["currentMetrics"],
76
+ description: "Business and technical constraints",
150
77
  },
151
78
  },
152
- ],
153
- };
154
- });
155
- this.server.setRequestHandler(CallToolRequestSchema, async (request) => {
156
- const { name, arguments: args } = request.params;
157
- switch (name) {
158
- case "analyze_ci_cd_pipeline":
159
- return await this.analyzeCICDPipeline(args);
160
- case "design_deployment_strategy":
161
- return await this.designDeploymentStrategy(args);
162
- case "generate_infrastructure_code":
163
- return await this.generateInfrastructureCode(args);
164
- case "optimize_deployment_performance":
165
- return await this.optimizeDeploymentPerformance(args);
166
- default:
167
- throw new Error(`Unknown tool: ${name}`);
168
- }
169
- });
79
+ required: ["currentMetrics"],
80
+ },
81
+ },
82
+ ];
83
+ this.handlers = {
84
+ "analyze_ci_cd_pipeline": async (args) => this.analyzeCICDPipeline(args),
85
+ "design_deployment_strategy": async (args) => this.designDeploymentStrategy(args),
86
+ "generate_infrastructure_code": async (args) => this.generateInfrastructureCode(args),
87
+ "optimize_deployment_performance": async (args) => this.optimizeDeploymentPerformance(args),
88
+ };
89
+ this.setupToolHandlers();
170
90
  }
171
91
  async analyzeCICDPipeline(args) {
172
92
  const { pipelineConfig, platform, includeSecurity = true } = args;
@@ -1162,19 +1082,10 @@ spec:
1162
1082
  return "json";
1163
1083
  }
1164
1084
  }
1165
- async run() {
1166
- const transport = new StdioServerTransport();
1167
- await this.server.connect(transport);
1168
- // Use centralized shutdown handler
1169
- createGracefulShutdown({
1170
- serverName: "devops-deployment.server",
1171
- server: this.server,
1172
- });
1173
- }
1174
1085
  }
1175
1086
  // Run the server if this file is executed directly
1176
1087
  if (import.meta.url === `file://${process.argv[1]}`) {
1177
1088
  const server = new XrayDevOpsDeploymentServer();
1178
- server.run().catch(() => { });
1089
+ server.run("devops-deployment").catch((err) => { frameworkLogger.log("devops-deployment", "run", "error", { error: err instanceof Error ? err.message : String(err) }); });
1179
1090
  }
1180
1091
  export { XrayDevOpsDeploymentServer };
@@ -4,12 +4,10 @@
4
4
  * Knowledge skill for version control strategies, branching models,
5
5
  * and collaborative development workflows
6
6
  */
7
- declare class XrayGitWorkflowServer {
8
- private server;
7
+ import { XrayKnowledgeSkillBase } from "../shared/knowledge-skill-base.js";
8
+ declare class XrayGitWorkflowServer extends XrayKnowledgeSkillBase {
9
9
  constructor();
10
- private setupToolHandlers;
11
10
  private analyzeGitHistory;
12
11
  private recommendBranchingStrategy;
13
- run(): Promise<void>;
14
12
  }
15
13
  export default XrayGitWorkflowServer;