claude-flow-novice 2.0.4 ā 2.0.5
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 +668 -487
- package/dist/src/cli/commands/index-validate.js +29 -18
- package/dist/src/cli/commands/mcp-troubleshoot.js +282 -230
- package/dist/src/cli/commands/neural-goal-init.js +125 -92
- package/dist/src/cli/commands/swarm-exec.js +393 -317
- package/dist/src/cli/commands/validate-framework.js +1100 -983
- package/dist/src/cli/commands/validate.js +223 -144
- package/dist/src/cli/main.js +1 -1
- package/dist/src/cli/simple-commands/__tests__/agent.test.js +277 -265
- package/dist/src/cli/simple-commands/__tests__/memory.test.js +7 -6
- package/dist/src/cli/simple-commands/__tests__/swarm.test.js +356 -373
- package/dist/src/cli/simple-commands/__tests__/task.test.js +7 -6
- package/dist/src/cli/simple-commands/agent.js +193 -157
- package/dist/src/cli/simple-commands/analysis.js +446 -336
- package/dist/src/cli/simple-commands/automation-executor.js +1339 -1095
- package/dist/src/cli/simple-commands/automation.js +469 -481
- package/dist/src/cli/simple-commands/batch-manager.js +313 -261
- package/dist/src/cli/simple-commands/claude-telemetry.js +267 -241
- package/dist/src/cli/simple-commands/claude-track.js +90 -68
- package/dist/src/cli/simple-commands/concurrent-display.js +320 -266
- package/dist/src/cli/simple-commands/config.js +290 -245
- package/dist/src/cli/simple-commands/coordination.js +234 -182
- package/dist/src/cli/simple-commands/enhanced-ui-views.js +615 -812
- package/dist/src/cli/simple-commands/enhanced-webui-complete.js +981 -922
- package/dist/src/cli/simple-commands/fix-hook-variables.js +294 -274
- package/dist/src/cli/simple-commands/github/gh-coordinator.js +457 -378
- package/dist/src/cli/simple-commands/github/github-api.js +574 -535
- package/dist/src/cli/simple-commands/github/init.js +303 -276
- package/dist/src/cli/simple-commands/github.js +247 -222
- package/dist/src/cli/simple-commands/goal.js +63 -51
- package/dist/src/cli/simple-commands/hive-mind/auto-save-middleware.js +278 -208
- package/dist/src/cli/simple-commands/hive-mind/communication.js +696 -601
- package/dist/src/cli/simple-commands/hive-mind/core.js +979 -907
- package/dist/src/cli/simple-commands/hive-mind/db-optimizer.js +655 -406
- package/dist/src/cli/simple-commands/hive-mind/mcp-wrapper.js +1245 -1125
- package/dist/src/cli/simple-commands/hive-mind/memory.js +1090 -854
- package/dist/src/cli/simple-commands/hive-mind/performance-optimizer.js +574 -459
- package/dist/src/cli/simple-commands/hive-mind/performance-test.js +347 -263
- package/dist/src/cli/simple-commands/hive-mind/queen.js +768 -727
- package/dist/src/cli/simple-commands/hive-mind/session-manager.js +1049 -745
- package/dist/src/cli/simple-commands/hive-mind-optimize.js +283 -227
- package/dist/src/cli/simple-commands/hive-mind-wizard.js +217 -174
- package/dist/src/cli/simple-commands/hive-mind.js +2282 -1841
- package/dist/src/cli/simple-commands/hive.js +79 -90
- package/dist/src/cli/simple-commands/hook-safety.js +521 -431
- package/dist/src/cli/simple-commands/hooks/session-start-soul.js +254 -203
- package/dist/src/cli/simple-commands/hooks.js +1204 -1064
- package/dist/src/cli/simple-commands/init/agent-copier.js +319 -294
- package/dist/src/cli/simple-commands/init/batch-init.js +562 -496
- package/dist/src/cli/simple-commands/init/claude-commands/claude-flow-commands.js +19 -13
- package/dist/src/cli/simple-commands/init/claude-commands/optimized-claude-flow-commands.js +19 -13
- package/dist/src/cli/simple-commands/init/claude-commands/optimized-slash-commands.js +88 -61
- package/dist/src/cli/simple-commands/init/claude-commands/optimized-sparc-commands.js +150 -125
- package/dist/src/cli/simple-commands/init/claude-commands/slash-commands.js +49 -42
- package/dist/src/cli/simple-commands/init/claude-commands/sparc-commands.js +61 -43
- package/dist/src/cli/simple-commands/init/copy-revised-templates.js +147 -141
- package/dist/src/cli/simple-commands/init/executable-wrapper.js +44 -31
- package/dist/src/cli/simple-commands/init/gitignore-updater.js +90 -64
- package/dist/src/cli/simple-commands/init/help.js +107 -104
- package/dist/src/cli/simple-commands/init/hive-mind-init.js +528 -509
- package/dist/src/cli/simple-commands/init/index.js +1759 -1510
- package/dist/src/cli/simple-commands/init/performance-monitor.js +317 -234
- package/dist/src/cli/simple-commands/init/rollback/backup-manager.js +504 -441
- package/dist/src/cli/simple-commands/init/rollback/index.js +364 -289
- package/dist/src/cli/simple-commands/init/rollback/recovery-manager.js +728 -652
- package/dist/src/cli/simple-commands/init/rollback/rollback-executor.js +481 -416
- package/dist/src/cli/simple-commands/init/rollback/state-tracker.js +448 -369
- package/dist/src/cli/simple-commands/init/sparc/roo-readme.js +2 -1
- package/dist/src/cli/simple-commands/init/sparc/roomodes-config.js +99 -122
- package/dist/src/cli/simple-commands/init/sparc/workflows.js +37 -32
- package/dist/src/cli/simple-commands/init/sparc-structure.js +62 -55
- package/dist/src/cli/simple-commands/init/template-copier.js +533 -421
- package/dist/src/cli/simple-commands/init/templates/coordination-md.js +6 -3
- package/dist/src/cli/simple-commands/init/templates/enhanced-templates.js +318 -344
- package/dist/src/cli/simple-commands/init/templates/github-safe-enhanced.js +218 -173
- package/dist/src/cli/simple-commands/init/templates/github-safe.js +75 -65
- package/dist/src/cli/simple-commands/init/templates/memory-bank-md.js +6 -3
- package/dist/src/cli/simple-commands/init/templates/readme-files.js +4 -2
- package/dist/src/cli/simple-commands/init/templates/safe-hook-patterns.js +230 -187
- package/dist/src/cli/simple-commands/init/templates/sparc-modes.js +80 -53
- package/dist/src/cli/simple-commands/init/templates/verification-claude-md.js +85 -101
- package/dist/src/cli/simple-commands/init/validation/config-validator.js +330 -283
- package/dist/src/cli/simple-commands/init/validation/health-checker.js +561 -495
- package/dist/src/cli/simple-commands/init/validation/index.js +358 -302
- package/dist/src/cli/simple-commands/init/validation/mode-validator.js +359 -308
- package/dist/src/cli/simple-commands/init/validation/post-init-validator.js +366 -389
- package/dist/src/cli/simple-commands/init/validation/pre-init-validator.js +268 -270
- package/dist/src/cli/simple-commands/init/validation/test-runner.js +447 -427
- package/dist/src/cli/simple-commands/init.js +2 -1
- package/dist/src/cli/simple-commands/mcp-health.js +158 -131
- package/dist/src/cli/simple-commands/mcp-integration-layer.js +634 -533
- package/dist/src/cli/simple-commands/mcp.js +400 -345
- package/dist/src/cli/simple-commands/memory-consolidation.js +537 -426
- package/dist/src/cli/simple-commands/memory.js +311 -247
- package/dist/src/cli/simple-commands/migrate-hooks.js +46 -39
- package/dist/src/cli/simple-commands/monitor.js +363 -294
- package/dist/src/cli/simple-commands/neural.js +65 -51
- package/dist/src/cli/simple-commands/pair-autofix-only.js +662 -538
- package/dist/src/cli/simple-commands/pair-basic.js +656 -528
- package/dist/src/cli/simple-commands/pair-old.js +543 -430
- package/dist/src/cli/simple-commands/pair-working.js +751 -615
- package/dist/src/cli/simple-commands/pair.js +751 -615
- package/dist/src/cli/simple-commands/performance-hooks.js +111 -83
- package/dist/src/cli/simple-commands/performance-metrics.js +433 -348
- package/dist/src/cli/simple-commands/process-ui-enhanced.js +787 -708
- package/dist/src/cli/simple-commands/process-ui.js +254 -230
- package/dist/src/cli/simple-commands/realtime-update-system.js +611 -525
- package/dist/src/cli/simple-commands/sparc/architecture.js +1530 -1704
- package/dist/src/cli/simple-commands/sparc/commands.js +516 -438
- package/dist/src/cli/simple-commands/sparc/completion.js +1481 -1224
- package/dist/src/cli/simple-commands/sparc/coordinator.js +978 -913
- package/dist/src/cli/simple-commands/sparc/index.js +298 -241
- package/dist/src/cli/simple-commands/sparc/phase-base.js +390 -314
- package/dist/src/cli/simple-commands/sparc/pseudocode.js +869 -965
- package/dist/src/cli/simple-commands/sparc/refinement.js +1273 -980
- package/dist/src/cli/simple-commands/sparc/specification.js +645 -559
- 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 +55 -47
- 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 +87 -101
- 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 +493 -465
- package/dist/src/cli/simple-commands/start-ui.js +132 -108
- package/dist/src/cli/simple-commands/start-wrapper.js +268 -240
- package/dist/src/cli/simple-commands/start.js +1 -1
- package/dist/src/cli/simple-commands/status.js +275 -254
- package/dist/src/cli/simple-commands/stream-chain-clean.js +171 -128
- package/dist/src/cli/simple-commands/stream-chain-fixed.js +82 -61
- package/dist/src/cli/simple-commands/stream-chain-real.js +331 -267
- package/dist/src/cli/simple-commands/stream-chain-working.js +263 -211
- package/dist/src/cli/simple-commands/stream-chain.js +318 -260
- package/dist/src/cli/simple-commands/stream-processor.js +315 -290
- package/dist/src/cli/simple-commands/swarm-executor.js +222 -189
- package/dist/src/cli/simple-commands/swarm-metrics-integration.js +300 -208
- package/dist/src/cli/simple-commands/swarm-ui.js +703 -623
- package/dist/src/cli/simple-commands/swarm-webui-integration.js +286 -258
- package/dist/src/cli/simple-commands/swarm.js +1082 -887
- package/dist/src/cli/simple-commands/task.js +206 -161
- package/dist/src/cli/simple-commands/timestamp-fix.js +89 -59
- package/dist/src/cli/simple-commands/token-tracker.js +316 -258
- package/dist/src/cli/simple-commands/tool-execution-framework.js +519 -433
- package/dist/src/cli/simple-commands/train-and-stream.js +331 -275
- package/dist/src/cli/simple-commands/training-pipeline.js +725 -619
- package/dist/src/cli/simple-commands/training.js +227 -170
- package/dist/src/cli/simple-commands/verification-hooks.js +284 -261
- package/dist/src/cli/simple-commands/verification-integration.js +417 -389
- package/dist/src/cli/simple-commands/verification-training-integration.js +606 -486
- package/dist/src/cli/simple-commands/verification.js +513 -493
- package/dist/src/cli/simple-commands/web-server.js +836 -766
- package/dist/src/cli/simple-commands/webui-validator.js +124 -106
- package/dist/src/coordination/byzantine-memory-channels.js +25 -1
- package/dist/src/coordination/event-bus/demo-wasm-integration.js +251 -212
- package/dist/src/coordination/event-bus/qe-event-bus.js +748 -608
- package/dist/src/coordination/event-bus/qe-event-bus.test.js +454 -379
- package/dist/src/coordination/iteration-tracker.js +454 -363
- package/dist/src/index.js +384 -35
- package/dist/src/mcp/DEPRECATED.js +60 -46
- package/dist/src/mcp/fixes/mcp-error-fixes.js +134 -115
- package/dist/src/mcp/implementations/agent-tracker.js +128 -114
- package/dist/src/mcp/implementations/daa-tools.js +350 -292
- package/dist/src/mcp/implementations/workflow-tools.js +361 -329
- package/dist/src/mcp/mcp-config-manager.js +1331 -1183
- package/dist/src/mcp/mcp-server-novice-simplified.js +17 -11
- package/dist/src/mcp/mcp-server-novice.js +17 -11
- package/dist/src/mcp/mcp-server-sdk.js +17 -11
- package/dist/src/mcp/mcp-server.js +1484 -1620
- package/dist/src/mcp/ruv-swarm-wrapper.js +239 -209
- package/dist/src/memory/advanced-serializer.js +589 -609
- package/dist/src/memory/enhanced-examples.js +305 -220
- package/dist/src/memory/enhanced-memory.js +336 -295
- package/dist/src/memory/enhanced-session-serializer.js +492 -408
- package/dist/src/memory/fallback-memory-system.js +1021 -900
- package/dist/src/memory/fallback-store.js +131 -93
- package/dist/src/memory/high-performance-serialization.js +730 -592
- package/dist/src/memory/in-memory-store.js +213 -161
- package/dist/src/memory/index.js +157 -123
- package/dist/src/memory/lock-free-structures.js +764 -578
- package/dist/src/memory/memory-mapped-persistence.js +766 -585
- package/dist/src/memory/memory-pressure-manager.js +707 -569
- package/dist/src/memory/migration.js +445 -358
- package/dist/src/memory/shared-memory.js +768 -641
- package/dist/src/memory/sqlite-store.js +325 -245
- package/dist/src/memory/sqlite-wrapper.js +151 -122
- package/dist/src/memory/swarm-memory.js +603 -470
- package/dist/src/memory/test-example.js +134 -126
- package/dist/src/memory/ultra-fast-memory-store.js +821 -622
- package/dist/src/memory/unified-memory-manager.js +437 -356
- package/dist/src/swarm/CodeRefactoringSwarm.js +952 -777
- package/dist/src/utils/__tests__/github-cli-safety-wrapper.test.js +400 -332
- package/dist/src/utils/error-handler.js +2 -36
- package/dist/src/utils/github-cli-safe.js +64 -56
- package/dist/src/utils/github-cli-safety-wrapper.js +546 -451
- package/dist/src/utils/npx-isolated-cache.js +119 -104
- package/dist/src/utils/preference-manager.js +652 -622
- package/dist/src/utils/timezone-utils.js +105 -86
- package/dist/src/web/api/apm-routes.js +353 -0
- package/dist/src/web/api/config/api-config.js +184 -0
- package/dist/src/web/api/middleware/auth.js +203 -0
- package/dist/src/web/api/middleware/cache.js +273 -0
- package/dist/src/web/api/middleware/error-handler.js +257 -0
- package/dist/src/web/api/middleware/request-logger.js +215 -0
- package/dist/src/web/api/middleware/validation.js +323 -0
- package/dist/src/web/api/routes/events.js +463 -0
- package/dist/src/web/api/routes/hierarchy.js +300 -0
- package/dist/src/web/api/routes/index.js +12 -0
- package/dist/src/web/api/routes/metrics.js +559 -0
- package/dist/src/web/api/routes/parallel-status.js +359 -0
- package/dist/src/web/api/routes/status.js +448 -0
- package/dist/src/web/api/server.js +462 -0
- package/dist/src/web/dashboard/hooks/useWebSocket.js +383 -0
- package/dist/src/web/dashboard/index.js +85 -0
- package/dist/src/web/dashboard/realtime/CustomSyncManager.js +439 -0
- package/dist/src/web/dashboard/realtime/NativeWebSocketManager.js +323 -0
- package/dist/src/web/dashboard/realtime/PerformanceBenchmark.js +527 -0
- package/dist/src/web/dashboard/realtime/RealtimeCommunicationManager.js +474 -0
- package/dist/src/web/dashboard/realtime/RealtimeServer.js +666 -0
- package/dist/src/web/dashboard/realtime/SSEManager.js +426 -0
- package/dist/src/web/dashboard/types.js +4 -0
- package/dist/src/web/messaging/agent-status-tracker.js +453 -0
- package/dist/src/web/messaging/human-intervention-system.js +305 -0
- package/dist/src/web/messaging/message-filter.js +302 -0
- package/dist/src/web/messaging/swarm-message-router.js +324 -0
- package/dist/src/web/messaging/transparency-logger.js +421 -0
- package/dist/src/web/portal-server.js +460 -0
- package/dist/src/web/server.js +322 -0
- package/dist/src/web/websocket/apm-websocket-handler.js +453 -0
- package/dist/src/web/websocket/websocket-manager.js +780 -0
- package/package.json +5 -3
- package/dist/src/cli/minimal-main.js +0 -22
- package/dist/src/enterprise/analytics-manager.js +0 -1135
- package/dist/src/enterprise/audit-manager.js +0 -1115
- package/dist/src/enterprise/cloud-manager.js +0 -891
- package/dist/src/enterprise/deployment-manager.js +0 -966
- package/dist/src/enterprise/index.js +0 -6
- package/dist/src/enterprise/project-manager.js +0 -584
- package/dist/src/enterprise/security-manager.js +0 -991
- package/dist/src/migration/index.js +0 -92
- package/dist/src/migration/logger.js +0 -121
- package/dist/src/migration/migration-analyzer.js +0 -268
- package/dist/src/migration/migration-runner.js +0 -522
- package/dist/src/migration/migration-validator.js +0 -285
- package/dist/src/migration/progress-reporter.js +0 -150
- package/dist/src/migration/rollback-manager.js +0 -321
- package/dist/src/migration/tests/migration-system.test.js +0 -7
- package/dist/src/migration/types.js +0 -3
- package/dist/src/swarm/__tests__/integration.test.js +0 -227
- package/dist/src/swarm/__tests__/prompt-copier.test.js +0 -344
- package/dist/src/swarm/advanced-orchestrator.js +0 -1095
- package/dist/src/swarm/claude-code-interface.js +0 -961
- package/dist/src/swarm/claude-flow-executor.js +0 -229
- package/dist/src/swarm/consensus-coordinator.js +0 -475
- package/dist/src/swarm/coordinator.js +0 -2993
- package/dist/src/swarm/direct-executor.js +0 -1180
- package/dist/src/swarm/error-recovery/advanced-error-detection.js +0 -691
- package/dist/src/swarm/error-recovery/automated-recovery-workflows.js +0 -998
- package/dist/src/swarm/error-recovery/error-recovery-coordinator.js +0 -1197
- package/dist/src/swarm/error-recovery/recovery-monitoring.js +0 -772
- package/dist/src/swarm/error-recovery/resilience-architecture.js +0 -714
- package/dist/src/swarm/error-recovery/self-healing-mechanisms.js +0 -1319
- package/dist/src/swarm/error-recovery/test-error-recovery-effectiveness.js +0 -808
- package/dist/src/swarm/executor-v2.js +0 -322
- package/dist/src/swarm/executor.js +0 -815
- package/dist/src/swarm/hive-mind-integration.js +0 -703
- package/dist/src/swarm/index.js +0 -41
- package/dist/src/swarm/json-output-aggregator.js +0 -267
- package/dist/src/swarm/large-scale-coordinator.js +0 -542
- package/dist/src/swarm/mcp-integration-wrapper.js +0 -628
- package/dist/src/swarm/memory.js +0 -1117
- package/dist/src/swarm/optimizations/__tests__/optimization.test.js +0 -348
- package/dist/src/swarm/optimizations/async-file-manager.js +0 -285
- package/dist/src/swarm/optimizations/circular-buffer.js +0 -162
- package/dist/src/swarm/optimizations/connection-pool.js +0 -244
- package/dist/src/swarm/optimizations/index.js +0 -28
- package/dist/src/swarm/optimizations/optimized-executor.js +0 -320
- package/dist/src/swarm/optimizations/ttl-map.js +0 -234
- package/dist/src/swarm/prompt-cli.js +0 -200
- package/dist/src/swarm/prompt-copier-enhanced.js +0 -202
- package/dist/src/swarm/prompt-copier.js +0 -381
- package/dist/src/swarm/prompt-manager.js +0 -295
- package/dist/src/swarm/prompt-utils.js +0 -310
- package/dist/src/swarm/result-aggregator.js +0 -718
- package/dist/src/swarm/sparc-executor.js +0 -1568
- package/dist/src/swarm/strategies/auto.js +0 -758
- package/dist/src/swarm/strategies/base.js +0 -128
- package/dist/src/swarm/strategies/research.js +0 -914
- package/dist/src/swarm/strategies/strategy-metrics-patch.js +0 -2
- package/dist/src/swarm/types.js +0 -52
- package/dist/src/swarm/workers/copy-worker.js +0 -56
- package/dist/src/validators/epic-config-schema.js +0 -214
- package/dist/src/validators/index.js +0 -10
- package/dist/src/validators/swarm-init-validator.js +0 -259
- package/dist/src/validators/todowrite-batching-validator.js +0 -215
- package/dist/src/validators/todowrite-integration.js +0 -187
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/documentSymbols/browser/documentSymbols.js +0 -23
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/dropOrPasteInto/browser/copyPasteContribution.js +0 -57
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/dropOrPasteInto/browser/copyPasteController.js +0 -401
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/dropOrPasteInto/browser/defaultProviders.js +0 -181
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/dropOrPasteInto/browser/dropIntoEditorContribution.js +0 -44
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/dropOrPasteInto/browser/dropIntoEditorController.js +0 -157
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/dropOrPasteInto/browser/edit.js +0 -71
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/editorState/browser/editorState.js +0 -112
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/find/browser/findController.js +0 -990
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/find/browser/findDecorations.js +0 -296
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/find/browser/findModel.js +0 -488
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/find/browser/findOptionsWidget.js +0 -138
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/find/browser/findState.js +0 -243
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/find/browser/findWidget.js +0 -1177
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/folding/browser/folding.js +0 -1093
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/folding/browser/foldingDecorations.js +0 -133
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/folding/browser/foldingModel.js +0 -538
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/folding/browser/foldingRanges.js +0 -351
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/fontZoom/browser/fontZoom.js +0 -49
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/format/browser/format.js +0 -360
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/format/browser/formatActions.js +0 -263
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/format/browser/formattingEdit.js +0 -54
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/gotoSymbol/browser/link/clickLinkGesture.js +0 -149
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/hover/browser/contentHover.js +0 -874
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/inlineCompletions/browser/commandIds.js +0 -7
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/inlineCompletions/browser/commands.js +0 -199
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/linesOperations/browser/copyLinesCommand.js +0 -70
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/quickAccess/browser/commandsQuickAccess.js +0 -26
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/quickAccess/browser/editorNavigationQuickAccess.js +0 -153
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/readOnlyMessage/browser/contribution.js +0 -33
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/semanticTokens/browser/documentSemanticTokens.js +0 -354
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/smartSelect/browser/bracketSelections.js +0 -146
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/suggest/browser/completionModel.js +0 -224
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/contrib/unicodeHighlighter/browser/bannerController.js +0 -119
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/edcore.main.js +0 -14
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/editor.all.js +0 -63
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/editor.api.js +0 -55
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/editor.main.js +0 -7
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/editor.worker.js +0 -25
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/editor/standalone/browser/colorizer.js +0 -118
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/language/css/css.worker.js +0 -36869
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/language/css/cssMode.js +0 -2035
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/accessibility/browser/accessibilityService.js +0 -88
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/accessibility/common/accessibility.js +0 -9
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/action/common/action.js +0 -7
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/action/common/actionCommonCategories.js +0 -13
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/actionWidget/browser/actionList.js +0 -276
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/actionWidget/browser/actionWidget.js +0 -248
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/actionWidget/common/actionWidget.js +0 -5
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/actions/common/actions.js +0 -409
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/audioCues/browser/audioCueService.js +0 -176
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/clipboard/browser/clipboardService.js +0 -141
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/clipboard/common/clipboardService.js +0 -6
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/commands/common/commands.js +0 -80
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/configuration/common/configuration.js +0 -86
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/configuration/common/configurationModels.js +0 -554
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/configuration/common/configurationRegistry.js +0 -317
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/configuration/common/configurations.js +0 -41
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/contextkey/browser/contextKeyService.js +0 -432
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/contextkey/common/contextkey.js +0 -1547
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/contextkey/common/contextkeys.js +0 -18
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/contextview/browser/contextMenuHandler.js +0 -124
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/contextview/browser/contextMenuService.js +0 -101
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/contextview/browser/contextView.js +0 -7
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/contextview/browser/contextViewService.js +0 -72
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/dialogs/common/dialogs.js +0 -2
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/dnd/browser/dnd.js +0 -36
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/editor/common/editor.js +0 -17
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/environment/common/environment.js +0 -2
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/extensions/common/extensions.js +0 -47
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/files/common/files.js +0 -9
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/history/browser/contextScopedHistoryWidget.js +0 -105
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/instantiation/common/descriptors.js +0 -11
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/instantiation/common/extensions.js +0 -15
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/keybinding/common/abstractKeybindingService.js +0 -277
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/keybinding/common/baseResolvedKeybinding.js +0 -53
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/quickinput/browser/commandsQuickAccess.js +0 -354
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/theme/browser/defaultStyles.js +0 -162
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/theme/common/colorRegistry.js +0 -482
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/abap/abap.js +0 -10
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/apex/apex.js +0 -10
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/azcli/azcli.js +0 -10
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/bat/bat.js +0 -10
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/bicep/bicep.js +0 -11
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/cameligo/cameligo.js +0 -10
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/clojure/clojure.js +0 -10
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/coffee/coffee.js +0 -10
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/cpp/cpp.js +0 -10
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/csharp/csharp.js +0 -10
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/csp/csp.js +0 -10
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/css/css.js +0 -12
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/cypher/cypher.js +0 -10
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/dart/dart.js +0 -10
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/dockerfile/dockerfile.js +0 -10
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/ecl/ecl.js +0 -10
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/elixir/elixir.js +0 -10
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/flow9/flow9.js +0 -10
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/editor/editor.main.js +0 -745
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/editor/editor.main.nls.de.js +0 -31
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/editor/editor.main.nls.es.js +0 -31
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/editor/editor.main.nls.fr.js +0 -29
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/editor/editor.main.nls.it.js +0 -29
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/editor/editor.main.nls.ja.js +0 -31
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/editor/editor.main.nls.js +0 -29
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/editor/editor.main.nls.ko.js +0 -29
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/editor/editor.main.nls.ru.js +0 -31
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/editor/editor.main.nls.zh-cn.js +0 -31
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/editor/editor.main.nls.zh-tw.js +0 -29
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/language/css/cssMode.js +0 -13
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/language/css/cssWorker.js +0 -81
- package/dist/src/web/frontend/node_modules/.multicast-dns-iKseM9bB/cli.js +0 -64
- package/dist/src/web/frontend/node_modules/.multicast-dns-iKseM9bB/example.js +0 -36
- package/dist/src/web/frontend/node_modules/.multicast-dns-iKseM9bB/index.js +0 -205
- package/dist/src/web/frontend/node_modules/.multicast-dns-iKseM9bB/test.js +0 -260
- package/dist/src/web/frontend/node_modules/.nanoid-PAMEV9Hd/async/index.browser.js +0 -34
- package/dist/src/web/frontend/node_modules/.nanoid-PAMEV9Hd/async/index.js +0 -35
- package/dist/src/web/frontend/node_modules/.nanoid-PAMEV9Hd/async/index.native.js +0 -26
- package/dist/src/web/frontend/node_modules/.nanoid-PAMEV9Hd/index.browser.js +0 -34
- package/dist/src/web/frontend/node_modules/.nanoid-PAMEV9Hd/index.js +0 -45
- package/dist/src/web/frontend/node_modules/.nanoid-PAMEV9Hd/nanoid.js +0 -1
- package/dist/src/web/frontend/node_modules/.nanoid-PAMEV9Hd/non-secure/index.js +0 -21
- package/dist/src/web/frontend/node_modules/.nanoid-PAMEV9Hd/url-alphabet/index.js +0 -3
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/bin/nodemon.js +0 -16
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/cli/index.js +0 -49
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/cli/parse.js +0 -230
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/config/command.js +0 -43
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/config/defaults.js +0 -34
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/config/exec.js +0 -234
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/config/index.js +0 -93
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/config/load.js +0 -225
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/help/index.js +0 -27
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/index.js +0 -1
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/monitor/index.js +0 -4
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/monitor/match.js +0 -287
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/monitor/run.js +0 -562
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/monitor/signals.js +0 -34
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/monitor/watch.js +0 -244
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/nodemon.js +0 -317
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/rules/add.js +0 -89
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/rules/index.js +0 -53
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/rules/parse.js +0 -43
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/spawn.js +0 -74
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/utils/bus.js +0 -44
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/utils/clone.js +0 -40
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/utils/colour.js +0 -26
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/utils/index.js +0 -103
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/utils/log.js +0 -82
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/utils/merge.js +0 -47
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/lib/version.js +0 -100
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/node_modules/brace-expansion/index.js +0 -201
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/node_modules/has-flag/index.js +0 -8
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/node_modules/minimatch/minimatch.js +0 -947
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/node_modules/supports-color/browser.js +0 -5
- package/dist/src/web/frontend/node_modules/.nodemon-QcvNKhKT/node_modules/supports-color/index.js +0 -131
- package/dist/src/web/frontend/node_modules/.pidtree-icfat3SQ/bin/pidtree.js +0 -128
- package/dist/src/web/frontend/node_modules/.pidtree-icfat3SQ/index.js +0 -49
- package/dist/src/web/frontend/node_modules/.pidtree-icfat3SQ/lib/bin.js +0 -61
- package/dist/src/web/frontend/node_modules/.pidtree-icfat3SQ/lib/get.js +0 -45
- package/dist/src/web/frontend/node_modules/.pidtree-icfat3SQ/lib/pidtree.js +0 -104
- package/dist/src/web/frontend/node_modules/.pidtree-icfat3SQ/lib/ps.js +0 -47
- package/dist/src/web/frontend/node_modules/.pidtree-icfat3SQ/lib/wmic.js +0 -49
- package/dist/src/web/frontend/node_modules/.prettier-ApZm3b7s/doc.js +0 -1270
- package/dist/src/web/frontend/node_modules/.prettier-ApZm3b7s/plugins/acorn.js +0 -15
- package/dist/src/web/frontend/node_modules/.prettier-ApZm3b7s/plugins/angular.js +0 -2
- package/dist/src/web/frontend/node_modules/.prettier-ApZm3b7s/plugins/babel.js +0 -15
- package/dist/src/web/frontend/node_modules/.prettier-ApZm3b7s/plugins/estree.js +0 -36
- package/dist/src/web/frontend/node_modules/.prettier-ApZm3b7s/plugins/flow.js +0 -19
- package/dist/src/web/frontend/node_modules/.prettier-ApZm3b7s/plugins/glimmer.js +0 -29
- package/dist/src/web/frontend/node_modules/.prettier-ApZm3b7s/plugins/graphql.js +0 -29
- package/dist/src/web/frontend/node_modules/.prettier-ApZm3b7s/plugins/html.js +0 -22
- package/dist/src/web/frontend/node_modules/.prettier-ApZm3b7s/plugins/markdown.js +0 -63
- package/dist/src/web/frontend/node_modules/.prettier-ApZm3b7s/plugins/meriyah.js +0 -4
- package/dist/src/web/frontend/node_modules/.prettier-ApZm3b7s/plugins/postcss.js +0 -54
- package/dist/src/web/frontend/node_modules/.prettier-ApZm3b7s/plugins/typescript.js +0 -20
- package/dist/src/web/frontend/node_modules/.prettier-ApZm3b7s/plugins/yaml.js +0 -160
- package/dist/src/web/frontend/node_modules/.prettier-ApZm3b7s/standalone.js +0 -34
- package/dist/src/web/frontend/node_modules/.react-scripts-OTANyoRb/bin/react-scripts.js +0 -58
- package/dist/src/web/frontend/node_modules/.react-scripts-OTANyoRb/config/env.js +0 -112
- package/dist/src/web/frontend/node_modules/.react-scripts-OTANyoRb/config/getHttpsConfig.js +0 -74
- package/dist/src/web/frontend/node_modules/.react-scripts-OTANyoRb/config/jest/babelTransform.js +0 -37
- package/dist/src/web/frontend/node_modules/.react-scripts-OTANyoRb/config/jest/cssTransform.js +0 -22
- package/dist/src/web/frontend/node_modules/.react-scripts-OTANyoRb/config/jest/fileTransform.js +0 -40
- package/dist/src/web/frontend/node_modules/.react-scripts-OTANyoRb/config/modules.js +0 -142
- package/dist/src/web/frontend/node_modules/.react-scripts-OTANyoRb/config/paths.js +0 -153
- package/dist/src/web/frontend/node_modules/.react-scripts-OTANyoRb/config/webpack/persistentCache/createEnvironmentHash.js +0 -9
- package/dist/src/web/frontend/node_modules/.react-scripts-OTANyoRb/config/webpack.config.js +0 -796
- package/dist/src/web/frontend/node_modules/.react-scripts-OTANyoRb/config/webpackDevServer.config.js +0 -135
- package/dist/src/web/frontend/node_modules/.react-scripts-OTANyoRb/scripts/build.js +0 -225
- package/dist/src/web/frontend/node_modules/.react-scripts-OTANyoRb/scripts/eject.js +0 -340
|
@@ -16,1042 +16,1159 @@
|
|
|
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
|
|
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
|
+
|
|
26
30
|
/**
|
|
27
31
|
* Framework Validation CLI Handler
|
|
28
|
-
*/
|
|
29
|
-
|
|
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
|
+
/**
|
|
30
47
|
* Initialize the validation CLI
|
|
31
|
-
*/
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
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;
|
|
45
66
|
}
|
|
46
|
-
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
/**
|
|
47
70
|
* Main CLI handler
|
|
48
|
-
*/
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
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();
|
|
69
94
|
}
|
|
70
|
-
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
/**
|
|
71
98
|
* Handle: claude-flow-novice validate framework add <framework-file>
|
|
72
|
-
*/
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
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
|
-
};
|
|
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 };
|
|
157
145
|
}
|
|
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 };
|
|
158
188
|
}
|
|
159
|
-
|
|
189
|
+
}
|
|
190
|
+
|
|
191
|
+
/**
|
|
160
192
|
* Handle: claude-flow-novice validate framework test <framework-id>
|
|
161
|
-
*/
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
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 };
|
|
195
235
|
}
|
|
196
|
-
|
|
236
|
+
}
|
|
237
|
+
|
|
238
|
+
/**
|
|
197
239
|
* Handle: claude-flow-novice validate framework list
|
|
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
|
-
}
|
|
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 };
|
|
224
264
|
}
|
|
225
|
-
|
|
265
|
+
}
|
|
266
|
+
|
|
267
|
+
/**
|
|
226
268
|
* Handle: claude-flow-novice validate framework remove <framework-id>
|
|
227
|
-
*/
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
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
|
-
}
|
|
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' };
|
|
281
279
|
}
|
|
282
|
-
|
|
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 };
|
|
320
|
+
}
|
|
321
|
+
}
|
|
322
|
+
|
|
323
|
+
/**
|
|
283
324
|
* Handle: claude-flow-novice validate framework export <framework-id>
|
|
284
|
-
*/
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
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
|
-
}
|
|
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' };
|
|
324
337
|
}
|
|
325
|
-
|
|
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 };
|
|
367
|
+
}
|
|
368
|
+
}
|
|
369
|
+
|
|
370
|
+
/**
|
|
326
371
|
* Handle: claude-flow-novice validate framework wizard
|
|
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
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
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
|
-
|
|
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 };
|
|
404
457
|
}
|
|
405
|
-
|
|
458
|
+
}
|
|
459
|
+
|
|
460
|
+
/**
|
|
406
461
|
* Handle: claude-flow-novice validate framework validate <completion-file> <framework-id>
|
|
407
|
-
*/
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
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
|
-
}
|
|
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' };
|
|
442
474
|
}
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
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 };
|
|
468
506
|
}
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
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}`);
|
|
479
519
|
}
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
if (error.path) {
|
|
486
|
-
console.log(chalk.gray(` Path: ${error.path}`));
|
|
487
|
-
}
|
|
488
|
-
});
|
|
489
|
-
}
|
|
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();
|
|
520
|
+
|
|
521
|
+
if (framework.validation_config) {
|
|
522
|
+
console.log(
|
|
523
|
+
` ${chalk.bold('Truth Threshold:')} ${framework.validation_config.truth_threshold}`,
|
|
524
|
+
);
|
|
502
525
|
}
|
|
503
|
-
|
|
504
|
-
|
|
505
|
-
|
|
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();
|
|
526
|
+
|
|
527
|
+
if (framework.validation_rules) {
|
|
528
|
+
console.log(` ${chalk.bold('Validation Rules:')} ${framework.validation_rules.length}`);
|
|
522
529
|
}
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
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();
|
|
530
|
+
|
|
531
|
+
if (framework.quality_gates) {
|
|
532
|
+
console.log(` ${chalk.bold('Quality Gates:')} ${framework.quality_gates.length}`);
|
|
532
533
|
}
|
|
533
|
-
|
|
534
|
-
|
|
535
|
-
|
|
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}`);
|
|
543
|
-
}
|
|
544
|
-
console.log();
|
|
534
|
+
|
|
535
|
+
if (framework.extends) {
|
|
536
|
+
console.log(` ${chalk.bold('Extends:')} ${framework.extends}`);
|
|
545
537
|
}
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
|
|
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();
|
|
538
|
+
|
|
539
|
+
if (framework.composes) {
|
|
540
|
+
console.log(` ${chalk.bold('Composes:')} ${framework.composes.join(', ')}`);
|
|
556
541
|
}
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
|
|
568
|
-
|
|
569
|
-
|
|
570
|
-
|
|
571
|
-
|
|
572
|
-
|
|
573
|
-
|
|
574
|
-
|
|
575
|
-
|
|
576
|
-
|
|
577
|
-
|
|
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
|
-
}));
|
|
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
|
+
);
|
|
600
563
|
}
|
|
601
|
-
|
|
602
|
-
|
|
603
|
-
|
|
604
|
-
|
|
605
|
-
|
|
606
|
-
|
|
607
|
-
|
|
608
|
-
|
|
609
|
-
|
|
610
|
-
|
|
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}`));
|
|
611
576
|
}
|
|
612
|
-
|
|
577
|
+
});
|
|
613
578
|
}
|
|
614
|
-
|
|
615
|
-
|
|
616
|
-
|
|
617
|
-
|
|
618
|
-
|
|
619
|
-
|
|
620
|
-
}
|
|
621
|
-
if (result.error) {
|
|
622
|
-
console.log(` ${chalk.bold('Error:')} ${result.error}`);
|
|
623
|
-
}
|
|
624
|
-
console.log();
|
|
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
|
+
});
|
|
625
585
|
}
|
|
626
|
-
|
|
627
|
-
|
|
628
|
-
|
|
629
|
-
|
|
630
|
-
|
|
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
|
-
]);
|
|
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}`);
|
|
660
591
|
}
|
|
661
|
-
|
|
662
|
-
|
|
663
|
-
|
|
664
|
-
|
|
665
|
-
|
|
666
|
-
|
|
667
|
-
|
|
668
|
-
|
|
669
|
-
|
|
670
|
-
|
|
671
|
-
|
|
672
|
-
|
|
673
|
-
|
|
674
|
-
|
|
675
|
-
|
|
676
|
-
|
|
677
|
-
|
|
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;
|
|
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`);
|
|
718
609
|
}
|
|
719
|
-
|
|
610
|
+
});
|
|
720
611
|
}
|
|
721
|
-
|
|
722
|
-
|
|
723
|
-
|
|
724
|
-
|
|
725
|
-
|
|
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;
|
|
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`);
|
|
778
617
|
}
|
|
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
|
-
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
|
-
}
|
|
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
|
+
);
|
|
651
|
+
}
|
|
652
|
+
|
|
653
|
+
if (result.qualityGates) {
|
|
654
|
+
console.log(
|
|
655
|
+
` ${chalk.bold('Quality Gates:')} ${result.qualityGates.gatesPassed}/${result.qualityGates.gatesApplied}`,
|
|
656
|
+
);
|
|
855
657
|
}
|
|
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
|
-
|
|
895
|
-
|
|
896
|
-
|
|
897
|
-
|
|
898
|
-
|
|
899
|
-
|
|
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}`);
|
|
668
|
+
}
|
|
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
|
+
);
|
|
674
|
+
}
|
|
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)}%`);
|
|
900
728
|
}
|
|
901
|
-
|
|
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
|
+
);
|
|
744
|
+
}
|
|
745
|
+
|
|
746
|
+
if (result.error) {
|
|
747
|
+
console.log(` ${chalk.bold('Error:')} ${result.error}`);
|
|
748
|
+
}
|
|
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;
|
|
902
847
|
}
|
|
903
|
-
|
|
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
|
+
}
|
|
899
|
+
}
|
|
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':
|
|
904
960
|
return inquirer.prompt([
|
|
905
|
-
|
|
906
|
-
|
|
907
|
-
|
|
908
|
-
|
|
909
|
-
|
|
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;
|
|
910
971
|
},
|
|
911
|
-
|
|
912
|
-
type: 'confirm',
|
|
913
|
-
name: 'composable',
|
|
914
|
-
message: 'Allow this framework to be used in composition?',
|
|
915
|
-
default: true
|
|
916
|
-
}
|
|
972
|
+
},
|
|
917
973
|
]);
|
|
974
|
+
|
|
975
|
+
default:
|
|
976
|
+
return {};
|
|
918
977
|
}
|
|
919
|
-
|
|
920
|
-
|
|
921
|
-
|
|
922
|
-
|
|
923
|
-
|
|
924
|
-
|
|
925
|
-
|
|
926
|
-
|
|
927
|
-
|
|
928
|
-
|
|
929
|
-
|
|
930
|
-
|
|
931
|
-
|
|
932
|
-
|
|
933
|
-
|
|
934
|
-
|
|
935
|
-
|
|
936
|
-
|
|
937
|
-
|
|
938
|
-
|
|
939
|
-
|
|
940
|
-
|
|
941
|
-
|
|
942
|
-
|
|
943
|
-
|
|
944
|
-
|
|
945
|
-
|
|
946
|
-
|
|
947
|
-
|
|
948
|
-
|
|
949
|
-
|
|
950
|
-
|
|
951
|
-
|
|
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
|
+
}
|
|
952
1027
|
}
|
|
953
|
-
|
|
954
|
-
|
|
955
|
-
|
|
956
|
-
|
|
957
|
-
|
|
958
|
-
|
|
959
|
-
|
|
960
|
-
|
|
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));
|
|
961
1076
|
}
|
|
1077
|
+
}
|
|
1078
|
+
|
|
1079
|
+
return frameworks;
|
|
1080
|
+
} catch (error) {
|
|
1081
|
+
return [];
|
|
962
1082
|
}
|
|
963
|
-
|
|
964
|
-
|
|
965
|
-
|
|
966
|
-
|
|
967
|
-
|
|
968
|
-
|
|
969
|
-
|
|
970
|
-
|
|
971
|
-
|
|
972
|
-
|
|
973
|
-
|
|
974
|
-
|
|
975
|
-
|
|
976
|
-
|
|
977
|
-
|
|
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
|
-
};
|
|
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;
|
|
1023
1098
|
}
|
|
1024
|
-
|
|
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
|
+
/**
|
|
1025
1146
|
* Cleanup resources
|
|
1026
|
-
*/
|
|
1027
|
-
|
|
1028
|
-
|
|
1029
|
-
|
|
1030
|
-
if (this.spinner && this.spinner.isSpinning) {
|
|
1031
|
-
this.spinner.stop();
|
|
1032
|
-
}
|
|
1147
|
+
*/
|
|
1148
|
+
async cleanup() {
|
|
1149
|
+
if (this.validator) {
|
|
1150
|
+
await this.validator.shutdown();
|
|
1033
1151
|
}
|
|
1034
|
-
|
|
1035
|
-
|
|
1036
|
-
|
|
1037
|
-
verbose: options.verbose === true,
|
|
1038
|
-
autoFix: options.autoFix === true,
|
|
1039
|
-
...options
|
|
1040
|
-
};
|
|
1041
|
-
this.validator = null;
|
|
1042
|
-
this.spinner = null;
|
|
1152
|
+
|
|
1153
|
+
if (this.spinner && this.spinner.isSpinning) {
|
|
1154
|
+
this.spinner.stop();
|
|
1043
1155
|
}
|
|
1156
|
+
}
|
|
1044
1157
|
}
|
|
1158
|
+
|
|
1045
1159
|
/**
|
|
1046
1160
|
* Main CLI handler function
|
|
1047
|
-
*/
|
|
1048
|
-
|
|
1049
|
-
|
|
1050
|
-
|
|
1051
|
-
|
|
1052
|
-
|
|
1053
|
-
|
|
1054
|
-
|
|
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
|
+
}
|
|
1055
1171
|
}
|
|
1172
|
+
|
|
1056
1173
|
// Export default handler
|
|
1057
1174
|
export default handleFrameworkValidationCommand;
|