@sparkleideas/mcp 3.0.0-alpha.9
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/.claude/agents/analysis/analyze-code-quality.md +179 -0
- package/.claude/agents/analysis/code-analyzer.md +210 -0
- package/.claude/agents/analysis/code-review/analyze-code-quality.md +179 -0
- package/.claude/agents/architecture/arch-system-design.md +157 -0
- package/.claude/agents/architecture/system-design/arch-system-design.md +155 -0
- package/.claude/agents/consensus/byzantine-coordinator.md +63 -0
- package/.claude/agents/consensus/crdt-synchronizer.md +997 -0
- package/.claude/agents/consensus/gossip-coordinator.md +63 -0
- package/.claude/agents/consensus/performance-benchmarker.md +851 -0
- package/.claude/agents/consensus/quorum-manager.md +823 -0
- package/.claude/agents/consensus/raft-manager.md +63 -0
- package/.claude/agents/consensus/security-manager.md +622 -0
- package/.claude/agents/core/coder.md +453 -0
- package/.claude/agents/core/planner.md +375 -0
- package/.claude/agents/core/researcher.md +369 -0
- package/.claude/agents/core/reviewer.md +520 -0
- package/.claude/agents/core/tester.md +512 -0
- package/.claude/agents/custom/test-long-runner.md +44 -0
- package/.claude/agents/data/data-ml-model.md +445 -0
- package/.claude/agents/data/ml/data-ml-model.md +193 -0
- package/.claude/agents/development/backend/dev-backend-api.md +142 -0
- package/.claude/agents/development/dev-backend-api.md +345 -0
- package/.claude/agents/devops/ci-cd/ops-cicd-github.md +164 -0
- package/.claude/agents/devops/ops-cicd-github.md +165 -0
- package/.claude/agents/documentation/api-docs/docs-api-openapi.md +174 -0
- package/.claude/agents/documentation/docs-api-openapi.md +355 -0
- package/.claude/agents/flow-nexus/app-store.md +88 -0
- package/.claude/agents/flow-nexus/authentication.md +69 -0
- package/.claude/agents/flow-nexus/challenges.md +81 -0
- package/.claude/agents/flow-nexus/neural-network.md +88 -0
- package/.claude/agents/flow-nexus/payments.md +83 -0
- package/.claude/agents/flow-nexus/sandbox.md +76 -0
- package/.claude/agents/flow-nexus/swarm.md +76 -0
- package/.claude/agents/flow-nexus/user-tools.md +96 -0
- package/.claude/agents/flow-nexus/workflow.md +84 -0
- package/.claude/agents/github/code-review-swarm.md +377 -0
- package/.claude/agents/github/github-modes.md +173 -0
- package/.claude/agents/github/issue-tracker.md +576 -0
- package/.claude/agents/github/multi-repo-swarm.md +553 -0
- package/.claude/agents/github/pr-manager.md +438 -0
- package/.claude/agents/github/project-board-sync.md +509 -0
- package/.claude/agents/github/release-manager.md +605 -0
- package/.claude/agents/github/release-swarm.md +583 -0
- package/.claude/agents/github/repo-architect.md +398 -0
- package/.claude/agents/github/swarm-issue.md +573 -0
- package/.claude/agents/github/swarm-pr.md +428 -0
- package/.claude/agents/github/sync-coordinator.md +452 -0
- package/.claude/agents/github/workflow-automation.md +903 -0
- package/.claude/agents/goal/agent.md +816 -0
- package/.claude/agents/goal/goal-planner.md +73 -0
- package/.claude/agents/optimization/benchmark-suite.md +665 -0
- package/.claude/agents/optimization/load-balancer.md +431 -0
- package/.claude/agents/optimization/performance-monitor.md +672 -0
- package/.claude/agents/optimization/resource-allocator.md +674 -0
- package/.claude/agents/optimization/topology-optimizer.md +808 -0
- package/.claude/agents/payments/agentic-payments.md +126 -0
- package/.claude/agents/sona/sona-learning-optimizer.md +74 -0
- package/.claude/agents/sparc/architecture.md +699 -0
- package/.claude/agents/sparc/pseudocode.md +520 -0
- package/.claude/agents/sparc/refinement.md +802 -0
- package/.claude/agents/sparc/specification.md +478 -0
- package/.claude/agents/specialized/mobile/spec-mobile-react-native.md +225 -0
- package/.claude/agents/specialized/spec-mobile-react-native.md +227 -0
- package/.claude/agents/sublinear/consensus-coordinator.md +338 -0
- package/.claude/agents/sublinear/matrix-optimizer.md +185 -0
- package/.claude/agents/sublinear/pagerank-analyzer.md +299 -0
- package/.claude/agents/sublinear/performance-optimizer.md +368 -0
- package/.claude/agents/sublinear/trading-predictor.md +246 -0
- package/.claude/agents/swarm/adaptive-coordinator.md +1127 -0
- package/.claude/agents/swarm/hierarchical-coordinator.md +710 -0
- package/.claude/agents/swarm/mesh-coordinator.md +963 -0
- package/.claude/agents/templates/automation-smart-agent.md +205 -0
- package/.claude/agents/templates/base-template-generator.md +268 -0
- package/.claude/agents/templates/coordinator-swarm-init.md +90 -0
- package/.claude/agents/templates/github-pr-manager.md +177 -0
- package/.claude/agents/templates/implementer-sparc-coder.md +259 -0
- package/.claude/agents/templates/memory-coordinator.md +187 -0
- package/.claude/agents/templates/orchestrator-task.md +139 -0
- package/.claude/agents/templates/performance-analyzer.md +199 -0
- package/.claude/agents/templates/sparc-coordinator.md +514 -0
- package/.claude/agents/testing/production-validator.md +395 -0
- package/.claude/agents/testing/tdd-london-swarm.md +244 -0
- package/.claude/agents/v3/adr-architect.md +184 -0
- package/.claude/agents/v3/aidefence-guardian.md +282 -0
- package/.claude/agents/v3/claims-authorizer.md +208 -0
- package/.claude/agents/v3/collective-intelligence-coordinator.md +993 -0
- package/.claude/agents/v3/ddd-domain-expert.md +220 -0
- package/.claude/agents/v3/injection-analyst.md +236 -0
- package/.claude/agents/v3/memory-specialist.md +995 -0
- package/.claude/agents/v3/performance-engineer.md +1233 -0
- package/.claude/agents/v3/pii-detector.md +151 -0
- package/.claude/agents/v3/reasoningbank-learner.md +213 -0
- package/.claude/agents/v3/security-architect-aidefence.md +410 -0
- package/.claude/agents/v3/security-architect.md +867 -0
- package/.claude/agents/v3/security-auditor.md +771 -0
- package/.claude/agents/v3/sparc-orchestrator.md +182 -0
- package/.claude/agents/v3/swarm-memory-manager.md +157 -0
- package/.claude/agents/v3/v3-integration-architect.md +205 -0
- package/.claude/commands/analysis/COMMAND_COMPLIANCE_REPORT.md +54 -0
- package/.claude/commands/analysis/README.md +9 -0
- package/.claude/commands/analysis/bottleneck-detect.md +162 -0
- package/.claude/commands/analysis/performance-bottlenecks.md +59 -0
- package/.claude/commands/analysis/performance-report.md +25 -0
- package/.claude/commands/analysis/token-efficiency.md +45 -0
- package/.claude/commands/analysis/token-usage.md +25 -0
- package/.claude/commands/automation/README.md +9 -0
- package/.claude/commands/automation/auto-agent.md +122 -0
- package/.claude/commands/automation/self-healing.md +106 -0
- package/.claude/commands/automation/session-memory.md +90 -0
- package/.claude/commands/automation/smart-agents.md +73 -0
- package/.claude/commands/automation/smart-spawn.md +25 -0
- package/.claude/commands/automation/workflow-select.md +25 -0
- package/.claude/commands/claude-flow-help.md +103 -0
- package/.claude/commands/claude-flow-memory.md +107 -0
- package/.claude/commands/claude-flow-swarm.md +205 -0
- package/.claude/commands/github/README.md +11 -0
- package/.claude/commands/github/code-review-swarm.md +514 -0
- package/.claude/commands/github/code-review.md +25 -0
- package/.claude/commands/github/github-modes.md +147 -0
- package/.claude/commands/github/github-swarm.md +121 -0
- package/.claude/commands/github/issue-tracker.md +292 -0
- package/.claude/commands/github/issue-triage.md +25 -0
- package/.claude/commands/github/multi-repo-swarm.md +519 -0
- package/.claude/commands/github/pr-enhance.md +26 -0
- package/.claude/commands/github/pr-manager.md +170 -0
- package/.claude/commands/github/project-board-sync.md +471 -0
- package/.claude/commands/github/release-manager.md +338 -0
- package/.claude/commands/github/release-swarm.md +544 -0
- package/.claude/commands/github/repo-analyze.md +25 -0
- package/.claude/commands/github/repo-architect.md +367 -0
- package/.claude/commands/github/swarm-issue.md +482 -0
- package/.claude/commands/github/swarm-pr.md +285 -0
- package/.claude/commands/github/sync-coordinator.md +301 -0
- package/.claude/commands/github/workflow-automation.md +442 -0
- package/.claude/commands/hooks/README.md +11 -0
- package/.claude/commands/hooks/overview.md +58 -0
- package/.claude/commands/hooks/post-edit.md +117 -0
- package/.claude/commands/hooks/post-task.md +112 -0
- package/.claude/commands/hooks/pre-edit.md +113 -0
- package/.claude/commands/hooks/pre-task.md +111 -0
- package/.claude/commands/hooks/session-end.md +118 -0
- package/.claude/commands/hooks/setup.md +103 -0
- package/.claude/commands/monitoring/README.md +9 -0
- package/.claude/commands/monitoring/agent-metrics.md +25 -0
- package/.claude/commands/monitoring/agents.md +44 -0
- package/.claude/commands/monitoring/real-time-view.md +25 -0
- package/.claude/commands/monitoring/status.md +46 -0
- package/.claude/commands/monitoring/swarm-monitor.md +25 -0
- package/.claude/commands/optimization/README.md +9 -0
- package/.claude/commands/optimization/auto-topology.md +62 -0
- package/.claude/commands/optimization/cache-manage.md +25 -0
- package/.claude/commands/optimization/parallel-execute.md +25 -0
- package/.claude/commands/optimization/parallel-execution.md +50 -0
- package/.claude/commands/optimization/topology-optimize.md +25 -0
- package/.claude/commands/sparc/analyzer.md +52 -0
- package/.claude/commands/sparc/architect.md +53 -0
- package/.claude/commands/sparc/ask.md +97 -0
- package/.claude/commands/sparc/batch-executor.md +54 -0
- package/.claude/commands/sparc/code.md +89 -0
- package/.claude/commands/sparc/coder.md +54 -0
- package/.claude/commands/sparc/debug.md +83 -0
- package/.claude/commands/sparc/debugger.md +54 -0
- package/.claude/commands/sparc/designer.md +53 -0
- package/.claude/commands/sparc/devops.md +109 -0
- package/.claude/commands/sparc/docs-writer.md +80 -0
- package/.claude/commands/sparc/documenter.md +54 -0
- package/.claude/commands/sparc/innovator.md +54 -0
- package/.claude/commands/sparc/integration.md +83 -0
- package/.claude/commands/sparc/mcp.md +117 -0
- package/.claude/commands/sparc/memory-manager.md +54 -0
- package/.claude/commands/sparc/optimizer.md +54 -0
- package/.claude/commands/sparc/orchestrator.md +132 -0
- package/.claude/commands/sparc/post-deployment-monitoring-mode.md +83 -0
- package/.claude/commands/sparc/refinement-optimization-mode.md +83 -0
- package/.claude/commands/sparc/researcher.md +54 -0
- package/.claude/commands/sparc/reviewer.md +54 -0
- package/.claude/commands/sparc/security-review.md +80 -0
- package/.claude/commands/sparc/sparc-modes.md +174 -0
- package/.claude/commands/sparc/sparc.md +111 -0
- package/.claude/commands/sparc/spec-pseudocode.md +80 -0
- package/.claude/commands/sparc/supabase-admin.md +348 -0
- package/.claude/commands/sparc/swarm-coordinator.md +54 -0
- package/.claude/commands/sparc/tdd.md +54 -0
- package/.claude/commands/sparc/tester.md +54 -0
- package/.claude/commands/sparc/tutorial.md +79 -0
- package/.claude/commands/sparc/workflow-manager.md +54 -0
- package/.claude/helpers/README.md +97 -0
- package/.claude/helpers/adr-compliance.sh +186 -0
- package/.claude/helpers/auto-commit.sh +178 -0
- package/.claude/helpers/checkpoint-manager.sh +251 -0
- package/.claude/helpers/daemon-manager.sh +252 -0
- package/.claude/helpers/ddd-tracker.sh +144 -0
- package/.claude/helpers/github-safe.js +106 -0
- package/.claude/helpers/github-setup.sh +28 -0
- package/.claude/helpers/guidance-hook.sh +13 -0
- package/.claude/helpers/guidance-hooks.sh +102 -0
- package/.claude/helpers/health-monitor.sh +108 -0
- package/.claude/helpers/learning-hooks.sh +329 -0
- package/.claude/helpers/learning-optimizer.sh +127 -0
- package/.claude/helpers/learning-service.mjs +1144 -0
- package/.claude/helpers/memory.js +83 -0
- package/.claude/helpers/metrics-db.mjs +488 -0
- package/.claude/helpers/pattern-consolidator.sh +86 -0
- package/.claude/helpers/perf-worker.sh +160 -0
- package/.claude/helpers/post-commit +16 -0
- package/.claude/helpers/pre-commit +26 -0
- package/.claude/helpers/quick-start.sh +19 -0
- package/.claude/helpers/router.js +66 -0
- package/.claude/helpers/security-scanner.sh +127 -0
- package/.claude/helpers/session.js +127 -0
- package/.claude/helpers/setup-mcp.sh +18 -0
- package/.claude/helpers/standard-checkpoint-hooks.sh +189 -0
- package/.claude/helpers/statusline-hook.sh +21 -0
- package/.claude/helpers/statusline.cjs +509 -0
- package/.claude/helpers/statusline.js +316 -0
- package/.claude/helpers/swarm-comms.sh +353 -0
- package/.claude/helpers/swarm-hooks.sh +761 -0
- package/.claude/helpers/swarm-monitor.sh +211 -0
- package/.claude/helpers/sync-v3-metrics.sh +245 -0
- package/.claude/helpers/update-v3-progress.sh +166 -0
- package/.claude/helpers/v3-quick-status.sh +58 -0
- package/.claude/helpers/v3.sh +111 -0
- package/.claude/helpers/validate-v3-config.sh +216 -0
- package/.claude/helpers/worker-manager.sh +170 -0
- package/.claude/settings.json +237 -0
- package/.claude/skills/agentdb-advanced/SKILL.md +550 -0
- package/.claude/skills/agentdb-learning/SKILL.md +545 -0
- package/.claude/skills/agentdb-memory-patterns/SKILL.md +339 -0
- package/.claude/skills/agentdb-optimization/SKILL.md +509 -0
- package/.claude/skills/agentdb-vector-search/SKILL.md +339 -0
- package/.claude/skills/github-code-review/SKILL.md +1140 -0
- package/.claude/skills/github-multi-repo/SKILL.md +874 -0
- package/.claude/skills/github-project-management/SKILL.md +1277 -0
- package/.claude/skills/github-release-management/SKILL.md +1081 -0
- package/.claude/skills/github-workflow-automation/SKILL.md +1065 -0
- package/.claude/skills/hooks-automation/SKILL.md +1201 -0
- package/.claude/skills/pair-programming/SKILL.md +1202 -0
- package/.claude/skills/reasoningbank-agentdb/SKILL.md +446 -0
- package/.claude/skills/reasoningbank-intelligence/SKILL.md +201 -0
- package/.claude/skills/skill-builder/SKILL.md +910 -0
- package/.claude/skills/sparc-methodology/SKILL.md +1115 -0
- package/.claude/skills/stream-chain/SKILL.md +563 -0
- package/.claude/skills/swarm-advanced/SKILL.md +973 -0
- package/.claude/skills/swarm-orchestration/SKILL.md +179 -0
- package/.claude/skills/v3-cli-modernization/SKILL.md +872 -0
- package/.claude/skills/v3-core-implementation/SKILL.md +797 -0
- package/.claude/skills/v3-ddd-architecture/SKILL.md +442 -0
- package/.claude/skills/v3-integration-deep/SKILL.md +241 -0
- package/.claude/skills/v3-mcp-optimization/SKILL.md +777 -0
- package/.claude/skills/v3-memory-unification/SKILL.md +174 -0
- package/.claude/skills/v3-performance-optimization/SKILL.md +390 -0
- package/.claude/skills/v3-security-overhaul/SKILL.md +82 -0
- package/.claude/skills/v3-swarm-coordination/SKILL.md +340 -0
- package/.claude/skills/verification-quality/SKILL.md +649 -0
- package/CLAUDE.md +711 -0
- package/README.md +428 -0
- package/__tests__/integration.test.ts +449 -0
- package/__tests__/mcp.test.ts +641 -0
- package/package.json +44 -0
- package/src/connection-pool.ts +344 -0
- package/src/index.ts +253 -0
- package/src/oauth.ts +447 -0
- package/src/prompt-registry.ts +296 -0
- package/src/rate-limiter.ts +266 -0
- package/src/resource-registry.ts +530 -0
- package/src/sampling.ts +363 -0
- package/src/schema-validator.ts +213 -0
- package/src/server.ts +1134 -0
- package/src/session-manager.ts +339 -0
- package/src/task-manager.ts +427 -0
- package/src/tool-registry.ts +475 -0
- package/src/transport/http.ts +532 -0
- package/src/transport/index.ts +233 -0
- package/src/transport/stdio.ts +252 -0
- package/src/transport/websocket.ts +396 -0
- package/src/types.ts +664 -0
- package/tmp.json +0 -0
- package/tsconfig.json +20 -0
- package/vitest.config.ts +13 -0
|
@@ -0,0 +1,144 @@
|
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
# Claude Flow V3 - DDD Progress Tracker Worker
|
|
3
|
+
# Tracks Domain-Driven Design implementation progress
|
|
4
|
+
|
|
5
|
+
set -euo pipefail
|
|
6
|
+
|
|
7
|
+
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
8
|
+
PROJECT_ROOT="$(cd "$SCRIPT_DIR/../.." && pwd)"
|
|
9
|
+
METRICS_DIR="$PROJECT_ROOT/.claude-flow/metrics"
|
|
10
|
+
DDD_FILE="$METRICS_DIR/ddd-progress.json"
|
|
11
|
+
V3_PROGRESS="$METRICS_DIR/v3-progress.json"
|
|
12
|
+
LAST_RUN_FILE="$METRICS_DIR/.ddd-last-run"
|
|
13
|
+
|
|
14
|
+
mkdir -p "$METRICS_DIR"
|
|
15
|
+
|
|
16
|
+
# V3 Target Domains
|
|
17
|
+
DOMAINS=("agent-lifecycle" "task-execution" "memory-management" "coordination" "shared-kernel")
|
|
18
|
+
|
|
19
|
+
should_run() {
|
|
20
|
+
if [ ! -f "$LAST_RUN_FILE" ]; then return 0; fi
|
|
21
|
+
local last_run=$(cat "$LAST_RUN_FILE" 2>/dev/null || echo "0")
|
|
22
|
+
local now=$(date +%s)
|
|
23
|
+
[ $((now - last_run)) -ge 600 ] # 10 minutes
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
check_domain() {
|
|
27
|
+
local domain="$1"
|
|
28
|
+
local domain_path="$PROJECT_ROOT/v3/@claude-flow/$domain"
|
|
29
|
+
local alt_path="$PROJECT_ROOT/src/domains/$domain"
|
|
30
|
+
|
|
31
|
+
local score=0
|
|
32
|
+
local max_score=100
|
|
33
|
+
|
|
34
|
+
# Check if domain directory exists (20 points)
|
|
35
|
+
if [ -d "$domain_path" ] || [ -d "$alt_path" ]; then
|
|
36
|
+
score=$((score + 20))
|
|
37
|
+
local path="${domain_path:-$alt_path}"
|
|
38
|
+
[ -d "$domain_path" ] && path="$domain_path" || path="$alt_path"
|
|
39
|
+
|
|
40
|
+
# Check for domain layer (15 points)
|
|
41
|
+
[ -d "$path/domain" ] || [ -d "$path/src/domain" ] && score=$((score + 15))
|
|
42
|
+
|
|
43
|
+
# Check for application layer (15 points)
|
|
44
|
+
[ -d "$path/application" ] || [ -d "$path/src/application" ] && score=$((score + 15))
|
|
45
|
+
|
|
46
|
+
# Check for infrastructure layer (15 points)
|
|
47
|
+
[ -d "$path/infrastructure" ] || [ -d "$path/src/infrastructure" ] && score=$((score + 15))
|
|
48
|
+
|
|
49
|
+
# Check for API/interface layer (10 points)
|
|
50
|
+
[ -d "$path/api" ] || [ -d "$path/src/api" ] && score=$((score + 10))
|
|
51
|
+
|
|
52
|
+
# Check for tests (15 points)
|
|
53
|
+
local test_count=$(find "$path" -name "*.test.ts" -o -name "*.spec.ts" 2>/dev/null | wc -l)
|
|
54
|
+
[ "$test_count" -gt 0 ] && score=$((score + 15))
|
|
55
|
+
|
|
56
|
+
# Check for index/exports (10 points)
|
|
57
|
+
[ -f "$path/index.ts" ] || [ -f "$path/src/index.ts" ] && score=$((score + 10))
|
|
58
|
+
fi
|
|
59
|
+
|
|
60
|
+
echo "$score"
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
count_entities() {
|
|
64
|
+
local type="$1"
|
|
65
|
+
local pattern="$2"
|
|
66
|
+
|
|
67
|
+
find "$PROJECT_ROOT/v3" "$PROJECT_ROOT/src" -name "*.ts" 2>/dev/null | \
|
|
68
|
+
xargs grep -l "$pattern" 2>/dev/null | \
|
|
69
|
+
grep -v node_modules | grep -v ".test." | wc -l || echo "0"
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
track_ddd() {
|
|
73
|
+
echo "[$(date +%H:%M:%S)] Tracking DDD progress..."
|
|
74
|
+
|
|
75
|
+
local total_score=0
|
|
76
|
+
local domain_scores=""
|
|
77
|
+
local completed_domains=0
|
|
78
|
+
|
|
79
|
+
for domain in "${DOMAINS[@]}"; do
|
|
80
|
+
local score=$(check_domain "$domain")
|
|
81
|
+
total_score=$((total_score + score))
|
|
82
|
+
domain_scores="$domain_scores\"$domain\": $score, "
|
|
83
|
+
|
|
84
|
+
[ "$score" -ge 50 ] && completed_domains=$((completed_domains + 1))
|
|
85
|
+
done
|
|
86
|
+
|
|
87
|
+
# Calculate overall progress
|
|
88
|
+
local max_total=$((${#DOMAINS[@]} * 100))
|
|
89
|
+
local progress=$((total_score * 100 / max_total))
|
|
90
|
+
|
|
91
|
+
# Count DDD artifacts
|
|
92
|
+
local entities=$(count_entities "entities" "class.*Entity\|interface.*Entity")
|
|
93
|
+
local value_objects=$(count_entities "value-objects" "class.*VO\|ValueObject")
|
|
94
|
+
local aggregates=$(count_entities "aggregates" "class.*Aggregate\|AggregateRoot")
|
|
95
|
+
local repositories=$(count_entities "repositories" "interface.*Repository\|Repository")
|
|
96
|
+
local services=$(count_entities "services" "class.*Service\|Service")
|
|
97
|
+
local events=$(count_entities "events" "class.*Event\|DomainEvent")
|
|
98
|
+
|
|
99
|
+
# Write DDD metrics
|
|
100
|
+
cat > "$DDD_FILE" << EOF
|
|
101
|
+
{
|
|
102
|
+
"timestamp": "$(date -Iseconds)",
|
|
103
|
+
"progress": $progress,
|
|
104
|
+
"domains": {
|
|
105
|
+
${domain_scores%,*}
|
|
106
|
+
},
|
|
107
|
+
"completed": $completed_domains,
|
|
108
|
+
"total": ${#DOMAINS[@]},
|
|
109
|
+
"artifacts": {
|
|
110
|
+
"entities": $entities,
|
|
111
|
+
"valueObjects": $value_objects,
|
|
112
|
+
"aggregates": $aggregates,
|
|
113
|
+
"repositories": $repositories,
|
|
114
|
+
"services": $services,
|
|
115
|
+
"domainEvents": $events
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
EOF
|
|
119
|
+
|
|
120
|
+
# Update v3-progress.json
|
|
121
|
+
if [ -f "$V3_PROGRESS" ] && command -v jq &>/dev/null; then
|
|
122
|
+
jq --argjson progress "$progress" --argjson completed "$completed_domains" \
|
|
123
|
+
'.ddd.progress = $progress | .domains.completed = $completed' \
|
|
124
|
+
"$V3_PROGRESS" > "$V3_PROGRESS.tmp" && mv "$V3_PROGRESS.tmp" "$V3_PROGRESS"
|
|
125
|
+
fi
|
|
126
|
+
|
|
127
|
+
echo "[$(date +%H:%M:%S)] ✓ DDD: ${progress}% | Domains: $completed_domains/${#DOMAINS[@]} | Entities: $entities | Services: $services"
|
|
128
|
+
|
|
129
|
+
date +%s > "$LAST_RUN_FILE"
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
case "${1:-check}" in
|
|
133
|
+
"run"|"track") track_ddd ;;
|
|
134
|
+
"check") should_run && track_ddd || echo "[$(date +%H:%M:%S)] Skipping (throttled)" ;;
|
|
135
|
+
"force") rm -f "$LAST_RUN_FILE"; track_ddd ;;
|
|
136
|
+
"status")
|
|
137
|
+
if [ -f "$DDD_FILE" ]; then
|
|
138
|
+
jq -r '"Progress: \(.progress)% | Domains: \(.completed)/\(.total) | Entities: \(.artifacts.entities) | Services: \(.artifacts.services)"' "$DDD_FILE"
|
|
139
|
+
else
|
|
140
|
+
echo "No DDD data available"
|
|
141
|
+
fi
|
|
142
|
+
;;
|
|
143
|
+
*) echo "Usage: $0 [run|check|force|status]" ;;
|
|
144
|
+
esac
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Safe GitHub CLI Helper
|
|
5
|
+
* Prevents timeout issues when using gh commands with special characters
|
|
6
|
+
*
|
|
7
|
+
* Usage:
|
|
8
|
+
* ./github-safe.js issue comment 123 "Message with `backticks`"
|
|
9
|
+
* ./github-safe.js pr create --title "Title" --body "Complex body"
|
|
10
|
+
*/
|
|
11
|
+
|
|
12
|
+
import { execSync } from 'child_process';
|
|
13
|
+
import { writeFileSync, unlinkSync } from 'fs';
|
|
14
|
+
import { tmpdir } from 'os';
|
|
15
|
+
import { join } from 'path';
|
|
16
|
+
import { randomBytes } from 'crypto';
|
|
17
|
+
|
|
18
|
+
const args = process.argv.slice(2);
|
|
19
|
+
|
|
20
|
+
if (args.length < 2) {
|
|
21
|
+
console.log(`
|
|
22
|
+
Safe GitHub CLI Helper
|
|
23
|
+
|
|
24
|
+
Usage:
|
|
25
|
+
./github-safe.js issue comment <number> <body>
|
|
26
|
+
./github-safe.js pr comment <number> <body>
|
|
27
|
+
./github-safe.js issue create --title <title> --body <body>
|
|
28
|
+
./github-safe.js pr create --title <title> --body <body>
|
|
29
|
+
|
|
30
|
+
This helper prevents timeout issues with special characters like:
|
|
31
|
+
- Backticks in code examples
|
|
32
|
+
- Command substitution \$(...)
|
|
33
|
+
- Directory paths
|
|
34
|
+
- Special shell characters
|
|
35
|
+
`);
|
|
36
|
+
process.exit(1);
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
const [command, subcommand, ...restArgs] = args;
|
|
40
|
+
|
|
41
|
+
// Handle commands that need body content
|
|
42
|
+
if ((command === 'issue' || command === 'pr') &&
|
|
43
|
+
(subcommand === 'comment' || subcommand === 'create')) {
|
|
44
|
+
|
|
45
|
+
let bodyIndex = -1;
|
|
46
|
+
let body = '';
|
|
47
|
+
|
|
48
|
+
if (subcommand === 'comment' && restArgs.length >= 2) {
|
|
49
|
+
// Simple format: github-safe.js issue comment 123 "body"
|
|
50
|
+
body = restArgs[1];
|
|
51
|
+
bodyIndex = 1;
|
|
52
|
+
} else {
|
|
53
|
+
// Flag format: --body "content"
|
|
54
|
+
bodyIndex = restArgs.indexOf('--body');
|
|
55
|
+
if (bodyIndex !== -1 && bodyIndex < restArgs.length - 1) {
|
|
56
|
+
body = restArgs[bodyIndex + 1];
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
if (body) {
|
|
61
|
+
// Use temporary file for body content
|
|
62
|
+
const tmpFile = join(tmpdir(), `gh-body-${randomBytes(8).toString('hex')}.tmp`);
|
|
63
|
+
|
|
64
|
+
try {
|
|
65
|
+
writeFileSync(tmpFile, body, 'utf8');
|
|
66
|
+
|
|
67
|
+
// Build new command with --body-file
|
|
68
|
+
const newArgs = [...restArgs];
|
|
69
|
+
if (subcommand === 'comment' && bodyIndex === 1) {
|
|
70
|
+
// Replace body with --body-file
|
|
71
|
+
newArgs[1] = '--body-file';
|
|
72
|
+
newArgs.push(tmpFile);
|
|
73
|
+
} else if (bodyIndex !== -1) {
|
|
74
|
+
// Replace --body with --body-file
|
|
75
|
+
newArgs[bodyIndex] = '--body-file';
|
|
76
|
+
newArgs[bodyIndex + 1] = tmpFile;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
// Execute safely
|
|
80
|
+
const ghCommand = `gh ${command} ${subcommand} ${newArgs.join(' ')}`;
|
|
81
|
+
console.log(`Executing: ${ghCommand}`);
|
|
82
|
+
|
|
83
|
+
const result = execSync(ghCommand, {
|
|
84
|
+
stdio: 'inherit',
|
|
85
|
+
timeout: 30000 // 30 second timeout
|
|
86
|
+
});
|
|
87
|
+
|
|
88
|
+
} catch (error) {
|
|
89
|
+
console.error('Error:', error.message);
|
|
90
|
+
process.exit(1);
|
|
91
|
+
} finally {
|
|
92
|
+
// Clean up
|
|
93
|
+
try {
|
|
94
|
+
unlinkSync(tmpFile);
|
|
95
|
+
} catch (e) {
|
|
96
|
+
// Ignore cleanup errors
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
} else {
|
|
100
|
+
// No body content, execute normally
|
|
101
|
+
execSync(`gh ${args.join(' ')}`, { stdio: 'inherit' });
|
|
102
|
+
}
|
|
103
|
+
} else {
|
|
104
|
+
// Other commands, execute normally
|
|
105
|
+
execSync(`gh ${args.join(' ')}`, { stdio: 'inherit' });
|
|
106
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
# Setup GitHub integration for Claude Flow
|
|
3
|
+
|
|
4
|
+
echo "🔗 Setting up GitHub integration..."
|
|
5
|
+
|
|
6
|
+
# Check for gh CLI
|
|
7
|
+
if ! command -v gh &> /dev/null; then
|
|
8
|
+
echo "⚠️ GitHub CLI (gh) not found"
|
|
9
|
+
echo "Install from: https://cli.github.com/"
|
|
10
|
+
echo "Continuing without GitHub features..."
|
|
11
|
+
else
|
|
12
|
+
echo "✅ GitHub CLI found"
|
|
13
|
+
|
|
14
|
+
# Check auth status
|
|
15
|
+
if gh auth status &> /dev/null; then
|
|
16
|
+
echo "✅ GitHub authentication active"
|
|
17
|
+
else
|
|
18
|
+
echo "⚠️ Not authenticated with GitHub"
|
|
19
|
+
echo "Run: gh auth login"
|
|
20
|
+
fi
|
|
21
|
+
fi
|
|
22
|
+
|
|
23
|
+
echo ""
|
|
24
|
+
echo "📦 GitHub swarm commands available:"
|
|
25
|
+
echo " - npx claude-flow github swarm"
|
|
26
|
+
echo " - npx claude-flow repo analyze"
|
|
27
|
+
echo " - npx claude-flow pr enhance"
|
|
28
|
+
echo " - npx claude-flow issue triage"
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
# Capture hook guidance for Claude visibility
|
|
3
|
+
GUIDANCE_FILE=".claude-flow/last-guidance.txt"
|
|
4
|
+
mkdir -p .claude-flow
|
|
5
|
+
|
|
6
|
+
case "$1" in
|
|
7
|
+
"route")
|
|
8
|
+
npx agentic-flow@alpha hooks route "$2" 2>&1 | tee "$GUIDANCE_FILE"
|
|
9
|
+
;;
|
|
10
|
+
"pre-edit")
|
|
11
|
+
npx agentic-flow@alpha hooks pre-edit "$2" 2>&1 | tee "$GUIDANCE_FILE"
|
|
12
|
+
;;
|
|
13
|
+
esac
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
# Guidance Hooks for Claude Flow V3
|
|
3
|
+
# Provides context and routing for Claude Code operations
|
|
4
|
+
|
|
5
|
+
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
6
|
+
PROJECT_ROOT="$(cd "$SCRIPT_DIR/../.." && pwd)"
|
|
7
|
+
CACHE_DIR="$PROJECT_ROOT/.claude-flow"
|
|
8
|
+
|
|
9
|
+
# Ensure cache directory exists
|
|
10
|
+
mkdir -p "$CACHE_DIR" 2>/dev/null || true
|
|
11
|
+
|
|
12
|
+
# Color codes
|
|
13
|
+
CYAN='\033[0;36m'
|
|
14
|
+
GREEN='\033[0;32m'
|
|
15
|
+
YELLOW='\033[1;33m'
|
|
16
|
+
RED='\033[0;31m'
|
|
17
|
+
RESET='\033[0m'
|
|
18
|
+
DIM='\033[2m'
|
|
19
|
+
|
|
20
|
+
# Get command
|
|
21
|
+
COMMAND="${1:-help}"
|
|
22
|
+
shift || true
|
|
23
|
+
|
|
24
|
+
case "$COMMAND" in
|
|
25
|
+
pre-edit)
|
|
26
|
+
FILE_PATH="$1"
|
|
27
|
+
if [[ -n "$FILE_PATH" ]]; then
|
|
28
|
+
if [[ "$FILE_PATH" =~ (config|secret|credential|password|key|auth) ]]; then
|
|
29
|
+
echo -e "${YELLOW}[Guidance] Security-sensitive file${RESET}"
|
|
30
|
+
fi
|
|
31
|
+
if [[ "$FILE_PATH" =~ ^v3/ ]]; then
|
|
32
|
+
echo -e "${CYAN}[Guidance] V3 module - follow ADR guidelines${RESET}"
|
|
33
|
+
fi
|
|
34
|
+
fi
|
|
35
|
+
exit 0
|
|
36
|
+
;;
|
|
37
|
+
|
|
38
|
+
post-edit)
|
|
39
|
+
FILE_PATH="$1"
|
|
40
|
+
echo "$(date -Iseconds) edit $FILE_PATH" >> "$CACHE_DIR/edit-history.log" 2>/dev/null || true
|
|
41
|
+
exit 0
|
|
42
|
+
;;
|
|
43
|
+
|
|
44
|
+
pre-command)
|
|
45
|
+
COMMAND_STR="$1"
|
|
46
|
+
if [[ "$COMMAND_STR" =~ (rm -rf|sudo|chmod 777) ]]; then
|
|
47
|
+
echo -e "${RED}[Guidance] High-risk command${RESET}"
|
|
48
|
+
fi
|
|
49
|
+
exit 0
|
|
50
|
+
;;
|
|
51
|
+
|
|
52
|
+
route)
|
|
53
|
+
TASK="$1"
|
|
54
|
+
[[ -z "$TASK" ]] && exit 0
|
|
55
|
+
if [[ "$TASK" =~ (security|CVE|vulnerability) ]]; then
|
|
56
|
+
echo -e "${DIM}[Route] security-architect${RESET}"
|
|
57
|
+
elif [[ "$TASK" =~ (memory|AgentDB|HNSW|vector) ]]; then
|
|
58
|
+
echo -e "${DIM}[Route] memory-specialist${RESET}"
|
|
59
|
+
elif [[ "$TASK" =~ (performance|optimize|benchmark) ]]; then
|
|
60
|
+
echo -e "${DIM}[Route] performance-engineer${RESET}"
|
|
61
|
+
elif [[ "$TASK" =~ (test|TDD|spec) ]]; then
|
|
62
|
+
echo -e "${DIM}[Route] test-architect${RESET}"
|
|
63
|
+
fi
|
|
64
|
+
exit 0
|
|
65
|
+
;;
|
|
66
|
+
|
|
67
|
+
session-context)
|
|
68
|
+
cat << 'EOF'
|
|
69
|
+
## V3 Development Context
|
|
70
|
+
|
|
71
|
+
**Architecture**: Domain-Driven Design with 15 @claude-flow modules
|
|
72
|
+
**Priority**: Security-first (CVE-1, CVE-2, CVE-3 remediation)
|
|
73
|
+
**Performance Targets**:
|
|
74
|
+
- HNSW search: 150x-12,500x faster
|
|
75
|
+
- Flash Attention: 2.49x-7.47x speedup
|
|
76
|
+
- Memory: 50-75% reduction
|
|
77
|
+
|
|
78
|
+
**Active Patterns**:
|
|
79
|
+
- Use TDD London School (mock-first)
|
|
80
|
+
- Event sourcing for state changes
|
|
81
|
+
- agentic-flow@alpha as core foundation
|
|
82
|
+
- Bounded contexts with clear interfaces
|
|
83
|
+
|
|
84
|
+
**Code Quality Rules**:
|
|
85
|
+
- Files under 500 lines
|
|
86
|
+
- No hardcoded secrets
|
|
87
|
+
- Input validation at boundaries
|
|
88
|
+
- Typed interfaces for all public APIs
|
|
89
|
+
|
|
90
|
+
**Learned Patterns**: 17 available for reference
|
|
91
|
+
EOF
|
|
92
|
+
exit 0
|
|
93
|
+
;;
|
|
94
|
+
|
|
95
|
+
user-prompt)
|
|
96
|
+
exit 0
|
|
97
|
+
;;
|
|
98
|
+
|
|
99
|
+
*)
|
|
100
|
+
exit 0
|
|
101
|
+
;;
|
|
102
|
+
esac
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
# Claude Flow V3 - Health Monitor Worker
|
|
3
|
+
# Checks disk space, memory pressure, process health
|
|
4
|
+
|
|
5
|
+
set -euo pipefail
|
|
6
|
+
|
|
7
|
+
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
8
|
+
PROJECT_ROOT="$(cd "$SCRIPT_DIR/../.." && pwd)"
|
|
9
|
+
METRICS_DIR="$PROJECT_ROOT/.claude-flow/metrics"
|
|
10
|
+
HEALTH_FILE="$METRICS_DIR/health.json"
|
|
11
|
+
LAST_RUN_FILE="$METRICS_DIR/.health-last-run"
|
|
12
|
+
|
|
13
|
+
mkdir -p "$METRICS_DIR"
|
|
14
|
+
|
|
15
|
+
should_run() {
|
|
16
|
+
if [ ! -f "$LAST_RUN_FILE" ]; then return 0; fi
|
|
17
|
+
local last_run=$(cat "$LAST_RUN_FILE" 2>/dev/null || echo "0")
|
|
18
|
+
local now=$(date +%s)
|
|
19
|
+
[ $((now - last_run)) -ge 300 ] # 5 minutes
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
check_health() {
|
|
23
|
+
echo "[$(date +%H:%M:%S)] Running health check..."
|
|
24
|
+
|
|
25
|
+
# Disk usage
|
|
26
|
+
local disk_usage=$(df -h "$PROJECT_ROOT" 2>/dev/null | awk 'NR==2 {print $5}' | tr -d '%')
|
|
27
|
+
local disk_free=$(df -h "$PROJECT_ROOT" 2>/dev/null | awk 'NR==2 {print $4}')
|
|
28
|
+
|
|
29
|
+
# Memory usage
|
|
30
|
+
local mem_total=$(free -m 2>/dev/null | awk '/Mem:/ {print $2}' || echo "0")
|
|
31
|
+
local mem_used=$(free -m 2>/dev/null | awk '/Mem:/ {print $3}' || echo "0")
|
|
32
|
+
local mem_pct=$((mem_used * 100 / (mem_total + 1)))
|
|
33
|
+
|
|
34
|
+
# Process counts
|
|
35
|
+
local node_procs=$(pgrep -c node 2>/dev/null || echo "0")
|
|
36
|
+
local agentic_procs=$(ps aux 2>/dev/null | grep -c "agentic-flow" | grep -v grep || echo "0")
|
|
37
|
+
|
|
38
|
+
# CPU load
|
|
39
|
+
local load_avg=$(cat /proc/loadavg 2>/dev/null | awk '{print $1}' || echo "0")
|
|
40
|
+
|
|
41
|
+
# File descriptor usage
|
|
42
|
+
local fd_used=$(ls /proc/$$/fd 2>/dev/null | wc -l || echo "0")
|
|
43
|
+
|
|
44
|
+
# Determine health status
|
|
45
|
+
local status="healthy"
|
|
46
|
+
local warnings=""
|
|
47
|
+
|
|
48
|
+
if [ "$disk_usage" -gt 90 ]; then
|
|
49
|
+
status="critical"
|
|
50
|
+
warnings="$warnings disk_full"
|
|
51
|
+
elif [ "$disk_usage" -gt 80 ]; then
|
|
52
|
+
status="warning"
|
|
53
|
+
warnings="$warnings disk_high"
|
|
54
|
+
fi
|
|
55
|
+
|
|
56
|
+
if [ "$mem_pct" -gt 90 ]; then
|
|
57
|
+
status="critical"
|
|
58
|
+
warnings="$warnings memory_full"
|
|
59
|
+
elif [ "$mem_pct" -gt 80 ]; then
|
|
60
|
+
[ "$status" != "critical" ] && status="warning"
|
|
61
|
+
warnings="$warnings memory_high"
|
|
62
|
+
fi
|
|
63
|
+
|
|
64
|
+
# Write health metrics
|
|
65
|
+
cat > "$HEALTH_FILE" << EOF
|
|
66
|
+
{
|
|
67
|
+
"status": "$status",
|
|
68
|
+
"timestamp": "$(date -Iseconds)",
|
|
69
|
+
"disk": {
|
|
70
|
+
"usage_pct": $disk_usage,
|
|
71
|
+
"free": "$disk_free"
|
|
72
|
+
},
|
|
73
|
+
"memory": {
|
|
74
|
+
"total_mb": $mem_total,
|
|
75
|
+
"used_mb": $mem_used,
|
|
76
|
+
"usage_pct": $mem_pct
|
|
77
|
+
},
|
|
78
|
+
"processes": {
|
|
79
|
+
"node": $node_procs,
|
|
80
|
+
"agentic_flow": $agentic_procs
|
|
81
|
+
},
|
|
82
|
+
"load_avg": $load_avg,
|
|
83
|
+
"fd_used": $fd_used,
|
|
84
|
+
"warnings": "$(echo $warnings | xargs)"
|
|
85
|
+
}
|
|
86
|
+
EOF
|
|
87
|
+
|
|
88
|
+
echo "[$(date +%H:%M:%S)] ✓ Health: $status | Disk: ${disk_usage}% | Memory: ${mem_pct}% | Load: $load_avg"
|
|
89
|
+
|
|
90
|
+
date +%s > "$LAST_RUN_FILE"
|
|
91
|
+
|
|
92
|
+
# Return non-zero if unhealthy
|
|
93
|
+
[ "$status" = "healthy" ] && return 0 || return 1
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
case "${1:-check}" in
|
|
97
|
+
"run") check_health ;;
|
|
98
|
+
"check") should_run && check_health || echo "[$(date +%H:%M:%S)] Skipping (throttled)" ;;
|
|
99
|
+
"force") rm -f "$LAST_RUN_FILE"; check_health ;;
|
|
100
|
+
"status")
|
|
101
|
+
if [ -f "$HEALTH_FILE" ]; then
|
|
102
|
+
jq -r '"Status: \(.status) | Disk: \(.disk.usage_pct)% | Memory: \(.memory.usage_pct)% | Load: \(.load_avg)"' "$HEALTH_FILE"
|
|
103
|
+
else
|
|
104
|
+
echo "No health data available"
|
|
105
|
+
fi
|
|
106
|
+
;;
|
|
107
|
+
*) echo "Usage: $0 [run|check|force|status]" ;;
|
|
108
|
+
esac
|