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
@@ -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
- this.logger.warn('[OpenClawHooks] Already initialized');
45
+ frameworkLogger.log('openclaw-hooks', 'Already initialized', 'warning', {});
47
46
  return;
48
47
  }
49
48
  if (!this.config.enabled) {
50
- this.logger.info('[OpenClawHooks] Hooks disabled in configuration');
49
+ frameworkLogger.log('openclaw-hooks', 'Hooks disabled in configuration', 'info', {});
51
50
  return;
52
51
  }
53
- this.logger.info('[OpenClawHooks] Initializing 0xRay tool hooks...');
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
- this.logger.info('[OpenClawHooks] Hooks initialized successfully');
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
- this.logger.error('[OpenClawHooks] Callback error in tool.before:', error);
123
+ frameworkLogger.log('openclaw-hooks', 'Callback error in tool.before:', 'error', { error });
125
124
  }
126
125
  }
127
- this.logger.debug(`[OpenClawHooks] tool.before: ${event.toolName}`);
126
+ frameworkLogger.log('openclaw-hooks', `tool.before: ${event.toolName}`, 'debug', {});
128
127
  }
129
128
  catch (error) {
130
- this.logger.error('[OpenClawHooks] Error handling tool.before:', error);
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
- this.logger.error('[OpenClawHooks] Callback error in tool.after:', error);
173
+ frameworkLogger.log('openclaw-hooks', 'Callback error in tool.after:', 'error', { error });
175
174
  }
176
175
  }
177
- this.logger.debug(`[OpenClawHooks] tool.after: ${event.toolName} (${event.error ? 'error' : 'success'})`);
176
+ frameworkLogger.log('openclaw-hooks', `tool.after: ${event.toolName} (${event.error ? 'error' : 'success'})`, 'debug', {});
178
177
  }
179
178
  catch (error) {
180
- this.logger.error('[OpenClawHooks] Error handling tool.after:', error);
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
- this.logger.warn('[OpenClawHooks] Event queue full, dropping oldest event');
189
+ frameworkLogger.log('openclaw-hooks', 'Event queue full, dropping oldest event', 'warning', {});
191
190
  }
192
191
  this.eventQueue.push({ type, event });
193
- this.logger.debug(`[OpenClawHooks] Queued ${type} event (queue size: ${this.eventQueue.length})`);
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
- this.logger.error(`[OpenClawHooks] Failed to send queued ${item.type} event:`, error);
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
- this.logger.info(`[OpenClawHooks] Flushed ${queue.length} queued events`);
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
- this.logger.info(`[OpenClawHooks] Client reconnected, flushing ${this.eventQueue.length} queued events...`);
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
- this.logger.info(`[OpenClawHooks] Hooks shutdown complete (${queuedCount} queued events dropped)`);
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 }).catch(() => { });
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) }).catch(() => { });
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) }).catch(() => { });
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 }).catch(() => { });
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 }).catch(() => { });
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
- declare class XrayArchitectToolsServer {
8
- private server;
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
- class XrayArchitectToolsServer {
13
- server;
9
+ import { XrayKnowledgeSkillBase } from "./shared/knowledge-skill-base.js";
10
+ class XrayArchitectToolsServer extends XrayKnowledgeSkillBase {
14
11
  constructor() {
15
- this.server = new Server({
16
- name: "architect-tools", version: "2.0.1",
17
- }, {
18
- capabilities: {
19
- tools: {},
20
- },
21
- });
22
- this.setupToolHandlers();
23
- frameworkLogger.log("mcps/architect-tools", "init", "info", { message: "0xRay Architect Tools MCP Server initialized" });
24
- }
25
- setupToolHandlers() {
26
- this.server.setRequestHandler(ListToolsRequestSchema, async () => {
27
- return {
28
- tools: [
29
- {
30
- name: "context-analysis",
31
- description: "Perform comprehensive codebase intelligence gathering including structure analysis, dependency mapping, and architectural pattern recognition",
32
- inputSchema: {
33
- type: "object",
34
- properties: {
35
- projectRoot: {
36
- type: "string",
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
- name: "codebase-structure",
56
- description: "Analyze file organization, module distribution, and directory hierarchy with optional metrics",
57
- inputSchema: {
58
- type: "object",
59
- properties: {
60
- projectRoot: {
61
- type: "string",
62
- description: "Root directory of the project",
63
- },
64
- includeMetrics: {
65
- type: "boolean",
66
- default: true,
67
- description: "Include detailed metrics",
68
- },
69
- maxDepth: {
70
- type: "number",
71
- default: 10,
72
- description: "Maximum directory depth to analyze",
73
- },
74
- },
75
- required: ["projectRoot"],
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
- name: "dependency-analysis",
80
- description: "Map component dependencies, identify coupling patterns, and assess architectural relationships",
81
- inputSchema: {
82
- type: "object",
83
- properties: {
84
- projectRoot: {
85
- type: "string",
86
- description: "Root directory of the project",
87
- },
88
- focusAreas: {
89
- type: "array",
90
- items: { type: "string" },
91
- description: "Specific areas to focus dependency analysis on",
92
- },
93
- includeGraphs: {
94
- type: "boolean",
95
- default: true,
96
- description: "Include dependency graphs in output",
97
- },
98
- },
99
- required: ["projectRoot"],
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
- name: "architecture-assessment",
104
- description: "Evaluate overall architectural health with scores, issues, and improvement recommendations",
105
- inputSchema: {
106
- type: "object",
107
- properties: {
108
- projectRoot: {
109
- type: "string",
110
- description: "Root directory of the project",
111
- },
112
- assessmentType: {
113
- type: "string",
114
- enum: ["quick", "comprehensive"],
115
- default: "comprehensive",
116
- description: "Type of assessment to perform",
117
- },
118
- focusMetrics: {
119
- type: "array",
120
- items: {
121
- type: "string",
122
- enum: [
123
- "complexity",
124
- "coupling",
125
- "cohesion",
126
- "testability",
127
- "scalability",
128
- ],
129
- },
130
- description: "Specific metrics to focus assessment on",
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
- required: ["projectRoot"],
115
+ description: "Specific metrics to focus assessment on",
134
116
  },
135
117
  },
136
- ],
137
- };
138
- });
139
- this.server.setRequestHandler(CallToolRequestSchema, async (request) => {
140
- const { name, arguments: args } = request.params;
141
- try {
142
- switch (name) {
143
- case "context-analysis":
144
- return await this.contextAnalysis(args);
145
- case "codebase-structure":
146
- return await this.codebaseStructure(args);
147
- case "dependency-analysis":
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
- declare class XrayAutoFormatServer {
7
- private server;
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 };