specweave 0.21.2 → 0.22.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CLAUDE.md +429 -10
- package/README.md +33 -3
- package/dist/plugins/specweave-github/lib/CodeValidator.d.ts +101 -0
- package/dist/plugins/specweave-github/lib/CodeValidator.d.ts.map +1 -0
- package/dist/plugins/specweave-github/lib/CodeValidator.js +219 -0
- package/dist/plugins/specweave-github/lib/CodeValidator.js.map +1 -0
- package/dist/plugins/specweave-github/lib/IssueStateManager.d.ts +98 -0
- package/dist/plugins/specweave-github/lib/IssueStateManager.d.ts.map +1 -0
- package/dist/plugins/specweave-github/lib/IssueStateManager.js +146 -0
- package/dist/plugins/specweave-github/lib/IssueStateManager.js.map +1 -0
- package/dist/plugins/specweave-github/lib/ThreeLayerSyncManager.d.ts +182 -0
- package/dist/plugins/specweave-github/lib/ThreeLayerSyncManager.d.ts.map +1 -0
- package/dist/plugins/specweave-github/lib/ThreeLayerSyncManager.js +603 -0
- package/dist/plugins/specweave-github/lib/ThreeLayerSyncManager.js.map +1 -0
- package/dist/plugins/specweave-github/lib/types.d.ts +34 -0
- package/dist/plugins/specweave-github/lib/types.d.ts.map +1 -1
- package/dist/plugins/specweave-github/lib/user-story-issue-builder.d.ts.map +1 -1
- package/dist/plugins/specweave-github/lib/user-story-issue-builder.js +6 -0
- package/dist/plugins/specweave-github/lib/user-story-issue-builder.js.map +1 -1
- package/dist/src/cli/commands/check-hooks.d.ts +11 -0
- package/dist/src/cli/commands/check-hooks.d.ts.map +1 -0
- package/dist/src/cli/commands/check-hooks.js +144 -0
- package/dist/src/cli/commands/check-hooks.js.map +1 -0
- package/dist/src/cli/commands/cicd-monitor.js +3 -3
- package/dist/src/cli/commands/cicd-monitor.js.map +1 -1
- package/dist/src/cli/commands/import-docs.js +2 -2
- package/dist/src/cli/commands/import-docs.js.map +1 -1
- package/dist/src/cli/commands/init-multiproject.js +4 -4
- package/dist/src/cli/commands/init-multiproject.js.map +1 -1
- package/dist/src/cli/commands/init.d.ts.map +1 -1
- package/dist/src/cli/commands/init.js +60 -5
- package/dist/src/cli/commands/init.js.map +1 -1
- package/dist/src/cli/commands/migrate-to-multiproject.js +3 -3
- package/dist/src/cli/commands/migrate-to-multiproject.js.map +1 -1
- package/dist/src/cli/commands/plan/agent-invoker.d.ts +79 -0
- package/dist/src/cli/commands/plan/agent-invoker.d.ts.map +1 -0
- package/dist/src/cli/commands/plan/agent-invoker.js +383 -0
- package/dist/src/cli/commands/plan/agent-invoker.js.map +1 -0
- package/dist/src/cli/commands/plan/increment-detector.d.ts +27 -0
- package/dist/src/cli/commands/plan/increment-detector.d.ts.map +1 -0
- package/dist/src/cli/commands/plan/increment-detector.js +159 -0
- package/dist/src/cli/commands/plan/increment-detector.js.map +1 -0
- package/dist/src/cli/commands/plan/plan-orchestrator.d.ts +45 -0
- package/dist/src/cli/commands/plan/plan-orchestrator.d.ts.map +1 -0
- package/dist/src/cli/commands/plan/plan-orchestrator.js +229 -0
- package/dist/src/cli/commands/plan/plan-orchestrator.js.map +1 -0
- package/dist/src/cli/commands/plan/plan-validator.d.ts +36 -0
- package/dist/src/cli/commands/plan/plan-validator.d.ts.map +1 -0
- package/dist/src/cli/commands/plan/plan-validator.js +174 -0
- package/dist/src/cli/commands/plan/plan-validator.js.map +1 -0
- package/dist/src/cli/commands/plan/types.d.ts +170 -0
- package/dist/src/cli/commands/plan/types.d.ts.map +1 -0
- package/dist/src/cli/commands/plan/types.js +42 -0
- package/dist/src/cli/commands/plan/types.js.map +1 -0
- package/dist/src/cli/commands/plan-command.d.ts +16 -0
- package/dist/src/cli/commands/plan-command.d.ts.map +1 -0
- package/dist/src/cli/commands/plan-command.js +127 -0
- package/dist/src/cli/commands/plan-command.js.map +1 -0
- package/dist/src/cli/commands/switch-project.js +3 -3
- package/dist/src/cli/commands/switch-project.js.map +1 -1
- package/dist/src/cli/commands/validate-parent-repo.js +1 -1
- package/dist/src/cli/commands/validate-parent-repo.js.map +1 -1
- package/dist/src/config/ConfigManager.d.ts +69 -0
- package/dist/src/config/ConfigManager.d.ts.map +1 -0
- package/dist/src/config/ConfigManager.js +130 -0
- package/dist/src/config/ConfigManager.js.map +1 -0
- package/dist/src/config/types.d.ts +1357 -0
- package/dist/src/config/types.d.ts.map +1 -0
- package/dist/src/config/types.js +67 -0
- package/dist/src/config/types.js.map +1 -0
- package/dist/src/core/brownfield/importer.d.ts +1 -1
- package/dist/src/core/brownfield/importer.d.ts.map +1 -1
- package/dist/src/core/brownfield/importer.js +3 -3
- package/dist/src/core/brownfield/importer.js.map +1 -1
- package/dist/src/core/cicd/config-loader.d.ts +1 -1
- package/dist/src/core/cicd/config-loader.d.ts.map +1 -1
- package/dist/src/core/cicd/index.d.ts +6 -6
- package/dist/src/core/cicd/index.d.ts.map +1 -1
- package/dist/src/core/cicd/index.js +6 -6
- package/dist/src/core/cicd/index.js.map +1 -1
- package/dist/src/core/cicd/monitor-service.d.ts +3 -3
- package/dist/src/core/cicd/monitor-service.d.ts.map +1 -1
- package/dist/src/core/cicd/monitor-service.js +3 -3
- package/dist/src/core/cicd/monitor-service.js.map +1 -1
- package/dist/src/core/cicd/notifier.d.ts +1 -1
- package/dist/src/core/cicd/notifier.d.ts.map +1 -1
- package/dist/src/core/cicd/state-manager.d.ts +1 -1
- package/dist/src/core/cicd/state-manager.d.ts.map +1 -1
- package/dist/src/core/cicd/state-manager.js +1 -1
- package/dist/src/core/cicd/state-manager.js.map +1 -1
- package/dist/src/core/cicd/workflow-monitor.d.ts +1 -1
- package/dist/src/core/cicd/workflow-monitor.d.ts.map +1 -1
- package/dist/src/core/cicd/workflow-monitor.js +1 -1
- package/dist/src/core/cicd/workflow-monitor.js.map +1 -1
- package/dist/src/core/cost-tracker.d.ts +2 -2
- package/dist/src/core/cost-tracker.d.ts.map +1 -1
- package/dist/src/core/cost-tracker.js +1 -1
- package/dist/src/core/cost-tracker.js.map +1 -1
- package/dist/src/core/hooks/HealthReporter.d.ts +55 -0
- package/dist/src/core/hooks/HealthReporter.d.ts.map +1 -0
- package/dist/src/core/hooks/HealthReporter.js +268 -0
- package/dist/src/core/hooks/HealthReporter.js.map +1 -0
- package/dist/src/core/hooks/HookAutoFixer.d.ts +41 -0
- package/dist/src/core/hooks/HookAutoFixer.d.ts.map +1 -0
- package/dist/src/core/hooks/HookAutoFixer.js +222 -0
- package/dist/src/core/hooks/HookAutoFixer.js.map +1 -0
- package/dist/src/core/hooks/HookExecutor.d.ts +57 -0
- package/dist/src/core/hooks/HookExecutor.d.ts.map +1 -0
- package/dist/src/core/hooks/HookExecutor.js +287 -0
- package/dist/src/core/hooks/HookExecutor.js.map +1 -0
- package/dist/src/core/hooks/HookHealthChecker.d.ts +51 -0
- package/dist/src/core/hooks/HookHealthChecker.d.ts.map +1 -0
- package/dist/src/core/hooks/HookHealthChecker.js +212 -0
- package/dist/src/core/hooks/HookHealthChecker.js.map +1 -0
- package/dist/src/core/hooks/HookScanner.d.ts +65 -0
- package/dist/src/core/hooks/HookScanner.d.ts.map +1 -0
- package/dist/src/core/hooks/HookScanner.js +214 -0
- package/dist/src/core/hooks/HookScanner.js.map +1 -0
- package/dist/src/core/hooks/types.d.ts +281 -0
- package/dist/src/core/hooks/types.d.ts.map +1 -0
- package/dist/src/core/hooks/types.js +10 -0
- package/dist/src/core/hooks/types.js.map +1 -0
- package/dist/src/core/iac/index.d.ts +10 -0
- package/dist/src/core/iac/index.d.ts.map +1 -0
- package/dist/src/core/iac/index.js +11 -0
- package/dist/src/core/iac/index.js.map +1 -0
- package/dist/src/core/iac/template-engine.d.ts +77 -0
- package/dist/src/core/iac/template-engine.d.ts.map +1 -0
- package/dist/src/core/iac/template-engine.js +182 -0
- package/dist/src/core/iac/template-engine.js.map +1 -0
- package/dist/src/core/increment/ac-status-manager.d.ts +115 -0
- package/dist/src/core/increment/ac-status-manager.d.ts.map +1 -0
- package/dist/src/core/increment/ac-status-manager.js +343 -0
- package/dist/src/core/increment/ac-status-manager.js.map +1 -0
- package/dist/src/core/increment/auto-transition-manager.d.ts +60 -0
- package/dist/src/core/increment/auto-transition-manager.d.ts.map +1 -0
- package/dist/src/core/increment/auto-transition-manager.js +192 -0
- package/dist/src/core/increment/auto-transition-manager.js.map +1 -0
- package/dist/src/core/increment/limits.d.ts +1 -1
- package/dist/src/core/increment/limits.d.ts.map +1 -1
- package/dist/src/core/increment/limits.js +2 -2
- package/dist/src/core/increment/limits.js.map +1 -1
- package/dist/src/core/increment/spec-sync-manager.d.ts +177 -0
- package/dist/src/core/increment/spec-sync-manager.d.ts.map +1 -0
- package/dist/src/core/increment/spec-sync-manager.js +496 -0
- package/dist/src/core/increment/spec-sync-manager.js.map +1 -0
- package/dist/src/core/increment/status-auto-transition.d.ts +46 -0
- package/dist/src/core/increment/status-auto-transition.d.ts.map +1 -0
- package/dist/src/core/increment/status-auto-transition.js +178 -0
- package/dist/src/core/increment/status-auto-transition.js.map +1 -0
- package/dist/src/core/increment/task-state-manager.d.ts +75 -0
- package/dist/src/core/increment/task-state-manager.d.ts.map +1 -0
- package/dist/src/core/increment/task-state-manager.js +117 -0
- package/dist/src/core/increment/task-state-manager.js.map +1 -0
- package/dist/src/core/living-docs/CodeValidator.d.ts +68 -0
- package/dist/src/core/living-docs/CodeValidator.d.ts.map +1 -0
- package/dist/src/core/living-docs/CodeValidator.js +160 -0
- package/dist/src/core/living-docs/CodeValidator.js.map +1 -0
- package/dist/src/core/living-docs/CompletionPropagator.d.ts +84 -0
- package/dist/src/core/living-docs/CompletionPropagator.d.ts.map +1 -0
- package/dist/src/core/living-docs/CompletionPropagator.js +206 -0
- package/dist/src/core/living-docs/CompletionPropagator.js.map +1 -0
- package/dist/src/core/living-docs/ProjectDetector.d.ts +29 -0
- package/dist/src/core/living-docs/ProjectDetector.d.ts.map +1 -0
- package/dist/src/core/living-docs/ProjectDetector.js +94 -0
- package/dist/src/core/living-docs/ProjectDetector.js.map +1 -0
- package/dist/src/core/living-docs/SpecDistributor.d.ts +60 -0
- package/dist/src/core/living-docs/SpecDistributor.d.ts.map +1 -0
- package/dist/src/core/living-docs/SpecDistributor.js +228 -0
- package/dist/src/core/living-docs/SpecDistributor.js.map +1 -0
- package/dist/src/core/living-docs/ThreeLayerSyncManager.d.ts +116 -0
- package/dist/src/core/living-docs/ThreeLayerSyncManager.d.ts.map +1 -0
- package/dist/src/core/living-docs/ThreeLayerSyncManager.js +356 -0
- package/dist/src/core/living-docs/ThreeLayerSyncManager.js.map +1 -0
- package/dist/src/core/living-docs/hierarchy-mapper.d.ts.map +1 -1
- package/dist/src/core/living-docs/hierarchy-mapper.js +2 -1
- package/dist/src/core/living-docs/hierarchy-mapper.js.map +1 -1
- package/dist/src/core/living-docs/index.d.ts +1 -1
- package/dist/src/core/living-docs/index.d.ts.map +1 -1
- package/dist/src/core/living-docs/index.js +5 -1
- package/dist/src/core/living-docs/index.js.map +1 -1
- package/dist/src/core/living-docs/project-detector.d.ts.map +1 -1
- package/dist/src/core/living-docs/project-detector.js +38 -0
- package/dist/src/core/living-docs/project-detector.js.map +1 -1
- package/dist/src/core/living-docs/types.d.ts +70 -300
- package/dist/src/core/living-docs/types.d.ts.map +1 -1
- package/dist/src/core/living-docs/types.js +2 -10
- package/dist/src/core/living-docs/types.js.map +1 -1
- package/dist/src/core/project-manager.d.ts +1 -1
- package/dist/src/core/project-manager.d.ts.map +1 -1
- package/dist/src/core/project-manager.js +2 -2
- package/dist/src/core/project-manager.js.map +1 -1
- package/dist/src/core/qa/quality-gate-decider.d.ts +1 -1
- package/dist/src/core/qa/quality-gate-decider.d.ts.map +1 -1
- package/dist/src/core/qa/risk-calculator.d.ts +1 -1
- package/dist/src/core/qa/risk-calculator.d.ts.map +1 -1
- package/dist/src/core/repo-structure/setup-summary.d.ts +1 -1
- package/dist/src/core/repo-structure/setup-summary.d.ts.map +1 -1
- package/dist/src/core/rfc-generator-v2.d.ts +1 -1
- package/dist/src/core/rfc-generator-v2.d.ts.map +1 -1
- package/dist/src/core/rfc-generator-v2.js +1 -1
- package/dist/src/core/rfc-generator-v2.js.map +1 -1
- package/dist/src/core/serverless/context-detector.d.ts +12 -0
- package/dist/src/core/serverless/context-detector.d.ts.map +1 -0
- package/dist/src/core/serverless/context-detector.js +213 -0
- package/dist/src/core/serverless/context-detector.js.map +1 -0
- package/dist/src/core/serverless/cost-comparison.d.ts +73 -0
- package/dist/src/core/serverless/cost-comparison.d.ts.map +1 -0
- package/dist/src/core/serverless/cost-comparison.js +198 -0
- package/dist/src/core/serverless/cost-comparison.js.map +1 -0
- package/dist/src/core/serverless/cost-estimator.d.ts +69 -0
- package/dist/src/core/serverless/cost-estimator.d.ts.map +1 -0
- package/dist/src/core/serverless/cost-estimator.js +127 -0
- package/dist/src/core/serverless/cost-estimator.js.map +1 -0
- package/dist/src/core/serverless/cost-optimizer.d.ts +57 -0
- package/dist/src/core/serverless/cost-optimizer.d.ts.map +1 -0
- package/dist/src/core/serverless/cost-optimizer.js +221 -0
- package/dist/src/core/serverless/cost-optimizer.js.map +1 -0
- package/dist/src/core/serverless/index.d.ts +20 -0
- package/dist/src/core/serverless/index.d.ts.map +1 -0
- package/dist/src/core/serverless/index.js +26 -0
- package/dist/src/core/serverless/index.js.map +1 -0
- package/dist/src/core/serverless/learning-path-recommender.d.ts +152 -0
- package/dist/src/core/serverless/learning-path-recommender.d.ts.map +1 -0
- package/dist/src/core/serverless/learning-path-recommender.js +389 -0
- package/dist/src/core/serverless/learning-path-recommender.js.map +1 -0
- package/dist/src/core/serverless/platform-data-loader.d.ts +22 -0
- package/dist/src/core/serverless/platform-data-loader.d.ts.map +1 -0
- package/dist/src/core/serverless/platform-data-loader.js +49 -0
- package/dist/src/core/serverless/platform-data-loader.js.map +1 -0
- package/dist/src/core/serverless/platform-selector.d.ts +20 -0
- package/dist/src/core/serverless/platform-selector.d.ts.map +1 -0
- package/dist/src/core/serverless/platform-selector.js +279 -0
- package/dist/src/core/serverless/platform-selector.js.map +1 -0
- package/dist/src/core/serverless/recommendation-formatter.d.ts +24 -0
- package/dist/src/core/serverless/recommendation-formatter.d.ts.map +1 -0
- package/dist/src/core/serverless/recommendation-formatter.js +70 -0
- package/dist/src/core/serverless/recommendation-formatter.js.map +1 -0
- package/dist/src/core/serverless/suitability-analyzer.d.ts +22 -0
- package/dist/src/core/serverless/suitability-analyzer.d.ts.map +1 -0
- package/dist/src/core/serverless/suitability-analyzer.js +262 -0
- package/dist/src/core/serverless/suitability-analyzer.js.map +1 -0
- package/dist/src/core/serverless/types.d.ts +96 -0
- package/dist/src/core/serverless/types.d.ts.map +1 -0
- package/dist/src/core/serverless/types.js +5 -0
- package/dist/src/core/serverless/types.js.map +1 -0
- package/dist/src/core/sync/bidirectional-engine.d.ts +1 -1
- package/dist/src/core/sync/bidirectional-engine.d.ts.map +1 -1
- package/dist/src/core/sync/enhanced-content-builder.d.ts +1 -1
- package/dist/src/core/sync/enhanced-content-builder.d.ts.map +1 -1
- package/dist/src/core/sync/profile-manager.d.ts +1 -1
- package/dist/src/core/sync/profile-manager.d.ts.map +1 -1
- package/dist/src/core/sync/profile-selector.d.ts +1 -1
- package/dist/src/core/sync/profile-selector.d.ts.map +1 -1
- package/dist/src/core/sync/profile-selector.js +1 -1
- package/dist/src/core/sync/profile-selector.js.map +1 -1
- package/dist/src/core/sync/project-context.d.ts +1 -1
- package/dist/src/core/sync/project-context.d.ts.map +1 -1
- package/dist/src/core/sync/rate-limiter.d.ts +1 -1
- package/dist/src/core/sync/rate-limiter.d.ts.map +1 -1
- package/dist/src/core/sync/status-sync-engine.d.ts +2 -2
- package/dist/src/core/sync/status-sync-engine.d.ts.map +1 -1
- package/dist/src/core/sync/status-sync-engine.js +2 -2
- package/dist/src/core/sync/status-sync-engine.js.map +1 -1
- package/dist/src/core/sync/time-range-selector.d.ts +1 -1
- package/dist/src/core/sync/time-range-selector.d.ts.map +1 -1
- package/dist/src/core/sync/time-range-selector.js +1 -1
- package/dist/src/core/sync/time-range-selector.js.map +1 -1
- package/dist/src/core/types/config.d.ts +23 -0
- package/dist/src/core/types/config.d.ts.map +1 -1
- package/dist/src/core/types/config.js +10 -0
- package/dist/src/core/types/config.js.map +1 -1
- package/dist/src/core/types/increment-metadata.d.ts +27 -0
- package/dist/src/core/types/increment-metadata.d.ts.map +1 -1
- package/dist/src/core/types/increment-metadata.js +45 -1
- package/dist/src/core/types/increment-metadata.js.map +1 -1
- package/dist/src/core/types/sync-profile.d.ts +2 -0
- package/dist/src/core/types/sync-profile.d.ts.map +1 -1
- package/dist/src/core/types/sync-profile.js.map +1 -1
- package/dist/src/core/validation/increment-structure-validator.d.ts +47 -0
- package/dist/src/core/validation/increment-structure-validator.d.ts.map +1 -0
- package/dist/src/core/validation/increment-structure-validator.js +187 -0
- package/dist/src/core/validation/increment-structure-validator.js.map +1 -0
- package/dist/src/core/validation/three-file-validator.d.ts +82 -0
- package/dist/src/core/validation/three-file-validator.d.ts.map +1 -0
- package/dist/src/core/validation/three-file-validator.js +320 -0
- package/dist/src/core/validation/three-file-validator.js.map +1 -0
- package/dist/src/core/workflow/phase-detector.d.ts +103 -0
- package/dist/src/core/workflow/phase-detector.d.ts.map +1 -0
- package/dist/src/core/workflow/phase-detector.js +704 -0
- package/dist/src/core/workflow/phase-detector.js.map +1 -0
- package/dist/src/core/workflow/types.d.ts +153 -0
- package/dist/src/core/workflow/types.d.ts.map +1 -0
- package/dist/src/core/workflow/types.js +47 -0
- package/dist/src/core/workflow/types.js.map +1 -0
- package/dist/src/init/ArchitecturePresenter.d.ts +47 -0
- package/dist/src/init/ArchitecturePresenter.d.ts.map +1 -0
- package/dist/src/init/ArchitecturePresenter.js +180 -0
- package/dist/src/init/ArchitecturePresenter.js.map +1 -0
- package/dist/src/init/InitFlow.d.ts +37 -0
- package/dist/src/init/InitFlow.d.ts.map +1 -0
- package/dist/src/init/InitFlow.js +238 -0
- package/dist/src/init/InitFlow.js.map +1 -0
- package/dist/src/init/architecture/ArchitectureDecisionEngine.d.ts +107 -0
- package/dist/src/init/architecture/ArchitectureDecisionEngine.d.ts.map +1 -0
- package/dist/src/init/architecture/ArchitectureDecisionEngine.js +405 -0
- package/dist/src/init/architecture/ArchitectureDecisionEngine.js.map +1 -0
- package/dist/src/init/architecture/CloudCreditsDatabase.d.ts +11 -0
- package/dist/src/init/architecture/CloudCreditsDatabase.d.ts.map +1 -0
- package/dist/src/init/architecture/CloudCreditsDatabase.js +92 -0
- package/dist/src/init/architecture/CloudCreditsDatabase.js.map +1 -0
- package/dist/src/init/architecture/CostEstimator.d.ts +52 -0
- package/dist/src/init/architecture/CostEstimator.d.ts.map +1 -0
- package/dist/src/init/architecture/CostEstimator.js +107 -0
- package/dist/src/init/architecture/CostEstimator.js.map +1 -0
- package/dist/src/init/architecture/InfrastructureMapper.d.ts +41 -0
- package/dist/src/init/architecture/InfrastructureMapper.d.ts.map +1 -0
- package/dist/src/init/architecture/InfrastructureMapper.js +140 -0
- package/dist/src/init/architecture/InfrastructureMapper.js.map +1 -0
- package/dist/src/init/architecture/ProjectGenerator.d.ts +44 -0
- package/dist/src/init/architecture/ProjectGenerator.d.ts.map +1 -0
- package/dist/src/init/architecture/ProjectGenerator.js +216 -0
- package/dist/src/init/architecture/ProjectGenerator.js.map +1 -0
- package/dist/src/init/architecture/types.d.ts +251 -0
- package/dist/src/init/architecture/types.d.ts.map +1 -0
- package/dist/src/init/architecture/types.js +54 -0
- package/dist/src/init/architecture/types.js.map +1 -0
- package/dist/src/init/compliance/ComplianceDetector.d.ts +17 -0
- package/dist/src/init/compliance/ComplianceDetector.d.ts.map +1 -0
- package/dist/src/init/compliance/ComplianceDetector.js +64 -0
- package/dist/src/init/compliance/ComplianceDetector.js.map +1 -0
- package/dist/src/init/compliance/standards-database.d.ts +48 -0
- package/dist/src/init/compliance/standards-database.d.ts.map +1 -0
- package/dist/src/init/compliance/standards-database.js +506 -0
- package/dist/src/init/compliance/standards-database.js.map +1 -0
- package/dist/src/init/compliance/types.d.ts +91 -0
- package/dist/src/init/compliance/types.d.ts.map +1 -0
- package/dist/src/init/compliance/types.js +43 -0
- package/dist/src/init/compliance/types.js.map +1 -0
- package/dist/src/init/repo/GitHubAPIClient.d.ts +51 -0
- package/dist/src/init/repo/GitHubAPIClient.d.ts.map +1 -0
- package/dist/src/init/repo/GitHubAPIClient.js +144 -0
- package/dist/src/init/repo/GitHubAPIClient.js.map +1 -0
- package/dist/src/init/repo/RepositorySelector.d.ts +45 -0
- package/dist/src/init/repo/RepositorySelector.d.ts.map +1 -0
- package/dist/src/init/repo/RepositorySelector.js +106 -0
- package/dist/src/init/repo/RepositorySelector.js.map +1 -0
- package/dist/src/init/repo/types.d.ts +95 -0
- package/dist/src/init/repo/types.d.ts.map +1 -0
- package/dist/src/init/repo/types.js +25 -0
- package/dist/src/init/repo/types.js.map +1 -0
- package/dist/src/init/research/CompetitorAnalyzer.d.ts +79 -0
- package/dist/src/init/research/CompetitorAnalyzer.d.ts.map +1 -0
- package/dist/src/init/research/CompetitorAnalyzer.js +265 -0
- package/dist/src/init/research/CompetitorAnalyzer.js.map +1 -0
- package/dist/src/init/research/MarketDetector.d.ts +62 -0
- package/dist/src/init/research/MarketDetector.d.ts.map +1 -0
- package/dist/src/init/research/MarketDetector.js +247 -0
- package/dist/src/init/research/MarketDetector.js.map +1 -0
- package/dist/src/init/research/OpportunityScorer.d.ts +58 -0
- package/dist/src/init/research/OpportunityScorer.d.ts.map +1 -0
- package/dist/src/init/research/OpportunityScorer.js +194 -0
- package/dist/src/init/research/OpportunityScorer.js.map +1 -0
- package/dist/src/init/research/QuestionGenerator.d.ts +68 -0
- package/dist/src/init/research/QuestionGenerator.d.ts.map +1 -0
- package/dist/src/init/research/QuestionGenerator.js +244 -0
- package/dist/src/init/research/QuestionGenerator.js.map +1 -0
- package/dist/src/init/research/ReportGenerator.d.ts +36 -0
- package/dist/src/init/research/ReportGenerator.d.ts.map +1 -0
- package/dist/src/init/research/ReportGenerator.js +125 -0
- package/dist/src/init/research/ReportGenerator.js.map +1 -0
- package/dist/src/init/research/VisionAnalyzer.d.ts +129 -0
- package/dist/src/init/research/VisionAnalyzer.d.ts.map +1 -0
- package/dist/src/init/research/VisionAnalyzer.js +212 -0
- package/dist/src/init/research/VisionAnalyzer.js.map +1 -0
- package/dist/src/init/research/keyword-extractor.d.ts +78 -0
- package/dist/src/init/research/keyword-extractor.d.ts.map +1 -0
- package/dist/src/init/research/keyword-extractor.js +230 -0
- package/dist/src/init/research/keyword-extractor.js.map +1 -0
- package/dist/src/init/research/src/config/ConfigManager.d.ts +14 -0
- package/dist/src/init/research/src/config/ConfigManager.d.ts.map +1 -0
- package/dist/src/init/research/src/config/ConfigManager.js +45 -0
- package/dist/src/init/research/src/config/ConfigManager.js.map +1 -0
- package/dist/src/init/research/src/config/types.d.ts +102 -0
- package/dist/src/init/research/src/config/types.d.ts.map +1 -0
- package/dist/src/init/research/src/config/types.js +24 -0
- package/dist/src/init/research/src/config/types.js.map +1 -0
- package/dist/src/init/research/types.d.ts +183 -0
- package/dist/src/init/research/types.d.ts.map +1 -0
- package/dist/src/init/research/types.js +65 -0
- package/dist/src/init/research/types.js.map +1 -0
- package/dist/src/init/team/ServerlessSavingsCalculator.d.ts +136 -0
- package/dist/src/init/team/ServerlessSavingsCalculator.d.ts.map +1 -0
- package/dist/src/init/team/ServerlessSavingsCalculator.js +360 -0
- package/dist/src/init/team/ServerlessSavingsCalculator.js.map +1 -0
- package/dist/src/init/team/TeamRecommender.d.ts +122 -0
- package/dist/src/init/team/TeamRecommender.d.ts.map +1 -0
- package/dist/src/init/team/TeamRecommender.js +405 -0
- package/dist/src/init/team/TeamRecommender.js.map +1 -0
- package/dist/src/init/team/types.d.ts +95 -0
- package/dist/src/init/team/types.d.ts.map +1 -0
- package/dist/src/init/team/types.js +23 -0
- package/dist/src/init/team/types.js.map +1 -0
- package/dist/src/integrations/jira/jira-mapper.d.ts +1 -1
- package/dist/src/integrations/jira/jira-mapper.d.ts.map +1 -1
- package/dist/src/types/cost-tracking.d.ts +1 -1
- package/dist/src/types/cost-tracking.d.ts.map +1 -1
- package/dist/src/utils/cost-reporter.d.ts +2 -2
- package/dist/src/utils/cost-reporter.d.ts.map +1 -1
- package/dist/src/utils/docs-preview/config-generator.d.ts +1 -1
- package/dist/src/utils/docs-preview/config-generator.d.ts.map +1 -1
- package/dist/src/utils/docs-preview/config-generator.js +1 -1
- package/dist/src/utils/docs-preview/docusaurus-setup.d.ts +1 -1
- package/dist/src/utils/docs-preview/docusaurus-setup.d.ts.map +1 -1
- package/dist/src/utils/docs-preview/docusaurus-setup.js +4 -4
- package/dist/src/utils/docs-preview/docusaurus-setup.js.map +1 -1
- package/dist/src/utils/docs-preview/index.d.ts +6 -6
- package/dist/src/utils/docs-preview/index.d.ts.map +1 -1
- package/dist/src/utils/docs-preview/index.js +6 -6
- package/dist/src/utils/docs-preview/index.js.map +1 -1
- package/dist/src/utils/docs-preview/package-installer.d.ts +1 -1
- package/dist/src/utils/docs-preview/package-installer.d.ts.map +1 -1
- package/dist/src/utils/docs-preview/package-installer.js +1 -1
- package/dist/src/utils/docs-preview/package-installer.js.map +1 -1
- package/dist/src/utils/docs-preview/server-manager.d.ts +1 -1
- package/dist/src/utils/docs-preview/server-manager.d.ts.map +1 -1
- package/dist/src/utils/docs-preview/server-manager.js +1 -1
- package/dist/src/utils/docs-preview/server-manager.js.map +1 -1
- package/dist/src/utils/docs-preview/sidebar-builder.d.ts +1 -1
- package/dist/src/utils/docs-preview/sidebar-builder.d.ts.map +1 -1
- package/dist/src/utils/generate-skills-index.d.ts +1 -1
- package/dist/src/utils/generate-skills-index.js +1 -1
- package/dist/src/utils/project-detection.js +1 -1
- package/dist/src/utils/project-detection.js.map +1 -1
- package/package.json +17 -10
- package/plugins/specweave/agents/architect/AGENT.md +605 -0
- package/plugins/specweave/agents/infrastructure/AGENT.md +760 -0
- package/plugins/specweave/agents/pm/AGENT.md +14 -13
- package/plugins/specweave/commands/specweave-check-hooks.md +186 -0
- package/plugins/specweave/commands/specweave-plan.md +151 -0
- package/plugins/specweave/commands/specweave-sync-acs.md +342 -0
- package/plugins/specweave/commands/specweave-validate.md +60 -11
- package/plugins/specweave/hooks/lib/update-status-line.sh +8 -4
- package/plugins/specweave/hooks/post-increment-change.sh +4 -0
- package/plugins/specweave/hooks/post-increment-completion.sh +7 -1
- package/plugins/specweave/hooks/post-increment-planning.sh +4 -0
- package/plugins/specweave/hooks/post-increment-status-change.sh +4 -0
- package/plugins/specweave/hooks/user-prompt-submit.sh +78 -0
- package/plugins/specweave/iac-templates/aws-lambda/README.md.hbs +280 -0
- package/plugins/specweave/iac-templates/aws-lambda/defaults.json +118 -0
- package/plugins/specweave/iac-templates/aws-lambda/environments/dev.defaults.json +46 -0
- package/plugins/specweave/iac-templates/aws-lambda/environments/prod.defaults.json +67 -0
- package/plugins/specweave/iac-templates/aws-lambda/environments/staging.defaults.json +47 -0
- package/plugins/specweave/iac-templates/aws-lambda/main.tf.hbs +241 -0
- package/plugins/specweave/iac-templates/aws-lambda/outputs.tf.hbs +61 -0
- package/plugins/specweave/iac-templates/aws-lambda/provider.tf.hbs +15 -0
- package/plugins/specweave/iac-templates/aws-lambda/variables.tf.hbs +88 -0
- package/plugins/specweave/iac-templates/azure-functions/README.md.hbs +315 -0
- package/plugins/specweave/iac-templates/azure-functions/defaults.json +65 -0
- package/plugins/specweave/iac-templates/azure-functions/environments/dev.defaults.json +30 -0
- package/plugins/specweave/iac-templates/azure-functions/environments/prod.defaults.json +34 -0
- package/plugins/specweave/iac-templates/azure-functions/environments/staging.defaults.json +31 -0
- package/plugins/specweave/iac-templates/azure-functions/iam.tf.hbs +34 -0
- package/plugins/specweave/iac-templates/azure-functions/main.tf.hbs +247 -0
- package/plugins/specweave/iac-templates/azure-functions/outputs.tf.hbs +72 -0
- package/plugins/specweave/iac-templates/azure-functions/provider.tf.hbs +14 -0
- package/plugins/specweave/iac-templates/azure-functions/variables.tf.hbs +64 -0
- package/plugins/specweave/iac-templates/firebase/README.md.hbs +487 -0
- package/plugins/specweave/iac-templates/firebase/defaults.json +55 -0
- package/plugins/specweave/iac-templates/firebase/environments/dev.defaults.json +44 -0
- package/plugins/specweave/iac-templates/firebase/environments/prod.defaults.json +52 -0
- package/plugins/specweave/iac-templates/firebase/environments/staging.defaults.json +43 -0
- package/plugins/specweave/iac-templates/firebase/iam.tf.hbs +75 -0
- package/plugins/specweave/iac-templates/firebase/main.tf.hbs +297 -0
- package/plugins/specweave/iac-templates/firebase/outputs.tf.hbs +67 -0
- package/plugins/specweave/iac-templates/firebase/provider.tf.hbs +26 -0
- package/plugins/specweave/iac-templates/firebase/variables.tf.hbs +68 -0
- package/plugins/specweave/iac-templates/gcp-cloud-functions/README.md.hbs +330 -0
- package/plugins/specweave/iac-templates/gcp-cloud-functions/defaults.json +69 -0
- package/plugins/specweave/iac-templates/gcp-cloud-functions/environments/dev.defaults.json +33 -0
- package/plugins/specweave/iac-templates/gcp-cloud-functions/environments/prod.defaults.json +40 -0
- package/plugins/specweave/iac-templates/gcp-cloud-functions/environments/staging.defaults.json +33 -0
- package/plugins/specweave/iac-templates/gcp-cloud-functions/iam.tf.hbs +54 -0
- package/plugins/specweave/iac-templates/gcp-cloud-functions/main.tf.hbs +211 -0
- package/plugins/specweave/iac-templates/gcp-cloud-functions/outputs.tf.hbs +44 -0
- package/plugins/specweave/iac-templates/gcp-cloud-functions/provider.tf.hbs +14 -0
- package/plugins/specweave/iac-templates/gcp-cloud-functions/variables.tf.hbs +82 -0
- package/plugins/specweave/iac-templates/supabase/README.md.hbs +534 -0
- package/plugins/specweave/iac-templates/supabase/defaults.json +69 -0
- package/plugins/specweave/iac-templates/supabase/environments/dev.defaults.json +55 -0
- package/plugins/specweave/iac-templates/supabase/environments/prod.defaults.json +75 -0
- package/plugins/specweave/iac-templates/supabase/environments/staging.defaults.json +54 -0
- package/plugins/specweave/iac-templates/supabase/iam.tf.hbs +146 -0
- package/plugins/specweave/iac-templates/supabase/main.tf.hbs +310 -0
- package/plugins/specweave/iac-templates/supabase/outputs.tf.hbs +74 -0
- package/plugins/specweave/iac-templates/supabase/provider.tf.hbs +19 -0
- package/plugins/specweave/iac-templates/supabase/variables.tf.hbs +78 -0
- package/plugins/specweave/knowledge-base/serverless/FRESHNESS.md +69 -0
- package/plugins/specweave/knowledge-base/serverless/learning-paths.json +865 -0
- package/plugins/specweave/knowledge-base/serverless/platforms/aws-lambda.json +41 -0
- package/plugins/specweave/knowledge-base/serverless/platforms/azure-functions.json +41 -0
- package/plugins/specweave/knowledge-base/serverless/platforms/firebase.json +46 -0
- package/plugins/specweave/knowledge-base/serverless/platforms/gcp-cloud-functions.json +41 -0
- package/plugins/specweave/knowledge-base/serverless/platforms/supabase.json +41 -0
- package/plugins/specweave/knowledge-base/serverless/schema.json +155 -0
- package/plugins/specweave/lib/hooks/auto-transition.js +50 -0
- package/plugins/specweave/lib/hooks/auto-transition.ts +84 -0
- package/plugins/specweave/lib/hooks/invoke-translator-skill.js +1 -1
- package/plugins/specweave/lib/hooks/invoke-translator-skill.ts +1 -1
- package/plugins/specweave/lib/hooks/sync-living-docs.js +4 -31
- package/plugins/specweave/lib/hooks/{sync-living-docs.ts → sync-living-docs.ts.DISABLED} +9 -48
- package/plugins/specweave/lib/hooks/translate-file.js +1 -1
- package/plugins/specweave/lib/hooks/translate-file.ts +1 -1
- package/plugins/specweave/lib/hooks/update-ac-status.js +24 -75
- package/plugins/specweave/lib/hooks/update-ac-status.ts +46 -135
- package/plugins/specweave/lib/hooks/update-tasks-md.js +115 -3
- package/plugins/specweave/lib/hooks/update-tasks-md.ts +182 -10
- package/plugins/specweave/lib/utils/validate-dev-setup.sh +133 -0
- package/plugins/specweave/skills/increment-planner/SKILL.md +25 -15
- package/plugins/specweave/skills/serverless-recommender/SKILL.md +368 -0
- package/plugins/specweave/templates/iac/aws-lambda/templates/iam.tf.hbs +137 -0
- package/plugins/specweave/templates/iac/aws-lambda/templates/main.tf.hbs +216 -0
- package/plugins/specweave-ado/lib/enhanced-ado-sync.js +170 -0
- package/plugins/specweave-github/lib/CodeValidator.js +195 -0
- package/plugins/specweave-github/lib/CodeValidator.ts +284 -0
- package/plugins/specweave-github/lib/IssueStateManager.js +117 -0
- package/plugins/specweave-github/lib/IssueStateManager.ts +231 -0
- package/plugins/specweave-github/lib/ThreeLayerSyncManager.js +545 -0
- package/plugins/specweave-github/lib/ThreeLayerSyncManager.ts +809 -0
- package/plugins/specweave-github/lib/types.ts +38 -0
- package/plugins/specweave-github/lib/user-story-issue-builder.js +7 -0
- package/plugins/specweave-github/lib/user-story-issue-builder.ts +11 -0
- package/plugins/specweave-release/hooks/.specweave/logs/dora-tracking.log +1200 -0
- package/plugins/specweave-ui/.mcp.json +0 -10
- package/plugins/specweave-ui/README.md +26 -26
- package/plugins/specweave-ui/skills/browser-automation/SKILL.md +31 -18
- package/src/templates/AGENTS.md.template +22 -1
- package/src/templates/tasks.md.template +51 -33
- package/dist/plugins/specweave/lib/hooks/git-diff-analyzer.d.ts +0 -89
- package/dist/plugins/specweave/lib/hooks/git-diff-analyzer.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/git-diff-analyzer.js +0 -226
- package/dist/plugins/specweave/lib/hooks/git-diff-analyzer.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/invoke-translator-skill.d.ts +0 -60
- package/dist/plugins/specweave/lib/hooks/invoke-translator-skill.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/invoke-translator-skill.js +0 -201
- package/dist/plugins/specweave/lib/hooks/invoke-translator-skill.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/prepare-reflection-context.d.ts +0 -42
- package/dist/plugins/specweave/lib/hooks/prepare-reflection-context.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/prepare-reflection-context.js +0 -123
- package/dist/plugins/specweave/lib/hooks/prepare-reflection-context.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/reflection-config-loader.d.ts +0 -45
- package/dist/plugins/specweave/lib/hooks/reflection-config-loader.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/reflection-config-loader.js +0 -132
- package/dist/plugins/specweave/lib/hooks/reflection-config-loader.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/reflection-parser.d.ts +0 -33
- package/dist/plugins/specweave/lib/hooks/reflection-parser.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/reflection-parser.js +0 -419
- package/dist/plugins/specweave/lib/hooks/reflection-parser.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/reflection-prompt-builder.d.ts +0 -56
- package/dist/plugins/specweave/lib/hooks/reflection-prompt-builder.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/reflection-prompt-builder.js +0 -239
- package/dist/plugins/specweave/lib/hooks/reflection-prompt-builder.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/reflection-storage.d.ts +0 -64
- package/dist/plugins/specweave/lib/hooks/reflection-storage.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/reflection-storage.js +0 -305
- package/dist/plugins/specweave/lib/hooks/reflection-storage.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/run-self-reflection.d.ts +0 -43
- package/dist/plugins/specweave/lib/hooks/run-self-reflection.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/run-self-reflection.js +0 -203
- package/dist/plugins/specweave/lib/hooks/run-self-reflection.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/sync-living-docs.d.ts +0 -32
- package/dist/plugins/specweave/lib/hooks/sync-living-docs.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/sync-living-docs.js +0 -405
- package/dist/plugins/specweave/lib/hooks/sync-living-docs.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/translate-file.d.ts +0 -59
- package/dist/plugins/specweave/lib/hooks/translate-file.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/translate-file.js +0 -350
- package/dist/plugins/specweave/lib/hooks/translate-file.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/translate-living-docs.d.ts +0 -13
- package/dist/plugins/specweave/lib/hooks/translate-living-docs.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/translate-living-docs.js +0 -175
- package/dist/plugins/specweave/lib/hooks/translate-living-docs.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/types/reflection-types.d.ts +0 -164
- package/dist/plugins/specweave/lib/hooks/types/reflection-types.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/types/reflection-types.js +0 -73
- package/dist/plugins/specweave/lib/hooks/types/reflection-types.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/update-ac-status.d.ts +0 -21
- package/dist/plugins/specweave/lib/hooks/update-ac-status.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/update-ac-status.js +0 -162
- package/dist/plugins/specweave/lib/hooks/update-ac-status.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/update-tasks-md.d.ts +0 -29
- package/dist/plugins/specweave/lib/hooks/update-tasks-md.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/update-tasks-md.js +0 -203
- package/dist/plugins/specweave/lib/hooks/update-tasks-md.js.map +0 -1
- package/dist/src/core/living-docs/spec-distributor.d.ts +0 -180
- package/dist/src/core/living-docs/spec-distributor.d.ts.map +0 -1
- package/dist/src/core/living-docs/spec-distributor.js +0 -1840
- package/dist/src/core/living-docs/spec-distributor.js.map +0 -1
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Ultra-Smart Team Recommender
|
|
3
|
+
*
|
|
4
|
+
* Goes beyond backend/frontend to recommend:
|
|
5
|
+
* - Compliance-driven teams (HIPAA → auth + data teams)
|
|
6
|
+
* - Security teams (SOC2 → DevSecOps + CISO)
|
|
7
|
+
* - Infrastructure teams (platform, data, observability)
|
|
8
|
+
* - Serverless alternatives (with cost savings analysis)
|
|
9
|
+
*
|
|
10
|
+
* Implements T-020 to T-026 from increment 0037.
|
|
11
|
+
*/
|
|
12
|
+
import { TeamRecommendation } from './types.js';
|
|
13
|
+
import type { ComplianceStandard } from '../compliance/ComplianceDetector.js';
|
|
14
|
+
/**
|
|
15
|
+
* Input for team recommendation
|
|
16
|
+
*/
|
|
17
|
+
export interface TeamRecommendationInput {
|
|
18
|
+
/** Detected compliance standards */
|
|
19
|
+
complianceStandards: ComplianceStandard[];
|
|
20
|
+
/** Expected team size */
|
|
21
|
+
teamSize?: number;
|
|
22
|
+
/** Number of microservices (if applicable) */
|
|
23
|
+
microserviceCount?: number;
|
|
24
|
+
/** Whether analytics/ML is part of the product */
|
|
25
|
+
hasAnalytics?: boolean;
|
|
26
|
+
/** Detected use cases for serverless analysis */
|
|
27
|
+
useCases?: string[];
|
|
28
|
+
/** Project type */
|
|
29
|
+
projectType?: 'startup' | 'scale-up' | 'enterprise' | 'learning';
|
|
30
|
+
/** Data types being handled */
|
|
31
|
+
dataTypes?: ('healthcare' | 'payment' | 'personal' | 'financial' | 'education')[];
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Ultra-Smart Team Recommender
|
|
35
|
+
*/
|
|
36
|
+
export declare class TeamRecommender {
|
|
37
|
+
private savingsCalculator;
|
|
38
|
+
constructor();
|
|
39
|
+
/**
|
|
40
|
+
* Recommend teams based on compliance, scale, and architecture
|
|
41
|
+
*
|
|
42
|
+
* @param input - Project characteristics
|
|
43
|
+
* @returns Array of team recommendations with priorities
|
|
44
|
+
*
|
|
45
|
+
* @example
|
|
46
|
+
* ```typescript
|
|
47
|
+
* const recommender = new TeamRecommender();
|
|
48
|
+
* const teams = recommender.recommend({
|
|
49
|
+
* complianceStandards: ['HIPAA', 'SOC2'],
|
|
50
|
+
* teamSize: 20,
|
|
51
|
+
* useCases: ['auth', 'file-uploads']
|
|
52
|
+
* });
|
|
53
|
+
* ```
|
|
54
|
+
*/
|
|
55
|
+
recommend(input: TeamRecommendationInput): TeamRecommendation[];
|
|
56
|
+
/**
|
|
57
|
+
* T-020: HIPAA-driven team recommendations
|
|
58
|
+
*
|
|
59
|
+
* HIPAA requires:
|
|
60
|
+
* - Separate auth team (BAA, encryption, audit logs)
|
|
61
|
+
* - Separate data team (PHI handling, encryption at rest)
|
|
62
|
+
*/
|
|
63
|
+
private getHipaaTeams;
|
|
64
|
+
/**
|
|
65
|
+
* T-021: PCI-DSS team recommendations
|
|
66
|
+
*
|
|
67
|
+
* PCI-DSS options:
|
|
68
|
+
* - Option A: Isolated payments team (expensive, $3.5K/month overhead)
|
|
69
|
+
* - Option B: Use Stripe/PayPal (recommended, 2.9% + $0.30/transaction)
|
|
70
|
+
*/
|
|
71
|
+
private getPciDssTeams;
|
|
72
|
+
/**
|
|
73
|
+
* T-022: SOC2/ISO 27001 team recommendations
|
|
74
|
+
*
|
|
75
|
+
* SOC2/ISO 27001 + >15 people → DevSecOps team + CISO
|
|
76
|
+
*/
|
|
77
|
+
private getSoc2Teams;
|
|
78
|
+
/**
|
|
79
|
+
* T-023: Infrastructure team recommendations
|
|
80
|
+
*
|
|
81
|
+
* - Platform team if >5 microservices
|
|
82
|
+
* - Data team if analytics/ML
|
|
83
|
+
* - Observability team if >20 services
|
|
84
|
+
*/
|
|
85
|
+
private getInfrastructureTeams;
|
|
86
|
+
/**
|
|
87
|
+
* T-024: Specialized service teams
|
|
88
|
+
*
|
|
89
|
+
* Detects needs for: payments, notifications, analytics, file storage, image processing, email
|
|
90
|
+
*/
|
|
91
|
+
private getSpecializedServiceTeams;
|
|
92
|
+
/**
|
|
93
|
+
* Get core teams (always recommended)
|
|
94
|
+
*/
|
|
95
|
+
private getCoreTeams;
|
|
96
|
+
/**
|
|
97
|
+
* Get compliance-driven teams based on detected standards
|
|
98
|
+
*/
|
|
99
|
+
private getComplianceTeams;
|
|
100
|
+
/**
|
|
101
|
+
* T-026: Store team recommendations in config
|
|
102
|
+
*
|
|
103
|
+
* @param recommendations - Team recommendations
|
|
104
|
+
* @param configPath - Optional custom config path
|
|
105
|
+
*/
|
|
106
|
+
static saveToConfig(recommendations: TeamRecommendation[], configPath?: string): Promise<void>;
|
|
107
|
+
/**
|
|
108
|
+
* Get serverless savings analysis for detected use cases
|
|
109
|
+
*
|
|
110
|
+
* @param useCases - Detected use cases
|
|
111
|
+
* @returns Savings analysis
|
|
112
|
+
*/
|
|
113
|
+
getServerlessSavings(useCases: string[]): import("./ServerlessSavingsCalculator.js").ServerlessSavingsAnalysis;
|
|
114
|
+
/**
|
|
115
|
+
* Format team recommendations as markdown report
|
|
116
|
+
*
|
|
117
|
+
* @param recommendations - Team recommendations
|
|
118
|
+
* @returns Markdown report
|
|
119
|
+
*/
|
|
120
|
+
formatReport(recommendations: TeamRecommendation[]): string;
|
|
121
|
+
}
|
|
122
|
+
//# sourceMappingURL=TeamRecommender.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TeamRecommender.d.ts","sourceRoot":"","sources":["../../../../src/init/team/TeamRecommender.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,OAAO,EAAE,kBAAkB,EAAyB,MAAM,YAAY,CAAC;AAIvE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AAE9E;;GAEG;AACH,MAAM,WAAW,uBAAuB;IACtC,oCAAoC;IACpC,mBAAmB,EAAE,kBAAkB,EAAE,CAAC;IAE1C,yBAAyB;IACzB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAElB,8CAA8C;IAC9C,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAE3B,kDAAkD;IAClD,YAAY,CAAC,EAAE,OAAO,CAAC;IAEvB,iDAAiD;IACjD,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;IAEpB,mBAAmB;IACnB,WAAW,CAAC,EAAE,SAAS,GAAG,UAAU,GAAG,YAAY,GAAG,UAAU,CAAC;IAEjE,+BAA+B;IAC/B,SAAS,CAAC,EAAE,CAAC,YAAY,GAAG,SAAS,GAAG,UAAU,GAAG,WAAW,GAAG,WAAW,CAAC,EAAE,CAAC;CACnF;AAED;;GAEG;AACH,qBAAa,eAAe;IAC1B,OAAO,CAAC,iBAAiB,CAA8B;;IAMvD;;;;;;;;;;;;;;;OAeG;IACH,SAAS,CAAC,KAAK,EAAE,uBAAuB,GAAG,kBAAkB,EAAE;IAmB/D;;;;;;OAMG;IACH,OAAO,CAAC,aAAa;IA6CrB;;;;;;OAMG;IACH,OAAO,CAAC,cAAc;IA+BtB;;;;OAIG;IACH,OAAO,CAAC,YAAY;IA2CpB;;;;;;OAMG;IACH,OAAO,CAAC,sBAAsB;IAgE9B;;;;OAIG;IACH,OAAO,CAAC,0BAA0B;IA+ClC;;OAEG;IACH,OAAO,CAAC,YAAY;IAuBpB;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAsB1B;;;;;OAKG;WACU,YAAY,CAAC,eAAe,EAAE,kBAAkB,EAAE,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKpG;;;;;OAKG;IACH,oBAAoB,CAAC,QAAQ,EAAE,MAAM,EAAE;IAIvC;;;;;OAKG;IACH,YAAY,CAAC,eAAe,EAAE,kBAAkB,EAAE,GAAG,MAAM;CA4C5D"}
|
|
@@ -0,0 +1,405 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Ultra-Smart Team Recommender
|
|
3
|
+
*
|
|
4
|
+
* Goes beyond backend/frontend to recommend:
|
|
5
|
+
* - Compliance-driven teams (HIPAA → auth + data teams)
|
|
6
|
+
* - Security teams (SOC2 → DevSecOps + CISO)
|
|
7
|
+
* - Infrastructure teams (platform, data, observability)
|
|
8
|
+
* - Serverless alternatives (with cost savings analysis)
|
|
9
|
+
*
|
|
10
|
+
* Implements T-020 to T-026 from increment 0037.
|
|
11
|
+
*/
|
|
12
|
+
import { ServerlessSavingsCalculator } from './ServerlessSavingsCalculator.js';
|
|
13
|
+
/**
|
|
14
|
+
* Ultra-Smart Team Recommender
|
|
15
|
+
*/
|
|
16
|
+
export class TeamRecommender {
|
|
17
|
+
constructor() {
|
|
18
|
+
this.savingsCalculator = new ServerlessSavingsCalculator();
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Recommend teams based on compliance, scale, and architecture
|
|
22
|
+
*
|
|
23
|
+
* @param input - Project characteristics
|
|
24
|
+
* @returns Array of team recommendations with priorities
|
|
25
|
+
*
|
|
26
|
+
* @example
|
|
27
|
+
* ```typescript
|
|
28
|
+
* const recommender = new TeamRecommender();
|
|
29
|
+
* const teams = recommender.recommend({
|
|
30
|
+
* complianceStandards: ['HIPAA', 'SOC2'],
|
|
31
|
+
* teamSize: 20,
|
|
32
|
+
* useCases: ['auth', 'file-uploads']
|
|
33
|
+
* });
|
|
34
|
+
* ```
|
|
35
|
+
*/
|
|
36
|
+
recommend(input) {
|
|
37
|
+
const recommendations = [];
|
|
38
|
+
// 1. Core teams (ALWAYS recommended)
|
|
39
|
+
recommendations.push(...this.getCoreTeams());
|
|
40
|
+
// 2. Compliance-driven teams (T-020, T-021, T-022)
|
|
41
|
+
recommendations.push(...this.getComplianceTeams(input));
|
|
42
|
+
// 3. Infrastructure teams based on scale (T-023)
|
|
43
|
+
recommendations.push(...this.getInfrastructureTeams(input));
|
|
44
|
+
// 4. Specialized services (T-024)
|
|
45
|
+
recommendations.push(...this.getSpecializedServiceTeams(input));
|
|
46
|
+
// Sort by priority (descending)
|
|
47
|
+
return recommendations.sort((a, b) => (b.priority || 0) - (a.priority || 0));
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* T-020: HIPAA-driven team recommendations
|
|
51
|
+
*
|
|
52
|
+
* HIPAA requires:
|
|
53
|
+
* - Separate auth team (BAA, encryption, audit logs)
|
|
54
|
+
* - Separate data team (PHI handling, encryption at rest)
|
|
55
|
+
*/
|
|
56
|
+
getHipaaTeams() {
|
|
57
|
+
return [
|
|
58
|
+
{
|
|
59
|
+
teamName: 'auth-team',
|
|
60
|
+
role: 'Authentication & Authorization',
|
|
61
|
+
required: true,
|
|
62
|
+
reason: 'HIPAA requires BAA-compliant authentication, audit logs, and MFA enforcement',
|
|
63
|
+
size: '2-3 engineers',
|
|
64
|
+
skills: [
|
|
65
|
+
'OAuth 2.0 / SAML',
|
|
66
|
+
'JWT token management',
|
|
67
|
+
'MFA implementation',
|
|
68
|
+
'Audit logging',
|
|
69
|
+
'HIPAA security controls'
|
|
70
|
+
],
|
|
71
|
+
serverlessAlternative: {
|
|
72
|
+
service: 'AWS Cognito (BAA-eligible)',
|
|
73
|
+
costSavings: 185,
|
|
74
|
+
tradeoffs: [
|
|
75
|
+
'Must sign AWS BAA for HIPAA compliance',
|
|
76
|
+
'Limited customization vs full control',
|
|
77
|
+
'AWS vendor lock-in'
|
|
78
|
+
],
|
|
79
|
+
pricingModel: '$50-$150/month for 10K users with MFA'
|
|
80
|
+
},
|
|
81
|
+
priority: 100
|
|
82
|
+
},
|
|
83
|
+
{
|
|
84
|
+
teamName: 'data-team',
|
|
85
|
+
role: 'PHI Data Management',
|
|
86
|
+
required: true,
|
|
87
|
+
reason: 'HIPAA requires specialized team for PHI (Protected Health Information) handling',
|
|
88
|
+
size: '2-4 engineers',
|
|
89
|
+
skills: [
|
|
90
|
+
'Encryption at rest (AES-256)',
|
|
91
|
+
'Encryption in transit (TLS 1.2+)',
|
|
92
|
+
'Database security (row-level)',
|
|
93
|
+
'Data anonymization',
|
|
94
|
+
'HIPAA data lifecycle management'
|
|
95
|
+
],
|
|
96
|
+
priority: 95
|
|
97
|
+
}
|
|
98
|
+
];
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* T-021: PCI-DSS team recommendations
|
|
102
|
+
*
|
|
103
|
+
* PCI-DSS options:
|
|
104
|
+
* - Option A: Isolated payments team (expensive, $3.5K/month overhead)
|
|
105
|
+
* - Option B: Use Stripe/PayPal (recommended, 2.9% + $0.30/transaction)
|
|
106
|
+
*/
|
|
107
|
+
getPciDssTeams() {
|
|
108
|
+
return [
|
|
109
|
+
{
|
|
110
|
+
teamName: 'payments-team',
|
|
111
|
+
role: 'PCI-DSS Compliant Payments',
|
|
112
|
+
required: false, // Optional because Stripe is better
|
|
113
|
+
reason: 'PCI-DSS compliance for credit card processing (ONLY if not using Stripe/PayPal)',
|
|
114
|
+
size: '3-5 engineers + PCI compliance officer',
|
|
115
|
+
skills: [
|
|
116
|
+
'PCI-DSS Level 1 certification',
|
|
117
|
+
'Tokenization',
|
|
118
|
+
'Network segmentation',
|
|
119
|
+
'Quarterly ASV scans',
|
|
120
|
+
'Annual PCI audit preparation'
|
|
121
|
+
],
|
|
122
|
+
serverlessAlternative: {
|
|
123
|
+
service: 'Stripe',
|
|
124
|
+
costSavings: 3500, // Avoids PCI overhead: infrastructure ($1K) + compliance ($2.5K)
|
|
125
|
+
tradeoffs: [
|
|
126
|
+
'No PCI compliance burden (Stripe is PCI Level 1)',
|
|
127
|
+
'Pay 2.9% + $0.30 per transaction vs lower fees with direct processor',
|
|
128
|
+
'Vendor lock-in vs self-hosted',
|
|
129
|
+
'Limited customization vs full control'
|
|
130
|
+
],
|
|
131
|
+
pricingModel: '2.9% + $0.30 per transaction (vs $3.5K/month fixed overhead)'
|
|
132
|
+
},
|
|
133
|
+
priority: 50 // Low priority because Stripe is almost always better
|
|
134
|
+
}
|
|
135
|
+
];
|
|
136
|
+
}
|
|
137
|
+
/**
|
|
138
|
+
* T-022: SOC2/ISO 27001 team recommendations
|
|
139
|
+
*
|
|
140
|
+
* SOC2/ISO 27001 + >15 people → DevSecOps team + CISO
|
|
141
|
+
*/
|
|
142
|
+
getSoc2Teams(teamSize = 10) {
|
|
143
|
+
const teams = [];
|
|
144
|
+
// DevSecOps team (if team > 15)
|
|
145
|
+
if (teamSize > 15) {
|
|
146
|
+
teams.push({
|
|
147
|
+
teamName: 'devsecops-team',
|
|
148
|
+
role: 'DevSecOps & Security Engineering',
|
|
149
|
+
required: true,
|
|
150
|
+
reason: 'SOC2/ISO 27001 compliance requires dedicated security team for organizations > 15 people',
|
|
151
|
+
size: '2-3 engineers',
|
|
152
|
+
skills: [
|
|
153
|
+
'Security monitoring (SIEM)',
|
|
154
|
+
'Vulnerability management',
|
|
155
|
+
'Incident response',
|
|
156
|
+
'Penetration testing',
|
|
157
|
+
'SOC2 Type II controls',
|
|
158
|
+
'ISO 27001 ISMS implementation'
|
|
159
|
+
],
|
|
160
|
+
priority: 90
|
|
161
|
+
});
|
|
162
|
+
// CISO (Chief Information Security Officer) for large orgs
|
|
163
|
+
teams.push({
|
|
164
|
+
teamName: 'ciso',
|
|
165
|
+
role: 'Chief Information Security Officer',
|
|
166
|
+
required: false,
|
|
167
|
+
reason: 'SOC2/ISO 27001 audits prefer dedicated CISO role for organizations > 15 people',
|
|
168
|
+
size: '1 executive',
|
|
169
|
+
skills: [
|
|
170
|
+
'Security strategy',
|
|
171
|
+
'Compliance oversight',
|
|
172
|
+
'Risk management',
|
|
173
|
+
'Security awareness training',
|
|
174
|
+
'Audit coordination'
|
|
175
|
+
],
|
|
176
|
+
priority: 70
|
|
177
|
+
});
|
|
178
|
+
}
|
|
179
|
+
return teams;
|
|
180
|
+
}
|
|
181
|
+
/**
|
|
182
|
+
* T-023: Infrastructure team recommendations
|
|
183
|
+
*
|
|
184
|
+
* - Platform team if >5 microservices
|
|
185
|
+
* - Data team if analytics/ML
|
|
186
|
+
* - Observability team if >20 services
|
|
187
|
+
*/
|
|
188
|
+
getInfrastructureTeams(input) {
|
|
189
|
+
const teams = [];
|
|
190
|
+
const { microserviceCount = 0, hasAnalytics = false, teamSize = 10 } = input;
|
|
191
|
+
// Platform team (if >5 microservices)
|
|
192
|
+
if (microserviceCount > 5) {
|
|
193
|
+
teams.push({
|
|
194
|
+
teamName: 'platform-team',
|
|
195
|
+
role: 'Platform Engineering',
|
|
196
|
+
required: true,
|
|
197
|
+
reason: `Managing ${microserviceCount} microservices requires dedicated platform team`,
|
|
198
|
+
size: '2-4 engineers',
|
|
199
|
+
skills: [
|
|
200
|
+
'Kubernetes (EKS/AKS/GKE)',
|
|
201
|
+
'Service mesh (Istio/Linkerd)',
|
|
202
|
+
'CI/CD pipelines',
|
|
203
|
+
'Infrastructure as Code (Terraform)',
|
|
204
|
+
'Developer tooling'
|
|
205
|
+
],
|
|
206
|
+
priority: 85
|
|
207
|
+
});
|
|
208
|
+
}
|
|
209
|
+
// Data team (if analytics/ML)
|
|
210
|
+
if (hasAnalytics) {
|
|
211
|
+
teams.push({
|
|
212
|
+
teamName: 'data-team',
|
|
213
|
+
role: 'Data Engineering & Analytics',
|
|
214
|
+
required: true,
|
|
215
|
+
reason: 'Analytics and ML features require specialized data engineering',
|
|
216
|
+
size: '2-3 engineers',
|
|
217
|
+
skills: [
|
|
218
|
+
'Data pipelines (Airflow/Prefect)',
|
|
219
|
+
'Data warehousing (Snowflake/BigQuery)',
|
|
220
|
+
'ML model deployment',
|
|
221
|
+
'Data quality monitoring',
|
|
222
|
+
'SQL optimization'
|
|
223
|
+
],
|
|
224
|
+
priority: 80
|
|
225
|
+
});
|
|
226
|
+
}
|
|
227
|
+
// Observability team (if >20 services OR team >30 people)
|
|
228
|
+
if (microserviceCount > 20 || teamSize > 30) {
|
|
229
|
+
teams.push({
|
|
230
|
+
teamName: 'observability-team',
|
|
231
|
+
role: 'Observability & Monitoring',
|
|
232
|
+
required: false,
|
|
233
|
+
reason: `${microserviceCount} services require dedicated observability team`,
|
|
234
|
+
size: '1-2 engineers',
|
|
235
|
+
skills: [
|
|
236
|
+
'Distributed tracing (Jaeger/Zipkin)',
|
|
237
|
+
'Metrics (Prometheus/Grafana)',
|
|
238
|
+
'Logging (ELK/Loki)',
|
|
239
|
+
'Alerting strategy',
|
|
240
|
+
'SLO/SLI management'
|
|
241
|
+
],
|
|
242
|
+
priority: 60
|
|
243
|
+
});
|
|
244
|
+
}
|
|
245
|
+
return teams;
|
|
246
|
+
}
|
|
247
|
+
/**
|
|
248
|
+
* T-024: Specialized service teams
|
|
249
|
+
*
|
|
250
|
+
* Detects needs for: payments, notifications, analytics, file storage, image processing, email
|
|
251
|
+
*/
|
|
252
|
+
getSpecializedServiceTeams(input) {
|
|
253
|
+
const teams = [];
|
|
254
|
+
const { useCases = [], dataTypes = [] } = input;
|
|
255
|
+
// Check for payment needs
|
|
256
|
+
if (dataTypes.includes('payment') && !useCases.includes('auth')) { // If no PCI-DSS team recommended
|
|
257
|
+
const savingsOption = this.savingsCalculator.getOption('authentication');
|
|
258
|
+
teams.push({
|
|
259
|
+
teamName: 'payment-integration',
|
|
260
|
+
role: 'Payment Integration',
|
|
261
|
+
required: false,
|
|
262
|
+
reason: 'Payment processing detected',
|
|
263
|
+
size: '1-2 engineers',
|
|
264
|
+
skills: ['Stripe/PayPal API', 'Webhook handling', 'Payment reconciliation'],
|
|
265
|
+
serverlessAlternative: savingsOption ? {
|
|
266
|
+
service: 'Stripe',
|
|
267
|
+
costSavings: 3500,
|
|
268
|
+
tradeoffs: savingsOption.tradeoffs,
|
|
269
|
+
pricingModel: '2.9% + $0.30/transaction'
|
|
270
|
+
} : undefined,
|
|
271
|
+
priority: 65
|
|
272
|
+
});
|
|
273
|
+
}
|
|
274
|
+
// Notification service (if email use case detected)
|
|
275
|
+
if (useCases.includes('email') || useCases.includes('notifications')) {
|
|
276
|
+
const emailOption = this.savingsCalculator.getOption('email-sending');
|
|
277
|
+
teams.push({
|
|
278
|
+
teamName: 'notifications-service',
|
|
279
|
+
role: 'Notifications & Messaging',
|
|
280
|
+
required: false,
|
|
281
|
+
reason: 'Email/notification features detected',
|
|
282
|
+
size: '1 engineer',
|
|
283
|
+
skills: ['Email templates', 'SendGrid/SES', 'Push notifications', 'SMS (Twilio)'],
|
|
284
|
+
serverlessAlternative: emailOption ? {
|
|
285
|
+
service: emailOption.service,
|
|
286
|
+
costSavings: emailOption.savings,
|
|
287
|
+
tradeoffs: emailOption.tradeoffs,
|
|
288
|
+
pricingModel: '$20-90/month for transactional emails'
|
|
289
|
+
} : undefined,
|
|
290
|
+
priority: 55
|
|
291
|
+
});
|
|
292
|
+
}
|
|
293
|
+
return teams;
|
|
294
|
+
}
|
|
295
|
+
/**
|
|
296
|
+
* Get core teams (always recommended)
|
|
297
|
+
*/
|
|
298
|
+
getCoreTeams() {
|
|
299
|
+
return [
|
|
300
|
+
{
|
|
301
|
+
teamName: 'backend',
|
|
302
|
+
role: 'Backend Engineering',
|
|
303
|
+
required: true,
|
|
304
|
+
reason: 'Core backend development and API design',
|
|
305
|
+
size: '2-5 engineers',
|
|
306
|
+
skills: ['API design', 'Database optimization', 'Microservices', 'Security'],
|
|
307
|
+
priority: 100
|
|
308
|
+
},
|
|
309
|
+
{
|
|
310
|
+
teamName: 'frontend',
|
|
311
|
+
role: 'Frontend Engineering',
|
|
312
|
+
required: true,
|
|
313
|
+
reason: 'User interface and experience development',
|
|
314
|
+
size: '2-4 engineers',
|
|
315
|
+
skills: ['React/Vue/Angular', 'CSS', 'Performance optimization', 'Accessibility'],
|
|
316
|
+
priority: 100
|
|
317
|
+
}
|
|
318
|
+
];
|
|
319
|
+
}
|
|
320
|
+
/**
|
|
321
|
+
* Get compliance-driven teams based on detected standards
|
|
322
|
+
*/
|
|
323
|
+
getComplianceTeams(input) {
|
|
324
|
+
const teams = [];
|
|
325
|
+
const { complianceStandards = [], teamSize = 10 } = input;
|
|
326
|
+
// T-020: HIPAA teams
|
|
327
|
+
if (complianceStandards.some(s => ['HIPAA', 'FDA21CFR'].includes(s))) {
|
|
328
|
+
teams.push(...this.getHipaaTeams());
|
|
329
|
+
}
|
|
330
|
+
// T-021: PCI-DSS teams
|
|
331
|
+
if (complianceStandards.some(s => ['PCI-DSS', 'PSD2', 'SOX'].includes(s))) {
|
|
332
|
+
teams.push(...this.getPciDssTeams());
|
|
333
|
+
}
|
|
334
|
+
// T-022: SOC2/ISO 27001 teams
|
|
335
|
+
if (complianceStandards.some(s => ['SOC2', 'ISO27001'].includes(s))) {
|
|
336
|
+
teams.push(...this.getSoc2Teams(teamSize));
|
|
337
|
+
}
|
|
338
|
+
return teams;
|
|
339
|
+
}
|
|
340
|
+
/**
|
|
341
|
+
* T-026: Store team recommendations in config
|
|
342
|
+
*
|
|
343
|
+
* @param recommendations - Team recommendations
|
|
344
|
+
* @param configPath - Optional custom config path
|
|
345
|
+
*/
|
|
346
|
+
static async saveToConfig(recommendations, configPath) {
|
|
347
|
+
const { ConfigManager } = await import('../../config/ConfigManager.js');
|
|
348
|
+
await ConfigManager.updateResearch({ teams: recommendations }, configPath);
|
|
349
|
+
}
|
|
350
|
+
/**
|
|
351
|
+
* Get serverless savings analysis for detected use cases
|
|
352
|
+
*
|
|
353
|
+
* @param useCases - Detected use cases
|
|
354
|
+
* @returns Savings analysis
|
|
355
|
+
*/
|
|
356
|
+
getServerlessSavings(useCases) {
|
|
357
|
+
return this.savingsCalculator.calculateSavings(useCases);
|
|
358
|
+
}
|
|
359
|
+
/**
|
|
360
|
+
* Format team recommendations as markdown report
|
|
361
|
+
*
|
|
362
|
+
* @param recommendations - Team recommendations
|
|
363
|
+
* @returns Markdown report
|
|
364
|
+
*/
|
|
365
|
+
formatReport(recommendations) {
|
|
366
|
+
const lines = [];
|
|
367
|
+
lines.push('# Team Structure Recommendations\n');
|
|
368
|
+
// Required teams
|
|
369
|
+
const required = recommendations.filter(t => t.required);
|
|
370
|
+
if (required.length > 0) {
|
|
371
|
+
lines.push('## Required Teams\n');
|
|
372
|
+
for (const team of required) {
|
|
373
|
+
lines.push(`### ${team.teamName} (${team.role})`);
|
|
374
|
+
lines.push(`**Size**: ${team.size}`);
|
|
375
|
+
lines.push(`**Reason**: ${team.reason}`);
|
|
376
|
+
lines.push(`**Skills**: ${team.skills.join(', ')}\n`);
|
|
377
|
+
if (team.serverlessAlternative) {
|
|
378
|
+
lines.push('**Serverless Alternative**:');
|
|
379
|
+
lines.push(`- Service: ${team.serverlessAlternative.service}`);
|
|
380
|
+
lines.push(`- Cost Savings: $${team.serverlessAlternative.costSavings}/month`);
|
|
381
|
+
if (team.serverlessAlternative.pricingModel) {
|
|
382
|
+
lines.push(`- Pricing: ${team.serverlessAlternative.pricingModel}`);
|
|
383
|
+
}
|
|
384
|
+
lines.push('- Trade-offs:');
|
|
385
|
+
for (const tradeoff of team.serverlessAlternative.tradeoffs) {
|
|
386
|
+
lines.push(` - ${tradeoff}`);
|
|
387
|
+
}
|
|
388
|
+
lines.push('');
|
|
389
|
+
}
|
|
390
|
+
}
|
|
391
|
+
}
|
|
392
|
+
// Optional teams
|
|
393
|
+
const optional = recommendations.filter(t => !t.required);
|
|
394
|
+
if (optional.length > 0) {
|
|
395
|
+
lines.push('## Optional Teams\n');
|
|
396
|
+
for (const team of optional) {
|
|
397
|
+
lines.push(`### ${team.teamName} (${team.role})`);
|
|
398
|
+
lines.push(`**Size**: ${team.size}`);
|
|
399
|
+
lines.push(`**Reason**: ${team.reason}\n`);
|
|
400
|
+
}
|
|
401
|
+
}
|
|
402
|
+
return lines.join('\n');
|
|
403
|
+
}
|
|
404
|
+
}
|
|
405
|
+
//# sourceMappingURL=TeamRecommender.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TeamRecommender.js","sourceRoot":"","sources":["../../../../src/init/team/TeamRecommender.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Types for Team Recommendation System
|
|
3
|
+
*/
|
|
4
|
+
import { z } from 'zod';
|
|
5
|
+
/**
|
|
6
|
+
* Serverless alternative for a team/service
|
|
7
|
+
*/
|
|
8
|
+
export interface ServerlessAlternative {
|
|
9
|
+
/** Service name (e.g., "AWS Cognito", "Stripe") */
|
|
10
|
+
service: string;
|
|
11
|
+
/** Monthly cost savings compared to in-house */
|
|
12
|
+
costSavings: number;
|
|
13
|
+
/** Tradeoffs of using serverless */
|
|
14
|
+
tradeoffs: string[];
|
|
15
|
+
/** Pricing model */
|
|
16
|
+
pricingModel?: string;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Team recommendation
|
|
20
|
+
*/
|
|
21
|
+
export interface TeamRecommendation {
|
|
22
|
+
/** Team name identifier */
|
|
23
|
+
teamName: string;
|
|
24
|
+
/** Human-readable role */
|
|
25
|
+
role: string;
|
|
26
|
+
/** Whether this team is required (true) or optional (false) */
|
|
27
|
+
required: boolean;
|
|
28
|
+
/** Why this team is needed */
|
|
29
|
+
reason: string;
|
|
30
|
+
/** Recommended team size */
|
|
31
|
+
size: string;
|
|
32
|
+
/** Required skills for this team */
|
|
33
|
+
skills: string[];
|
|
34
|
+
/** Serverless alternative (if applicable) */
|
|
35
|
+
serverlessAlternative?: ServerlessAlternative;
|
|
36
|
+
/** Priority (higher = more important) */
|
|
37
|
+
priority?: number;
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Zod schema for TeamRecommendation
|
|
41
|
+
*/
|
|
42
|
+
export declare const TeamRecommendationSchema: z.ZodObject<{
|
|
43
|
+
teamName: z.ZodString;
|
|
44
|
+
role: z.ZodString;
|
|
45
|
+
required: z.ZodBoolean;
|
|
46
|
+
reason: z.ZodString;
|
|
47
|
+
size: z.ZodString;
|
|
48
|
+
skills: z.ZodArray<z.ZodString, "many">;
|
|
49
|
+
serverlessAlternative: z.ZodOptional<z.ZodObject<{
|
|
50
|
+
service: z.ZodString;
|
|
51
|
+
costSavings: z.ZodNumber;
|
|
52
|
+
tradeoffs: z.ZodArray<z.ZodString, "many">;
|
|
53
|
+
pricingModel: z.ZodOptional<z.ZodString>;
|
|
54
|
+
}, "strip", z.ZodTypeAny, {
|
|
55
|
+
service?: string;
|
|
56
|
+
costSavings?: number;
|
|
57
|
+
tradeoffs?: string[];
|
|
58
|
+
pricingModel?: string;
|
|
59
|
+
}, {
|
|
60
|
+
service?: string;
|
|
61
|
+
costSavings?: number;
|
|
62
|
+
tradeoffs?: string[];
|
|
63
|
+
pricingModel?: string;
|
|
64
|
+
}>>;
|
|
65
|
+
priority: z.ZodOptional<z.ZodNumber>;
|
|
66
|
+
}, "strip", z.ZodTypeAny, {
|
|
67
|
+
skills?: string[];
|
|
68
|
+
reason?: string;
|
|
69
|
+
required?: boolean;
|
|
70
|
+
priority?: number;
|
|
71
|
+
teamName?: string;
|
|
72
|
+
role?: string;
|
|
73
|
+
size?: string;
|
|
74
|
+
serverlessAlternative?: {
|
|
75
|
+
service?: string;
|
|
76
|
+
costSavings?: number;
|
|
77
|
+
tradeoffs?: string[];
|
|
78
|
+
pricingModel?: string;
|
|
79
|
+
};
|
|
80
|
+
}, {
|
|
81
|
+
skills?: string[];
|
|
82
|
+
reason?: string;
|
|
83
|
+
required?: boolean;
|
|
84
|
+
priority?: number;
|
|
85
|
+
teamName?: string;
|
|
86
|
+
role?: string;
|
|
87
|
+
size?: string;
|
|
88
|
+
serverlessAlternative?: {
|
|
89
|
+
service?: string;
|
|
90
|
+
costSavings?: number;
|
|
91
|
+
tradeoffs?: string[];
|
|
92
|
+
pricingModel?: string;
|
|
93
|
+
};
|
|
94
|
+
}>;
|
|
95
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/init/team/types.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB;;GAEG;AACH,MAAM,WAAW,qBAAqB;IACpC,mDAAmD;IACnD,OAAO,EAAE,MAAM,CAAC;IAEhB,gDAAgD;IAChD,WAAW,EAAE,MAAM,CAAC;IAEpB,oCAAoC;IACpC,SAAS,EAAE,MAAM,EAAE,CAAC;IAEpB,oBAAoB;IACpB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED;;GAEG;AACH,MAAM,WAAW,kBAAkB;IACjC,2BAA2B;IAC3B,QAAQ,EAAE,MAAM,CAAC;IAEjB,0BAA0B;IAC1B,IAAI,EAAE,MAAM,CAAC;IAEb,+DAA+D;IAC/D,QAAQ,EAAE,OAAO,CAAC;IAElB,8BAA8B;IAC9B,MAAM,EAAE,MAAM,CAAC;IAEf,4BAA4B;IAC5B,IAAI,EAAE,MAAM,CAAC;IAEb,oCAAoC;IACpC,MAAM,EAAE,MAAM,EAAE,CAAC;IAEjB,6CAA6C;IAC7C,qBAAqB,CAAC,EAAE,qBAAqB,CAAC;IAE9C,yCAAyC;IACzC,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED;;GAEG;AACH,eAAO,MAAM,wBAAwB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAcnC,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Types for Team Recommendation System
|
|
3
|
+
*/
|
|
4
|
+
import { z } from 'zod';
|
|
5
|
+
/**
|
|
6
|
+
* Zod schema for TeamRecommendation
|
|
7
|
+
*/
|
|
8
|
+
export const TeamRecommendationSchema = z.object({
|
|
9
|
+
teamName: z.string(),
|
|
10
|
+
role: z.string(),
|
|
11
|
+
required: z.boolean(),
|
|
12
|
+
reason: z.string(),
|
|
13
|
+
size: z.string(),
|
|
14
|
+
skills: z.array(z.string()),
|
|
15
|
+
serverlessAlternative: z.object({
|
|
16
|
+
service: z.string(),
|
|
17
|
+
costSavings: z.number(),
|
|
18
|
+
tradeoffs: z.array(z.string()),
|
|
19
|
+
pricingModel: z.string().optional()
|
|
20
|
+
}).optional(),
|
|
21
|
+
priority: z.number().optional()
|
|
22
|
+
});
|
|
23
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/init/team/types.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAgDxB;;GAEG;AACH,MAAM,CAAC,MAAM,wBAAwB,GAAG,CAAC,CAAC,MAAM,CAAC;IAC/C,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE;IACpB,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE;IAChB,QAAQ,EAAE,CAAC,CAAC,OAAO,EAAE;IACrB,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE;IAClB,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE;IAChB,MAAM,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;IAC3B,qBAAqB,EAAE,CAAC,CAAC,MAAM,CAAC;QAC9B,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE;QACnB,WAAW,EAAE,CAAC,CAAC,MAAM,EAAE;QACvB,SAAS,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;QAC9B,YAAY,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;KACpC,CAAC,CAAC,QAAQ,EAAE;IACb,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CAChC,CAAC,CAAC"}
|