specweave 1.0.506 → 1.0.508
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-plugin/README.md +25 -32
- package/.claude-plugin/marketplace.json +1 -78
- package/dist/plugins/specweave/lib/features/release/dashboard-generator.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/features/release/dashboard-generator.js.map +1 -0
- package/dist/plugins/specweave/lib/features/release/dora-tracker.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/features/release/dora-tracker.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-ac-checkbox-sync.d.ts +44 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-ac-checkbox-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-ac-checkbox-sync.js +236 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-ac-checkbox-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-board-resolver.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-board-resolver.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-client-v2.d.ts +139 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-client-v2.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-client-v2.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-client.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-client.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-duplicate-detector.d.ts +100 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-duplicate-detector.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-duplicate-detector.js +292 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-duplicate-detector.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-permission-gate.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-permission-gate.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-profile-resolver.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-profile-resolver.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-pull-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-pull-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-rate-limiter.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-rate-limiter.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-spec-commit-sync.d.ts +38 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-spec-commit-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-spec-commit-sync.js +210 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-spec-commit-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-spec-content-sync.d.ts +28 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-spec-content-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-spec-content-sync.js +300 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-spec-content-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-spec-sync.d.ts +147 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-spec-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-spec-sync.js +749 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-spec-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-status-sync.d.ts +79 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-status-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-status-sync.js +162 -0
- package/dist/plugins/specweave/lib/integrations/ado/ado-status-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/conflict-resolver.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/conflict-resolver.js +439 -0
- package/dist/plugins/specweave/lib/integrations/ado/conflict-resolver.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/per-us-sync.d.ts +131 -0
- package/dist/plugins/specweave/lib/integrations/ado/per-us-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/ado/per-us-sync.js +322 -0
- package/dist/plugins/specweave/lib/integrations/ado/per-us-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/CodeValidator.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/CodeValidator.js +219 -0
- package/dist/plugins/specweave/lib/integrations/github/CodeValidator.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/IssueStateManager.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/IssueStateManager.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/completion-calculator.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/completion-calculator.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/duplicate-detector.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/duplicate-detector.js +423 -0
- package/dist/plugins/specweave/lib/integrations/github/duplicate-detector.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-ac-checkbox-sync.d.ts +54 -0
- package/dist/plugins/specweave/lib/integrations/github/github-ac-checkbox-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-ac-checkbox-sync.js +305 -0
- package/dist/plugins/specweave/lib/integrations/github/github-ac-checkbox-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-ac-comment-poster.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-ac-comment-poster.js +232 -0
- package/dist/plugins/specweave/lib/integrations/github/github-ac-comment-poster.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-batch-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-batch-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-board-resolver-v2.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-board-resolver-v2.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-client-v2.d.ts +214 -0
- package/dist/plugins/specweave/lib/integrations/github/github-client-v2.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-client-v2.js +812 -0
- package/dist/plugins/specweave/lib/integrations/github/github-client-v2.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-client.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-client.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-conflict-resolver.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-conflict-resolver.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-cross-repo-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-cross-repo-sync.js +172 -0
- package/dist/plugins/specweave/lib/integrations/github/github-cross-repo-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-feature-sync-cli.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-feature-sync-cli.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-feature-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-feature-sync.js +1112 -0
- package/dist/plugins/specweave/lib/integrations/github/github-feature-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-field-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-field-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-graphql-client.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-graphql-client.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-issue-body-generator.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-issue-body-generator.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-issue-body-parser.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-issue-body-parser.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-issue-updater.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-issue-updater.js +339 -0
- package/dist/plugins/specweave/lib/integrations/github/github-issue-updater.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-pull-sync.d.ts +94 -0
- package/dist/plugins/specweave/lib/integrations/github/github-pull-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-pull-sync.js +232 -0
- package/dist/plugins/specweave/lib/integrations/github/github-pull-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-push-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-push-sync.js +127 -0
- package/dist/plugins/specweave/lib/integrations/github/github-push-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-rate-limiter.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-rate-limiter.js +109 -0
- package/dist/plugins/specweave/lib/integrations/github/github-rate-limiter.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-spec-commit-sync.d.ts +37 -0
- package/dist/plugins/specweave/lib/integrations/github/github-spec-commit-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-spec-commit-sync.js +209 -0
- package/dist/plugins/specweave/lib/integrations/github/github-spec-commit-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-spec-content-sync.d.ts +28 -0
- package/dist/plugins/specweave/lib/integrations/github/github-spec-content-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-spec-content-sync.js +365 -0
- package/dist/plugins/specweave/lib/integrations/github/github-spec-content-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-spec-frontmatter-updater.d.ts +21 -0
- package/dist/plugins/specweave/lib/integrations/github/github-spec-frontmatter-updater.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-spec-frontmatter-updater.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-spec-sync.d.ts +225 -0
- package/dist/plugins/specweave/lib/integrations/github/github-spec-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-spec-sync.js +974 -0
- package/dist/plugins/specweave/lib/integrations/github/github-spec-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-sync-orchestrator.d.ts +47 -0
- package/dist/plugins/specweave/lib/integrations/github/github-sync-orchestrator.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-sync-orchestrator.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-us-auto-closer.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/github-us-auto-closer.js +219 -0
- package/dist/plugins/specweave/lib/integrations/github/github-us-auto-closer.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/index.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/index.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/per-us-sync.d.ts +126 -0
- package/dist/plugins/specweave/lib/integrations/github/per-us-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/per-us-sync.js +394 -0
- package/dist/plugins/specweave/lib/integrations/github/per-us-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/progress-comment-builder.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/progress-comment-builder.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/types.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/types.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/user-story-content-builder.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/user-story-content-builder.js +310 -0
- package/dist/plugins/specweave/lib/integrations/github/user-story-content-builder.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/user-story-issue-builder.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/github/user-story-issue-builder.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/content-format-adapter.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/content-format-adapter.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-ac-checkbox-sync.d.ts +47 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-ac-checkbox-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-ac-checkbox-sync.js +307 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-ac-checkbox-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-board-resolver.d.ts +50 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-board-resolver.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-board-resolver.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-deployment-detector.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-deployment-detector.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-duplicate-detector.d.ts +103 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-duplicate-detector.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-duplicate-detector.js +295 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-duplicate-detector.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-epic-sync.d.ts +67 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-epic-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-epic-sync.js +286 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-epic-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-field-discovery.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-field-discovery.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-paginated-search.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-paginated-search.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-permission-gate.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-permission-gate.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-spec-commit-sync.d.ts +43 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-spec-commit-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-spec-commit-sync.js +284 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-spec-commit-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-spec-content-sync.d.ts +33 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-spec-content-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-spec-content-sync.js +294 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-spec-content-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-spec-sync.d.ts +180 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-spec-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-spec-sync.js +757 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-spec-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-status-sync.d.ts +116 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-status-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-status-sync.js +302 -0
- package/dist/plugins/specweave/lib/integrations/jira/jira-status-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/metadata-paths.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/metadata-paths.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/per-us-sync.d.ts +117 -0
- package/dist/plugins/specweave/lib/integrations/jira/per-us-sync.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/per-us-sync.js +274 -0
- package/dist/plugins/specweave/lib/integrations/jira/per-us-sync.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/reorganization-detector.d.ts +80 -0
- package/dist/plugins/specweave/lib/integrations/jira/reorganization-detector.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/reorganization-detector.js.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/setup-wizard.d.ts +29 -0
- package/dist/plugins/specweave/lib/integrations/jira/setup-wizard.d.ts.map +1 -0
- package/dist/plugins/specweave/lib/integrations/jira/setup-wizard.js +198 -0
- package/dist/plugins/specweave/lib/integrations/jira/setup-wizard.js.map +1 -0
- package/dist/plugins/specweave/lib/vendor/sync/github-reconciler.d.ts +1 -1
- package/dist/plugins/specweave/lib/vendor/sync/github-reconciler.js +2 -2
- package/dist/plugins/specweave/lib/vendor/sync/github-reconciler.js.map +1 -1
- package/dist/src/cli/commands/refresh-plugins.d.ts.map +1 -1
- package/dist/src/cli/commands/refresh-plugins.js +9 -1
- package/dist/src/cli/commands/refresh-plugins.js.map +1 -1
- package/dist/src/cli/commands/sync-progress.js +1 -1
- package/dist/src/cli/commands/sync-progress.js.map +1 -1
- package/dist/src/cli/helpers/async-project-loader.js +1 -1
- package/dist/src/cli/helpers/async-project-loader.js.map +1 -1
- package/dist/src/cli/helpers/cancelation-handler.d.ts +1 -1
- package/dist/src/cli/helpers/cancelation-handler.js +1 -1
- package/dist/src/cli/helpers/init/ado-repo-cloning.js +1 -1
- package/dist/src/cli/helpers/init/ado-repo-cloning.js.map +1 -1
- package/dist/src/cli/helpers/init/github-repo-cloning.js +1 -1
- package/dist/src/cli/helpers/init/github-repo-cloning.js.map +1 -1
- package/dist/src/cli/helpers/init/jira-ado-auto-detect.d.ts +2 -2
- package/dist/src/cli/helpers/init/jira-ado-auto-detect.d.ts.map +1 -1
- package/dist/src/cli/helpers/init/jira-ado-auto-detect.js +2 -2
- package/dist/src/cli/helpers/init/jira-ado-auto-detect.js.map +1 -1
- package/dist/src/cli/helpers/init/plugin-installer.d.ts.map +1 -1
- package/dist/src/cli/helpers/init/plugin-installer.js +11 -3
- package/dist/src/cli/helpers/init/plugin-installer.js.map +1 -1
- package/dist/src/cli/helpers/issue-tracker/ado-area-selection.js +1 -1
- package/dist/src/cli/helpers/issue-tracker/ado-area-selection.js.map +1 -1
- package/dist/src/cli/helpers/issue-tracker/ado.js +3 -3
- package/dist/src/cli/helpers/issue-tracker/ado.js.map +1 -1
- package/dist/src/cli/helpers/issue-tracker/github-multi-repo.js +1 -1
- package/dist/src/cli/helpers/issue-tracker/github-multi-repo.js.map +1 -1
- package/dist/src/cli/helpers/issue-tracker/github.js +4 -4
- package/dist/src/cli/helpers/issue-tracker/github.js.map +1 -1
- package/dist/src/cli/helpers/issue-tracker/index.js +1 -1
- package/dist/src/cli/helpers/issue-tracker/index.js.map +1 -1
- package/dist/src/cli/helpers/issue-tracker/jira-board-selection.js +1 -1
- package/dist/src/cli/helpers/issue-tracker/jira-board-selection.js.map +1 -1
- package/dist/src/core/ac-progress-sync.js +5 -5
- package/dist/src/core/ac-progress-sync.js.map +1 -1
- package/dist/src/core/analytics/types.d.ts +1 -1
- package/dist/src/core/analytics/types.d.ts.map +1 -1
- package/dist/src/core/config/types.d.ts +1 -1
- package/dist/src/core/hooks/github-project-sync.js +4 -4
- package/dist/src/core/hooks/github-project-sync.js.map +1 -1
- package/dist/src/core/living-docs/living-docs-sync.js +5 -5
- package/dist/src/core/living-docs/living-docs-sync.js.map +1 -1
- package/dist/src/core/types/plugin.d.ts +1 -1
- package/dist/src/core/types/plugin.d.ts.map +1 -1
- package/dist/src/integrations/ado/ado-client-factory.d.ts +1 -1
- package/dist/src/integrations/ado/ado-client-factory.d.ts.map +1 -1
- package/dist/src/integrations/ado/ado-client-factory.js +1 -1
- package/dist/src/integrations/ado/ado-client-factory.js.map +1 -1
- package/dist/src/integrations/ado/ado-dependency-loader.js +1 -1
- package/dist/src/integrations/ado/ado-dependency-loader.js.map +1 -1
- package/dist/src/living-docs/smart-doc-organizer.js +1 -1
- package/dist/src/living-docs/smart-doc-organizer.js.map +1 -1
- package/dist/src/sync/ado-reconciler.d.ts +1 -1
- package/dist/src/sync/ado-reconciler.js +1 -1
- package/dist/src/sync/external-change-puller.js +1 -1
- package/dist/src/sync/external-change-puller.js.map +1 -1
- package/dist/src/sync/external-issue-auto-creator.js +1 -1
- package/dist/src/sync/external-issue-auto-creator.js.map +1 -1
- package/dist/src/sync/external-item-sync-service.js +2 -2
- package/dist/src/sync/external-item-sync-service.js.map +1 -1
- package/dist/src/sync/format-preservation-sync.d.ts +1 -1
- package/dist/src/sync/format-preservation-sync.d.ts.map +1 -1
- package/dist/src/sync/format-preservation-sync.js +1 -1
- package/dist/src/sync/format-preservation-sync.js.map +1 -1
- package/dist/src/sync/github-reconciler.d.ts +1 -1
- package/dist/src/sync/github-reconciler.js +2 -2
- package/dist/src/sync/github-reconciler.js.map +1 -1
- package/dist/src/sync/github-sync-wrapper.d.ts +2 -2
- package/dist/src/sync/github-sync-wrapper.d.ts.map +1 -1
- package/dist/src/sync/github-sync-wrapper.js +1 -1
- package/dist/src/sync/github-sync-wrapper.js.map +1 -1
- package/dist/src/sync/jira-reconciler.d.ts +1 -1
- package/dist/src/sync/jira-reconciler.js +1 -1
- package/dist/src/sync/living-docs-updater.d.ts +1 -1
- package/dist/src/sync/living-docs-updater.d.ts.map +1 -1
- package/dist/src/sync/living-docs-updater.js +1 -1
- package/dist/src/sync/living-docs-updater.js.map +1 -1
- package/dist/src/sync/pr-linker.js +1 -1
- package/dist/src/sync/pr-linker.js.map +1 -1
- package/dist/src/sync/providers/github.d.ts +1 -1
- package/dist/src/sync/providers/github.js +1 -1
- package/dist/src/sync/sync-coordinator.js +4 -4
- package/dist/src/sync/sync-coordinator.js.map +1 -1
- package/dist/src/utils/cleanup-stale-plugins.d.ts.map +1 -1
- package/dist/src/utils/cleanup-stale-plugins.js +7 -0
- package/dist/src/utils/cleanup-stale-plugins.js.map +1 -1
- package/dist/src/utils/docs-validator.js +1 -1
- package/dist/src/utils/docs-validator.js.map +1 -1
- package/dist/src/utils/plugin-copier.d.ts +16 -0
- package/dist/src/utils/plugin-copier.d.ts.map +1 -1
- package/dist/src/utils/plugin-copier.js +79 -0
- package/dist/src/utils/plugin-copier.js.map +1 -1
- package/package.json +1 -1
- package/plugins/PLUGINS-INDEX.md +23 -42
- package/plugins/specweave/.claude-plugin/plugin.json +9 -2
- package/plugins/specweave/lib/integrations/ado/ado-ac-checkbox-sync.js +241 -0
- package/plugins/specweave/lib/integrations/ado/ado-ac-checkbox-sync.ts +311 -0
- package/plugins/specweave/lib/integrations/ado/ado-client-v2.d.ts +134 -0
- package/plugins/specweave/lib/integrations/ado/ado-client-v2.ts +742 -0
- package/plugins/specweave/lib/integrations/ado/ado-duplicate-detector.js +279 -0
- package/plugins/specweave/lib/integrations/ado/ado-duplicate-detector.ts +408 -0
- package/plugins/specweave/lib/integrations/ado/ado-hierarchical-sync.d.ts +40 -0
- package/plugins/specweave/lib/integrations/ado/ado-hierarchical-sync.js +300 -0
- package/plugins/specweave/lib/integrations/ado/ado-hierarchical-sync.ts +554 -0
- package/plugins/specweave/lib/integrations/ado/ado-multi-project-sync.js +486 -0
- package/plugins/specweave/lib/integrations/ado/ado-multi-project-sync.ts +675 -0
- package/plugins/specweave/lib/integrations/ado/ado-project-detector.js +502 -0
- package/plugins/specweave/lib/integrations/ado/ado-project-detector.ts +560 -0
- package/plugins/specweave/lib/integrations/ado/ado-spec-commit-sync.d.ts +38 -0
- package/plugins/specweave/lib/integrations/ado/ado-spec-commit-sync.js +189 -0
- package/plugins/specweave/lib/integrations/ado/ado-spec-commit-sync.ts +288 -0
- package/plugins/specweave/lib/integrations/ado/ado-spec-content-sync.js +249 -0
- package/plugins/specweave/lib/integrations/ado/ado-spec-content-sync.ts +379 -0
- package/plugins/specweave/lib/integrations/ado/ado-spec-sync.d.ts +100 -0
- package/plugins/specweave/lib/integrations/ado/ado-spec-sync.js +681 -0
- package/plugins/specweave/lib/integrations/ado/ado-spec-sync.ts +893 -0
- package/plugins/specweave/lib/integrations/ado/ado-status-sync.js +150 -0
- package/plugins/specweave/lib/integrations/ado/ado-status-sync.ts +213 -0
- package/plugins/specweave/lib/integrations/ado/conflict-resolver.js +400 -0
- package/plugins/specweave/lib/integrations/ado/conflict-resolver.ts +583 -0
- package/plugins/specweave/lib/integrations/ado/per-us-sync.js +272 -0
- package/plugins/specweave/lib/integrations/ado/per-us-sync.ts +457 -0
- package/plugins/specweave/lib/integrations/ado/project-selector.d.ts +42 -0
- package/plugins/specweave/lib/integrations/ado/project-selector.ts +304 -0
- package/plugins/specweave/lib/integrations/github/CodeValidator.js +195 -0
- package/plugins/specweave/lib/integrations/github/CodeValidator.ts +284 -0
- package/plugins/specweave/lib/integrations/github/duplicate-detector.js +397 -0
- package/plugins/specweave/lib/integrations/github/duplicate-detector.ts +561 -0
- package/plugins/specweave/lib/integrations/github/github-ac-checkbox-sync.js +287 -0
- package/plugins/specweave/lib/integrations/github/github-ac-checkbox-sync.ts +391 -0
- package/plugins/specweave/lib/integrations/github/github-ac-comment-poster.js +191 -0
- package/plugins/specweave/lib/integrations/github/github-ac-comment-poster.ts +315 -0
- package/plugins/specweave/lib/integrations/github/github-board-resolver.js +81 -0
- package/plugins/specweave/lib/integrations/github/github-board-resolver.ts +175 -0
- package/plugins/specweave/lib/integrations/github/github-client-v2.js +814 -0
- package/plugins/specweave/lib/integrations/github/github-client-v2.ts +1035 -0
- package/plugins/specweave/lib/integrations/github/github-cross-repo-sync.js +182 -0
- package/plugins/specweave/lib/integrations/github/github-cross-repo-sync.ts +265 -0
- package/plugins/specweave/lib/integrations/github/github-feature-sync.js +1007 -0
- package/plugins/specweave/lib/integrations/github/github-feature-sync.ts +1403 -0
- package/plugins/specweave/lib/integrations/github/github-hierarchical-sync.d.ts +29 -0
- package/plugins/specweave/lib/integrations/github/github-hierarchical-sync.js +190 -0
- package/plugins/specweave/lib/integrations/github/github-hierarchical-sync.ts +355 -0
- package/plugins/specweave/lib/integrations/github/github-issue-updater.js +275 -0
- package/plugins/specweave/lib/integrations/github/github-issue-updater.ts +462 -0
- package/plugins/specweave/lib/integrations/github/github-multi-project-sync.js +409 -0
- package/plugins/specweave/lib/integrations/github/github-multi-project-sync.ts +555 -0
- package/plugins/specweave/lib/integrations/github/github-pull-sync.js +185 -0
- package/plugins/specweave/lib/integrations/github/github-pull-sync.ts +343 -0
- package/plugins/specweave/lib/integrations/github/github-push-sync.js +129 -0
- package/plugins/specweave/lib/integrations/github/github-push-sync.ts +188 -0
- package/plugins/specweave/lib/integrations/github/github-rate-limiter.js +96 -0
- package/plugins/specweave/lib/integrations/github/github-rate-limiter.ts +143 -0
- package/plugins/specweave/lib/integrations/github/github-spec-commit-sync.d.ts +37 -0
- package/plugins/specweave/lib/integrations/github/github-spec-commit-sync.js +186 -0
- package/plugins/specweave/lib/integrations/github/github-spec-commit-sync.ts +285 -0
- package/plugins/specweave/lib/integrations/github/github-spec-content-sync.js +298 -0
- package/plugins/specweave/lib/integrations/github/github-spec-content-sync.ts +465 -0
- package/plugins/specweave/lib/integrations/github/github-spec-frontmatter-updater.ts +306 -0
- package/plugins/specweave/lib/integrations/github/github-spec-sync.d.ts +108 -0
- package/plugins/specweave/lib/integrations/github/github-spec-sync.js +900 -0
- package/plugins/specweave/lib/integrations/github/github-spec-sync.ts +1281 -0
- package/plugins/specweave/lib/integrations/github/github-sync-orchestrator.ts +158 -0
- package/plugins/specweave/lib/integrations/github/github-us-auto-closer.js +190 -0
- package/plugins/specweave/lib/integrations/github/github-us-auto-closer.ts +313 -0
- package/plugins/specweave/lib/integrations/github/per-us-sync.js +330 -0
- package/plugins/specweave/lib/integrations/github/per-us-sync.ts +515 -0
- package/plugins/specweave/lib/integrations/github/user-story-content-builder.js +306 -0
- package/plugins/specweave/lib/integrations/github/user-story-content-builder.ts +424 -0
- package/plugins/specweave/lib/integrations/jira/jira-ac-checkbox-sync.js +300 -0
- package/plugins/specweave/lib/integrations/jira/jira-ac-checkbox-sync.ts +380 -0
- package/plugins/specweave/lib/integrations/jira/jira-board-resolver.d.ts +50 -0
- package/plugins/specweave/lib/integrations/jira/jira-board-resolver.ts +127 -0
- package/plugins/specweave/lib/integrations/jira/jira-duplicate-detector.js +279 -0
- package/plugins/specweave/lib/integrations/jira/jira-duplicate-detector.ts +420 -0
- package/plugins/specweave/lib/integrations/jira/jira-epic-sync.js +314 -0
- package/plugins/specweave/lib/integrations/jira/jira-epic-sync.ts +474 -0
- package/plugins/specweave/lib/integrations/jira/jira-hierarchical-sync.d.ts +33 -0
- package/plugins/specweave/lib/integrations/jira/jira-hierarchical-sync.js +144 -0
- package/plugins/specweave/lib/integrations/jira/jira-hierarchical-sync.ts +294 -0
- package/plugins/specweave/lib/integrations/jira/jira-multi-project-sync.js +279 -0
- package/plugins/specweave/lib/integrations/jira/jira-multi-project-sync.ts +398 -0
- package/plugins/specweave/lib/integrations/jira/jira-spec-commit-sync.d.ts +43 -0
- package/plugins/specweave/lib/integrations/jira/jira-spec-commit-sync.js +262 -0
- package/plugins/specweave/lib/integrations/jira/jira-spec-commit-sync.ts +370 -0
- package/plugins/specweave/lib/integrations/jira/jira-spec-content-sync.js +260 -0
- package/plugins/specweave/lib/integrations/jira/jira-spec-content-sync.ts +367 -0
- package/plugins/specweave/lib/integrations/jira/jira-spec-sync.d.ts +105 -0
- package/plugins/specweave/lib/integrations/jira/jira-spec-sync.js +689 -0
- package/plugins/specweave/lib/integrations/jira/jira-spec-sync.ts +947 -0
- package/plugins/specweave/lib/integrations/jira/jira-status-sync.js +215 -0
- package/plugins/specweave/lib/integrations/jira/jira-status-sync.ts +375 -0
- package/plugins/specweave/lib/integrations/jira/per-us-sync.js +235 -0
- package/plugins/specweave/lib/integrations/jira/per-us-sync.ts +384 -0
- package/plugins/specweave/lib/integrations/jira/project-selector.d.ts +42 -0
- package/plugins/specweave/lib/integrations/jira/project-selector.ts +310 -0
- package/plugins/specweave/lib/integrations/jira/reorganization-detector.d.ts +67 -0
- package/plugins/specweave/lib/integrations/jira/reorganization-detector.ts +449 -0
- package/plugins/specweave/lib/integrations/jira/setup-wizard.d.js +4 -0
- package/plugins/specweave/lib/integrations/jira/setup-wizard.d.ts +29 -0
- package/plugins/specweave/lib/integrations/jira/setup-wizard.js +156 -0
- package/plugins/specweave/lib/integrations/jira/setup-wizard.ts +238 -0
- package/plugins/specweave/lib/vendor/sync/github-reconciler.d.ts +1 -1
- package/plugins/specweave/lib/vendor/sync/github-reconciler.js +2 -2
- package/plugins/specweave/lib/vendor/sync/github-reconciler.js.map +1 -1
- package/plugins/specweave/skills/team-lead/SKILL.md +10 -5
- package/plugins/specweave/skills/team-lead/agents/brainstorm-advocate.md +12 -6
- package/plugins/specweave/skills/team-lead/agents/brainstorm-critic.md +12 -6
- package/plugins/specweave/skills/team-lead/agents/brainstorm-pragmatist.md +12 -6
- package/dist/plugins/specweave-ado/lib/ado-ac-checkbox-sync.d.ts +0 -44
- package/dist/plugins/specweave-ado/lib/ado-ac-checkbox-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-ac-checkbox-sync.js +0 -236
- package/dist/plugins/specweave-ado/lib/ado-ac-checkbox-sync.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-board-resolver.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-board-resolver.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-client-v2.d.ts +0 -139
- package/dist/plugins/specweave-ado/lib/ado-client-v2.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-client-v2.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-client.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-client.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-duplicate-detector.d.ts +0 -100
- package/dist/plugins/specweave-ado/lib/ado-duplicate-detector.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-duplicate-detector.js +0 -292
- package/dist/plugins/specweave-ado/lib/ado-duplicate-detector.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-permission-gate.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-permission-gate.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-profile-resolver.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-profile-resolver.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-pull-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-pull-sync.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-rate-limiter.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-rate-limiter.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-spec-commit-sync.d.ts +0 -38
- package/dist/plugins/specweave-ado/lib/ado-spec-commit-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-spec-commit-sync.js +0 -210
- package/dist/plugins/specweave-ado/lib/ado-spec-commit-sync.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-spec-content-sync.d.ts +0 -28
- package/dist/plugins/specweave-ado/lib/ado-spec-content-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-spec-content-sync.js +0 -300
- package/dist/plugins/specweave-ado/lib/ado-spec-content-sync.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-spec-sync.d.ts +0 -147
- package/dist/plugins/specweave-ado/lib/ado-spec-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-spec-sync.js +0 -749
- package/dist/plugins/specweave-ado/lib/ado-spec-sync.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-status-sync.d.ts +0 -79
- package/dist/plugins/specweave-ado/lib/ado-status-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-status-sync.js +0 -162
- package/dist/plugins/specweave-ado/lib/ado-status-sync.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/conflict-resolver.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/conflict-resolver.js +0 -439
- package/dist/plugins/specweave-ado/lib/conflict-resolver.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/per-us-sync.d.ts +0 -131
- package/dist/plugins/specweave-ado/lib/per-us-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/per-us-sync.js +0 -322
- package/dist/plugins/specweave-ado/lib/per-us-sync.js.map +0 -1
- package/dist/plugins/specweave-github/lib/CodeValidator.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/CodeValidator.js +0 -219
- package/dist/plugins/specweave-github/lib/CodeValidator.js.map +0 -1
- package/dist/plugins/specweave-github/lib/IssueStateManager.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/IssueStateManager.js.map +0 -1
- package/dist/plugins/specweave-github/lib/completion-calculator.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/completion-calculator.js.map +0 -1
- package/dist/plugins/specweave-github/lib/duplicate-detector.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/duplicate-detector.js +0 -423
- package/dist/plugins/specweave-github/lib/duplicate-detector.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-ac-checkbox-sync.d.ts +0 -54
- package/dist/plugins/specweave-github/lib/github-ac-checkbox-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-ac-checkbox-sync.js +0 -305
- package/dist/plugins/specweave-github/lib/github-ac-checkbox-sync.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-ac-comment-poster.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-ac-comment-poster.js +0 -232
- package/dist/plugins/specweave-github/lib/github-ac-comment-poster.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-batch-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-batch-sync.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-board-resolver-v2.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-board-resolver-v2.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-client-v2.d.ts +0 -214
- package/dist/plugins/specweave-github/lib/github-client-v2.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-client-v2.js +0 -812
- package/dist/plugins/specweave-github/lib/github-client-v2.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-client.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-client.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-conflict-resolver.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-conflict-resolver.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-cross-repo-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-cross-repo-sync.js +0 -172
- package/dist/plugins/specweave-github/lib/github-cross-repo-sync.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-feature-sync-cli.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-feature-sync-cli.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-feature-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-feature-sync.js +0 -1112
- package/dist/plugins/specweave-github/lib/github-feature-sync.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-field-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-field-sync.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-graphql-client.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-graphql-client.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-issue-body-generator.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-issue-body-generator.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-issue-body-parser.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-issue-body-parser.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-issue-updater.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-issue-updater.js +0 -339
- package/dist/plugins/specweave-github/lib/github-issue-updater.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-pull-sync.d.ts +0 -94
- package/dist/plugins/specweave-github/lib/github-pull-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-pull-sync.js +0 -232
- package/dist/plugins/specweave-github/lib/github-pull-sync.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-push-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-push-sync.js +0 -127
- package/dist/plugins/specweave-github/lib/github-push-sync.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-rate-limiter.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-rate-limiter.js +0 -109
- package/dist/plugins/specweave-github/lib/github-rate-limiter.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-spec-commit-sync.d.ts +0 -37
- package/dist/plugins/specweave-github/lib/github-spec-commit-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-spec-commit-sync.js +0 -209
- package/dist/plugins/specweave-github/lib/github-spec-commit-sync.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-spec-content-sync.d.ts +0 -28
- package/dist/plugins/specweave-github/lib/github-spec-content-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-spec-content-sync.js +0 -365
- package/dist/plugins/specweave-github/lib/github-spec-content-sync.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-spec-frontmatter-updater.d.ts +0 -21
- package/dist/plugins/specweave-github/lib/github-spec-frontmatter-updater.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-spec-frontmatter-updater.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-spec-sync.d.ts +0 -225
- package/dist/plugins/specweave-github/lib/github-spec-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-spec-sync.js +0 -974
- package/dist/plugins/specweave-github/lib/github-spec-sync.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-sync-orchestrator.d.ts +0 -47
- package/dist/plugins/specweave-github/lib/github-sync-orchestrator.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-sync-orchestrator.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-us-auto-closer.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-us-auto-closer.js +0 -219
- package/dist/plugins/specweave-github/lib/github-us-auto-closer.js.map +0 -1
- package/dist/plugins/specweave-github/lib/index.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/index.js.map +0 -1
- package/dist/plugins/specweave-github/lib/per-us-sync.d.ts +0 -126
- package/dist/plugins/specweave-github/lib/per-us-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/per-us-sync.js +0 -394
- package/dist/plugins/specweave-github/lib/per-us-sync.js.map +0 -1
- package/dist/plugins/specweave-github/lib/progress-comment-builder.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/progress-comment-builder.js.map +0 -1
- package/dist/plugins/specweave-github/lib/types.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/types.js.map +0 -1
- package/dist/plugins/specweave-github/lib/user-story-content-builder.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/user-story-content-builder.js +0 -310
- package/dist/plugins/specweave-github/lib/user-story-content-builder.js.map +0 -1
- package/dist/plugins/specweave-github/lib/user-story-issue-builder.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/user-story-issue-builder.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/content-format-adapter.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/content-format-adapter.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-ac-checkbox-sync.d.ts +0 -47
- package/dist/plugins/specweave-jira/lib/jira-ac-checkbox-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-ac-checkbox-sync.js +0 -307
- package/dist/plugins/specweave-jira/lib/jira-ac-checkbox-sync.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-board-resolver.d.ts +0 -50
- package/dist/plugins/specweave-jira/lib/jira-board-resolver.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-board-resolver.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-deployment-detector.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-deployment-detector.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-duplicate-detector.d.ts +0 -103
- package/dist/plugins/specweave-jira/lib/jira-duplicate-detector.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-duplicate-detector.js +0 -295
- package/dist/plugins/specweave-jira/lib/jira-duplicate-detector.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-epic-sync.d.ts +0 -67
- package/dist/plugins/specweave-jira/lib/jira-epic-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-epic-sync.js +0 -286
- package/dist/plugins/specweave-jira/lib/jira-epic-sync.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-field-discovery.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-field-discovery.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-paginated-search.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-paginated-search.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-permission-gate.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-permission-gate.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-spec-commit-sync.d.ts +0 -43
- package/dist/plugins/specweave-jira/lib/jira-spec-commit-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-spec-commit-sync.js +0 -284
- package/dist/plugins/specweave-jira/lib/jira-spec-commit-sync.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-spec-content-sync.d.ts +0 -33
- package/dist/plugins/specweave-jira/lib/jira-spec-content-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-spec-content-sync.js +0 -294
- package/dist/plugins/specweave-jira/lib/jira-spec-content-sync.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-spec-sync.d.ts +0 -180
- package/dist/plugins/specweave-jira/lib/jira-spec-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-spec-sync.js +0 -757
- package/dist/plugins/specweave-jira/lib/jira-spec-sync.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-status-sync.d.ts +0 -116
- package/dist/plugins/specweave-jira/lib/jira-status-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-status-sync.js +0 -302
- package/dist/plugins/specweave-jira/lib/jira-status-sync.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/metadata-paths.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/metadata-paths.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/per-us-sync.d.ts +0 -117
- package/dist/plugins/specweave-jira/lib/per-us-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/per-us-sync.js +0 -274
- package/dist/plugins/specweave-jira/lib/per-us-sync.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/reorganization-detector.d.ts +0 -80
- package/dist/plugins/specweave-jira/lib/reorganization-detector.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/reorganization-detector.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/setup-wizard.d.ts +0 -29
- package/dist/plugins/specweave-jira/lib/setup-wizard.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/setup-wizard.js +0 -198
- package/dist/plugins/specweave-jira/lib/setup-wizard.js.map +0 -1
- package/dist/plugins/specweave-release/lib/dashboard-generator.d.ts.map +0 -1
- package/dist/plugins/specweave-release/lib/dashboard-generator.js.map +0 -1
- package/dist/plugins/specweave-release/lib/dora-tracker.d.ts.map +0 -1
- package/dist/plugins/specweave-release/lib/dora-tracker.js.map +0 -1
- package/plugins/specweave-ado/.claude-plugin/plugin.json +0 -20
- package/plugins/specweave-ado/PLUGIN.md +0 -39
- package/plugins/specweave-ado/hooks/README.md +0 -201
- package/plugins/specweave-ado/lib/ado-ac-checkbox-sync.js +0 -241
- package/plugins/specweave-ado/lib/ado-ac-checkbox-sync.ts +0 -311
- package/plugins/specweave-ado/lib/ado-client-v2.d.ts +0 -134
- package/plugins/specweave-ado/lib/ado-client-v2.ts +0 -742
- package/plugins/specweave-ado/lib/ado-duplicate-detector.js +0 -279
- package/plugins/specweave-ado/lib/ado-duplicate-detector.ts +0 -408
- package/plugins/specweave-ado/lib/ado-hierarchical-sync.d.ts +0 -40
- package/plugins/specweave-ado/lib/ado-hierarchical-sync.js +0 -300
- package/plugins/specweave-ado/lib/ado-hierarchical-sync.ts +0 -554
- package/plugins/specweave-ado/lib/ado-multi-project-sync.js +0 -486
- package/plugins/specweave-ado/lib/ado-multi-project-sync.ts +0 -675
- package/plugins/specweave-ado/lib/ado-project-detector.js +0 -502
- package/plugins/specweave-ado/lib/ado-project-detector.ts +0 -560
- package/plugins/specweave-ado/lib/ado-spec-commit-sync.d.ts +0 -38
- package/plugins/specweave-ado/lib/ado-spec-commit-sync.js +0 -189
- package/plugins/specweave-ado/lib/ado-spec-commit-sync.ts +0 -288
- package/plugins/specweave-ado/lib/ado-spec-content-sync.js +0 -249
- package/plugins/specweave-ado/lib/ado-spec-content-sync.ts +0 -379
- package/plugins/specweave-ado/lib/ado-spec-sync.d.ts +0 -100
- package/plugins/specweave-ado/lib/ado-spec-sync.js +0 -681
- package/plugins/specweave-ado/lib/ado-spec-sync.ts +0 -893
- package/plugins/specweave-ado/lib/ado-status-sync.js +0 -150
- package/plugins/specweave-ado/lib/ado-status-sync.ts +0 -213
- package/plugins/specweave-ado/lib/conflict-resolver.js +0 -400
- package/plugins/specweave-ado/lib/conflict-resolver.ts +0 -583
- package/plugins/specweave-ado/lib/per-us-sync.js +0 -272
- package/plugins/specweave-ado/lib/per-us-sync.ts +0 -457
- package/plugins/specweave-ado/lib/project-selector.d.ts +0 -42
- package/plugins/specweave-ado/lib/project-selector.ts +0 -304
- package/plugins/specweave-diagrams/.claude-plugin/plugin.json +0 -20
- package/plugins/specweave-diagrams/PLUGIN.md +0 -32
- package/plugins/specweave-docs/.claude-plugin/plugin.json +0 -10
- package/plugins/specweave-docs/PLUGIN.md +0 -27
- package/plugins/specweave-github/.claude-plugin/plugin.json +0 -19
- package/plugins/specweave-github/MULTI-PROJECT-SYNC-ARCHITECTURE.md +0 -744
- package/plugins/specweave-github/PLUGIN.md +0 -29
- package/plugins/specweave-github/SYNC-ARCHITECTURE-FIX-SUMMARY.md +0 -302
- package/plugins/specweave-github/hooks/README.md +0 -289
- package/plugins/specweave-github/lib/CodeValidator.js +0 -195
- package/plugins/specweave-github/lib/CodeValidator.ts +0 -284
- package/plugins/specweave-github/lib/duplicate-detector.js +0 -397
- package/plugins/specweave-github/lib/duplicate-detector.ts +0 -561
- package/plugins/specweave-github/lib/github-ac-checkbox-sync.js +0 -287
- package/plugins/specweave-github/lib/github-ac-checkbox-sync.ts +0 -391
- package/plugins/specweave-github/lib/github-ac-comment-poster.js +0 -191
- package/plugins/specweave-github/lib/github-ac-comment-poster.ts +0 -315
- package/plugins/specweave-github/lib/github-board-resolver.js +0 -81
- package/plugins/specweave-github/lib/github-board-resolver.ts +0 -175
- package/plugins/specweave-github/lib/github-client-v2.js +0 -814
- package/plugins/specweave-github/lib/github-client-v2.ts +0 -1035
- package/plugins/specweave-github/lib/github-cross-repo-sync.js +0 -182
- package/plugins/specweave-github/lib/github-cross-repo-sync.ts +0 -265
- package/plugins/specweave-github/lib/github-feature-sync.js +0 -1007
- package/plugins/specweave-github/lib/github-feature-sync.ts +0 -1403
- package/plugins/specweave-github/lib/github-hierarchical-sync.d.ts +0 -29
- package/plugins/specweave-github/lib/github-hierarchical-sync.js +0 -190
- package/plugins/specweave-github/lib/github-hierarchical-sync.ts +0 -355
- package/plugins/specweave-github/lib/github-issue-updater.js +0 -275
- package/plugins/specweave-github/lib/github-issue-updater.ts +0 -462
- package/plugins/specweave-github/lib/github-multi-project-sync.js +0 -409
- package/plugins/specweave-github/lib/github-multi-project-sync.ts +0 -555
- package/plugins/specweave-github/lib/github-pull-sync.js +0 -185
- package/plugins/specweave-github/lib/github-pull-sync.ts +0 -343
- package/plugins/specweave-github/lib/github-push-sync.js +0 -129
- package/plugins/specweave-github/lib/github-push-sync.ts +0 -188
- package/plugins/specweave-github/lib/github-rate-limiter.js +0 -96
- package/plugins/specweave-github/lib/github-rate-limiter.ts +0 -143
- package/plugins/specweave-github/lib/github-spec-commit-sync.d.ts +0 -37
- package/plugins/specweave-github/lib/github-spec-commit-sync.js +0 -186
- package/plugins/specweave-github/lib/github-spec-commit-sync.ts +0 -285
- package/plugins/specweave-github/lib/github-spec-content-sync.js +0 -298
- package/plugins/specweave-github/lib/github-spec-content-sync.ts +0 -465
- package/plugins/specweave-github/lib/github-spec-frontmatter-updater.ts +0 -306
- package/plugins/specweave-github/lib/github-spec-sync.d.ts +0 -108
- package/plugins/specweave-github/lib/github-spec-sync.js +0 -900
- package/plugins/specweave-github/lib/github-spec-sync.ts +0 -1281
- package/plugins/specweave-github/lib/github-sync-orchestrator.ts +0 -158
- package/plugins/specweave-github/lib/github-us-auto-closer.js +0 -190
- package/plugins/specweave-github/lib/github-us-auto-closer.ts +0 -313
- package/plugins/specweave-github/lib/per-us-sync.js +0 -330
- package/plugins/specweave-github/lib/per-us-sync.ts +0 -515
- package/plugins/specweave-github/lib/user-story-content-builder.js +0 -306
- package/plugins/specweave-github/lib/user-story-content-builder.ts +0 -424
- package/plugins/specweave-jira/.claude-plugin/plugin.json +0 -20
- package/plugins/specweave-jira/PLUGIN.md +0 -28
- package/plugins/specweave-jira/hooks/README.md +0 -201
- package/plugins/specweave-jira/lib/jira-ac-checkbox-sync.js +0 -300
- package/plugins/specweave-jira/lib/jira-ac-checkbox-sync.ts +0 -380
- package/plugins/specweave-jira/lib/jira-board-resolver.d.ts +0 -50
- package/plugins/specweave-jira/lib/jira-board-resolver.ts +0 -127
- package/plugins/specweave-jira/lib/jira-duplicate-detector.js +0 -279
- package/plugins/specweave-jira/lib/jira-duplicate-detector.ts +0 -420
- package/plugins/specweave-jira/lib/jira-epic-sync.js +0 -314
- package/plugins/specweave-jira/lib/jira-epic-sync.ts +0 -474
- package/plugins/specweave-jira/lib/jira-hierarchical-sync.d.ts +0 -33
- package/plugins/specweave-jira/lib/jira-hierarchical-sync.js +0 -144
- package/plugins/specweave-jira/lib/jira-hierarchical-sync.ts +0 -294
- package/plugins/specweave-jira/lib/jira-multi-project-sync.js +0 -279
- package/plugins/specweave-jira/lib/jira-multi-project-sync.ts +0 -398
- package/plugins/specweave-jira/lib/jira-spec-commit-sync.d.ts +0 -43
- package/plugins/specweave-jira/lib/jira-spec-commit-sync.js +0 -262
- package/plugins/specweave-jira/lib/jira-spec-commit-sync.ts +0 -370
- package/plugins/specweave-jira/lib/jira-spec-content-sync.js +0 -260
- package/plugins/specweave-jira/lib/jira-spec-content-sync.ts +0 -367
- package/plugins/specweave-jira/lib/jira-spec-sync.d.ts +0 -105
- package/plugins/specweave-jira/lib/jira-spec-sync.js +0 -689
- package/plugins/specweave-jira/lib/jira-spec-sync.ts +0 -947
- package/plugins/specweave-jira/lib/jira-status-sync.js +0 -215
- package/plugins/specweave-jira/lib/jira-status-sync.ts +0 -375
- package/plugins/specweave-jira/lib/per-us-sync.js +0 -235
- package/plugins/specweave-jira/lib/per-us-sync.ts +0 -384
- package/plugins/specweave-jira/lib/project-selector.d.ts +0 -42
- package/plugins/specweave-jira/lib/project-selector.ts +0 -310
- package/plugins/specweave-jira/lib/reorganization-detector.d.ts +0 -67
- package/plugins/specweave-jira/lib/reorganization-detector.ts +0 -449
- package/plugins/specweave-jira/lib/setup-wizard.d.js +0 -4
- package/plugins/specweave-jira/lib/setup-wizard.d.ts +0 -29
- package/plugins/specweave-jira/lib/setup-wizard.js +0 -156
- package/plugins/specweave-jira/lib/setup-wizard.ts +0 -238
- package/plugins/specweave-media/.claude-plugin/plugin.json +0 -24
- package/plugins/specweave-media/PLUGIN.md +0 -37
- package/plugins/specweave-media/test-providers.sh +0 -308
- package/plugins/specweave-release/.claude-plugin/plugin.json +0 -29
- package/plugins/specweave-release/IMPLEMENTATION.md +0 -446
- package/plugins/specweave-release/PLUGIN.md +0 -38
- package/plugins/specweave-release/README.md +0 -508
- package/plugins/specweave-release/hooks/post-task-completion.sh +0 -113
- /package/dist/plugins/{specweave-release/lib → specweave/lib/features/release}/dashboard-generator.d.ts +0 -0
- /package/dist/plugins/{specweave-release/lib → specweave/lib/features/release}/dashboard-generator.js +0 -0
- /package/dist/plugins/{specweave-release/lib → specweave/lib/features/release}/dora-tracker.d.ts +0 -0
- /package/dist/plugins/{specweave-release/lib → specweave/lib/features/release}/dora-tracker.js +0 -0
- /package/dist/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-board-resolver.d.ts +0 -0
- /package/dist/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-board-resolver.js +0 -0
- /package/dist/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-client-v2.js +0 -0
- /package/dist/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-client.d.ts +0 -0
- /package/dist/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-client.js +0 -0
- /package/dist/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-permission-gate.d.ts +0 -0
- /package/dist/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-permission-gate.js +0 -0
- /package/dist/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-profile-resolver.d.ts +0 -0
- /package/dist/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-profile-resolver.js +0 -0
- /package/dist/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-pull-sync.d.ts +0 -0
- /package/dist/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-pull-sync.js +0 -0
- /package/dist/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-rate-limiter.d.ts +0 -0
- /package/dist/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-rate-limiter.js +0 -0
- /package/dist/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/conflict-resolver.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/CodeValidator.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/IssueStateManager.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/IssueStateManager.js +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/completion-calculator.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/completion-calculator.js +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/duplicate-detector.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-ac-comment-poster.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-batch-sync.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-batch-sync.js +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-board-resolver-v2.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-board-resolver-v2.js +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-client.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-client.js +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-conflict-resolver.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-conflict-resolver.js +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-cross-repo-sync.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-feature-sync-cli.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-feature-sync-cli.js +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-feature-sync.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-field-sync.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-field-sync.js +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-graphql-client.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-graphql-client.js +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-issue-body-generator.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-issue-body-generator.js +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-issue-body-parser.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-issue-body-parser.js +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-issue-updater.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-push-sync.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-rate-limiter.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-spec-frontmatter-updater.js +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-sync-orchestrator.js +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-us-auto-closer.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/index.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/index.js +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/progress-comment-builder.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/progress-comment-builder.js +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/types.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/types.js +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/user-story-content-builder.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/user-story-issue-builder.d.ts +0 -0
- /package/dist/plugins/{specweave-github/lib → specweave/lib/integrations/github}/user-story-issue-builder.js +0 -0
- /package/dist/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/content-format-adapter.d.ts +0 -0
- /package/dist/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/content-format-adapter.js +0 -0
- /package/dist/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-board-resolver.js +0 -0
- /package/dist/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-deployment-detector.d.ts +0 -0
- /package/dist/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-deployment-detector.js +0 -0
- /package/dist/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-field-discovery.d.ts +0 -0
- /package/dist/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-field-discovery.js +0 -0
- /package/dist/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-paginated-search.d.ts +0 -0
- /package/dist/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-paginated-search.js +0 -0
- /package/dist/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-permission-gate.d.ts +0 -0
- /package/dist/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-permission-gate.js +0 -0
- /package/dist/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/metadata-paths.d.ts +0 -0
- /package/dist/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/metadata-paths.js +0 -0
- /package/dist/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/reorganization-detector.js +0 -0
- /package/plugins/{specweave-ado/commands/cleanup-duplicates.md → specweave/commands/ado-cleanup-duplicates.md} +0 -0
- /package/plugins/{specweave-ado/commands/clone.md → specweave/commands/ado-clone.md} +0 -0
- /package/plugins/{specweave-ado/commands/close.md → specweave/commands/ado-close.md} +0 -0
- /package/plugins/{specweave-ado/commands/create.md → specweave/commands/ado-create.md} +0 -0
- /package/plugins/{specweave-ado/commands/import-areas.md → specweave/commands/ado-import-areas.md} +0 -0
- /package/plugins/{specweave-ado/commands/import-projects.md → specweave/commands/ado-import-projects.md} +0 -0
- /package/plugins/{specweave-ado/commands/pull.md → specweave/commands/ado-pull.md} +0 -0
- /package/plugins/{specweave-ado/commands/push.md → specweave/commands/ado-push.md} +0 -0
- /package/plugins/{specweave-ado/commands/reconcile.md → specweave/commands/ado-reconcile.md} +0 -0
- /package/plugins/{specweave-ado/commands/status.md → specweave/commands/ado-status.md} +0 -0
- /package/plugins/{specweave-ado/commands/sync.md → specweave/commands/ado-sync.md} +0 -0
- /package/plugins/{specweave-diagrams → specweave}/commands/diagrams-generate.md +0 -0
- /package/plugins/{specweave-docs/commands/build.md → specweave/commands/docs-build.md} +0 -0
- /package/plugins/{specweave-docs/commands/generate.md → specweave/commands/docs-generate.md} +0 -0
- /package/plugins/{specweave-docs/commands/health.md → specweave/commands/docs-health.md} +0 -0
- /package/plugins/{specweave-docs/commands/init.md → specweave/commands/docs-init.md} +0 -0
- /package/plugins/{specweave-docs/commands/organize.md → specweave/commands/docs-organize.md} +0 -0
- /package/plugins/{specweave-docs/commands/validate.md → specweave/commands/docs-validate.md} +0 -0
- /package/plugins/{specweave-docs/commands/view.md → specweave/commands/docs-view.md} +0 -0
- /package/plugins/{specweave-github/commands/cleanup-duplicates.md → specweave/commands/github-cleanup-duplicates.md} +0 -0
- /package/plugins/{specweave-github/commands/clone.md → specweave/commands/github-clone.md} +0 -0
- /package/plugins/{specweave-github/commands/close.md → specweave/commands/github-close.md} +0 -0
- /package/plugins/{specweave-github/commands/create.md → specweave/commands/github-create.md} +0 -0
- /package/plugins/{specweave-github/commands/pull.md → specweave/commands/github-pull.md} +0 -0
- /package/plugins/{specweave-github/commands/push.md → specweave/commands/github-push.md} +0 -0
- /package/plugins/{specweave-github/commands/reconcile.md → specweave/commands/github-reconcile.md} +0 -0
- /package/plugins/{specweave-github/commands/status.md → specweave/commands/github-status.md} +0 -0
- /package/plugins/{specweave-github/commands/sync.md → specweave/commands/github-sync.md} +0 -0
- /package/plugins/{specweave-github/commands/update-user-story.md → specweave/commands/github-update-user-story.md} +0 -0
- /package/plugins/{specweave-jira/commands/cleanup-duplicates.md → specweave/commands/jira-cleanup-duplicates.md} +0 -0
- /package/plugins/{specweave-jira/commands/close.md → specweave/commands/jira-close.md} +0 -0
- /package/plugins/{specweave-jira/commands/create.md → specweave/commands/jira-create.md} +0 -0
- /package/plugins/{specweave-jira/commands/import-boards.md → specweave/commands/jira-import-boards.md} +0 -0
- /package/plugins/{specweave-jira/commands/import-projects-full.md → specweave/commands/jira-import-projects-full.md} +0 -0
- /package/plugins/{specweave-jira/commands/import-projects.md → specweave/commands/jira-import-projects.md} +0 -0
- /package/plugins/{specweave-jira/commands/pull.md → specweave/commands/jira-pull.md} +0 -0
- /package/plugins/{specweave-jira/commands/push.md → specweave/commands/jira-push.md} +0 -0
- /package/plugins/{specweave-jira/commands/reconcile.md → specweave/commands/jira-reconcile.md} +0 -0
- /package/plugins/{specweave-jira/commands/status.md → specweave/commands/jira-status.md} +0 -0
- /package/plugins/{specweave-jira/commands/sync.md → specweave/commands/jira-sync.md} +0 -0
- /package/plugins/{specweave-release/commands/align.md → specweave/commands/release-align.md} +0 -0
- /package/plugins/{specweave-release/commands/init.md → specweave/commands/release-init.md} +0 -0
- /package/plugins/{specweave-release/commands/npm.md → specweave/commands/release-npm.md} +0 -0
- /package/plugins/{specweave-release/commands/platform.md → specweave/commands/release-platform.md} +0 -0
- /package/plugins/{specweave-release/commands/rc.md → specweave/commands/release-rc.md} +0 -0
- /package/plugins/{specweave-ado/hooks/post-living-docs-update.sh → specweave/hooks/v2/integrations/ado-post-living-docs-update.sh} +0 -0
- /package/plugins/{specweave-ado/hooks/post-task-completion.sh → specweave/hooks/v2/integrations/ado-post-task.sh} +0 -0
- /package/plugins/{specweave-github/hooks → specweave/hooks/v2/integrations}/github-auto-create-handler.sh +0 -0
- /package/plugins/{specweave-github/hooks/post-task-completion.sh → specweave/hooks/v2/integrations/github-post-task.sh} +0 -0
- /package/plugins/{specweave-jira/hooks/post-task-completion.sh → specweave/hooks/v2/integrations/jira-post-task.sh} +0 -0
- /package/plugins/{specweave-release/lib → specweave/lib/features/release}/dashboard-generator.js +0 -0
- /package/plugins/{specweave-release/lib → specweave/lib/features/release}/dashboard-generator.ts +0 -0
- /package/plugins/{specweave-release/lib → specweave/lib/features/release}/dora-tracker.js +0 -0
- /package/plugins/{specweave-release/lib → specweave/lib/features/release}/dora-tracker.ts +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-board-resolver.d.js +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-board-resolver.d.ts +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-board-resolver.d.ts.map +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-board-resolver.js +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-board-resolver.js.map +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-board-resolver.ts +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-client-v2.d.js +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-client-v2.d.ts.map +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-client-v2.js +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-client-v2.js.map +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-client.d.js +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-client.d.ts +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-client.d.ts.map +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-client.js +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-client.js.map +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-client.ts +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-hierarchical-sync.d.js +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-hierarchical-sync.d.ts.map +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-hierarchical-sync.js.map +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-permission-gate.js +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-permission-gate.ts +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-profile-resolver.js +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-profile-resolver.ts +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-pull-sync.js +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-pull-sync.ts +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-rate-limiter.js +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-rate-limiter.ts +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-spec-commit-sync.d.js +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-spec-commit-sync.d.ts.map +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-spec-commit-sync.js.map +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-spec-sync.d.js +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-spec-sync.d.ts.map +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/ado-spec-sync.js.map +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/project-selector.d.js +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/project-selector.d.ts.map +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/project-selector.js +0 -0
- /package/plugins/{specweave-ado/lib → specweave/lib/integrations/ado}/project-selector.js.map +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/IssueStateManager.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/IssueStateManager.ts +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/completion-calculator.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/completion-calculator.ts +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-batch-sync.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-batch-sync.ts +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-board-resolver-v2.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-board-resolver-v2.ts +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-board-resolver.d.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-board-resolver.d.ts +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-board-resolver.d.ts.map +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-board-resolver.js.map +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-client.d.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-client.d.ts +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-client.d.ts.map +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-client.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-client.js.map +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-client.ts +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-conflict-resolver.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-conflict-resolver.ts +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-feature-sync-cli.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-feature-sync-cli.ts +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-field-sync.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-field-sync.ts +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-graphql-client.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-graphql-client.ts +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-hierarchical-sync.d.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-hierarchical-sync.d.ts.map +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-hierarchical-sync.js.map +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-issue-body-generator.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-issue-body-generator.ts +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-issue-body-parser.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-issue-body-parser.ts +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-issue-updater.d.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-issue-updater.d.ts +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-issue-updater.d.ts.map +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-issue-updater.js.map +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-spec-commit-sync.d.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-spec-commit-sync.d.ts.map +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-spec-commit-sync.js.map +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-spec-frontmatter-updater.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-spec-sync.d.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-spec-sync.d.ts.map +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-spec-sync.js.map +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/github-sync-orchestrator.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/index.d.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/index.d.ts +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/index.d.ts.map +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/index.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/index.js.map +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/index.ts +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/progress-comment-builder.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/progress-comment-builder.ts +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/repo-selector.d.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/repo-selector.d.ts +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/repo-selector.d.ts.map +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/repo-selector.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/repo-selector.js.map +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/repo-selector.ts +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/types.d.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/types.d.ts +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/types.d.ts.map +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/types.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/types.js.map +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/types.ts +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/user-story-issue-builder.js +0 -0
- /package/plugins/{specweave-github/lib → specweave/lib/integrations/github}/user-story-issue-builder.ts +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/content-format-adapter.js +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/content-format-adapter.ts +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-board-resolver.d.js +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-board-resolver.d.ts.map +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-board-resolver.js +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-board-resolver.js.map +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-deployment-detector.js +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-deployment-detector.ts +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-field-discovery.js +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-field-discovery.ts +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-hierarchical-sync.d.js +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-hierarchical-sync.d.ts.map +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-hierarchical-sync.js.map +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-paginated-search.js +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-paginated-search.ts +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-permission-gate.js +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-permission-gate.ts +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-profile-resolver.js +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-profile-resolver.ts +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-spec-commit-sync.d.js +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-spec-commit-sync.d.ts.map +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-spec-commit-sync.js.map +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-spec-sync.d.js +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-spec-sync.d.ts.map +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/jira-spec-sync.js.map +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/metadata-paths.js +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/metadata-paths.ts +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/project-selector.d.js +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/project-selector.d.ts.map +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/project-selector.js +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/project-selector.js.map +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/reorganization-detector.d.js +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/reorganization-detector.d.ts.map +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/reorganization-detector.js +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/reorganization-detector.js.map +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/setup-wizard.d.ts.map +0 -0
- /package/plugins/{specweave-jira/lib → specweave/lib/integrations/jira}/setup-wizard.js.map +0 -0
- /package/plugins/{specweave-ado/reference → specweave/reference/ado}/ado-specweave-mapping.md +0 -0
- /package/plugins/{specweave-github/reference → specweave/reference/github}/github-specweave-mapping.md +0 -0
- /package/plugins/{specweave-jira/reference → specweave/reference/jira}/confluence-page-api.md +0 -0
- /package/plugins/{specweave-jira/reference → specweave/reference/jira}/jira-specweave-mapping.md +0 -0
- /package/plugins/{specweave-ado/scripts → specweave/scripts/ado}/refresh-cache.js +0 -0
- /package/plugins/{specweave-ado/scripts → specweave/scripts/ado}/refresh-cache.ts +0 -0
- /package/plugins/{specweave-jira/scripts → specweave/scripts/jira}/import-projects.js +0 -0
- /package/plugins/{specweave-jira/scripts → specweave/scripts/jira}/import-projects.ts +0 -0
- /package/plugins/{specweave-jira/scripts → specweave/scripts/jira}/refresh-cache.js +0 -0
- /package/plugins/{specweave-jira/scripts → specweave/scripts/jira}/refresh-cache.ts +0 -0
- /package/plugins/{specweave-ado → specweave}/skills/ado-mapper/SKILL.md +0 -0
- /package/plugins/{specweave-ado → specweave}/skills/ado-multi-project/SKILL.md +0 -0
- /package/plugins/{specweave-ado → specweave}/skills/ado-resource-validator/SKILL.md +0 -0
- /package/plugins/{specweave-ado → specweave}/skills/ado-sync/README.md +0 -0
- /package/plugins/{specweave-ado → specweave}/skills/ado-sync/SKILL.md +0 -0
- /package/plugins/{specweave-diagrams → specweave}/skills/diagrams/SKILL.md +0 -0
- /package/plugins/{specweave-github → specweave}/skills/github-issue-standard/SKILL.md +0 -0
- /package/plugins/{specweave-github → specweave}/skills/github-multi-project/SKILL.md +0 -0
- /package/plugins/{specweave-github → specweave}/skills/github-sync/SKILL.md +0 -0
- /package/plugins/{specweave-github → specweave}/skills/github-sync/evals/HOW-TO-RUN-EVALS.md +0 -0
- /package/plugins/{specweave-github → specweave}/skills/github-sync/evals/evals.json +0 -0
- /package/plugins/{specweave-media → specweave}/skills/image/SKILL.md +0 -0
- /package/plugins/{specweave-jira → specweave}/skills/jira-mapper/SKILL.md +0 -0
- /package/plugins/{specweave-jira → specweave}/skills/jira-resource-validator/SKILL.md +0 -0
- /package/plugins/{specweave-jira → specweave}/skills/jira-sync/README.md +0 -0
- /package/plugins/{specweave-jira → specweave}/skills/jira-sync/SKILL.md +0 -0
- /package/plugins/{specweave-github → specweave}/skills/pr-review/SKILL.md +0 -0
- /package/plugins/{specweave-release → specweave}/skills/release-expert/SKILL.md +0 -0
- /package/plugins/{specweave-media → specweave}/skills/remotion/SKILL.md +0 -0
- /package/plugins/{specweave-media → specweave}/skills/video/SKILL.md +0 -0
|
@@ -0,0 +1,279 @@
|
|
|
1
|
+
import { consoleLogger } from "../../../../../src/utils/logger.js";
|
|
2
|
+
class AdoDuplicateDetector {
|
|
3
|
+
constructor(options = {}) {
|
|
4
|
+
this.org = options.org || process.env.AZURE_DEVOPS_ORG || "";
|
|
5
|
+
this.project = options.project || process.env.AZURE_DEVOPS_PROJECT || "";
|
|
6
|
+
this.pat = options.pat || process.env.AZURE_DEVOPS_PAT || process.env.AZURE_DEVOPS_TOKEN || "";
|
|
7
|
+
this.logger = options.logger || consoleLogger;
|
|
8
|
+
}
|
|
9
|
+
/**
|
|
10
|
+
* Phase 1: Check if work item exists before creating
|
|
11
|
+
*/
|
|
12
|
+
async checkBeforeCreate(titlePattern, incrementId) {
|
|
13
|
+
try {
|
|
14
|
+
const items = await this.searchWorkItems(titlePattern);
|
|
15
|
+
if (items.length > 0) {
|
|
16
|
+
return {
|
|
17
|
+
found: true,
|
|
18
|
+
existingItem: items[0],
|
|
19
|
+
count: items.length
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
return { found: false, count: 0 };
|
|
23
|
+
} catch (error) {
|
|
24
|
+
this.logger.log(`\u26A0\uFE0F Detection check failed: ${error.message}`);
|
|
25
|
+
return { found: false, count: 0 };
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Phase 2: Verify count after creation
|
|
30
|
+
*/
|
|
31
|
+
async verifyAfterCreate(titlePattern, expectedCount = 1) {
|
|
32
|
+
try {
|
|
33
|
+
const items = await this.searchWorkItems(titlePattern);
|
|
34
|
+
if (items.length > expectedCount) {
|
|
35
|
+
const sorted = items.sort(
|
|
36
|
+
(a, b) => a.id - b.id
|
|
37
|
+
// Sort by ID (lowest = oldest)
|
|
38
|
+
);
|
|
39
|
+
return {
|
|
40
|
+
success: false,
|
|
41
|
+
expectedCount,
|
|
42
|
+
actualCount: items.length,
|
|
43
|
+
duplicates: sorted.slice(expectedCount)
|
|
44
|
+
// All items after expected count
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
return {
|
|
48
|
+
success: true,
|
|
49
|
+
expectedCount,
|
|
50
|
+
actualCount: items.length,
|
|
51
|
+
duplicates: []
|
|
52
|
+
};
|
|
53
|
+
} catch (error) {
|
|
54
|
+
this.logger.log(`\u26A0\uFE0F Verification check failed: ${error.message}`);
|
|
55
|
+
return {
|
|
56
|
+
success: false,
|
|
57
|
+
expectedCount,
|
|
58
|
+
actualCount: -1,
|
|
59
|
+
duplicates: [],
|
|
60
|
+
error: `Verification failed: ${error.message}`
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Phase 3: Auto-close duplicates
|
|
66
|
+
*/
|
|
67
|
+
async closeDuplicates(duplicates, keepItemId) {
|
|
68
|
+
const result = {
|
|
69
|
+
closedCount: 0,
|
|
70
|
+
keptCount: 1,
|
|
71
|
+
errors: []
|
|
72
|
+
};
|
|
73
|
+
for (const item of duplicates) {
|
|
74
|
+
try {
|
|
75
|
+
await this.closeWorkItem(item.id, keepItemId);
|
|
76
|
+
result.closedCount++;
|
|
77
|
+
this.logger.log(` \u2705 Closed #${item.id} (duplicate of #${keepItemId})`);
|
|
78
|
+
} catch (error) {
|
|
79
|
+
result.errors.push(`#${item.id}: ${error.message}`);
|
|
80
|
+
this.logger.log(` \u274C Failed to close #${item.id}: ${error.message}`);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
return result;
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* Full cleanup: Find and close all duplicates for a feature
|
|
87
|
+
*/
|
|
88
|
+
async cleanupFeatureDuplicates(featureId, dryRun = false) {
|
|
89
|
+
const searchPattern = `[${featureId}]`;
|
|
90
|
+
const items = await this.searchWorkItems(searchPattern);
|
|
91
|
+
this.logger.log(`
|
|
92
|
+
\u{1F50D} Scanning for duplicates in Feature ${featureId}...`);
|
|
93
|
+
this.logger.log(` Found ${items.length} total work items`);
|
|
94
|
+
const groups = this.groupByTitle(items);
|
|
95
|
+
const duplicateGroups = groups.filter((g) => g.duplicates.length > 0);
|
|
96
|
+
if (duplicateGroups.length === 0) {
|
|
97
|
+
this.logger.log(` \u2705 No duplicates found!`);
|
|
98
|
+
return {
|
|
99
|
+
groups: [],
|
|
100
|
+
totalItems: items.length,
|
|
101
|
+
duplicateCount: 0,
|
|
102
|
+
closedCount: 0
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
this.logger.log(` Detected ${duplicateGroups.length} duplicate groups:
|
|
106
|
+
`);
|
|
107
|
+
for (let i = 0; i < duplicateGroups.length; i++) {
|
|
108
|
+
const group = duplicateGroups[i];
|
|
109
|
+
this.logger.log(` \u{1F4CB} Group ${i + 1}: "${group.title.substring(0, 50)}..."`);
|
|
110
|
+
this.logger.log(` - #${group.keepItem.id} (KEEP) - Created ${group.keepItem.createdDate.split("T")[0]}`);
|
|
111
|
+
for (const dup of group.duplicates) {
|
|
112
|
+
this.logger.log(` - #${dup.id} (CLOSE) - Created ${dup.createdDate.split("T")[0]} - DUPLICATE`);
|
|
113
|
+
}
|
|
114
|
+
this.logger.log("");
|
|
115
|
+
}
|
|
116
|
+
const totalDuplicates = duplicateGroups.reduce((sum, g) => sum + g.duplicates.length, 0);
|
|
117
|
+
if (dryRun) {
|
|
118
|
+
this.logger.log(`
|
|
119
|
+
\u2705 Dry run complete!`);
|
|
120
|
+
this.logger.log(` Total work items: ${items.length}`);
|
|
121
|
+
this.logger.log(` Duplicate groups: ${duplicateGroups.length}`);
|
|
122
|
+
this.logger.log(` Work items to close: ${totalDuplicates}`);
|
|
123
|
+
this.logger.log(`
|
|
124
|
+
\u26A0\uFE0F This was a DRY RUN - no changes made.`);
|
|
125
|
+
return {
|
|
126
|
+
groups: duplicateGroups,
|
|
127
|
+
totalItems: items.length,
|
|
128
|
+
duplicateCount: totalDuplicates,
|
|
129
|
+
closedCount: 0
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
let closedCount = 0;
|
|
133
|
+
this.logger.log(`\u{1F5D1}\uFE0F Closing duplicates...`);
|
|
134
|
+
for (const group of duplicateGroups) {
|
|
135
|
+
const result = await this.closeDuplicates(group.duplicates, group.keepItem.id);
|
|
136
|
+
closedCount += result.closedCount;
|
|
137
|
+
}
|
|
138
|
+
this.logger.log(`
|
|
139
|
+
\u2705 Cleanup complete!`);
|
|
140
|
+
this.logger.log(` Closed: ${closedCount} duplicates`);
|
|
141
|
+
this.logger.log(` Kept: ${duplicateGroups.length} original work items`);
|
|
142
|
+
return {
|
|
143
|
+
groups: duplicateGroups,
|
|
144
|
+
totalItems: items.length,
|
|
145
|
+
duplicateCount: totalDuplicates,
|
|
146
|
+
closedCount
|
|
147
|
+
};
|
|
148
|
+
}
|
|
149
|
+
/**
|
|
150
|
+
* Group work items by title
|
|
151
|
+
*/
|
|
152
|
+
groupByTitle(items) {
|
|
153
|
+
const titleMap = /* @__PURE__ */ new Map();
|
|
154
|
+
for (const item of items) {
|
|
155
|
+
const existing = titleMap.get(item.title) || [];
|
|
156
|
+
existing.push(item);
|
|
157
|
+
titleMap.set(item.title, existing);
|
|
158
|
+
}
|
|
159
|
+
const groups = [];
|
|
160
|
+
for (const [title, groupItems] of titleMap) {
|
|
161
|
+
const sorted = groupItems.sort((a, b) => a.id - b.id);
|
|
162
|
+
groups.push({
|
|
163
|
+
title,
|
|
164
|
+
items: sorted,
|
|
165
|
+
keepItem: sorted[0],
|
|
166
|
+
duplicates: sorted.slice(1)
|
|
167
|
+
});
|
|
168
|
+
}
|
|
169
|
+
return groups;
|
|
170
|
+
}
|
|
171
|
+
/**
|
|
172
|
+
* Search for work items using WIQL
|
|
173
|
+
*/
|
|
174
|
+
async searchWorkItems(titlePattern) {
|
|
175
|
+
if (!this.org || !this.pat) {
|
|
176
|
+
throw new Error("ADO credentials not configured");
|
|
177
|
+
}
|
|
178
|
+
const wiql = {
|
|
179
|
+
query: `SELECT [System.Id], [System.Title], [System.State], [System.CreatedDate]
|
|
180
|
+
FROM WorkItems
|
|
181
|
+
WHERE [System.TeamProject] = '${this.project}'
|
|
182
|
+
AND [System.Title] CONTAINS '${titlePattern}'
|
|
183
|
+
ORDER BY [System.Id] ASC`
|
|
184
|
+
};
|
|
185
|
+
const auth = Buffer.from(`:${this.pat}`).toString("base64");
|
|
186
|
+
const url = `https://dev.azure.com/${this.org}/${this.project}/_apis/wit/wiql?api-version=7.1`;
|
|
187
|
+
const response = await fetch(url, {
|
|
188
|
+
method: "POST",
|
|
189
|
+
headers: {
|
|
190
|
+
Authorization: `Basic ${auth}`,
|
|
191
|
+
"Content-Type": "application/json"
|
|
192
|
+
},
|
|
193
|
+
body: JSON.stringify(wiql)
|
|
194
|
+
});
|
|
195
|
+
if (!response.ok) {
|
|
196
|
+
throw new Error(`WIQL query failed: ${response.status}`);
|
|
197
|
+
}
|
|
198
|
+
const data = await response.json();
|
|
199
|
+
const workItemIds = data.workItems?.map((wi) => wi.id) || [];
|
|
200
|
+
if (workItemIds.length === 0) {
|
|
201
|
+
return [];
|
|
202
|
+
}
|
|
203
|
+
return this.getWorkItemDetails(workItemIds);
|
|
204
|
+
}
|
|
205
|
+
/**
|
|
206
|
+
* Get work item details by IDs
|
|
207
|
+
*/
|
|
208
|
+
async getWorkItemDetails(ids) {
|
|
209
|
+
if (ids.length === 0) return [];
|
|
210
|
+
const auth = Buffer.from(`:${this.pat}`).toString("base64");
|
|
211
|
+
const url = `https://dev.azure.com/${this.org}/_apis/wit/workitems?ids=${ids.join(",")}&api-version=7.1`;
|
|
212
|
+
const response = await fetch(url, {
|
|
213
|
+
headers: {
|
|
214
|
+
Authorization: `Basic ${auth}`,
|
|
215
|
+
"Content-Type": "application/json"
|
|
216
|
+
}
|
|
217
|
+
});
|
|
218
|
+
if (!response.ok) {
|
|
219
|
+
throw new Error(`Failed to get work items: ${response.status}`);
|
|
220
|
+
}
|
|
221
|
+
const data = await response.json();
|
|
222
|
+
return (data.value || []).map((wi) => ({
|
|
223
|
+
id: wi.id,
|
|
224
|
+
title: wi.fields["System.Title"],
|
|
225
|
+
state: wi.fields["System.State"],
|
|
226
|
+
createdDate: wi.fields["System.CreatedDate"],
|
|
227
|
+
url: wi._links?.html?.href
|
|
228
|
+
}));
|
|
229
|
+
}
|
|
230
|
+
/**
|
|
231
|
+
* Close a work item with duplicate comment
|
|
232
|
+
*/
|
|
233
|
+
async closeWorkItem(workItemId, originalId) {
|
|
234
|
+
const auth = Buffer.from(`:${this.pat}`).toString("base64");
|
|
235
|
+
const url = `https://dev.azure.com/${this.org}/_apis/wit/workitems/${workItemId}?api-version=7.1`;
|
|
236
|
+
const comment = `## Duplicate of #${originalId}
|
|
237
|
+
|
|
238
|
+
This work item was automatically closed by SpecWeave cleanup because it is a duplicate.
|
|
239
|
+
|
|
240
|
+
The original work item (#${originalId}) contains the same content and should be used for tracking instead.
|
|
241
|
+
|
|
242
|
+
---
|
|
243
|
+
\u{1F916} Auto-closed by SpecWeave Duplicate Cleanup`;
|
|
244
|
+
const operations = [
|
|
245
|
+
{
|
|
246
|
+
op: "add",
|
|
247
|
+
path: "/fields/System.State",
|
|
248
|
+
value: "Closed"
|
|
249
|
+
},
|
|
250
|
+
{
|
|
251
|
+
op: "add",
|
|
252
|
+
path: "/fields/System.History",
|
|
253
|
+
value: comment
|
|
254
|
+
}
|
|
255
|
+
];
|
|
256
|
+
const response = await fetch(url, {
|
|
257
|
+
method: "PATCH",
|
|
258
|
+
headers: {
|
|
259
|
+
Authorization: `Basic ${auth}`,
|
|
260
|
+
"Content-Type": "application/json-patch+json"
|
|
261
|
+
},
|
|
262
|
+
body: JSON.stringify(operations)
|
|
263
|
+
});
|
|
264
|
+
if (!response.ok) {
|
|
265
|
+
const error = await response.text();
|
|
266
|
+
throw new Error(`Failed to close work item: ${response.status} - ${error}`);
|
|
267
|
+
}
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
async function cleanupAdoDuplicates(featureId, dryRun = false) {
|
|
271
|
+
const detector = new AdoDuplicateDetector();
|
|
272
|
+
return detector.cleanupFeatureDuplicates(featureId, dryRun);
|
|
273
|
+
}
|
|
274
|
+
var ado_duplicate_detector_default = AdoDuplicateDetector;
|
|
275
|
+
export {
|
|
276
|
+
AdoDuplicateDetector,
|
|
277
|
+
cleanupAdoDuplicates,
|
|
278
|
+
ado_duplicate_detector_default as default
|
|
279
|
+
};
|
|
@@ -0,0 +1,408 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Azure DevOps Duplicate Detector (v0.33.0)
|
|
3
|
+
*
|
|
4
|
+
* Implements 3-phase duplicate protection for ADO work items:
|
|
5
|
+
* 1. Detection: Check before create
|
|
6
|
+
* 2. Verification: Count check after create
|
|
7
|
+
* 3. Reflection: Auto-close duplicates
|
|
8
|
+
*
|
|
9
|
+
* Mirrors the GitHub DuplicateDetector pattern for consistency.
|
|
10
|
+
*/
|
|
11
|
+
|
|
12
|
+
import { Logger, consoleLogger } from '../../../../../src/utils/logger.js';
|
|
13
|
+
|
|
14
|
+
export interface AdoWorkItem {
|
|
15
|
+
id: number;
|
|
16
|
+
title: string;
|
|
17
|
+
state: string;
|
|
18
|
+
createdDate: string;
|
|
19
|
+
url?: string;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export interface DuplicateGroup {
|
|
23
|
+
title: string;
|
|
24
|
+
items: AdoWorkItem[];
|
|
25
|
+
keepItem: AdoWorkItem;
|
|
26
|
+
duplicates: AdoWorkItem[];
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export interface DetectionResult {
|
|
30
|
+
found: boolean;
|
|
31
|
+
existingItem?: AdoWorkItem;
|
|
32
|
+
count: number;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
export interface VerificationResult {
|
|
36
|
+
success: boolean;
|
|
37
|
+
expectedCount: number;
|
|
38
|
+
actualCount: number;
|
|
39
|
+
duplicates: AdoWorkItem[];
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
export interface CleanupResult {
|
|
43
|
+
closedCount: number;
|
|
44
|
+
keptCount: number;
|
|
45
|
+
errors: string[];
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
export class AdoDuplicateDetector {
|
|
49
|
+
private org: string;
|
|
50
|
+
private project: string;
|
|
51
|
+
private pat: string;
|
|
52
|
+
private logger: Logger;
|
|
53
|
+
|
|
54
|
+
constructor(options: {
|
|
55
|
+
org?: string;
|
|
56
|
+
project?: string;
|
|
57
|
+
pat?: string;
|
|
58
|
+
logger?: Logger;
|
|
59
|
+
} = {}) {
|
|
60
|
+
this.org = options.org || process.env.AZURE_DEVOPS_ORG || '';
|
|
61
|
+
this.project = options.project || process.env.AZURE_DEVOPS_PROJECT || '';
|
|
62
|
+
this.pat = options.pat || process.env.AZURE_DEVOPS_PAT || process.env.AZURE_DEVOPS_TOKEN || '';
|
|
63
|
+
this.logger = options.logger || consoleLogger;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
/**
|
|
67
|
+
* Phase 1: Check if work item exists before creating
|
|
68
|
+
*/
|
|
69
|
+
async checkBeforeCreate(
|
|
70
|
+
titlePattern: string,
|
|
71
|
+
incrementId?: string
|
|
72
|
+
): Promise<DetectionResult> {
|
|
73
|
+
try {
|
|
74
|
+
const items = await this.searchWorkItems(titlePattern);
|
|
75
|
+
|
|
76
|
+
if (items.length > 0) {
|
|
77
|
+
return {
|
|
78
|
+
found: true,
|
|
79
|
+
existingItem: items[0],
|
|
80
|
+
count: items.length,
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
return { found: false, count: 0 };
|
|
85
|
+
} catch (error: any) {
|
|
86
|
+
this.logger.log(`⚠️ Detection check failed: ${error.message}`);
|
|
87
|
+
// Graceful degradation - continue anyway
|
|
88
|
+
return { found: false, count: 0 };
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
/**
|
|
93
|
+
* Phase 2: Verify count after creation
|
|
94
|
+
*/
|
|
95
|
+
async verifyAfterCreate(
|
|
96
|
+
titlePattern: string,
|
|
97
|
+
expectedCount: number = 1
|
|
98
|
+
): Promise<VerificationResult> {
|
|
99
|
+
try {
|
|
100
|
+
const items = await this.searchWorkItems(titlePattern);
|
|
101
|
+
|
|
102
|
+
if (items.length > expectedCount) {
|
|
103
|
+
// Duplicates detected!
|
|
104
|
+
const sorted = items.sort(
|
|
105
|
+
(a, b) => a.id - b.id // Sort by ID (lowest = oldest)
|
|
106
|
+
);
|
|
107
|
+
|
|
108
|
+
return {
|
|
109
|
+
success: false,
|
|
110
|
+
expectedCount,
|
|
111
|
+
actualCount: items.length,
|
|
112
|
+
duplicates: sorted.slice(expectedCount), // All items after expected count
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
return {
|
|
117
|
+
success: true,
|
|
118
|
+
expectedCount,
|
|
119
|
+
actualCount: items.length,
|
|
120
|
+
duplicates: [],
|
|
121
|
+
};
|
|
122
|
+
} catch (error: any) {
|
|
123
|
+
this.logger.log(`⚠️ Verification check failed: ${error.message}`);
|
|
124
|
+
return {
|
|
125
|
+
success: false,
|
|
126
|
+
expectedCount,
|
|
127
|
+
actualCount: -1,
|
|
128
|
+
duplicates: [],
|
|
129
|
+
error: `Verification failed: ${error.message}`,
|
|
130
|
+
} as VerificationResult & { error: string };
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
/**
|
|
135
|
+
* Phase 3: Auto-close duplicates
|
|
136
|
+
*/
|
|
137
|
+
async closeDuplicates(
|
|
138
|
+
duplicates: AdoWorkItem[],
|
|
139
|
+
keepItemId: number
|
|
140
|
+
): Promise<CleanupResult> {
|
|
141
|
+
const result: CleanupResult = {
|
|
142
|
+
closedCount: 0,
|
|
143
|
+
keptCount: 1,
|
|
144
|
+
errors: [],
|
|
145
|
+
};
|
|
146
|
+
|
|
147
|
+
for (const item of duplicates) {
|
|
148
|
+
try {
|
|
149
|
+
await this.closeWorkItem(item.id, keepItemId);
|
|
150
|
+
result.closedCount++;
|
|
151
|
+
this.logger.log(` ✅ Closed #${item.id} (duplicate of #${keepItemId})`);
|
|
152
|
+
} catch (error: any) {
|
|
153
|
+
result.errors.push(`#${item.id}: ${error.message}`);
|
|
154
|
+
this.logger.log(` ❌ Failed to close #${item.id}: ${error.message}`);
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
return result;
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
/**
|
|
162
|
+
* Full cleanup: Find and close all duplicates for a feature
|
|
163
|
+
*/
|
|
164
|
+
async cleanupFeatureDuplicates(
|
|
165
|
+
featureId: string,
|
|
166
|
+
dryRun: boolean = false
|
|
167
|
+
): Promise<{
|
|
168
|
+
groups: DuplicateGroup[];
|
|
169
|
+
totalItems: number;
|
|
170
|
+
duplicateCount: number;
|
|
171
|
+
closedCount: number;
|
|
172
|
+
}> {
|
|
173
|
+
// 1. Search for all work items with feature ID
|
|
174
|
+
const searchPattern = `[${featureId}]`;
|
|
175
|
+
const items = await this.searchWorkItems(searchPattern);
|
|
176
|
+
|
|
177
|
+
this.logger.log(`\n🔍 Scanning for duplicates in Feature ${featureId}...`);
|
|
178
|
+
this.logger.log(` Found ${items.length} total work items`);
|
|
179
|
+
|
|
180
|
+
// 2. Group by title
|
|
181
|
+
const groups = this.groupByTitle(items);
|
|
182
|
+
const duplicateGroups = groups.filter(g => g.duplicates.length > 0);
|
|
183
|
+
|
|
184
|
+
if (duplicateGroups.length === 0) {
|
|
185
|
+
this.logger.log(` ✅ No duplicates found!`);
|
|
186
|
+
return {
|
|
187
|
+
groups: [],
|
|
188
|
+
totalItems: items.length,
|
|
189
|
+
duplicateCount: 0,
|
|
190
|
+
closedCount: 0,
|
|
191
|
+
};
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
this.logger.log(` Detected ${duplicateGroups.length} duplicate groups:\n`);
|
|
195
|
+
|
|
196
|
+
// 3. Display groups
|
|
197
|
+
for (let i = 0; i < duplicateGroups.length; i++) {
|
|
198
|
+
const group = duplicateGroups[i];
|
|
199
|
+
this.logger.log(` 📋 Group ${i + 1}: "${group.title.substring(0, 50)}..."`);
|
|
200
|
+
this.logger.log(` - #${group.keepItem.id} (KEEP) - Created ${group.keepItem.createdDate.split('T')[0]}`);
|
|
201
|
+
for (const dup of group.duplicates) {
|
|
202
|
+
this.logger.log(` - #${dup.id} (CLOSE) - Created ${dup.createdDate.split('T')[0]} - DUPLICATE`);
|
|
203
|
+
}
|
|
204
|
+
this.logger.log('');
|
|
205
|
+
}
|
|
206
|
+
|
|
207
|
+
const totalDuplicates = duplicateGroups.reduce((sum, g) => sum + g.duplicates.length, 0);
|
|
208
|
+
|
|
209
|
+
if (dryRun) {
|
|
210
|
+
this.logger.log(`\n✅ Dry run complete!`);
|
|
211
|
+
this.logger.log(` Total work items: ${items.length}`);
|
|
212
|
+
this.logger.log(` Duplicate groups: ${duplicateGroups.length}`);
|
|
213
|
+
this.logger.log(` Work items to close: ${totalDuplicates}`);
|
|
214
|
+
this.logger.log(`\n⚠️ This was a DRY RUN - no changes made.`);
|
|
215
|
+
|
|
216
|
+
return {
|
|
217
|
+
groups: duplicateGroups,
|
|
218
|
+
totalItems: items.length,
|
|
219
|
+
duplicateCount: totalDuplicates,
|
|
220
|
+
closedCount: 0,
|
|
221
|
+
};
|
|
222
|
+
}
|
|
223
|
+
|
|
224
|
+
// 4. Close duplicates
|
|
225
|
+
let closedCount = 0;
|
|
226
|
+
this.logger.log(`🗑️ Closing duplicates...`);
|
|
227
|
+
|
|
228
|
+
for (const group of duplicateGroups) {
|
|
229
|
+
const result = await this.closeDuplicates(group.duplicates, group.keepItem.id);
|
|
230
|
+
closedCount += result.closedCount;
|
|
231
|
+
}
|
|
232
|
+
|
|
233
|
+
this.logger.log(`\n✅ Cleanup complete!`);
|
|
234
|
+
this.logger.log(` Closed: ${closedCount} duplicates`);
|
|
235
|
+
this.logger.log(` Kept: ${duplicateGroups.length} original work items`);
|
|
236
|
+
|
|
237
|
+
return {
|
|
238
|
+
groups: duplicateGroups,
|
|
239
|
+
totalItems: items.length,
|
|
240
|
+
duplicateCount: totalDuplicates,
|
|
241
|
+
closedCount,
|
|
242
|
+
};
|
|
243
|
+
}
|
|
244
|
+
|
|
245
|
+
/**
|
|
246
|
+
* Group work items by title
|
|
247
|
+
*/
|
|
248
|
+
private groupByTitle(items: AdoWorkItem[]): DuplicateGroup[] {
|
|
249
|
+
const titleMap = new Map<string, AdoWorkItem[]>();
|
|
250
|
+
|
|
251
|
+
for (const item of items) {
|
|
252
|
+
const existing = titleMap.get(item.title) || [];
|
|
253
|
+
existing.push(item);
|
|
254
|
+
titleMap.set(item.title, existing);
|
|
255
|
+
}
|
|
256
|
+
|
|
257
|
+
const groups: DuplicateGroup[] = [];
|
|
258
|
+
|
|
259
|
+
for (const [title, groupItems] of titleMap) {
|
|
260
|
+
// Sort by ID (lowest = oldest)
|
|
261
|
+
const sorted = groupItems.sort((a, b) => a.id - b.id);
|
|
262
|
+
|
|
263
|
+
groups.push({
|
|
264
|
+
title,
|
|
265
|
+
items: sorted,
|
|
266
|
+
keepItem: sorted[0],
|
|
267
|
+
duplicates: sorted.slice(1),
|
|
268
|
+
});
|
|
269
|
+
}
|
|
270
|
+
|
|
271
|
+
return groups;
|
|
272
|
+
}
|
|
273
|
+
|
|
274
|
+
/**
|
|
275
|
+
* Search for work items using WIQL
|
|
276
|
+
*/
|
|
277
|
+
private async searchWorkItems(titlePattern: string): Promise<AdoWorkItem[]> {
|
|
278
|
+
if (!this.org || !this.pat) {
|
|
279
|
+
throw new Error('ADO credentials not configured');
|
|
280
|
+
}
|
|
281
|
+
|
|
282
|
+
const wiql = {
|
|
283
|
+
query: `SELECT [System.Id], [System.Title], [System.State], [System.CreatedDate]
|
|
284
|
+
FROM WorkItems
|
|
285
|
+
WHERE [System.TeamProject] = '${this.project}'
|
|
286
|
+
AND [System.Title] CONTAINS '${titlePattern}'
|
|
287
|
+
ORDER BY [System.Id] ASC`,
|
|
288
|
+
};
|
|
289
|
+
|
|
290
|
+
const auth = Buffer.from(`:${this.pat}`).toString('base64');
|
|
291
|
+
const url = `https://dev.azure.com/${this.org}/${this.project}/_apis/wit/wiql?api-version=7.1`;
|
|
292
|
+
|
|
293
|
+
const response = await fetch(url, {
|
|
294
|
+
method: 'POST',
|
|
295
|
+
headers: {
|
|
296
|
+
Authorization: `Basic ${auth}`,
|
|
297
|
+
'Content-Type': 'application/json',
|
|
298
|
+
},
|
|
299
|
+
body: JSON.stringify(wiql),
|
|
300
|
+
});
|
|
301
|
+
|
|
302
|
+
if (!response.ok) {
|
|
303
|
+
throw new Error(`WIQL query failed: ${response.status}`);
|
|
304
|
+
}
|
|
305
|
+
|
|
306
|
+
const data = await response.json();
|
|
307
|
+
const workItemIds = data.workItems?.map((wi: any) => wi.id) || [];
|
|
308
|
+
|
|
309
|
+
if (workItemIds.length === 0) {
|
|
310
|
+
return [];
|
|
311
|
+
}
|
|
312
|
+
|
|
313
|
+
// Fetch full work item details
|
|
314
|
+
return this.getWorkItemDetails(workItemIds);
|
|
315
|
+
}
|
|
316
|
+
|
|
317
|
+
/**
|
|
318
|
+
* Get work item details by IDs
|
|
319
|
+
*/
|
|
320
|
+
private async getWorkItemDetails(ids: number[]): Promise<AdoWorkItem[]> {
|
|
321
|
+
if (ids.length === 0) return [];
|
|
322
|
+
|
|
323
|
+
const auth = Buffer.from(`:${this.pat}`).toString('base64');
|
|
324
|
+
const url = `https://dev.azure.com/${this.org}/_apis/wit/workitems?ids=${ids.join(',')}&api-version=7.1`;
|
|
325
|
+
|
|
326
|
+
const response = await fetch(url, {
|
|
327
|
+
headers: {
|
|
328
|
+
Authorization: `Basic ${auth}`,
|
|
329
|
+
'Content-Type': 'application/json',
|
|
330
|
+
},
|
|
331
|
+
});
|
|
332
|
+
|
|
333
|
+
if (!response.ok) {
|
|
334
|
+
throw new Error(`Failed to get work items: ${response.status}`);
|
|
335
|
+
}
|
|
336
|
+
|
|
337
|
+
const data = await response.json();
|
|
338
|
+
return (data.value || []).map((wi: any) => ({
|
|
339
|
+
id: wi.id,
|
|
340
|
+
title: wi.fields['System.Title'],
|
|
341
|
+
state: wi.fields['System.State'],
|
|
342
|
+
createdDate: wi.fields['System.CreatedDate'],
|
|
343
|
+
url: wi._links?.html?.href,
|
|
344
|
+
}));
|
|
345
|
+
}
|
|
346
|
+
|
|
347
|
+
/**
|
|
348
|
+
* Close a work item with duplicate comment
|
|
349
|
+
*/
|
|
350
|
+
private async closeWorkItem(workItemId: number, originalId: number): Promise<void> {
|
|
351
|
+
const auth = Buffer.from(`:${this.pat}`).toString('base64');
|
|
352
|
+
const url = `https://dev.azure.com/${this.org}/_apis/wit/workitems/${workItemId}?api-version=7.1`;
|
|
353
|
+
|
|
354
|
+
const comment = `## Duplicate of #${originalId}
|
|
355
|
+
|
|
356
|
+
This work item was automatically closed by SpecWeave cleanup because it is a duplicate.
|
|
357
|
+
|
|
358
|
+
The original work item (#${originalId}) contains the same content and should be used for tracking instead.
|
|
359
|
+
|
|
360
|
+
---
|
|
361
|
+
🤖 Auto-closed by SpecWeave Duplicate Cleanup`;
|
|
362
|
+
|
|
363
|
+
const operations = [
|
|
364
|
+
{
|
|
365
|
+
op: 'add',
|
|
366
|
+
path: '/fields/System.State',
|
|
367
|
+
value: 'Closed',
|
|
368
|
+
},
|
|
369
|
+
{
|
|
370
|
+
op: 'add',
|
|
371
|
+
path: '/fields/System.History',
|
|
372
|
+
value: comment,
|
|
373
|
+
},
|
|
374
|
+
];
|
|
375
|
+
|
|
376
|
+
const response = await fetch(url, {
|
|
377
|
+
method: 'PATCH',
|
|
378
|
+
headers: {
|
|
379
|
+
Authorization: `Basic ${auth}`,
|
|
380
|
+
'Content-Type': 'application/json-patch+json',
|
|
381
|
+
},
|
|
382
|
+
body: JSON.stringify(operations),
|
|
383
|
+
});
|
|
384
|
+
|
|
385
|
+
if (!response.ok) {
|
|
386
|
+
const error = await response.text();
|
|
387
|
+
throw new Error(`Failed to close work item: ${response.status} - ${error}`);
|
|
388
|
+
}
|
|
389
|
+
}
|
|
390
|
+
}
|
|
391
|
+
|
|
392
|
+
/**
|
|
393
|
+
* Convenience function for quick duplicate cleanup
|
|
394
|
+
*/
|
|
395
|
+
export async function cleanupAdoDuplicates(
|
|
396
|
+
featureId: string,
|
|
397
|
+
dryRun: boolean = false
|
|
398
|
+
): Promise<{
|
|
399
|
+
groups: DuplicateGroup[];
|
|
400
|
+
totalItems: number;
|
|
401
|
+
duplicateCount: number;
|
|
402
|
+
closedCount: number;
|
|
403
|
+
}> {
|
|
404
|
+
const detector = new AdoDuplicateDetector();
|
|
405
|
+
return detector.cleanupFeatureDuplicates(featureId, dryRun);
|
|
406
|
+
}
|
|
407
|
+
|
|
408
|
+
export default AdoDuplicateDetector;
|