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.
Files changed (250) 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 +2 -1
  5. package/README.md +12 -11
  6. package/dist/AGENTS.md +2 -1
  7. package/dist/CHANGELOG.md +38 -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 +13 -10
  168. package/scripts/node/universal-version-manager.js +11 -11
  169. package/src/mcps/architect-tools.server.ts +112 -215
  170. package/src/mcps/auto-format.server.ts +50 -110
  171. package/src/mcps/boot-orchestrator.server.ts +75 -121
  172. package/src/mcps/config/__tests__/server-config-registry.test.ts +21 -12
  173. package/src/mcps/config/server-config-registry.ts +3 -3
  174. package/src/mcps/enforcer-tools.server.ts +212 -310
  175. package/src/mcps/estimation.server.ts +62 -122
  176. package/src/mcps/framework-compliance-audit.server.ts +52 -97
  177. package/src/mcps/framework-help.server.ts +64 -114
  178. package/src/mcps/governance.server.ts +2 -2
  179. package/src/mcps/knowledge-skills/api-design.server.ts +32 -77
  180. package/src/mcps/knowledge-skills/architecture-patterns.server.ts +31 -87
  181. package/src/mcps/knowledge-skills/bug-triage-specialist.server.ts +165 -193
  182. package/src/mcps/knowledge-skills/code-analyzer.server.ts +20 -55
  183. package/src/mcps/knowledge-skills/code-review.server.ts +114 -161
  184. package/src/mcps/knowledge-skills/content-creator.server.ts +218 -255
  185. package/src/mcps/knowledge-skills/database-design.server.ts +118 -165
  186. package/src/mcps/knowledge-skills/devops-deployment.server.ts +67 -172
  187. package/src/mcps/knowledge-skills/git-workflow.server.ts +32 -77
  188. package/src/mcps/knowledge-skills/growth-strategist.server.ts +324 -361
  189. package/src/mcps/knowledge-skills/log-monitor.server.ts +160 -187
  190. package/src/mcps/knowledge-skills/mobile-development.server.ts +89 -223
  191. package/src/mcps/knowledge-skills/multimodal-looker.server.ts +128 -175
  192. package/src/mcps/knowledge-skills/performance-optimization.server.ts +156 -329
  193. package/src/mcps/knowledge-skills/project-analysis.server.ts +72 -248
  194. package/src/mcps/knowledge-skills/refactoring-strategies.server.ts +59 -171
  195. package/src/mcps/knowledge-skills/security-audit.server.ts +104 -151
  196. package/src/mcps/knowledge-skills/seo-consultant.server.ts +80 -220
  197. package/src/mcps/knowledge-skills/session-management.server.ts +51 -232
  198. package/src/mcps/knowledge-skills/skill-invocation.server.ts +165 -372
  199. package/src/mcps/knowledge-skills/strategist.server.ts +72 -143
  200. package/src/mcps/knowledge-skills/tech-writer.server.ts +85 -350
  201. package/src/mcps/knowledge-skills/testing-best-practices.server.ts +146 -195
  202. package/src/mcps/knowledge-skills/testing-strategy.server.ts +75 -161
  203. package/src/mcps/knowledge-skills/ui-ux-design.server.ts +93 -487
  204. package/src/mcps/lint.server.ts +53 -107
  205. package/src/mcps/mcp-client.ts +2 -2
  206. package/src/mcps/model-health-check.server.ts +34 -71
  207. package/src/mcps/performance-analysis.server.ts +60 -104
  208. package/src/mcps/processor-pipeline.server.ts +72 -110
  209. package/src/mcps/registry.json +1 -1
  210. package/src/mcps/researcher.server.ts +88 -177
  211. package/src/mcps/security-scan.server.ts +55 -104
  212. package/src/mcps/shared/knowledge-skill-base.ts +62 -0
  213. package/src/mcps/shared/prompt-security-validator.ts +199 -0
  214. package/src/mcps/shared/security-scanner.ts +599 -0
  215. package/src/mcps/state-manager.server.ts +117 -175
  216. package/src/opencode/codex.codex +1 -1
  217. package/src/opencode/commands/dependency-audit.md +3 -3
  218. package/src/opencode/enforcer-config.json +2 -2
  219. package/src/skills/registry.json +1 -1
  220. package/xray/codex.json +1 -1
  221. package/xray/config.json +1 -1
  222. package/xray/features.json +1 -1
  223. package/xray/integrations.json +3 -3
  224. package/dist/integrations/hermes-agent/__pycache__/__init__.cpython-313.pyc +0 -0
  225. package/dist/integrations/hermes-agent/__pycache__/conftest.cpython-313-pytest-9.0.2.pyc +0 -0
  226. package/dist/integrations/hermes-agent/__pycache__/schemas.cpython-313.pyc +0 -0
  227. package/dist/integrations/hermes-agent/__pycache__/test_plugin.cpython-313-pytest-9.0.2.pyc +0 -0
  228. package/dist/integrations/hermes-agent/__pycache__/test_plugin.cpython-313.pyc +0 -0
  229. package/dist/integrations/hermes-agent/__pycache__/tools.cpython-313.pyc +0 -0
  230. package/dist/integrations/hermes-agent/conftest.py +0 -14
  231. package/dist/integrations/hermes-agent/test_plugin.py +0 -1103
  232. package/dist/processors/implementations/refactoring-logging-processor.d.ts +0 -31
  233. package/dist/processors/implementations/refactoring-logging-processor.js +0 -96
  234. package/dist/processors/implementations/session-capture-processor.d.ts +0 -14
  235. package/dist/processors/implementations/session-capture-processor.js +0 -37
  236. package/dist/scripts/activate-kernel-pipeline.d.ts +0 -7
  237. package/dist/scripts/activate-kernel-pipeline.js +0 -101
  238. package/dist/security/index.d.ts +0 -13
  239. package/dist/security/index.js +0 -13
  240. package/dist/security/security-agent-coordinator.d.ts +0 -72
  241. package/dist/security/security-agent-coordinator.js +0 -204
  242. package/dist/security/security-auditor.d.ts +0 -56
  243. package/dist/security/security-auditor.js +0 -584
  244. package/dist/security/security-hardening-system.d.ts +0 -239
  245. package/dist/security/security-hardening-system.js +0 -727
  246. package/dist/security/security-orchestration-layer.d.ts +0 -119
  247. package/dist/security/security-orchestration-layer.js +0 -496
  248. /package/dist/{security → mcps/shared}/prompt-security-validator.d.ts +0 -0
  249. /package/dist/{security → mcps/shared}/prompt-security-validator.js +0 -0
  250. /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 };