claude-flow-novice 2.0.3 → 2.0.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 (272) hide show
  1. package/dist/src/cli/commands/guidance.js +487 -668
  2. package/dist/src/cli/commands/index-validate.js +18 -29
  3. package/dist/src/cli/commands/mcp-troubleshoot.js +230 -282
  4. package/dist/src/cli/commands/neural-goal-init.js +92 -125
  5. package/dist/src/cli/commands/swarm-exec.js +317 -393
  6. package/dist/src/cli/commands/swarm.js +1 -1
  7. package/dist/src/cli/commands/validate-framework.js +983 -1100
  8. package/dist/src/cli/commands/validate.js +144 -223
  9. package/dist/src/cli/simple-commands/__tests__/agent.test.js +265 -277
  10. package/dist/src/cli/simple-commands/__tests__/memory.test.js +6 -7
  11. package/dist/src/cli/simple-commands/__tests__/swarm.test.js +373 -356
  12. package/dist/src/cli/simple-commands/__tests__/task.test.js +6 -7
  13. package/dist/src/cli/simple-commands/agent.js +157 -193
  14. package/dist/src/cli/simple-commands/analysis.js +336 -446
  15. package/dist/src/cli/simple-commands/automation-executor.js +1095 -1339
  16. package/dist/src/cli/simple-commands/automation.js +481 -469
  17. package/dist/src/cli/simple-commands/batch-manager.js +261 -313
  18. package/dist/src/cli/simple-commands/claude-telemetry.js +241 -267
  19. package/dist/src/cli/simple-commands/claude-track.js +68 -90
  20. package/dist/src/cli/simple-commands/concurrent-display.js +266 -320
  21. package/dist/src/cli/simple-commands/config.js +245 -290
  22. package/dist/src/cli/simple-commands/coordination.js +182 -234
  23. package/dist/src/cli/simple-commands/enhanced-ui-views.js +812 -615
  24. package/dist/src/cli/simple-commands/enhanced-webui-complete.js +922 -981
  25. package/dist/src/cli/simple-commands/fix-hook-variables.js +274 -294
  26. package/dist/src/cli/simple-commands/github/gh-coordinator.js +378 -457
  27. package/dist/src/cli/simple-commands/github/github-api.js +535 -574
  28. package/dist/src/cli/simple-commands/github/init.js +276 -303
  29. package/dist/src/cli/simple-commands/github.js +222 -247
  30. package/dist/src/cli/simple-commands/goal.js +51 -63
  31. package/dist/src/cli/simple-commands/hive-mind/auto-save-middleware.js +208 -278
  32. package/dist/src/cli/simple-commands/hive-mind/communication.js +601 -696
  33. package/dist/src/cli/simple-commands/hive-mind/core.js +907 -979
  34. package/dist/src/cli/simple-commands/hive-mind/db-optimizer.js +406 -655
  35. package/dist/src/cli/simple-commands/hive-mind/mcp-wrapper.js +1125 -1245
  36. package/dist/src/cli/simple-commands/hive-mind/memory.js +854 -1090
  37. package/dist/src/cli/simple-commands/hive-mind/performance-optimizer.js +459 -574
  38. package/dist/src/cli/simple-commands/hive-mind/performance-test.js +263 -347
  39. package/dist/src/cli/simple-commands/hive-mind/queen.js +727 -768
  40. package/dist/src/cli/simple-commands/hive-mind/session-manager.js +745 -1049
  41. package/dist/src/cli/simple-commands/hive-mind-optimize.js +227 -283
  42. package/dist/src/cli/simple-commands/hive-mind-wizard.js +174 -217
  43. package/dist/src/cli/simple-commands/hive-mind.js +1842 -2283
  44. package/dist/src/cli/simple-commands/hive.js +90 -79
  45. package/dist/src/cli/simple-commands/hook-safety.js +431 -521
  46. package/dist/src/cli/simple-commands/hooks/session-start-soul.js +203 -254
  47. package/dist/src/cli/simple-commands/hooks.js +1064 -1204
  48. package/dist/src/cli/simple-commands/init/agent-copier.js +294 -319
  49. package/dist/src/cli/simple-commands/init/batch-init.js +496 -562
  50. package/dist/src/cli/simple-commands/init/claude-commands/claude-flow-commands.js +13 -19
  51. package/dist/src/cli/simple-commands/init/claude-commands/optimized-claude-flow-commands.js +13 -19
  52. package/dist/src/cli/simple-commands/init/claude-commands/optimized-slash-commands.js +61 -88
  53. package/dist/src/cli/simple-commands/init/claude-commands/optimized-sparc-commands.js +125 -150
  54. package/dist/src/cli/simple-commands/init/claude-commands/slash-commands.js +42 -49
  55. package/dist/src/cli/simple-commands/init/claude-commands/sparc-commands.js +43 -61
  56. package/dist/src/cli/simple-commands/init/copy-revised-templates.js +141 -147
  57. package/dist/src/cli/simple-commands/init/executable-wrapper.js +31 -44
  58. package/dist/src/cli/simple-commands/init/gitignore-updater.js +64 -90
  59. package/dist/src/cli/simple-commands/init/help.js +104 -107
  60. package/dist/src/cli/simple-commands/init/hive-mind-init.js +509 -528
  61. package/dist/src/cli/simple-commands/init/index.js +1510 -1759
  62. package/dist/src/cli/simple-commands/init/performance-monitor.js +234 -317
  63. package/dist/src/cli/simple-commands/init/rollback/backup-manager.js +441 -504
  64. package/dist/src/cli/simple-commands/init/rollback/index.js +289 -364
  65. package/dist/src/cli/simple-commands/init/rollback/recovery-manager.js +652 -728
  66. package/dist/src/cli/simple-commands/init/rollback/rollback-executor.js +416 -481
  67. package/dist/src/cli/simple-commands/init/rollback/state-tracker.js +369 -448
  68. package/dist/src/cli/simple-commands/init/sparc/roo-readme.js +1 -2
  69. package/dist/src/cli/simple-commands/init/sparc/roomodes-config.js +122 -99
  70. package/dist/src/cli/simple-commands/init/sparc/workflows.js +32 -37
  71. package/dist/src/cli/simple-commands/init/sparc-structure.js +55 -62
  72. package/dist/src/cli/simple-commands/init/template-copier.js +421 -533
  73. package/dist/src/cli/simple-commands/init/templates/coordination-md.js +3 -6
  74. package/dist/src/cli/simple-commands/init/templates/enhanced-templates.js +344 -318
  75. package/dist/src/cli/simple-commands/init/templates/github-safe-enhanced.js +173 -218
  76. package/dist/src/cli/simple-commands/init/templates/github-safe.js +65 -75
  77. package/dist/src/cli/simple-commands/init/templates/memory-bank-md.js +3 -6
  78. package/dist/src/cli/simple-commands/init/templates/readme-files.js +2 -4
  79. package/dist/src/cli/simple-commands/init/templates/safe-hook-patterns.js +187 -230
  80. package/dist/src/cli/simple-commands/init/templates/sparc-modes.js +53 -80
  81. package/dist/src/cli/simple-commands/init/templates/verification-claude-md.js +101 -85
  82. package/dist/src/cli/simple-commands/init/validation/config-validator.js +283 -330
  83. package/dist/src/cli/simple-commands/init/validation/health-checker.js +495 -561
  84. package/dist/src/cli/simple-commands/init/validation/index.js +302 -358
  85. package/dist/src/cli/simple-commands/init/validation/mode-validator.js +308 -359
  86. package/dist/src/cli/simple-commands/init/validation/post-init-validator.js +389 -366
  87. package/dist/src/cli/simple-commands/init/validation/pre-init-validator.js +270 -268
  88. package/dist/src/cli/simple-commands/init/validation/test-runner.js +427 -447
  89. package/dist/src/cli/simple-commands/init.js +1 -2
  90. package/dist/src/cli/simple-commands/mcp-health.js +131 -158
  91. package/dist/src/cli/simple-commands/mcp-integration-layer.js +533 -634
  92. package/dist/src/cli/simple-commands/mcp.js +345 -400
  93. package/dist/src/cli/simple-commands/memory-consolidation.js +426 -537
  94. package/dist/src/cli/simple-commands/memory.js +247 -311
  95. package/dist/src/cli/simple-commands/migrate-hooks.js +39 -46
  96. package/dist/src/cli/simple-commands/monitor.js +294 -363
  97. package/dist/src/cli/simple-commands/neural.js +51 -65
  98. package/dist/src/cli/simple-commands/pair-autofix-only.js +538 -662
  99. package/dist/src/cli/simple-commands/pair-basic.js +528 -656
  100. package/dist/src/cli/simple-commands/pair-old.js +430 -543
  101. package/dist/src/cli/simple-commands/pair-working.js +615 -751
  102. package/dist/src/cli/simple-commands/pair.js +615 -751
  103. package/dist/src/cli/simple-commands/performance-hooks.js +83 -111
  104. package/dist/src/cli/simple-commands/performance-metrics.js +348 -433
  105. package/dist/src/cli/simple-commands/process-ui-enhanced.js +708 -787
  106. package/dist/src/cli/simple-commands/process-ui.js +230 -254
  107. package/dist/src/cli/simple-commands/realtime-update-system.js +525 -611
  108. package/dist/src/cli/simple-commands/sparc/architecture.js +1704 -1530
  109. package/dist/src/cli/simple-commands/sparc/commands.js +438 -516
  110. package/dist/src/cli/simple-commands/sparc/completion.js +1224 -1481
  111. package/dist/src/cli/simple-commands/sparc/coordinator.js +913 -978
  112. package/dist/src/cli/simple-commands/sparc/index.js +241 -298
  113. package/dist/src/cli/simple-commands/sparc/phase-base.js +314 -390
  114. package/dist/src/cli/simple-commands/sparc/pseudocode.js +965 -869
  115. package/dist/src/cli/simple-commands/sparc/refinement.js +980 -1273
  116. package/dist/src/cli/simple-commands/sparc/specification.js +559 -645
  117. package/dist/src/cli/simple-commands/sparc-modes/architect.js +1 -1
  118. package/dist/src/cli/simple-commands/sparc-modes/ask.js +1 -1
  119. package/dist/src/cli/simple-commands/sparc-modes/code.js +1 -1
  120. package/dist/src/cli/simple-commands/sparc-modes/debug.js +1 -1
  121. package/dist/src/cli/simple-commands/sparc-modes/devops.js +1 -1
  122. package/dist/src/cli/simple-commands/sparc-modes/docs-writer.js +1 -1
  123. package/dist/src/cli/simple-commands/sparc-modes/generic.js +1 -1
  124. package/dist/src/cli/simple-commands/sparc-modes/index.js +47 -55
  125. package/dist/src/cli/simple-commands/sparc-modes/integration.js +1 -1
  126. package/dist/src/cli/simple-commands/sparc-modes/mcp.js +1 -1
  127. package/dist/src/cli/simple-commands/sparc-modes/monitoring.js +1 -1
  128. package/dist/src/cli/simple-commands/sparc-modes/optimization.js +1 -1
  129. package/dist/src/cli/simple-commands/sparc-modes/security-review.js +1 -1
  130. package/dist/src/cli/simple-commands/sparc-modes/sparc-orchestrator.js +1 -1
  131. package/dist/src/cli/simple-commands/sparc-modes/spec-pseudocode.js +1 -1
  132. package/dist/src/cli/simple-commands/sparc-modes/supabase-admin.js +1 -1
  133. package/dist/src/cli/simple-commands/sparc-modes/swarm.js +101 -87
  134. package/dist/src/cli/simple-commands/sparc-modes/tdd.js +1 -1
  135. package/dist/src/cli/simple-commands/sparc-modes/tutorial.js +1 -1
  136. package/dist/src/cli/simple-commands/sparc.js +465 -493
  137. package/dist/src/cli/simple-commands/start-ui.js +108 -132
  138. package/dist/src/cli/simple-commands/start-wrapper.js +240 -268
  139. package/dist/src/cli/simple-commands/start.js +1 -1
  140. package/dist/src/cli/simple-commands/status.js +254 -275
  141. package/dist/src/cli/simple-commands/stream-chain-clean.js +128 -171
  142. package/dist/src/cli/simple-commands/stream-chain-fixed.js +61 -82
  143. package/dist/src/cli/simple-commands/stream-chain-real.js +267 -331
  144. package/dist/src/cli/simple-commands/stream-chain-working.js +211 -263
  145. package/dist/src/cli/simple-commands/stream-chain.js +260 -318
  146. package/dist/src/cli/simple-commands/stream-processor.js +290 -315
  147. package/dist/src/cli/simple-commands/swarm-executor.js +189 -222
  148. package/dist/src/cli/simple-commands/swarm-metrics-integration.js +208 -300
  149. package/dist/src/cli/simple-commands/swarm-ui.js +623 -703
  150. package/dist/src/cli/simple-commands/swarm-webui-integration.js +258 -286
  151. package/dist/src/cli/simple-commands/swarm.js +887 -1082
  152. package/dist/src/cli/simple-commands/task.js +161 -206
  153. package/dist/src/cli/simple-commands/timestamp-fix.js +59 -89
  154. package/dist/src/cli/simple-commands/token-tracker.js +258 -316
  155. package/dist/src/cli/simple-commands/tool-execution-framework.js +433 -519
  156. package/dist/src/cli/simple-commands/train-and-stream.js +275 -331
  157. package/dist/src/cli/simple-commands/training-pipeline.js +619 -725
  158. package/dist/src/cli/simple-commands/training.js +170 -227
  159. package/dist/src/cli/simple-commands/verification-hooks.js +261 -284
  160. package/dist/src/cli/simple-commands/verification-integration.js +389 -417
  161. package/dist/src/cli/simple-commands/verification-training-integration.js +486 -606
  162. package/dist/src/cli/simple-commands/verification.js +493 -513
  163. package/dist/src/cli/simple-commands/web-server.js +766 -836
  164. package/dist/src/cli/simple-commands/webui-validator.js +106 -124
  165. package/dist/src/coordination/event-bus/demo-wasm-integration.js +212 -251
  166. package/dist/src/coordination/event-bus/qe-event-bus.js +608 -748
  167. package/dist/src/coordination/event-bus/qe-event-bus.test.js +379 -454
  168. package/dist/src/coordination/iteration-tracker.js +363 -454
  169. package/dist/src/enterprise/analytics-manager.js +1135 -0
  170. package/dist/src/enterprise/audit-manager.js +1115 -0
  171. package/dist/src/enterprise/cloud-manager.js +891 -0
  172. package/dist/src/enterprise/deployment-manager.js +966 -0
  173. package/dist/src/enterprise/index.js +6 -0
  174. package/dist/src/enterprise/project-manager.js +584 -0
  175. package/dist/src/enterprise/security-manager.js +991 -0
  176. package/dist/src/index.js +1 -1
  177. package/dist/src/mcp/DEPRECATED.js +46 -60
  178. package/dist/src/mcp/fixes/mcp-error-fixes.js +115 -134
  179. package/dist/src/mcp/implementations/agent-tracker.js +114 -128
  180. package/dist/src/mcp/implementations/daa-tools.js +292 -350
  181. package/dist/src/mcp/implementations/workflow-tools.js +329 -361
  182. package/dist/src/mcp/mcp-config-manager.js +1183 -1331
  183. package/dist/src/mcp/mcp-server-novice-simplified.js +11 -17
  184. package/dist/src/mcp/mcp-server-novice.js +11 -17
  185. package/dist/src/mcp/mcp-server-sdk.js +11 -17
  186. package/dist/src/mcp/mcp-server.js +1620 -1484
  187. package/dist/src/mcp/ruv-swarm-wrapper.js +209 -239
  188. package/dist/src/memory/advanced-serializer.js +609 -589
  189. package/dist/src/memory/enhanced-examples.js +220 -305
  190. package/dist/src/memory/enhanced-memory.js +295 -336
  191. package/dist/src/memory/enhanced-session-serializer.js +408 -492
  192. package/dist/src/memory/fallback-memory-system.js +900 -1021
  193. package/dist/src/memory/fallback-store.js +93 -131
  194. package/dist/src/memory/high-performance-serialization.js +592 -730
  195. package/dist/src/memory/in-memory-store.js +161 -213
  196. package/dist/src/memory/index.js +123 -157
  197. package/dist/src/memory/lock-free-structures.js +578 -764
  198. package/dist/src/memory/memory-mapped-persistence.js +585 -766
  199. package/dist/src/memory/memory-pressure-manager.js +569 -707
  200. package/dist/src/memory/migration.js +358 -445
  201. package/dist/src/memory/shared-memory.js +641 -768
  202. package/dist/src/memory/sqlite-store.js +245 -325
  203. package/dist/src/memory/sqlite-wrapper.js +122 -151
  204. package/dist/src/memory/swarm-memory.js +470 -603
  205. package/dist/src/memory/test-example.js +126 -134
  206. package/dist/src/memory/ultra-fast-memory-store.js +622 -821
  207. package/dist/src/memory/unified-memory-manager.js +356 -437
  208. package/dist/src/migration/index.js +92 -0
  209. package/dist/src/migration/logger.js +121 -0
  210. package/dist/src/migration/migration-analyzer.js +268 -0
  211. package/dist/src/migration/migration-runner.js +522 -0
  212. package/dist/src/migration/migration-validator.js +285 -0
  213. package/dist/src/migration/progress-reporter.js +150 -0
  214. package/dist/src/migration/rollback-manager.js +321 -0
  215. package/dist/src/migration/tests/migration-system.test.js +7 -0
  216. package/dist/src/migration/types.js +3 -0
  217. package/dist/src/swarm/CodeRefactoringSwarm.js +777 -952
  218. package/dist/src/swarm/__tests__/integration.test.js +227 -0
  219. package/dist/src/swarm/__tests__/prompt-copier.test.js +344 -0
  220. package/dist/src/swarm/advanced-orchestrator.js +1095 -0
  221. package/dist/src/swarm/claude-code-interface.js +961 -0
  222. package/dist/src/swarm/claude-flow-executor.js +229 -0
  223. package/dist/src/swarm/consensus-coordinator.js +475 -0
  224. package/dist/src/swarm/coordinator.js +2993 -0
  225. package/dist/src/swarm/direct-executor.js +1180 -0
  226. package/dist/src/swarm/error-recovery/advanced-error-detection.js +691 -0
  227. package/dist/src/swarm/error-recovery/automated-recovery-workflows.js +998 -0
  228. package/dist/src/swarm/error-recovery/error-recovery-coordinator.js +1197 -0
  229. package/dist/src/swarm/error-recovery/recovery-monitoring.js +772 -0
  230. package/dist/src/swarm/error-recovery/resilience-architecture.js +714 -0
  231. package/dist/src/swarm/error-recovery/self-healing-mechanisms.js +1319 -0
  232. package/dist/src/swarm/error-recovery/test-error-recovery-effectiveness.js +808 -0
  233. package/dist/src/swarm/executor-v2.js +322 -0
  234. package/dist/src/swarm/executor.js +815 -0
  235. package/dist/src/swarm/hive-mind-integration.js +703 -0
  236. package/dist/src/swarm/index.js +41 -0
  237. package/dist/src/swarm/json-output-aggregator.js +267 -0
  238. package/dist/src/swarm/large-scale-coordinator.js +542 -0
  239. package/dist/src/swarm/mcp-integration-wrapper.js +628 -0
  240. package/dist/src/swarm/memory.js +1117 -0
  241. package/dist/src/swarm/optimizations/__tests__/optimization.test.js +348 -0
  242. package/dist/src/swarm/optimizations/async-file-manager.js +285 -0
  243. package/dist/src/swarm/optimizations/circular-buffer.js +162 -0
  244. package/dist/src/swarm/optimizations/connection-pool.js +244 -0
  245. package/dist/src/swarm/optimizations/index.js +28 -0
  246. package/dist/src/swarm/optimizations/optimized-executor.js +320 -0
  247. package/dist/src/swarm/optimizations/ttl-map.js +234 -0
  248. package/dist/src/swarm/prompt-cli.js +200 -0
  249. package/dist/src/swarm/prompt-copier-enhanced.js +202 -0
  250. package/dist/src/swarm/prompt-copier.js +381 -0
  251. package/dist/src/swarm/prompt-manager.js +295 -0
  252. package/dist/src/swarm/prompt-utils.js +310 -0
  253. package/dist/src/swarm/result-aggregator.js +718 -0
  254. package/dist/src/swarm/sparc-executor.js +1568 -0
  255. package/dist/src/swarm/strategies/auto.js +758 -0
  256. package/dist/src/swarm/strategies/base.js +128 -0
  257. package/dist/src/swarm/strategies/research.js +914 -0
  258. package/dist/src/swarm/strategies/strategy-metrics-patch.js +2 -0
  259. package/dist/src/swarm/types.js +52 -0
  260. package/dist/src/swarm/workers/copy-worker.js +56 -0
  261. package/dist/src/utils/__tests__/github-cli-safety-wrapper.test.js +332 -400
  262. package/dist/src/utils/github-cli-safe.js +56 -64
  263. package/dist/src/utils/github-cli-safety-wrapper.js +451 -546
  264. package/dist/src/utils/npx-isolated-cache.js +104 -119
  265. package/dist/src/utils/preference-manager.js +622 -652
  266. package/dist/src/utils/timezone-utils.js +86 -105
  267. package/dist/src/validators/epic-config-schema.js +214 -0
  268. package/dist/src/validators/index.js +10 -0
  269. package/dist/src/validators/swarm-init-validator.js +259 -0
  270. package/dist/src/validators/todowrite-batching-validator.js +215 -0
  271. package/dist/src/validators/todowrite-integration.js +187 -0
  272. package/package.json +2 -2
@@ -16,1159 +16,1042 @@
16
16
  * - Framework testing and verification
17
17
  * - Integration with Byzantine consensus system
18
18
  * - Security vulnerability scanning
19
- */
20
-
21
- import { promises as fs } from 'fs';
22
- import path from 'path';
23
- import chalk from 'chalk';
24
- import ora from 'ora';
25
- import inquirer from 'inquirer';
26
- import { table } from 'table';
27
- import EnhancedCustomFrameworkValidator from '../validation/custom-framework-validator.js';
28
- import { defaultFrameworkValidator } from '../schemas/custom-framework-schema.js';
29
-
19
+ */ import { promises as fs } from "fs";
20
+ import path from "path";
21
+ import chalk from "chalk";
22
+ import ora from "ora";
23
+ import inquirer from "inquirer";
24
+ import { table } from "table";
25
+ import EnhancedCustomFrameworkValidator from "../validation/custom-framework-validator.js";
30
26
  /**
31
27
  * Framework Validation CLI Handler
32
- */
33
- export class FrameworkValidationCLI {
34
- constructor(options = {}) {
35
- this.options = {
36
- interactive: options.interactive !== false,
37
- verbose: options.verbose === true,
38
- autoFix: options.autoFix === true,
39
- ...options,
40
- };
41
-
42
- this.validator = null;
43
- this.spinner = null;
44
- }
45
-
46
- /**
28
+ */ export class FrameworkValidationCLI {
29
+ /**
47
30
  * Initialize the validation CLI
48
- */
49
- async initialize() {
50
- if (this.validator) return;
51
-
52
- this.spinner = ora('Initializing framework validation system...').start();
53
-
54
- try {
55
- this.validator = new EnhancedCustomFrameworkValidator({
56
- enableByzantineValidation: true,
57
- enableSecuritySandbox: true,
58
- });
59
-
60
- await this.validator.initialize();
61
-
62
- this.spinner.succeed(chalk.green('Framework validation system initialized'));
63
- } catch (error) {
64
- this.spinner.fail(chalk.red(`Failed to initialize: ${error.message}`));
65
- throw error;
31
+ */ async initialize() {
32
+ if (this.validator) return;
33
+ this.spinner = ora('Initializing framework validation system...').start();
34
+ try {
35
+ this.validator = new EnhancedCustomFrameworkValidator({
36
+ enableByzantineValidation: true,
37
+ enableSecuritySandbox: true
38
+ });
39
+ await this.validator.initialize();
40
+ this.spinner.succeed(chalk.green('Framework validation system initialized'));
41
+ } catch (error) {
42
+ this.spinner.fail(chalk.red(`Failed to initialize: ${error.message}`));
43
+ throw error;
44
+ }
66
45
  }
67
- }
68
-
69
- /**
46
+ /**
70
47
  * Main CLI handler
71
- */
72
- async handleCommand(args) {
73
- await this.initialize();
74
-
75
- const [subcommand, ...subArgs] = args;
76
-
77
- switch (subcommand) {
78
- case 'add':
79
- return this.handleAdd(subArgs);
80
- case 'test':
81
- return this.handleTest(subArgs);
82
- case 'list':
83
- return this.handleList(subArgs);
84
- case 'remove':
85
- return this.handleRemove(subArgs);
86
- case 'export':
87
- return this.handleExport(subArgs);
88
- case 'wizard':
89
- return this.handleWizard(subArgs);
90
- case 'validate':
91
- return this.handleValidate(subArgs);
92
- default:
93
- return this.showHelp();
48
+ */ async handleCommand(args) {
49
+ await this.initialize();
50
+ const [subcommand, ...subArgs] = args;
51
+ switch(subcommand){
52
+ case 'add':
53
+ return this.handleAdd(subArgs);
54
+ case 'test':
55
+ return this.handleTest(subArgs);
56
+ case 'list':
57
+ return this.handleList(subArgs);
58
+ case 'remove':
59
+ return this.handleRemove(subArgs);
60
+ case 'export':
61
+ return this.handleExport(subArgs);
62
+ case 'wizard':
63
+ return this.handleWizard(subArgs);
64
+ case 'validate':
65
+ return this.handleValidate(subArgs);
66
+ default:
67
+ return this.showHelp();
68
+ }
94
69
  }
95
- }
96
-
97
- /**
70
+ /**
98
71
  * Handle: claude-flow-novice validate framework add <framework-file>
99
- */
100
- async handleAdd(args) {
101
- const [frameworkFile] = args;
102
-
103
- if (!frameworkFile) {
104
- console.error(chalk.red('āŒ Error: Framework file path is required'));
105
- console.log(
106
- chalk.yellow('šŸ’” Usage: claude-flow-novice validate framework add <framework-file>'),
107
- );
108
- return { success: false, error: 'Missing framework file path' };
109
- }
110
-
111
- try {
112
- // Check if file exists
113
- const frameworkPath = path.resolve(frameworkFile);
114
- await fs.access(frameworkPath);
115
-
116
- // Load and parse framework definition
117
- const frameworkContent = await fs.readFile(frameworkPath, 'utf8');
118
- let frameworkDefinition;
119
-
120
- try {
121
- frameworkDefinition = JSON.parse(frameworkContent);
122
- } catch (parseError) {
123
- console.error(chalk.red('āŒ Error: Invalid JSON in framework file'));
124
- console.error(chalk.gray(` ${parseError.message}`));
125
- return { success: false, error: 'Invalid JSON format' };
126
- }
127
-
128
- // Display framework info
129
- this.displayFrameworkInfo(frameworkDefinition);
130
-
131
- // Ask for confirmation if interactive
132
- if (this.options.interactive) {
133
- const { confirm } = await inquirer.prompt([
134
- {
135
- type: 'confirm',
136
- name: 'confirm',
137
- message: 'Add this custom framework?',
138
- default: true,
139
- },
140
- ]);
141
-
142
- if (!confirm) {
143
- console.log(chalk.yellow('šŸ“‹ Framework addition cancelled'));
144
- return { success: false, cancelled: true };
72
+ */ async handleAdd(args) {
73
+ const [frameworkFile] = args;
74
+ if (!frameworkFile) {
75
+ console.error(chalk.red('āŒ Error: Framework file path is required'));
76
+ console.log(chalk.yellow('šŸ’” Usage: claude-flow-novice validate framework add <framework-file>'));
77
+ return {
78
+ success: false,
79
+ error: 'Missing framework file path'
80
+ };
81
+ }
82
+ try {
83
+ // Check if file exists
84
+ const frameworkPath = path.resolve(frameworkFile);
85
+ await fs.access(frameworkPath);
86
+ // Load and parse framework definition
87
+ const frameworkContent = await fs.readFile(frameworkPath, 'utf8');
88
+ let frameworkDefinition;
89
+ try {
90
+ frameworkDefinition = JSON.parse(frameworkContent);
91
+ } catch (parseError) {
92
+ console.error(chalk.red('āŒ Error: Invalid JSON in framework file'));
93
+ console.error(chalk.gray(` ${parseError.message}`));
94
+ return {
95
+ success: false,
96
+ error: 'Invalid JSON format'
97
+ };
98
+ }
99
+ // Display framework info
100
+ this.displayFrameworkInfo(frameworkDefinition);
101
+ // Ask for confirmation if interactive
102
+ if (this.options.interactive) {
103
+ const { confirm } = await inquirer.prompt([
104
+ {
105
+ type: 'confirm',
106
+ name: 'confirm',
107
+ message: 'Add this custom framework?',
108
+ default: true
109
+ }
110
+ ]);
111
+ if (!confirm) {
112
+ console.log(chalk.yellow('šŸ“‹ Framework addition cancelled'));
113
+ return {
114
+ success: false,
115
+ cancelled: true
116
+ };
117
+ }
118
+ }
119
+ // Start validation process
120
+ const spinner = ora('Validating custom framework...').start();
121
+ let validationResult;
122
+ try {
123
+ validationResult = await this.validator.validateAndAddFramework(frameworkDefinition);
124
+ } catch (error) {
125
+ spinner.fail(chalk.red('Framework validation failed'));
126
+ console.error(chalk.red(`āŒ Error: ${error.message}`));
127
+ return {
128
+ success: false,
129
+ error: error.message
130
+ };
131
+ }
132
+ if (validationResult.success) {
133
+ spinner.succeed(chalk.green('āœ… Framework successfully validated and added'));
134
+ // Display success details
135
+ this.displayValidationSuccess(validationResult);
136
+ // Show framework usage instructions
137
+ this.showUsageInstructions(frameworkDefinition.id);
138
+ } else {
139
+ spinner.fail(chalk.red('āŒ Framework validation failed'));
140
+ // Display detailed error information
141
+ this.displayValidationErrors(validationResult);
142
+ // Show suggestions for fixing issues
143
+ this.showFixingSuggestions(validationResult);
144
+ }
145
+ return validationResult;
146
+ } catch (error) {
147
+ if (error.code === 'ENOENT') {
148
+ console.error(chalk.red(`āŒ Error: Framework file not found: ${frameworkFile}`));
149
+ console.log(chalk.yellow('šŸ’” Tip: Check the file path and ensure the file exists'));
150
+ } else {
151
+ console.error(chalk.red(`āŒ Error: ${error.message}`));
152
+ }
153
+ return {
154
+ success: false,
155
+ error: error.message
156
+ };
145
157
  }
146
- }
147
-
148
- // Start validation process
149
- const spinner = ora('Validating custom framework...').start();
150
-
151
- let validationResult;
152
- try {
153
- validationResult = await this.validator.validateAndAddFramework(frameworkDefinition);
154
- } catch (error) {
155
- spinner.fail(chalk.red('Framework validation failed'));
156
- console.error(chalk.red(`āŒ Error: ${error.message}`));
157
- return { success: false, error: error.message };
158
- }
159
-
160
- if (validationResult.success) {
161
- spinner.succeed(chalk.green('āœ… Framework successfully validated and added'));
162
-
163
- // Display success details
164
- this.displayValidationSuccess(validationResult);
165
-
166
- // Show framework usage instructions
167
- this.showUsageInstructions(frameworkDefinition.id);
168
- } else {
169
- spinner.fail(chalk.red('āŒ Framework validation failed'));
170
-
171
- // Display detailed error information
172
- this.displayValidationErrors(validationResult);
173
-
174
- // Show suggestions for fixing issues
175
- this.showFixingSuggestions(validationResult);
176
- }
177
-
178
- return validationResult;
179
- } catch (error) {
180
- if (error.code === 'ENOENT') {
181
- console.error(chalk.red(`āŒ Error: Framework file not found: ${frameworkFile}`));
182
- console.log(chalk.yellow('šŸ’” Tip: Check the file path and ensure the file exists'));
183
- } else {
184
- console.error(chalk.red(`āŒ Error: ${error.message}`));
185
- }
186
-
187
- return { success: false, error: error.message };
188
158
  }
189
- }
190
-
191
- /**
159
+ /**
192
160
  * Handle: claude-flow-novice validate framework test <framework-id>
193
- */
194
- async handleTest(args) {
195
- const [frameworkId] = args;
196
-
197
- if (!frameworkId) {
198
- console.error(chalk.red('āŒ Error: Framework ID is required'));
199
- console.log(
200
- chalk.yellow('šŸ’” Usage: claude-flow-novice validate framework test <framework-id>'),
201
- );
202
- return { success: false, error: 'Missing framework ID' };
203
- }
204
-
205
- const spinner = ora(`Testing framework: ${frameworkId}...`).start();
206
-
207
- try {
208
- // Create mock completion for testing
209
- const mockCompletion = this.createMockCompletion();
210
-
211
- // Test framework validation
212
- const testResult = await this.validator.validateCompletionWithCustomFramework(
213
- mockCompletion,
214
- frameworkId,
215
- );
216
-
217
- if (testResult.success) {
218
- spinner.succeed(chalk.green(`āœ… Framework test passed: ${frameworkId}`));
219
-
220
- // Display test results
221
- this.displayTestResults(testResult);
222
- } else {
223
- spinner.fail(chalk.red(`āŒ Framework test failed: ${frameworkId}`));
224
-
225
- // Display test failure details
226
- this.displayTestFailure(testResult);
227
- }
228
-
229
- return testResult;
230
- } catch (error) {
231
- spinner.fail(chalk.red(`Framework test error: ${error.message}`));
232
- console.error(chalk.gray(` ${error.stack}`));
233
-
234
- return { success: false, error: error.message };
161
+ */ async handleTest(args) {
162
+ const [frameworkId] = args;
163
+ if (!frameworkId) {
164
+ console.error(chalk.red('āŒ Error: Framework ID is required'));
165
+ console.log(chalk.yellow('šŸ’” Usage: claude-flow-novice validate framework test <framework-id>'));
166
+ return {
167
+ success: false,
168
+ error: 'Missing framework ID'
169
+ };
170
+ }
171
+ const spinner = ora(`Testing framework: ${frameworkId}...`).start();
172
+ try {
173
+ // Create mock completion for testing
174
+ const mockCompletion = this.createMockCompletion();
175
+ // Test framework validation
176
+ const testResult = await this.validator.validateCompletionWithCustomFramework(mockCompletion, frameworkId);
177
+ if (testResult.success) {
178
+ spinner.succeed(chalk.green(`āœ… Framework test passed: ${frameworkId}`));
179
+ // Display test results
180
+ this.displayTestResults(testResult);
181
+ } else {
182
+ spinner.fail(chalk.red(`āŒ Framework test failed: ${frameworkId}`));
183
+ // Display test failure details
184
+ this.displayTestFailure(testResult);
185
+ }
186
+ return testResult;
187
+ } catch (error) {
188
+ spinner.fail(chalk.red(`Framework test error: ${error.message}`));
189
+ console.error(chalk.gray(` ${error.stack}`));
190
+ return {
191
+ success: false,
192
+ error: error.message
193
+ };
194
+ }
235
195
  }
236
- }
237
-
238
- /**
196
+ /**
239
197
  * Handle: claude-flow-novice validate framework list
240
- */
241
- async handleList(args) {
242
- const spinner = ora('Loading custom frameworks...').start();
243
-
244
- try {
245
- const frameworks = await this.getFrameworksList();
246
-
247
- spinner.stop();
248
-
249
- if (frameworks.length === 0) {
250
- console.log(chalk.yellow('šŸ“ No custom frameworks found'));
251
- console.log(
252
- chalk.gray(' Use "claude-flow-novice validate framework add" to add frameworks'),
253
- );
254
- return { success: true, frameworks: [] };
255
- }
256
-
257
- // Display frameworks in table format
258
- this.displayFrameworksTable(frameworks);
259
-
260
- return { success: true, frameworks };
261
- } catch (error) {
262
- spinner.fail(chalk.red(`Failed to load frameworks: ${error.message}`));
263
- return { success: false, error: error.message };
198
+ */ async handleList(args) {
199
+ const spinner = ora('Loading custom frameworks...').start();
200
+ try {
201
+ const frameworks = await this.getFrameworksList();
202
+ spinner.stop();
203
+ if (frameworks.length === 0) {
204
+ console.log(chalk.yellow('šŸ“ No custom frameworks found'));
205
+ console.log(chalk.gray(' Use "claude-flow-novice validate framework add" to add frameworks'));
206
+ return {
207
+ success: true,
208
+ frameworks: []
209
+ };
210
+ }
211
+ // Display frameworks in table format
212
+ this.displayFrameworksTable(frameworks);
213
+ return {
214
+ success: true,
215
+ frameworks
216
+ };
217
+ } catch (error) {
218
+ spinner.fail(chalk.red(`Failed to load frameworks: ${error.message}`));
219
+ return {
220
+ success: false,
221
+ error: error.message
222
+ };
223
+ }
264
224
  }
265
- }
266
-
267
- /**
225
+ /**
268
226
  * Handle: claude-flow-novice validate framework remove <framework-id>
269
- */
270
- async handleRemove(args) {
271
- const [frameworkId] = args;
272
-
273
- if (!frameworkId) {
274
- console.error(chalk.red('āŒ Error: Framework ID is required'));
275
- console.log(
276
- chalk.yellow('šŸ’” Usage: claude-flow-novice validate framework remove <framework-id>'),
277
- );
278
- return { success: false, error: 'Missing framework ID' };
279
- }
280
-
281
- try {
282
- // Check if framework exists
283
- const framework = await this.getFramework(frameworkId);
284
-
285
- if (!framework) {
286
- console.error(chalk.red(`āŒ Error: Framework not found: ${frameworkId}`));
287
- return { success: false, error: 'Framework not found' };
288
- }
289
-
290
- // Display framework info
291
- console.log(chalk.cyan('šŸ—‘ļø Removing custom framework:'));
292
- this.displayFrameworkInfo(framework);
293
-
294
- // Ask for confirmation
295
- const { confirm } = await inquirer.prompt([
296
- {
297
- type: 'confirm',
298
- name: 'confirm',
299
- message: chalk.red('Are you sure you want to remove this framework?'),
300
- default: false,
301
- },
302
- ]);
303
-
304
- if (!confirm) {
305
- console.log(chalk.yellow('šŸ“‹ Framework removal cancelled'));
306
- return { success: false, cancelled: true };
307
- }
308
-
309
- const spinner = ora(`Removing framework: ${frameworkId}...`).start();
310
-
311
- // Remove framework
312
- await this.removeFramework(frameworkId);
313
-
314
- spinner.succeed(chalk.green(`āœ… Framework removed: ${frameworkId}`));
315
-
316
- return { success: true, removed: frameworkId };
317
- } catch (error) {
318
- console.error(chalk.red(`āŒ Error: ${error.message}`));
319
- return { success: false, error: error.message };
227
+ */ async handleRemove(args) {
228
+ const [frameworkId] = args;
229
+ if (!frameworkId) {
230
+ console.error(chalk.red('āŒ Error: Framework ID is required'));
231
+ console.log(chalk.yellow('šŸ’” Usage: claude-flow-novice validate framework remove <framework-id>'));
232
+ return {
233
+ success: false,
234
+ error: 'Missing framework ID'
235
+ };
236
+ }
237
+ try {
238
+ // Check if framework exists
239
+ const framework = await this.getFramework(frameworkId);
240
+ if (!framework) {
241
+ console.error(chalk.red(`āŒ Error: Framework not found: ${frameworkId}`));
242
+ return {
243
+ success: false,
244
+ error: 'Framework not found'
245
+ };
246
+ }
247
+ // Display framework info
248
+ console.log(chalk.cyan('šŸ—‘ļø Removing custom framework:'));
249
+ this.displayFrameworkInfo(framework);
250
+ // Ask for confirmation
251
+ const { confirm } = await inquirer.prompt([
252
+ {
253
+ type: 'confirm',
254
+ name: 'confirm',
255
+ message: chalk.red('Are you sure you want to remove this framework?'),
256
+ default: false
257
+ }
258
+ ]);
259
+ if (!confirm) {
260
+ console.log(chalk.yellow('šŸ“‹ Framework removal cancelled'));
261
+ return {
262
+ success: false,
263
+ cancelled: true
264
+ };
265
+ }
266
+ const spinner = ora(`Removing framework: ${frameworkId}...`).start();
267
+ // Remove framework
268
+ await this.removeFramework(frameworkId);
269
+ spinner.succeed(chalk.green(`āœ… Framework removed: ${frameworkId}`));
270
+ return {
271
+ success: true,
272
+ removed: frameworkId
273
+ };
274
+ } catch (error) {
275
+ console.error(chalk.red(`āŒ Error: ${error.message}`));
276
+ return {
277
+ success: false,
278
+ error: error.message
279
+ };
280
+ }
320
281
  }
321
- }
322
-
323
- /**
282
+ /**
324
283
  * Handle: claude-flow-novice validate framework export <framework-id>
325
- */
326
- async handleExport(args) {
327
- const [frameworkId, outputFile] = args;
328
-
329
- if (!frameworkId) {
330
- console.error(chalk.red('āŒ Error: Framework ID is required'));
331
- console.log(
332
- chalk.yellow(
333
- 'šŸ’” Usage: claude-flow-novice validate framework export <framework-id> [output-file]',
334
- ),
335
- );
336
- return { success: false, error: 'Missing framework ID' };
337
- }
338
-
339
- try {
340
- const framework = await this.getFramework(frameworkId);
341
-
342
- if (!framework) {
343
- console.error(chalk.red(`āŒ Error: Framework not found: ${frameworkId}`));
344
- return { success: false, error: 'Framework not found' };
345
- }
346
-
347
- // Determine output file
348
- const exportFile = outputFile || `${frameworkId}-framework.json`;
349
- const exportPath = path.resolve(exportFile);
350
-
351
- const spinner = ora(`Exporting framework: ${frameworkId}...`).start();
352
-
353
- // Export framework
354
- await fs.writeFile(exportPath, JSON.stringify(framework, null, 2));
355
-
356
- spinner.succeed(chalk.green(`āœ… Framework exported: ${exportPath}`));
357
-
358
- console.log(chalk.gray(` Framework: ${framework.name} v${framework.version}`));
359
- console.log(
360
- chalk.gray(` File size: ${this.formatFileSize(JSON.stringify(framework).length)}`),
361
- );
362
-
363
- return { success: true, exported: exportPath, framework };
364
- } catch (error) {
365
- console.error(chalk.red(`āŒ Error: ${error.message}`));
366
- return { success: false, error: error.message };
284
+ */ async handleExport(args) {
285
+ const [frameworkId, outputFile] = args;
286
+ if (!frameworkId) {
287
+ console.error(chalk.red('āŒ Error: Framework ID is required'));
288
+ console.log(chalk.yellow('šŸ’” Usage: claude-flow-novice validate framework export <framework-id> [output-file]'));
289
+ return {
290
+ success: false,
291
+ error: 'Missing framework ID'
292
+ };
293
+ }
294
+ try {
295
+ const framework = await this.getFramework(frameworkId);
296
+ if (!framework) {
297
+ console.error(chalk.red(`āŒ Error: Framework not found: ${frameworkId}`));
298
+ return {
299
+ success: false,
300
+ error: 'Framework not found'
301
+ };
302
+ }
303
+ // Determine output file
304
+ const exportFile = outputFile || `${frameworkId}-framework.json`;
305
+ const exportPath = path.resolve(exportFile);
306
+ const spinner = ora(`Exporting framework: ${frameworkId}...`).start();
307
+ // Export framework
308
+ await fs.writeFile(exportPath, JSON.stringify(framework, null, 2));
309
+ spinner.succeed(chalk.green(`āœ… Framework exported: ${exportPath}`));
310
+ console.log(chalk.gray(` Framework: ${framework.name} v${framework.version}`));
311
+ console.log(chalk.gray(` File size: ${this.formatFileSize(JSON.stringify(framework).length)}`));
312
+ return {
313
+ success: true,
314
+ exported: exportPath,
315
+ framework
316
+ };
317
+ } catch (error) {
318
+ console.error(chalk.red(`āŒ Error: ${error.message}`));
319
+ return {
320
+ success: false,
321
+ error: error.message
322
+ };
323
+ }
367
324
  }
368
- }
369
-
370
- /**
325
+ /**
371
326
  * Handle: claude-flow-novice validate framework wizard
372
- */
373
- async handleWizard(args) {
374
- console.log(chalk.cyan('šŸ§™ Custom Framework Creation Wizard'));
375
- console.log(chalk.gray("Let's create a custom validation framework step by step\n"));
376
-
377
- try {
378
- // Step 1: Basic Information
379
- const basicInfo = await this.collectBasicInfo();
380
-
381
- // Step 2: Validation Configuration
382
- const validationConfig = await this.collectValidationConfig();
383
-
384
- // Step 3: Validation Rules
385
- const validationRules = await this.collectValidationRules();
386
-
387
- // Step 4: Quality Gates
388
- const qualityGates = await this.collectQualityGates();
389
-
390
- // Step 5: Advanced Options
391
- const advancedOptions = await this.collectAdvancedOptions();
392
-
393
- // Build framework definition
394
- const frameworkDefinition = {
395
- ...basicInfo,
396
- validation_config: validationConfig,
397
- validation_rules: validationRules,
398
- quality_gates: qualityGates,
399
- ...advancedOptions,
400
- metadata: {
401
- created_at: new Date().toISOString(),
402
- author: 'wizard',
403
- generator: 'claude-flow-novice-wizard',
404
- },
405
- };
406
-
407
- // Display preview
408
- console.log(chalk.cyan('\nšŸ“‹ Framework Preview:'));
409
- this.displayFrameworkInfo(frameworkDefinition);
410
-
411
- // Ask for confirmation
412
- const { confirm } = await inquirer.prompt([
413
- {
414
- type: 'confirm',
415
- name: 'confirm',
416
- message: 'Create this framework?',
417
- default: true,
418
- },
419
- ]);
420
-
421
- if (!confirm) {
422
- console.log(chalk.yellow('šŸ“‹ Framework creation cancelled'));
423
- return { success: false, cancelled: true };
424
- }
425
-
426
- // Save framework
427
- const { saveToFile } = await inquirer.prompt([
428
- {
429
- type: 'confirm',
430
- name: 'saveToFile',
431
- message: 'Save framework definition to file?',
432
- default: true,
433
- },
434
- ]);
435
-
436
- if (saveToFile) {
437
- const frameworkFile = `${frameworkDefinition.id}-framework.json`;
438
- await fs.writeFile(frameworkFile, JSON.stringify(frameworkDefinition, null, 2));
439
- console.log(chalk.green(`āœ… Framework saved to: ${frameworkFile}`));
440
- }
441
-
442
- // Add to system
443
- const validationResult = await this.validator.validateAndAddFramework(frameworkDefinition);
444
-
445
- if (validationResult.success) {
446
- console.log(chalk.green('āœ… Framework successfully created and added'));
447
- this.showUsageInstructions(frameworkDefinition.id);
448
- } else {
449
- console.log(chalk.red('āŒ Framework creation failed during validation'));
450
- this.displayValidationErrors(validationResult);
451
- }
452
-
453
- return validationResult;
454
- } catch (error) {
455
- console.error(chalk.red(`āŒ Wizard error: ${error.message}`));
456
- return { success: false, error: error.message };
327
+ */ async handleWizard(args) {
328
+ console.log(chalk.cyan('šŸ§™ Custom Framework Creation Wizard'));
329
+ console.log(chalk.gray("Let's create a custom validation framework step by step\n"));
330
+ try {
331
+ // Step 1: Basic Information
332
+ const basicInfo = await this.collectBasicInfo();
333
+ // Step 2: Validation Configuration
334
+ const validationConfig = await this.collectValidationConfig();
335
+ // Step 3: Validation Rules
336
+ const validationRules = await this.collectValidationRules();
337
+ // Step 4: Quality Gates
338
+ const qualityGates = await this.collectQualityGates();
339
+ // Step 5: Advanced Options
340
+ const advancedOptions = await this.collectAdvancedOptions();
341
+ // Build framework definition
342
+ const frameworkDefinition = {
343
+ ...basicInfo,
344
+ validation_config: validationConfig,
345
+ validation_rules: validationRules,
346
+ quality_gates: qualityGates,
347
+ ...advancedOptions,
348
+ metadata: {
349
+ created_at: new Date().toISOString(),
350
+ author: 'wizard',
351
+ generator: 'claude-flow-novice-wizard'
352
+ }
353
+ };
354
+ // Display preview
355
+ console.log(chalk.cyan('\nšŸ“‹ Framework Preview:'));
356
+ this.displayFrameworkInfo(frameworkDefinition);
357
+ // Ask for confirmation
358
+ const { confirm } = await inquirer.prompt([
359
+ {
360
+ type: 'confirm',
361
+ name: 'confirm',
362
+ message: 'Create this framework?',
363
+ default: true
364
+ }
365
+ ]);
366
+ if (!confirm) {
367
+ console.log(chalk.yellow('šŸ“‹ Framework creation cancelled'));
368
+ return {
369
+ success: false,
370
+ cancelled: true
371
+ };
372
+ }
373
+ // Save framework
374
+ const { saveToFile } = await inquirer.prompt([
375
+ {
376
+ type: 'confirm',
377
+ name: 'saveToFile',
378
+ message: 'Save framework definition to file?',
379
+ default: true
380
+ }
381
+ ]);
382
+ if (saveToFile) {
383
+ const frameworkFile = `${frameworkDefinition.id}-framework.json`;
384
+ await fs.writeFile(frameworkFile, JSON.stringify(frameworkDefinition, null, 2));
385
+ console.log(chalk.green(`āœ… Framework saved to: ${frameworkFile}`));
386
+ }
387
+ // Add to system
388
+ const validationResult = await this.validator.validateAndAddFramework(frameworkDefinition);
389
+ if (validationResult.success) {
390
+ console.log(chalk.green('āœ… Framework successfully created and added'));
391
+ this.showUsageInstructions(frameworkDefinition.id);
392
+ } else {
393
+ console.log(chalk.red('āŒ Framework creation failed during validation'));
394
+ this.displayValidationErrors(validationResult);
395
+ }
396
+ return validationResult;
397
+ } catch (error) {
398
+ console.error(chalk.red(`āŒ Wizard error: ${error.message}`));
399
+ return {
400
+ success: false,
401
+ error: error.message
402
+ };
403
+ }
457
404
  }
458
- }
459
-
460
- /**
405
+ /**
461
406
  * Handle: claude-flow-novice validate framework validate <completion-file> <framework-id>
462
- */
463
- async handleValidate(args) {
464
- const [completionFile, frameworkId] = args;
465
-
466
- if (!completionFile || !frameworkId) {
467
- console.error(chalk.red('āŒ Error: Both completion file and framework ID are required'));
468
- console.log(
469
- chalk.yellow(
470
- 'šŸ’” Usage: claude-flow-novice validate framework validate <completion-file> <framework-id>',
471
- ),
472
- );
473
- return { success: false, error: 'Missing required arguments' };
474
- }
475
-
476
- try {
477
- // Load completion
478
- const completionPath = path.resolve(completionFile);
479
- const completionContent = await fs.readFile(completionPath, 'utf8');
480
- const completion = JSON.parse(completionContent);
481
-
482
- const spinner = ora(`Validating completion with framework: ${frameworkId}...`).start();
483
-
484
- // Validate completion
485
- const validationResult = await this.validator.validateCompletionWithCustomFramework(
486
- completion,
487
- frameworkId,
488
- );
489
-
490
- if (validationResult.success) {
491
- spinner.succeed(chalk.green('āœ… Completion validation passed'));
492
-
493
- // Display validation details
494
- this.displayValidationDetails(validationResult);
495
- } else {
496
- spinner.fail(chalk.red('āŒ Completion validation failed'));
497
-
498
- // Display failure details
499
- this.displayValidationFailure(validationResult);
500
- }
501
-
502
- return validationResult;
503
- } catch (error) {
504
- console.error(chalk.red(`āŒ Error: ${error.message}`));
505
- return { success: false, error: error.message };
506
- }
507
- }
508
-
509
- // Display and helper methods
510
-
511
- displayFrameworkInfo(framework) {
512
- console.log(chalk.cyan('\nšŸ“‹ Framework Information:'));
513
- console.log(` ${chalk.bold('ID:')} ${framework.id}`);
514
- console.log(` ${chalk.bold('Name:')} ${framework.name}`);
515
- console.log(` ${chalk.bold('Version:')} ${framework.version}`);
516
-
517
- if (framework.description) {
518
- console.log(` ${chalk.bold('Description:')} ${framework.description}`);
519
- }
520
-
521
- if (framework.validation_config) {
522
- console.log(
523
- ` ${chalk.bold('Truth Threshold:')} ${framework.validation_config.truth_threshold}`,
524
- );
525
- }
526
-
527
- if (framework.validation_rules) {
528
- console.log(` ${chalk.bold('Validation Rules:')} ${framework.validation_rules.length}`);
529
- }
530
-
531
- if (framework.quality_gates) {
532
- console.log(` ${chalk.bold('Quality Gates:')} ${framework.quality_gates.length}`);
533
- }
534
-
535
- if (framework.extends) {
536
- console.log(` ${chalk.bold('Extends:')} ${framework.extends}`);
407
+ */ async handleValidate(args) {
408
+ const [completionFile, frameworkId] = args;
409
+ if (!completionFile || !frameworkId) {
410
+ console.error(chalk.red('āŒ Error: Both completion file and framework ID are required'));
411
+ console.log(chalk.yellow('šŸ’” Usage: claude-flow-novice validate framework validate <completion-file> <framework-id>'));
412
+ return {
413
+ success: false,
414
+ error: 'Missing required arguments'
415
+ };
416
+ }
417
+ try {
418
+ // Load completion
419
+ const completionPath = path.resolve(completionFile);
420
+ const completionContent = await fs.readFile(completionPath, 'utf8');
421
+ const completion = JSON.parse(completionContent);
422
+ const spinner = ora(`Validating completion with framework: ${frameworkId}...`).start();
423
+ // Validate completion
424
+ const validationResult = await this.validator.validateCompletionWithCustomFramework(completion, frameworkId);
425
+ if (validationResult.success) {
426
+ spinner.succeed(chalk.green('āœ… Completion validation passed'));
427
+ // Display validation details
428
+ this.displayValidationDetails(validationResult);
429
+ } else {
430
+ spinner.fail(chalk.red('āŒ Completion validation failed'));
431
+ // Display failure details
432
+ this.displayValidationFailure(validationResult);
433
+ }
434
+ return validationResult;
435
+ } catch (error) {
436
+ console.error(chalk.red(`āŒ Error: ${error.message}`));
437
+ return {
438
+ success: false,
439
+ error: error.message
440
+ };
441
+ }
537
442
  }
538
-
539
- if (framework.composes) {
540
- console.log(` ${chalk.bold('Composes:')} ${framework.composes.join(', ')}`);
443
+ // Display and helper methods
444
+ displayFrameworkInfo(framework) {
445
+ console.log(chalk.cyan('\nšŸ“‹ Framework Information:'));
446
+ console.log(` ${chalk.bold('ID:')} ${framework.id}`);
447
+ console.log(` ${chalk.bold('Name:')} ${framework.name}`);
448
+ console.log(` ${chalk.bold('Version:')} ${framework.version}`);
449
+ if (framework.description) {
450
+ console.log(` ${chalk.bold('Description:')} ${framework.description}`);
451
+ }
452
+ if (framework.validation_config) {
453
+ console.log(` ${chalk.bold('Truth Threshold:')} ${framework.validation_config.truth_threshold}`);
454
+ }
455
+ if (framework.validation_rules) {
456
+ console.log(` ${chalk.bold('Validation Rules:')} ${framework.validation_rules.length}`);
457
+ }
458
+ if (framework.quality_gates) {
459
+ console.log(` ${chalk.bold('Quality Gates:')} ${framework.quality_gates.length}`);
460
+ }
461
+ if (framework.extends) {
462
+ console.log(` ${chalk.bold('Extends:')} ${framework.extends}`);
463
+ }
464
+ if (framework.composes) {
465
+ console.log(` ${chalk.bold('Composes:')} ${framework.composes.join(', ')}`);
466
+ }
467
+ console.log();
541
468
  }
542
-
543
- console.log();
544
- }
545
-
546
- displayValidationSuccess(result) {
547
- console.log(chalk.green('\nšŸŽ‰ Validation Results:'));
548
- console.log(` ${chalk.bold('Framework ID:')} ${result.frameworkId}`);
549
- console.log(
550
- ` ${chalk.bold('Validation Time:')} ${(result.performance?.totalTime || 0).toFixed(2)}ms`,
551
- );
552
-
553
- if (result.validationResults) {
554
- console.log(
555
- ` ${chalk.bold('Schema Valid:')} ${result.validationResults.schema?.valid ? 'āœ…' : 'āŒ'}`,
556
- );
557
- console.log(
558
- ` ${chalk.bold('Security Check:')} ${result.validationResults.security?.secure ? 'āœ…' : 'āŒ'}`,
559
- );
560
- console.log(
561
- ` ${chalk.bold('Byzantine Approved:')} ${result.validationResults.byzantine?.approved ? 'āœ…' : 'āŒ'}`,
562
- );
469
+ displayValidationSuccess(result) {
470
+ console.log(chalk.green('\nšŸŽ‰ Validation Results:'));
471
+ console.log(` ${chalk.bold('Framework ID:')} ${result.frameworkId}`);
472
+ console.log(` ${chalk.bold('Validation Time:')} ${(result.performance?.totalTime || 0).toFixed(2)}ms`);
473
+ if (result.validationResults) {
474
+ console.log(` ${chalk.bold('Schema Valid:')} ${result.validationResults.schema?.valid ? 'āœ…' : 'āŒ'}`);
475
+ console.log(` ${chalk.bold('Security Check:')} ${result.validationResults.security?.secure ? 'āœ…' : 'āŒ'}`);
476
+ console.log(` ${chalk.bold('Byzantine Approved:')} ${result.validationResults.byzantine?.approved ? 'āœ…' : 'āŒ'}`);
477
+ }
478
+ console.log();
563
479
  }
564
-
565
- console.log();
566
- }
567
-
568
- displayValidationErrors(result) {
569
- console.log(chalk.red('\nāŒ Validation Errors:'));
570
-
571
- if (result.errors) {
572
- result.errors.forEach((error, index) => {
573
- console.log(` ${index + 1}. ${error.message || error}`);
574
- if (error.path) {
575
- console.log(chalk.gray(` Path: ${error.path}`));
480
+ displayValidationErrors(result) {
481
+ console.log(chalk.red('\nāŒ Validation Errors:'));
482
+ if (result.errors) {
483
+ result.errors.forEach((error, index)=>{
484
+ console.log(` ${index + 1}. ${error.message || error}`);
485
+ if (error.path) {
486
+ console.log(chalk.gray(` Path: ${error.path}`));
487
+ }
488
+ });
576
489
  }
577
- });
490
+ if (result.securityViolations) {
491
+ console.log(chalk.red('\nšŸ”’ Security Violations:'));
492
+ result.securityViolations.forEach((violation, index)=>{
493
+ console.log(` ${index + 1}. [${violation.severity.toUpperCase()}] ${violation.message}`);
494
+ });
495
+ }
496
+ if (result.byzantineRejected && result.consensus) {
497
+ console.log(chalk.red('\nšŸ›ļø Byzantine Consensus Rejection:'));
498
+ console.log(` Consensus Ratio: ${(result.consensus.consensusRatio * 100).toFixed(1)}%`);
499
+ console.log(` Security Concerns: ${result.consensus.securityConcerns || 0}`);
500
+ }
501
+ console.log();
578
502
  }
579
-
580
- if (result.securityViolations) {
581
- console.log(chalk.red('\nšŸ”’ Security Violations:'));
582
- result.securityViolations.forEach((violation, index) => {
583
- console.log(` ${index + 1}. [${violation.severity.toUpperCase()}] ${violation.message}`);
584
- });
503
+ showFixingSuggestions(result) {
504
+ console.log(chalk.yellow('šŸ’” Fixing Suggestions:'));
505
+ if (result.errors) {
506
+ result.errors.forEach((error)=>{
507
+ if (error.type === 'missing_required_field') {
508
+ console.log(` • Add the required field: ${error.field}`);
509
+ } else if (error.type === 'invalid_id_format') {
510
+ console.log(` • Framework ID must contain only lowercase letters, numbers, hyphens, and underscores`);
511
+ } else if (error.type === 'truth_threshold_out_of_range') {
512
+ console.log(` • Set truth_threshold between 0.01 and 0.99`);
513
+ }
514
+ });
515
+ }
516
+ if (result.securityViolations) {
517
+ console.log(` • Review and remove security violations in validation rules`);
518
+ console.log(` • Avoid using eval(), Function(), require(), or file system access`);
519
+ console.log(` • Use safe validation patterns and built-in validators`);
520
+ }
521
+ console.log();
585
522
  }
586
-
587
- if (result.byzantineRejected && result.consensus) {
588
- console.log(chalk.red('\nšŸ›ļø Byzantine Consensus Rejection:'));
589
- console.log(` Consensus Ratio: ${(result.consensus.consensusRatio * 100).toFixed(1)}%`);
590
- console.log(` Security Concerns: ${result.consensus.securityConcerns || 0}`);
523
+ showUsageInstructions(frameworkId) {
524
+ console.log(chalk.cyan('šŸš€ Usage Instructions:'));
525
+ console.log(` Test framework:`);
526
+ console.log(chalk.gray(` claude-flow-novice validate framework test ${frameworkId}`));
527
+ console.log(` Validate completion:`);
528
+ console.log(chalk.gray(` claude-flow-novice validate framework validate completion.json ${frameworkId}`));
529
+ console.log(` Export framework:`);
530
+ console.log(chalk.gray(` claude-flow-novice validate framework export ${frameworkId}`));
531
+ console.log();
591
532
  }
592
-
593
- console.log();
594
- }
595
-
596
- showFixingSuggestions(result) {
597
- console.log(chalk.yellow('šŸ’” Fixing Suggestions:'));
598
-
599
- if (result.errors) {
600
- result.errors.forEach((error) => {
601
- if (error.type === 'missing_required_field') {
602
- console.log(` • Add the required field: ${error.field}`);
603
- } else if (error.type === 'invalid_id_format') {
604
- console.log(
605
- ` • Framework ID must contain only lowercase letters, numbers, hyphens, and underscores`,
606
- );
607
- } else if (error.type === 'truth_threshold_out_of_range') {
608
- console.log(` • Set truth_threshold between 0.01 and 0.99`);
533
+ displayTestResults(result) {
534
+ console.log(chalk.green('\nšŸ“Š Test Results:'));
535
+ console.log(` ${chalk.bold('Framework:')} ${result.frameworkUsed} v${result.frameworkVersion || '?'}`);
536
+ console.log(` ${chalk.bold('Truth Score:')} ${(result.truthScore * 100).toFixed(1)}%`);
537
+ console.log(` ${chalk.bold('Threshold:')} ${(result.frameworkTruthThreshold * 100).toFixed(1)}%`);
538
+ if (result.frameworkValidation) {
539
+ console.log(` ${chalk.bold('Rules Passed:')} ${result.frameworkValidation.rulesPassed}/${result.frameworkValidation.rulesExecuted}`);
540
+ }
541
+ if (result.qualityGates) {
542
+ console.log(` ${chalk.bold('Quality Gates:')} ${result.qualityGates.gatesPassed}/${result.qualityGates.gatesApplied}`);
609
543
  }
610
- });
544
+ console.log();
611
545
  }
612
-
613
- if (result.securityViolations) {
614
- console.log(` • Review and remove security violations in validation rules`);
615
- console.log(` • Avoid using eval(), Function(), require(), or file system access`);
616
- console.log(` • Use safe validation patterns and built-in validators`);
546
+ displayTestFailure(result) {
547
+ console.log(chalk.red('\nāŒ Test Failure Details:'));
548
+ console.log(` ${chalk.bold('Framework:')} ${result.frameworkUsed}`);
549
+ if (result.error) {
550
+ console.log(` ${chalk.bold('Error:')} ${result.error}`);
551
+ }
552
+ if (result.truthScore !== undefined) {
553
+ console.log(` ${chalk.bold('Truth Score:')} ${(result.truthScore * 100).toFixed(1)}% (Required: ${(result.frameworkTruthThreshold * 100).toFixed(1)}%)`);
554
+ }
555
+ console.log();
617
556
  }
618
-
619
- console.log();
620
- }
621
-
622
- showUsageInstructions(frameworkId) {
623
- console.log(chalk.cyan('šŸš€ Usage Instructions:'));
624
- console.log(` Test framework:`);
625
- console.log(chalk.gray(` claude-flow-novice validate framework test ${frameworkId}`));
626
- console.log(` Validate completion:`);
627
- console.log(
628
- chalk.gray(
629
- ` claude-flow-novice validate framework validate completion.json ${frameworkId}`,
630
- ),
631
- );
632
- console.log(` Export framework:`);
633
- console.log(chalk.gray(` claude-flow-novice validate framework export ${frameworkId}`));
634
- console.log();
635
- }
636
-
637
- displayTestResults(result) {
638
- console.log(chalk.green('\nšŸ“Š Test Results:'));
639
- console.log(
640
- ` ${chalk.bold('Framework:')} ${result.frameworkUsed} v${result.frameworkVersion || '?'}`,
641
- );
642
- console.log(` ${chalk.bold('Truth Score:')} ${(result.truthScore * 100).toFixed(1)}%`);
643
- console.log(
644
- ` ${chalk.bold('Threshold:')} ${(result.frameworkTruthThreshold * 100).toFixed(1)}%`,
645
- );
646
-
647
- if (result.frameworkValidation) {
648
- console.log(
649
- ` ${chalk.bold('Rules Passed:')} ${result.frameworkValidation.rulesPassed}/${result.frameworkValidation.rulesExecuted}`,
650
- );
557
+ displayFrameworksTable(frameworks) {
558
+ console.log(chalk.cyan('\nšŸ“š Custom Frameworks:\n'));
559
+ const tableData = [
560
+ [
561
+ 'ID',
562
+ 'Name',
563
+ 'Version',
564
+ 'Rules',
565
+ 'Gates',
566
+ 'Threshold',
567
+ 'Status'
568
+ ]
569
+ ];
570
+ frameworks.forEach((framework)=>{
571
+ tableData.push([
572
+ framework.id,
573
+ framework.name || 'N/A',
574
+ framework.version || 'N/A',
575
+ framework.validation_rules?.length || 0,
576
+ framework.quality_gates?.length || 0,
577
+ `${((framework.validation_config?.truth_threshold || 0) * 100).toFixed(0)}%`,
578
+ framework.metadata?.validated ? 'āœ…' : 'ā“'
579
+ ]);
580
+ });
581
+ console.log(table(tableData, {
582
+ border: {
583
+ topBody: `─`,
584
+ topJoin: `┬`,
585
+ topLeft: `ā”Œ`,
586
+ topRight: `┐`,
587
+ bottomBody: `─`,
588
+ bottomJoin: `┓`,
589
+ bottomLeft: `ā””`,
590
+ bottomRight: `ā”˜`,
591
+ bodyLeft: `│`,
592
+ bodyRight: `│`,
593
+ bodyJoin: `│`,
594
+ joinBody: `─`,
595
+ joinLeft: `ā”œ`,
596
+ joinRight: `┤`,
597
+ joinJoin: `┼`
598
+ }
599
+ }));
651
600
  }
652
-
653
- if (result.qualityGates) {
654
- console.log(
655
- ` ${chalk.bold('Quality Gates:')} ${result.qualityGates.gatesPassed}/${result.qualityGates.gatesApplied}`,
656
- );
601
+ displayValidationDetails(result) {
602
+ console.log(chalk.green('\nšŸ“Š Validation Details:'));
603
+ console.log(` ${chalk.bold('Truth Score:')} ${(result.truthScore * 100).toFixed(1)}%`);
604
+ if (result.truthScoreComponents) {
605
+ console.log(` ${chalk.bold('Components:')}`);
606
+ Object.entries(result.truthScoreComponents).forEach(([component, score])=>{
607
+ if (component !== 'overall') {
608
+ console.log(` ${component}: ${(score * 100).toFixed(1)}%`);
609
+ }
610
+ });
611
+ }
612
+ console.log();
657
613
  }
658
-
659
- console.log();
660
- }
661
-
662
- displayTestFailure(result) {
663
- console.log(chalk.red('\nāŒ Test Failure Details:'));
664
- console.log(` ${chalk.bold('Framework:')} ${result.frameworkUsed}`);
665
-
666
- if (result.error) {
667
- console.log(` ${chalk.bold('Error:')} ${result.error}`);
614
+ displayValidationFailure(result) {
615
+ console.log(chalk.red('\nāŒ Validation Failure:'));
616
+ console.log(` ${chalk.bold('Framework:')} ${result.frameworkUsed}`);
617
+ if (result.truthScore !== undefined) {
618
+ console.log(` ${chalk.bold('Truth Score:')} ${(result.truthScore * 100).toFixed(1)}%`);
619
+ console.log(` ${chalk.bold('Required:')} ${(result.frameworkTruthThreshold * 100).toFixed(1)}%`);
620
+ }
621
+ if (result.error) {
622
+ console.log(` ${chalk.bold('Error:')} ${result.error}`);
623
+ }
624
+ console.log();
668
625
  }
669
-
670
- if (result.truthScore !== undefined) {
671
- console.log(
672
- ` ${chalk.bold('Truth Score:')} ${(result.truthScore * 100).toFixed(1)}% (Required: ${(result.frameworkTruthThreshold * 100).toFixed(1)}%)`,
673
- );
626
+ async collectBasicInfo() {
627
+ return inquirer.prompt([
628
+ {
629
+ type: 'input',
630
+ name: 'id',
631
+ message: 'Framework ID (lowercase, letters, numbers, hyphens, underscores):',
632
+ validate: (input)=>{
633
+ if (!input) return 'Framework ID is required';
634
+ if (!/^[a-z0-9-_]+$/.test(input)) return 'Invalid ID format';
635
+ return true;
636
+ }
637
+ },
638
+ {
639
+ type: 'input',
640
+ name: 'name',
641
+ message: 'Framework name:',
642
+ validate: (input)=>input ? true : 'Framework name is required'
643
+ },
644
+ {
645
+ type: 'input',
646
+ name: 'version',
647
+ message: 'Version (semver format):',
648
+ default: '1.0.0',
649
+ validate: (input)=>{
650
+ if (!/^\d+\.\d+\.\d+/.test(input)) return 'Use semantic versioning (e.g., 1.0.0)';
651
+ return true;
652
+ }
653
+ },
654
+ {
655
+ type: 'input',
656
+ name: 'description',
657
+ message: 'Framework description (optional):'
658
+ }
659
+ ]);
674
660
  }
675
-
676
- console.log();
677
- }
678
-
679
- displayFrameworksTable(frameworks) {
680
- console.log(chalk.cyan('\nšŸ“š Custom Frameworks:\n'));
681
-
682
- const tableData = [['ID', 'Name', 'Version', 'Rules', 'Gates', 'Threshold', 'Status']];
683
-
684
- frameworks.forEach((framework) => {
685
- tableData.push([
686
- framework.id,
687
- framework.name || 'N/A',
688
- framework.version || 'N/A',
689
- framework.validation_rules?.length || 0,
690
- framework.quality_gates?.length || 0,
691
- `${((framework.validation_config?.truth_threshold || 0) * 100).toFixed(0)}%`,
692
- framework.metadata?.validated ? 'āœ…' : 'ā“',
693
- ]);
694
- });
695
-
696
- console.log(
697
- table(tableData, {
698
- border: {
699
- topBody: `─`,
700
- topJoin: `┬`,
701
- topLeft: `ā”Œ`,
702
- topRight: `┐`,
703
- bottomBody: `─`,
704
- bottomJoin: `┓`,
705
- bottomLeft: `ā””`,
706
- bottomRight: `ā”˜`,
707
- bodyLeft: `│`,
708
- bodyRight: `│`,
709
- bodyJoin: `│`,
710
- joinBody: `─`,
711
- joinLeft: `ā”œ`,
712
- joinRight: `┤`,
713
- joinJoin: `┼`,
714
- },
715
- }),
716
- );
717
- }
718
-
719
- displayValidationDetails(result) {
720
- console.log(chalk.green('\nšŸ“Š Validation Details:'));
721
- console.log(` ${chalk.bold('Truth Score:')} ${(result.truthScore * 100).toFixed(1)}%`);
722
-
723
- if (result.truthScoreComponents) {
724
- console.log(` ${chalk.bold('Components:')}`);
725
- Object.entries(result.truthScoreComponents).forEach(([component, score]) => {
726
- if (component !== 'overall') {
727
- console.log(` ${component}: ${(score * 100).toFixed(1)}%`);
661
+ async collectValidationConfig() {
662
+ const answers = await inquirer.prompt([
663
+ {
664
+ type: 'number',
665
+ name: 'truth_threshold',
666
+ message: 'Truth score threshold (0.01-0.99):',
667
+ default: 0.85,
668
+ validate: (input)=>{
669
+ if (input < 0.01 || input > 0.99) return 'Threshold must be between 0.01 and 0.99';
670
+ return true;
671
+ }
672
+ },
673
+ {
674
+ type: 'confirm',
675
+ name: 'customize_weights',
676
+ message: 'Customize truth component weights?',
677
+ default: false
678
+ }
679
+ ]);
680
+ const config = {
681
+ truth_threshold: answers.truth_threshold
682
+ };
683
+ if (answers.customize_weights) {
684
+ const weights = await inquirer.prompt([
685
+ {
686
+ type: 'number',
687
+ name: 'agent_reliability',
688
+ message: 'Agent reliability weight (0-1):',
689
+ default: 0.3,
690
+ validate: (input)=>input >= 0 && input <= 1 ? true : 'Weight must be between 0 and 1'
691
+ },
692
+ {
693
+ type: 'number',
694
+ name: 'cross_validation',
695
+ message: 'Cross validation weight (0-1):',
696
+ default: 0.25
697
+ },
698
+ {
699
+ type: 'number',
700
+ name: 'external_verification',
701
+ message: 'External verification weight (0-1):',
702
+ default: 0.2
703
+ },
704
+ {
705
+ type: 'number',
706
+ name: 'factual_consistency',
707
+ message: 'Factual consistency weight (0-1):',
708
+ default: 0.15
709
+ },
710
+ {
711
+ type: 'number',
712
+ name: 'logical_coherence',
713
+ message: 'Logical coherence weight (0-1):',
714
+ default: 0.1
715
+ }
716
+ ]);
717
+ config.truth_component_weights = weights;
728
718
  }
729
- });
730
- }
731
-
732
- console.log();
733
- }
734
-
735
- displayValidationFailure(result) {
736
- console.log(chalk.red('\nāŒ Validation Failure:'));
737
- console.log(` ${chalk.bold('Framework:')} ${result.frameworkUsed}`);
738
-
739
- if (result.truthScore !== undefined) {
740
- console.log(` ${chalk.bold('Truth Score:')} ${(result.truthScore * 100).toFixed(1)}%`);
741
- console.log(
742
- ` ${chalk.bold('Required:')} ${(result.frameworkTruthThreshold * 100).toFixed(1)}%`,
743
- );
719
+ return config;
744
720
  }
745
-
746
- if (result.error) {
747
- console.log(` ${chalk.bold('Error:')} ${result.error}`);
721
+ async collectValidationRules() {
722
+ const rules = [];
723
+ let addMore = true;
724
+ while(addMore && rules.length < 10){
725
+ const rule = await inquirer.prompt([
726
+ {
727
+ type: 'input',
728
+ name: 'name',
729
+ message: `Validation rule ${rules.length + 1} name:`,
730
+ validate: (input)=>input ? true : 'Rule name is required'
731
+ },
732
+ {
733
+ type: 'list',
734
+ name: 'type',
735
+ message: 'Rule type:',
736
+ choices: [
737
+ {
738
+ name: 'Threshold check',
739
+ value: 'threshold'
740
+ },
741
+ {
742
+ name: 'Value exists',
743
+ value: 'exists'
744
+ },
745
+ {
746
+ name: 'Range check',
747
+ value: 'range'
748
+ },
749
+ {
750
+ name: 'Custom expression',
751
+ value: 'custom'
752
+ }
753
+ ]
754
+ }
755
+ ]);
756
+ // Collect type-specific configuration
757
+ const typeConfig = await this.collectRuleTypeConfig(rule.type);
758
+ rules.push({
759
+ name: rule.name,
760
+ validator: {
761
+ type: rule.type,
762
+ config: typeConfig
763
+ }
764
+ });
765
+ if (rules.length < 10) {
766
+ const { continueAdding } = await inquirer.prompt([
767
+ {
768
+ type: 'confirm',
769
+ name: 'continueAdding',
770
+ message: 'Add another validation rule?',
771
+ default: false
772
+ }
773
+ ]);
774
+ addMore = continueAdding;
775
+ }
776
+ }
777
+ return rules;
748
778
  }
749
-
750
- console.log();
751
- }
752
-
753
- async collectBasicInfo() {
754
- return inquirer.prompt([
755
- {
756
- type: 'input',
757
- name: 'id',
758
- message: 'Framework ID (lowercase, letters, numbers, hyphens, underscores):',
759
- validate: (input) => {
760
- if (!input) return 'Framework ID is required';
761
- if (!/^[a-z0-9-_]+$/.test(input)) return 'Invalid ID format';
762
- return true;
763
- },
764
- },
765
- {
766
- type: 'input',
767
- name: 'name',
768
- message: 'Framework name:',
769
- validate: (input) => (input ? true : 'Framework name is required'),
770
- },
771
- {
772
- type: 'input',
773
- name: 'version',
774
- message: 'Version (semver format):',
775
- default: '1.0.0',
776
- validate: (input) => {
777
- if (!/^\d+\.\d+\.\d+/.test(input)) return 'Use semantic versioning (e.g., 1.0.0)';
778
- return true;
779
- },
780
- },
781
- {
782
- type: 'input',
783
- name: 'description',
784
- message: 'Framework description (optional):',
785
- },
786
- ]);
787
- }
788
-
789
- async collectValidationConfig() {
790
- const answers = await inquirer.prompt([
791
- {
792
- type: 'number',
793
- name: 'truth_threshold',
794
- message: 'Truth score threshold (0.01-0.99):',
795
- default: 0.85,
796
- validate: (input) => {
797
- if (input < 0.01 || input > 0.99) return 'Threshold must be between 0.01 and 0.99';
798
- return true;
799
- },
800
- },
801
- {
802
- type: 'confirm',
803
- name: 'customize_weights',
804
- message: 'Customize truth component weights?',
805
- default: false,
806
- },
807
- ]);
808
-
809
- const config = { truth_threshold: answers.truth_threshold };
810
-
811
- if (answers.customize_weights) {
812
- const weights = await inquirer.prompt([
813
- {
814
- type: 'number',
815
- name: 'agent_reliability',
816
- message: 'Agent reliability weight (0-1):',
817
- default: 0.3,
818
- validate: (input) => (input >= 0 && input <= 1 ? true : 'Weight must be between 0 and 1'),
819
- },
820
- {
821
- type: 'number',
822
- name: 'cross_validation',
823
- message: 'Cross validation weight (0-1):',
824
- default: 0.25,
825
- },
826
- {
827
- type: 'number',
828
- name: 'external_verification',
829
- message: 'External verification weight (0-1):',
830
- default: 0.2,
831
- },
832
- {
833
- type: 'number',
834
- name: 'factual_consistency',
835
- message: 'Factual consistency weight (0-1):',
836
- default: 0.15,
837
- },
838
- {
839
- type: 'number',
840
- name: 'logical_coherence',
841
- message: 'Logical coherence weight (0-1):',
842
- default: 0.1,
843
- },
844
- ]);
845
-
846
- config.truth_component_weights = weights;
779
+ async collectRuleTypeConfig(type) {
780
+ switch(type){
781
+ case 'threshold':
782
+ return inquirer.prompt([
783
+ {
784
+ type: 'input',
785
+ name: 'field',
786
+ message: 'Field to check (e.g., completion.accuracy):',
787
+ validate: (input)=>input ? true : 'Field is required'
788
+ },
789
+ {
790
+ type: 'number',
791
+ name: 'threshold',
792
+ message: 'Threshold value:',
793
+ validate: (input)=>typeof input === 'number' ? true : 'Must be a number'
794
+ },
795
+ {
796
+ type: 'list',
797
+ name: 'operator',
798
+ message: 'Comparison operator:',
799
+ choices: [
800
+ '>=',
801
+ '>',
802
+ '<=',
803
+ '<',
804
+ '=='
805
+ ],
806
+ default: '>='
807
+ }
808
+ ]);
809
+ case 'exists':
810
+ return inquirer.prompt([
811
+ {
812
+ type: 'input',
813
+ name: 'field',
814
+ message: 'Field that must exist:',
815
+ validate: (input)=>input ? true : 'Field is required'
816
+ }
817
+ ]);
818
+ case 'range':
819
+ return inquirer.prompt([
820
+ {
821
+ type: 'input',
822
+ name: 'field',
823
+ message: 'Field to check:',
824
+ validate: (input)=>input ? true : 'Field is required'
825
+ },
826
+ {
827
+ type: 'number',
828
+ name: 'min',
829
+ message: 'Minimum value:'
830
+ },
831
+ {
832
+ type: 'number',
833
+ name: 'max',
834
+ message: 'Maximum value:'
835
+ }
836
+ ]);
837
+ case 'custom':
838
+ return inquirer.prompt([
839
+ {
840
+ type: 'input',
841
+ name: 'expression',
842
+ message: 'Custom validation expression (safe only):',
843
+ validate: (input)=>{
844
+ if (!input) return 'Expression is required';
845
+ if (input.includes('eval') || input.includes('Function')) {
846
+ return 'Unsafe expressions not allowed';
847
+ }
848
+ return true;
849
+ }
850
+ }
851
+ ]);
852
+ default:
853
+ return {};
854
+ }
847
855
  }
848
-
849
- return config;
850
- }
851
-
852
- async collectValidationRules() {
853
- const rules = [];
854
- let addMore = true;
855
-
856
- while (addMore && rules.length < 10) {
857
- const rule = await inquirer.prompt([
858
- {
859
- type: 'input',
860
- name: 'name',
861
- message: `Validation rule ${rules.length + 1} name:`,
862
- validate: (input) => (input ? true : 'Rule name is required'),
863
- },
864
- {
865
- type: 'list',
866
- name: 'type',
867
- message: 'Rule type:',
868
- choices: [
869
- { name: 'Threshold check', value: 'threshold' },
870
- { name: 'Value exists', value: 'exists' },
871
- { name: 'Range check', value: 'range' },
872
- { name: 'Custom expression', value: 'custom' },
873
- ],
874
- },
875
- ]);
876
-
877
- // Collect type-specific configuration
878
- const typeConfig = await this.collectRuleTypeConfig(rule.type);
879
-
880
- rules.push({
881
- name: rule.name,
882
- validator: {
883
- type: rule.type,
884
- config: typeConfig,
885
- },
886
- });
887
-
888
- if (rules.length < 10) {
889
- const { continueAdding } = await inquirer.prompt([
890
- {
891
- type: 'confirm',
892
- name: 'continueAdding',
893
- message: 'Add another validation rule?',
894
- default: false,
895
- },
896
- ]);
897
- addMore = continueAdding;
898
- }
856
+ async collectQualityGates() {
857
+ const gates = [];
858
+ let addMore = true;
859
+ while(addMore && gates.length < 5){
860
+ const gate = await inquirer.prompt([
861
+ {
862
+ type: 'input',
863
+ name: 'name',
864
+ message: `Quality gate ${gates.length + 1} name:`,
865
+ validate: (input)=>input ? true : 'Gate name is required'
866
+ },
867
+ {
868
+ type: 'list',
869
+ name: 'metric',
870
+ message: 'Metric to check:',
871
+ choices: [
872
+ 'truth_score',
873
+ 'execution_time',
874
+ 'memory_usage',
875
+ 'error_rate',
876
+ 'test_coverage',
877
+ 'code_quality',
878
+ 'security_score'
879
+ ]
880
+ },
881
+ {
882
+ type: 'number',
883
+ name: 'threshold',
884
+ message: 'Threshold value:',
885
+ validate: (input)=>typeof input === 'number' ? true : 'Must be a number'
886
+ }
887
+ ]);
888
+ gates.push(gate);
889
+ if (gates.length < 5) {
890
+ const { continueAdding } = await inquirer.prompt([
891
+ {
892
+ type: 'confirm',
893
+ name: 'continueAdding',
894
+ message: 'Add another quality gate?',
895
+ default: false
896
+ }
897
+ ]);
898
+ addMore = continueAdding;
899
+ }
900
+ }
901
+ return gates;
899
902
  }
900
-
901
- return rules;
902
- }
903
-
904
- async collectRuleTypeConfig(type) {
905
- switch (type) {
906
- case 'threshold':
907
- return inquirer.prompt([
908
- {
909
- type: 'input',
910
- name: 'field',
911
- message: 'Field to check (e.g., completion.accuracy):',
912
- validate: (input) => (input ? true : 'Field is required'),
913
- },
914
- {
915
- type: 'number',
916
- name: 'threshold',
917
- message: 'Threshold value:',
918
- validate: (input) => (typeof input === 'number' ? true : 'Must be a number'),
919
- },
920
- {
921
- type: 'list',
922
- name: 'operator',
923
- message: 'Comparison operator:',
924
- choices: ['>=', '>', '<=', '<', '=='],
925
- default: '>=',
926
- },
927
- ]);
928
-
929
- case 'exists':
930
- return inquirer.prompt([
931
- {
932
- type: 'input',
933
- name: 'field',
934
- message: 'Field that must exist:',
935
- validate: (input) => (input ? true : 'Field is required'),
936
- },
937
- ]);
938
-
939
- case 'range':
940
- return inquirer.prompt([
941
- {
942
- type: 'input',
943
- name: 'field',
944
- message: 'Field to check:',
945
- validate: (input) => (input ? true : 'Field is required'),
946
- },
947
- {
948
- type: 'number',
949
- name: 'min',
950
- message: 'Minimum value:',
951
- },
952
- {
953
- type: 'number',
954
- name: 'max',
955
- message: 'Maximum value:',
956
- },
957
- ]);
958
-
959
- case 'custom':
903
+ async collectAdvancedOptions() {
960
904
  return inquirer.prompt([
961
- {
962
- type: 'input',
963
- name: 'expression',
964
- message: 'Custom validation expression (safe only):',
965
- validate: (input) => {
966
- if (!input) return 'Expression is required';
967
- if (input.includes('eval') || input.includes('Function')) {
968
- return 'Unsafe expressions not allowed';
969
- }
970
- return true;
905
+ {
906
+ type: 'confirm',
907
+ name: 'inheritable',
908
+ message: 'Allow other frameworks to extend this framework?',
909
+ default: true
971
910
  },
972
- },
911
+ {
912
+ type: 'confirm',
913
+ name: 'composable',
914
+ message: 'Allow this framework to be used in composition?',
915
+ default: true
916
+ }
973
917
  ]);
974
-
975
- default:
976
- return {};
977
918
  }
978
- }
979
-
980
- async collectQualityGates() {
981
- const gates = [];
982
- let addMore = true;
983
-
984
- while (addMore && gates.length < 5) {
985
- const gate = await inquirer.prompt([
986
- {
987
- type: 'input',
988
- name: 'name',
989
- message: `Quality gate ${gates.length + 1} name:`,
990
- validate: (input) => (input ? true : 'Gate name is required'),
991
- },
992
- {
993
- type: 'list',
994
- name: 'metric',
995
- message: 'Metric to check:',
996
- choices: [
997
- 'truth_score',
998
- 'execution_time',
999
- 'memory_usage',
1000
- 'error_rate',
1001
- 'test_coverage',
1002
- 'code_quality',
1003
- 'security_score',
1004
- ],
1005
- },
1006
- {
1007
- type: 'number',
1008
- name: 'threshold',
1009
- message: 'Threshold value:',
1010
- validate: (input) => (typeof input === 'number' ? true : 'Must be a number'),
1011
- },
1012
- ]);
1013
-
1014
- gates.push(gate);
1015
-
1016
- if (gates.length < 5) {
1017
- const { continueAdding } = await inquirer.prompt([
1018
- {
1019
- type: 'confirm',
1020
- name: 'continueAdding',
1021
- message: 'Add another quality gate?',
1022
- default: false,
1023
- },
1024
- ]);
1025
- addMore = continueAdding;
1026
- }
919
+ createMockCompletion() {
920
+ return {
921
+ title: 'Test Completion',
922
+ description: 'Mock completion for framework testing',
923
+ accuracy: 0.9,
924
+ execution_time: 1500,
925
+ memory_usage: 256000,
926
+ test_coverage: 0.85,
927
+ code_quality_score: 8.5,
928
+ security_score: 0.95,
929
+ evidence: [
930
+ 'test_evidence'
931
+ ],
932
+ confidence: 0.8
933
+ };
1027
934
  }
1028
-
1029
- return gates;
1030
- }
1031
-
1032
- async collectAdvancedOptions() {
1033
- return inquirer.prompt([
1034
- {
1035
- type: 'confirm',
1036
- name: 'inheritable',
1037
- message: 'Allow other frameworks to extend this framework?',
1038
- default: true,
1039
- },
1040
- {
1041
- type: 'confirm',
1042
- name: 'composable',
1043
- message: 'Allow this framework to be used in composition?',
1044
- default: true,
1045
- },
1046
- ]);
1047
- }
1048
-
1049
- createMockCompletion() {
1050
- return {
1051
- title: 'Test Completion',
1052
- description: 'Mock completion for framework testing',
1053
- accuracy: 0.9,
1054
- execution_time: 1500,
1055
- memory_usage: 256000,
1056
- test_coverage: 0.85,
1057
- code_quality_score: 8.5,
1058
- security_score: 0.95,
1059
- evidence: ['test_evidence'],
1060
- confidence: 0.8,
1061
- };
1062
- }
1063
-
1064
- async getFrameworksList() {
1065
- // In production, this would query the framework registry
1066
- try {
1067
- const frameworksPath = path.join(process.cwd(), '.claude-flow-novice', 'frameworks');
1068
- const files = await fs.readdir(frameworksPath);
1069
- const frameworks = [];
1070
-
1071
- for (const file of files) {
1072
- if (file.endsWith('.json')) {
1073
- const frameworkPath = path.join(frameworksPath, file);
1074
- const content = await fs.readFile(frameworkPath, 'utf8');
1075
- frameworks.push(JSON.parse(content));
935
+ async getFrameworksList() {
936
+ // In production, this would query the framework registry
937
+ try {
938
+ const frameworksPath = path.join(process.cwd(), '.claude-flow-novice', 'frameworks');
939
+ const files = await fs.readdir(frameworksPath);
940
+ const frameworks = [];
941
+ for (const file of files){
942
+ if (file.endsWith('.json')) {
943
+ const frameworkPath = path.join(frameworksPath, file);
944
+ const content = await fs.readFile(frameworkPath, 'utf8');
945
+ frameworks.push(JSON.parse(content));
946
+ }
947
+ }
948
+ return frameworks;
949
+ } catch (error) {
950
+ return [];
1076
951
  }
1077
- }
1078
-
1079
- return frameworks;
1080
- } catch (error) {
1081
- return [];
1082
952
  }
1083
- }
1084
-
1085
- async getFramework(frameworkId) {
1086
- // In production, this would query the framework registry
1087
- try {
1088
- const frameworkPath = path.join(
1089
- process.cwd(),
1090
- '.claude-flow-novice',
1091
- 'frameworks',
1092
- `${frameworkId}.json`,
1093
- );
1094
- const content = await fs.readFile(frameworkPath, 'utf8');
1095
- return JSON.parse(content);
1096
- } catch (error) {
1097
- return null;
953
+ async getFramework(frameworkId) {
954
+ // In production, this would query the framework registry
955
+ try {
956
+ const frameworkPath = path.join(process.cwd(), '.claude-flow-novice', 'frameworks', `${frameworkId}.json`);
957
+ const content = await fs.readFile(frameworkPath, 'utf8');
958
+ return JSON.parse(content);
959
+ } catch (error) {
960
+ return null;
961
+ }
962
+ }
963
+ async removeFramework(frameworkId) {
964
+ // In production, this would use the framework registry
965
+ const frameworkPath = path.join(process.cwd(), '.claude-flow-novice', 'frameworks', `${frameworkId}.json`);
966
+ await fs.unlink(frameworkPath);
967
+ }
968
+ formatFileSize(bytes) {
969
+ const sizes = [
970
+ 'Bytes',
971
+ 'KB',
972
+ 'MB',
973
+ 'GB'
974
+ ];
975
+ if (bytes === 0) return '0 Byte';
976
+ const i = parseInt(Math.floor(Math.log(bytes) / Math.log(1024)));
977
+ return Math.round(bytes / Math.pow(1024, i) * 100) / 100 + ' ' + sizes[i];
978
+ }
979
+ showHelp() {
980
+ console.log(chalk.cyan('\nšŸ” Framework Validation Commands:\n'));
981
+ const commands = [
982
+ [
983
+ 'add <file>',
984
+ 'Add and validate a custom framework'
985
+ ],
986
+ [
987
+ 'test <id>',
988
+ 'Test a framework with mock completion'
989
+ ],
990
+ [
991
+ 'list',
992
+ 'List all custom frameworks'
993
+ ],
994
+ [
995
+ 'remove <id>',
996
+ 'Remove a custom framework'
997
+ ],
998
+ [
999
+ 'export <id> [file]',
1000
+ 'Export framework to file'
1001
+ ],
1002
+ [
1003
+ 'wizard',
1004
+ 'Interactive framework creation wizard'
1005
+ ],
1006
+ [
1007
+ 'validate <completion> <id>',
1008
+ 'Validate completion with framework'
1009
+ ]
1010
+ ];
1011
+ commands.forEach(([cmd, desc])=>{
1012
+ console.log(` ${chalk.yellow('claude-flow-novice validate framework ' + cmd)} ${desc}`);
1013
+ });
1014
+ console.log(chalk.gray('\nExamples:'));
1015
+ console.log(chalk.gray(' claude-flow-novice validate framework add my-framework.json'));
1016
+ console.log(chalk.gray(' claude-flow-novice validate framework wizard'));
1017
+ console.log(chalk.gray(' claude-flow-novice validate framework test my-custom-framework'));
1018
+ console.log();
1019
+ return {
1020
+ success: true,
1021
+ help: true
1022
+ };
1098
1023
  }
1099
- }
1100
-
1101
- async removeFramework(frameworkId) {
1102
- // In production, this would use the framework registry
1103
- const frameworkPath = path.join(
1104
- process.cwd(),
1105
- '.claude-flow-novice',
1106
- 'frameworks',
1107
- `${frameworkId}.json`,
1108
- );
1109
- await fs.unlink(frameworkPath);
1110
- }
1111
-
1112
- formatFileSize(bytes) {
1113
- const sizes = ['Bytes', 'KB', 'MB', 'GB'];
1114
- if (bytes === 0) return '0 Byte';
1115
- const i = parseInt(Math.floor(Math.log(bytes) / Math.log(1024)));
1116
- return Math.round((bytes / Math.pow(1024, i)) * 100) / 100 + ' ' + sizes[i];
1117
- }
1118
-
1119
- showHelp() {
1120
- console.log(chalk.cyan('\nšŸ” Framework Validation Commands:\n'));
1121
-
1122
- const commands = [
1123
- ['add <file>', 'Add and validate a custom framework'],
1124
- ['test <id>', 'Test a framework with mock completion'],
1125
- ['list', 'List all custom frameworks'],
1126
- ['remove <id>', 'Remove a custom framework'],
1127
- ['export <id> [file]', 'Export framework to file'],
1128
- ['wizard', 'Interactive framework creation wizard'],
1129
- ['validate <completion> <id>', 'Validate completion with framework'],
1130
- ];
1131
-
1132
- commands.forEach(([cmd, desc]) => {
1133
- console.log(` ${chalk.yellow('claude-flow-novice validate framework ' + cmd)} ${desc}`);
1134
- });
1135
-
1136
- console.log(chalk.gray('\nExamples:'));
1137
- console.log(chalk.gray(' claude-flow-novice validate framework add my-framework.json'));
1138
- console.log(chalk.gray(' claude-flow-novice validate framework wizard'));
1139
- console.log(chalk.gray(' claude-flow-novice validate framework test my-custom-framework'));
1140
- console.log();
1141
-
1142
- return { success: true, help: true };
1143
- }
1144
-
1145
- /**
1024
+ /**
1146
1025
  * Cleanup resources
1147
- */
1148
- async cleanup() {
1149
- if (this.validator) {
1150
- await this.validator.shutdown();
1026
+ */ async cleanup() {
1027
+ if (this.validator) {
1028
+ await this.validator.shutdown();
1029
+ }
1030
+ if (this.spinner && this.spinner.isSpinning) {
1031
+ this.spinner.stop();
1032
+ }
1151
1033
  }
1152
-
1153
- if (this.spinner && this.spinner.isSpinning) {
1154
- this.spinner.stop();
1034
+ constructor(options = {}){
1035
+ this.options = {
1036
+ interactive: options.interactive !== false,
1037
+ verbose: options.verbose === true,
1038
+ autoFix: options.autoFix === true,
1039
+ ...options
1040
+ };
1041
+ this.validator = null;
1042
+ this.spinner = null;
1155
1043
  }
1156
- }
1157
1044
  }
1158
-
1159
1045
  /**
1160
1046
  * Main CLI handler function
1161
- */
1162
- export async function handleFrameworkValidationCommand(args, options = {}) {
1163
- const cli = new FrameworkValidationCLI(options);
1164
-
1165
- try {
1166
- const result = await cli.handleCommand(args);
1167
- return result;
1168
- } finally {
1169
- await cli.cleanup();
1170
- }
1047
+ */ export async function handleFrameworkValidationCommand(args, options = {}) {
1048
+ const cli = new FrameworkValidationCLI(options);
1049
+ try {
1050
+ const result = await cli.handleCommand(args);
1051
+ return result;
1052
+ } finally{
1053
+ await cli.cleanup();
1054
+ }
1171
1055
  }
1172
-
1173
1056
  // Export default handler
1174
1057
  export default handleFrameworkValidationCommand;