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.
Files changed (703) hide show
  1. package/README.md +30 -16
  2. package/dist/analyzers/pythonDependencyRiskCheck.js +1 -1
  3. package/dist/analyzers/pythonDependencyRiskCheck.js.map +1 -1
  4. package/dist/cli/_shared.d.ts +4 -5
  5. package/dist/cli/_shared.js +34 -213
  6. package/dist/cli/_shared.js.map +1 -1
  7. package/dist/cli/architectureLayers.d.ts +2 -0
  8. package/dist/cli/architectureLayers.js +112 -0
  9. package/dist/cli/architectureLayers.js.map +1 -0
  10. package/dist/cli/bannerDisplay.d.ts +9 -0
  11. package/dist/cli/bannerDisplay.js +18 -0
  12. package/dist/cli/bannerDisplay.js.map +1 -0
  13. package/dist/cli/changedIssueFilter.d.ts +10 -0
  14. package/dist/cli/changedIssueFilter.js +24 -0
  15. package/dist/cli/changedIssueFilter.js.map +1 -0
  16. package/dist/cli/changedOnly.d.ts +16 -0
  17. package/dist/cli/changedOnly.js +28 -0
  18. package/dist/cli/changedOnly.js.map +1 -0
  19. package/dist/cli/commandPath.d.ts +2 -0
  20. package/dist/cli/commandPath.js +12 -0
  21. package/dist/cli/commandPath.js.map +1 -0
  22. package/dist/cli/commands/agentBrief.js +11 -0
  23. package/dist/cli/commands/agentBrief.js.map +1 -1
  24. package/dist/cli/commands/analyze.js +6 -5
  25. package/dist/cli/commands/analyze.js.map +1 -1
  26. package/dist/cli/commands/ci.js +5 -4
  27. package/dist/cli/commands/ci.js.map +1 -1
  28. package/dist/cli/commands/coordinate.js +27 -0
  29. package/dist/cli/commands/coordinate.js.map +1 -1
  30. package/dist/cli/commands/doctor.js +6 -5
  31. package/dist/cli/commands/doctor.js.map +1 -1
  32. package/dist/cli/formatOptions.d.ts +4 -0
  33. package/dist/cli/formatOptions.js +30 -0
  34. package/dist/cli/formatOptions.js.map +1 -0
  35. package/dist/cli/pluginReporter.d.ts +14 -0
  36. package/dist/cli/pluginReporter.js +46 -0
  37. package/dist/cli/pluginReporter.js.map +1 -0
  38. package/dist/cli/projectConfig.d.ts +12 -0
  39. package/dist/cli/projectConfig.js +41 -0
  40. package/dist/cli/projectConfig.js.map +1 -0
  41. package/dist/cli/treeSlice.d.ts +3 -0
  42. package/dist/cli/treeSlice.js +12 -0
  43. package/dist/cli/treeSlice.js.map +1 -0
  44. package/dist/core/agentBrief.js +6 -1
  45. package/dist/core/agentBrief.js.map +1 -1
  46. package/dist/core/ast.d.ts +4 -81
  47. package/dist/core/ast.js +11 -637
  48. package/dist/core/ast.js.map +1 -1
  49. package/dist/core/astBodySignals.d.ts +17 -0
  50. package/dist/core/astBodySignals.js +106 -0
  51. package/dist/core/astBodySignals.js.map +1 -0
  52. package/dist/core/astFunctionCollector.d.ts +11 -0
  53. package/dist/core/astFunctionCollector.js +140 -0
  54. package/dist/core/astFunctionCollector.js.map +1 -0
  55. package/dist/core/astFunctionNames.d.ts +2 -0
  56. package/dist/core/astFunctionNames.js +53 -0
  57. package/dist/core/astFunctionNames.js.map +1 -0
  58. package/dist/core/astFunctionNodes.d.ts +2 -0
  59. package/dist/core/astFunctionNodes.js +12 -0
  60. package/dist/core/astFunctionNodes.js.map +1 -0
  61. package/dist/core/astMembers.d.ts +14 -0
  62. package/dist/core/astMembers.js +145 -0
  63. package/dist/core/astMembers.js.map +1 -0
  64. package/dist/core/astModuleSignals.d.ts +3 -0
  65. package/dist/core/astModuleSignals.js +140 -0
  66. package/dist/core/astModuleSignals.js.map +1 -0
  67. package/dist/core/astParser.d.ts +11 -0
  68. package/dist/core/astParser.js +38 -0
  69. package/dist/core/astParser.js.map +1 -0
  70. package/dist/core/astProgramSignals.d.ts +11 -0
  71. package/dist/core/astProgramSignals.js +97 -0
  72. package/dist/core/astProgramSignals.js.map +1 -0
  73. package/dist/core/astTypes.d.ts +78 -0
  74. package/dist/core/astTypes.js +2 -0
  75. package/dist/core/astTypes.js.map +1 -0
  76. package/dist/core/bugHunt.js +2 -142
  77. package/dist/core/bugHunt.js.map +1 -1
  78. package/dist/core/bugHuntHotspotFindings.d.ts +2 -0
  79. package/dist/core/bugHuntHotspotFindings.js +68 -0
  80. package/dist/core/bugHuntHotspotFindings.js.map +1 -0
  81. package/dist/core/bugHuntPreflightFindings.d.ts +3 -0
  82. package/dist/core/bugHuntPreflightFindings.js +115 -0
  83. package/dist/core/bugHuntPreflightFindings.js.map +1 -0
  84. package/dist/core/codeGraph.d.ts +3 -35
  85. package/dist/core/codeGraph.js +7 -261
  86. package/dist/core/codeGraph.js.map +1 -1
  87. package/dist/core/codeGraphFanMetrics.d.ts +17 -0
  88. package/dist/core/codeGraphFanMetrics.js +89 -0
  89. package/dist/core/codeGraphFanMetrics.js.map +1 -0
  90. package/dist/core/codeGraphFileSelection.d.ts +7 -0
  91. package/dist/core/codeGraphFileSelection.js +19 -0
  92. package/dist/core/codeGraphFileSelection.js.map +1 -0
  93. package/dist/core/codeGraphIndexes.d.ts +23 -0
  94. package/dist/core/codeGraphIndexes.js +57 -0
  95. package/dist/core/codeGraphIndexes.js.map +1 -0
  96. package/dist/core/codeGraphParsing.d.ts +20 -0
  97. package/dist/core/codeGraphParsing.js +104 -0
  98. package/dist/core/codeGraphParsing.js.map +1 -0
  99. package/dist/core/codeGraphQueries.d.ts +9 -0
  100. package/dist/core/codeGraphQueries.js +25 -0
  101. package/dist/core/codeGraphQueries.js.map +1 -0
  102. package/dist/core/codeGraphTypes.d.ts +28 -0
  103. package/dist/core/codeGraphTypes.js +2 -0
  104. package/dist/core/codeGraphTypes.js.map +1 -0
  105. package/dist/core/collisionDetector.d.ts +2 -0
  106. package/dist/core/collisionDetector.js +17 -12
  107. package/dist/core/collisionDetector.js.map +1 -1
  108. package/dist/core/coordination.d.ts +4 -2
  109. package/dist/core/coordination.js +40 -4
  110. package/dist/core/coordination.js.map +1 -1
  111. package/dist/core/coordinationEvidence.d.ts +32 -0
  112. package/dist/core/coordinationEvidence.js +101 -0
  113. package/dist/core/coordinationEvidence.js.map +1 -0
  114. package/dist/core/dataflow.js +3 -338
  115. package/dist/core/dataflow.js.map +1 -1
  116. package/dist/core/dataflowDatabaseSinks.d.ts +8 -0
  117. package/dist/core/dataflowDatabaseSinks.js +78 -0
  118. package/dist/core/dataflowDatabaseSinks.js.map +1 -0
  119. package/dist/core/dataflowRiskAssembly.d.ts +11 -0
  120. package/dist/core/dataflowRiskAssembly.js +117 -0
  121. package/dist/core/dataflowRiskAssembly.js.map +1 -0
  122. package/dist/core/dataflowTraversal.d.ts +25 -0
  123. package/dist/core/dataflowTraversal.js +200 -0
  124. package/dist/core/dataflowTraversal.js.map +1 -0
  125. package/dist/core/fileAccess.d.ts +16 -0
  126. package/dist/core/fileAccess.js +78 -0
  127. package/dist/core/fileAccess.js.map +1 -0
  128. package/dist/core/fileExportTypes.d.ts +2 -0
  129. package/dist/core/fileExportTypes.js +16 -0
  130. package/dist/core/fileExportTypes.js.map +1 -0
  131. package/dist/core/fileGraphMetrics.d.ts +4 -0
  132. package/dist/core/fileGraphMetrics.js +34 -0
  133. package/dist/core/fileGraphMetrics.js.map +1 -0
  134. package/dist/core/fileInspectionEvidence.d.ts +13 -0
  135. package/dist/core/fileInspectionEvidence.js +14 -0
  136. package/dist/core/fileInspectionEvidence.js.map +1 -0
  137. package/dist/core/fileInspectionGraph.d.ts +5 -0
  138. package/dist/core/fileInspectionGraph.js +29 -0
  139. package/dist/core/fileInspectionGraph.js.map +1 -0
  140. package/dist/core/fileInspectionReport.d.ts +13 -0
  141. package/dist/core/fileInspectionReport.js +49 -0
  142. package/dist/core/fileInspectionReport.js.map +1 -0
  143. package/dist/core/fileInspector.d.ts +5 -13
  144. package/dist/core/fileInspector.js +8 -239
  145. package/dist/core/fileInspector.js.map +1 -1
  146. package/dist/core/fileIssues.d.ts +1 -0
  147. package/dist/core/fileIssues.js +18 -0
  148. package/dist/core/fileIssues.js.map +1 -0
  149. package/dist/core/filePurpose.d.ts +2 -0
  150. package/dist/core/filePurpose.js +61 -0
  151. package/dist/core/filePurpose.js.map +1 -0
  152. package/dist/core/fixSuggest.d.ts +1 -9
  153. package/dist/core/fixSuggest.js +2 -58
  154. package/dist/core/fixSuggest.js.map +1 -1
  155. package/dist/core/fixSuggestDependencyNames.d.ts +1 -0
  156. package/dist/core/fixSuggestDependencyNames.js +9 -0
  157. package/dist/core/fixSuggestDependencyNames.js.map +1 -0
  158. package/dist/core/fixSuggestPreview.d.ts +10 -0
  159. package/dist/core/fixSuggestPreview.js +87 -0
  160. package/dist/core/fixSuggestPreview.js.map +1 -0
  161. package/dist/core/frameworkExpressSources.d.ts +4 -0
  162. package/dist/core/frameworkExpressSources.js +95 -0
  163. package/dist/core/frameworkExpressSources.js.map +1 -0
  164. package/dist/core/frameworkFastifySources.d.ts +4 -0
  165. package/dist/core/frameworkFastifySources.js +74 -0
  166. package/dist/core/frameworkFastifySources.js.map +1 -0
  167. package/dist/core/frameworkHonoSources.d.ts +4 -0
  168. package/dist/core/frameworkHonoSources.js +80 -0
  169. package/dist/core/frameworkHonoSources.js.map +1 -0
  170. package/dist/core/frameworkKoaSources.d.ts +4 -0
  171. package/dist/core/frameworkKoaSources.js +81 -0
  172. package/dist/core/frameworkKoaSources.js.map +1 -0
  173. package/dist/core/frameworkNextRouteSources.d.ts +7 -0
  174. package/dist/core/frameworkNextRouteSources.js +85 -0
  175. package/dist/core/frameworkNextRouteSources.js.map +1 -0
  176. package/dist/core/frameworkRemixSources.d.ts +2 -0
  177. package/dist/core/frameworkRemixSources.js +63 -0
  178. package/dist/core/frameworkRemixSources.js.map +1 -0
  179. package/dist/core/frameworkSources.d.ts +15 -3
  180. package/dist/core/frameworkSources.js +42 -210
  181. package/dist/core/frameworkSources.js.map +1 -1
  182. package/dist/core/hotspotAnalyzer.d.ts +2 -18
  183. package/dist/core/hotspotAnalyzer.js +15 -477
  184. package/dist/core/hotspotAnalyzer.js.map +1 -1
  185. package/dist/core/hotspotBuilder.d.ts +14 -0
  186. package/dist/core/hotspotBuilder.js +70 -0
  187. package/dist/core/hotspotBuilder.js.map +1 -0
  188. package/dist/core/hotspotCandidates.d.ts +9 -0
  189. package/dist/core/hotspotCandidates.js +63 -0
  190. package/dist/core/hotspotCandidates.js.map +1 -0
  191. package/dist/core/hotspotGit.d.ts +10 -0
  192. package/dist/core/hotspotGit.js +152 -0
  193. package/dist/core/hotspotGit.js.map +1 -0
  194. package/dist/core/hotspotIssues.d.ts +2 -0
  195. package/dist/core/hotspotIssues.js +83 -0
  196. package/dist/core/hotspotIssues.js.map +1 -0
  197. package/dist/core/hotspotLines.d.ts +2 -0
  198. package/dist/core/hotspotLines.js +24 -0
  199. package/dist/core/hotspotLines.js.map +1 -0
  200. package/dist/core/hotspotMemory.d.ts +2 -0
  201. package/dist/core/hotspotMemory.js +21 -0
  202. package/dist/core/hotspotMemory.js.map +1 -0
  203. package/dist/core/hotspotRanking.d.ts +13 -0
  204. package/dist/core/hotspotRanking.js +44 -0
  205. package/dist/core/hotspotRanking.js.map +1 -0
  206. package/dist/core/hotspotScoring.d.ts +23 -0
  207. package/dist/core/hotspotScoring.js +128 -0
  208. package/dist/core/hotspotScoring.js.map +1 -0
  209. package/dist/core/indexCache.js +3 -1
  210. package/dist/core/indexCache.js.map +1 -1
  211. package/dist/core/intentRouter.d.ts +5 -28
  212. package/dist/core/intentRouter.js +8 -7376
  213. package/dist/core/intentRouter.js.map +1 -1
  214. package/dist/core/intentRouterCatalog.d.ts +16 -0
  215. package/dist/core/intentRouterCatalog.js +1709 -0
  216. package/dist/core/intentRouterCatalog.js.map +1 -0
  217. package/dist/core/intentRouterCoordinationSignals.d.ts +12 -0
  218. package/dist/core/intentRouterCoordinationSignals.js +111 -0
  219. package/dist/core/intentRouterCoordinationSignals.js.map +1 -0
  220. package/dist/core/intentRouterDependencySignals.d.ts +9 -0
  221. package/dist/core/intentRouterDependencySignals.js +226 -0
  222. package/dist/core/intentRouterDependencySignals.js.map +1 -0
  223. package/dist/core/intentRouterKeywordContext.d.ts +14 -0
  224. package/dist/core/intentRouterKeywordContext.js +2 -0
  225. package/dist/core/intentRouterKeywordContext.js.map +1 -0
  226. package/dist/core/intentRouterKeywordEarlyGuards.d.ts +2 -0
  227. package/dist/core/intentRouterKeywordEarlyGuards.js +127 -0
  228. package/dist/core/intentRouterKeywordEarlyGuards.js.map +1 -0
  229. package/dist/core/intentRouterKeywordMatches.d.ts +3 -0
  230. package/dist/core/intentRouterKeywordMatches.js +31 -0
  231. package/dist/core/intentRouterKeywordMatches.js.map +1 -0
  232. package/dist/core/intentRouterKeywordSearchGuards.d.ts +2 -0
  233. package/dist/core/intentRouterKeywordSearchGuards.js +239 -0
  234. package/dist/core/intentRouterKeywordSearchGuards.js.map +1 -0
  235. package/dist/core/intentRouterKeywordTargetGuards.d.ts +2 -0
  236. package/dist/core/intentRouterKeywordTargetGuards.js +191 -0
  237. package/dist/core/intentRouterKeywordTargetGuards.js.map +1 -0
  238. package/dist/core/intentRouterKeywordToolGuards.d.ts +2 -0
  239. package/dist/core/intentRouterKeywordToolGuards.js +133 -0
  240. package/dist/core/intentRouterKeywordToolGuards.js.map +1 -0
  241. package/dist/core/intentRouterKeywordWeights.d.ts +4 -0
  242. package/dist/core/intentRouterKeywordWeights.js +1197 -0
  243. package/dist/core/intentRouterKeywordWeights.js.map +1 -0
  244. package/dist/core/intentRouterPlanningSignals.d.ts +7 -0
  245. package/dist/core/intentRouterPlanningSignals.js +268 -0
  246. package/dist/core/intentRouterPlanningSignals.js.map +1 -0
  247. package/dist/core/intentRouterPrDiffSignals.d.ts +1 -0
  248. package/dist/core/intentRouterPrDiffSignals.js +41 -0
  249. package/dist/core/intentRouterPrDiffSignals.js.map +1 -0
  250. package/dist/core/intentRouterPreflightSignals.d.ts +3 -0
  251. package/dist/core/intentRouterPreflightSignals.js +54 -0
  252. package/dist/core/intentRouterPreflightSignals.js.map +1 -0
  253. package/dist/core/intentRouterRegressionKeywordMatches.d.ts +1 -0
  254. package/dist/core/intentRouterRegressionKeywordMatches.js +176 -0
  255. package/dist/core/intentRouterRegressionKeywordMatches.js.map +1 -0
  256. package/dist/core/intentRouterRegressionSignals.d.ts +10 -0
  257. package/dist/core/intentRouterRegressionSignals.js +207 -0
  258. package/dist/core/intentRouterRegressionSignals.js.map +1 -0
  259. package/dist/core/intentRouterReleaseSignals.d.ts +8 -0
  260. package/dist/core/intentRouterReleaseSignals.js +139 -0
  261. package/dist/core/intentRouterReleaseSignals.js.map +1 -0
  262. package/dist/core/intentRouterRepoSignals.d.ts +8 -0
  263. package/dist/core/intentRouterRepoSignals.js +226 -0
  264. package/dist/core/intentRouterRepoSignals.js.map +1 -0
  265. package/dist/core/intentRouterResult.d.ts +16 -0
  266. package/dist/core/intentRouterResult.js +34 -0
  267. package/dist/core/intentRouterResult.js.map +1 -0
  268. package/dist/core/intentRouterReviewSignals.d.ts +2 -0
  269. package/dist/core/intentRouterReviewSignals.js +109 -0
  270. package/dist/core/intentRouterReviewSignals.js.map +1 -0
  271. package/dist/core/intentRouterRiskSignals.d.ts +12 -0
  272. package/dist/core/intentRouterRiskSignals.js +242 -0
  273. package/dist/core/intentRouterRiskSignals.js.map +1 -0
  274. package/dist/core/intentRouterScoring.d.ts +9 -0
  275. package/dist/core/intentRouterScoring.js +40 -0
  276. package/dist/core/intentRouterScoring.js.map +1 -0
  277. package/dist/core/intentRouterSearchApiSignals.d.ts +1 -0
  278. package/dist/core/intentRouterSearchApiSignals.js +62 -0
  279. package/dist/core/intentRouterSearchApiSignals.js.map +1 -0
  280. package/dist/core/intentRouterSearchBackgroundSignals.d.ts +1 -0
  281. package/dist/core/intentRouterSearchBackgroundSignals.js +55 -0
  282. package/dist/core/intentRouterSearchBackgroundSignals.js.map +1 -0
  283. package/dist/core/intentRouterSearchCommunicationSignals.d.ts +1 -0
  284. package/dist/core/intentRouterSearchCommunicationSignals.js +74 -0
  285. package/dist/core/intentRouterSearchCommunicationSignals.js.map +1 -0
  286. package/dist/core/intentRouterSearchDataSignals.d.ts +2 -0
  287. package/dist/core/intentRouterSearchDataSignals.js +98 -0
  288. package/dist/core/intentRouterSearchDataSignals.js.map +1 -0
  289. package/dist/core/intentRouterSearchDomainSignals.d.ts +1 -0
  290. package/dist/core/intentRouterSearchDomainSignals.js +71 -0
  291. package/dist/core/intentRouterSearchDomainSignals.js.map +1 -0
  292. package/dist/core/intentRouterSearchInfraSignals.d.ts +1 -0
  293. package/dist/core/intentRouterSearchInfraSignals.js +79 -0
  294. package/dist/core/intentRouterSearchInfraSignals.js.map +1 -0
  295. package/dist/core/intentRouterSearchIntegrationSignals.d.ts +1 -0
  296. package/dist/core/intentRouterSearchIntegrationSignals.js +117 -0
  297. package/dist/core/intentRouterSearchIntegrationSignals.js.map +1 -0
  298. package/dist/core/intentRouterSearchLookupSignals.d.ts +10 -0
  299. package/dist/core/intentRouterSearchLookupSignals.js +310 -0
  300. package/dist/core/intentRouterSearchLookupSignals.js.map +1 -0
  301. package/dist/core/intentRouterSearchNavigationSignals.d.ts +1 -0
  302. package/dist/core/intentRouterSearchNavigationSignals.js +62 -0
  303. package/dist/core/intentRouterSearchNavigationSignals.js.map +1 -0
  304. package/dist/core/intentRouterSearchOwnershipSignals.d.ts +1 -0
  305. package/dist/core/intentRouterSearchOwnershipSignals.js +15 -0
  306. package/dist/core/intentRouterSearchOwnershipSignals.js.map +1 -0
  307. package/dist/core/intentRouterSearchPageSignals.d.ts +1 -0
  308. package/dist/core/intentRouterSearchPageSignals.js +84 -0
  309. package/dist/core/intentRouterSearchPageSignals.js.map +1 -0
  310. package/dist/core/intentRouterSearchReliabilitySignals.d.ts +1 -0
  311. package/dist/core/intentRouterSearchReliabilitySignals.js +94 -0
  312. package/dist/core/intentRouterSearchReliabilitySignals.js.map +1 -0
  313. package/dist/core/intentRouterSearchStateSignals.d.ts +1 -0
  314. package/dist/core/intentRouterSearchStateSignals.js +107 -0
  315. package/dist/core/intentRouterSearchStateSignals.js.map +1 -0
  316. package/dist/core/intentRouterSearchStyleSignals.d.ts +1 -0
  317. package/dist/core/intentRouterSearchStyleSignals.js +99 -0
  318. package/dist/core/intentRouterSearchStyleSignals.js.map +1 -0
  319. package/dist/core/intentRouterSearchTestSignals.d.ts +1 -0
  320. package/dist/core/intentRouterSearchTestSignals.js +34 -0
  321. package/dist/core/intentRouterSearchTestSignals.js.map +1 -0
  322. package/dist/core/intentRouterSearchToolingSignals.d.ts +1 -0
  323. package/dist/core/intentRouterSearchToolingSignals.js +106 -0
  324. package/dist/core/intentRouterSearchToolingSignals.js.map +1 -0
  325. package/dist/core/intentRouterSearchUiSignals.d.ts +1 -0
  326. package/dist/core/intentRouterSearchUiSignals.js +77 -0
  327. package/dist/core/intentRouterSearchUiSignals.js.map +1 -0
  328. package/dist/core/intentRouterSecuritySignals.d.ts +4 -0
  329. package/dist/core/intentRouterSecuritySignals.js +235 -0
  330. package/dist/core/intentRouterSecuritySignals.js.map +1 -0
  331. package/dist/core/intentRouterTargetSignals.d.ts +5 -0
  332. package/dist/core/intentRouterTargetSignals.js +76 -0
  333. package/dist/core/intentRouterTargetSignals.js.map +1 -0
  334. package/dist/core/intentRouterTokens.d.ts +1 -0
  335. package/dist/core/intentRouterTokens.js +36 -0
  336. package/dist/core/intentRouterTokens.js.map +1 -0
  337. package/dist/core/intentRouterUnderstandSignals.d.ts +1 -0
  338. package/dist/core/intentRouterUnderstandSignals.js +171 -0
  339. package/dist/core/intentRouterUnderstandSignals.js.map +1 -0
  340. package/dist/core/intentRouterVerificationSignals.d.ts +8 -0
  341. package/dist/core/intentRouterVerificationSignals.js +119 -0
  342. package/dist/core/intentRouterVerificationSignals.js.map +1 -0
  343. package/dist/core/intentRouterWorkSignals.d.ts +4 -0
  344. package/dist/core/intentRouterWorkSignals.js +175 -0
  345. package/dist/core/intentRouterWorkSignals.js.map +1 -0
  346. package/dist/core/languages/pythonLockfiles.d.ts +15 -0
  347. package/dist/core/languages/pythonLockfiles.js +210 -0
  348. package/dist/core/languages/pythonLockfiles.js.map +1 -0
  349. package/dist/core/languages/pythonManifestText.d.ts +7 -0
  350. package/dist/core/languages/pythonManifestText.js +25 -0
  351. package/dist/core/languages/pythonManifestText.js.map +1 -0
  352. package/dist/core/languages/pythonManifests.d.ts +6 -38
  353. package/dist/core/languages/pythonManifests.js +27 -316
  354. package/dist/core/languages/pythonManifests.js.map +1 -1
  355. package/dist/core/languages/pythonPep508.d.ts +4 -0
  356. package/dist/core/languages/pythonPep508.js +14 -0
  357. package/dist/core/languages/pythonPep508.js.map +1 -0
  358. package/dist/core/languages/pythonProjectEvidence.d.ts +2 -0
  359. package/dist/core/languages/pythonProjectEvidence.js +29 -0
  360. package/dist/core/languages/pythonProjectEvidence.js.map +1 -0
  361. package/dist/core/languages/pythonProjectTypes.d.ts +31 -0
  362. package/dist/core/languages/pythonProjectTypes.js +2 -0
  363. package/dist/core/languages/pythonProjectTypes.js.map +1 -0
  364. package/dist/core/languages/pythonPyproject.d.ts +2 -0
  365. package/dist/core/languages/pythonPyproject.js +160 -0
  366. package/dist/core/languages/pythonPyproject.js.map +1 -0
  367. package/dist/core/languages/pythonRequirements.d.ts +9 -0
  368. package/dist/core/languages/pythonRequirements.js +212 -0
  369. package/dist/core/languages/pythonRequirements.js.map +1 -0
  370. package/dist/core/languages/pythonRoots.d.ts +3 -0
  371. package/dist/core/languages/pythonRoots.js +83 -0
  372. package/dist/core/languages/pythonRoots.js.map +1 -0
  373. package/dist/core/languages/pythonSetuptools.d.ts +6 -0
  374. package/dist/core/languages/pythonSetuptools.js +58 -0
  375. package/dist/core/languages/pythonSetuptools.js.map +1 -0
  376. package/dist/core/pluginManifestValidation.d.ts +41 -0
  377. package/dist/core/pluginManifestValidation.js +179 -0
  378. package/dist/core/pluginManifestValidation.js.map +1 -0
  379. package/dist/core/plugins.d.ts +3 -41
  380. package/dist/core/plugins.js +2 -129
  381. package/dist/core/plugins.js.map +1 -1
  382. package/dist/core/prDiff.js +12 -0
  383. package/dist/core/prDiff.js.map +1 -1
  384. package/dist/core/preflight.d.ts +3 -3
  385. package/dist/core/preflight.js +28 -542
  386. package/dist/core/preflight.js.map +1 -1
  387. package/dist/core/preflightChangedFileReasons.d.ts +14 -0
  388. package/dist/core/preflightChangedFileReasons.js +75 -0
  389. package/dist/core/preflightChangedFileReasons.js.map +1 -0
  390. package/dist/core/preflightChangedFiles.d.ts +9 -0
  391. package/dist/core/preflightChangedFiles.js +34 -0
  392. package/dist/core/preflightChangedFiles.js.map +1 -0
  393. package/dist/core/preflightContextReasons.d.ts +17 -0
  394. package/dist/core/preflightContextReasons.js +73 -0
  395. package/dist/core/preflightContextReasons.js.map +1 -0
  396. package/dist/core/preflightEvidence.d.ts +34 -0
  397. package/dist/core/preflightEvidence.js +119 -0
  398. package/dist/core/preflightEvidence.js.map +1 -0
  399. package/dist/core/preflightInputs.d.ts +15 -0
  400. package/dist/core/preflightInputs.js +31 -0
  401. package/dist/core/preflightInputs.js.map +1 -0
  402. package/dist/core/preflightIssueReasons.d.ts +2 -0
  403. package/dist/core/preflightIssueReasons.js +39 -0
  404. package/dist/core/preflightIssueReasons.js.map +1 -0
  405. package/dist/core/preflightLocalEvidence.d.ts +12 -0
  406. package/dist/core/preflightLocalEvidence.js +36 -0
  407. package/dist/core/preflightLocalEvidence.js.map +1 -0
  408. package/dist/core/preflightReleaseScale.d.ts +28 -0
  409. package/dist/core/preflightReleaseScale.js +95 -0
  410. package/dist/core/preflightReleaseScale.js.map +1 -0
  411. package/dist/core/preflightRequiredChecks.d.ts +26 -0
  412. package/dist/core/preflightRequiredChecks.js +96 -0
  413. package/dist/core/preflightRequiredChecks.js.map +1 -0
  414. package/dist/core/preflightReviewEvidence.d.ts +16 -0
  415. package/dist/core/preflightReviewEvidence.js +31 -0
  416. package/dist/core/preflightReviewEvidence.js.map +1 -0
  417. package/dist/core/preflightReviewReasons.d.ts +15 -0
  418. package/dist/core/preflightReviewReasons.js +76 -0
  419. package/dist/core/preflightReviewReasons.js.map +1 -0
  420. package/dist/core/preflightSuggestedActions.d.ts +15 -0
  421. package/dist/core/preflightSuggestedActions.js +84 -0
  422. package/dist/core/preflightSuggestedActions.js.map +1 -0
  423. package/dist/core/preflightTruncation.d.ts +6 -0
  424. package/dist/core/preflightTruncation.js +7 -0
  425. package/dist/core/preflightTruncation.js.map +1 -0
  426. package/dist/core/preflightVerdict.d.ts +3 -0
  427. package/dist/core/preflightVerdict.js +17 -0
  428. package/dist/core/preflightVerdict.js.map +1 -0
  429. package/dist/core/regressionPlan.d.ts +2 -1
  430. package/dist/core/regressionPlan.js +7 -1
  431. package/dist/core/regressionPlan.js.map +1 -1
  432. package/dist/core/releaseEvidence.d.ts +4 -3
  433. package/dist/core/releaseEvidence.js +17 -382
  434. package/dist/core/releaseEvidence.js.map +1 -1
  435. package/dist/core/releaseEvidenceArtifacts.d.ts +3 -0
  436. package/dist/core/releaseEvidenceArtifacts.js +65 -0
  437. package/dist/core/releaseEvidenceArtifacts.js.map +1 -0
  438. package/dist/core/releaseEvidenceBaseline.d.ts +2 -0
  439. package/dist/core/releaseEvidenceBaseline.js +28 -0
  440. package/dist/core/releaseEvidenceBaseline.js.map +1 -0
  441. package/dist/core/releaseEvidencePrSummary.d.ts +13 -0
  442. package/dist/core/releaseEvidencePrSummary.js +240 -0
  443. package/dist/core/releaseEvidencePrSummary.js.map +1 -0
  444. package/dist/core/releaseEvidenceVerdict.d.ts +6 -0
  445. package/dist/core/releaseEvidenceVerdict.js +54 -0
  446. package/dist/core/releaseEvidenceVerdict.js.map +1 -0
  447. package/dist/core/releaseTrain.js +3 -317
  448. package/dist/core/releaseTrain.js.map +1 -1
  449. package/dist/core/releaseTrainFallbacks.d.ts +3 -0
  450. package/dist/core/releaseTrainFallbacks.js +318 -0
  451. package/dist/core/releaseTrainFallbacks.js.map +1 -0
  452. package/dist/core/reportPathRedaction.d.ts +4 -0
  453. package/dist/core/reportPathRedaction.js +64 -0
  454. package/dist/core/reportPathRedaction.js.map +1 -0
  455. package/dist/core/reportScope.d.ts +7 -0
  456. package/dist/core/reportScope.js +16 -86
  457. package/dist/core/reportScope.js.map +1 -1
  458. package/dist/core/reportScopeFiltering.d.ts +9 -0
  459. package/dist/core/reportScopeFiltering.js +102 -0
  460. package/dist/core/reportScopeFiltering.js.map +1 -0
  461. package/dist/core/review.d.ts +2 -25
  462. package/dist/core/review.js +34 -1034
  463. package/dist/core/review.js.map +1 -1
  464. package/dist/core/reviewBaseSnapshot.d.ts +14 -0
  465. package/dist/core/reviewBaseSnapshot.js +41 -0
  466. package/dist/core/reviewBaseSnapshot.js.map +1 -0
  467. package/dist/core/reviewChangedFiles.d.ts +8 -0
  468. package/dist/core/reviewChangedFiles.js +63 -0
  469. package/dist/core/reviewChangedFiles.js.map +1 -0
  470. package/dist/core/reviewContractChanges.d.ts +5 -0
  471. package/dist/core/reviewContractChanges.js +114 -0
  472. package/dist/core/reviewContractChanges.js.map +1 -0
  473. package/dist/core/reviewCycles.d.ts +7 -0
  474. package/dist/core/reviewCycles.js +53 -0
  475. package/dist/core/reviewCycles.js.map +1 -0
  476. package/dist/core/reviewFindings.d.ts +17 -0
  477. package/dist/core/reviewFindings.js +49 -0
  478. package/dist/core/reviewFindings.js.map +1 -0
  479. package/dist/core/reviewFlowDiffs.d.ts +4 -0
  480. package/dist/core/reviewFlowDiffs.js +99 -0
  481. package/dist/core/reviewFlowDiffs.js.map +1 -0
  482. package/dist/core/reviewGit.d.ts +7 -0
  483. package/dist/core/reviewGit.js +45 -0
  484. package/dist/core/reviewGit.js.map +1 -0
  485. package/dist/core/reviewGraphEvidence.d.ts +3 -0
  486. package/dist/core/reviewGraphEvidence.js +55 -0
  487. package/dist/core/reviewGraphEvidence.js.map +1 -0
  488. package/dist/core/reviewHeadSnapshot.d.ts +8 -0
  489. package/dist/core/reviewHeadSnapshot.js +15 -0
  490. package/dist/core/reviewHeadSnapshot.js.map +1 -0
  491. package/dist/core/reviewIntent.d.ts +2 -0
  492. package/dist/core/reviewIntent.js +18 -0
  493. package/dist/core/reviewIntent.js.map +1 -0
  494. package/dist/core/reviewManifests.d.ts +12 -0
  495. package/dist/core/reviewManifests.js +124 -0
  496. package/dist/core/reviewManifests.js.map +1 -0
  497. package/dist/core/reviewNoChanges.d.ts +9 -0
  498. package/dist/core/reviewNoChanges.js +26 -0
  499. package/dist/core/reviewNoChanges.js.map +1 -0
  500. package/dist/core/reviewPackageScope.d.ts +4 -0
  501. package/dist/core/reviewPackageScope.js +24 -0
  502. package/dist/core/reviewPackageScope.js.map +1 -0
  503. package/dist/core/reviewRefs.d.ts +4 -0
  504. package/dist/core/reviewRefs.js +65 -0
  505. package/dist/core/reviewRefs.js.map +1 -0
  506. package/dist/core/reviewRiskyFunctions.d.ts +8 -0
  507. package/dist/core/reviewRiskyFunctions.js +83 -0
  508. package/dist/core/reviewRiskyFunctions.js.map +1 -0
  509. package/dist/core/reviewState.d.ts +21 -0
  510. package/dist/core/reviewState.js +96 -0
  511. package/dist/core/reviewState.js.map +1 -0
  512. package/dist/core/reviewTier.d.ts +18 -0
  513. package/dist/core/reviewTier.js +99 -0
  514. package/dist/core/reviewTier.js.map +1 -0
  515. package/dist/core/reviewVerdict.d.ts +9 -0
  516. package/dist/core/reviewVerdict.js +121 -0
  517. package/dist/core/reviewVerdict.js.map +1 -0
  518. package/dist/core/searchIndex.d.ts +2 -14
  519. package/dist/core/searchIndex.js +4 -227
  520. package/dist/core/searchIndex.js.map +1 -1
  521. package/dist/core/searchIndexFiles.d.ts +1 -0
  522. package/dist/core/searchIndexFiles.js +26 -0
  523. package/dist/core/searchIndexFiles.js.map +1 -0
  524. package/dist/core/searchIndexText.d.ts +15 -0
  525. package/dist/core/searchIndexText.js +204 -0
  526. package/dist/core/searchIndexText.js.map +1 -0
  527. package/dist/core/start.d.ts +1 -1
  528. package/dist/core/start.js +14 -87
  529. package/dist/core/start.js.map +1 -1
  530. package/dist/core/startAdoptionGaps.d.ts +3 -0
  531. package/dist/core/startAdoptionGaps.js +12 -0
  532. package/dist/core/startAdoptionGaps.js.map +1 -0
  533. package/dist/core/startEvidence.d.ts +1 -1
  534. package/dist/core/startEvidence.js +16 -1
  535. package/dist/core/startEvidence.js.map +1 -1
  536. package/dist/core/startInputs.d.ts +32 -0
  537. package/dist/core/startInputs.js +30 -0
  538. package/dist/core/startInputs.js.map +1 -0
  539. package/dist/core/startMissionPolicy.js +10 -0
  540. package/dist/core/startMissionPolicy.js.map +1 -1
  541. package/dist/core/startMode.js +7 -1
  542. package/dist/core/startMode.js.map +1 -1
  543. package/dist/core/startReportBuilder.d.ts +26 -0
  544. package/dist/core/startReportBuilder.js +45 -0
  545. package/dist/core/startReportBuilder.js.map +1 -0
  546. package/dist/core/startReportContext.d.ts +23 -0
  547. package/dist/core/startReportContext.js +51 -0
  548. package/dist/core/startReportContext.js.map +1 -0
  549. package/dist/core/startRoadmapPreview.d.ts +2 -0
  550. package/dist/core/startRoadmapPreview.js +31 -0
  551. package/dist/core/startRoadmapPreview.js.map +1 -0
  552. package/dist/core/taint.d.ts +2 -67
  553. package/dist/core/taint.js +41 -276
  554. package/dist/core/taint.js.map +1 -1
  555. package/dist/core/taintIndex.d.ts +20 -0
  556. package/dist/core/taintIndex.js +81 -0
  557. package/dist/core/taintIndex.js.map +1 -0
  558. package/dist/core/taintMatching.d.ts +11 -0
  559. package/dist/core/taintMatching.js +126 -0
  560. package/dist/core/taintMatching.js.map +1 -0
  561. package/dist/core/taintTraversal.d.ts +8 -0
  562. package/dist/core/taintTraversal.js +113 -0
  563. package/dist/core/taintTraversal.js.map +1 -0
  564. package/dist/core/taintTypes.d.ts +67 -0
  565. package/dist/core/taintTypes.js +2 -0
  566. package/dist/core/taintTypes.js.map +1 -0
  567. package/dist/core/telemetry.js +36 -30
  568. package/dist/core/telemetry.js.map +1 -1
  569. package/dist/core/upgradePreview.d.ts +1 -12
  570. package/dist/core/upgradePreview.js +9 -229
  571. package/dist/core/upgradePreview.js.map +1 -1
  572. package/dist/core/upgradePreviewNpmEvidence.d.ts +19 -0
  573. package/dist/core/upgradePreviewNpmEvidence.js +164 -0
  574. package/dist/core/upgradePreviewNpmEvidence.js.map +1 -0
  575. package/dist/core/upgradePreviewPython.d.ts +2 -0
  576. package/dist/core/upgradePreviewPython.js +71 -0
  577. package/dist/core/upgradePreviewPython.js.map +1 -0
  578. package/dist/index.d.ts +6 -12
  579. package/dist/index.js +2 -3
  580. package/dist/index.js.map +1 -1
  581. package/dist/mcp/server.d.ts +3 -24
  582. package/dist/mcp/server.js +32 -414
  583. package/dist/mcp/server.js.map +1 -1
  584. package/dist/mcp/serverContext.d.ts +6 -0
  585. package/dist/mcp/serverContext.js +55 -0
  586. package/dist/mcp/serverContext.js.map +1 -0
  587. package/dist/mcp/serverDispatch.d.ts +39 -0
  588. package/dist/mcp/serverDispatch.js +74 -0
  589. package/dist/mcp/serverDispatch.js.map +1 -0
  590. package/dist/mcp/serverHandlers.d.ts +15 -0
  591. package/dist/mcp/serverHandlers.js +94 -0
  592. package/dist/mcp/serverHandlers.js.map +1 -0
  593. package/dist/mcp/serverLifecycle.d.ts +14 -0
  594. package/dist/mcp/serverLifecycle.js +65 -0
  595. package/dist/mcp/serverLifecycle.js.map +1 -0
  596. package/dist/mcp/serverMessage.d.ts +11 -0
  597. package/dist/mcp/serverMessage.js +37 -0
  598. package/dist/mcp/serverMessage.js.map +1 -0
  599. package/dist/mcp/serverSession.d.ts +6 -0
  600. package/dist/mcp/serverSession.js +77 -0
  601. package/dist/mcp/serverSession.js.map +1 -0
  602. package/dist/mcp/serverStdio.d.ts +7 -0
  603. package/dist/mcp/serverStdio.js +34 -0
  604. package/dist/mcp/serverStdio.js.map +1 -0
  605. package/dist/mcp/serverTypes.d.ts +18 -0
  606. package/dist/mcp/serverTypes.js +2 -0
  607. package/dist/mcp/serverTypes.js.map +1 -0
  608. package/dist/mcp/serverVersion.d.ts +1 -0
  609. package/dist/mcp/serverVersion.js +17 -0
  610. package/dist/mcp/serverVersion.js.map +1 -0
  611. package/dist/mcp/toolCatalog.d.ts +2 -0
  612. package/dist/mcp/toolCatalog.js +93 -0
  613. package/dist/mcp/toolCatalog.js.map +1 -0
  614. package/dist/mcp/tools.d.ts +2 -3
  615. package/dist/mcp/tools.js +15 -108
  616. package/dist/mcp/tools.js.map +1 -1
  617. package/dist/projscan-sbom.cdx.json +6 -6
  618. package/dist/reporters/consoleFixReporter.d.ts +3 -0
  619. package/dist/reporters/consoleFixReporter.js +41 -0
  620. package/dist/reporters/consoleFixReporter.js.map +1 -0
  621. package/dist/reporters/consoleReporter.d.ts +1 -3
  622. package/dist/reporters/consoleReporter.js +1 -42
  623. package/dist/reporters/consoleReporter.js.map +1 -1
  624. package/dist/reporters/htmlReporter.d.ts +3 -2
  625. package/dist/reporters/htmlReporter.js +14 -2
  626. package/dist/reporters/htmlReporter.js.map +1 -1
  627. package/dist/reporters/jsonReporter.d.ts +4 -3
  628. package/dist/reporters/jsonReporter.js +9 -4
  629. package/dist/reporters/jsonReporter.js.map +1 -1
  630. package/dist/reporters/markdownAnalysisReporter.d.ts +2 -1
  631. package/dist/reporters/markdownAnalysisReporter.js +8 -1
  632. package/dist/reporters/markdownAnalysisReporter.js.map +1 -1
  633. package/dist/reporters/markdownArchitectureReporter.d.ts +3 -0
  634. package/dist/reporters/markdownArchitectureReporter.js +33 -0
  635. package/dist/reporters/markdownArchitectureReporter.js.map +1 -0
  636. package/dist/reporters/markdownCouplingReporter.d.ts +2 -0
  637. package/dist/reporters/markdownCouplingReporter.js +43 -0
  638. package/dist/reporters/markdownCouplingReporter.js.map +1 -0
  639. package/dist/reporters/markdownCoverageReporter.d.ts +2 -0
  640. package/dist/reporters/markdownCoverageReporter.js +40 -0
  641. package/dist/reporters/markdownCoverageReporter.js.map +1 -0
  642. package/dist/reporters/markdownExplanationReporter.d.ts +2 -0
  643. package/dist/reporters/markdownExplanationReporter.js +37 -0
  644. package/dist/reporters/markdownExplanationReporter.js.map +1 -0
  645. package/dist/reporters/markdownHealthReporter.d.ts +4 -0
  646. package/dist/reporters/markdownHealthReporter.js +66 -0
  647. package/dist/reporters/markdownHealthReporter.js.map +1 -0
  648. package/dist/reporters/markdownHotspotReporter.d.ts +2 -0
  649. package/dist/reporters/markdownHotspotReporter.js +36 -0
  650. package/dist/reporters/markdownHotspotReporter.js.map +1 -0
  651. package/dist/reporters/markdownOutdatedReporter.d.ts +2 -0
  652. package/dist/reporters/markdownOutdatedReporter.js +31 -0
  653. package/dist/reporters/markdownOutdatedReporter.js.map +1 -0
  654. package/dist/reporters/markdownPrDiffReporter.d.ts +2 -0
  655. package/dist/reporters/markdownPrDiffReporter.js +63 -0
  656. package/dist/reporters/markdownPrDiffReporter.js.map +1 -0
  657. package/dist/reporters/markdownReporter.d.ts +9 -12
  658. package/dist/reporters/markdownReporter.js +9 -288
  659. package/dist/reporters/markdownReporter.js.map +1 -1
  660. package/dist/reporters/markdownWorkspaceReporter.d.ts +2 -0
  661. package/dist/reporters/markdownWorkspaceReporter.js +25 -0
  662. package/dist/reporters/markdownWorkspaceReporter.js.map +1 -0
  663. package/dist/reporters/sarifReporter.d.ts +6 -4
  664. package/dist/reporters/sarifReporter.js +8 -7
  665. package/dist/reporters/sarifReporter.js.map +1 -1
  666. package/dist/tool-manifest.json +3 -3
  667. package/dist/types/start.d.ts +14 -0
  668. package/dist/types.d.ts +34 -34
  669. package/dist/utils/config.d.ts +2 -8
  670. package/dist/utils/config.js +13 -211
  671. package/dist/utils/config.js.map +1 -1
  672. package/dist/utils/configBasics.d.ts +5 -0
  673. package/dist/utils/configBasics.js +21 -0
  674. package/dist/utils/configBasics.js.map +1 -0
  675. package/dist/utils/configHotspots.d.ts +2 -0
  676. package/dist/utils/configHotspots.js +15 -0
  677. package/dist/utils/configHotspots.js.map +1 -0
  678. package/dist/utils/configIssueRules.d.ts +8 -0
  679. package/dist/utils/configIssueRules.js +24 -0
  680. package/dist/utils/configIssueRules.js.map +1 -0
  681. package/dist/utils/configMonorepo.d.ts +2 -0
  682. package/dist/utils/configMonorepo.js +38 -0
  683. package/dist/utils/configMonorepo.js.map +1 -0
  684. package/dist/utils/configReportPolicies.d.ts +2 -0
  685. package/dist/utils/configReportPolicies.js +32 -0
  686. package/dist/utils/configReportPolicies.js.map +1 -0
  687. package/dist/utils/configScan.d.ts +2 -0
  688. package/dist/utils/configScan.js +15 -0
  689. package/dist/utils/configScan.js.map +1 -0
  690. package/dist/utils/configSeverity.d.ts +2 -0
  691. package/dist/utils/configSeverity.js +15 -0
  692. package/dist/utils/configSeverity.js.map +1 -0
  693. package/dist/utils/configSources.d.ts +5 -0
  694. package/dist/utils/configSources.js +55 -0
  695. package/dist/utils/configSources.js.map +1 -0
  696. package/dist/utils/configTaint.d.ts +2 -0
  697. package/dist/utils/configTaint.js +15 -0
  698. package/dist/utils/configTaint.js.map +1 -0
  699. package/docs/GUIDE.md +22 -11
  700. package/docs/ROADMAP.md +18 -7
  701. package/docs/examples/adoption-workflows.md +2 -2
  702. package/docs/examples/swarm-coordination.md +11 -0
  703. package/package.json +1 -1
package/docs/GUIDE.md CHANGED
@@ -180,14 +180,14 @@ When the agent first opens a repo, or before starting a refactor, the question i
180
180
  For short proof-command phrasing, such as `projscan start --intent "give me proof commands"`, it also routes to `projscan_regression_plan --level focused`; reviewer-proof wording with PR comments still routes to `projscan_evidence_pack`.
181
181
  For pre-push command questions, such as `projscan start --intent "what commands should I run before pushing?"`, it routes to `projscan_regression_plan --level focused` so the branch has a small verification loop before it leaves the workstation.
182
182
  For release-readiness wording, such as `projscan start --intent "what should I check before release?"`, `projscan start --intent "can I deploy this?"`, `projscan start --intent "prepare this branch for deployment"`, `projscan start --intent "what changed since last release?"`, `projscan start --intent "write a release note for this change"`, or `projscan start --intent "draft changelog entry"`, it routes to `projscan_release_train` so changelog, package, SBOM, provenance, and blockers are reviewed before deploying or publishing.
183
- For product-planning questions, such as `projscan start --intent "what should we build next?"` or `projscan start --intent "plan the product roadmap"`, it routes to `projscan_workplan --mode bug_hunt` so broad product direction becomes an ordered, verifiable product-planning workplan with explicit accept, defer, or split criteria instead of a generic before-edit orientation.
183
+ For product-planning questions, such as `projscan start --intent "what should we build next?"` or `projscan start --intent "plan the product roadmap"`, it routes to `projscan_release_train` / `projscan release-train` so broad product direction becomes read-only roadmap planning with current post-4.4 workstreams and `evidence.roadmapPreview` instead of a generic before-edit orientation.
184
184
  For broad improvement-planning questions, such as `projscan start --intent "what should we improve next?"`, it routes to `projscan_bug_hunt` so the agent gets an actionable ranked queue; technical variants such as tests, performance, release, dependencies, or safety keep their specialized routes.
185
185
  For quick-win and low-risk improvement wording, such as `projscan start --intent "find a quick win"`, `projscan start --intent "what is a low risk improvement?"`, or `projscan start --intent "pick a small safe task"`, it routes to `projscan_bug_hunt` so a ranked, verifiable action queue is selected instead of a generic quality readout.
186
186
  For tiny-task and beginner-safe wording, such as `projscan start --intent "what can I do in five minutes?"`, `projscan start --intent "pick an easy task for me"`, or `projscan start --intent "what should an intern work on?"`, it also routes to `projscan_bug_hunt`.
187
187
  For branch-diff, PR-size, and commit-message questions, such as `projscan start --intent "what did I change since main?"`, `projscan start --intent "is this PR too large?"`, `projscan start --intent "how big is this change?"`, `projscan start --intent "write a commit message for these changes"`, or `projscan start --intent "summarize my changes for a commit"`, it routes to `projscan_pr_diff` so changed exports, imports, call sites, complexity, and fan-in are reviewed before full review.
188
188
  For branch freshness and comparison questions, such as `projscan start --intent "is my branch stale?"` or `projscan start --intent "compare my branch with main"`, it also routes to `projscan_pr_diff` so the developer checks the structural diff before rebasing or asking for review. For rebase and merge-conflict recovery, such as `projscan start --intent "rebase went wrong"` or `projscan start --intent "resolve merge conflicts"`, it routes to `projscan_preflight --mode before_merge`; post-conflict test-plan wording such as `projscan start --intent "what should I test after resolving conflicts?"` stays on `projscan_regression_plan`.
189
189
  For resume questions, such as `projscan start --intent "where did I leave off?"`, `projscan start --intent "what changed while I was away?"`, `projscan start --intent "what changed while I was offline?"`, `projscan start --intent "what changed while I was asleep?"`, `projscan start --intent "what did the last agent touch?"`, or `projscan start --intent "what did the last agent do?"`, it routes to `projscan_session { action: "touched" }` so remembered touched files are reviewed before live preflight evidence gates the next edit.
190
- For parallel-agent coordination questions, such as `projscan start --intent "show coordination status for parallel agents"`, `projscan start --intent "who else is working on this?"`, `projscan start --intent "am I going to collide with another agent?"`, or `projscan start --intent "what worktrees are active?"`, it routes to `projscan_coordinate` so collisions, claims, and merge order are reviewed through one readiness verdict before editing continues. For merge-order wording, such as `projscan start --intent "what should merge first?"`, it routes to `projscan_merge_risk`; for overlap wording, such as `projscan start --intent "show me overlapping changes"`, it routes to `projscan_collision`.
190
+ For parallel-agent coordination questions, such as `projscan start --intent "show coordination status for parallel agents"`, `projscan start --intent "who else is working on this?"`, `projscan start --intent "am I going to collide with another agent?"`, or `projscan start --intent "what worktrees are active?"`, it routes to `projscan_coordinate` so collisions, claims, merge order, and the current-worktree-versus-remembered-session evidence boundary are reviewed through one readiness verdict before editing continues. For merge-order wording, such as `projscan start --intent "what should merge first?"`, it routes to `projscan_merge_risk`; for overlap wording, such as `projscan start --intent "show me overlapping changes"`, it routes to `projscan_collision`.
191
191
  For active-claim questions, such as `projscan start --intent "show active claims"`, it routes to `projscan_claim { action: "list" }` so owners, leases, and contention warnings are reviewed before parallel work continues.
192
192
  For file-claim requests, such as `projscan start --intent "claim src/core/start.ts for me"`, it routes to `projscan_claim`, lists active claims first, then adds the requested target only after a real agent name replaces `Needs Input`.
193
193
  For architecture-coupling questions, such as `projscan start --intent "show circular dependencies"` or `projscan start --intent "find dependency cycles"`, it routes to `projscan_coupling` with `direction: "cycles_only"` / `projscan coupling --cycles-only --format json`; broader wording such as `projscan start --intent "what modules are tightly coupled"` routes to the full fan-in, fan-out, instability, cross-package-edge, and cycle report.
@@ -204,7 +204,7 @@ When the agent first opens a repo, or before starting a refactor, the question i
204
204
  - **`projscan_preflight` / `projscan preflight`** — agent safety gate. Returns `proceed`, `caution`, or `block` with health, changed-file, review, remembered session, hotspot, plugin-policy, supply-chain, and release-scale evidence. `evidence.riskSources.currentWorktree` is current Git/worktree evidence; `evidence.riskSources.sessionMemory` is remembered handoff context. Use `--mode before_edit` at the start of work and `--mode before_commit` / `--mode before_merge` before handing off or merging; scale-only commit blocks are cautions, while merge gates still require manual release sign-off.
205
205
  - **`projscan_hotspots` / `projscan hotspots`** — files ranked by `git churn × AST cyclomatic complexity × open issues × ownership × coverage`. Pass `view: "functions"` for top-N risky individual functions across the repo (0.13+).
206
206
  - **`projscan_semantic_graph` / `projscan semantic-graph`** — stable v3 graph contract with file, function, package, and symbol nodes plus imports, exports, definitions, and calls edges. Use it when an agent needs one normalized graph shape instead of several targeted queries.
207
- - **`projscan_dataflow` / `projscan dataflow`** — direct, propagated, and bridge source-to-sink dataflow risks. Use it for a focused safety pass before touching command execution, raw SQL, filesystem writes, or DOM sinks.
207
+ - **`projscan_dataflow` / `projscan dataflow`** — direct, propagated, and bridge source-to-sink dataflow risks, including framework-aware Next.js route request body and URL sources. Use it for a focused safety pass before touching command execution, raw SQL, filesystem writes, or DOM sinks.
208
208
  - **`projscan_coupling` / `projscan coupling`** — per-file fan-in / fan-out / instability plus circular-import cycles (Tarjan SCC). Use `direction: cycles_only` or `projscan coupling --cycles-only` to surface architectural debt directly.
209
209
  - **`projscan_analyze` / `projscan analyze`** — the everything report; useful at session start but verbose.
210
210
 
@@ -435,7 +435,11 @@ and a sink wrapper is surfaced even when legacy taint reachability cannot see a
435
435
  downstream call path from source to sink. By default, dataflow suppresses test-file paths,
436
436
  broad readFile/writeFile-style noise, and JavaScript RegExp.exec false positives.
437
437
  Framework request-source detection covers narrow tested patterns for Next.js, Hono,
438
- Express, Fastify, and Koa handlers while keeping lookalike helpers quiet.
438
+ Express, Fastify, and Koa handlers, including Hono validator output,
439
+ Express/Fastify/Koa request IP metadata, Fastify host/hostname and raw
440
+ URL/header evidence, and Express/Koa header accessors plus Express
441
+ `req.param(...)` and `req.originalUrl`, while
442
+ keeping lookalike helpers quiet.
439
443
 
440
444
  For release hardening, `npm run check:graph-corpus` compares bundled fixture metrics against `docs/graph-corpus-baseline.json`. The gate fails only when graph coverage drops below the baseline or dataflow risks rise above it.
441
445
 
@@ -698,8 +702,8 @@ Preview the impact of upgrading a package. The default path is fully offline; pa
698
702
  - Breaking-change markers found in the CHANGELOG: scans for `BREAKING CHANGE`, `deprecated`, `removed support`, `no longer supported`, and section headers containing "breaking"
699
703
  - CHANGELOG excerpt sliced to the relevant version range (read from `node_modules/<pkg>/CHANGELOG.md`)
700
704
  - Importer list - every file in your source tree that imports the package (direct or sub-path)
701
- - Python manifest evidence for packages declared in `pyproject.toml`, `setup.cfg`, `setup.py`, or root `requirements*.txt`
702
- - Python current-version evidence from `poetry.lock` package blocks or pinned root `requirements*.txt` entries
705
+ - Python manifest evidence for packages declared in `pyproject.toml` (including PEP 735 `dependency-groups`, Poetry dependency groups, and legacy `tool.poetry.dev-dependencies`), `setup.cfg`, `setup.py`, or root `requirements*.txt`. Root Python manifests are sufficient local evidence even before `.py` files exist.
706
+ - Python current-version evidence from `poetry.lock` / `uv.lock` / `pdm.lock` package blocks, `conda-lock.yml` / `conda-lock.yaml` package entries, `Pipfile.lock` exact versions, pinned root `requirements*.txt`, or pinned root `constraints*.txt` entries
703
707
 
704
708
  **Example:**
705
709
 
@@ -721,7 +725,7 @@ $ projscan upgrade react --format markdown
721
725
 
722
726
  - Reads the CHANGELOG that npm already placed in `node_modules/`. If the package author doesn't ship one, you'll see "No local CHANGELOG found."
723
727
  - Without `--check-registry`, works with what's **installed** and reports `latestSource: "installed"`. With `--check-registry`, npm registry lookup is attempted and failures fall back to the installed version with `registryError`.
724
- - Python previews stay offline. They do not query PyPI; current-version evidence comes from supported local lockfiles or pinned root requirements.
728
+ - Python previews stay offline. They do not query PyPI; current-version evidence comes from supported local lockfiles, pinned root requirements, or pinned root constraints.
725
729
 
726
730
  ### coverage
727
731
 
@@ -909,6 +913,10 @@ projscan doctor --format html > HEALTH.html
909
913
  ```
910
914
 
911
915
  Supported on `analyze`, `doctor`, `hotspots`, `coupling`, `pr-diff`, `review`, `impact`, and `coverage`.
916
+ For `analyze` and `doctor`, scoped/redacted report controls also appear as a
917
+ path-safe controls card when active.
918
+ Path redaction keeps HTTP(S) documentation links readable while redacting
919
+ standalone file-like path tokens from issue text.
912
920
 
913
921
  ### SARIF
914
922
 
@@ -929,9 +937,11 @@ Supported on `analyze`, `audit`, `ci`, `doctor`, and `outdated`. Each issue is e
929
937
  For shareable evidence artifacts, `analyze`, `doctor`, and `ci` accept
930
938
  `--report-policy <name>`, `--report-scope <paths>`, and `--redact-paths`. Scope
931
939
  is comma-separated and repo-relative. Redaction replaces file paths with stable
932
- labels while preserving correlation across issues and files in the same report.
933
- Direct `--report-scope` and `--redact-paths` flags override the selected preset
934
- for a single run.
940
+ labels while preserving correlation across issues and files in the same report,
941
+ including file-like path tokens in issue text that has no location anchor.
942
+ JSON/SARIF include path-safe `reportControls` metadata, and Markdown/HTML print
943
+ path-safe controls banners. Direct `--report-scope` and `--redact-paths` flags
944
+ override the selected preset for a single run.
935
945
  - `properties.fixAvailable` - whether `projscan fix` can remediate it
936
946
 
937
947
  When uploaded to GitHub Code Scanning, findings appear in the **Security → Code scanning** tab and (for PRs) as inline annotations on changed lines.
@@ -1622,7 +1632,8 @@ src/
1622
1632
  │ ├── markdownReporter.ts # Markdown output
1623
1633
  │ └── sarifReporter.ts # SARIF 2.1.0 output
1624
1634
  ├── mcp/
1625
- │ ├── server.ts # JSON-RPC 2.0 dispatcher, stdio transport, negotiation
1635
+ │ ├── server.ts # MCP server factory and JSON-RPC request orchestration
1636
+ │ ├── serverStdio.ts # stdio transport loop for the CLI entry point
1626
1637
  │ ├── tools.ts # 41 MCP tools (barrel; per-tool files under tools/)
1627
1638
  │ ├── tokenBudget.ts # Record-aware response truncator
1628
1639
  │ ├── pagination.ts # Cursor-based pagination (opaque base64 + checksum)
package/docs/ROADMAP.md CHANGED
@@ -1,6 +1,6 @@
1
1
  # ProjScan Roadmap
2
2
 
3
- Last reviewed 2026-06-16.
3
+ Last reviewed 2026-06-17.
4
4
 
5
5
  ---
6
6
 
@@ -45,7 +45,7 @@ Four plays, in order:
45
45
  3. **Become the operator, not the advisor** — stop suggesting and start acting (cross-repo, apply, security gate). ✅ Shipped in the 1.6 arc.
46
46
  4. **Expand the moat** — depth where it matters (CFG / dataflow on hot paths, more languages, sub-file embeddings, cost analytics, live PR review, plugin extensibility). Not everywhere; we're not trying to be Cody. ✅ The 1.7 → 2.0 arc turns this into a platform contract.
47
47
  5. **Coordinate the swarm** — collision detection, claims/leases, merge-risk preflight, intent routing, one-call coordination, and live coordinate watch shipped across the 3.6 through 3.7 arc, with the 4.0 tool-surface consolidation now complete. The next work is evidence: prove which commands agents reach for in real multi-worktree sessions, then deepen only the paths that prevent integration failures.
48
- 6. **Make agent proof release-ready** — 4.1 through 4.5 turned Mission Control into a goal → mission → proof → review harness and packaged the post-4.4 implementation train: current planning surfaces, adoption examples, precise framework dataflow, scoped/redacted evidence exports, Python upgrade previews, and hotspot maintainability cleanup.
48
+ 6. **Make agent proof release-ready** — 4.1 through 4.6 turned Mission Control into a goal → mission → proof → review harness and packaged the post-4.4 implementation train: current planning surfaces, adoption examples, precise framework dataflow, scoped/redacted evidence exports, Python upgrade previews, coordination evidence, public graph types, and hotspot maintainability cleanup.
49
49
 
50
50
  We are _not_ trying to be:
51
51
 
@@ -56,9 +56,9 @@ We are _not_ trying to be:
56
56
 
57
57
  ## Now / Next / Later
58
58
 
59
- ### Now — Post-4.5 Validation
59
+ ### Now — Post-4.6 Validation
60
60
 
61
- 4.5.0 "Review-Ready Intelligence Train" packages the post-4.4 implementation train. The next work is validation and selective hardening from real use, not another broad feature push.
61
+ 4.6.0 "Agent Coordination And Routing Hardening" packages the latest post-4.4 implementation train. The next work is validation and selective hardening from real use, not another broad feature push or another release push.
62
62
 
63
63
  The active validation lines are:
64
64
 
@@ -70,7 +70,18 @@ The active validation lines are:
70
70
 
71
71
  Strictly **local-first** throughout: same-repo / same-machine evidence, no daemon, no cloud, no hidden network calls, no new telemetry, and no secret-value reads.
72
72
 
73
- Success signals: teams copy the adoption examples into real reviews, scoped/redacted artifacts are accepted by reviewers, Python upgrade previews identify useful local evidence, dataflow additions stay quiet on lookalikes, and release bug-hunts remain free of concrete defects.
73
+ Success signals: teams copy the adoption examples into real reviews, scoped/redacted artifacts are accepted by reviewers, Python upgrade previews identify useful local evidence, coordination evidence explains multi-agent decisions, dataflow additions stay quiet on lookalikes, and release bug-hunts remain free of concrete defects.
74
+
75
+ ### Recently Completed — 4.6.0 (2026)
76
+
77
+ **4.6.0 "Agent Coordination And Routing Hardening"** shipped the next hardening pass after the review-ready train:
78
+
79
+ - Framework-gated request-source coverage now includes Next `nextUrl`, Hono URL reads, Express URL reads, Koa URL reads, and Fastify URL reads.
80
+ - Agent hints include concrete local coordination evidence for multi-agent collision, handoff, and coordination decisions.
81
+ - Public consumers can import code graph result types.
82
+ - Mission Control start, intent router, review, CLI, and MCP test surfaces were split into focused suites while preserving public behavior.
83
+ - Intent routing, code graph parsing/indexing, release evidence, upgrade preview, CLI reporting, and MCP transport helpers moved into smaller modules.
84
+ - MCP watch IDs, request notifications, no-release continuation routing, agent harness proof routing, Python upgrade evidence, scoped dependency redaction, path-safe file links, unresolved review refs, and inspector purpose detection were tightened.
74
85
 
75
86
  ### Recently Completed — 4.5.0 (2026)
76
87
 
@@ -79,8 +90,8 @@ Success signals: teams copy the adoption examples into real reviews, scoped/reda
79
90
  - Roadmap and release-train planning now default to the current post-4.4 product lines instead of stale shipped work.
80
91
  - Adoption examples cover agent orchestration, package ownership, custom policy plugins, swarm coordination, and scoped evidence exports.
81
92
  - `analyze`, `doctor`, and `ci` can scope and redact shareable evidence with direct flags or named `reportPolicies` presets.
82
- - `projscan upgrade` and MCP `projscan_upgrade` support offline Python previews from manifests, Poetry lockfiles, pinned requirements, and Python importers.
83
- - Dataflow detects narrow Fastify and Koa request-source patterns while suppressing lookalike helpers and Koa response-body writes.
93
+ - `projscan upgrade` and MCP `projscan_upgrade` support offline Python previews from manifests, Poetry/Pipfile/uv/PDM/Conda lockfiles, pinned requirements/constraints, and Python importers.
94
+ - Dataflow detects narrow Fastify and Koa request-source patterns, including Fastify raw URL/header and Koa IP evidence, while suppressing lookalike helpers and Koa response-body writes.
84
95
  - Start next-action assembly and taint function identity were tightened during release readiness cleanup.
85
96
 
86
97
  ### Recently Completed — 4.4.0 (2026)
@@ -50,8 +50,8 @@ projscan agent-brief --intent "handoff package ownership for fastapi" --format j
50
50
  For Node packages, `upgrade` reads local `package.json`, `node_modules`, local
51
51
  CHANGELOG files, and importer evidence. For Python packages, it reads
52
52
  `pyproject.toml`, `setup.cfg`, `setup.py`, root `requirements*.txt` files,
53
- Poetry lockfiles, and pinned root requirements, then returns declared scope,
54
- current-version source, drift, and Python importers.
53
+ Poetry/Pipfile/uv/PDM/Conda lockfiles, and pinned root requirements/constraints, then
54
+ returns declared scope, current-version source, drift, and Python importers.
55
55
 
56
56
  Decision loop:
57
57
 
@@ -51,6 +51,17 @@ Read the outputs this way:
51
51
  | `coordinate` | Is the current swarm clear, cautious, or conflicted? | Use this as the one-line status in handoffs. |
52
52
  | `agent-brief` | What should the next agent know? | Include coordination hints in the next-agent packet. |
53
53
 
54
+ The JSON reports for `collisions` and `coordinate` include an `evidence` block
55
+ with the active command path, current worktree state, local-only source signals,
56
+ the validation workflow above, and a reminder that session memory is separate
57
+ from current Git/worktree evidence. The default `coordinate` console view prints
58
+ the same session-boundary reminder inside its `Evidence` section.
59
+ When multiple worktrees are present, `agent-brief` also carries a
60
+ `context.coordinationHints` entry even for a clear swarm, so the next agent knows
61
+ to validate locally with `projscan coordinate --format json`,
62
+ `projscan coordinate --watch --interval 5 --format json`, and
63
+ `projscan agent-brief --format json` before continuing parallel edits.
64
+
54
65
  For MCP clients that support long-running notifications, use the watch tool:
55
66
 
56
67
  ```text
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "projscan",
3
3
  "mcpName": "io.github.abhiyoheswaran1/projscan",
4
- "version": "4.5.0",
4
+ "version": "4.7.0",
5
5
  "description": "Agent-first code intelligence. MCP server (2025-03-26) with 11 AST adapters covering 12 named languages: JavaScript, TypeScript, Python, Go, Java, Ruby, Rust, PHP, C#, Kotlin, Swift, and C++; repo understanding maps (projscan_understand), stable v3 semantic graph (projscan_semantic_graph), dataflow risk engine with bridge-helper detection (projscan_dataflow), code graph, file + per-function AST cyclomatic complexity, per-function fan-in + fan-out, coupling + cycle detection, structural PR diff with HTML reporter, coverage report with HTML reporter, intent-grounded one-call PR review (projscan_review with optional `intent` arg, new taint flows, contract changes, and newDataflowRisks) and long-running PR-watch mode with structured per-bucket deltas (projscan_review_watch), first-60-seconds workflow orientation (projscan_start), agent workplans (projscan_workplan), bug-hunt queues (projscan_bug_hunt), product-line planning (projscan_release_train), evidence packs (projscan_evidence_pack), regression planning (projscan_regression_plan), agent briefs (projscan_agent_brief), quality scorecards (projscan_quality_scorecard), and preflight with supply-chain IOC evidence, rule-driven fix suggestions + mechanical apply layer with rollback (projscan_apply_fix, projscan_fix_suggest, projscan_explain_issue), source-to-sink taint analysis (projscan_taint) with truncation reporting, transitive blast-radius analysis with cross-repo mode (projscan_impact for files and symbols), cross-repo workspace registration + intelligence (projscan_workspace_graph), per-function semantic search chunks (sub-file embeddings), per-rule confidence + severity drift + cost-summary analytics with live streaming (projscan_cost_summary), stable local analyzer + reporter plugin API (projscan_plugin, CLI --reporter, opt-in via PROJSCAN_PLUGINS_PREVIEW=1), monorepo workspace awareness with cross-package import policy + per-package dependencies / outdated / audit, BM25 + optional semantic search, cursor pagination, progress notifications, context-budgeted output, and a stable-surface CI guard. CLI on the side.",
6
6
  "type": "module",
7
7
  "main": "./dist/index.js",