0xray 2.1.2 → 2.1.4
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.
- package/.opencode/codex.codex +1 -1
- package/.opencode/commands/dependency-audit.md +3 -3
- package/.opencode/enforcer-config.json +2 -2
- package/AGENTS.md +2 -1
- package/README.md +12 -11
- package/dist/AGENTS.md +2 -1
- package/dist/CHANGELOG.md +38 -0
- package/dist/README.md +12 -11
- package/dist/agents/code-reviewer.js +1 -1
- package/dist/analytics/routing-refiner.js +1 -1
- package/dist/cli/index.js +11 -1
- package/dist/cli/server.js +3 -3
- package/dist/core/activity-logger.d.ts +2 -2
- package/dist/core/activity-logger.js +4 -4
- package/dist/core/boot-orchestrator.d.ts +1 -1
- package/dist/core/boot-orchestrator.js +13 -28
- package/dist/core/bridge.mjs +3 -3
- package/dist/core/codex-formatter.js +2 -2
- package/dist/core/codex-injector.d.ts +0 -1
- package/dist/core/codex-injector.js +2 -3
- package/dist/core/config-loader.d.ts +1 -1
- package/dist/core/config-loader.js +1 -1
- package/dist/core/config-paths.d.ts +0 -2
- package/dist/core/config-paths.js +7 -8
- package/dist/core/context-loader.d.ts +1 -1
- package/dist/core/context-loader.js +1 -1
- package/dist/core/errors.d.ts +3 -0
- package/dist/core/errors.js +10 -0
- package/dist/core/features-config.js +1 -1
- package/dist/core/framework-logger.d.ts +3 -3
- package/dist/core/framework-logger.js +17 -9
- package/dist/core/index.d.ts +2 -2
- package/dist/core/index.js +4 -2
- package/dist/core/logging-config.d.ts +2 -1
- package/dist/core/logging-config.js +7 -7
- package/dist/enforcement/loaders/codex-loader.js +1 -1
- package/dist/execution/opencode-cli-invoker.js +5 -5
- package/dist/governance/governance-service.js +1 -1
- package/dist/index.d.ts +3 -3
- package/dist/index.js +3 -3
- package/dist/inference/inference-cycle.d.ts +1 -1
- package/dist/inference/inference-cycle.js +10 -10
- package/dist/integrations/base/Integration.js +1 -1
- package/dist/integrations/base/registry.js +19 -19
- package/dist/integrations/grok/grok-cli.js +17 -17
- package/dist/integrations/grok/hooks/pre-tool-use.js +1 -1
- package/dist/integrations/hermes-agent/bridge.mjs +1 -1
- package/dist/integrations/openclaw/api-server.d.ts +0 -1
- package/dist/integrations/openclaw/api-server.js +7 -10
- package/dist/integrations/openclaw/client.d.ts +0 -1
- package/dist/integrations/openclaw/client.js +22 -24
- package/dist/integrations/openclaw/hooks/xray-hooks.d.ts +0 -1
- package/dist/integrations/openclaw/hooks/xray-hooks.js +17 -18
- package/dist/integrations/plugins/plugin-registry.js +5 -5
- package/dist/mcps/architect-tools.server.d.ts +2 -4
- package/dist/mcps/architect-tools.server.js +112 -195
- package/dist/mcps/auto-format.server.d.ts +2 -4
- package/dist/mcps/auto-format.server.js +49 -95
- package/dist/mcps/boot-orchestrator.server.d.ts +2 -4
- package/dist/mcps/boot-orchestrator.server.js +73 -105
- package/dist/mcps/config/server-config-registry.js +3 -3
- package/dist/mcps/enforcer-tools.server.d.ts +2 -4
- package/dist/mcps/enforcer-tools.server.js +202 -285
- package/dist/mcps/estimation.server.d.ts +2 -4
- package/dist/mcps/estimation.server.js +63 -107
- package/dist/mcps/framework-compliance-audit.server.d.ts +2 -4
- package/dist/mcps/framework-compliance-audit.server.js +53 -82
- package/dist/mcps/framework-help.server.d.ts +2 -4
- package/dist/mcps/framework-help.server.js +63 -101
- package/dist/mcps/governance.server.js +2 -2
- package/dist/mcps/knowledge-skills/api-design.server.d.ts +2 -4
- package/dist/mcps/knowledge-skills/api-design.server.js +35 -67
- package/dist/mcps/knowledge-skills/architecture-patterns.server.d.ts +2 -10
- package/dist/mcps/knowledge-skills/architecture-patterns.server.js +35 -74
- package/dist/mcps/knowledge-skills/bug-triage-specialist.server.d.ts +2 -4
- package/dist/mcps/knowledge-skills/bug-triage-specialist.server.js +143 -162
- package/dist/mcps/knowledge-skills/code-analyzer.server.d.ts +3 -4
- package/dist/mcps/knowledge-skills/code-analyzer.server.js +20 -45
- package/dist/mcps/knowledge-skills/code-review.server.d.ts +2 -4
- package/dist/mcps/knowledge-skills/code-review.server.js +109 -143
- package/dist/mcps/knowledge-skills/content-creator.server.d.ts +2 -4
- package/dist/mcps/knowledge-skills/content-creator.server.js +205 -226
- package/dist/mcps/knowledge-skills/database-design.server.d.ts +2 -4
- package/dist/mcps/knowledge-skills/database-design.server.js +117 -151
- package/dist/mcps/knowledge-skills/devops-deployment.server.d.ts +2 -4
- package/dist/mcps/knowledge-skills/devops-deployment.server.js +71 -160
- package/dist/mcps/knowledge-skills/git-workflow.server.d.ts +2 -4
- package/dist/mcps/knowledge-skills/git-workflow.server.js +36 -68
- package/dist/mcps/knowledge-skills/growth-strategist.server.d.ts +2 -4
- package/dist/mcps/knowledge-skills/growth-strategist.server.js +303 -324
- package/dist/mcps/knowledge-skills/log-monitor.server.d.ts +2 -4
- package/dist/mcps/knowledge-skills/log-monitor.server.js +141 -160
- package/dist/mcps/knowledge-skills/mobile-development.server.d.ts +2 -4
- package/dist/mcps/knowledge-skills/mobile-development.server.js +92 -209
- package/dist/mcps/knowledge-skills/multimodal-looker.server.d.ts +2 -4
- package/dist/mcps/knowledge-skills/multimodal-looker.server.js +123 -159
- package/dist/mcps/knowledge-skills/performance-optimization.server.d.ts +2 -5
- package/dist/mcps/knowledge-skills/performance-optimization.server.js +155 -296
- package/dist/mcps/knowledge-skills/project-analysis.server.d.ts +2 -4
- package/dist/mcps/knowledge-skills/project-analysis.server.js +75 -226
- package/dist/mcps/knowledge-skills/refactoring-strategies.server.d.ts +2 -4
- package/dist/mcps/knowledge-skills/refactoring-strategies.server.js +63 -156
- package/dist/mcps/knowledge-skills/security-audit.server.d.ts +2 -4
- package/dist/mcps/knowledge-skills/security-audit.server.js +102 -136
- package/dist/mcps/knowledge-skills/seo-consultant.server.d.ts +2 -4
- package/dist/mcps/knowledge-skills/seo-consultant.server.js +80 -203
- package/dist/mcps/knowledge-skills/session-management.server.d.ts +2 -4
- package/dist/mcps/knowledge-skills/session-management.server.js +50 -203
- package/dist/mcps/knowledge-skills/skill-invocation.server.d.ts +2 -4
- package/dist/mcps/knowledge-skills/skill-invocation.server.js +168 -347
- package/dist/mcps/knowledge-skills/strategist.server.d.ts +2 -11
- package/dist/mcps/knowledge-skills/strategist.server.js +72 -122
- package/dist/mcps/knowledge-skills/tech-writer.server.d.ts +2 -4
- package/dist/mcps/knowledge-skills/tech-writer.server.js +87 -300
- package/dist/mcps/knowledge-skills/testing-best-practices.server.d.ts +2 -4
- package/dist/mcps/knowledge-skills/testing-best-practices.server.js +147 -182
- package/dist/mcps/knowledge-skills/testing-strategy.server.d.ts +2 -4
- package/dist/mcps/knowledge-skills/testing-strategy.server.js +78 -153
- package/dist/mcps/knowledge-skills/ui-ux-design.server.d.ts +2 -5
- package/dist/mcps/knowledge-skills/ui-ux-design.server.js +90 -399
- package/dist/mcps/lint.server.d.ts +2 -4
- package/dist/mcps/lint.server.js +51 -92
- package/dist/mcps/mcp-client.js +2 -2
- package/dist/mcps/model-health-check.server.d.ts +2 -4
- package/dist/mcps/model-health-check.server.js +32 -60
- package/dist/mcps/performance-analysis.server.d.ts +2 -4
- package/dist/mcps/performance-analysis.server.js +57 -88
- package/dist/mcps/processor-pipeline.server.d.ts +2 -4
- package/dist/mcps/processor-pipeline.server.js +69 -100
- package/dist/mcps/registry.json +1 -1
- package/dist/mcps/researcher.server.d.ts +3 -5
- package/dist/mcps/researcher.server.js +81 -154
- package/dist/mcps/security-scan.server.d.ts +2 -4
- package/dist/mcps/security-scan.server.js +54 -96
- package/dist/mcps/shared/knowledge-skill-base.d.ts +14 -0
- package/dist/mcps/shared/knowledge-skill-base.js +45 -0
- package/dist/{security → mcps/shared}/security-scanner.js +1 -1
- package/dist/mcps/state-manager.server.d.ts +2 -4
- package/dist/mcps/state-manager.server.js +115 -160
- package/dist/orchestrator/orchestrator.d.ts +1 -1
- package/dist/orchestrator/orchestrator.js +1 -1
- package/dist/orchestrator/universal-registry-bridge.js +1 -1
- package/dist/plugin/xray-codex-injection.d.ts +1 -1
- package/dist/plugin/xray-codex-injection.js +1 -1
- package/dist/postprocessor/PostProcessor.d.ts +4 -44
- package/dist/postprocessor/PostProcessor.js +39 -553
- package/dist/postprocessor/analysis/CodeChangeAnalyzer.d.ts +11 -0
- package/dist/postprocessor/analysis/CodeChangeAnalyzer.js +50 -0
- package/dist/postprocessor/compliance/ArchitecturalComplianceChecker.d.ts +11 -0
- package/dist/postprocessor/compliance/ArchitecturalComplianceChecker.js +356 -0
- package/dist/postprocessor/config/ProcessorConfigLoader.d.ts +44 -0
- package/dist/postprocessor/config/ProcessorConfigLoader.js +21 -0
- package/dist/postprocessor/reporting/PostProcessorReporter.d.ts +19 -0
- package/dist/postprocessor/reporting/PostProcessorReporter.js +96 -0
- package/dist/postprocessor/triggers/GitHookTrigger.js +11 -11
- package/dist/processors/implementations/refactoring-logging-processor-wrapper.d.ts +32 -0
- package/dist/processors/implementations/refactoring-logging-processor-wrapper.js +95 -1
- package/dist/processors/processor-manager.js +346 -314
- package/dist/reporting/report-formatter.js +1 -1
- package/dist/security/security-hardener.d.ts +69 -2
- package/dist/security/security-hardener.js +129 -1
- package/dist/skills/registry.json +1 -1
- package/dist/state/index.d.ts +3 -5
- package/dist/state/index.js +1 -7
- package/dist/state/state-manager.d.ts +1 -1
- package/dist/state/state-manager.js +2 -3
- package/package.json +13 -10
- package/scripts/node/universal-version-manager.js +11 -11
- package/src/mcps/architect-tools.server.ts +112 -215
- package/src/mcps/auto-format.server.ts +50 -110
- package/src/mcps/boot-orchestrator.server.ts +75 -121
- package/src/mcps/config/__tests__/server-config-registry.test.ts +21 -12
- package/src/mcps/config/server-config-registry.ts +3 -3
- package/src/mcps/enforcer-tools.server.ts +212 -310
- package/src/mcps/estimation.server.ts +62 -122
- package/src/mcps/framework-compliance-audit.server.ts +52 -97
- package/src/mcps/framework-help.server.ts +64 -114
- package/src/mcps/governance.server.ts +2 -2
- package/src/mcps/knowledge-skills/api-design.server.ts +32 -77
- package/src/mcps/knowledge-skills/architecture-patterns.server.ts +31 -87
- package/src/mcps/knowledge-skills/bug-triage-specialist.server.ts +165 -193
- package/src/mcps/knowledge-skills/code-analyzer.server.ts +20 -55
- package/src/mcps/knowledge-skills/code-review.server.ts +114 -161
- package/src/mcps/knowledge-skills/content-creator.server.ts +218 -255
- package/src/mcps/knowledge-skills/database-design.server.ts +118 -165
- package/src/mcps/knowledge-skills/devops-deployment.server.ts +67 -172
- package/src/mcps/knowledge-skills/git-workflow.server.ts +32 -77
- package/src/mcps/knowledge-skills/growth-strategist.server.ts +324 -361
- package/src/mcps/knowledge-skills/log-monitor.server.ts +160 -187
- package/src/mcps/knowledge-skills/mobile-development.server.ts +89 -223
- package/src/mcps/knowledge-skills/multimodal-looker.server.ts +128 -175
- package/src/mcps/knowledge-skills/performance-optimization.server.ts +156 -329
- package/src/mcps/knowledge-skills/project-analysis.server.ts +72 -248
- package/src/mcps/knowledge-skills/refactoring-strategies.server.ts +59 -171
- package/src/mcps/knowledge-skills/security-audit.server.ts +104 -151
- package/src/mcps/knowledge-skills/seo-consultant.server.ts +80 -220
- package/src/mcps/knowledge-skills/session-management.server.ts +51 -232
- package/src/mcps/knowledge-skills/skill-invocation.server.ts +165 -372
- package/src/mcps/knowledge-skills/strategist.server.ts +72 -143
- package/src/mcps/knowledge-skills/tech-writer.server.ts +85 -350
- package/src/mcps/knowledge-skills/testing-best-practices.server.ts +146 -195
- package/src/mcps/knowledge-skills/testing-strategy.server.ts +75 -161
- package/src/mcps/knowledge-skills/ui-ux-design.server.ts +93 -487
- package/src/mcps/lint.server.ts +53 -107
- package/src/mcps/mcp-client.ts +2 -2
- package/src/mcps/model-health-check.server.ts +34 -71
- package/src/mcps/performance-analysis.server.ts +60 -104
- package/src/mcps/processor-pipeline.server.ts +72 -110
- package/src/mcps/registry.json +1 -1
- package/src/mcps/researcher.server.ts +88 -177
- package/src/mcps/security-scan.server.ts +55 -104
- package/src/mcps/shared/knowledge-skill-base.ts +62 -0
- package/src/mcps/shared/prompt-security-validator.ts +199 -0
- package/src/mcps/shared/security-scanner.ts +599 -0
- package/src/mcps/state-manager.server.ts +117 -175
- package/src/opencode/codex.codex +1 -1
- package/src/opencode/commands/dependency-audit.md +3 -3
- package/src/opencode/enforcer-config.json +2 -2
- package/src/skills/registry.json +1 -1
- package/xray/codex.json +1 -1
- package/xray/config.json +1 -1
- package/xray/features.json +1 -1
- package/xray/integrations.json +3 -3
- package/dist/integrations/hermes-agent/__pycache__/__init__.cpython-313.pyc +0 -0
- package/dist/integrations/hermes-agent/__pycache__/conftest.cpython-313-pytest-9.0.2.pyc +0 -0
- package/dist/integrations/hermes-agent/__pycache__/schemas.cpython-313.pyc +0 -0
- package/dist/integrations/hermes-agent/__pycache__/test_plugin.cpython-313-pytest-9.0.2.pyc +0 -0
- package/dist/integrations/hermes-agent/__pycache__/test_plugin.cpython-313.pyc +0 -0
- package/dist/integrations/hermes-agent/__pycache__/tools.cpython-313.pyc +0 -0
- package/dist/integrations/hermes-agent/conftest.py +0 -14
- package/dist/integrations/hermes-agent/test_plugin.py +0 -1103
- package/dist/processors/implementations/refactoring-logging-processor.d.ts +0 -31
- package/dist/processors/implementations/refactoring-logging-processor.js +0 -96
- package/dist/processors/implementations/session-capture-processor.d.ts +0 -14
- package/dist/processors/implementations/session-capture-processor.js +0 -37
- package/dist/scripts/activate-kernel-pipeline.d.ts +0 -7
- package/dist/scripts/activate-kernel-pipeline.js +0 -101
- package/dist/security/index.d.ts +0 -13
- package/dist/security/index.js +0 -13
- package/dist/security/security-agent-coordinator.d.ts +0 -72
- package/dist/security/security-agent-coordinator.js +0 -204
- package/dist/security/security-auditor.d.ts +0 -56
- package/dist/security/security-auditor.js +0 -584
- package/dist/security/security-hardening-system.d.ts +0 -239
- package/dist/security/security-hardening-system.js +0 -727
- package/dist/security/security-orchestration-layer.d.ts +0 -119
- package/dist/security/security-orchestration-layer.js +0 -496
- /package/dist/{security → mcps/shared}/prompt-security-validator.d.ts +0 -0
- /package/dist/{security → mcps/shared}/prompt-security-validator.js +0 -0
- /package/dist/{security → mcps/shared}/security-scanner.d.ts +0 -0
|
@@ -1,321 +1,191 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
|
|
1
|
+
import { XrayKnowledgeSkillBase } from "../shared/knowledge-skill-base.js";
|
|
3
2
|
import { StreamableHTTPServerTransport } from "@modelcontextprotocol/sdk/server/streamableHttp.js";
|
|
4
3
|
import { createMcpExpressApp } from "@modelcontextprotocol/sdk/server/express.js";
|
|
5
|
-
import { CallToolRequestSchema, ErrorCode, ListToolsRequestSchema, McpError, } from "@modelcontextprotocol/sdk/types.js";
|
|
6
4
|
import * as path from "path";
|
|
7
5
|
import { fileURLToPath } from "url";
|
|
8
6
|
import { randomUUID } from "crypto";
|
|
9
7
|
import { mcpClientManager } from "../mcp-client.js";
|
|
10
8
|
import { frameworkLogger } from "../../core/framework-logger.js";
|
|
11
|
-
class SkillInvocationServer {
|
|
12
|
-
server;
|
|
9
|
+
class SkillInvocationServer extends XrayKnowledgeSkillBase {
|
|
13
10
|
constructor() {
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
setupToolHandlers() {
|
|
24
|
-
// List available tools
|
|
25
|
-
this.server.setRequestHandler(ListToolsRequestSchema, async () => {
|
|
26
|
-
return {
|
|
27
|
-
tools: [
|
|
28
|
-
{
|
|
29
|
-
name: "list-skills",
|
|
30
|
-
description: "List all available skills with descriptions",
|
|
31
|
-
inputSchema: {
|
|
32
|
-
type: "object",
|
|
33
|
-
properties: {
|
|
34
|
-
category: {
|
|
35
|
-
type: "string",
|
|
36
|
-
enum: ["all", "core", "registry", "knowledge"],
|
|
37
|
-
description: "Filter by category",
|
|
38
|
-
},
|
|
39
|
-
},
|
|
40
|
-
},
|
|
11
|
+
super("xray/skill-invocation", "2.0.1");
|
|
12
|
+
this.tools = [
|
|
13
|
+
{
|
|
14
|
+
name: "list-skills",
|
|
15
|
+
description: "List all available skills with descriptions",
|
|
16
|
+
inputSchema: {
|
|
17
|
+
type: "object",
|
|
18
|
+
properties: {
|
|
19
|
+
category: { type: "string", enum: ["all", "core", "registry", "knowledge"], description: "Filter by category" },
|
|
41
20
|
},
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
type: "string",
|
|
54
|
-
description: "Name of the tool within the skill to execute",
|
|
55
|
-
},
|
|
56
|
-
args: {
|
|
57
|
-
type: "object",
|
|
58
|
-
description: "Arguments to pass to the skill tool",
|
|
59
|
-
},
|
|
60
|
-
},
|
|
61
|
-
required: ["skillName", "toolName"],
|
|
62
|
-
},
|
|
21
|
+
},
|
|
22
|
+
},
|
|
23
|
+
{
|
|
24
|
+
name: "invoke-skill",
|
|
25
|
+
description: "Generic skill invocation tool for calling any MCP skill server",
|
|
26
|
+
inputSchema: {
|
|
27
|
+
type: "object",
|
|
28
|
+
properties: {
|
|
29
|
+
skillName: { type: "string", description: "Name of the skill to invoke (use list-skills to see available)" },
|
|
30
|
+
toolName: { type: "string", description: "Name of the tool within the skill to execute" },
|
|
31
|
+
args: { type: "object", description: "Arguments to pass to the skill tool" },
|
|
63
32
|
},
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
},
|
|
77
|
-
required: ["code"],
|
|
78
|
-
},
|
|
33
|
+
required: ["skillName", "toolName"],
|
|
34
|
+
},
|
|
35
|
+
},
|
|
36
|
+
{
|
|
37
|
+
name: "skill-code-review",
|
|
38
|
+
description: "Invoke code review skill for comprehensive code analysis",
|
|
39
|
+
inputSchema: {
|
|
40
|
+
type: "object",
|
|
41
|
+
properties: {
|
|
42
|
+
code: { type: "string", description: "Code to analyze" },
|
|
43
|
+
language: { type: "string", description: "Programming language" },
|
|
44
|
+
context: { type: "object", description: "Additional context" },
|
|
79
45
|
},
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
severity: {
|
|
92
|
-
type: "string",
|
|
93
|
-
enum: ["low", "medium", "high", "critical"],
|
|
94
|
-
description: "Minimum severity level",
|
|
95
|
-
},
|
|
96
|
-
},
|
|
97
|
-
required: ["files"],
|
|
98
|
-
},
|
|
46
|
+
required: ["code"],
|
|
47
|
+
},
|
|
48
|
+
},
|
|
49
|
+
{
|
|
50
|
+
name: "skill-security-audit",
|
|
51
|
+
description: "Invoke security audit skill for vulnerability scanning",
|
|
52
|
+
inputSchema: {
|
|
53
|
+
type: "object",
|
|
54
|
+
properties: {
|
|
55
|
+
files: { type: "array", items: { type: "string" }, description: "Files to audit" },
|
|
56
|
+
severity: { type: "string", enum: ["low", "medium", "high", "critical"], description: "Minimum severity level" },
|
|
99
57
|
},
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
type: "array",
|
|
113
|
-
items: { type: "string" },
|
|
114
|
-
description: "Performance metrics to analyze",
|
|
115
|
-
},
|
|
116
|
-
},
|
|
117
|
-
required: ["code"],
|
|
118
|
-
},
|
|
58
|
+
required: ["files"],
|
|
59
|
+
},
|
|
60
|
+
},
|
|
61
|
+
{
|
|
62
|
+
name: "skill-performance-optimization",
|
|
63
|
+
description: "Invoke performance optimization skill for bottleneck analysis",
|
|
64
|
+
inputSchema: {
|
|
65
|
+
type: "object",
|
|
66
|
+
properties: {
|
|
67
|
+
code: { type: "string", description: "Code to analyze" },
|
|
68
|
+
language: { type: "string", description: "Programming language" },
|
|
69
|
+
metrics: { type: "array", items: { type: "string" }, description: "Performance metrics to analyze" },
|
|
119
70
|
},
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
items: { type: "string" },
|
|
133
|
-
description: "Existing test files",
|
|
134
|
-
},
|
|
135
|
-
requirements: {
|
|
136
|
-
type: "object",
|
|
137
|
-
description: "Testing requirements and constraints",
|
|
138
|
-
},
|
|
139
|
-
},
|
|
140
|
-
required: ["code"],
|
|
141
|
-
},
|
|
71
|
+
required: ["code"],
|
|
72
|
+
},
|
|
73
|
+
},
|
|
74
|
+
{
|
|
75
|
+
name: "skill-testing-strategy",
|
|
76
|
+
description: "Invoke testing strategy skill for test planning",
|
|
77
|
+
inputSchema: {
|
|
78
|
+
type: "object",
|
|
79
|
+
properties: {
|
|
80
|
+
code: { type: "string", description: "Code to analyze for testing" },
|
|
81
|
+
existingTests: { type: "array", items: { type: "string" }, description: "Existing test files" },
|
|
82
|
+
requirements: { type: "object", description: "Testing requirements and constraints" },
|
|
142
83
|
},
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
analysis: {
|
|
155
|
-
type: "array",
|
|
156
|
-
items: { type: "string" },
|
|
157
|
-
description: "Types of analysis to perform",
|
|
158
|
-
},
|
|
159
|
-
},
|
|
160
|
-
},
|
|
84
|
+
required: ["code"],
|
|
85
|
+
},
|
|
86
|
+
},
|
|
87
|
+
{
|
|
88
|
+
name: "skill-project-analysis",
|
|
89
|
+
description: "Invoke project analysis skill for codebase insights",
|
|
90
|
+
inputSchema: {
|
|
91
|
+
type: "object",
|
|
92
|
+
properties: {
|
|
93
|
+
scope: { type: "string", enum: ["full", "directory", "file"], description: "Analysis scope" },
|
|
94
|
+
analysis: { type: "array", items: { type: "string" }, description: "Types of analysis to perform" },
|
|
161
95
|
},
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
databaseType: {
|
|
173
|
-
type: "string",
|
|
174
|
-
enum: ["postgresql", "mysql", "mongodb", "dynamodb"],
|
|
175
|
-
description: "Target database type",
|
|
176
|
-
},
|
|
177
|
-
},
|
|
178
|
-
required: ["schema"],
|
|
179
|
-
},
|
|
96
|
+
},
|
|
97
|
+
},
|
|
98
|
+
{
|
|
99
|
+
name: "skill-database-design",
|
|
100
|
+
description: "Invoke database design skill for schema design and query optimization",
|
|
101
|
+
inputSchema: {
|
|
102
|
+
type: "object",
|
|
103
|
+
properties: {
|
|
104
|
+
schema: { type: "string", description: "Database schema or entities" },
|
|
105
|
+
databaseType: { type: "string", enum: ["postgresql", "mysql", "mongodb", "dynamodb"], description: "Target database type" },
|
|
180
106
|
},
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
},
|
|
193
|
-
},
|
|
194
|
-
required: ["projectType"],
|
|
195
|
-
},
|
|
107
|
+
required: ["schema"],
|
|
108
|
+
},
|
|
109
|
+
},
|
|
110
|
+
{
|
|
111
|
+
name: "skill-devops-deployment",
|
|
112
|
+
description: "Invoke DevOps deployment skill for CI/CD and infrastructure",
|
|
113
|
+
inputSchema: {
|
|
114
|
+
type: "object",
|
|
115
|
+
properties: {
|
|
116
|
+
projectType: { type: "string", description: "Type of project" },
|
|
117
|
+
cloudProvider: { type: "string", enum: ["aws", "gcp", "azure"], description: "Target cloud provider" },
|
|
196
118
|
},
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
style: {
|
|
209
|
-
type: "string",
|
|
210
|
-
enum: ["rest", "graphql"],
|
|
211
|
-
description: "API style",
|
|
212
|
-
},
|
|
213
|
-
},
|
|
214
|
-
required: ["resources"],
|
|
215
|
-
},
|
|
119
|
+
required: ["projectType"],
|
|
120
|
+
},
|
|
121
|
+
},
|
|
122
|
+
{
|
|
123
|
+
name: "skill-api-design",
|
|
124
|
+
description: "Invoke API design skill for REST/GraphQL endpoints",
|
|
125
|
+
inputSchema: {
|
|
126
|
+
type: "object",
|
|
127
|
+
properties: {
|
|
128
|
+
resources: { type: "array", items: { type: "string" }, description: "API resources" },
|
|
129
|
+
style: { type: "string", enum: ["rest", "graphql"], description: "API style" },
|
|
216
130
|
},
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
type: "string",
|
|
229
|
-
enum: ["react", "vue", "angular", "svelte"],
|
|
230
|
-
description: "Target framework",
|
|
231
|
-
},
|
|
232
|
-
},
|
|
233
|
-
required: ["component"],
|
|
234
|
-
},
|
|
131
|
+
required: ["resources"],
|
|
132
|
+
},
|
|
133
|
+
},
|
|
134
|
+
{
|
|
135
|
+
name: "skill-ui-ux-design",
|
|
136
|
+
description: "Invoke UI/UX design skill for component design",
|
|
137
|
+
inputSchema: {
|
|
138
|
+
type: "object",
|
|
139
|
+
properties: {
|
|
140
|
+
component: { type: "string", description: "Component to design" },
|
|
141
|
+
framework: { type: "string", enum: ["react", "vue", "angular", "svelte"], description: "Target framework" },
|
|
235
142
|
},
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
code: { type: "string", description: "Code to document" },
|
|
248
|
-
},
|
|
249
|
-
required: ["type"],
|
|
250
|
-
},
|
|
143
|
+
required: ["component"],
|
|
144
|
+
},
|
|
145
|
+
},
|
|
146
|
+
{
|
|
147
|
+
name: "skill-documentation-generation",
|
|
148
|
+
description: "Invoke documentation skill for API docs and README",
|
|
149
|
+
inputSchema: {
|
|
150
|
+
type: "object",
|
|
151
|
+
properties: {
|
|
152
|
+
type: { type: "string", enum: ["api", "readme", "guide"], description: "Documentation type" },
|
|
153
|
+
code: { type: "string", description: "Code to document" },
|
|
251
154
|
},
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
type: "object",
|
|
266
|
-
description: "Context including commits, changes, metadata",
|
|
267
|
-
},
|
|
268
|
-
framework: {
|
|
269
|
-
type: "string",
|
|
270
|
-
enum: ["three_act_structure", "hero_journey", "spiral"],
|
|
271
|
-
description: "Storytelling framework to use",
|
|
272
|
-
},
|
|
273
|
-
},
|
|
274
|
-
required: ["storyType"],
|
|
275
|
-
},
|
|
155
|
+
required: ["type"],
|
|
156
|
+
},
|
|
157
|
+
},
|
|
158
|
+
{
|
|
159
|
+
name: "skill-storyteller",
|
|
160
|
+
description: "Invoke storyteller skill for writing reflections, sagas, and journeys",
|
|
161
|
+
inputSchema: {
|
|
162
|
+
type: "object",
|
|
163
|
+
properties: {
|
|
164
|
+
storyType: { type: "string", enum: ["reflection", "saga", "journey", "narrative"], description: "Type of story to write" },
|
|
165
|
+
title: { type: "string", description: "Title for the story" },
|
|
166
|
+
context: { type: "object", description: "Context including commits, changes, metadata" },
|
|
167
|
+
framework: { type: "string", enum: ["three_act_structure", "hero_journey", "spiral"], description: "Storytelling framework to use" },
|
|
276
168
|
},
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
this.
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
case "skill-project-analysis":
|
|
298
|
-
return await this.handleSkillProjectAnalysis(args);
|
|
299
|
-
case "skill-database-design":
|
|
300
|
-
return await this.handleSkillDatabaseDesign(args);
|
|
301
|
-
case "skill-devops-deployment":
|
|
302
|
-
return await this.handleSkillDevopsDeployment(args);
|
|
303
|
-
case "skill-api-design":
|
|
304
|
-
return await this.handleSkillApiDesign(args);
|
|
305
|
-
case "skill-ui-ux-design":
|
|
306
|
-
return await this.handleSkillUiUxDesign(args);
|
|
307
|
-
case "skill-documentation-generation":
|
|
308
|
-
return await this.handleSkillDocumentationGeneration(args);
|
|
309
|
-
case "skill-storyteller":
|
|
310
|
-
return await this.handleSkillStoryteller(args);
|
|
311
|
-
default:
|
|
312
|
-
throw new McpError(ErrorCode.MethodNotFound, `Unknown tool: ${name}`);
|
|
313
|
-
}
|
|
314
|
-
}
|
|
315
|
-
catch (error) {
|
|
316
|
-
throw new McpError(ErrorCode.InternalError, `Tool execution failed: ${error instanceof Error ? error.message : String(error)}`);
|
|
317
|
-
}
|
|
318
|
-
});
|
|
169
|
+
required: ["storyType"],
|
|
170
|
+
},
|
|
171
|
+
},
|
|
172
|
+
];
|
|
173
|
+
this.handlers = {
|
|
174
|
+
"list-skills": async (args) => this.handleListSkills(args),
|
|
175
|
+
"invoke-skill": async (args) => this.handleInvokeSkill(args),
|
|
176
|
+
"skill-code-review": async (args) => this.handleSkillCodeReview(args),
|
|
177
|
+
"skill-security-audit": async (args) => this.handleSkillSecurityAudit(args),
|
|
178
|
+
"skill-performance-optimization": async (args) => this.handleSkillPerformanceOptimization(args),
|
|
179
|
+
"skill-testing-strategy": async (args) => this.handleSkillTestingStrategy(args),
|
|
180
|
+
"skill-project-analysis": async (args) => this.handleSkillProjectAnalysis(args),
|
|
181
|
+
"skill-database-design": async (args) => this.handleSkillDatabaseDesign(args),
|
|
182
|
+
"skill-devops-deployment": async (args) => this.handleSkillDevopsDeployment(args),
|
|
183
|
+
"skill-api-design": async (args) => this.handleSkillApiDesign(args),
|
|
184
|
+
"skill-ui-ux-design": async (args) => this.handleSkillUiUxDesign(args),
|
|
185
|
+
"skill-documentation-generation": async (args) => this.handleSkillDocumentationGeneration(args),
|
|
186
|
+
"skill-storyteller": async (args) => this.handleSkillStoryteller(args),
|
|
187
|
+
};
|
|
188
|
+
this.setupToolHandlers();
|
|
319
189
|
}
|
|
320
190
|
skillMetrics = new Map();
|
|
321
191
|
/**
|
|
@@ -626,55 +496,6 @@ class SkillInvocationServer {
|
|
|
626
496
|
],
|
|
627
497
|
};
|
|
628
498
|
}
|
|
629
|
-
async run() {
|
|
630
|
-
const transport = new StdioServerTransport();
|
|
631
|
-
await this.server.connect(transport);
|
|
632
|
-
let parentCheckTimer = null;
|
|
633
|
-
const cleanup = async (signal) => {
|
|
634
|
-
if (parentCheckTimer !== null) {
|
|
635
|
-
clearTimeout(parentCheckTimer);
|
|
636
|
-
parentCheckTimer = null;
|
|
637
|
-
}
|
|
638
|
-
const timeout = setTimeout(() => {
|
|
639
|
-
frameworkLogger.log("mcps/skill-invocation", "shutdown", "error", { message: "Graceful shutdown timeout, forcing exit..." });
|
|
640
|
-
process.exit(1);
|
|
641
|
-
}, 5000);
|
|
642
|
-
try {
|
|
643
|
-
if (this.server && typeof this.server.close === "function") {
|
|
644
|
-
await this.server.close();
|
|
645
|
-
}
|
|
646
|
-
clearTimeout(timeout);
|
|
647
|
-
process.exit(0);
|
|
648
|
-
}
|
|
649
|
-
catch (error) {
|
|
650
|
-
clearTimeout(timeout);
|
|
651
|
-
frameworkLogger.log("mcps/skill-invocation", "shutdown", "error", { message: `Error during server shutdown: ${String(error)}` });
|
|
652
|
-
process.exit(1);
|
|
653
|
-
}
|
|
654
|
-
};
|
|
655
|
-
process.on("SIGINT", () => cleanup("SIGINT"));
|
|
656
|
-
process.on("SIGTERM", () => cleanup("SIGTERM"));
|
|
657
|
-
process.on("SIGHUP", () => cleanup("SIGHUP"));
|
|
658
|
-
const checkParent = () => {
|
|
659
|
-
try {
|
|
660
|
-
process.kill(process.ppid, 0);
|
|
661
|
-
parentCheckTimer = setTimeout(checkParent, 1000);
|
|
662
|
-
}
|
|
663
|
-
catch (error) {
|
|
664
|
-
parentCheckTimer = null;
|
|
665
|
-
cleanup("parent-process-death");
|
|
666
|
-
}
|
|
667
|
-
};
|
|
668
|
-
parentCheckTimer = setTimeout(checkParent, 2000);
|
|
669
|
-
process.on("uncaughtException", (error) => {
|
|
670
|
-
frameworkLogger.log("mcps/skill-invocation", "uncaughtException", "error", { message: `Uncaught Exception: ${String(error)}` });
|
|
671
|
-
cleanup("uncaughtException");
|
|
672
|
-
});
|
|
673
|
-
process.on("unhandledRejection", (reason) => {
|
|
674
|
-
frameworkLogger.log("mcps/skill-invocation", "unhandledRejection", "error", { message: `Unhandled Rejection: ${String(reason)}` });
|
|
675
|
-
cleanup("unhandledRejection");
|
|
676
|
-
});
|
|
677
|
-
}
|
|
678
499
|
/**
|
|
679
500
|
* Run as HTTP server using Streamable HTTP transport (for Grok CLI compatibility).
|
|
680
501
|
*/
|
|
@@ -720,7 +541,7 @@ if (entryPoint && fileURLToPath(import.meta.url) === entryPoint) {
|
|
|
720
541
|
}
|
|
721
542
|
else {
|
|
722
543
|
const server = new SkillInvocationServer();
|
|
723
|
-
server.run().catch((error) => {
|
|
544
|
+
server.run("skill-invocation").catch((error) => {
|
|
724
545
|
frameworkLogger.log("skill-invocation", "fatal-startup-error", "error", { error: String(error) });
|
|
725
546
|
process.exit(1);
|
|
726
547
|
});
|
|
@@ -1,17 +1,8 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
*
|
|
4
|
-
* Strategic guidance and complex problem-solving for architectural decisions.
|
|
5
|
-
* Provides strategic planning, risk assessment, and technical strategy tools.
|
|
6
|
-
*/
|
|
7
|
-
declare class StrategistServer {
|
|
8
|
-
private server;
|
|
9
|
-
private tools;
|
|
1
|
+
import { XrayKnowledgeSkillBase } from "../shared/knowledge-skill-base.js";
|
|
2
|
+
declare class StrategistServer extends XrayKnowledgeSkillBase {
|
|
10
3
|
constructor();
|
|
11
|
-
private setupToolHandlers;
|
|
12
4
|
private handleStrategicGuidance;
|
|
13
5
|
private handleRiskAssessment;
|
|
14
6
|
private handleArchitectureReview;
|
|
15
|
-
start(): Promise<void>;
|
|
16
7
|
}
|
|
17
8
|
export { StrategistServer };
|