specweave 0.18.1 → 0.20.0
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.md +229 -1817
- package/README.md +68 -0
- package/bin/specweave.js +62 -6
- package/dist/plugins/specweave/lib/hooks/sync-living-docs.d.ts.map +1 -1
- package/dist/plugins/specweave/lib/hooks/sync-living-docs.js +3 -0
- package/dist/plugins/specweave/lib/hooks/sync-living-docs.js.map +1 -1
- package/dist/plugins/specweave/lib/hooks/update-ac-status.d.ts +21 -0
- package/dist/plugins/specweave/lib/hooks/update-ac-status.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/hooks/update-ac-status.js +162 -0
- package/dist/plugins/specweave/lib/hooks/update-ac-status.js.map +1 -0
- package/dist/plugins/specweave-ado/lib/ado-spec-content-sync.d.ts.map +1 -1
- package/dist/plugins/specweave-ado/lib/ado-spec-content-sync.js +65 -6
- package/dist/plugins/specweave-ado/lib/ado-spec-content-sync.js.map +1 -1
- package/dist/plugins/specweave-github/lib/completion-calculator.d.ts +112 -0
- package/dist/plugins/specweave-github/lib/completion-calculator.d.ts.map +1 -0
- package/dist/plugins/specweave-github/lib/completion-calculator.js +301 -0
- package/dist/plugins/specweave-github/lib/completion-calculator.js.map +1 -0
- package/dist/plugins/specweave-github/lib/duplicate-detector.d.ts +3 -3
- package/dist/plugins/specweave-github/lib/duplicate-detector.js +3 -3
- package/dist/plugins/specweave-github/lib/epic-content-builder.d.ts +7 -0
- package/dist/plugins/specweave-github/lib/epic-content-builder.d.ts.map +1 -1
- package/dist/plugins/specweave-github/lib/epic-content-builder.js +42 -0
- package/dist/plugins/specweave-github/lib/epic-content-builder.js.map +1 -1
- package/dist/plugins/specweave-github/lib/github-client-v2.d.ts +14 -0
- package/dist/plugins/specweave-github/lib/github-client-v2.d.ts.map +1 -1
- package/dist/plugins/specweave-github/lib/github-client-v2.js +51 -0
- package/dist/plugins/specweave-github/lib/github-client-v2.js.map +1 -1
- package/dist/plugins/specweave-github/lib/github-epic-sync.js +1 -1
- package/dist/plugins/specweave-github/lib/github-epic-sync.js.map +1 -1
- package/dist/plugins/specweave-github/lib/github-feature-sync.d.ts +87 -0
- package/dist/plugins/specweave-github/lib/github-feature-sync.d.ts.map +1 -0
- package/dist/plugins/specweave-github/lib/github-feature-sync.js +412 -0
- package/dist/plugins/specweave-github/lib/github-feature-sync.js.map +1 -0
- package/dist/plugins/specweave-github/lib/github-spec-content-sync.d.ts.map +1 -1
- package/dist/plugins/specweave-github/lib/github-spec-content-sync.js +64 -13
- package/dist/plugins/specweave-github/lib/github-spec-content-sync.js.map +1 -1
- package/dist/plugins/specweave-github/lib/progress-comment-builder.d.ts +78 -0
- package/dist/plugins/specweave-github/lib/progress-comment-builder.d.ts.map +1 -0
- package/dist/plugins/specweave-github/lib/progress-comment-builder.js +237 -0
- package/dist/plugins/specweave-github/lib/progress-comment-builder.js.map +1 -0
- package/dist/plugins/specweave-github/lib/user-story-content-builder.d.ts +97 -0
- package/dist/plugins/specweave-github/lib/user-story-content-builder.d.ts.map +1 -0
- package/dist/plugins/specweave-github/lib/user-story-content-builder.js +301 -0
- package/dist/plugins/specweave-github/lib/user-story-content-builder.js.map +1 -0
- package/dist/plugins/specweave-github/lib/user-story-issue-builder.d.ts +83 -0
- package/dist/plugins/specweave-github/lib/user-story-issue-builder.d.ts.map +1 -0
- package/dist/plugins/specweave-github/lib/user-story-issue-builder.js +386 -0
- package/dist/plugins/specweave-github/lib/user-story-issue-builder.js.map +1 -0
- package/dist/plugins/specweave-jira/lib/enhanced-jira-sync.d.ts +8 -6
- package/dist/plugins/specweave-jira/lib/enhanced-jira-sync.d.ts.map +1 -1
- package/dist/plugins/specweave-jira/lib/enhanced-jira-sync.js +78 -117
- package/dist/plugins/specweave-jira/lib/enhanced-jira-sync.js.map +1 -1
- package/dist/plugins/specweave-kafka/lib/cli/kcat-wrapper.d.ts +57 -0
- package/dist/plugins/specweave-kafka/lib/cli/kcat-wrapper.d.ts.map +1 -0
- package/dist/plugins/specweave-kafka/lib/cli/kcat-wrapper.js +248 -0
- package/dist/plugins/specweave-kafka/lib/cli/kcat-wrapper.js.map +1 -0
- package/dist/plugins/specweave-kafka/lib/cli/types.d.ts +82 -0
- package/dist/plugins/specweave-kafka/lib/cli/types.d.ts.map +1 -0
- package/dist/plugins/specweave-kafka/lib/cli/types.js +13 -0
- package/dist/plugins/specweave-kafka/lib/cli/types.js.map +1 -0
- package/dist/plugins/specweave-kafka/lib/mcp/detector.d.ts +49 -0
- package/dist/plugins/specweave-kafka/lib/mcp/detector.d.ts.map +1 -0
- package/dist/plugins/specweave-kafka/lib/mcp/detector.js +316 -0
- package/dist/plugins/specweave-kafka/lib/mcp/detector.js.map +1 -0
- package/dist/plugins/specweave-kafka/lib/mcp/types.d.ts +70 -0
- package/dist/plugins/specweave-kafka/lib/mcp/types.d.ts.map +1 -0
- package/dist/plugins/specweave-kafka/lib/mcp/types.js +23 -0
- package/dist/plugins/specweave-kafka/lib/mcp/types.js.map +1 -0
- package/dist/plugins/specweave-kafka/lib/utils/partitioning.d.ts +85 -0
- package/dist/plugins/specweave-kafka/lib/utils/partitioning.d.ts.map +1 -0
- package/dist/plugins/specweave-kafka/lib/utils/partitioning.js +281 -0
- package/dist/plugins/specweave-kafka/lib/utils/partitioning.js.map +1 -0
- package/dist/plugins/specweave-kafka/lib/utils/sizing.d.ts +75 -0
- package/dist/plugins/specweave-kafka/lib/utils/sizing.d.ts.map +1 -0
- package/dist/plugins/specweave-kafka/lib/utils/sizing.js +238 -0
- package/dist/plugins/specweave-kafka/lib/utils/sizing.js.map +1 -0
- package/dist/src/cli/commands/import-docs.js +4 -4
- package/dist/src/cli/commands/import-docs.js.map +1 -1
- package/dist/src/cli/commands/init-multiproject.d.ts.map +1 -1
- package/dist/src/cli/commands/init-multiproject.js +17 -18
- package/dist/src/cli/commands/init-multiproject.js.map +1 -1
- package/dist/src/cli/commands/migrate-to-multiproject.d.ts.map +1 -1
- package/dist/src/cli/commands/migrate-to-multiproject.js +8 -4
- package/dist/src/cli/commands/migrate-to-multiproject.js.map +1 -1
- package/dist/src/cli/commands/switch-project.d.ts.map +1 -1
- package/dist/src/cli/commands/switch-project.js +9 -26
- package/dist/src/cli/commands/switch-project.js.map +1 -1
- package/dist/src/cli/commands/sync-spec-content.js +3 -0
- package/dist/src/cli/commands/sync-spec-content.js.map +1 -1
- package/dist/src/core/deduplication/command-deduplicator.d.ts +166 -0
- package/dist/src/core/deduplication/command-deduplicator.d.ts.map +1 -0
- package/dist/src/core/deduplication/command-deduplicator.js +254 -0
- package/dist/src/core/deduplication/command-deduplicator.js.map +1 -0
- package/dist/src/core/increment/active-increment-manager.d.ts +42 -15
- package/dist/src/core/increment/active-increment-manager.d.ts.map +1 -1
- package/dist/src/core/increment/active-increment-manager.js +113 -46
- package/dist/src/core/increment/active-increment-manager.js.map +1 -1
- package/dist/src/core/increment/conflict-resolver.d.ts +40 -0
- package/dist/src/core/increment/conflict-resolver.d.ts.map +1 -0
- package/dist/src/core/increment/conflict-resolver.js +219 -0
- package/dist/src/core/increment/conflict-resolver.js.map +1 -0
- package/dist/src/core/increment/discipline-checker.d.ts.map +1 -1
- package/dist/src/core/increment/discipline-checker.js +7 -1
- package/dist/src/core/increment/discipline-checker.js.map +1 -1
- package/dist/src/core/increment/duplicate-detector.d.ts +52 -0
- package/dist/src/core/increment/duplicate-detector.d.ts.map +1 -0
- package/dist/src/core/increment/duplicate-detector.js +276 -0
- package/dist/src/core/increment/duplicate-detector.js.map +1 -0
- package/dist/src/core/increment/increment-archiver.d.ts +90 -0
- package/dist/src/core/increment/increment-archiver.d.ts.map +1 -0
- package/dist/src/core/increment/increment-archiver.js +368 -0
- package/dist/src/core/increment/increment-archiver.js.map +1 -0
- package/dist/src/core/increment/increment-reopener.d.ts +165 -0
- package/dist/src/core/increment/increment-reopener.d.ts.map +1 -0
- package/dist/src/core/increment/increment-reopener.js +390 -0
- package/dist/src/core/increment/increment-reopener.js.map +1 -0
- package/dist/src/core/increment/metadata-manager.d.ts +26 -1
- package/dist/src/core/increment/metadata-manager.d.ts.map +1 -1
- package/dist/src/core/increment/metadata-manager.js +143 -5
- package/dist/src/core/increment/metadata-manager.js.map +1 -1
- package/dist/src/core/increment/recent-work-scanner.d.ts +121 -0
- package/dist/src/core/increment/recent-work-scanner.d.ts.map +1 -0
- package/dist/src/core/increment/recent-work-scanner.js +303 -0
- package/dist/src/core/increment/recent-work-scanner.js.map +1 -0
- package/dist/src/core/increment/types.d.ts +1 -0
- package/dist/src/core/increment/types.d.ts.map +1 -1
- package/dist/src/core/increment-utils.d.ts +112 -0
- package/dist/src/core/increment-utils.d.ts.map +1 -0
- package/dist/src/core/increment-utils.js +210 -0
- package/dist/src/core/increment-utils.js.map +1 -0
- package/dist/src/core/living-docs/ac-project-specific-generator.d.ts +65 -0
- package/dist/src/core/living-docs/ac-project-specific-generator.d.ts.map +1 -0
- package/dist/src/core/living-docs/ac-project-specific-generator.js +175 -0
- package/dist/src/core/living-docs/ac-project-specific-generator.js.map +1 -0
- package/dist/src/core/living-docs/feature-archiver.d.ts +130 -0
- package/dist/src/core/living-docs/feature-archiver.d.ts.map +1 -0
- package/dist/src/core/living-docs/feature-archiver.js +549 -0
- package/dist/src/core/living-docs/feature-archiver.js.map +1 -0
- package/dist/src/core/living-docs/feature-id-manager.d.ts +81 -0
- package/dist/src/core/living-docs/feature-id-manager.d.ts.map +1 -0
- package/dist/src/core/living-docs/feature-id-manager.js +339 -0
- package/dist/src/core/living-docs/feature-id-manager.js.map +1 -0
- package/dist/src/core/living-docs/hierarchy-mapper.d.ts +144 -83
- package/dist/src/core/living-docs/hierarchy-mapper.d.ts.map +1 -1
- package/dist/src/core/living-docs/hierarchy-mapper.js +488 -270
- package/dist/src/core/living-docs/hierarchy-mapper.js.map +1 -1
- package/dist/src/core/living-docs/index.d.ts +6 -0
- package/dist/src/core/living-docs/index.d.ts.map +1 -1
- package/dist/src/core/living-docs/index.js +6 -0
- package/dist/src/core/living-docs/index.js.map +1 -1
- package/dist/src/core/living-docs/project-detector.d.ts +6 -0
- package/dist/src/core/living-docs/project-detector.d.ts.map +1 -1
- package/dist/src/core/living-docs/project-detector.js +35 -1
- package/dist/src/core/living-docs/project-detector.js.map +1 -1
- package/dist/src/core/living-docs/spec-distributor.d.ts +100 -26
- package/dist/src/core/living-docs/spec-distributor.d.ts.map +1 -1
- package/dist/src/core/living-docs/spec-distributor.js +1275 -258
- package/dist/src/core/living-docs/spec-distributor.js.map +1 -1
- package/dist/src/core/living-docs/task-project-specific-generator.d.ts +109 -0
- package/dist/src/core/living-docs/task-project-specific-generator.d.ts.map +1 -0
- package/dist/src/core/living-docs/task-project-specific-generator.js +221 -0
- package/dist/src/core/living-docs/task-project-specific-generator.js.map +1 -0
- package/dist/src/core/living-docs/types.d.ts +143 -0
- package/dist/src/core/living-docs/types.d.ts.map +1 -1
- package/dist/src/core/project-manager.d.ts +2 -17
- package/dist/src/core/project-manager.d.ts.map +1 -1
- package/dist/src/core/project-manager.js +68 -48
- package/dist/src/core/project-manager.js.map +1 -1
- package/dist/src/core/spec-content-sync.d.ts +1 -1
- package/dist/src/core/spec-content-sync.d.ts.map +1 -1
- package/dist/src/core/sync/enhanced-content-builder.d.ts.map +1 -1
- package/dist/src/core/sync/enhanced-content-builder.js +2 -1
- package/dist/src/core/sync/enhanced-content-builder.js.map +1 -1
- package/dist/src/core/sync/performance-optimizer.d.ts +153 -0
- package/dist/src/core/sync/performance-optimizer.d.ts.map +1 -0
- package/dist/src/core/sync/performance-optimizer.js +220 -0
- package/dist/src/core/sync/performance-optimizer.js.map +1 -0
- package/dist/src/core/sync/retry-handler.d.ts +98 -0
- package/dist/src/core/sync/retry-handler.d.ts.map +1 -0
- package/dist/src/core/sync/retry-handler.js +196 -0
- package/dist/src/core/sync/retry-handler.js.map +1 -0
- package/dist/src/core/types/config.d.ts +94 -0
- package/dist/src/core/types/config.d.ts.map +1 -1
- package/dist/src/core/types/config.js +16 -0
- package/dist/src/core/types/config.js.map +1 -1
- package/dist/src/core/types/increment-metadata.d.ts +6 -0
- package/dist/src/core/types/increment-metadata.d.ts.map +1 -1
- package/dist/src/core/types/increment-metadata.js +10 -1
- package/dist/src/core/types/increment-metadata.js.map +1 -1
- package/dist/src/integrations/jira/jira-incremental-mapper.d.ts.map +1 -1
- package/dist/src/integrations/jira/jira-incremental-mapper.js +4 -8
- package/dist/src/integrations/jira/jira-incremental-mapper.js.map +1 -1
- package/dist/src/integrations/jira/jira-mapper.d.ts.map +1 -1
- package/dist/src/integrations/jira/jira-mapper.js +4 -8
- package/dist/src/integrations/jira/jira-mapper.js.map +1 -1
- package/package.json +1 -1
- package/plugins/specweave/COMMANDS.md +13 -4
- package/plugins/specweave/commands/specweave-abandon.md +22 -20
- package/plugins/specweave/commands/specweave-archive-features.md +121 -0
- package/plugins/specweave/commands/specweave-archive-increments.md +82 -0
- package/plugins/specweave/commands/specweave-archive.md +363 -0
- package/plugins/specweave/commands/specweave-backlog.md +211 -0
- package/plugins/specweave/commands/specweave-fix-duplicates.md +517 -0
- package/plugins/specweave/commands/specweave-increment.md +4 -3
- package/plugins/specweave/commands/specweave-progress.md +176 -27
- package/plugins/specweave/commands/specweave-reopen.md +391 -0
- package/plugins/specweave/commands/specweave-restore-feature.md +90 -0
- package/plugins/specweave/commands/specweave-restore.md +309 -0
- package/plugins/specweave/commands/specweave-resume.md +51 -23
- package/plugins/specweave/commands/specweave-status.md +41 -7
- package/plugins/specweave/commands/specweave-sync-specs.md +425 -0
- package/plugins/specweave/hooks/hooks.json +4 -0
- package/plugins/specweave/hooks/lib/sync-spec-content.sh +2 -2
- package/plugins/specweave/hooks/post-task-completion.sh +39 -0
- package/plugins/specweave/hooks/pre-command-deduplication.sh +83 -0
- package/plugins/specweave/hooks/user-prompt-submit.sh +1 -1
- package/plugins/specweave/lib/hooks/sync-living-docs.js +2 -0
- package/plugins/specweave/lib/hooks/sync-living-docs.ts +4 -0
- package/plugins/specweave/lib/hooks/update-ac-status.js +102 -0
- package/plugins/specweave/lib/hooks/update-ac-status.ts +192 -0
- package/plugins/specweave/skills/archive-increments/SKILL.md +198 -0
- package/plugins/specweave/skills/increment-planner/scripts/feature-utils.js +14 -0
- package/plugins/specweave/skills/smart-reopen-detector/SKILL.md +244 -0
- package/plugins/specweave-ado/lib/ado-spec-content-sync.js +49 -5
- package/plugins/specweave-ado/lib/ado-spec-content-sync.ts +72 -6
- package/plugins/specweave-confluent/.claude-plugin/plugin.json +23 -0
- package/plugins/specweave-confluent/README.md +375 -0
- package/plugins/specweave-confluent/agents/confluent-architect/AGENT.md +306 -0
- package/plugins/specweave-confluent/skills/confluent-kafka-connect/SKILL.md +453 -0
- package/plugins/specweave-confluent/skills/confluent-ksqldb/SKILL.md +470 -0
- package/plugins/specweave-confluent/skills/confluent-schema-registry/SKILL.md +316 -0
- package/plugins/specweave-github/agents/github-task-splitter/AGENT.md +2 -2
- package/plugins/specweave-github/agents/user-story-updater/AGENT.md +148 -0
- package/plugins/specweave-github/commands/specweave-github-cleanup-duplicates.md +1 -1
- package/plugins/specweave-github/commands/specweave-github-update-user-story.md +156 -0
- package/plugins/specweave-github/hooks/post-task-completion.sh +10 -9
- package/plugins/specweave-github/lib/completion-calculator.js +262 -0
- package/plugins/specweave-github/lib/completion-calculator.ts +434 -0
- package/plugins/specweave-github/lib/duplicate-detector.js +3 -3
- package/plugins/specweave-github/lib/duplicate-detector.ts +4 -4
- package/plugins/specweave-github/lib/epic-content-builder.js +38 -0
- package/plugins/specweave-github/lib/epic-content-builder.ts +59 -0
- package/plugins/specweave-github/lib/github-client-v2.js +49 -0
- package/plugins/specweave-github/lib/github-client-v2.ts +59 -0
- package/plugins/specweave-github/lib/github-epic-sync.ts +1 -1
- package/plugins/specweave-github/lib/github-feature-sync.js +381 -0
- package/plugins/specweave-github/lib/github-feature-sync.ts +568 -0
- package/plugins/specweave-github/lib/github-spec-content-sync.js +40 -10
- package/plugins/specweave-github/lib/github-spec-content-sync.ts +82 -14
- package/plugins/specweave-github/lib/progress-comment-builder.js +229 -0
- package/plugins/specweave-github/lib/progress-comment-builder.ts +324 -0
- package/plugins/specweave-github/lib/user-story-content-builder.js +299 -0
- package/plugins/specweave-github/lib/user-story-content-builder.ts +413 -0
- package/plugins/specweave-github/lib/user-story-issue-builder.js +344 -0
- package/plugins/specweave-github/lib/user-story-issue-builder.ts +543 -0
- package/plugins/specweave-github/skills/github-issue-standard/SKILL.md +189 -0
- package/plugins/specweave-jira/lib/enhanced-jira-sync.js +134 -0
- package/plugins/specweave-jira/lib/{enhanced-jira-sync.ts.disabled → enhanced-jira-sync.ts} +26 -52
- package/plugins/specweave-kafka/.claude-plugin/plugin.json +26 -0
- package/plugins/specweave-kafka/IMPLEMENTATION-COMPLETE.md +483 -0
- package/plugins/specweave-kafka/README.md +242 -0
- package/plugins/specweave-kafka/agents/kafka-architect/AGENT.md +235 -0
- package/plugins/specweave-kafka/agents/kafka-devops/AGENT.md +209 -0
- package/plugins/specweave-kafka/agents/kafka-observability/AGENT.md +266 -0
- package/plugins/specweave-kafka/commands/deploy.md +99 -0
- package/plugins/specweave-kafka/commands/dev-env.md +176 -0
- package/plugins/specweave-kafka/commands/mcp-configure.md +101 -0
- package/plugins/specweave-kafka/commands/monitor-setup.md +96 -0
- package/plugins/specweave-kafka/docker/kafka-local/docker-compose.yml +187 -0
- package/plugins/specweave-kafka/docker/redpanda/docker-compose.yml +199 -0
- package/plugins/specweave-kafka/docker/templates/consumer-nodejs.js +225 -0
- package/plugins/specweave-kafka/docker/templates/consumer-python.py +220 -0
- package/plugins/specweave-kafka/docker/templates/producer-nodejs.js +168 -0
- package/plugins/specweave-kafka/docker/templates/producer-python.py +167 -0
- package/plugins/specweave-kafka/lib/adapters/apache-kafka-adapter.js +438 -0
- package/plugins/specweave-kafka/lib/adapters/apache-kafka-adapter.ts +541 -0
- package/plugins/specweave-kafka/lib/adapters/platform-adapter.js +47 -0
- package/plugins/specweave-kafka/lib/adapters/platform-adapter.ts +343 -0
- package/plugins/specweave-kafka/lib/cli/kcat-wrapper.js +258 -0
- package/plugins/specweave-kafka/lib/cli/kcat-wrapper.ts +298 -0
- package/plugins/specweave-kafka/lib/cli/types.js +10 -0
- package/plugins/specweave-kafka/lib/cli/types.ts +92 -0
- package/plugins/specweave-kafka/lib/connectors/connector-catalog.js +305 -0
- package/plugins/specweave-kafka/lib/connectors/connector-catalog.ts +528 -0
- package/plugins/specweave-kafka/lib/documentation/diagram-generator.js +114 -0
- package/plugins/specweave-kafka/lib/documentation/diagram-generator.ts +195 -0
- package/plugins/specweave-kafka/lib/documentation/exporter.js +210 -0
- package/plugins/specweave-kafka/lib/documentation/exporter.ts +338 -0
- package/plugins/specweave-kafka/lib/documentation/schema-catalog-generator.js +60 -0
- package/plugins/specweave-kafka/lib/documentation/schema-catalog-generator.ts +130 -0
- package/plugins/specweave-kafka/lib/documentation/topology-generator.js +143 -0
- package/plugins/specweave-kafka/lib/documentation/topology-generator.ts +290 -0
- package/plugins/specweave-kafka/lib/mcp/detector.js +298 -0
- package/plugins/specweave-kafka/lib/mcp/detector.ts +352 -0
- package/plugins/specweave-kafka/lib/mcp/types.js +21 -0
- package/plugins/specweave-kafka/lib/mcp/types.ts +77 -0
- package/plugins/specweave-kafka/lib/multi-cluster/cluster-config-manager.js +193 -0
- package/plugins/specweave-kafka/lib/multi-cluster/cluster-config-manager.ts +362 -0
- package/plugins/specweave-kafka/lib/multi-cluster/cluster-switcher.js +188 -0
- package/plugins/specweave-kafka/lib/multi-cluster/cluster-switcher.ts +359 -0
- package/plugins/specweave-kafka/lib/multi-cluster/health-aggregator.js +195 -0
- package/plugins/specweave-kafka/lib/multi-cluster/health-aggregator.ts +380 -0
- package/plugins/specweave-kafka/lib/observability/opentelemetry-kafka.js +209 -0
- package/plugins/specweave-kafka/lib/observability/opentelemetry-kafka.ts +358 -0
- package/plugins/specweave-kafka/lib/patterns/advanced-ksqldb-patterns.js +354 -0
- package/plugins/specweave-kafka/lib/patterns/advanced-ksqldb-patterns.ts +563 -0
- package/plugins/specweave-kafka/lib/patterns/circuit-breaker-resilience.js +259 -0
- package/plugins/specweave-kafka/lib/patterns/circuit-breaker-resilience.ts +516 -0
- package/plugins/specweave-kafka/lib/patterns/dead-letter-queue.js +233 -0
- package/plugins/specweave-kafka/lib/patterns/dead-letter-queue.ts +423 -0
- package/plugins/specweave-kafka/lib/patterns/exactly-once-semantics.js +266 -0
- package/plugins/specweave-kafka/lib/patterns/exactly-once-semantics.ts +445 -0
- package/plugins/specweave-kafka/lib/patterns/flink-kafka-integration.js +312 -0
- package/plugins/specweave-kafka/lib/patterns/flink-kafka-integration.ts +561 -0
- package/plugins/specweave-kafka/lib/patterns/multi-dc-replication.js +289 -0
- package/plugins/specweave-kafka/lib/patterns/multi-dc-replication.ts +607 -0
- package/plugins/specweave-kafka/lib/patterns/rate-limiting-backpressure.js +264 -0
- package/plugins/specweave-kafka/lib/patterns/rate-limiting-backpressure.ts +498 -0
- package/plugins/specweave-kafka/lib/patterns/stream-processing-optimization.js +263 -0
- package/plugins/specweave-kafka/lib/patterns/stream-processing-optimization.ts +549 -0
- package/plugins/specweave-kafka/lib/patterns/tiered-storage-compaction.js +205 -0
- package/plugins/specweave-kafka/lib/patterns/tiered-storage-compaction.ts +399 -0
- package/plugins/specweave-kafka/lib/performance/performance-optimizer.js +249 -0
- package/plugins/specweave-kafka/lib/performance/performance-optimizer.ts +427 -0
- package/plugins/specweave-kafka/lib/security/kafka-security.js +252 -0
- package/plugins/specweave-kafka/lib/security/kafka-security.ts +494 -0
- package/plugins/specweave-kafka/lib/utils/capacity-planner.js +203 -0
- package/plugins/specweave-kafka/lib/utils/capacity-planner.ts +469 -0
- package/plugins/specweave-kafka/lib/utils/config-validator.js +419 -0
- package/plugins/specweave-kafka/lib/utils/config-validator.ts +564 -0
- package/plugins/specweave-kafka/lib/utils/partitioning.js +329 -0
- package/plugins/specweave-kafka/lib/utils/partitioning.ts +473 -0
- package/plugins/specweave-kafka/lib/utils/sizing.js +221 -0
- package/plugins/specweave-kafka/lib/utils/sizing.ts +374 -0
- package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-broker-metrics.json +628 -0
- package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-cluster-overview.json +564 -0
- package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-consumer-lag.json +509 -0
- package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-jvm-metrics.json +674 -0
- package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-topic-metrics.json +578 -0
- package/plugins/specweave-kafka/monitoring/grafana/provisioning/dashboards/kafka.yml +17 -0
- package/plugins/specweave-kafka/monitoring/grafana/provisioning/datasources/prometheus.yml +17 -0
- package/plugins/specweave-kafka/monitoring/prometheus/kafka-alerts.yml +415 -0
- package/plugins/specweave-kafka/monitoring/prometheus/kafka-jmx-exporter.yml +256 -0
- package/plugins/specweave-kafka/package.json +41 -0
- package/plugins/specweave-kafka/skills/kafka-architecture/SKILL.md +647 -0
- package/plugins/specweave-kafka/skills/kafka-cli-tools/SKILL.md +433 -0
- package/plugins/specweave-kafka/skills/kafka-iac-deployment/SKILL.md +449 -0
- package/plugins/specweave-kafka/skills/kafka-kubernetes/SKILL.md +667 -0
- package/plugins/specweave-kafka/skills/kafka-mcp-integration/SKILL.md +273 -0
- package/plugins/specweave-kafka/skills/kafka-observability/SKILL.md +576 -0
- package/plugins/specweave-kafka/templates/config/broker-production.properties +254 -0
- package/plugins/specweave-kafka/templates/config/consumer-low-latency.properties +112 -0
- package/plugins/specweave-kafka/templates/config/producer-high-throughput.properties +120 -0
- package/plugins/specweave-kafka/templates/migration/mirrormaker2-config.properties +234 -0
- package/plugins/specweave-kafka/templates/monitoring/grafana/multi-cluster-dashboard.json +686 -0
- package/plugins/specweave-kafka/terraform/apache-kafka/main.tf +347 -0
- package/plugins/specweave-kafka/terraform/apache-kafka/outputs.tf +107 -0
- package/plugins/specweave-kafka/terraform/apache-kafka/templates/kafka-broker-init.sh.tpl +216 -0
- package/plugins/specweave-kafka/terraform/apache-kafka/variables.tf +156 -0
- package/plugins/specweave-kafka/terraform/aws-msk/main.tf +362 -0
- package/plugins/specweave-kafka/terraform/aws-msk/outputs.tf +93 -0
- package/plugins/specweave-kafka/terraform/aws-msk/templates/server.properties.tpl +32 -0
- package/plugins/specweave-kafka/terraform/aws-msk/variables.tf +235 -0
- package/plugins/specweave-kafka/terraform/azure-event-hubs/main.tf +281 -0
- package/plugins/specweave-kafka/terraform/azure-event-hubs/outputs.tf +118 -0
- package/plugins/specweave-kafka/terraform/azure-event-hubs/variables.tf +148 -0
- package/plugins/specweave-kafka/tsconfig.json +21 -0
- package/plugins/specweave-kafka-streams/.claude-plugin/plugin.json +23 -0
- package/plugins/specweave-kafka-streams/README.md +310 -0
- package/plugins/specweave-kafka-streams/skills/kafka-streams-topology/SKILL.md +539 -0
- package/plugins/specweave-n8n/.claude-plugin/plugin.json +22 -0
- package/plugins/specweave-n8n/README.md +354 -0
- package/plugins/specweave-n8n/skills/n8n-kafka-workflows/SKILL.md +504 -0
- package/plugins/specweave-release/commands/specweave-release-platform.md +1 -1
- package/plugins/specweave-release/hooks/post-task-completion.sh +2 -2
- package/src/templates/AGENTS.md.template +601 -7
- package/src/templates/CLAUDE.md.template +188 -88
- package/plugins/specweave-ado/commands/specweave-ado-sync-spec.md +0 -255
- package/plugins/specweave-github/commands/specweave-github-sync-epic.md +0 -248
- package/plugins/specweave-github/commands/specweave-github-sync-from.md +0 -147
- package/plugins/specweave-github/commands/specweave-github-sync-spec.md +0 -208
- package/plugins/specweave-github/commands/specweave-github-sync-tasks.md +0 -530
- package/plugins/specweave-jira/commands/specweave-jira-sync-epic.md +0 -267
- package/plugins/specweave-jira/commands/specweave-jira-sync-spec.md +0 -240
|
@@ -1,530 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: specweave-github:sync-tasks
|
|
3
|
-
description: Sync SpecWeave increment tasks to GitHub issues (task-level granularity). Creates milestone, epic issue, and individual issues for each task.
|
|
4
|
-
---
|
|
5
|
-
|
|
6
|
-
# Sync Tasks to GitHub
|
|
7
|
-
|
|
8
|
-
**Purpose**: Create or update GitHub issues for all tasks in a SpecWeave increment. Each task becomes a separate GitHub issue linked to an epic.
|
|
9
|
-
|
|
10
|
-
**When to Use**:
|
|
11
|
-
- After creating a new increment (sync all tasks at once)
|
|
12
|
-
- To create GitHub visibility for team collaboration
|
|
13
|
-
- When you need granular task assignment and tracking
|
|
14
|
-
- For GitHub Projects / Kanban board integration
|
|
15
|
-
|
|
16
|
-
---
|
|
17
|
-
|
|
18
|
-
## Usage
|
|
19
|
-
|
|
20
|
-
```bash
|
|
21
|
-
/specweave:github:sync-tasks <increment-id> [options]
|
|
22
|
-
```
|
|
23
|
-
|
|
24
|
-
## Arguments
|
|
25
|
-
|
|
26
|
-
- `increment-id` - The increment ID (e.g., `0004` or `0004-plugin-architecture`)
|
|
27
|
-
|
|
28
|
-
## Options
|
|
29
|
-
|
|
30
|
-
- `--force` - Overwrite existing issues (⚠️ WARNING: creates duplicates!)
|
|
31
|
-
- `--dry-run` - Show what would be created without actually creating issues
|
|
32
|
-
- `--batch-size <N>` - Number of issues per batch (default: 10)
|
|
33
|
-
- `--batch-delay <ms>` - Delay between batches in milliseconds (default: 6000)
|
|
34
|
-
- `--milestone-days <N>` - Days until milestone due (default: 2 - SpecWeave AI velocity)
|
|
35
|
-
- `--fast-mode` - Skip rate limiting (auto-enabled for < 10 tasks)
|
|
36
|
-
- `--project <name>` - Add issues to GitHub Project (e.g., "SpecWeave v0.4.0") [TODO]
|
|
37
|
-
|
|
38
|
-
---
|
|
39
|
-
|
|
40
|
-
## Examples
|
|
41
|
-
|
|
42
|
-
### Basic Sync (Recommended)
|
|
43
|
-
|
|
44
|
-
```bash
|
|
45
|
-
/specweave:github:sync-tasks 0004
|
|
46
|
-
```
|
|
47
|
-
|
|
48
|
-
**Output**:
|
|
49
|
-
```
|
|
50
|
-
🔄 Syncing increment to GitHub...
|
|
51
|
-
📦 Increment: 0004-plugin-architecture - Plugin Architecture
|
|
52
|
-
📋 Found 54 tasks
|
|
53
|
-
|
|
54
|
-
📍 Creating milestone: v0.4.0
|
|
55
|
-
✅ Milestone #1: v0.4.0
|
|
56
|
-
|
|
57
|
-
🎯 Creating epic issue for increment 0004-plugin-architecture...
|
|
58
|
-
✅ Epic issue #42: https://github.com/owner/repo/issues/42
|
|
59
|
-
|
|
60
|
-
📝 Creating 54 task issues...
|
|
61
|
-
Creating issues 1-10 of 54...
|
|
62
|
-
✅ #43: [T-001] Create plugin type definitions
|
|
63
|
-
✅ #44: [T-002] Create plugin manifest schema
|
|
64
|
-
...
|
|
65
|
-
Waiting 6s to avoid rate limits...
|
|
66
|
-
Creating issues 11-20 of 54...
|
|
67
|
-
✅ #53: [T-011] Create config schema
|
|
68
|
-
...
|
|
69
|
-
|
|
70
|
-
📄 Updating tasks.md with GitHub issue numbers...
|
|
71
|
-
✅ Updated tasks.md
|
|
72
|
-
|
|
73
|
-
💾 Saving sync mapping...
|
|
74
|
-
✅ Saved to .github-sync.yaml
|
|
75
|
-
|
|
76
|
-
🎉 GitHub sync complete!
|
|
77
|
-
📍 Milestone: #1 v0.4.0
|
|
78
|
-
🎯 Epic: #42 https://github.com/owner/repo/issues/42
|
|
79
|
-
📝 Tasks: #43-#96 (54 issues)
|
|
80
|
-
```
|
|
81
|
-
|
|
82
|
-
### Dry Run (Preview)
|
|
83
|
-
|
|
84
|
-
```bash
|
|
85
|
-
/specweave:github:sync-tasks 0004 --dry-run
|
|
86
|
-
```
|
|
87
|
-
|
|
88
|
-
Shows what would be created without actually creating anything.
|
|
89
|
-
|
|
90
|
-
### Force Re-Sync
|
|
91
|
-
|
|
92
|
-
```bash
|
|
93
|
-
/specweave:github:sync-tasks 0004 --force
|
|
94
|
-
```
|
|
95
|
-
|
|
96
|
-
⚠️ **WARNING**: This will create duplicate issues! Only use if you know what you're doing.
|
|
97
|
-
|
|
98
|
-
### Custom Rate Limiting
|
|
99
|
-
|
|
100
|
-
```bash
|
|
101
|
-
/specweave:github:sync-tasks 0004 --batch-size 5 --batch-delay 10000
|
|
102
|
-
```
|
|
103
|
-
|
|
104
|
-
Creates 5 issues at a time with 10 second delays (slower, safer for rate limits).
|
|
105
|
-
|
|
106
|
-
### Custom Milestone Timeline
|
|
107
|
-
|
|
108
|
-
```bash
|
|
109
|
-
# 1-day sprint (aggressive AI velocity)
|
|
110
|
-
/specweave:github:sync-tasks 0004 --milestone-days 1
|
|
111
|
-
|
|
112
|
-
# 7-day sprint (traditional scrum)
|
|
113
|
-
/specweave:github:sync-tasks 0004 --milestone-days 7
|
|
114
|
-
```
|
|
115
|
-
|
|
116
|
-
**SpecWeave Default**: 2 days (assumes AI-assisted development)
|
|
117
|
-
**Rationale**: With Claude Code + SpecWeave, 54 tasks = 1-2 days (not weeks!)
|
|
118
|
-
|
|
119
|
-
### Fast Mode (No Rate Limiting)
|
|
120
|
-
|
|
121
|
-
```bash
|
|
122
|
-
/specweave:github:sync-tasks 0004 --fast-mode
|
|
123
|
-
```
|
|
124
|
-
|
|
125
|
-
Skips all delays between issue creation. **Auto-enabled** for increments < 10 tasks.
|
|
126
|
-
|
|
127
|
-
---
|
|
128
|
-
|
|
129
|
-
## What Gets Created
|
|
130
|
-
|
|
131
|
-
### 1. GitHub Milestone
|
|
132
|
-
|
|
133
|
-
**Title**: Based on increment version or ID
|
|
134
|
-
**Example**: `v0.4.0` or `Increment 0004-plugin-architecture`
|
|
135
|
-
**Description**: Auto-generated summary
|
|
136
|
-
|
|
137
|
-
### 2. Epic Issue (Increment-Level)
|
|
138
|
-
|
|
139
|
-
**Title**: `[INC-####] Increment Title`
|
|
140
|
-
**Example**: `[INC-0004] Plugin Architecture`
|
|
141
|
-
**Labels**: `increment`, `specweave`, priority (`p0`/`p1`/`p2`/`p3`)
|
|
142
|
-
**Body**:
|
|
143
|
-
- Executive summary from `spec.md`
|
|
144
|
-
- Task checklist (all tasks grouped by phase)
|
|
145
|
-
- Links to spec, plan, tasks files
|
|
146
|
-
|
|
147
|
-
### 3. Task Issues (One Per Task)
|
|
148
|
-
|
|
149
|
-
**Title**: `[T-###] Task Title`
|
|
150
|
-
**Example**: `[T-001] Create plugin type definitions`
|
|
151
|
-
**Labels**: `task`, priority, phase slug
|
|
152
|
-
**Body**:
|
|
153
|
-
- Link to epic issue (`Part of #42`)
|
|
154
|
-
- Priority, estimate, phase
|
|
155
|
-
- Description
|
|
156
|
-
- Subtasks (as checkboxes)
|
|
157
|
-
- Files to create/modify
|
|
158
|
-
- Implementation snippets
|
|
159
|
-
- Acceptance criteria
|
|
160
|
-
- Dependencies (links to other task issues)
|
|
161
|
-
- Blocks (tasks waiting on this)
|
|
162
|
-
|
|
163
|
-
**Example Task Issue**:
|
|
164
|
-
```markdown
|
|
165
|
-
# [T-001] Create Plugin Type Definitions
|
|
166
|
-
|
|
167
|
-
**Part of**: #42 (Increment 0004 - Plugin Architecture)
|
|
168
|
-
**Priority**: P0
|
|
169
|
-
**Estimate**: 2 hours
|
|
170
|
-
**Phase**: Phase 1: Foundation
|
|
171
|
-
|
|
172
|
-
## Description
|
|
173
|
-
|
|
174
|
-
Create TypeScript interfaces and types for plugin system.
|
|
175
|
-
|
|
176
|
-
## Subtasks
|
|
177
|
-
|
|
178
|
-
- [ ] S-001-01: Define PluginManifest interface (30min)
|
|
179
|
-
- [ ] S-001-02: Define Plugin interface (30min)
|
|
180
|
-
- [ ] S-001-03: Define Skill, Agent, Command types (45min)
|
|
181
|
-
- [ ] S-001-04: Add JSDoc documentation (15min)
|
|
182
|
-
|
|
183
|
-
## Files to Create
|
|
184
|
-
|
|
185
|
-
- `src/core/types/plugin.ts`
|
|
186
|
-
|
|
187
|
-
## Acceptance Criteria
|
|
188
|
-
|
|
189
|
-
- ✅ All interfaces defined
|
|
190
|
-
- ✅ TypeScript compiles without errors
|
|
191
|
-
- ✅ JSDoc on all exports
|
|
192
|
-
- ✅ Unit tests pass
|
|
193
|
-
|
|
194
|
-
## Dependencies
|
|
195
|
-
|
|
196
|
-
None (foundation task)
|
|
197
|
-
|
|
198
|
-
## Blocks
|
|
199
|
-
|
|
200
|
-
- T-003 (PluginLoader needs types)
|
|
201
|
-
- T-004 (PluginManager needs types)
|
|
202
|
-
|
|
203
|
-
---
|
|
204
|
-
🤖 Synced from SpecWeave increment `0004-plugin-architecture`
|
|
205
|
-
- **Tasks**: [`tasks.md`](link)
|
|
206
|
-
```
|
|
207
|
-
|
|
208
|
-
---
|
|
209
|
-
|
|
210
|
-
## Workflow
|
|
211
|
-
|
|
212
|
-
### Step 1: Parse tasks.md
|
|
213
|
-
|
|
214
|
-
Reads and parses `.specweave/increments/####/tasks.md` to extract:
|
|
215
|
-
- Task ID, title, description
|
|
216
|
-
- Priority, estimate, status
|
|
217
|
-
- Subtasks (with IDs and estimates)
|
|
218
|
-
- Dependencies and blocks
|
|
219
|
-
- Files to create/modify
|
|
220
|
-
- Acceptance criteria
|
|
221
|
-
- Phase grouping
|
|
222
|
-
|
|
223
|
-
### Step 2: Create Milestone
|
|
224
|
-
|
|
225
|
-
Creates or retrieves existing milestone:
|
|
226
|
-
- Title: `v{version}` or `Increment {id}`
|
|
227
|
-
- Description: Auto-generated
|
|
228
|
-
- State: `open`
|
|
229
|
-
|
|
230
|
-
### Step 3: Create Epic Issue
|
|
231
|
-
|
|
232
|
-
Creates increment-level epic issue:
|
|
233
|
-
- Contains executive summary from `spec.md`
|
|
234
|
-
- Shows all tasks as checkboxes (grouped by phase)
|
|
235
|
-
- Links to increment files (spec, plan, tasks)
|
|
236
|
-
- Labels: `increment`, `specweave`, priority
|
|
237
|
-
|
|
238
|
-
### Step 4: Create Task Issues (Batched)
|
|
239
|
-
|
|
240
|
-
Creates individual issues for each task:
|
|
241
|
-
- Batch size: 10 issues per batch (configurable)
|
|
242
|
-
- Delay: 6 seconds between batches (configurable)
|
|
243
|
-
- Rate limit awareness: Checks GitHub rate limit before each batch
|
|
244
|
-
- Each issue links back to epic via `Part of #42`
|
|
245
|
-
|
|
246
|
-
### Step 5: Link Dependencies
|
|
247
|
-
|
|
248
|
-
For tasks with dependencies or blocks:
|
|
249
|
-
- Adds "Depends on" links to dependency task issues
|
|
250
|
-
- Adds "Blocks" links to blocked task issues
|
|
251
|
-
- GitHub shows these as issue references
|
|
252
|
-
|
|
253
|
-
### Step 6: Update tasks.md
|
|
254
|
-
|
|
255
|
-
Updates each task in `tasks.md` with:
|
|
256
|
-
- `**GitHub Issue**: #NNN` field
|
|
257
|
-
- Preserves all other task content
|
|
258
|
-
|
|
259
|
-
**Before**:
|
|
260
|
-
```markdown
|
|
261
|
-
### T-001: Create Plugin Type Definitions
|
|
262
|
-
**Priority**: P0
|
|
263
|
-
**Estimate**: 2 hours
|
|
264
|
-
**Status**: pending
|
|
265
|
-
|
|
266
|
-
**Description**:
|
|
267
|
-
...
|
|
268
|
-
```
|
|
269
|
-
|
|
270
|
-
**After**:
|
|
271
|
-
```markdown
|
|
272
|
-
### T-001: Create Plugin Type Definitions
|
|
273
|
-
**Priority**: P0
|
|
274
|
-
**Estimate**: 2 hours
|
|
275
|
-
**Status**: pending
|
|
276
|
-
**GitHub Issue**: #43
|
|
277
|
-
|
|
278
|
-
**Description**:
|
|
279
|
-
...
|
|
280
|
-
```
|
|
281
|
-
|
|
282
|
-
### Step 7: Save Sync Mapping
|
|
283
|
-
|
|
284
|
-
Creates `.specweave/increments/####/.github-sync.yaml`:
|
|
285
|
-
```yaml
|
|
286
|
-
milestone: 1
|
|
287
|
-
epic_issue: 42
|
|
288
|
-
task_issues:
|
|
289
|
-
T-001: 43
|
|
290
|
-
T-002: 44
|
|
291
|
-
T-003: 45
|
|
292
|
-
# ... all tasks
|
|
293
|
-
last_sync: '2025-11-01T10:30:00.000Z'
|
|
294
|
-
```
|
|
295
|
-
|
|
296
|
-
---
|
|
297
|
-
|
|
298
|
-
## Prerequisites
|
|
299
|
-
|
|
300
|
-
### 1. GitHub CLI Installed
|
|
301
|
-
|
|
302
|
-
```bash
|
|
303
|
-
# macOS
|
|
304
|
-
brew install gh
|
|
305
|
-
|
|
306
|
-
# Ubuntu/Debian
|
|
307
|
-
sudo apt install gh
|
|
308
|
-
|
|
309
|
-
# Windows
|
|
310
|
-
choco install gh
|
|
311
|
-
```
|
|
312
|
-
|
|
313
|
-
### 2. GitHub CLI Authenticated
|
|
314
|
-
|
|
315
|
-
```bash
|
|
316
|
-
gh auth login
|
|
317
|
-
```
|
|
318
|
-
|
|
319
|
-
Follow prompts to authenticate with your GitHub account.
|
|
320
|
-
|
|
321
|
-
### 3. Git Repository with GitHub Remote
|
|
322
|
-
|
|
323
|
-
```bash
|
|
324
|
-
git remote get-url origin
|
|
325
|
-
# Should output: git@github.com:owner/repo.git
|
|
326
|
-
```
|
|
327
|
-
|
|
328
|
-
### 4. Permissions
|
|
329
|
-
|
|
330
|
-
You need **write access** to the repository to create issues and milestones.
|
|
331
|
-
|
|
332
|
-
---
|
|
333
|
-
|
|
334
|
-
## Error Handling
|
|
335
|
-
|
|
336
|
-
### Rate Limiting
|
|
337
|
-
|
|
338
|
-
GitHub API has rate limits (5000 requests/hour for authenticated users).
|
|
339
|
-
|
|
340
|
-
**Automatic Handling**:
|
|
341
|
-
- Batches issues (10 per batch by default)
|
|
342
|
-
- Delays between batches (6 seconds default)
|
|
343
|
-
- Checks rate limit before proceeding
|
|
344
|
-
- Fails gracefully if rate limit exceeded
|
|
345
|
-
|
|
346
|
-
**If Rate Limited**:
|
|
347
|
-
```
|
|
348
|
-
❌ Sync failed: Rate limit exceeded. Try again in X minutes.
|
|
349
|
-
```
|
|
350
|
-
|
|
351
|
-
**Solution**: Wait or adjust batch settings:
|
|
352
|
-
```bash
|
|
353
|
-
/specweave:github:sync-tasks 0004 --batch-size 5 --batch-delay 12000
|
|
354
|
-
```
|
|
355
|
-
|
|
356
|
-
### Duplicate Issues
|
|
357
|
-
|
|
358
|
-
If you run sync twice without `--force`, you'll see:
|
|
359
|
-
```
|
|
360
|
-
⚠️ Increment already synced to GitHub (epic #42)
|
|
361
|
-
Use --force to re-sync (WARNING: will create duplicate issues)
|
|
362
|
-
```
|
|
363
|
-
|
|
364
|
-
**Solution**: Only use `--force` if you truly want duplicates (e.g., testing).
|
|
365
|
-
|
|
366
|
-
### Network Errors
|
|
367
|
-
|
|
368
|
-
If GitHub is unreachable:
|
|
369
|
-
```
|
|
370
|
-
❌ Sync failed: Failed to create epic issue: network timeout
|
|
371
|
-
```
|
|
372
|
-
|
|
373
|
-
**Solution**: Check internet connection, retry.
|
|
374
|
-
|
|
375
|
-
### Authentication Errors
|
|
376
|
-
|
|
377
|
-
If not authenticated:
|
|
378
|
-
```
|
|
379
|
-
❌ Sync failed: GitHub CLI not authenticated. Run: gh auth login
|
|
380
|
-
```
|
|
381
|
-
|
|
382
|
-
**Solution**: Run `gh auth login`.
|
|
383
|
-
|
|
384
|
-
---
|
|
385
|
-
|
|
386
|
-
## Integration with Workflow
|
|
387
|
-
|
|
388
|
-
### After Creating Increment
|
|
389
|
-
|
|
390
|
-
```bash
|
|
391
|
-
# 1. Create increment
|
|
392
|
-
/specweave:inc "0005-user-authentication"
|
|
393
|
-
|
|
394
|
-
# PM agent generates: spec.md, plan.md, tasks.md, tests.md
|
|
395
|
-
|
|
396
|
-
# 2. Review and approve
|
|
397
|
-
|
|
398
|
-
# 3. Sync to GitHub
|
|
399
|
-
/specweave:github:sync-tasks 0005
|
|
400
|
-
|
|
401
|
-
# Now team can see all tasks in GitHub!
|
|
402
|
-
```
|
|
403
|
-
|
|
404
|
-
### During Development
|
|
405
|
-
|
|
406
|
-
```bash
|
|
407
|
-
# Tasks are completed via /specweave:do
|
|
408
|
-
/specweave:do
|
|
409
|
-
|
|
410
|
-
# Automatically:
|
|
411
|
-
# - Closes task GitHub issue
|
|
412
|
-
# - Checks off task in epic
|
|
413
|
-
# - Posts completion comment
|
|
414
|
-
# - Updates epic progress
|
|
415
|
-
```
|
|
416
|
-
|
|
417
|
-
### Team Collaboration
|
|
418
|
-
|
|
419
|
-
**On GitHub**:
|
|
420
|
-
- Team members assign themselves to task issues
|
|
421
|
-
- Discuss implementation in issue comments
|
|
422
|
-
- Link pull requests to task issues
|
|
423
|
-
- Track progress in GitHub Projects (Kanban)
|
|
424
|
-
|
|
425
|
-
**In SpecWeave**:
|
|
426
|
-
- Developer works locally with `/specweave:do`
|
|
427
|
-
- Progress automatically syncs to GitHub
|
|
428
|
-
- Team sees real-time updates
|
|
429
|
-
|
|
430
|
-
---
|
|
431
|
-
|
|
432
|
-
## Advanced Usage
|
|
433
|
-
|
|
434
|
-
### Selective Task Sync
|
|
435
|
-
|
|
436
|
-
Currently syncs all tasks. For selective sync, manually create issues:
|
|
437
|
-
```bash
|
|
438
|
-
/specweave:github:create-issue 0004 T-001
|
|
439
|
-
```
|
|
440
|
-
|
|
441
|
-
### Multi-Repo Projects
|
|
442
|
-
|
|
443
|
-
For monorepos with multiple GitHub repositories, each increment can specify repo:
|
|
444
|
-
```yaml
|
|
445
|
-
# .specweave/config.yaml
|
|
446
|
-
plugins:
|
|
447
|
-
settings:
|
|
448
|
-
specweave-github:
|
|
449
|
-
repo: "org/frontend" # Override auto-detected repo
|
|
450
|
-
```
|
|
451
|
-
|
|
452
|
-
### Custom Labels
|
|
453
|
-
|
|
454
|
-
Edit labels after sync in GitHub or pre-configure in plugin settings:
|
|
455
|
-
```yaml
|
|
456
|
-
plugins:
|
|
457
|
-
settings:
|
|
458
|
-
specweave-github:
|
|
459
|
-
default_labels:
|
|
460
|
-
- "specweave"
|
|
461
|
-
- "increment"
|
|
462
|
-
priority_labels:
|
|
463
|
-
P0: "critical"
|
|
464
|
-
P1: "high"
|
|
465
|
-
P2: "medium"
|
|
466
|
-
P3: "low"
|
|
467
|
-
```
|
|
468
|
-
|
|
469
|
-
---
|
|
470
|
-
|
|
471
|
-
## Troubleshooting
|
|
472
|
-
|
|
473
|
-
### "Could not detect GitHub repository"
|
|
474
|
-
|
|
475
|
-
**Problem**: Not in a git repo or no GitHub remote.
|
|
476
|
-
|
|
477
|
-
**Solution**:
|
|
478
|
-
```bash
|
|
479
|
-
# Check remote
|
|
480
|
-
git remote get-url origin
|
|
481
|
-
|
|
482
|
-
# Add remote if missing
|
|
483
|
-
git remote add origin git@github.com:owner/repo.git
|
|
484
|
-
```
|
|
485
|
-
|
|
486
|
-
### "GitHub CLI not installed"
|
|
487
|
-
|
|
488
|
-
**Solution**: Install `gh` CLI (see Prerequisites).
|
|
489
|
-
|
|
490
|
-
### "Permission denied"
|
|
491
|
-
|
|
492
|
-
**Problem**: No write access to repository.
|
|
493
|
-
|
|
494
|
-
**Solution**: Request write access from repository owner or use repository you own.
|
|
495
|
-
|
|
496
|
-
### Tasks.md Parse Errors
|
|
497
|
-
|
|
498
|
-
**Problem**: tasks.md format doesn't match expected structure.
|
|
499
|
-
|
|
500
|
-
**Solution**: Ensure tasks.md follows template format. Check for:
|
|
501
|
-
- Task headers: `### T-XXX: Title`
|
|
502
|
-
- Required fields: `**Priority**`, `**Estimate**`, `**Status**`
|
|
503
|
-
- Proper markdown formatting
|
|
504
|
-
|
|
505
|
-
---
|
|
506
|
-
|
|
507
|
-
## See Also
|
|
508
|
-
|
|
509
|
-
- `/specweave:github:create-issue` - Create issue for single task
|
|
510
|
-
- `/specweave:github:sync` - Sync increment metadata only
|
|
511
|
-
- `/specweave:github:status` - Check sync status
|
|
512
|
-
- `/specweave:github:close-issue` - Close task issue
|
|
513
|
-
|
|
514
|
-
---
|
|
515
|
-
|
|
516
|
-
**Pro Tip**: Run with `--dry-run` first to preview what will be created!
|
|
517
|
-
|
|
518
|
-
```bash
|
|
519
|
-
/specweave:github:sync-tasks 0004 --dry-run
|
|
520
|
-
```
|
|
521
|
-
|
|
522
|
-
Then run for real:
|
|
523
|
-
|
|
524
|
-
```bash
|
|
525
|
-
/specweave:github:sync-tasks 0004
|
|
526
|
-
```
|
|
527
|
-
|
|
528
|
-
---
|
|
529
|
-
|
|
530
|
-
🤖 **SpecWeave GitHub Plugin** - Task-level sync for better team collaboration
|