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.
- package/dist/src/cli/commands/guidance.js +487 -668
- package/dist/src/cli/commands/index-validate.js +18 -29
- package/dist/src/cli/commands/mcp-troubleshoot.js +230 -282
- package/dist/src/cli/commands/neural-goal-init.js +92 -125
- package/dist/src/cli/commands/swarm-exec.js +317 -393
- package/dist/src/cli/commands/swarm.js +1 -1
- package/dist/src/cli/commands/validate-framework.js +983 -1100
- package/dist/src/cli/commands/validate.js +144 -223
- package/dist/src/cli/simple-commands/__tests__/agent.test.js +265 -277
- package/dist/src/cli/simple-commands/__tests__/memory.test.js +6 -7
- package/dist/src/cli/simple-commands/__tests__/swarm.test.js +373 -356
- package/dist/src/cli/simple-commands/__tests__/task.test.js +6 -7
- package/dist/src/cli/simple-commands/agent.js +157 -193
- package/dist/src/cli/simple-commands/analysis.js +336 -446
- package/dist/src/cli/simple-commands/automation-executor.js +1095 -1339
- package/dist/src/cli/simple-commands/automation.js +481 -469
- package/dist/src/cli/simple-commands/batch-manager.js +261 -313
- package/dist/src/cli/simple-commands/claude-telemetry.js +241 -267
- package/dist/src/cli/simple-commands/claude-track.js +68 -90
- package/dist/src/cli/simple-commands/concurrent-display.js +266 -320
- package/dist/src/cli/simple-commands/config.js +245 -290
- package/dist/src/cli/simple-commands/coordination.js +182 -234
- package/dist/src/cli/simple-commands/enhanced-ui-views.js +812 -615
- package/dist/src/cli/simple-commands/enhanced-webui-complete.js +922 -981
- package/dist/src/cli/simple-commands/fix-hook-variables.js +274 -294
- package/dist/src/cli/simple-commands/github/gh-coordinator.js +378 -457
- package/dist/src/cli/simple-commands/github/github-api.js +535 -574
- package/dist/src/cli/simple-commands/github/init.js +276 -303
- package/dist/src/cli/simple-commands/github.js +222 -247
- package/dist/src/cli/simple-commands/goal.js +51 -63
- package/dist/src/cli/simple-commands/hive-mind/auto-save-middleware.js +208 -278
- package/dist/src/cli/simple-commands/hive-mind/communication.js +601 -696
- package/dist/src/cli/simple-commands/hive-mind/core.js +907 -979
- package/dist/src/cli/simple-commands/hive-mind/db-optimizer.js +406 -655
- package/dist/src/cli/simple-commands/hive-mind/mcp-wrapper.js +1125 -1245
- package/dist/src/cli/simple-commands/hive-mind/memory.js +854 -1090
- package/dist/src/cli/simple-commands/hive-mind/performance-optimizer.js +459 -574
- package/dist/src/cli/simple-commands/hive-mind/performance-test.js +263 -347
- package/dist/src/cli/simple-commands/hive-mind/queen.js +727 -768
- package/dist/src/cli/simple-commands/hive-mind/session-manager.js +745 -1049
- package/dist/src/cli/simple-commands/hive-mind-optimize.js +227 -283
- package/dist/src/cli/simple-commands/hive-mind-wizard.js +174 -217
- package/dist/src/cli/simple-commands/hive-mind.js +1842 -2283
- package/dist/src/cli/simple-commands/hive.js +90 -79
- package/dist/src/cli/simple-commands/hook-safety.js +431 -521
- package/dist/src/cli/simple-commands/hooks/session-start-soul.js +203 -254
- package/dist/src/cli/simple-commands/hooks.js +1064 -1204
- package/dist/src/cli/simple-commands/init/agent-copier.js +294 -319
- package/dist/src/cli/simple-commands/init/batch-init.js +496 -562
- package/dist/src/cli/simple-commands/init/claude-commands/claude-flow-commands.js +13 -19
- package/dist/src/cli/simple-commands/init/claude-commands/optimized-claude-flow-commands.js +13 -19
- package/dist/src/cli/simple-commands/init/claude-commands/optimized-slash-commands.js +61 -88
- package/dist/src/cli/simple-commands/init/claude-commands/optimized-sparc-commands.js +125 -150
- package/dist/src/cli/simple-commands/init/claude-commands/slash-commands.js +42 -49
- package/dist/src/cli/simple-commands/init/claude-commands/sparc-commands.js +43 -61
- package/dist/src/cli/simple-commands/init/copy-revised-templates.js +141 -147
- package/dist/src/cli/simple-commands/init/executable-wrapper.js +31 -44
- package/dist/src/cli/simple-commands/init/gitignore-updater.js +64 -90
- package/dist/src/cli/simple-commands/init/help.js +104 -107
- package/dist/src/cli/simple-commands/init/hive-mind-init.js +509 -528
- package/dist/src/cli/simple-commands/init/index.js +1510 -1759
- package/dist/src/cli/simple-commands/init/performance-monitor.js +234 -317
- package/dist/src/cli/simple-commands/init/rollback/backup-manager.js +441 -504
- package/dist/src/cli/simple-commands/init/rollback/index.js +289 -364
- package/dist/src/cli/simple-commands/init/rollback/recovery-manager.js +652 -728
- package/dist/src/cli/simple-commands/init/rollback/rollback-executor.js +416 -481
- package/dist/src/cli/simple-commands/init/rollback/state-tracker.js +369 -448
- package/dist/src/cli/simple-commands/init/sparc/roo-readme.js +1 -2
- package/dist/src/cli/simple-commands/init/sparc/roomodes-config.js +122 -99
- package/dist/src/cli/simple-commands/init/sparc/workflows.js +32 -37
- package/dist/src/cli/simple-commands/init/sparc-structure.js +55 -62
- package/dist/src/cli/simple-commands/init/template-copier.js +421 -533
- package/dist/src/cli/simple-commands/init/templates/coordination-md.js +3 -6
- package/dist/src/cli/simple-commands/init/templates/enhanced-templates.js +344 -318
- package/dist/src/cli/simple-commands/init/templates/github-safe-enhanced.js +173 -218
- package/dist/src/cli/simple-commands/init/templates/github-safe.js +65 -75
- package/dist/src/cli/simple-commands/init/templates/memory-bank-md.js +3 -6
- package/dist/src/cli/simple-commands/init/templates/readme-files.js +2 -4
- package/dist/src/cli/simple-commands/init/templates/safe-hook-patterns.js +187 -230
- package/dist/src/cli/simple-commands/init/templates/sparc-modes.js +53 -80
- package/dist/src/cli/simple-commands/init/templates/verification-claude-md.js +101 -85
- package/dist/src/cli/simple-commands/init/validation/config-validator.js +283 -330
- package/dist/src/cli/simple-commands/init/validation/health-checker.js +495 -561
- package/dist/src/cli/simple-commands/init/validation/index.js +302 -358
- package/dist/src/cli/simple-commands/init/validation/mode-validator.js +308 -359
- package/dist/src/cli/simple-commands/init/validation/post-init-validator.js +389 -366
- package/dist/src/cli/simple-commands/init/validation/pre-init-validator.js +270 -268
- package/dist/src/cli/simple-commands/init/validation/test-runner.js +427 -447
- package/dist/src/cli/simple-commands/init.js +1 -2
- package/dist/src/cli/simple-commands/mcp-health.js +131 -158
- package/dist/src/cli/simple-commands/mcp-integration-layer.js +533 -634
- package/dist/src/cli/simple-commands/mcp.js +345 -400
- package/dist/src/cli/simple-commands/memory-consolidation.js +426 -537
- package/dist/src/cli/simple-commands/memory.js +247 -311
- package/dist/src/cli/simple-commands/migrate-hooks.js +39 -46
- package/dist/src/cli/simple-commands/monitor.js +294 -363
- package/dist/src/cli/simple-commands/neural.js +51 -65
- package/dist/src/cli/simple-commands/pair-autofix-only.js +538 -662
- package/dist/src/cli/simple-commands/pair-basic.js +528 -656
- package/dist/src/cli/simple-commands/pair-old.js +430 -543
- package/dist/src/cli/simple-commands/pair-working.js +615 -751
- package/dist/src/cli/simple-commands/pair.js +615 -751
- package/dist/src/cli/simple-commands/performance-hooks.js +83 -111
- package/dist/src/cli/simple-commands/performance-metrics.js +348 -433
- package/dist/src/cli/simple-commands/process-ui-enhanced.js +708 -787
- package/dist/src/cli/simple-commands/process-ui.js +230 -254
- package/dist/src/cli/simple-commands/realtime-update-system.js +525 -611
- package/dist/src/cli/simple-commands/sparc/architecture.js +1704 -1530
- package/dist/src/cli/simple-commands/sparc/commands.js +438 -516
- package/dist/src/cli/simple-commands/sparc/completion.js +1224 -1481
- package/dist/src/cli/simple-commands/sparc/coordinator.js +913 -978
- package/dist/src/cli/simple-commands/sparc/index.js +241 -298
- package/dist/src/cli/simple-commands/sparc/phase-base.js +314 -390
- package/dist/src/cli/simple-commands/sparc/pseudocode.js +965 -869
- package/dist/src/cli/simple-commands/sparc/refinement.js +980 -1273
- package/dist/src/cli/simple-commands/sparc/specification.js +559 -645
- package/dist/src/cli/simple-commands/sparc-modes/architect.js +1 -1
- package/dist/src/cli/simple-commands/sparc-modes/ask.js +1 -1
- package/dist/src/cli/simple-commands/sparc-modes/code.js +1 -1
- package/dist/src/cli/simple-commands/sparc-modes/debug.js +1 -1
- package/dist/src/cli/simple-commands/sparc-modes/devops.js +1 -1
- package/dist/src/cli/simple-commands/sparc-modes/docs-writer.js +1 -1
- package/dist/src/cli/simple-commands/sparc-modes/generic.js +1 -1
- package/dist/src/cli/simple-commands/sparc-modes/index.js +47 -55
- package/dist/src/cli/simple-commands/sparc-modes/integration.js +1 -1
- package/dist/src/cli/simple-commands/sparc-modes/mcp.js +1 -1
- package/dist/src/cli/simple-commands/sparc-modes/monitoring.js +1 -1
- package/dist/src/cli/simple-commands/sparc-modes/optimization.js +1 -1
- package/dist/src/cli/simple-commands/sparc-modes/security-review.js +1 -1
- package/dist/src/cli/simple-commands/sparc-modes/sparc-orchestrator.js +1 -1
- package/dist/src/cli/simple-commands/sparc-modes/spec-pseudocode.js +1 -1
- package/dist/src/cli/simple-commands/sparc-modes/supabase-admin.js +1 -1
- package/dist/src/cli/simple-commands/sparc-modes/swarm.js +101 -87
- package/dist/src/cli/simple-commands/sparc-modes/tdd.js +1 -1
- package/dist/src/cli/simple-commands/sparc-modes/tutorial.js +1 -1
- package/dist/src/cli/simple-commands/sparc.js +465 -493
- package/dist/src/cli/simple-commands/start-ui.js +108 -132
- package/dist/src/cli/simple-commands/start-wrapper.js +240 -268
- package/dist/src/cli/simple-commands/start.js +1 -1
- package/dist/src/cli/simple-commands/status.js +254 -275
- package/dist/src/cli/simple-commands/stream-chain-clean.js +128 -171
- package/dist/src/cli/simple-commands/stream-chain-fixed.js +61 -82
- package/dist/src/cli/simple-commands/stream-chain-real.js +267 -331
- package/dist/src/cli/simple-commands/stream-chain-working.js +211 -263
- package/dist/src/cli/simple-commands/stream-chain.js +260 -318
- package/dist/src/cli/simple-commands/stream-processor.js +290 -315
- package/dist/src/cli/simple-commands/swarm-executor.js +189 -222
- package/dist/src/cli/simple-commands/swarm-metrics-integration.js +208 -300
- package/dist/src/cli/simple-commands/swarm-ui.js +623 -703
- package/dist/src/cli/simple-commands/swarm-webui-integration.js +258 -286
- package/dist/src/cli/simple-commands/swarm.js +887 -1082
- package/dist/src/cli/simple-commands/task.js +161 -206
- package/dist/src/cli/simple-commands/timestamp-fix.js +59 -89
- package/dist/src/cli/simple-commands/token-tracker.js +258 -316
- package/dist/src/cli/simple-commands/tool-execution-framework.js +433 -519
- package/dist/src/cli/simple-commands/train-and-stream.js +275 -331
- package/dist/src/cli/simple-commands/training-pipeline.js +619 -725
- package/dist/src/cli/simple-commands/training.js +170 -227
- package/dist/src/cli/simple-commands/verification-hooks.js +261 -284
- package/dist/src/cli/simple-commands/verification-integration.js +389 -417
- package/dist/src/cli/simple-commands/verification-training-integration.js +486 -606
- package/dist/src/cli/simple-commands/verification.js +493 -513
- package/dist/src/cli/simple-commands/web-server.js +766 -836
- package/dist/src/cli/simple-commands/webui-validator.js +106 -124
- package/dist/src/coordination/event-bus/demo-wasm-integration.js +212 -251
- package/dist/src/coordination/event-bus/qe-event-bus.js +608 -748
- package/dist/src/coordination/event-bus/qe-event-bus.test.js +379 -454
- package/dist/src/coordination/iteration-tracker.js +363 -454
- package/dist/src/enterprise/analytics-manager.js +1135 -0
- package/dist/src/enterprise/audit-manager.js +1115 -0
- package/dist/src/enterprise/cloud-manager.js +891 -0
- package/dist/src/enterprise/deployment-manager.js +966 -0
- package/dist/src/enterprise/index.js +6 -0
- package/dist/src/enterprise/project-manager.js +584 -0
- package/dist/src/enterprise/security-manager.js +991 -0
- package/dist/src/index.js +1 -1
- package/dist/src/mcp/DEPRECATED.js +46 -60
- package/dist/src/mcp/fixes/mcp-error-fixes.js +115 -134
- package/dist/src/mcp/implementations/agent-tracker.js +114 -128
- package/dist/src/mcp/implementations/daa-tools.js +292 -350
- package/dist/src/mcp/implementations/workflow-tools.js +329 -361
- package/dist/src/mcp/mcp-config-manager.js +1183 -1331
- package/dist/src/mcp/mcp-server-novice-simplified.js +11 -17
- package/dist/src/mcp/mcp-server-novice.js +11 -17
- package/dist/src/mcp/mcp-server-sdk.js +11 -17
- package/dist/src/mcp/mcp-server.js +1620 -1484
- package/dist/src/mcp/ruv-swarm-wrapper.js +209 -239
- package/dist/src/memory/advanced-serializer.js +609 -589
- package/dist/src/memory/enhanced-examples.js +220 -305
- package/dist/src/memory/enhanced-memory.js +295 -336
- package/dist/src/memory/enhanced-session-serializer.js +408 -492
- package/dist/src/memory/fallback-memory-system.js +900 -1021
- package/dist/src/memory/fallback-store.js +93 -131
- package/dist/src/memory/high-performance-serialization.js +592 -730
- package/dist/src/memory/in-memory-store.js +161 -213
- package/dist/src/memory/index.js +123 -157
- package/dist/src/memory/lock-free-structures.js +578 -764
- package/dist/src/memory/memory-mapped-persistence.js +585 -766
- package/dist/src/memory/memory-pressure-manager.js +569 -707
- package/dist/src/memory/migration.js +358 -445
- package/dist/src/memory/shared-memory.js +641 -768
- package/dist/src/memory/sqlite-store.js +245 -325
- package/dist/src/memory/sqlite-wrapper.js +122 -151
- package/dist/src/memory/swarm-memory.js +470 -603
- package/dist/src/memory/test-example.js +126 -134
- package/dist/src/memory/ultra-fast-memory-store.js +622 -821
- package/dist/src/memory/unified-memory-manager.js +356 -437
- package/dist/src/migration/index.js +92 -0
- package/dist/src/migration/logger.js +121 -0
- package/dist/src/migration/migration-analyzer.js +268 -0
- package/dist/src/migration/migration-runner.js +522 -0
- package/dist/src/migration/migration-validator.js +285 -0
- package/dist/src/migration/progress-reporter.js +150 -0
- package/dist/src/migration/rollback-manager.js +321 -0
- package/dist/src/migration/tests/migration-system.test.js +7 -0
- package/dist/src/migration/types.js +3 -0
- package/dist/src/swarm/CodeRefactoringSwarm.js +777 -952
- package/dist/src/swarm/__tests__/integration.test.js +227 -0
- package/dist/src/swarm/__tests__/prompt-copier.test.js +344 -0
- package/dist/src/swarm/advanced-orchestrator.js +1095 -0
- package/dist/src/swarm/claude-code-interface.js +961 -0
- package/dist/src/swarm/claude-flow-executor.js +229 -0
- package/dist/src/swarm/consensus-coordinator.js +475 -0
- package/dist/src/swarm/coordinator.js +2993 -0
- package/dist/src/swarm/direct-executor.js +1180 -0
- package/dist/src/swarm/error-recovery/advanced-error-detection.js +691 -0
- package/dist/src/swarm/error-recovery/automated-recovery-workflows.js +998 -0
- package/dist/src/swarm/error-recovery/error-recovery-coordinator.js +1197 -0
- package/dist/src/swarm/error-recovery/recovery-monitoring.js +772 -0
- package/dist/src/swarm/error-recovery/resilience-architecture.js +714 -0
- package/dist/src/swarm/error-recovery/self-healing-mechanisms.js +1319 -0
- package/dist/src/swarm/error-recovery/test-error-recovery-effectiveness.js +808 -0
- package/dist/src/swarm/executor-v2.js +322 -0
- package/dist/src/swarm/executor.js +815 -0
- package/dist/src/swarm/hive-mind-integration.js +703 -0
- package/dist/src/swarm/index.js +41 -0
- package/dist/src/swarm/json-output-aggregator.js +267 -0
- package/dist/src/swarm/large-scale-coordinator.js +542 -0
- package/dist/src/swarm/mcp-integration-wrapper.js +628 -0
- package/dist/src/swarm/memory.js +1117 -0
- package/dist/src/swarm/optimizations/__tests__/optimization.test.js +348 -0
- package/dist/src/swarm/optimizations/async-file-manager.js +285 -0
- package/dist/src/swarm/optimizations/circular-buffer.js +162 -0
- package/dist/src/swarm/optimizations/connection-pool.js +244 -0
- package/dist/src/swarm/optimizations/index.js +28 -0
- package/dist/src/swarm/optimizations/optimized-executor.js +320 -0
- package/dist/src/swarm/optimizations/ttl-map.js +234 -0
- package/dist/src/swarm/prompt-cli.js +200 -0
- package/dist/src/swarm/prompt-copier-enhanced.js +202 -0
- package/dist/src/swarm/prompt-copier.js +381 -0
- package/dist/src/swarm/prompt-manager.js +295 -0
- package/dist/src/swarm/prompt-utils.js +310 -0
- package/dist/src/swarm/result-aggregator.js +718 -0
- package/dist/src/swarm/sparc-executor.js +1568 -0
- package/dist/src/swarm/strategies/auto.js +758 -0
- package/dist/src/swarm/strategies/base.js +128 -0
- package/dist/src/swarm/strategies/research.js +914 -0
- package/dist/src/swarm/strategies/strategy-metrics-patch.js +2 -0
- package/dist/src/swarm/types.js +52 -0
- package/dist/src/swarm/workers/copy-worker.js +56 -0
- package/dist/src/utils/__tests__/github-cli-safety-wrapper.test.js +332 -400
- package/dist/src/utils/github-cli-safe.js +56 -64
- package/dist/src/utils/github-cli-safety-wrapper.js +451 -546
- package/dist/src/utils/npx-isolated-cache.js +104 -119
- package/dist/src/utils/preference-manager.js +622 -652
- package/dist/src/utils/timezone-utils.js +86 -105
- package/dist/src/validators/epic-config-schema.js +214 -0
- package/dist/src/validators/index.js +10 -0
- package/dist/src/validators/swarm-init-validator.js +259 -0
- package/dist/src/validators/todowrite-batching-validator.js +215 -0
- package/dist/src/validators/todowrite-integration.js +187 -0
- 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
|
|
22
|
-
import
|
|
23
|
-
import
|
|
24
|
-
import
|
|
25
|
-
import
|
|
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
|
-
|
|
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
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
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
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
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
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
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
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
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
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
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
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
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
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
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
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
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
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
486
|
-
|
|
487
|
-
|
|
488
|
-
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
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
|
-
|
|
540
|
-
|
|
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
|
-
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
|
|
549
|
-
|
|
550
|
-
|
|
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
|
-
|
|
566
|
-
|
|
567
|
-
|
|
568
|
-
|
|
569
|
-
|
|
570
|
-
|
|
571
|
-
|
|
572
|
-
|
|
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
|
-
|
|
581
|
-
|
|
582
|
-
|
|
583
|
-
|
|
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
|
-
|
|
588
|
-
|
|
589
|
-
|
|
590
|
-
|
|
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
|
-
|
|
594
|
-
|
|
595
|
-
|
|
596
|
-
|
|
597
|
-
|
|
598
|
-
|
|
599
|
-
|
|
600
|
-
|
|
601
|
-
|
|
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
|
-
|
|
614
|
-
|
|
615
|
-
|
|
616
|
-
|
|
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
|
-
|
|
620
|
-
|
|
621
|
-
|
|
622
|
-
|
|
623
|
-
|
|
624
|
-
|
|
625
|
-
|
|
626
|
-
|
|
627
|
-
|
|
628
|
-
|
|
629
|
-
|
|
630
|
-
|
|
631
|
-
|
|
632
|
-
|
|
633
|
-
|
|
634
|
-
|
|
635
|
-
|
|
636
|
-
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
|
|
640
|
-
|
|
641
|
-
|
|
642
|
-
|
|
643
|
-
|
|
644
|
-
|
|
645
|
-
|
|
646
|
-
|
|
647
|
-
|
|
648
|
-
|
|
649
|
-
|
|
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
|
-
|
|
654
|
-
|
|
655
|
-
|
|
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
|
-
|
|
660
|
-
|
|
661
|
-
|
|
662
|
-
|
|
663
|
-
|
|
664
|
-
|
|
665
|
-
|
|
666
|
-
|
|
667
|
-
|
|
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
|
-
|
|
671
|
-
|
|
672
|
-
|
|
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
|
-
|
|
677
|
-
|
|
678
|
-
|
|
679
|
-
|
|
680
|
-
|
|
681
|
-
|
|
682
|
-
|
|
683
|
-
|
|
684
|
-
|
|
685
|
-
|
|
686
|
-
|
|
687
|
-
|
|
688
|
-
|
|
689
|
-
|
|
690
|
-
|
|
691
|
-
|
|
692
|
-
|
|
693
|
-
|
|
694
|
-
|
|
695
|
-
|
|
696
|
-
|
|
697
|
-
|
|
698
|
-
|
|
699
|
-
|
|
700
|
-
|
|
701
|
-
|
|
702
|
-
|
|
703
|
-
|
|
704
|
-
|
|
705
|
-
|
|
706
|
-
|
|
707
|
-
|
|
708
|
-
|
|
709
|
-
|
|
710
|
-
|
|
711
|
-
|
|
712
|
-
|
|
713
|
-
|
|
714
|
-
|
|
715
|
-
|
|
716
|
-
|
|
717
|
-
|
|
718
|
-
|
|
719
|
-
|
|
720
|
-
|
|
721
|
-
|
|
722
|
-
|
|
723
|
-
|
|
724
|
-
|
|
725
|
-
|
|
726
|
-
|
|
727
|
-
|
|
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
|
-
|
|
747
|
-
|
|
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
|
-
|
|
751
|
-
|
|
752
|
-
|
|
753
|
-
|
|
754
|
-
|
|
755
|
-
|
|
756
|
-
|
|
757
|
-
|
|
758
|
-
|
|
759
|
-
|
|
760
|
-
|
|
761
|
-
|
|
762
|
-
|
|
763
|
-
|
|
764
|
-
|
|
765
|
-
|
|
766
|
-
|
|
767
|
-
|
|
768
|
-
|
|
769
|
-
|
|
770
|
-
|
|
771
|
-
|
|
772
|
-
|
|
773
|
-
|
|
774
|
-
|
|
775
|
-
|
|
776
|
-
|
|
777
|
-
|
|
778
|
-
|
|
779
|
-
|
|
780
|
-
|
|
781
|
-
|
|
782
|
-
|
|
783
|
-
|
|
784
|
-
|
|
785
|
-
|
|
786
|
-
|
|
787
|
-
|
|
788
|
-
|
|
789
|
-
|
|
790
|
-
|
|
791
|
-
|
|
792
|
-
|
|
793
|
-
|
|
794
|
-
|
|
795
|
-
|
|
796
|
-
|
|
797
|
-
|
|
798
|
-
|
|
799
|
-
|
|
800
|
-
|
|
801
|
-
|
|
802
|
-
|
|
803
|
-
|
|
804
|
-
|
|
805
|
-
|
|
806
|
-
|
|
807
|
-
|
|
808
|
-
|
|
809
|
-
|
|
810
|
-
|
|
811
|
-
|
|
812
|
-
|
|
813
|
-
|
|
814
|
-
|
|
815
|
-
|
|
816
|
-
|
|
817
|
-
|
|
818
|
-
|
|
819
|
-
|
|
820
|
-
|
|
821
|
-
|
|
822
|
-
|
|
823
|
-
|
|
824
|
-
|
|
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
|
-
|
|
850
|
-
|
|
851
|
-
|
|
852
|
-
|
|
853
|
-
|
|
854
|
-
|
|
855
|
-
|
|
856
|
-
|
|
857
|
-
|
|
858
|
-
|
|
859
|
-
|
|
860
|
-
|
|
861
|
-
|
|
862
|
-
|
|
863
|
-
|
|
864
|
-
|
|
865
|
-
|
|
866
|
-
|
|
867
|
-
|
|
868
|
-
|
|
869
|
-
|
|
870
|
-
|
|
871
|
-
|
|
872
|
-
|
|
873
|
-
|
|
874
|
-
|
|
875
|
-
|
|
876
|
-
|
|
877
|
-
|
|
878
|
-
|
|
879
|
-
|
|
880
|
-
|
|
881
|
-
|
|
882
|
-
|
|
883
|
-
|
|
884
|
-
|
|
885
|
-
|
|
886
|
-
|
|
887
|
-
|
|
888
|
-
|
|
889
|
-
|
|
890
|
-
|
|
891
|
-
|
|
892
|
-
|
|
893
|
-
|
|
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
|
-
|
|
963
|
-
|
|
964
|
-
|
|
965
|
-
|
|
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
|
-
|
|
981
|
-
|
|
982
|
-
|
|
983
|
-
|
|
984
|
-
|
|
985
|
-
|
|
986
|
-
|
|
987
|
-
|
|
988
|
-
|
|
989
|
-
|
|
990
|
-
|
|
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
|
-
|
|
1030
|
-
|
|
1031
|
-
|
|
1032
|
-
|
|
1033
|
-
|
|
1034
|
-
|
|
1035
|
-
|
|
1036
|
-
|
|
1037
|
-
|
|
1038
|
-
|
|
1039
|
-
|
|
1040
|
-
|
|
1041
|
-
|
|
1042
|
-
|
|
1043
|
-
|
|
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
|
-
|
|
1086
|
-
|
|
1087
|
-
|
|
1088
|
-
|
|
1089
|
-
|
|
1090
|
-
|
|
1091
|
-
|
|
1092
|
-
|
|
1093
|
-
|
|
1094
|
-
|
|
1095
|
-
|
|
1096
|
-
|
|
1097
|
-
|
|
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
|
-
|
|
1149
|
-
|
|
1150
|
-
|
|
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
|
-
|
|
1154
|
-
|
|
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
|
-
|
|
1163
|
-
|
|
1164
|
-
|
|
1165
|
-
|
|
1166
|
-
|
|
1167
|
-
|
|
1168
|
-
|
|
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;
|