projscan 4.5.0 → 4.7.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 +30 -16
- 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 +34 -213
- 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/changedOnly.d.ts +16 -0
- package/dist/cli/changedOnly.js +28 -0
- package/dist/cli/changedOnly.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 +6 -5
- package/dist/cli/commands/analyze.js.map +1 -1
- package/dist/cli/commands/ci.js +5 -4
- 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 +6 -5
- package/dist/cli/commands/doctor.js.map +1 -1
- package/dist/cli/formatOptions.d.ts +4 -0
- package/dist/cli/formatOptions.js +30 -0
- package/dist/cli/formatOptions.js.map +1 -0
- 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/agentBrief.js +6 -1
- package/dist/core/agentBrief.js.map +1 -1
- package/dist/core/ast.d.ts +4 -81
- package/dist/core/ast.js +11 -637
- package/dist/core/ast.js.map +1 -1
- package/dist/core/astBodySignals.d.ts +17 -0
- package/dist/core/astBodySignals.js +106 -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 +14 -0
- package/dist/core/astMembers.js +145 -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/bugHunt.js +2 -142
- package/dist/core/bugHunt.js.map +1 -1
- package/dist/core/bugHuntHotspotFindings.d.ts +2 -0
- package/dist/core/bugHuntHotspotFindings.js +68 -0
- package/dist/core/bugHuntHotspotFindings.js.map +1 -0
- package/dist/core/bugHuntPreflightFindings.d.ts +3 -0
- package/dist/core/bugHuntPreflightFindings.js +115 -0
- package/dist/core/bugHuntPreflightFindings.js.map +1 -0
- package/dist/core/codeGraph.d.ts +3 -35
- package/dist/core/codeGraph.js +7 -261
- 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/codeGraphFileSelection.d.ts +7 -0
- package/dist/core/codeGraphFileSelection.js +19 -0
- package/dist/core/codeGraphFileSelection.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/codeGraphQueries.d.ts +9 -0
- package/dist/core/codeGraphQueries.js +25 -0
- package/dist/core/codeGraphQueries.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 +3 -338
- package/dist/core/dataflow.js.map +1 -1
- package/dist/core/dataflowDatabaseSinks.d.ts +8 -0
- package/dist/core/dataflowDatabaseSinks.js +78 -0
- package/dist/core/dataflowDatabaseSinks.js.map +1 -0
- package/dist/core/dataflowRiskAssembly.d.ts +11 -0
- package/dist/core/dataflowRiskAssembly.js +117 -0
- package/dist/core/dataflowRiskAssembly.js.map +1 -0
- package/dist/core/dataflowTraversal.d.ts +25 -0
- package/dist/core/dataflowTraversal.js +200 -0
- package/dist/core/dataflowTraversal.js.map +1 -0
- 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/fileInspectionReport.d.ts +13 -0
- package/dist/core/fileInspectionReport.js +49 -0
- package/dist/core/fileInspectionReport.js.map +1 -0
- package/dist/core/fileInspector.d.ts +5 -13
- package/dist/core/fileInspector.js +8 -239
- 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/fixSuggest.d.ts +1 -9
- package/dist/core/fixSuggest.js +2 -58
- package/dist/core/fixSuggest.js.map +1 -1
- package/dist/core/fixSuggestDependencyNames.d.ts +1 -0
- package/dist/core/fixSuggestDependencyNames.js +9 -0
- package/dist/core/fixSuggestDependencyNames.js.map +1 -0
- package/dist/core/fixSuggestPreview.d.ts +10 -0
- package/dist/core/fixSuggestPreview.js +87 -0
- package/dist/core/fixSuggestPreview.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 +80 -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 +7 -0
- package/dist/core/frameworkNextRouteSources.js +85 -0
- package/dist/core/frameworkNextRouteSources.js.map +1 -0
- package/dist/core/frameworkRemixSources.d.ts +2 -0
- package/dist/core/frameworkRemixSources.js +63 -0
- package/dist/core/frameworkRemixSources.js.map +1 -0
- package/dist/core/frameworkSources.d.ts +15 -3
- package/dist/core/frameworkSources.js +42 -210
- 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 +3 -1
- package/dist/core/indexCache.js.map +1 -1
- package/dist/core/intentRouter.d.ts +5 -28
- package/dist/core/intentRouter.js +8 -7376
- package/dist/core/intentRouter.js.map +1 -1
- package/dist/core/intentRouterCatalog.d.ts +16 -0
- package/dist/core/intentRouterCatalog.js +1709 -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 +1197 -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 +139 -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/intentRouterResult.d.ts +16 -0
- package/dist/core/intentRouterResult.js +34 -0
- package/dist/core/intentRouterResult.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 +175 -0
- package/dist/core/intentRouterWorkSignals.js.map +1 -0
- package/dist/core/languages/pythonLockfiles.d.ts +15 -0
- package/dist/core/languages/pythonLockfiles.js +210 -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 -38
- package/dist/core/languages/pythonManifests.js +27 -316
- 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 +212 -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/pluginManifestValidation.d.ts +41 -0
- package/dist/core/pluginManifestValidation.js +179 -0
- package/dist/core/pluginManifestValidation.js.map +1 -0
- package/dist/core/plugins.d.ts +3 -41
- package/dist/core/plugins.js +2 -129
- package/dist/core/plugins.js.map +1 -1
- 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/regressionPlan.d.ts +2 -1
- package/dist/core/regressionPlan.js +7 -1
- package/dist/core/regressionPlan.js.map +1 -1
- package/dist/core/releaseEvidence.d.ts +4 -3
- package/dist/core/releaseEvidence.js +17 -382
- package/dist/core/releaseEvidence.js.map +1 -1
- package/dist/core/releaseEvidenceArtifacts.d.ts +3 -0
- package/dist/core/releaseEvidenceArtifacts.js +65 -0
- package/dist/core/releaseEvidenceArtifacts.js.map +1 -0
- 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/releaseEvidenceVerdict.d.ts +6 -0
- package/dist/core/releaseEvidenceVerdict.js +54 -0
- package/dist/core/releaseEvidenceVerdict.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/reportPathRedaction.d.ts +4 -0
- package/dist/core/reportPathRedaction.js +64 -0
- package/dist/core/reportPathRedaction.js.map +1 -0
- package/dist/core/reportScope.d.ts +7 -0
- package/dist/core/reportScope.js +16 -86
- package/dist/core/reportScope.js.map +1 -1
- package/dist/core/reportScopeFiltering.d.ts +9 -0
- package/dist/core/reportScopeFiltering.js +102 -0
- package/dist/core/reportScopeFiltering.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/searchIndex.d.ts +2 -14
- package/dist/core/searchIndex.js +4 -227
- package/dist/core/searchIndex.js.map +1 -1
- package/dist/core/searchIndexFiles.d.ts +1 -0
- package/dist/core/searchIndexFiles.js +26 -0
- package/dist/core/searchIndexFiles.js.map +1 -0
- package/dist/core/searchIndexText.d.ts +15 -0
- package/dist/core/searchIndexText.js +204 -0
- package/dist/core/searchIndexText.js.map +1 -0
- package/dist/core/start.d.ts +1 -1
- package/dist/core/start.js +14 -87
- 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/startEvidence.d.ts +1 -1
- package/dist/core/startEvidence.js +16 -1
- package/dist/core/startEvidence.js.map +1 -1
- package/dist/core/startInputs.d.ts +32 -0
- package/dist/core/startInputs.js +30 -0
- package/dist/core/startInputs.js.map +1 -0
- package/dist/core/startMissionPolicy.js +10 -0
- package/dist/core/startMissionPolicy.js.map +1 -1
- package/dist/core/startMode.js +7 -1
- package/dist/core/startMode.js.map +1 -1
- package/dist/core/startReportBuilder.d.ts +26 -0
- package/dist/core/startReportBuilder.js +45 -0
- package/dist/core/startReportBuilder.js.map +1 -0
- package/dist/core/startReportContext.d.ts +23 -0
- package/dist/core/startReportContext.js +51 -0
- package/dist/core/startReportContext.js.map +1 -0
- package/dist/core/startRoadmapPreview.d.ts +2 -0
- package/dist/core/startRoadmapPreview.js +31 -0
- package/dist/core/startRoadmapPreview.js.map +1 -0
- package/dist/core/taint.d.ts +2 -67
- package/dist/core/taint.js +41 -276
- package/dist/core/taint.js.map +1 -1
- package/dist/core/taintIndex.d.ts +20 -0
- package/dist/core/taintIndex.js +81 -0
- package/dist/core/taintIndex.js.map +1 -0
- 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/taintTraversal.d.ts +8 -0
- package/dist/core/taintTraversal.js +113 -0
- package/dist/core/taintTraversal.js.map +1 -0
- package/dist/core/taintTypes.d.ts +67 -0
- package/dist/core/taintTypes.js +2 -0
- package/dist/core/taintTypes.js.map +1 -0
- package/dist/core/telemetry.js +36 -30
- package/dist/core/telemetry.js.map +1 -1
- package/dist/core/upgradePreview.d.ts +1 -12
- package/dist/core/upgradePreview.js +9 -229
- 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.d.ts +2 -3
- package/dist/mcp/tools.js +15 -108
- package/dist/mcp/tools.js.map +1 -1
- package/dist/projscan-sbom.cdx.json +6 -6
- package/dist/reporters/consoleFixReporter.d.ts +3 -0
- package/dist/reporters/consoleFixReporter.js +41 -0
- package/dist/reporters/consoleFixReporter.js.map +1 -0
- package/dist/reporters/consoleReporter.d.ts +1 -3
- package/dist/reporters/consoleReporter.js +1 -42
- package/dist/reporters/consoleReporter.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/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 +3 -3
- package/dist/types/start.d.ts +14 -0
- package/dist/types.d.ts +34 -34
- package/dist/utils/config.d.ts +2 -8
- package/dist/utils/config.js +13 -211
- 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 +22 -11
- package/docs/ROADMAP.md +18 -7
- package/docs/examples/adoption-workflows.md +2 -2
- package/docs/examples/swarm-coordination.md +11 -0
- package/package.json +1 -1
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { Issue, PreflightMode, PreflightReason } from '../types.js';
|
|
2
|
+
interface ChangedFilesEvidence {
|
|
3
|
+
available: boolean;
|
|
4
|
+
count: number;
|
|
5
|
+
files: string[];
|
|
6
|
+
reason?: string;
|
|
7
|
+
}
|
|
8
|
+
export declare function changedFileReasons(input: {
|
|
9
|
+
mode: PreflightMode;
|
|
10
|
+
issues: Issue[];
|
|
11
|
+
changedFiles: ChangedFilesEvidence;
|
|
12
|
+
maxChangedFiles: number;
|
|
13
|
+
}): PreflightReason[];
|
|
14
|
+
export {};
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
export function changedFileReasons(input) {
|
|
2
|
+
const reasons = [];
|
|
3
|
+
const issueReason = changedIssueReason(input.mode, input.issues, input.changedFiles);
|
|
4
|
+
const availabilityReason = changedFilesAvailabilityReason(input.mode, input.changedFiles);
|
|
5
|
+
const thresholdReason = changedFilesThresholdReason(input.mode, input.changedFiles, input.maxChangedFiles);
|
|
6
|
+
if (issueReason)
|
|
7
|
+
reasons.push(issueReason);
|
|
8
|
+
if (availabilityReason)
|
|
9
|
+
reasons.push(availabilityReason);
|
|
10
|
+
if (thresholdReason)
|
|
11
|
+
reasons.push(thresholdReason);
|
|
12
|
+
return reasons;
|
|
13
|
+
}
|
|
14
|
+
function changedIssueReason(mode, issues, changedFiles) {
|
|
15
|
+
if (!hasChangedFileScope(mode, changedFiles))
|
|
16
|
+
return undefined;
|
|
17
|
+
const issue = prioritizedChangedIssue(issues, new Set(changedFiles.files));
|
|
18
|
+
if (!issue)
|
|
19
|
+
return undefined;
|
|
20
|
+
const severity = issue.severity === 'error' ? 'error' : 'warning';
|
|
21
|
+
return {
|
|
22
|
+
severity,
|
|
23
|
+
source: 'doctor',
|
|
24
|
+
issueId: issue.id,
|
|
25
|
+
file: firstIssueFile(issue),
|
|
26
|
+
message: `Health ${severity} on changed file: ${issue.title}`,
|
|
27
|
+
tool: 'projscan_doctor',
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
function changedFilesAvailabilityReason(mode, changedFiles) {
|
|
31
|
+
if (!shouldReportChangedFilesUnavailable(mode, changedFiles))
|
|
32
|
+
return undefined;
|
|
33
|
+
return changedFilesUnavailableReason(changedFiles.reason);
|
|
34
|
+
}
|
|
35
|
+
function shouldReportChangedFilesUnavailable(mode, changedFiles) {
|
|
36
|
+
if (mode === 'before_edit')
|
|
37
|
+
return false;
|
|
38
|
+
return !changedFiles.available;
|
|
39
|
+
}
|
|
40
|
+
function changedFilesUnavailableReason(reason) {
|
|
41
|
+
return {
|
|
42
|
+
severity: 'warning',
|
|
43
|
+
source: 'changed-files',
|
|
44
|
+
message: `Changed files unavailable: ${reason ?? 'unknown reason'}`,
|
|
45
|
+
tool: 'projscan_review',
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
function changedFilesThresholdReason(mode, changedFiles, maxChangedFiles) {
|
|
49
|
+
if (!exceedsChangedFileThreshold(mode, changedFiles, maxChangedFiles))
|
|
50
|
+
return undefined;
|
|
51
|
+
return {
|
|
52
|
+
severity: 'warning',
|
|
53
|
+
source: 'changed-files',
|
|
54
|
+
message: `${changedFiles.count} changed files exceeds the preflight threshold of ${maxChangedFiles}`,
|
|
55
|
+
tool: 'projscan_review',
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
function hasChangedFileScope(mode, changedFiles) {
|
|
59
|
+
return mode !== 'before_edit' && changedFiles.available;
|
|
60
|
+
}
|
|
61
|
+
function exceedsChangedFileThreshold(mode, changedFiles, maxChangedFiles) {
|
|
62
|
+
return hasChangedFileScope(mode, changedFiles) && changedFiles.count > maxChangedFiles;
|
|
63
|
+
}
|
|
64
|
+
function prioritizedChangedIssue(issues, changedFiles) {
|
|
65
|
+
const changedIssues = issues.filter((issue) => issueTouchesChangedFile(issue, changedFiles));
|
|
66
|
+
return (changedIssues.find((issue) => issue.severity === 'error') ??
|
|
67
|
+
changedIssues.find((issue) => issue.severity === 'warning'));
|
|
68
|
+
}
|
|
69
|
+
function issueTouchesChangedFile(issue, changedFiles) {
|
|
70
|
+
return (issue.locations ?? []).some((location) => location.file && changedFiles.has(location.file));
|
|
71
|
+
}
|
|
72
|
+
function firstIssueFile(issue) {
|
|
73
|
+
return issue.locations?.find((location) => location.file)?.file;
|
|
74
|
+
}
|
|
75
|
+
//# sourceMappingURL=preflightChangedFileReasons.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"preflightChangedFileReasons.js","sourceRoot":"","sources":["../../src/core/preflightChangedFileReasons.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { PreflightMode } from '../types.js';
|
|
2
|
+
export interface PreflightChangedFiles {
|
|
3
|
+
available: boolean;
|
|
4
|
+
count: number;
|
|
5
|
+
files: string[];
|
|
6
|
+
baseRef: string | null;
|
|
7
|
+
reason?: string;
|
|
8
|
+
}
|
|
9
|
+
export declare function safeChangedFiles(rootPath: string, mode: PreflightMode, baseRef?: string): Promise<PreflightChangedFiles>;
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { getChangedFiles } from '../utils/changedFiles.js';
|
|
2
|
+
export async function safeChangedFiles(rootPath, mode, baseRef) {
|
|
3
|
+
if (mode === 'before_edit') {
|
|
4
|
+
return {
|
|
5
|
+
available: false,
|
|
6
|
+
count: 0,
|
|
7
|
+
files: [],
|
|
8
|
+
baseRef: null,
|
|
9
|
+
reason: 'changed-file detection is not required before edits',
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
try {
|
|
13
|
+
return changedFilesFromResult(await getChangedFiles(rootPath, baseRef));
|
|
14
|
+
}
|
|
15
|
+
catch (err) {
|
|
16
|
+
return {
|
|
17
|
+
available: false,
|
|
18
|
+
count: 0,
|
|
19
|
+
files: [],
|
|
20
|
+
baseRef: null,
|
|
21
|
+
reason: err instanceof Error ? err.message : String(err),
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
function changedFilesFromResult(result) {
|
|
26
|
+
return {
|
|
27
|
+
available: result.available,
|
|
28
|
+
count: result.files.length,
|
|
29
|
+
files: result.files,
|
|
30
|
+
baseRef: result.baseRef,
|
|
31
|
+
...(result.reason ? { reason: result.reason } : {}),
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=preflightChangedFiles.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"preflightChangedFiles.js","sourceRoot":"","sources":["../../src/core/preflightChangedFiles.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAA2B,MAAM,0BAA0B,CAAC;AAWpF,MAAM,CAAC,KAAK,UAAU,gBAAgB,CACpC,QAAgB,EAChB,IAAmB,EACnB,OAAgB;IAEhB,IAAI,IAAI,KAAK,aAAa,EAAE,CAAC;QAC3B,OAAO;YACL,SAAS,EAAE,KAAK;YAChB,KAAK,EAAE,CAAC;YACR,KAAK,EAAE,EAAE;YACT,OAAO,EAAE,IAAI;YACb,MAAM,EAAE,qDAAqD;SAC9D,CAAC;IACJ,CAAC;IACD,IAAI,CAAC;QACH,OAAO,sBAAsB,CAAC,MAAM,eAAe,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC;IAC1E,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO;YACL,SAAS,EAAE,KAAK;YAChB,KAAK,EAAE,CAAC;YACR,KAAK,EAAE,EAAE;YACT,OAAO,EAAE,IAAI;YACb,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,sBAAsB,CAAC,MAA0B;IACxD,OAAO;QACL,SAAS,EAAE,MAAM,CAAC,SAAS;QAC3B,KAAK,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM;QAC1B,KAAK,EAAE,MAAM,CAAC,KAAK;QACnB,OAAO,EAAE,MAAM,CAAC,OAAO;QACvB,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;KACpD,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { CoordinationSummary } from './coordination.js';
|
|
2
|
+
import type { HealthScore, HotspotReport, PreflightMode, PreflightReason } from '../types.js';
|
|
3
|
+
interface ChangedFilesEvidence {
|
|
4
|
+
available: boolean;
|
|
5
|
+
}
|
|
6
|
+
interface SessionEvidence {
|
|
7
|
+
touchedFiles: string[];
|
|
8
|
+
}
|
|
9
|
+
export declare function contextReasons(input: {
|
|
10
|
+
mode: PreflightMode;
|
|
11
|
+
changedFiles: ChangedFilesEvidence;
|
|
12
|
+
health: HealthScore;
|
|
13
|
+
session: SessionEvidence;
|
|
14
|
+
hotspots: HotspotReport | null;
|
|
15
|
+
coordination: CoordinationSummary | null;
|
|
16
|
+
}): PreflightReason[];
|
|
17
|
+
export {};
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
export function contextReasons(input) {
|
|
2
|
+
return [
|
|
3
|
+
...sessionHotspotReasons(input.session, input.hotspots),
|
|
4
|
+
...optionalReason(changedFileScopeHealthReason(input.mode, input.changedFiles, input.health)),
|
|
5
|
+
...optionalReason(coordinationReason(input.coordination)),
|
|
6
|
+
];
|
|
7
|
+
}
|
|
8
|
+
function optionalReason(reason) {
|
|
9
|
+
return reason ? [reason] : [];
|
|
10
|
+
}
|
|
11
|
+
function sessionHotspotReasons(session, hotspots) {
|
|
12
|
+
const touched = new Set(session.touchedFiles);
|
|
13
|
+
return touchedHighRiskHotspots(touched, hotspots).slice(0, 3).map(sessionHotspotReason);
|
|
14
|
+
}
|
|
15
|
+
function touchedHighRiskHotspots(touched, hotspots) {
|
|
16
|
+
if (hotspots?.available !== true)
|
|
17
|
+
return [];
|
|
18
|
+
return hotspots.hotspots.filter((hotspot) => touched.has(hotspot.relativePath) && hotspot.riskScore >= 40);
|
|
19
|
+
}
|
|
20
|
+
function sessionHotspotReason(hotspot) {
|
|
21
|
+
return {
|
|
22
|
+
severity: 'warning',
|
|
23
|
+
source: 'session',
|
|
24
|
+
file: hotspot.relativePath,
|
|
25
|
+
message: `Remembered session context touched high-risk hotspot ${hotspot.relativePath} (risk ${hotspot.riskScore})`,
|
|
26
|
+
tool: 'projscan_session',
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
function changedFileScopeHealthReason(mode, changedFiles, health) {
|
|
30
|
+
if (!shouldReportChangedFileScopeHealth(mode, changedFiles, health))
|
|
31
|
+
return undefined;
|
|
32
|
+
return {
|
|
33
|
+
severity: 'warning',
|
|
34
|
+
source: 'doctor',
|
|
35
|
+
message: `${health.errors} project health error(s) exist; changed-file scoping was unavailable`,
|
|
36
|
+
tool: 'projscan_doctor',
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
function shouldReportChangedFileScopeHealth(mode, changedFiles, health) {
|
|
40
|
+
return health.errors > 0 && mode === 'before_merge' && !hasChangedFileScope(mode, changedFiles);
|
|
41
|
+
}
|
|
42
|
+
function hasChangedFileScope(mode, changedFiles) {
|
|
43
|
+
return mode !== 'before_edit' && changedFiles.available;
|
|
44
|
+
}
|
|
45
|
+
function coordinationReason(coordination) {
|
|
46
|
+
if (!coordination?.available)
|
|
47
|
+
return undefined;
|
|
48
|
+
if (coordination.readiness === 'conflicted')
|
|
49
|
+
return conflictedCoordinationReason(coordination);
|
|
50
|
+
if (coordination.readiness === 'caution')
|
|
51
|
+
return cautionCoordinationReason(coordination);
|
|
52
|
+
return undefined;
|
|
53
|
+
}
|
|
54
|
+
function conflictedCoordinationReason(coordination) {
|
|
55
|
+
const contended = coordination.claims.contendedTargets > 0
|
|
56
|
+
? `, ${coordination.claims.contendedTargets} contended claim(s)`
|
|
57
|
+
: '';
|
|
58
|
+
return {
|
|
59
|
+
severity: 'warning',
|
|
60
|
+
source: 'coordination',
|
|
61
|
+
message: `Swarm collision risk across ${coordination.worktreeCount} in-flight worktrees: ${coordination.collisions.high} high / ${coordination.collisions.medium} medium${contended}. Run \`projscan coordinate\` before merging.`,
|
|
62
|
+
tool: 'projscan_coordinate',
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
function cautionCoordinationReason(coordination) {
|
|
66
|
+
return {
|
|
67
|
+
severity: 'info',
|
|
68
|
+
source: 'coordination',
|
|
69
|
+
message: `Dependency overlap with another in-flight worktree (${coordination.collisions.medium} medium). Run \`projscan coordinate\`.`,
|
|
70
|
+
tool: 'projscan_coordinate',
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
//# sourceMappingURL=preflightContextReasons.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"preflightContextReasons.js","sourceRoot":"","sources":["../../src/core/preflightContextReasons.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import type { CoordinationSummary } from './coordination.js';
|
|
2
|
+
import type { HealthScore, HotspotReport, Issue, PreflightEvidence, PreflightReleaseScaleEvidence } from '../types.js';
|
|
3
|
+
import type { ReviewReport } from '../types/review.js';
|
|
4
|
+
export declare const MAX_PREFLIGHT_EVIDENCE_FILES = 40;
|
|
5
|
+
interface ChangedFilesEvidence {
|
|
6
|
+
available: boolean;
|
|
7
|
+
count: number;
|
|
8
|
+
files: string[];
|
|
9
|
+
baseRef: string | null;
|
|
10
|
+
reason?: string;
|
|
11
|
+
}
|
|
12
|
+
interface SessionEvidence {
|
|
13
|
+
id: string;
|
|
14
|
+
touchedFiles: string[];
|
|
15
|
+
eventCount: number;
|
|
16
|
+
}
|
|
17
|
+
interface ReviewEvidence {
|
|
18
|
+
available: boolean;
|
|
19
|
+
verdict?: ReviewReport['verdict'];
|
|
20
|
+
summary?: string;
|
|
21
|
+
reason?: string;
|
|
22
|
+
}
|
|
23
|
+
export declare function buildEvidence(input: {
|
|
24
|
+
health: HealthScore;
|
|
25
|
+
changedFiles: ChangedFilesEvidence;
|
|
26
|
+
session: SessionEvidence;
|
|
27
|
+
hotspots: HotspotReport | null;
|
|
28
|
+
issues: Issue[];
|
|
29
|
+
pluginsEnabledForRun: boolean;
|
|
30
|
+
review: ReviewEvidence;
|
|
31
|
+
releaseScale: PreflightReleaseScaleEvidence | null;
|
|
32
|
+
coordination: CoordinationSummary | null;
|
|
33
|
+
}): PreflightEvidence;
|
|
34
|
+
export {};
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
export const MAX_PREFLIGHT_EVIDENCE_FILES = 40;
|
|
2
|
+
export function buildEvidence(input) {
|
|
3
|
+
const changedEvidenceFiles = input.changedFiles.files.slice(0, MAX_PREFLIGHT_EVIDENCE_FILES);
|
|
4
|
+
const sessionTouchedFiles = input.session.touchedFiles.slice(0, MAX_PREFLIGHT_EVIDENCE_FILES);
|
|
5
|
+
return {
|
|
6
|
+
health: healthEvidence(input.health),
|
|
7
|
+
changedFiles: changedFilesEvidence(input.changedFiles, changedEvidenceFiles),
|
|
8
|
+
review: reviewEvidence(input.review),
|
|
9
|
+
session: sessionEvidence(input.session, sessionTouchedFiles),
|
|
10
|
+
riskSources: riskSourcesEvidence(input.changedFiles, input.session, {
|
|
11
|
+
changedEvidenceFiles,
|
|
12
|
+
sessionTouchedFiles,
|
|
13
|
+
}),
|
|
14
|
+
hotspots: { touched: touchedHotspotEvidence(input.hotspots, input.session) },
|
|
15
|
+
plugins: pluginEvidence(input.issues, input.pluginsEnabledForRun),
|
|
16
|
+
supplyChain: supplyChainEvidence(input.issues),
|
|
17
|
+
...(input.releaseScale ? { releaseScale: input.releaseScale } : {}),
|
|
18
|
+
...(input.coordination ? { coordination: coordinationEvidence(input.coordination) } : {}),
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
function healthEvidence(health) {
|
|
22
|
+
return {
|
|
23
|
+
score: health.score,
|
|
24
|
+
grade: health.grade,
|
|
25
|
+
errors: health.errors,
|
|
26
|
+
warnings: health.warnings,
|
|
27
|
+
infos: health.infos,
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
function changedFilesEvidence(changedFiles, files) {
|
|
31
|
+
return {
|
|
32
|
+
available: changedFiles.available,
|
|
33
|
+
count: changedFiles.count,
|
|
34
|
+
files,
|
|
35
|
+
...(changedFiles.reason ? { reason: changedFiles.reason } : {}),
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
function reviewEvidence(review) {
|
|
39
|
+
return {
|
|
40
|
+
available: review.available,
|
|
41
|
+
...(review.verdict ? { verdict: review.verdict } : {}),
|
|
42
|
+
...(review.summary ? { summary: review.summary } : {}),
|
|
43
|
+
...(review.reason ? { reason: review.reason } : {}),
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
function sessionEvidence(session, touchedFiles) {
|
|
47
|
+
return {
|
|
48
|
+
kind: 'remembered-session',
|
|
49
|
+
id: session.id,
|
|
50
|
+
touchedFiles,
|
|
51
|
+
totalTouchedFiles: session.touchedFiles.length,
|
|
52
|
+
eventCount: session.eventCount,
|
|
53
|
+
note: 'remembered session context comes from previous projscan tool results, explicit touches, and MCP file-watch events. It is not the same as current Git/worktree changes.',
|
|
54
|
+
...(session.touchedFiles.length > MAX_PREFLIGHT_EVIDENCE_FILES ? { truncated: true } : {}),
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
function riskSourcesEvidence(changedFiles, session, files) {
|
|
58
|
+
return {
|
|
59
|
+
currentWorktree: currentWorktreeEvidence(changedFiles, files.changedEvidenceFiles),
|
|
60
|
+
sessionMemory: sessionMemoryEvidence(session, files.sessionTouchedFiles),
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
function currentWorktreeEvidence(changedFiles, files) {
|
|
64
|
+
return {
|
|
65
|
+
kind: 'current-worktree',
|
|
66
|
+
available: changedFiles.available,
|
|
67
|
+
count: changedFiles.count,
|
|
68
|
+
files,
|
|
69
|
+
baseRef: changedFiles.baseRef,
|
|
70
|
+
...(changedFiles.reason ? { reason: changedFiles.reason } : {}),
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
function sessionMemoryEvidence(session, touchedFiles) {
|
|
74
|
+
return {
|
|
75
|
+
kind: 'remembered-session',
|
|
76
|
+
id: session.id,
|
|
77
|
+
touchedFiles,
|
|
78
|
+
totalTouchedFiles: session.touchedFiles.length,
|
|
79
|
+
eventCount: session.eventCount,
|
|
80
|
+
note: 'remembered session context is useful for agent handoff, but it may include older files that are not part of the current Git/worktree diff.',
|
|
81
|
+
...(session.touchedFiles.length > MAX_PREFLIGHT_EVIDENCE_FILES ? { truncated: true } : {}),
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
function touchedHotspotEvidence(hotspots, session) {
|
|
85
|
+
if (hotspots?.available !== true)
|
|
86
|
+
return [];
|
|
87
|
+
return hotspots.hotspots
|
|
88
|
+
.filter((hotspot) => session.touchedFiles.includes(hotspot.relativePath))
|
|
89
|
+
.slice(0, MAX_PREFLIGHT_EVIDENCE_FILES)
|
|
90
|
+
.map((hotspot) => ({ file: hotspot.relativePath, riskScore: hotspot.riskScore }));
|
|
91
|
+
}
|
|
92
|
+
function pluginEvidence(issues, enabled) {
|
|
93
|
+
const pluginIssues = issues.filter((issue) => issue.id.startsWith('plugin:'));
|
|
94
|
+
return {
|
|
95
|
+
enabled,
|
|
96
|
+
errorIssues: pluginIssues.filter((issue) => issue.severity === 'error').length,
|
|
97
|
+
warningIssues: pluginIssues.filter((issue) => issue.severity === 'warning').length,
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
function supplyChainEvidence(issues) {
|
|
101
|
+
const supplyChainIssues = issues.filter((issue) => issue.category === 'supply-chain');
|
|
102
|
+
return {
|
|
103
|
+
errorIssues: supplyChainIssues.filter((issue) => issue.severity === 'error').length,
|
|
104
|
+
warningIssues: supplyChainIssues.filter((issue) => issue.severity === 'warning').length,
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
function coordinationEvidence(coordination) {
|
|
108
|
+
return {
|
|
109
|
+
available: true,
|
|
110
|
+
readiness: coordination.readiness,
|
|
111
|
+
worktreeCount: coordination.worktreeCount,
|
|
112
|
+
collisions: {
|
|
113
|
+
high: coordination.collisions.high,
|
|
114
|
+
medium: coordination.collisions.medium,
|
|
115
|
+
},
|
|
116
|
+
contendedClaims: coordination.claims.contendedTargets,
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
//# sourceMappingURL=preflightEvidence.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"preflightEvidence.js","sourceRoot":"","sources":["../../src/core/preflightEvidence.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { Issue, PreflightMode } from '../types.js';
|
|
2
|
+
export interface LoadPreflightInputsOptions {
|
|
3
|
+
baseRef?: string;
|
|
4
|
+
headRef?: string;
|
|
5
|
+
enablePlugins?: boolean;
|
|
6
|
+
}
|
|
7
|
+
export declare function loadPreflightInputs(rootPath: string, mode: PreflightMode, options?: LoadPreflightInputsOptions): Promise<{
|
|
8
|
+
issues: Issue[];
|
|
9
|
+
health: import("../types.js").HealthScore;
|
|
10
|
+
changedFiles: import("./preflightChangedFiles.js").PreflightChangedFiles;
|
|
11
|
+
session: import("./preflightLocalEvidence.js").PreflightSessionEvidence;
|
|
12
|
+
hotspots: import("../types.js").HotspotReport | null;
|
|
13
|
+
review: import("./preflightReviewEvidence.js").PreflightReviewEvidence;
|
|
14
|
+
coordination: import("./coordination.js").CoordinationSummary | null;
|
|
15
|
+
}>;
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { scanRepository } from './repositoryScanner.js';
|
|
2
|
+
import { collectIssues } from './issueEngine.js';
|
|
3
|
+
import { safeReviewEvidence } from './preflightReviewEvidence.js';
|
|
4
|
+
import { safeChangedFiles } from './preflightChangedFiles.js';
|
|
5
|
+
import { safeCoordination, safeHotspots, safeSession } from './preflightLocalEvidence.js';
|
|
6
|
+
import { loadConfig, applyConfigToIssues } from '../utils/config.js';
|
|
7
|
+
import { calculateScore } from '../utils/scoreCalculator.js';
|
|
8
|
+
export async function loadPreflightInputs(rootPath, mode, options = {}) {
|
|
9
|
+
const configResult = await loadConfig(rootPath).catch(() => ({ config: { ignore: [] } }));
|
|
10
|
+
const scan = await scanRepository(rootPath, { ignore: configResult.config.ignore });
|
|
11
|
+
const issues = applyConfigToIssues(await collectIssuesWithPluginOption(rootPath, scan.files, options.enablePlugins), configResult.config);
|
|
12
|
+
const health = calculateScore(issues);
|
|
13
|
+
const changedFiles = await safeChangedFiles(rootPath, mode, options.baseRef);
|
|
14
|
+
const session = await safeSession(rootPath);
|
|
15
|
+
const hotspots = await safeHotspots(rootPath, scan.files, issues);
|
|
16
|
+
const review = await safeReviewEvidence(rootPath, mode, options);
|
|
17
|
+
const coordination = await safeCoordination(rootPath, options.baseRef);
|
|
18
|
+
return {
|
|
19
|
+
issues,
|
|
20
|
+
health,
|
|
21
|
+
changedFiles,
|
|
22
|
+
session,
|
|
23
|
+
hotspots,
|
|
24
|
+
review,
|
|
25
|
+
coordination,
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
async function collectIssuesWithPluginOption(rootPath, files, _enablePlugins) {
|
|
29
|
+
return collectIssues(rootPath, files);
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=preflightInputs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"preflightInputs.js","sourceRoot":"","sources":["../../src/core/preflightInputs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EAAE,gBAAgB,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAC1F,OAAO,EAAE,UAAU,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AACrE,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAS7D,MAAM,CAAC,KAAK,UAAU,mBAAmB,CACvC,QAAgB,EAChB,IAAmB,EACnB,UAAsC,EAAE;IAExC,MAAM,YAAY,GAAG,MAAM,UAAU,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IAC1F,MAAM,IAAI,GAAG,MAAM,cAAc,CAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,YAAY,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC;IACpF,MAAM,MAAM,GAAG,mBAAmB,CAChC,MAAM,6BAA6B,CAAC,QAAQ,EAAE,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,aAAa,CAAC,EAChF,YAAY,CAAC,MAAM,CACpB,CAAC;IACF,MAAM,MAAM,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;IACtC,MAAM,YAAY,GAAG,MAAM,gBAAgB,CAAC,QAAQ,EAAE,IAAI,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC;IAC7E,MAAM,OAAO,GAAG,MAAM,WAAW,CAAC,QAAQ,CAAC,CAAC;IAC5C,MAAM,QAAQ,GAAG,MAAM,YAAY,CAAC,QAAQ,EAAE,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;IAClE,MAAM,MAAM,GAAG,MAAM,kBAAkB,CAAC,QAAQ,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC;IACjE,MAAM,YAAY,GAAG,MAAM,gBAAgB,CAAC,QAAQ,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC;IAEvE,OAAO;QACL,MAAM;QACN,MAAM;QACN,YAAY;QACZ,OAAO;QACP,QAAQ;QACR,MAAM;QACN,YAAY;KACb,CAAC;AACJ,CAAC;AAED,KAAK,UAAU,6BAA6B,CAC1C,QAAgB,EAChB,KAAkB,EAClB,cAAwB;IAExB,OAAO,aAAa,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;AACxC,CAAC"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
export function policyIssueReasons(issues) {
|
|
2
|
+
return [...supplyChainIssueReasons(issues), ...pluginIssueReasons(issues)];
|
|
3
|
+
}
|
|
4
|
+
function supplyChainIssueReasons(issues) {
|
|
5
|
+
return issues.filter(isSupplyChainIssue).map(supplyChainIssueReason);
|
|
6
|
+
}
|
|
7
|
+
function pluginIssueReasons(issues) {
|
|
8
|
+
return issues.filter(isPluginIssue).map(pluginIssueReason);
|
|
9
|
+
}
|
|
10
|
+
function isSupplyChainIssue(issue) {
|
|
11
|
+
return issue.category === 'supply-chain';
|
|
12
|
+
}
|
|
13
|
+
function isPluginIssue(issue) {
|
|
14
|
+
return issue.id.startsWith('plugin:');
|
|
15
|
+
}
|
|
16
|
+
function supplyChainIssueReason(issue) {
|
|
17
|
+
return {
|
|
18
|
+
severity: issue.severity,
|
|
19
|
+
source: 'supply-chain',
|
|
20
|
+
issueId: issue.id,
|
|
21
|
+
file: firstIssueFile(issue),
|
|
22
|
+
message: `${issue.severity === 'error' ? 'Supply-chain gate blocks' : 'Supply-chain gate flags'} ${issue.id}: ${issue.title}`,
|
|
23
|
+
tool: 'projscan_doctor',
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
function pluginIssueReason(issue) {
|
|
27
|
+
return {
|
|
28
|
+
severity: issue.severity,
|
|
29
|
+
source: 'plugin',
|
|
30
|
+
issueId: issue.id,
|
|
31
|
+
file: firstIssueFile(issue),
|
|
32
|
+
message: `${issue.severity === 'error' ? 'Plugin policy blocks' : 'Plugin policy flags'} ${issue.id}: ${issue.title}`,
|
|
33
|
+
tool: 'projscan_plugin',
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
function firstIssueFile(issue) {
|
|
37
|
+
return issue.locations?.find((location) => location.file)?.file;
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=preflightIssueReasons.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"preflightIssueReasons.js","sourceRoot":"","sources":["../../src/core/preflightIssueReasons.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,kBAAkB,CAAC,MAAe;IAChD,OAAO,CAAC,GAAG,uBAAuB,CAAC,MAAM,CAAC,EAAE,GAAG,kBAAkB,CAAC,MAAM,CAAC,CAAC,CAAC;AAC7E,CAAC;AAED,SAAS,uBAAuB,CAAC,MAAe;IAC9C,OAAO,MAAM,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC,GAAG,CAAC,sBAAsB,CAAC,CAAC;AACvE,CAAC;AAED,SAAS,kBAAkB,CAAC,MAAe;IACzC,OAAO,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;AAC7D,CAAC;AAED,SAAS,kBAAkB,CAAC,KAAY;IACtC,OAAO,KAAK,CAAC,QAAQ,KAAK,cAAc,CAAC;AAC3C,CAAC;AAED,SAAS,aAAa,CAAC,KAAY;IACjC,OAAO,KAAK,CAAC,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;AACxC,CAAC;AAED,SAAS,sBAAsB,CAAC,KAAY;IAC1C,OAAO;QACL,QAAQ,EAAE,KAAK,CAAC,QAAQ;QACxB,MAAM,EAAE,cAAc;QACtB,OAAO,EAAE,KAAK,CAAC,EAAE;QACjB,IAAI,EAAE,cAAc,CAAC,KAAK,CAAC;QAC3B,OAAO,EAAE,GAAG,KAAK,CAAC,QAAQ,KAAK,OAAO,CAAC,CAAC,CAAC,0BAA0B,CAAC,CAAC,CAAC,yBAAyB,IAAI,KAAK,CAAC,EAAE,KAAK,KAAK,CAAC,KAAK,EAAE;QAC7H,IAAI,EAAE,iBAAiB;KACxB,CAAC;AACJ,CAAC;AAED,SAAS,iBAAiB,CAAC,KAAY;IACrC,OAAO;QACL,QAAQ,EAAE,KAAK,CAAC,QAAQ;QACxB,MAAM,EAAE,QAAQ;QAChB,OAAO,EAAE,KAAK,CAAC,EAAE;QACjB,IAAI,EAAE,cAAc,CAAC,KAAK,CAAC;QAC3B,OAAO,EAAE,GAAG,KAAK,CAAC,QAAQ,KAAK,OAAO,CAAC,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAC,qBAAqB,IAAI,KAAK,CAAC,EAAE,KAAK,KAAK,CAAC,KAAK,EAAE;QACrH,IAAI,EAAE,iBAAiB;KACxB,CAAC;AACJ,CAAC;AAED,SAAS,cAAc,CAAC,KAAY;IAClC,OAAO,KAAK,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC;AAClE,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { type CoordinationSummary } from './coordination.js';
|
|
2
|
+
import type { FileEntry, HotspotReport, Issue } from '../types.js';
|
|
3
|
+
export type { CoordinationSummary } from './coordination.js';
|
|
4
|
+
export interface PreflightSessionEvidence {
|
|
5
|
+
id: string;
|
|
6
|
+
touchedFiles: string[];
|
|
7
|
+
eventCount: number;
|
|
8
|
+
}
|
|
9
|
+
export declare function safeSession(rootPath: string): Promise<PreflightSessionEvidence>;
|
|
10
|
+
export declare function safeHotspots(rootPath: string, files: FileEntry[], issues: Issue[]): Promise<HotspotReport | null>;
|
|
11
|
+
/** Coordination evidence for preflight; null when no real cross-worktree read. */
|
|
12
|
+
export declare function safeCoordination(rootPath: string, baseRef?: string): Promise<CoordinationSummary | null>;
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { computeCoordination } from './coordination.js';
|
|
2
|
+
import { analyzeHotspots } from './hotspotAnalyzer.js';
|
|
3
|
+
import { loadSession } from './session.js';
|
|
4
|
+
export async function safeSession(rootPath) {
|
|
5
|
+
const { session } = await loadSession(rootPath);
|
|
6
|
+
const touchedFiles = Object.values(session.touchedFiles)
|
|
7
|
+
.sort((a, b) => {
|
|
8
|
+
const byTime = Date.parse(b.lastTouchedAt) - Date.parse(a.lastTouchedAt);
|
|
9
|
+
return byTime !== 0 ? byTime : a.file.localeCompare(b.file);
|
|
10
|
+
})
|
|
11
|
+
.map((touch) => touch.file);
|
|
12
|
+
return {
|
|
13
|
+
id: session.id,
|
|
14
|
+
touchedFiles,
|
|
15
|
+
eventCount: session.events.length,
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
export async function safeHotspots(rootPath, files, issues) {
|
|
19
|
+
try {
|
|
20
|
+
return await analyzeHotspots(rootPath, files, issues, { limit: 20 });
|
|
21
|
+
}
|
|
22
|
+
catch {
|
|
23
|
+
return null;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
/** Coordination evidence for preflight; null when no real cross-worktree read. */
|
|
27
|
+
export async function safeCoordination(rootPath, baseRef) {
|
|
28
|
+
try {
|
|
29
|
+
const summary = await computeCoordination(rootPath, baseRef ? { baseRef } : {});
|
|
30
|
+
return summary.available ? summary : null;
|
|
31
|
+
}
|
|
32
|
+
catch {
|
|
33
|
+
return null;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=preflightLocalEvidence.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"preflightLocalEvidence.js","sourceRoot":"","sources":["../../src/core/preflightLocalEvidence.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAA4B,MAAM,mBAAmB,CAAC;AAClF,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAW3C,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,QAAgB;IAChD,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,WAAW,CAAC,QAAQ,CAAC,CAAC;IAChD,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC;SACrD,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;QACb,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC;QACzE,OAAO,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IAC9D,CAAC,CAAC;SACD,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAC9B,OAAO;QACL,EAAE,EAAE,OAAO,CAAC,EAAE;QACd,YAAY;QACZ,UAAU,EAAE,OAAO,CAAC,MAAM,CAAC,MAAM;KAClC,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,YAAY,CAChC,QAAgB,EAChB,KAAkB,EAClB,MAAe;IAEf,IAAI,CAAC;QACH,OAAO,MAAM,eAAe,CAAC,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC;IACvE,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC;AAED,kFAAkF;AAClF,MAAM,CAAC,KAAK,UAAU,gBAAgB,CACpC,QAAgB,EAChB,OAAgB;IAEhB,IAAI,CAAC;QACH,MAAM,OAAO,GAAG,MAAM,mBAAmB,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAChF,OAAO,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC;IAC5C,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import type { HealthScore, Issue, PreflightMode, PreflightReleaseScaleEvidence } from '../types.js';
|
|
2
|
+
import type { ReviewReport } from '../types/review.js';
|
|
3
|
+
interface ChangedFilesEvidence {
|
|
4
|
+
available: boolean;
|
|
5
|
+
count: number;
|
|
6
|
+
}
|
|
7
|
+
interface ReviewEvidence {
|
|
8
|
+
available: boolean;
|
|
9
|
+
verdict?: ReviewReport['verdict'];
|
|
10
|
+
summary?: string;
|
|
11
|
+
newTaintFlows?: number;
|
|
12
|
+
newDataflowRisks?: number;
|
|
13
|
+
}
|
|
14
|
+
interface SupplyChainIssueCounts {
|
|
15
|
+
errorIssues: number;
|
|
16
|
+
warningIssues: number;
|
|
17
|
+
}
|
|
18
|
+
interface ReleaseScaleInput {
|
|
19
|
+
mode: PreflightMode;
|
|
20
|
+
issues: Issue[];
|
|
21
|
+
changedFiles: ChangedFilesEvidence;
|
|
22
|
+
health: HealthScore;
|
|
23
|
+
review: ReviewEvidence;
|
|
24
|
+
supplyChain: SupplyChainIssueCounts;
|
|
25
|
+
maxChangedFiles: number;
|
|
26
|
+
}
|
|
27
|
+
export declare function buildReleaseScaleEvidence(input: ReleaseScaleInput): PreflightReleaseScaleEvidence | null;
|
|
28
|
+
export {};
|