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.
- package/.opencode/codex.codex +1 -1
- package/.opencode/commands/dependency-audit.md +3 -3
- package/.opencode/enforcer-config.json +2 -2
- package/AGENTS.md +3 -2
- package/README.md +12 -11
- package/dist/AGENTS.md +3 -2
- package/dist/CHANGELOG.md +26 -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 +14 -10
- package/scripts/node/setup.cjs +32 -0
- 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/agents_template.md +109 -0
- package/xray/codex.json +598 -0
- package/xray/config.json +26 -0
- package/xray/features.json +132 -0
- package/xray/integrations.json +23 -0
- package/xray/routing-mappings.json +752 -0
- package/xray/workflow_state.json +28 -0
- 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
|
@@ -7,6 +7,7 @@
|
|
|
7
7
|
* @version 1.0.0
|
|
8
8
|
* @since 2026-03-14
|
|
9
9
|
*/
|
|
10
|
+
import { frameworkLogger } from '../../../core/framework-logger.js';
|
|
10
11
|
/**
|
|
11
12
|
* OpenClaw Hooks Manager
|
|
12
13
|
*/
|
|
@@ -16,7 +17,6 @@ export class OpenClawHooksManager {
|
|
|
16
17
|
initialized = false;
|
|
17
18
|
toolBeforeCallbacks = new Set();
|
|
18
19
|
toolAfterCallbacks = new Set();
|
|
19
|
-
logger;
|
|
20
20
|
// Offline event buffering
|
|
21
21
|
eventQueue = [];
|
|
22
22
|
maxQueueSize = 100;
|
|
@@ -30,7 +30,6 @@ export class OpenClawHooksManager {
|
|
|
30
30
|
includeResult: config.includeResult ?? true,
|
|
31
31
|
...(config.toolFilter ? { toolFilter: config.toolFilter } : {}),
|
|
32
32
|
};
|
|
33
|
-
this.logger = console;
|
|
34
33
|
}
|
|
35
34
|
/**
|
|
36
35
|
* Set the OpenClaw client
|
|
@@ -43,19 +42,19 @@ export class OpenClawHooksManager {
|
|
|
43
42
|
*/
|
|
44
43
|
async initialize() {
|
|
45
44
|
if (this.initialized) {
|
|
46
|
-
|
|
45
|
+
frameworkLogger.log('openclaw-hooks', 'Already initialized', 'warning', {});
|
|
47
46
|
return;
|
|
48
47
|
}
|
|
49
48
|
if (!this.config.enabled) {
|
|
50
|
-
|
|
49
|
+
frameworkLogger.log('openclaw-hooks', 'Hooks disabled in configuration', 'info', {});
|
|
51
50
|
return;
|
|
52
51
|
}
|
|
53
|
-
|
|
52
|
+
frameworkLogger.log('openclaw-hooks', 'Initializing 0xRay tool hooks...', 'info', {});
|
|
54
53
|
// Register with 0xRay's event system
|
|
55
54
|
// The integration should call registerToolBefore and registerToolAfter
|
|
56
55
|
// to connect to 0xRay's actual tool execution events
|
|
57
56
|
this.initialized = true;
|
|
58
|
-
|
|
57
|
+
frameworkLogger.log('openclaw-hooks', 'Hooks initialized successfully', 'info', {});
|
|
59
58
|
}
|
|
60
59
|
/**
|
|
61
60
|
* Register a callback for tool.before events
|
|
@@ -121,13 +120,13 @@ export class OpenClawHooksManager {
|
|
|
121
120
|
await callback(event);
|
|
122
121
|
}
|
|
123
122
|
catch (error) {
|
|
124
|
-
|
|
123
|
+
frameworkLogger.log('openclaw-hooks', 'Callback error in tool.before:', 'error', { error });
|
|
125
124
|
}
|
|
126
125
|
}
|
|
127
|
-
|
|
126
|
+
frameworkLogger.log('openclaw-hooks', `tool.before: ${event.toolName}`, 'debug', {});
|
|
128
127
|
}
|
|
129
128
|
catch (error) {
|
|
130
|
-
|
|
129
|
+
frameworkLogger.log('openclaw-hooks', 'Error handling tool.before:', 'error', { error });
|
|
131
130
|
}
|
|
132
131
|
}
|
|
133
132
|
/**
|
|
@@ -171,13 +170,13 @@ export class OpenClawHooksManager {
|
|
|
171
170
|
await callback(event);
|
|
172
171
|
}
|
|
173
172
|
catch (error) {
|
|
174
|
-
|
|
173
|
+
frameworkLogger.log('openclaw-hooks', 'Callback error in tool.after:', 'error', { error });
|
|
175
174
|
}
|
|
176
175
|
}
|
|
177
|
-
|
|
176
|
+
frameworkLogger.log('openclaw-hooks', `tool.after: ${event.toolName} (${event.error ? 'error' : 'success'})`, 'debug', {});
|
|
178
177
|
}
|
|
179
178
|
catch (error) {
|
|
180
|
-
|
|
179
|
+
frameworkLogger.log('openclaw-hooks', 'Error handling tool.after:', 'error', { error });
|
|
181
180
|
}
|
|
182
181
|
}
|
|
183
182
|
/**
|
|
@@ -187,10 +186,10 @@ export class OpenClawHooksManager {
|
|
|
187
186
|
if (this.eventQueue.length >= this.maxQueueSize) {
|
|
188
187
|
// Remove oldest event to make room
|
|
189
188
|
this.eventQueue.shift();
|
|
190
|
-
|
|
189
|
+
frameworkLogger.log('openclaw-hooks', 'Event queue full, dropping oldest event', 'warning', {});
|
|
191
190
|
}
|
|
192
191
|
this.eventQueue.push({ type, event });
|
|
193
|
-
|
|
192
|
+
frameworkLogger.log('openclaw-hooks', `Queued ${type} event (queue size: ${this.eventQueue.length})`, 'debug', {});
|
|
194
193
|
}
|
|
195
194
|
/**
|
|
196
195
|
* Flush queued events to OpenClaw Gateway
|
|
@@ -213,12 +212,12 @@ export class OpenClawHooksManager {
|
|
|
213
212
|
}
|
|
214
213
|
}
|
|
215
214
|
catch (error) {
|
|
216
|
-
|
|
215
|
+
frameworkLogger.log('openclaw-hooks', `Failed to send queued ${item.type} event:`, 'error', { error });
|
|
217
216
|
// Re-queue failed events
|
|
218
217
|
this.eventQueue.push(item);
|
|
219
218
|
}
|
|
220
219
|
}
|
|
221
|
-
|
|
220
|
+
frameworkLogger.log('openclaw-hooks', `Flushed ${queue.length} queued events`, 'info', {});
|
|
222
221
|
}
|
|
223
222
|
finally {
|
|
224
223
|
this.isFlushing = false;
|
|
@@ -235,7 +234,7 @@ export class OpenClawHooksManager {
|
|
|
235
234
|
*/
|
|
236
235
|
async handleReconnect() {
|
|
237
236
|
if (this.eventQueue.length > 0) {
|
|
238
|
-
|
|
237
|
+
frameworkLogger.log('openclaw-hooks', `Client reconnected, flushing ${this.eventQueue.length} queued events...`, 'info', {});
|
|
239
238
|
await this.flushEventQueue();
|
|
240
239
|
}
|
|
241
240
|
}
|
|
@@ -248,7 +247,7 @@ export class OpenClawHooksManager {
|
|
|
248
247
|
this.eventQueue.length = 0;
|
|
249
248
|
this.initialized = false;
|
|
250
249
|
this.client = null;
|
|
251
|
-
|
|
250
|
+
frameworkLogger.log('openclaw-hooks', `Hooks shutdown complete (${queuedCount} queued events dropped)`, 'info', {});
|
|
252
251
|
}
|
|
253
252
|
/**
|
|
254
253
|
* Check if hooks are initialized
|
|
@@ -462,10 +462,10 @@ export class PluginRegistry extends EventEmitter {
|
|
|
462
462
|
this.debounceReload(pluginName);
|
|
463
463
|
}
|
|
464
464
|
});
|
|
465
|
-
frameworkLogger.log("plugin-registry", "hot-reload-started", "info", { pluginsDir: this.pluginsDir })
|
|
465
|
+
frameworkLogger.log("plugin-registry", "hot-reload-started", "info", { pluginsDir: this.pluginsDir });
|
|
466
466
|
}
|
|
467
467
|
catch (error) {
|
|
468
|
-
frameworkLogger.log("plugin-registry", "hot-reload-failed", "error", { error: error instanceof Error ? error.message : String(error) })
|
|
468
|
+
frameworkLogger.log("plugin-registry", "hot-reload-failed", "error", { error: error instanceof Error ? error.message : String(error) });
|
|
469
469
|
}
|
|
470
470
|
}
|
|
471
471
|
/**
|
|
@@ -479,7 +479,7 @@ export class PluginRegistry extends EventEmitter {
|
|
|
479
479
|
const timeout = setTimeout(() => {
|
|
480
480
|
this.reloadDebounce.delete(pluginName);
|
|
481
481
|
this.hotReloadPlugin(pluginName).catch((error) => {
|
|
482
|
-
frameworkLogger.log("plugin-registry", "hot-reload-error", "error", { pluginName, error: error instanceof Error ? error.message : String(error) })
|
|
482
|
+
frameworkLogger.log("plugin-registry", "hot-reload-error", "error", { pluginName, error: error instanceof Error ? error.message : String(error) });
|
|
483
483
|
});
|
|
484
484
|
}, 1000);
|
|
485
485
|
this.reloadDebounce.set(pluginName, timeout);
|
|
@@ -506,7 +506,7 @@ export class PluginRegistry extends EventEmitter {
|
|
|
506
506
|
await newPlugin.restart();
|
|
507
507
|
}
|
|
508
508
|
this.emitEvent("plugin-reloaded", { name: pluginName, phase: "loaded" });
|
|
509
|
-
await frameworkLogger.log("plugin-registry", "plugin-hot-reloaded", "info", { name: pluginName })
|
|
509
|
+
await frameworkLogger.log("plugin-registry", "plugin-hot-reloaded", "info", { name: pluginName });
|
|
510
510
|
}
|
|
511
511
|
}
|
|
512
512
|
/**
|
|
@@ -529,7 +529,7 @@ export class PluginRegistry extends EventEmitter {
|
|
|
529
529
|
results.forEach((result, index) => {
|
|
530
530
|
if (result.status === "rejected") {
|
|
531
531
|
const pluginNames = Array.from(this.plugins.keys());
|
|
532
|
-
frameworkLogger.log("plugin-registry", "plugin-shutdown-error", "error", { name: pluginNames[index], error: result.reason })
|
|
532
|
+
frameworkLogger.log("plugin-registry", "plugin-shutdown-error", "error", { name: pluginNames[index], error: result.reason });
|
|
533
533
|
}
|
|
534
534
|
});
|
|
535
535
|
this.plugins.clear();
|
|
@@ -4,14 +4,12 @@
|
|
|
4
4
|
* Converts architect-tools.ts functions into MCP server tools
|
|
5
5
|
* Provides contextual analysis capabilities via MCP protocol
|
|
6
6
|
*/
|
|
7
|
-
|
|
8
|
-
|
|
7
|
+
import { XrayKnowledgeSkillBase } from "./shared/knowledge-skill-base.js";
|
|
8
|
+
declare class XrayArchitectToolsServer extends XrayKnowledgeSkillBase {
|
|
9
9
|
constructor();
|
|
10
|
-
private setupToolHandlers;
|
|
11
10
|
private contextAnalysis;
|
|
12
11
|
private codebaseStructure;
|
|
13
12
|
private dependencyAnalysis;
|
|
14
13
|
private architectureAssessment;
|
|
15
|
-
run(): Promise<void>;
|
|
16
14
|
}
|
|
17
15
|
export default XrayArchitectToolsServer;
|
|
@@ -4,159 +4,129 @@
|
|
|
4
4
|
* Converts architect-tools.ts functions into MCP server tools
|
|
5
5
|
* Provides contextual analysis capabilities via MCP protocol
|
|
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";
|
|
10
7
|
import { frameworkLogger } from "../core/framework-logger.js";
|
|
11
8
|
import { contextAnalysis as architectContextAnalysis, codebaseStructure as architectCodebaseStructure, dependencyAnalysis as architectDependencyAnalysis, architectureAssessment as architectArchitectureAssessment, } from "../architect/architect-tools.js";
|
|
12
|
-
|
|
13
|
-
|
|
9
|
+
import { XrayKnowledgeSkillBase } from "./shared/knowledge-skill-base.js";
|
|
10
|
+
class XrayArchitectToolsServer extends XrayKnowledgeSkillBase {
|
|
14
11
|
constructor() {
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
description: "Root directory of the project to analyze",
|
|
38
|
-
},
|
|
39
|
-
depth: {
|
|
40
|
-
type: "string",
|
|
41
|
-
enum: ["overview", "detailed", "comprehensive"],
|
|
42
|
-
default: "detailed",
|
|
43
|
-
description: "Analysis depth level",
|
|
44
|
-
},
|
|
45
|
-
includeFiles: {
|
|
46
|
-
type: "array",
|
|
47
|
-
items: { type: "string" },
|
|
48
|
-
description: "Specific files to include in analysis",
|
|
49
|
-
},
|
|
50
|
-
},
|
|
51
|
-
required: ["projectRoot"],
|
|
12
|
+
super("architect-tools", "2.0.1");
|
|
13
|
+
this.tools = [
|
|
14
|
+
{
|
|
15
|
+
name: "context-analysis",
|
|
16
|
+
description: "Perform comprehensive codebase intelligence gathering including structure analysis, dependency mapping, and architectural pattern recognition",
|
|
17
|
+
inputSchema: {
|
|
18
|
+
type: "object",
|
|
19
|
+
properties: {
|
|
20
|
+
projectRoot: {
|
|
21
|
+
type: "string",
|
|
22
|
+
description: "Root directory of the project to analyze",
|
|
23
|
+
},
|
|
24
|
+
depth: {
|
|
25
|
+
type: "string",
|
|
26
|
+
enum: ["overview", "detailed", "comprehensive"],
|
|
27
|
+
default: "detailed",
|
|
28
|
+
description: "Analysis depth level",
|
|
29
|
+
},
|
|
30
|
+
includeFiles: {
|
|
31
|
+
type: "array",
|
|
32
|
+
items: { type: "string" },
|
|
33
|
+
description: "Specific files to include in analysis",
|
|
52
34
|
},
|
|
53
35
|
},
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
36
|
+
required: ["projectRoot"],
|
|
37
|
+
},
|
|
38
|
+
},
|
|
39
|
+
{
|
|
40
|
+
name: "codebase-structure",
|
|
41
|
+
description: "Analyze file organization, module distribution, and directory hierarchy with optional metrics",
|
|
42
|
+
inputSchema: {
|
|
43
|
+
type: "object",
|
|
44
|
+
properties: {
|
|
45
|
+
projectRoot: {
|
|
46
|
+
type: "string",
|
|
47
|
+
description: "Root directory of the project",
|
|
48
|
+
},
|
|
49
|
+
includeMetrics: {
|
|
50
|
+
type: "boolean",
|
|
51
|
+
default: true,
|
|
52
|
+
description: "Include detailed metrics",
|
|
53
|
+
},
|
|
54
|
+
maxDepth: {
|
|
55
|
+
type: "number",
|
|
56
|
+
default: 10,
|
|
57
|
+
description: "Maximum directory depth to analyze",
|
|
76
58
|
},
|
|
77
59
|
},
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
60
|
+
required: ["projectRoot"],
|
|
61
|
+
},
|
|
62
|
+
},
|
|
63
|
+
{
|
|
64
|
+
name: "dependency-analysis",
|
|
65
|
+
description: "Map component dependencies, identify coupling patterns, and assess architectural relationships",
|
|
66
|
+
inputSchema: {
|
|
67
|
+
type: "object",
|
|
68
|
+
properties: {
|
|
69
|
+
projectRoot: {
|
|
70
|
+
type: "string",
|
|
71
|
+
description: "Root directory of the project",
|
|
72
|
+
},
|
|
73
|
+
focusAreas: {
|
|
74
|
+
type: "array",
|
|
75
|
+
items: { type: "string" },
|
|
76
|
+
description: "Specific areas to focus dependency analysis on",
|
|
77
|
+
},
|
|
78
|
+
includeGraphs: {
|
|
79
|
+
type: "boolean",
|
|
80
|
+
default: true,
|
|
81
|
+
description: "Include dependency graphs in output",
|
|
100
82
|
},
|
|
101
83
|
},
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
84
|
+
required: ["projectRoot"],
|
|
85
|
+
},
|
|
86
|
+
},
|
|
87
|
+
{
|
|
88
|
+
name: "architecture-assessment",
|
|
89
|
+
description: "Evaluate overall architectural health with scores, issues, and improvement recommendations",
|
|
90
|
+
inputSchema: {
|
|
91
|
+
type: "object",
|
|
92
|
+
properties: {
|
|
93
|
+
projectRoot: {
|
|
94
|
+
type: "string",
|
|
95
|
+
description: "Root directory of the project",
|
|
96
|
+
},
|
|
97
|
+
assessmentType: {
|
|
98
|
+
type: "string",
|
|
99
|
+
enum: ["quick", "comprehensive"],
|
|
100
|
+
default: "comprehensive",
|
|
101
|
+
description: "Type of assessment to perform",
|
|
102
|
+
},
|
|
103
|
+
focusMetrics: {
|
|
104
|
+
type: "array",
|
|
105
|
+
items: {
|
|
106
|
+
type: "string",
|
|
107
|
+
enum: [
|
|
108
|
+
"complexity",
|
|
109
|
+
"coupling",
|
|
110
|
+
"cohesion",
|
|
111
|
+
"testability",
|
|
112
|
+
"scalability",
|
|
113
|
+
],
|
|
132
114
|
},
|
|
133
|
-
|
|
115
|
+
description: "Specific metrics to focus assessment on",
|
|
134
116
|
},
|
|
135
117
|
},
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
return await this.dependencyAnalysis(args);
|
|
149
|
-
case "architecture-assessment":
|
|
150
|
-
return await this.architectureAssessment(args);
|
|
151
|
-
default:
|
|
152
|
-
throw new Error(`Unknown tool: ${name}`);
|
|
153
|
-
}
|
|
154
|
-
}
|
|
155
|
-
catch (error) {
|
|
156
|
-
frameworkLogger.log("mcps/architect-tools", "tool", "error", { tool: name, error: String(error) });
|
|
157
|
-
throw error;
|
|
158
|
-
}
|
|
159
|
-
});
|
|
118
|
+
required: ["projectRoot"],
|
|
119
|
+
},
|
|
120
|
+
},
|
|
121
|
+
];
|
|
122
|
+
this.handlers = {
|
|
123
|
+
"context-analysis": async (args) => this.contextAnalysis(args),
|
|
124
|
+
"codebase-structure": async (args) => this.codebaseStructure(args),
|
|
125
|
+
"dependency-analysis": async (args) => this.dependencyAnalysis(args),
|
|
126
|
+
"architecture-assessment": async (args) => this.architectureAssessment(args),
|
|
127
|
+
};
|
|
128
|
+
this.setupToolHandlers();
|
|
129
|
+
frameworkLogger.log("mcps/architect-tools", "init", "info", { message: "0xRay Architect Tools MCP Server initialized" });
|
|
160
130
|
}
|
|
161
131
|
// Tool implementations — delegates to real architect-tools library
|
|
162
132
|
async contextAnalysis(args) {
|
|
@@ -216,62 +186,9 @@ class XrayArchitectToolsServer {
|
|
|
216
186
|
],
|
|
217
187
|
};
|
|
218
188
|
}
|
|
219
|
-
async run() {
|
|
220
|
-
const transport = new StdioServerTransport();
|
|
221
|
-
await this.server.connect(transport);
|
|
222
|
-
frameworkLogger.log("mcps/architect-tools", "start", "info");
|
|
223
|
-
const cleanup = async (signal) => {
|
|
224
|
-
frameworkLogger.log("mcps/architect-tools", "shutdown", "info", { signal });
|
|
225
|
-
// Set a timeout to force exit if graceful shutdown fails
|
|
226
|
-
const timeout = setTimeout(() => {
|
|
227
|
-
frameworkLogger.log("mcps/architect-tools", "shutdown", "error", { message: "Graceful shutdown timeout, forcing exit..." });
|
|
228
|
-
process.exit(1);
|
|
229
|
-
}, 5000); // 5 second timeout
|
|
230
|
-
try {
|
|
231
|
-
if (this.server && typeof this.server.close === "function") {
|
|
232
|
-
await this.server.close();
|
|
233
|
-
}
|
|
234
|
-
clearTimeout(timeout);
|
|
235
|
-
frameworkLogger.log("mcps/architect-tools", "shutdown", "success");
|
|
236
|
-
process.exit(0);
|
|
237
|
-
}
|
|
238
|
-
catch (error) {
|
|
239
|
-
clearTimeout(timeout);
|
|
240
|
-
frameworkLogger.log("mcps/architect-tools", "shutdown", "error", { message: `Error during server shutdown: ${String(error)}` });
|
|
241
|
-
process.exit(1);
|
|
242
|
-
}
|
|
243
|
-
};
|
|
244
|
-
// Handle multiple shutdown signals
|
|
245
|
-
process.on("SIGINT", () => cleanup("SIGINT"));
|
|
246
|
-
process.on("SIGTERM", () => cleanup("SIGTERM"));
|
|
247
|
-
process.on("SIGHUP", () => cleanup("SIGHUP"));
|
|
248
|
-
// Monitor parent process (opencode) and shutdown if it dies
|
|
249
|
-
const checkParent = () => {
|
|
250
|
-
try {
|
|
251
|
-
process.kill(process.ppid, 0); // Check if parent is alive
|
|
252
|
-
setTimeout(checkParent, 1000); // Check again in 1 second
|
|
253
|
-
}
|
|
254
|
-
catch (error) {
|
|
255
|
-
// Parent process died, shut down gracefully
|
|
256
|
-
frameworkLogger.log("mcps/architect-tools", "parent-death", "info");
|
|
257
|
-
cleanup("parent-process-death");
|
|
258
|
-
}
|
|
259
|
-
};
|
|
260
|
-
// Start monitoring parent process
|
|
261
|
-
setTimeout(checkParent, 2000); // Start checking after 2 seconds
|
|
262
|
-
// Handle uncaught exceptions and unhandled rejections
|
|
263
|
-
process.on("uncaughtException", (error) => {
|
|
264
|
-
frameworkLogger.log("mcps/architect-tools", "uncaughtException", "error", { error: String(error) });
|
|
265
|
-
cleanup("uncaughtException");
|
|
266
|
-
});
|
|
267
|
-
process.on("unhandledRejection", (reason, promise) => {
|
|
268
|
-
frameworkLogger.log("mcps/architect-tools", "unhandledRejection", "error", { error: String(reason) });
|
|
269
|
-
cleanup("unhandledRejection");
|
|
270
|
-
});
|
|
271
|
-
}
|
|
272
189
|
}
|
|
273
190
|
if (import.meta.url === `file://${process.argv[1]}`) {
|
|
274
191
|
const server = new XrayArchitectToolsServer();
|
|
275
|
-
server.run().catch((error) => frameworkLogger.log("mcps/architect-tools", "run", "error", { error: String(error) }));
|
|
192
|
+
server.run("architect-tools").catch((error) => frameworkLogger.log("mcps/architect-tools", "run", "error", { error: String(error) }));
|
|
276
193
|
}
|
|
277
194
|
export default XrayArchitectToolsServer;
|
|
@@ -3,10 +3,9 @@
|
|
|
3
3
|
*
|
|
4
4
|
* Automated code formatting hook with Prettier and framework-specific formatters
|
|
5
5
|
*/
|
|
6
|
-
|
|
7
|
-
|
|
6
|
+
import { XrayKnowledgeSkillBase } from "./shared/knowledge-skill-base.js";
|
|
7
|
+
declare class XrayAutoFormatServer extends XrayKnowledgeSkillBase {
|
|
8
8
|
constructor();
|
|
9
|
-
private setupToolHandlers;
|
|
10
9
|
private handleAutoFormat;
|
|
11
10
|
private handleFormatCheck;
|
|
12
11
|
private runPrettier;
|
|
@@ -14,6 +13,5 @@ declare class XrayAutoFormatServer {
|
|
|
14
13
|
private runTypeScriptFormat;
|
|
15
14
|
private checkFormatting;
|
|
16
15
|
private generateFormatSummary;
|
|
17
|
-
run(): Promise<void>;
|
|
18
16
|
}
|
|
19
17
|
export { XrayAutoFormatServer };
|