projscan 4.4.0 → 4.6.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/README.md +36 -12
- package/dist/analyzers/pythonDependencyRiskCheck.js +1 -1
- package/dist/analyzers/pythonDependencyRiskCheck.js.map +1 -1
- package/dist/cli/_shared.d.ts +4 -5
- package/dist/cli/_shared.js +41 -188
- package/dist/cli/_shared.js.map +1 -1
- package/dist/cli/architectureLayers.d.ts +2 -0
- package/dist/cli/architectureLayers.js +112 -0
- package/dist/cli/architectureLayers.js.map +1 -0
- package/dist/cli/bannerDisplay.d.ts +9 -0
- package/dist/cli/bannerDisplay.js +18 -0
- package/dist/cli/bannerDisplay.js.map +1 -0
- package/dist/cli/changedIssueFilter.d.ts +10 -0
- package/dist/cli/changedIssueFilter.js +24 -0
- package/dist/cli/changedIssueFilter.js.map +1 -0
- package/dist/cli/commandPath.d.ts +2 -0
- package/dist/cli/commandPath.js +12 -0
- package/dist/cli/commandPath.js.map +1 -0
- package/dist/cli/commands/agentBrief.js +11 -0
- package/dist/cli/commands/agentBrief.js.map +1 -1
- package/dist/cli/commands/analyze.js +17 -6
- package/dist/cli/commands/analyze.js.map +1 -1
- package/dist/cli/commands/ci.js +15 -3
- package/dist/cli/commands/ci.js.map +1 -1
- package/dist/cli/commands/coordinate.js +27 -0
- package/dist/cli/commands/coordinate.js.map +1 -1
- package/dist/cli/commands/doctor.js +16 -4
- package/dist/cli/commands/doctor.js.map +1 -1
- package/dist/cli/commands/upgrade.js +1 -1
- package/dist/cli/commands/upgrade.js.map +1 -1
- package/dist/cli/pluginReporter.d.ts +14 -0
- package/dist/cli/pluginReporter.js +46 -0
- package/dist/cli/pluginReporter.js.map +1 -0
- package/dist/cli/projectConfig.d.ts +12 -0
- package/dist/cli/projectConfig.js +41 -0
- package/dist/cli/projectConfig.js.map +1 -0
- package/dist/cli/treeSlice.d.ts +3 -0
- package/dist/cli/treeSlice.js +12 -0
- package/dist/cli/treeSlice.js.map +1 -0
- package/dist/core/ast.d.ts +4 -76
- package/dist/core/ast.js +11 -630
- package/dist/core/ast.js.map +1 -1
- package/dist/core/astBodySignals.d.ts +17 -0
- package/dist/core/astBodySignals.js +107 -0
- package/dist/core/astBodySignals.js.map +1 -0
- package/dist/core/astFunctionCollector.d.ts +11 -0
- package/dist/core/astFunctionCollector.js +140 -0
- package/dist/core/astFunctionCollector.js.map +1 -0
- package/dist/core/astFunctionNames.d.ts +2 -0
- package/dist/core/astFunctionNames.js +53 -0
- package/dist/core/astFunctionNames.js.map +1 -0
- package/dist/core/astFunctionNodes.d.ts +2 -0
- package/dist/core/astFunctionNodes.js +12 -0
- package/dist/core/astFunctionNodes.js.map +1 -0
- package/dist/core/astMembers.d.ts +13 -0
- package/dist/core/astMembers.js +116 -0
- package/dist/core/astMembers.js.map +1 -0
- package/dist/core/astModuleSignals.d.ts +3 -0
- package/dist/core/astModuleSignals.js +140 -0
- package/dist/core/astModuleSignals.js.map +1 -0
- package/dist/core/astParser.d.ts +11 -0
- package/dist/core/astParser.js +38 -0
- package/dist/core/astParser.js.map +1 -0
- package/dist/core/astProgramSignals.d.ts +11 -0
- package/dist/core/astProgramSignals.js +97 -0
- package/dist/core/astProgramSignals.js.map +1 -0
- package/dist/core/astTypes.d.ts +78 -0
- package/dist/core/astTypes.js +2 -0
- package/dist/core/astTypes.js.map +1 -0
- package/dist/core/codeGraph.d.ts +3 -28
- package/dist/core/codeGraph.js +3 -231
- package/dist/core/codeGraph.js.map +1 -1
- package/dist/core/codeGraphFanMetrics.d.ts +17 -0
- package/dist/core/codeGraphFanMetrics.js +89 -0
- package/dist/core/codeGraphFanMetrics.js.map +1 -0
- package/dist/core/codeGraphIndexes.d.ts +23 -0
- package/dist/core/codeGraphIndexes.js +57 -0
- package/dist/core/codeGraphIndexes.js.map +1 -0
- package/dist/core/codeGraphParsing.d.ts +20 -0
- package/dist/core/codeGraphParsing.js +104 -0
- package/dist/core/codeGraphParsing.js.map +1 -0
- package/dist/core/codeGraphTypes.d.ts +28 -0
- package/dist/core/codeGraphTypes.js +2 -0
- package/dist/core/codeGraphTypes.js.map +1 -0
- package/dist/core/collisionDetector.d.ts +2 -0
- package/dist/core/collisionDetector.js +17 -12
- package/dist/core/collisionDetector.js.map +1 -1
- package/dist/core/coordination.d.ts +4 -2
- package/dist/core/coordination.js +40 -4
- package/dist/core/coordination.js.map +1 -1
- package/dist/core/coordinationEvidence.d.ts +32 -0
- package/dist/core/coordinationEvidence.js +101 -0
- package/dist/core/coordinationEvidence.js.map +1 -0
- package/dist/core/dataflow.js +2 -1
- package/dist/core/dataflow.js.map +1 -1
- package/dist/core/fileAccess.d.ts +16 -0
- package/dist/core/fileAccess.js +78 -0
- package/dist/core/fileAccess.js.map +1 -0
- package/dist/core/fileExportTypes.d.ts +2 -0
- package/dist/core/fileExportTypes.js +16 -0
- package/dist/core/fileExportTypes.js.map +1 -0
- package/dist/core/fileGraphMetrics.d.ts +4 -0
- package/dist/core/fileGraphMetrics.js +34 -0
- package/dist/core/fileGraphMetrics.js.map +1 -0
- package/dist/core/fileInspectionEvidence.d.ts +13 -0
- package/dist/core/fileInspectionEvidence.js +14 -0
- package/dist/core/fileInspectionEvidence.js.map +1 -0
- package/dist/core/fileInspectionGraph.d.ts +5 -0
- package/dist/core/fileInspectionGraph.js +29 -0
- package/dist/core/fileInspectionGraph.js.map +1 -0
- package/dist/core/fileInspector.d.ts +4 -4
- package/dist/core/fileInspector.js +28 -215
- package/dist/core/fileInspector.js.map +1 -1
- package/dist/core/fileIssues.d.ts +1 -0
- package/dist/core/fileIssues.js +18 -0
- package/dist/core/fileIssues.js.map +1 -0
- package/dist/core/filePurpose.d.ts +2 -0
- package/dist/core/filePurpose.js +61 -0
- package/dist/core/filePurpose.js.map +1 -0
- package/dist/core/frameworkExpressSources.d.ts +4 -0
- package/dist/core/frameworkExpressSources.js +95 -0
- package/dist/core/frameworkExpressSources.js.map +1 -0
- package/dist/core/frameworkFastifySources.d.ts +4 -0
- package/dist/core/frameworkFastifySources.js +74 -0
- package/dist/core/frameworkFastifySources.js.map +1 -0
- package/dist/core/frameworkHonoSources.d.ts +4 -0
- package/dist/core/frameworkHonoSources.js +73 -0
- package/dist/core/frameworkHonoSources.js.map +1 -0
- package/dist/core/frameworkKoaSources.d.ts +4 -0
- package/dist/core/frameworkKoaSources.js +81 -0
- package/dist/core/frameworkKoaSources.js.map +1 -0
- package/dist/core/frameworkNextRouteSources.d.ts +2 -0
- package/dist/core/frameworkNextRouteSources.js +55 -0
- package/dist/core/frameworkNextRouteSources.js.map +1 -0
- package/dist/core/frameworkSources.d.ts +1 -1
- package/dist/core/frameworkSources.js +16 -125
- package/dist/core/frameworkSources.js.map +1 -1
- package/dist/core/hotspotAnalyzer.d.ts +2 -18
- package/dist/core/hotspotAnalyzer.js +15 -477
- package/dist/core/hotspotAnalyzer.js.map +1 -1
- package/dist/core/hotspotBuilder.d.ts +14 -0
- package/dist/core/hotspotBuilder.js +70 -0
- package/dist/core/hotspotBuilder.js.map +1 -0
- package/dist/core/hotspotCandidates.d.ts +9 -0
- package/dist/core/hotspotCandidates.js +63 -0
- package/dist/core/hotspotCandidates.js.map +1 -0
- package/dist/core/hotspotGit.d.ts +10 -0
- package/dist/core/hotspotGit.js +152 -0
- package/dist/core/hotspotGit.js.map +1 -0
- package/dist/core/hotspotIssues.d.ts +2 -0
- package/dist/core/hotspotIssues.js +83 -0
- package/dist/core/hotspotIssues.js.map +1 -0
- package/dist/core/hotspotLines.d.ts +2 -0
- package/dist/core/hotspotLines.js +24 -0
- package/dist/core/hotspotLines.js.map +1 -0
- package/dist/core/hotspotMemory.d.ts +2 -0
- package/dist/core/hotspotMemory.js +21 -0
- package/dist/core/hotspotMemory.js.map +1 -0
- package/dist/core/hotspotRanking.d.ts +13 -0
- package/dist/core/hotspotRanking.js +44 -0
- package/dist/core/hotspotRanking.js.map +1 -0
- package/dist/core/hotspotScoring.d.ts +23 -0
- package/dist/core/hotspotScoring.js +128 -0
- package/dist/core/hotspotScoring.js.map +1 -0
- package/dist/core/indexCache.js +4 -1
- package/dist/core/indexCache.js.map +1 -1
- package/dist/core/intentRouter.d.ts +3 -16
- package/dist/core/intentRouter.js +5 -7348
- package/dist/core/intentRouter.js.map +1 -1
- package/dist/core/intentRouterCatalog.d.ts +16 -0
- package/dist/core/intentRouterCatalog.js +1692 -0
- package/dist/core/intentRouterCatalog.js.map +1 -0
- package/dist/core/intentRouterCoordinationSignals.d.ts +12 -0
- package/dist/core/intentRouterCoordinationSignals.js +111 -0
- package/dist/core/intentRouterCoordinationSignals.js.map +1 -0
- package/dist/core/intentRouterDependencySignals.d.ts +9 -0
- package/dist/core/intentRouterDependencySignals.js +226 -0
- package/dist/core/intentRouterDependencySignals.js.map +1 -0
- package/dist/core/intentRouterKeywordContext.d.ts +14 -0
- package/dist/core/intentRouterKeywordContext.js +2 -0
- package/dist/core/intentRouterKeywordContext.js.map +1 -0
- package/dist/core/intentRouterKeywordEarlyGuards.d.ts +2 -0
- package/dist/core/intentRouterKeywordEarlyGuards.js +127 -0
- package/dist/core/intentRouterKeywordEarlyGuards.js.map +1 -0
- package/dist/core/intentRouterKeywordMatches.d.ts +3 -0
- package/dist/core/intentRouterKeywordMatches.js +31 -0
- package/dist/core/intentRouterKeywordMatches.js.map +1 -0
- package/dist/core/intentRouterKeywordSearchGuards.d.ts +2 -0
- package/dist/core/intentRouterKeywordSearchGuards.js +239 -0
- package/dist/core/intentRouterKeywordSearchGuards.js.map +1 -0
- package/dist/core/intentRouterKeywordTargetGuards.d.ts +2 -0
- package/dist/core/intentRouterKeywordTargetGuards.js +191 -0
- package/dist/core/intentRouterKeywordTargetGuards.js.map +1 -0
- package/dist/core/intentRouterKeywordToolGuards.d.ts +2 -0
- package/dist/core/intentRouterKeywordToolGuards.js +133 -0
- package/dist/core/intentRouterKeywordToolGuards.js.map +1 -0
- package/dist/core/intentRouterKeywordWeights.d.ts +4 -0
- package/dist/core/intentRouterKeywordWeights.js +1184 -0
- package/dist/core/intentRouterKeywordWeights.js.map +1 -0
- package/dist/core/intentRouterPlanningSignals.d.ts +7 -0
- package/dist/core/intentRouterPlanningSignals.js +268 -0
- package/dist/core/intentRouterPlanningSignals.js.map +1 -0
- package/dist/core/intentRouterPrDiffSignals.d.ts +1 -0
- package/dist/core/intentRouterPrDiffSignals.js +41 -0
- package/dist/core/intentRouterPrDiffSignals.js.map +1 -0
- package/dist/core/intentRouterPreflightSignals.d.ts +3 -0
- package/dist/core/intentRouterPreflightSignals.js +54 -0
- package/dist/core/intentRouterPreflightSignals.js.map +1 -0
- package/dist/core/intentRouterRegressionKeywordMatches.d.ts +1 -0
- package/dist/core/intentRouterRegressionKeywordMatches.js +176 -0
- package/dist/core/intentRouterRegressionKeywordMatches.js.map +1 -0
- package/dist/core/intentRouterRegressionSignals.d.ts +10 -0
- package/dist/core/intentRouterRegressionSignals.js +207 -0
- package/dist/core/intentRouterRegressionSignals.js.map +1 -0
- package/dist/core/intentRouterReleaseSignals.d.ts +8 -0
- package/dist/core/intentRouterReleaseSignals.js +59 -0
- package/dist/core/intentRouterReleaseSignals.js.map +1 -0
- package/dist/core/intentRouterRepoSignals.d.ts +8 -0
- package/dist/core/intentRouterRepoSignals.js +226 -0
- package/dist/core/intentRouterRepoSignals.js.map +1 -0
- package/dist/core/intentRouterReviewSignals.d.ts +2 -0
- package/dist/core/intentRouterReviewSignals.js +109 -0
- package/dist/core/intentRouterReviewSignals.js.map +1 -0
- package/dist/core/intentRouterRiskSignals.d.ts +12 -0
- package/dist/core/intentRouterRiskSignals.js +242 -0
- package/dist/core/intentRouterRiskSignals.js.map +1 -0
- package/dist/core/intentRouterScoring.d.ts +9 -0
- package/dist/core/intentRouterScoring.js +40 -0
- package/dist/core/intentRouterScoring.js.map +1 -0
- package/dist/core/intentRouterSearchApiSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchApiSignals.js +62 -0
- package/dist/core/intentRouterSearchApiSignals.js.map +1 -0
- package/dist/core/intentRouterSearchBackgroundSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchBackgroundSignals.js +55 -0
- package/dist/core/intentRouterSearchBackgroundSignals.js.map +1 -0
- package/dist/core/intentRouterSearchCommunicationSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchCommunicationSignals.js +74 -0
- package/dist/core/intentRouterSearchCommunicationSignals.js.map +1 -0
- package/dist/core/intentRouterSearchDataSignals.d.ts +2 -0
- package/dist/core/intentRouterSearchDataSignals.js +98 -0
- package/dist/core/intentRouterSearchDataSignals.js.map +1 -0
- package/dist/core/intentRouterSearchDomainSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchDomainSignals.js +71 -0
- package/dist/core/intentRouterSearchDomainSignals.js.map +1 -0
- package/dist/core/intentRouterSearchInfraSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchInfraSignals.js +79 -0
- package/dist/core/intentRouterSearchInfraSignals.js.map +1 -0
- package/dist/core/intentRouterSearchIntegrationSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchIntegrationSignals.js +117 -0
- package/dist/core/intentRouterSearchIntegrationSignals.js.map +1 -0
- package/dist/core/intentRouterSearchLookupSignals.d.ts +10 -0
- package/dist/core/intentRouterSearchLookupSignals.js +310 -0
- package/dist/core/intentRouterSearchLookupSignals.js.map +1 -0
- package/dist/core/intentRouterSearchNavigationSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchNavigationSignals.js +62 -0
- package/dist/core/intentRouterSearchNavigationSignals.js.map +1 -0
- package/dist/core/intentRouterSearchOwnershipSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchOwnershipSignals.js +15 -0
- package/dist/core/intentRouterSearchOwnershipSignals.js.map +1 -0
- package/dist/core/intentRouterSearchPageSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchPageSignals.js +84 -0
- package/dist/core/intentRouterSearchPageSignals.js.map +1 -0
- package/dist/core/intentRouterSearchReliabilitySignals.d.ts +1 -0
- package/dist/core/intentRouterSearchReliabilitySignals.js +94 -0
- package/dist/core/intentRouterSearchReliabilitySignals.js.map +1 -0
- package/dist/core/intentRouterSearchStateSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchStateSignals.js +107 -0
- package/dist/core/intentRouterSearchStateSignals.js.map +1 -0
- package/dist/core/intentRouterSearchStyleSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchStyleSignals.js +99 -0
- package/dist/core/intentRouterSearchStyleSignals.js.map +1 -0
- package/dist/core/intentRouterSearchTestSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchTestSignals.js +34 -0
- package/dist/core/intentRouterSearchTestSignals.js.map +1 -0
- package/dist/core/intentRouterSearchToolingSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchToolingSignals.js +106 -0
- package/dist/core/intentRouterSearchToolingSignals.js.map +1 -0
- package/dist/core/intentRouterSearchUiSignals.d.ts +1 -0
- package/dist/core/intentRouterSearchUiSignals.js +77 -0
- package/dist/core/intentRouterSearchUiSignals.js.map +1 -0
- package/dist/core/intentRouterSecuritySignals.d.ts +4 -0
- package/dist/core/intentRouterSecuritySignals.js +235 -0
- package/dist/core/intentRouterSecuritySignals.js.map +1 -0
- package/dist/core/intentRouterTargetSignals.d.ts +5 -0
- package/dist/core/intentRouterTargetSignals.js +76 -0
- package/dist/core/intentRouterTargetSignals.js.map +1 -0
- package/dist/core/intentRouterTokens.d.ts +1 -0
- package/dist/core/intentRouterTokens.js +36 -0
- package/dist/core/intentRouterTokens.js.map +1 -0
- package/dist/core/intentRouterUnderstandSignals.d.ts +1 -0
- package/dist/core/intentRouterUnderstandSignals.js +171 -0
- package/dist/core/intentRouterUnderstandSignals.js.map +1 -0
- package/dist/core/intentRouterVerificationSignals.d.ts +8 -0
- package/dist/core/intentRouterVerificationSignals.js +119 -0
- package/dist/core/intentRouterVerificationSignals.js.map +1 -0
- package/dist/core/intentRouterWorkSignals.d.ts +4 -0
- package/dist/core/intentRouterWorkSignals.js +157 -0
- package/dist/core/intentRouterWorkSignals.js.map +1 -0
- package/dist/core/languages/pythonLockfiles.d.ts +11 -0
- package/dist/core/languages/pythonLockfiles.js +206 -0
- package/dist/core/languages/pythonLockfiles.js.map +1 -0
- package/dist/core/languages/pythonManifestText.d.ts +7 -0
- package/dist/core/languages/pythonManifestText.js +25 -0
- package/dist/core/languages/pythonManifestText.js.map +1 -0
- package/dist/core/languages/pythonManifests.d.ts +6 -27
- package/dist/core/languages/pythonManifests.js +29 -303
- package/dist/core/languages/pythonManifests.js.map +1 -1
- package/dist/core/languages/pythonPep508.d.ts +4 -0
- package/dist/core/languages/pythonPep508.js +14 -0
- package/dist/core/languages/pythonPep508.js.map +1 -0
- package/dist/core/languages/pythonProjectEvidence.d.ts +2 -0
- package/dist/core/languages/pythonProjectEvidence.js +29 -0
- package/dist/core/languages/pythonProjectEvidence.js.map +1 -0
- package/dist/core/languages/pythonProjectTypes.d.ts +31 -0
- package/dist/core/languages/pythonProjectTypes.js +2 -0
- package/dist/core/languages/pythonProjectTypes.js.map +1 -0
- package/dist/core/languages/pythonPyproject.d.ts +2 -0
- package/dist/core/languages/pythonPyproject.js +160 -0
- package/dist/core/languages/pythonPyproject.js.map +1 -0
- package/dist/core/languages/pythonRequirements.d.ts +9 -0
- package/dist/core/languages/pythonRequirements.js +86 -0
- package/dist/core/languages/pythonRequirements.js.map +1 -0
- package/dist/core/languages/pythonRoots.d.ts +3 -0
- package/dist/core/languages/pythonRoots.js +83 -0
- package/dist/core/languages/pythonRoots.js.map +1 -0
- package/dist/core/languages/pythonSetuptools.d.ts +6 -0
- package/dist/core/languages/pythonSetuptools.js +58 -0
- package/dist/core/languages/pythonSetuptools.js.map +1 -0
- package/dist/core/prDiff.js +12 -0
- package/dist/core/prDiff.js.map +1 -1
- package/dist/core/preflight.d.ts +3 -3
- package/dist/core/preflight.js +28 -542
- package/dist/core/preflight.js.map +1 -1
- package/dist/core/preflightChangedFileReasons.d.ts +14 -0
- package/dist/core/preflightChangedFileReasons.js +75 -0
- package/dist/core/preflightChangedFileReasons.js.map +1 -0
- package/dist/core/preflightChangedFiles.d.ts +9 -0
- package/dist/core/preflightChangedFiles.js +34 -0
- package/dist/core/preflightChangedFiles.js.map +1 -0
- package/dist/core/preflightContextReasons.d.ts +17 -0
- package/dist/core/preflightContextReasons.js +73 -0
- package/dist/core/preflightContextReasons.js.map +1 -0
- package/dist/core/preflightEvidence.d.ts +34 -0
- package/dist/core/preflightEvidence.js +119 -0
- package/dist/core/preflightEvidence.js.map +1 -0
- package/dist/core/preflightInputs.d.ts +15 -0
- package/dist/core/preflightInputs.js +31 -0
- package/dist/core/preflightInputs.js.map +1 -0
- package/dist/core/preflightIssueReasons.d.ts +2 -0
- package/dist/core/preflightIssueReasons.js +39 -0
- package/dist/core/preflightIssueReasons.js.map +1 -0
- package/dist/core/preflightLocalEvidence.d.ts +12 -0
- package/dist/core/preflightLocalEvidence.js +36 -0
- package/dist/core/preflightLocalEvidence.js.map +1 -0
- package/dist/core/preflightReleaseScale.d.ts +28 -0
- package/dist/core/preflightReleaseScale.js +95 -0
- package/dist/core/preflightReleaseScale.js.map +1 -0
- package/dist/core/preflightRequiredChecks.d.ts +26 -0
- package/dist/core/preflightRequiredChecks.js +96 -0
- package/dist/core/preflightRequiredChecks.js.map +1 -0
- package/dist/core/preflightReviewEvidence.d.ts +16 -0
- package/dist/core/preflightReviewEvidence.js +31 -0
- package/dist/core/preflightReviewEvidence.js.map +1 -0
- package/dist/core/preflightReviewReasons.d.ts +15 -0
- package/dist/core/preflightReviewReasons.js +76 -0
- package/dist/core/preflightReviewReasons.js.map +1 -0
- package/dist/core/preflightSuggestedActions.d.ts +15 -0
- package/dist/core/preflightSuggestedActions.js +84 -0
- package/dist/core/preflightSuggestedActions.js.map +1 -0
- package/dist/core/preflightTruncation.d.ts +6 -0
- package/dist/core/preflightTruncation.js +7 -0
- package/dist/core/preflightTruncation.js.map +1 -0
- package/dist/core/preflightVerdict.d.ts +3 -0
- package/dist/core/preflightVerdict.js +17 -0
- package/dist/core/preflightVerdict.js.map +1 -0
- package/dist/core/releaseEvidence.d.ts +4 -3
- package/dist/core/releaseEvidence.js +12 -263
- package/dist/core/releaseEvidence.js.map +1 -1
- package/dist/core/releaseEvidenceBaseline.d.ts +2 -0
- package/dist/core/releaseEvidenceBaseline.js +28 -0
- package/dist/core/releaseEvidenceBaseline.js.map +1 -0
- package/dist/core/releaseEvidencePrSummary.d.ts +13 -0
- package/dist/core/releaseEvidencePrSummary.js +240 -0
- package/dist/core/releaseEvidencePrSummary.js.map +1 -0
- package/dist/core/releaseTrain.js +3 -317
- package/dist/core/releaseTrain.js.map +1 -1
- package/dist/core/releaseTrainFallbacks.d.ts +3 -0
- package/dist/core/releaseTrainFallbacks.js +318 -0
- package/dist/core/releaseTrainFallbacks.js.map +1 -0
- package/dist/core/reportScope.d.ts +24 -0
- package/dist/core/reportScope.js +234 -0
- package/dist/core/reportScope.js.map +1 -0
- package/dist/core/review.d.ts +2 -25
- package/dist/core/review.js +34 -1034
- package/dist/core/review.js.map +1 -1
- package/dist/core/reviewBaseSnapshot.d.ts +14 -0
- package/dist/core/reviewBaseSnapshot.js +41 -0
- package/dist/core/reviewBaseSnapshot.js.map +1 -0
- package/dist/core/reviewChangedFiles.d.ts +8 -0
- package/dist/core/reviewChangedFiles.js +63 -0
- package/dist/core/reviewChangedFiles.js.map +1 -0
- package/dist/core/reviewContractChanges.d.ts +5 -0
- package/dist/core/reviewContractChanges.js +114 -0
- package/dist/core/reviewContractChanges.js.map +1 -0
- package/dist/core/reviewCycles.d.ts +7 -0
- package/dist/core/reviewCycles.js +53 -0
- package/dist/core/reviewCycles.js.map +1 -0
- package/dist/core/reviewFindings.d.ts +17 -0
- package/dist/core/reviewFindings.js +49 -0
- package/dist/core/reviewFindings.js.map +1 -0
- package/dist/core/reviewFlowDiffs.d.ts +4 -0
- package/dist/core/reviewFlowDiffs.js +99 -0
- package/dist/core/reviewFlowDiffs.js.map +1 -0
- package/dist/core/reviewGit.d.ts +7 -0
- package/dist/core/reviewGit.js +45 -0
- package/dist/core/reviewGit.js.map +1 -0
- package/dist/core/reviewGraphEvidence.d.ts +3 -0
- package/dist/core/reviewGraphEvidence.js +55 -0
- package/dist/core/reviewGraphEvidence.js.map +1 -0
- package/dist/core/reviewHeadSnapshot.d.ts +8 -0
- package/dist/core/reviewHeadSnapshot.js +15 -0
- package/dist/core/reviewHeadSnapshot.js.map +1 -0
- package/dist/core/reviewIntent.d.ts +2 -0
- package/dist/core/reviewIntent.js +18 -0
- package/dist/core/reviewIntent.js.map +1 -0
- package/dist/core/reviewManifests.d.ts +12 -0
- package/dist/core/reviewManifests.js +124 -0
- package/dist/core/reviewManifests.js.map +1 -0
- package/dist/core/reviewNoChanges.d.ts +9 -0
- package/dist/core/reviewNoChanges.js +26 -0
- package/dist/core/reviewNoChanges.js.map +1 -0
- package/dist/core/reviewPackageScope.d.ts +4 -0
- package/dist/core/reviewPackageScope.js +24 -0
- package/dist/core/reviewPackageScope.js.map +1 -0
- package/dist/core/reviewRefs.d.ts +4 -0
- package/dist/core/reviewRefs.js +65 -0
- package/dist/core/reviewRefs.js.map +1 -0
- package/dist/core/reviewRiskyFunctions.d.ts +8 -0
- package/dist/core/reviewRiskyFunctions.js +83 -0
- package/dist/core/reviewRiskyFunctions.js.map +1 -0
- package/dist/core/reviewState.d.ts +21 -0
- package/dist/core/reviewState.js +96 -0
- package/dist/core/reviewState.js.map +1 -0
- package/dist/core/reviewTier.d.ts +18 -0
- package/dist/core/reviewTier.js +99 -0
- package/dist/core/reviewTier.js.map +1 -0
- package/dist/core/reviewVerdict.d.ts +9 -0
- package/dist/core/reviewVerdict.js +121 -0
- package/dist/core/reviewVerdict.js.map +1 -0
- package/dist/core/roadmapCatalog.d.ts +1 -0
- package/dist/core/roadmapCatalog.js +227 -7
- package/dist/core/roadmapCatalog.js.map +1 -1
- package/dist/core/start.d.ts +1 -1
- package/dist/core/start.js +26 -63
- package/dist/core/start.js.map +1 -1
- package/dist/core/startAdoptionGaps.d.ts +3 -0
- package/dist/core/startAdoptionGaps.js +12 -0
- package/dist/core/startAdoptionGaps.js.map +1 -0
- package/dist/core/startInputs.d.ts +31 -0
- package/dist/core/startInputs.js +27 -0
- package/dist/core/startInputs.js.map +1 -0
- package/dist/core/startMode.js +7 -1
- package/dist/core/startMode.js.map +1 -1
- package/dist/core/startNextActions.d.ts +13 -0
- package/dist/core/startNextActions.js +19 -0
- package/dist/core/startNextActions.js.map +1 -0
- package/dist/core/startReportBuilder.d.ts +25 -0
- package/dist/core/startReportBuilder.js +44 -0
- package/dist/core/startReportBuilder.js.map +1 -0
- package/dist/core/taint.js +14 -125
- package/dist/core/taint.js.map +1 -1
- package/dist/core/taintMatching.d.ts +11 -0
- package/dist/core/taintMatching.js +126 -0
- package/dist/core/taintMatching.js.map +1 -0
- package/dist/core/upgradePreview.d.ts +1 -12
- package/dist/core/upgradePreview.js +12 -160
- package/dist/core/upgradePreview.js.map +1 -1
- package/dist/core/upgradePreviewNpmEvidence.d.ts +19 -0
- package/dist/core/upgradePreviewNpmEvidence.js +164 -0
- package/dist/core/upgradePreviewNpmEvidence.js.map +1 -0
- package/dist/core/upgradePreviewPython.d.ts +2 -0
- package/dist/core/upgradePreviewPython.js +71 -0
- package/dist/core/upgradePreviewPython.js.map +1 -0
- package/dist/index.d.ts +6 -12
- package/dist/index.js +2 -3
- package/dist/index.js.map +1 -1
- package/dist/mcp/server.d.ts +3 -24
- package/dist/mcp/server.js +32 -414
- package/dist/mcp/server.js.map +1 -1
- package/dist/mcp/serverContext.d.ts +6 -0
- package/dist/mcp/serverContext.js +55 -0
- package/dist/mcp/serverContext.js.map +1 -0
- package/dist/mcp/serverDispatch.d.ts +39 -0
- package/dist/mcp/serverDispatch.js +74 -0
- package/dist/mcp/serverDispatch.js.map +1 -0
- package/dist/mcp/serverHandlers.d.ts +15 -0
- package/dist/mcp/serverHandlers.js +94 -0
- package/dist/mcp/serverHandlers.js.map +1 -0
- package/dist/mcp/serverLifecycle.d.ts +14 -0
- package/dist/mcp/serverLifecycle.js +65 -0
- package/dist/mcp/serverLifecycle.js.map +1 -0
- package/dist/mcp/serverMessage.d.ts +11 -0
- package/dist/mcp/serverMessage.js +37 -0
- package/dist/mcp/serverMessage.js.map +1 -0
- package/dist/mcp/serverSession.d.ts +6 -0
- package/dist/mcp/serverSession.js +77 -0
- package/dist/mcp/serverSession.js.map +1 -0
- package/dist/mcp/serverStdio.d.ts +7 -0
- package/dist/mcp/serverStdio.js +34 -0
- package/dist/mcp/serverStdio.js.map +1 -0
- package/dist/mcp/serverTypes.d.ts +18 -0
- package/dist/mcp/serverTypes.js +2 -0
- package/dist/mcp/serverTypes.js.map +1 -0
- package/dist/mcp/serverVersion.d.ts +1 -0
- package/dist/mcp/serverVersion.js +17 -0
- package/dist/mcp/serverVersion.js.map +1 -0
- package/dist/mcp/toolCatalog.d.ts +2 -0
- package/dist/mcp/toolCatalog.js +93 -0
- package/dist/mcp/toolCatalog.js.map +1 -0
- package/dist/mcp/tools/upgrade.d.ts +1 -1
- package/dist/mcp/tools/upgrade.js +2 -16
- package/dist/mcp/tools/upgrade.js.map +1 -1
- package/dist/mcp/tools.d.ts +2 -3
- package/dist/mcp/tools.js +5 -97
- package/dist/mcp/tools.js.map +1 -1
- package/dist/projscan-sbom.cdx.json +6 -6
- package/dist/reporters/consoleUpgradeReporter.js +24 -2
- package/dist/reporters/consoleUpgradeReporter.js.map +1 -1
- package/dist/reporters/htmlReporter.d.ts +3 -2
- package/dist/reporters/htmlReporter.js +14 -2
- package/dist/reporters/htmlReporter.js.map +1 -1
- package/dist/reporters/jsonReporter.d.ts +4 -3
- package/dist/reporters/jsonReporter.js +9 -4
- package/dist/reporters/jsonReporter.js.map +1 -1
- package/dist/reporters/markdownAnalysisReporter.d.ts +2 -1
- package/dist/reporters/markdownAnalysisReporter.js +8 -1
- package/dist/reporters/markdownAnalysisReporter.js.map +1 -1
- package/dist/reporters/markdownArchitectureReporter.d.ts +3 -0
- package/dist/reporters/markdownArchitectureReporter.js +33 -0
- package/dist/reporters/markdownArchitectureReporter.js.map +1 -0
- package/dist/reporters/markdownCouplingReporter.d.ts +2 -0
- package/dist/reporters/markdownCouplingReporter.js +43 -0
- package/dist/reporters/markdownCouplingReporter.js.map +1 -0
- package/dist/reporters/markdownCoverageReporter.d.ts +2 -0
- package/dist/reporters/markdownCoverageReporter.js +40 -0
- package/dist/reporters/markdownCoverageReporter.js.map +1 -0
- package/dist/reporters/markdownExplanationReporter.d.ts +2 -0
- package/dist/reporters/markdownExplanationReporter.js +37 -0
- package/dist/reporters/markdownExplanationReporter.js.map +1 -0
- package/dist/reporters/markdownHealthReporter.d.ts +4 -0
- package/dist/reporters/markdownHealthReporter.js +66 -0
- package/dist/reporters/markdownHealthReporter.js.map +1 -0
- package/dist/reporters/markdownHotspotReporter.d.ts +2 -0
- package/dist/reporters/markdownHotspotReporter.js +36 -0
- package/dist/reporters/markdownHotspotReporter.js.map +1 -0
- package/dist/reporters/markdownOutdatedReporter.d.ts +2 -0
- package/dist/reporters/markdownOutdatedReporter.js +31 -0
- package/dist/reporters/markdownOutdatedReporter.js.map +1 -0
- package/dist/reporters/markdownPrDiffReporter.d.ts +2 -0
- package/dist/reporters/markdownPrDiffReporter.js +63 -0
- package/dist/reporters/markdownPrDiffReporter.js.map +1 -0
- package/dist/reporters/markdownReporter.d.ts +9 -12
- package/dist/reporters/markdownReporter.js +9 -288
- package/dist/reporters/markdownReporter.js.map +1 -1
- package/dist/reporters/markdownUpgradeReporter.js +19 -4
- package/dist/reporters/markdownUpgradeReporter.js.map +1 -1
- package/dist/reporters/markdownWorkspaceReporter.d.ts +2 -0
- package/dist/reporters/markdownWorkspaceReporter.js +25 -0
- package/dist/reporters/markdownWorkspaceReporter.js.map +1 -0
- package/dist/reporters/sarifReporter.d.ts +6 -4
- package/dist/reporters/sarifReporter.js +8 -7
- package/dist/reporters/sarifReporter.js.map +1 -1
- package/dist/tool-manifest.json +4 -4
- package/dist/types/config.d.ts +10 -0
- package/dist/types/dependencyHealth.d.ts +12 -0
- package/dist/types.d.ts +34 -34
- package/dist/utils/config.d.ts +2 -8
- package/dist/utils/config.js +14 -180
- package/dist/utils/config.js.map +1 -1
- package/dist/utils/configBasics.d.ts +5 -0
- package/dist/utils/configBasics.js +21 -0
- package/dist/utils/configBasics.js.map +1 -0
- package/dist/utils/configHotspots.d.ts +2 -0
- package/dist/utils/configHotspots.js +15 -0
- package/dist/utils/configHotspots.js.map +1 -0
- package/dist/utils/configIssueRules.d.ts +8 -0
- package/dist/utils/configIssueRules.js +24 -0
- package/dist/utils/configIssueRules.js.map +1 -0
- package/dist/utils/configMonorepo.d.ts +2 -0
- package/dist/utils/configMonorepo.js +38 -0
- package/dist/utils/configMonorepo.js.map +1 -0
- package/dist/utils/configReportPolicies.d.ts +2 -0
- package/dist/utils/configReportPolicies.js +32 -0
- package/dist/utils/configReportPolicies.js.map +1 -0
- package/dist/utils/configScan.d.ts +2 -0
- package/dist/utils/configScan.js +15 -0
- package/dist/utils/configScan.js.map +1 -0
- package/dist/utils/configSeverity.d.ts +2 -0
- package/dist/utils/configSeverity.js +15 -0
- package/dist/utils/configSeverity.js.map +1 -0
- package/dist/utils/configSources.d.ts +5 -0
- package/dist/utils/configSources.js +55 -0
- package/dist/utils/configSources.js.map +1 -0
- package/dist/utils/configTaint.d.ts +2 -0
- package/dist/utils/configTaint.js +15 -0
- package/dist/utils/configTaint.js.map +1 -0
- package/docs/GUIDE.md +39 -4
- package/docs/ROADMAP.md +54 -21
- package/docs/examples/adoption-workflows.md +128 -0
- package/docs/examples/swarm-coordination.md +120 -0
- package/package.json +3 -1
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
export function buildReleaseScaleEvidence(input) {
|
|
2
|
+
const state = releaseScaleState(input);
|
|
3
|
+
if (!state)
|
|
4
|
+
return null;
|
|
5
|
+
return releaseScaleEvidence(input, state);
|
|
6
|
+
}
|
|
7
|
+
function releaseScaleState(input) {
|
|
8
|
+
if (!canEvaluateReleaseScale(input))
|
|
9
|
+
return null;
|
|
10
|
+
const concreteBlockers = concretePreflightBlockers(input);
|
|
11
|
+
if (concreteBlockers.length > 0)
|
|
12
|
+
return null;
|
|
13
|
+
const signals = releaseScaleSignals(input);
|
|
14
|
+
if (!signals.detected)
|
|
15
|
+
return null;
|
|
16
|
+
return { concreteBlockers, signals };
|
|
17
|
+
}
|
|
18
|
+
function releaseScaleEvidence(input, state) {
|
|
19
|
+
return {
|
|
20
|
+
detected: true,
|
|
21
|
+
changedFiles: input.changedFiles.count,
|
|
22
|
+
threshold: input.maxChangedFiles,
|
|
23
|
+
...(input.review.verdict ? { reviewVerdict: input.review.verdict } : {}),
|
|
24
|
+
...(state.signals.reviewSummary ? { reviewSummary: state.signals.reviewSummary } : {}),
|
|
25
|
+
concreteBlockers: state.concreteBlockers,
|
|
26
|
+
explanation: releaseScaleExplanation(state.signals),
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
function canEvaluateReleaseScale(input) {
|
|
30
|
+
return input.mode !== 'before_edit' && input.changedFiles.available;
|
|
31
|
+
}
|
|
32
|
+
function releaseScaleSignals(input) {
|
|
33
|
+
const reviewSummary = input.review.summary;
|
|
34
|
+
const changedFileThresholdExceeded = input.changedFiles.count > input.maxChangedFiles;
|
|
35
|
+
const reviewBlocksOnScale = reviewBlocks(input.review);
|
|
36
|
+
const reviewScaleOnly = reviewBlocksOnScale && isScaleComplexityReviewBlock(reviewSummary);
|
|
37
|
+
return {
|
|
38
|
+
detected: changedFileThresholdExceeded || reviewScaleOnly,
|
|
39
|
+
changedFileThresholdExceeded,
|
|
40
|
+
reviewScaleOnly,
|
|
41
|
+
reviewBlocksOnScale,
|
|
42
|
+
...(reviewSummary ? { reviewSummary } : {}),
|
|
43
|
+
triggers: releaseScaleTriggers(input, changedFileThresholdExceeded, reviewScaleOnly),
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
function releaseScaleTriggers(input, changedFileThresholdExceeded, reviewScaleOnly) {
|
|
47
|
+
const triggers = [];
|
|
48
|
+
if (changedFileThresholdExceeded) {
|
|
49
|
+
triggers.push(`${input.changedFiles.count} changed files exceeds the preflight threshold of ${input.maxChangedFiles}`);
|
|
50
|
+
}
|
|
51
|
+
if (reviewScaleOnly && input.review.summary) {
|
|
52
|
+
triggers.push(`review signal: ${trimTrailingSentencePunctuation(input.review.summary)}`);
|
|
53
|
+
}
|
|
54
|
+
return triggers;
|
|
55
|
+
}
|
|
56
|
+
function releaseScaleExplanation(signals) {
|
|
57
|
+
return `Large platform release risk: ${signals.triggers.join('; ')}. ${releaseScaleExplanationTail(signals)}${releaseScaleSignoffTail(signals.reviewSummary)}`;
|
|
58
|
+
}
|
|
59
|
+
function releaseScaleExplanationTail(signals) {
|
|
60
|
+
if (signals.reviewBlocksOnScale) {
|
|
61
|
+
return 'Review blocks on scale/complexity rather than new taint, dataflow, health, plugin, or supply-chain defects.';
|
|
62
|
+
}
|
|
63
|
+
return 'This is a configured scale threshold/manual review signal, not a concrete taint, dataflow, health, plugin, or supply-chain defect.';
|
|
64
|
+
}
|
|
65
|
+
function releaseScaleSignoffTail(reviewSummary) {
|
|
66
|
+
if (reviewSummary?.toLowerCase().includes('manual release sign-off'))
|
|
67
|
+
return '';
|
|
68
|
+
return ' Treat this as a manual release sign-off gate.';
|
|
69
|
+
}
|
|
70
|
+
function reviewBlocks(review) {
|
|
71
|
+
return review.available && review.verdict === 'block';
|
|
72
|
+
}
|
|
73
|
+
function isScaleComplexityReviewBlock(summary) {
|
|
74
|
+
if (!summary?.includes('Maximum changed-file risk score'))
|
|
75
|
+
return false;
|
|
76
|
+
return !summary.includes('new import cycle');
|
|
77
|
+
}
|
|
78
|
+
function trimTrailingSentencePunctuation(value) {
|
|
79
|
+
return value.trim().replace(/[.]+$/u, '');
|
|
80
|
+
}
|
|
81
|
+
function concretePreflightBlockers(input) {
|
|
82
|
+
const blockers = [];
|
|
83
|
+
if (input.health.errors > 0)
|
|
84
|
+
blockers.push('health');
|
|
85
|
+
if (input.supplyChain.errorIssues > 0)
|
|
86
|
+
blockers.push('supply-chain');
|
|
87
|
+
if (input.issues.some((issue) => issue.id.startsWith('plugin:') && issue.severity === 'error'))
|
|
88
|
+
blockers.push('plugin');
|
|
89
|
+
if ((input.review.newTaintFlows ?? 0) > 0)
|
|
90
|
+
blockers.push('taint');
|
|
91
|
+
if ((input.review.newDataflowRisks ?? 0) > 0)
|
|
92
|
+
blockers.push('dataflow');
|
|
93
|
+
return blockers;
|
|
94
|
+
}
|
|
95
|
+
//# sourceMappingURL=preflightReleaseScale.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"preflightReleaseScale.js","sourceRoot":"","sources":["../../src/core/preflightReleaseScale.ts"],"names":[],"mappings":"AAkDA,MAAM,UAAU,yBAAyB,CACvC,KAAwB;IAExB,MAAM,KAAK,GAAG,iBAAiB,CAAC,KAAK,CAAC,CAAC;IACvC,IAAI,CAAC,KAAK;QAAE,OAAO,IAAI,CAAC;IAExB,OAAO,oBAAoB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AAC5C,CAAC;AAED,SAAS,iBAAiB,CAAC,KAAwB;IACjD,IAAI,CAAC,uBAAuB,CAAC,KAAK,CAAC;QAAE,OAAO,IAAI,CAAC;IAEjD,MAAM,gBAAgB,GAAG,yBAAyB,CAAC,KAAK,CAAC,CAAC;IAC1D,IAAI,gBAAgB,CAAC,MAAM,GAAG,CAAC;QAAE,OAAO,IAAI,CAAC;IAE7C,MAAM,OAAO,GAAG,mBAAmB,CAAC,KAAK,CAAC,CAAC;IAC3C,IAAI,CAAC,OAAO,CAAC,QAAQ;QAAE,OAAO,IAAI,CAAC;IAEnC,OAAO,EAAE,gBAAgB,EAAE,OAAO,EAAE,CAAC;AACvC,CAAC;AAED,SAAS,oBAAoB,CAC3B,KAAwB,EACxB,KAAwB;IAExB,OAAO;QACL,QAAQ,EAAE,IAAI;QACd,YAAY,EAAE,KAAK,CAAC,YAAY,CAAC,KAAK;QACtC,SAAS,EAAE,KAAK,CAAC,eAAe;QAChC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,aAAa,EAAE,KAAK,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACxE,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,aAAa,EAAE,KAAK,CAAC,OAAO,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACtF,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;QACxC,WAAW,EAAE,uBAAuB,CAAC,KAAK,CAAC,OAAO,CAAC;KACpD,CAAC;AACJ,CAAC;AAED,SAAS,uBAAuB,CAAC,KAAwB;IACvD,OAAO,KAAK,CAAC,IAAI,KAAK,aAAa,IAAI,KAAK,CAAC,YAAY,CAAC,SAAS,CAAC;AACtE,CAAC;AAED,SAAS,mBAAmB,CAAC,KAAwB;IACnD,MAAM,aAAa,GAAG,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC;IAC3C,MAAM,4BAA4B,GAAG,KAAK,CAAC,YAAY,CAAC,KAAK,GAAG,KAAK,CAAC,eAAe,CAAC;IACtF,MAAM,mBAAmB,GAAG,YAAY,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IACvD,MAAM,eAAe,GACnB,mBAAmB,IAAI,4BAA4B,CAAC,aAAa,CAAC,CAAC;IACrE,OAAO;QACL,QAAQ,EAAE,4BAA4B,IAAI,eAAe;QACzD,4BAA4B;QAC5B,eAAe;QACf,mBAAmB;QACnB,GAAG,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,aAAa,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAC3C,QAAQ,EAAE,oBAAoB,CAAC,KAAK,EAAE,4BAA4B,EAAE,eAAe,CAAC;KACrF,CAAC;AACJ,CAAC;AAED,SAAS,oBAAoB,CAC3B,KAAwB,EACxB,4BAAqC,EACrC,eAAwB;IAExB,MAAM,QAAQ,GAAa,EAAE,CAAC;IAC9B,IAAI,4BAA4B,EAAE,CAAC;QACjC,QAAQ,CAAC,IAAI,CACX,GAAG,KAAK,CAAC,YAAY,CAAC,KAAK,qDAAqD,KAAK,CAAC,eAAe,EAAE,CACxG,CAAC;IACJ,CAAC;IACD,IAAI,eAAe,IAAI,KAAK,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;QAC5C,QAAQ,CAAC,IAAI,CAAC,kBAAkB,+BAA+B,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IAC3F,CAAC;IACD,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED,SAAS,uBAAuB,CAAC,OAA4B;IAC3D,OAAO,gCAAgC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,2BAA2B,CAAC,OAAO,CAAC,GAAG,uBAAuB,CAAC,OAAO,CAAC,aAAa,CAAC,EAAE,CAAC;AACjK,CAAC;AAED,SAAS,2BAA2B,CAAC,OAA4B;IAC/D,IAAI,OAAO,CAAC,mBAAmB,EAAE,CAAC;QAChC,OAAO,6GAA6G,CAAC;IACvH,CAAC;IACD,OAAO,oIAAoI,CAAC;AAC9I,CAAC;AAED,SAAS,uBAAuB,CAAC,aAAiC;IAChE,IAAI,aAAa,EAAE,WAAW,EAAE,CAAC,QAAQ,CAAC,yBAAyB,CAAC;QAAE,OAAO,EAAE,CAAC;IAChF,OAAO,gDAAgD,CAAC;AAC1D,CAAC;AAED,SAAS,YAAY,CAAC,MAAsB;IAC1C,OAAO,MAAM,CAAC,SAAS,IAAI,MAAM,CAAC,OAAO,KAAK,OAAO,CAAC;AACxD,CAAC;AAED,SAAS,4BAA4B,CAAC,OAA2B;IAC/D,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,iCAAiC,CAAC;QAAE,OAAO,KAAK,CAAC;IACxE,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAAC;AAC/C,CAAC;AAED,SAAS,+BAA+B,CAAC,KAAa;IACpD,OAAO,KAAK,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;AAC5C,CAAC;AAED,SAAS,yBAAyB,CAAC,KAAwB;IACzD,MAAM,QAAQ,GAAa,EAAE,CAAC;IAC9B,IAAI,KAAK,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC;QAAE,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACrD,IAAI,KAAK,CAAC,WAAW,CAAC,WAAW,GAAG,CAAC;QAAE,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IACrE,IAAI,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,KAAK,CAAC,QAAQ,KAAK,OAAO,CAAC;QAC5F,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC1B,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,aAAa,IAAI,CAAC,CAAC,GAAG,CAAC;QAAE,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAClE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,gBAAgB,IAAI,CAAC,CAAC,GAAG,CAAC;QAAE,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACxE,OAAO,QAAQ,CAAC;AAClB,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import type { HealthScore, PreflightMode, PreflightReleaseScaleEvidence, PreflightRequiredCheck } from '../types.js';
|
|
2
|
+
import type { ReviewReport } from '../types/review.js';
|
|
3
|
+
interface ChangedFilesEvidence {
|
|
4
|
+
available: boolean;
|
|
5
|
+
count: number;
|
|
6
|
+
reason?: string;
|
|
7
|
+
}
|
|
8
|
+
interface ReviewEvidence {
|
|
9
|
+
available: boolean;
|
|
10
|
+
verdict?: ReviewReport['verdict'];
|
|
11
|
+
summary?: string;
|
|
12
|
+
reason?: string;
|
|
13
|
+
}
|
|
14
|
+
interface PolicyIssueCounts {
|
|
15
|
+
errorIssues: number;
|
|
16
|
+
warningIssues: number;
|
|
17
|
+
}
|
|
18
|
+
export declare function buildRequiredChecks(input: {
|
|
19
|
+
mode: PreflightMode;
|
|
20
|
+
health: HealthScore;
|
|
21
|
+
changedFiles: ChangedFilesEvidence;
|
|
22
|
+
review: ReviewEvidence;
|
|
23
|
+
supplyChain?: PolicyIssueCounts;
|
|
24
|
+
releaseScale?: PreflightReleaseScaleEvidence | null;
|
|
25
|
+
}): PreflightRequiredCheck[];
|
|
26
|
+
export {};
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
export function buildRequiredChecks(input) {
|
|
2
|
+
return [
|
|
3
|
+
healthRequiredCheck(input.health),
|
|
4
|
+
supplyChainRequiredCheck(input.supplyChain),
|
|
5
|
+
changedFilesRequiredCheck(input.changedFiles),
|
|
6
|
+
reviewRequiredCheck(input.mode, input.review, input.releaseScale),
|
|
7
|
+
];
|
|
8
|
+
}
|
|
9
|
+
function healthRequiredCheck(health) {
|
|
10
|
+
return {
|
|
11
|
+
name: 'health',
|
|
12
|
+
status: healthCheckStatus(health),
|
|
13
|
+
reason: `${health.errors} error(s), ${health.warnings} warning(s), ${health.infos} info`,
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
function healthCheckStatus(health) {
|
|
17
|
+
if (health.errors > 0)
|
|
18
|
+
return 'fail';
|
|
19
|
+
if (health.warnings > 0)
|
|
20
|
+
return 'warn';
|
|
21
|
+
return 'pass';
|
|
22
|
+
}
|
|
23
|
+
function supplyChainRequiredCheck(supplyChain) {
|
|
24
|
+
const { errorIssues, warningIssues } = normalizedPolicyIssueCounts(supplyChain);
|
|
25
|
+
return {
|
|
26
|
+
name: 'supply-chain',
|
|
27
|
+
status: policyCheckStatus(errorIssues, warningIssues),
|
|
28
|
+
reason: `${errorIssues} error(s), ${warningIssues} warning(s)`,
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
function normalizedPolicyIssueCounts(supplyChain) {
|
|
32
|
+
return {
|
|
33
|
+
errorIssues: supplyChain?.errorIssues ?? 0,
|
|
34
|
+
warningIssues: supplyChain?.warningIssues ?? 0,
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
function policyCheckStatus(errorIssues, warningIssues) {
|
|
38
|
+
if (errorIssues > 0)
|
|
39
|
+
return 'fail';
|
|
40
|
+
if (warningIssues > 0)
|
|
41
|
+
return 'warn';
|
|
42
|
+
return 'pass';
|
|
43
|
+
}
|
|
44
|
+
function changedFilesRequiredCheck(changedFiles) {
|
|
45
|
+
return {
|
|
46
|
+
name: 'changed-files',
|
|
47
|
+
status: changedFiles.available ? 'pass' : 'unavailable',
|
|
48
|
+
reason: changedFiles.available
|
|
49
|
+
? `${changedFiles.count} changed file(s)`
|
|
50
|
+
: (changedFiles.reason ?? 'changed-file detection unavailable'),
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
function reviewRequiredCheck(mode, review, releaseScale) {
|
|
54
|
+
return {
|
|
55
|
+
name: 'review',
|
|
56
|
+
status: reviewCheckStatus(mode, review, releaseScale),
|
|
57
|
+
reason: reviewCheckReason(mode, review, releaseScale),
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
function reviewCheckStatus(mode, review, releaseScale) {
|
|
61
|
+
if (mode === 'before_edit')
|
|
62
|
+
return 'unavailable';
|
|
63
|
+
if (!review.available)
|
|
64
|
+
return 'unavailable';
|
|
65
|
+
if (review.verdict === 'block')
|
|
66
|
+
return reviewBlockStatus(releaseScale);
|
|
67
|
+
if (review.verdict === 'review')
|
|
68
|
+
return 'warn';
|
|
69
|
+
return 'pass';
|
|
70
|
+
}
|
|
71
|
+
function reviewBlockStatus(releaseScale) {
|
|
72
|
+
return releaseScale?.detected ? 'warn' : 'fail';
|
|
73
|
+
}
|
|
74
|
+
function reviewCheckReason(mode, review, releaseScale) {
|
|
75
|
+
if (mode === 'before_edit')
|
|
76
|
+
return 'review is not required before edits';
|
|
77
|
+
if (!review.available)
|
|
78
|
+
return review.reason ?? 'review unavailable';
|
|
79
|
+
return formatReviewCheckReason(review, releaseScale);
|
|
80
|
+
}
|
|
81
|
+
function formatReviewCheckReason(review, releaseScale) {
|
|
82
|
+
if (usesReleaseScaleReason(review, releaseScale)) {
|
|
83
|
+
return `scale/complexity: ${reviewCheckFallback(review)}`;
|
|
84
|
+
}
|
|
85
|
+
return reviewCheckFallback(review);
|
|
86
|
+
}
|
|
87
|
+
function usesReleaseScaleReason(review, releaseScale) {
|
|
88
|
+
return review.verdict === 'block' && releaseScaleDetected(releaseScale);
|
|
89
|
+
}
|
|
90
|
+
function releaseScaleDetected(releaseScale) {
|
|
91
|
+
return releaseScale?.detected === true;
|
|
92
|
+
}
|
|
93
|
+
function reviewCheckFallback(review) {
|
|
94
|
+
return review.summary ?? review.verdict ?? 'review unavailable';
|
|
95
|
+
}
|
|
96
|
+
//# sourceMappingURL=preflightRequiredChecks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"preflightRequiredChecks.js","sourceRoot":"","sources":["../../src/core/preflightRequiredChecks.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { PreflightMode } from '../types.js';
|
|
2
|
+
import type { ReviewReport } from '../types/review.js';
|
|
3
|
+
interface PreflightReviewOptions {
|
|
4
|
+
baseRef?: string;
|
|
5
|
+
headRef?: string;
|
|
6
|
+
}
|
|
7
|
+
export interface PreflightReviewEvidence {
|
|
8
|
+
available: boolean;
|
|
9
|
+
verdict?: ReviewReport['verdict'];
|
|
10
|
+
summary?: string;
|
|
11
|
+
reason?: string;
|
|
12
|
+
newTaintFlows?: number;
|
|
13
|
+
newDataflowRisks?: number;
|
|
14
|
+
}
|
|
15
|
+
export declare function safeReviewEvidence(rootPath: string, mode: PreflightMode, options: PreflightReviewOptions): Promise<PreflightReviewEvidence>;
|
|
16
|
+
export {};
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { computeReview } from './review.js';
|
|
2
|
+
export async function safeReviewEvidence(rootPath, mode, options) {
|
|
3
|
+
if (mode === 'before_edit') {
|
|
4
|
+
return { available: false, reason: 'review is not required before edits' };
|
|
5
|
+
}
|
|
6
|
+
try {
|
|
7
|
+
return reviewEvidenceFromReport(await computeReview(rootPath, {
|
|
8
|
+
base: options.baseRef,
|
|
9
|
+
head: options.headRef,
|
|
10
|
+
}));
|
|
11
|
+
}
|
|
12
|
+
catch (err) {
|
|
13
|
+
return {
|
|
14
|
+
available: false,
|
|
15
|
+
reason: err instanceof Error ? err.message : String(err),
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
function reviewEvidenceFromReport(report) {
|
|
20
|
+
if (!report.available) {
|
|
21
|
+
return { available: false, reason: report.reason };
|
|
22
|
+
}
|
|
23
|
+
return {
|
|
24
|
+
available: true,
|
|
25
|
+
verdict: report.verdict,
|
|
26
|
+
summary: report.summary.join('; '),
|
|
27
|
+
newTaintFlows: report.newTaintFlows.length,
|
|
28
|
+
newDataflowRisks: report.newDataflowRisks.length,
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=preflightReviewEvidence.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"preflightReviewEvidence.js","sourceRoot":"","sources":["../../src/core/preflightReviewEvidence.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAkB5C,MAAM,CAAC,KAAK,UAAU,kBAAkB,CACtC,QAAgB,EAChB,IAAmB,EACnB,OAA+B;IAE/B,IAAI,IAAI,KAAK,aAAa,EAAE,CAAC;QAC3B,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,qCAAqC,EAAE,CAAC;IAC7E,CAAC;IACD,IAAI,CAAC;QACH,OAAO,wBAAwB,CAC7B,MAAM,aAAa,CAAC,QAAQ,EAAE;YAC5B,IAAI,EAAE,OAAO,CAAC,OAAO;YACrB,IAAI,EAAE,OAAO,CAAC,OAAO;SACtB,CAAC,CACH,CAAC;IACJ,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO;YACL,SAAS,EAAE,KAAK;YAChB,MAAM,EAAE,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC;SACzD,CAAC;IACJ,CAAC;AACH,CAAC;AAED,SAAS,wBAAwB,CAAC,MAAoB;IACpD,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;QACtB,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC;IACrD,CAAC;IACD,OAAO;QACL,SAAS,EAAE,IAAI;QACf,OAAO,EAAE,MAAM,CAAC,OAAO;QACvB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC;QAClC,aAAa,EAAE,MAAM,CAAC,aAAa,CAAC,MAAM;QAC1C,gBAAgB,EAAE,MAAM,CAAC,gBAAgB,CAAC,MAAM;KACjD,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { PreflightMode, PreflightReason, PreflightReleaseScaleEvidence } from '../types.js';
|
|
2
|
+
import type { ReviewReport } from '../types/review.js';
|
|
3
|
+
interface ReviewEvidence {
|
|
4
|
+
available: boolean;
|
|
5
|
+
verdict?: ReviewReport['verdict'];
|
|
6
|
+
summary?: string;
|
|
7
|
+
reason?: string;
|
|
8
|
+
newTaintFlows?: number;
|
|
9
|
+
}
|
|
10
|
+
export declare function reviewReasons(input: {
|
|
11
|
+
mode: PreflightMode;
|
|
12
|
+
review: ReviewEvidence;
|
|
13
|
+
releaseScale: PreflightReleaseScaleEvidence | null;
|
|
14
|
+
}): PreflightReason[];
|
|
15
|
+
export {};
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
export function reviewReasons(input) {
|
|
2
|
+
const reasons = [];
|
|
3
|
+
const taint = taintReason(input.review);
|
|
4
|
+
const verdict = reviewVerdictReason(input.review, input.releaseScale);
|
|
5
|
+
const unavailable = reviewUnavailableReason(input.mode, input.review);
|
|
6
|
+
if (taint)
|
|
7
|
+
reasons.push(taint);
|
|
8
|
+
if (verdict)
|
|
9
|
+
reasons.push(verdict);
|
|
10
|
+
if (unavailable)
|
|
11
|
+
reasons.push(unavailable);
|
|
12
|
+
return reasons;
|
|
13
|
+
}
|
|
14
|
+
function taintReason(review) {
|
|
15
|
+
const newTaintFlows = review.newTaintFlows ?? 0;
|
|
16
|
+
if (!review.available || newTaintFlows <= 0)
|
|
17
|
+
return undefined;
|
|
18
|
+
return {
|
|
19
|
+
severity: 'error',
|
|
20
|
+
source: 'taint',
|
|
21
|
+
message: `${newTaintFlows} new taint flow(s) found in review`,
|
|
22
|
+
tool: 'projscan_review',
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
function reviewVerdictReason(review, releaseScale) {
|
|
26
|
+
if (!review.available)
|
|
27
|
+
return undefined;
|
|
28
|
+
if (review.verdict === 'block') {
|
|
29
|
+
return reviewBlockReason(review, releaseScale);
|
|
30
|
+
}
|
|
31
|
+
return reviewCautionReason(review);
|
|
32
|
+
}
|
|
33
|
+
function reviewBlockReason(review, releaseScale) {
|
|
34
|
+
return {
|
|
35
|
+
severity: releaseScale?.detected ? 'warning' : 'error',
|
|
36
|
+
source: 'review',
|
|
37
|
+
message: formatReviewBlockMessage(review, releaseScale),
|
|
38
|
+
tool: 'projscan_review',
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
function reviewCautionReason(review) {
|
|
42
|
+
if (review.verdict === 'review') {
|
|
43
|
+
return {
|
|
44
|
+
severity: 'warning',
|
|
45
|
+
source: 'review',
|
|
46
|
+
message: 'Review verdict requires careful review',
|
|
47
|
+
tool: 'projscan_review',
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
return undefined;
|
|
51
|
+
}
|
|
52
|
+
function reviewUnavailableReason(mode, review) {
|
|
53
|
+
if (!shouldReportReviewUnavailable(mode, review))
|
|
54
|
+
return undefined;
|
|
55
|
+
return reviewUnavailableWarning(review.reason);
|
|
56
|
+
}
|
|
57
|
+
function shouldReportReviewUnavailable(mode, review) {
|
|
58
|
+
if (mode === 'before_edit')
|
|
59
|
+
return false;
|
|
60
|
+
return !review.available;
|
|
61
|
+
}
|
|
62
|
+
function reviewUnavailableWarning(reason) {
|
|
63
|
+
return {
|
|
64
|
+
severity: 'warning',
|
|
65
|
+
source: 'review',
|
|
66
|
+
message: `Review unavailable: ${reason ?? 'unknown reason'}`,
|
|
67
|
+
tool: 'projscan_review',
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
function formatReviewBlockMessage(review, releaseScale) {
|
|
71
|
+
if (releaseScale?.detected) {
|
|
72
|
+
return `Review verdict is block due to scale/complexity risk: ${review.summary ?? 'review requires manual sign-off'}`;
|
|
73
|
+
}
|
|
74
|
+
return 'Review verdict is block';
|
|
75
|
+
}
|
|
76
|
+
//# sourceMappingURL=preflightReviewReasons.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"preflightReviewReasons.js","sourceRoot":"","sources":["../../src/core/preflightReviewReasons.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { PreflightMode, PreflightReason, PreflightSuggestedAction } from '../types.js';
|
|
2
|
+
interface ChangedFilesEvidence {
|
|
3
|
+
available: boolean;
|
|
4
|
+
}
|
|
5
|
+
export declare function buildSuggestedActions(input: {
|
|
6
|
+
reasons: PreflightReason[];
|
|
7
|
+
mode: PreflightMode;
|
|
8
|
+
changedFiles: ChangedFilesEvidence;
|
|
9
|
+
}): PreflightSuggestedAction[];
|
|
10
|
+
export declare function buildToolCalls(input: {
|
|
11
|
+
reasons: PreflightReason[];
|
|
12
|
+
mode: PreflightMode;
|
|
13
|
+
changedFiles: ChangedFilesEvidence;
|
|
14
|
+
}): PreflightSuggestedAction[];
|
|
15
|
+
export {};
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
export function buildSuggestedActions(input) {
|
|
2
|
+
if (input.reasons.length === 0)
|
|
3
|
+
return [];
|
|
4
|
+
return dedupeActions(actionsForReasons(input));
|
|
5
|
+
}
|
|
6
|
+
export function buildToolCalls(input) {
|
|
7
|
+
return buildSuggestedActions(input).map(toToolCallAction);
|
|
8
|
+
}
|
|
9
|
+
function actionsForReasons(input) {
|
|
10
|
+
return [
|
|
11
|
+
reviewActionForReasons(input.reasons),
|
|
12
|
+
healthPolicyActionForReasons(input.reasons),
|
|
13
|
+
sessionActionForReasons(input.reasons),
|
|
14
|
+
explicitBaseActionForState(input.mode, input.changedFiles),
|
|
15
|
+
].filter((action) => Boolean(action));
|
|
16
|
+
}
|
|
17
|
+
function hasAnyReasonSource(reasons, sources) {
|
|
18
|
+
const sourceSet = new Set(sources);
|
|
19
|
+
return reasons.some((reason) => sourceSet.has(reason.source));
|
|
20
|
+
}
|
|
21
|
+
function shouldSuggestExplicitBase(mode, changedFiles) {
|
|
22
|
+
return mode !== 'before_edit' && !changedFiles.available;
|
|
23
|
+
}
|
|
24
|
+
function reviewActionForReasons(reasons) {
|
|
25
|
+
return hasAnyReasonSource(reasons, ['review', 'taint']) ? reviewAction() : undefined;
|
|
26
|
+
}
|
|
27
|
+
function healthPolicyActionForReasons(reasons) {
|
|
28
|
+
return hasAnyReasonSource(reasons, ['doctor', 'plugin', 'supply-chain'])
|
|
29
|
+
? healthPolicyAction()
|
|
30
|
+
: undefined;
|
|
31
|
+
}
|
|
32
|
+
function sessionActionForReasons(reasons) {
|
|
33
|
+
return hasAnyReasonSource(reasons, ['hotspots', 'session']) ? sessionAction() : undefined;
|
|
34
|
+
}
|
|
35
|
+
function explicitBaseActionForState(mode, changedFiles) {
|
|
36
|
+
return shouldSuggestExplicitBase(mode, changedFiles) ? explicitBaseAction() : undefined;
|
|
37
|
+
}
|
|
38
|
+
function reviewAction() {
|
|
39
|
+
return {
|
|
40
|
+
label: 'Inspect the full review before continuing',
|
|
41
|
+
command: 'projscan review --format json',
|
|
42
|
+
tool: 'projscan_review',
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
function healthPolicyAction() {
|
|
46
|
+
return {
|
|
47
|
+
label: 'Inspect health, plugin policy, and supply-chain findings',
|
|
48
|
+
command: 'projscan doctor --format json',
|
|
49
|
+
tool: 'projscan_doctor',
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
function sessionAction() {
|
|
53
|
+
return {
|
|
54
|
+
label: 'Inspect remembered session hotspots',
|
|
55
|
+
command: 'projscan session touched --format json',
|
|
56
|
+
tool: 'projscan_session',
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
function explicitBaseAction() {
|
|
60
|
+
return {
|
|
61
|
+
label: 'Run preflight with an explicit base ref',
|
|
62
|
+
command: 'projscan preflight --base-ref main --format json',
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
function toToolCallAction(action) {
|
|
66
|
+
return {
|
|
67
|
+
label: action.label,
|
|
68
|
+
...(action.tool ? { tool: action.tool } : {}),
|
|
69
|
+
...(action.args ? { args: action.args } : {}),
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
function dedupeActions(actions) {
|
|
73
|
+
const seen = new Set();
|
|
74
|
+
const out = [];
|
|
75
|
+
for (const action of actions) {
|
|
76
|
+
const key = `${action.label}:${action.command ?? action.tool ?? ''}`;
|
|
77
|
+
if (seen.has(key))
|
|
78
|
+
continue;
|
|
79
|
+
seen.add(key);
|
|
80
|
+
out.push(action);
|
|
81
|
+
}
|
|
82
|
+
return out;
|
|
83
|
+
}
|
|
84
|
+
//# sourceMappingURL=preflightSuggestedActions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"preflightSuggestedActions.js","sourceRoot":"","sources":["../../src/core/preflightSuggestedActions.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { PreflightChangedFiles } from './preflightChangedFiles.js';
|
|
2
|
+
import type { PreflightEvidence } from '../types.js';
|
|
3
|
+
export declare function isPreflightReportTruncated(input: {
|
|
4
|
+
evidence: PreflightEvidence;
|
|
5
|
+
changedFiles: PreflightChangedFiles;
|
|
6
|
+
}): boolean;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { MAX_PREFLIGHT_EVIDENCE_FILES } from './preflightEvidence.js';
|
|
2
|
+
export function isPreflightReportTruncated(input) {
|
|
3
|
+
return (input.evidence.session?.truncated === true ||
|
|
4
|
+
input.changedFiles.files.length > MAX_PREFLIGHT_EVIDENCE_FILES ||
|
|
5
|
+
(input.evidence.hotspots?.touched.length ?? 0) > MAX_PREFLIGHT_EVIDENCE_FILES);
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=preflightTruncation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"preflightTruncation.js","sourceRoot":"","sources":["../../src/core/preflightTruncation.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,4BAA4B,EAAE,MAAM,wBAAwB,CAAC;AAGtE,MAAM,UAAU,0BAA0B,CAAC,KAG1C;IACC,OAAO,CACL,KAAK,CAAC,QAAQ,CAAC,OAAO,EAAE,SAAS,KAAK,IAAI;QAC1C,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,MAAM,GAAG,4BAA4B;QAC9D,CAAC,KAAK,CAAC,QAAQ,CAAC,QAAQ,EAAE,OAAO,CAAC,MAAM,IAAI,CAAC,CAAC,GAAG,4BAA4B,CAC9E,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export function decidePreflightVerdict(reasons) {
|
|
2
|
+
if (reasons.some((reason) => reason.severity === 'error'))
|
|
3
|
+
return 'block';
|
|
4
|
+
if (reasons.some((reason) => reason.severity === 'warning'))
|
|
5
|
+
return 'caution';
|
|
6
|
+
return 'proceed';
|
|
7
|
+
}
|
|
8
|
+
export function summarizePreflight(report) {
|
|
9
|
+
if (report.reasons.length === 0) {
|
|
10
|
+
return `${report.verdict}: no blocking or cautionary signals found`;
|
|
11
|
+
}
|
|
12
|
+
if (report.evidence.releaseScale?.detected) {
|
|
13
|
+
return `${report.verdict}: manual release sign-off recommended for large platform release risk`;
|
|
14
|
+
}
|
|
15
|
+
return `${report.verdict}: ${report.reasons[0].message}`;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=preflightVerdict.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"preflightVerdict.js","sourceRoot":"","sources":["../../src/core/preflightVerdict.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,sBAAsB,CAAC,OAA0B;IAC/D,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,QAAQ,KAAK,OAAO,CAAC;QAAE,OAAO,OAAO,CAAC;IAC1E,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,QAAQ,KAAK,SAAS,CAAC;QAAE,OAAO,SAAS,CAAC;IAC9E,OAAO,SAAS,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,MAAuB;IACxD,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAChC,OAAO,GAAG,MAAM,CAAC,OAAO,2CAA2C,CAAC;IACtE,CAAC;IACD,IAAI,MAAM,CAAC,QAAQ,CAAC,YAAY,EAAE,QAAQ,EAAE,CAAC;QAC3C,OAAO,GAAG,MAAM,CAAC,OAAO,uEAAuE,CAAC;IAClG,CAAC;IACD,OAAO,GAAG,MAAM,CAAC,OAAO,KAAK,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;AAC3D,CAAC"}
|
|
@@ -1,5 +1,7 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import { renderEvidencePackPrComment, validateEvidencePackPrComment } from './evidenceComment.js';
|
|
2
|
+
export { renderEvidencePackPrComment, validateEvidencePackPrComment };
|
|
3
|
+
export { calibratePreflightTrust } from './releaseEvidencePrSummary.js';
|
|
4
|
+
import type { EvidencePackReport } from '../types.js';
|
|
3
5
|
export interface ComputeEvidencePackOptions {
|
|
4
6
|
lines?: string[];
|
|
5
7
|
includeWebsitePrompt?: boolean;
|
|
@@ -8,4 +10,3 @@ export interface ComputeEvidencePackOptions {
|
|
|
8
10
|
preflightMaxChangedFiles?: number;
|
|
9
11
|
}
|
|
10
12
|
export declare function computeEvidencePack(rootPath: string, options?: ComputeEvidencePackOptions): Promise<EvidencePackReport>;
|
|
11
|
-
export declare function calibratePreflightTrust(preflight: PreflightReport): EvidencePackPrSummary['trust'];
|