@hongmaple0820/med-scale-research-os 0.43.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 (1104) hide show
  1. package/.scale/mcp-servers.yaml +144 -0
  2. package/.scale/skills.json +830 -0
  3. package/.scale/verification.json +52 -0
  4. package/LICENSE +15 -0
  5. package/README.en.md +156 -0
  6. package/README.md +156 -0
  7. package/dist/adapters/AiderAdapter.d.ts +22 -0
  8. package/dist/adapters/AiderAdapter.js +262 -0
  9. package/dist/adapters/AiderAdapter.js.map +1 -0
  10. package/dist/adapters/AntigravityAdapter.d.ts +4 -0
  11. package/dist/adapters/AntigravityAdapter.js +21 -0
  12. package/dist/adapters/AntigravityAdapter.js.map +1 -0
  13. package/dist/adapters/ClaudeCodeAdapter.d.ts +54 -0
  14. package/dist/adapters/ClaudeCodeAdapter.js +185 -0
  15. package/dist/adapters/ClaudeCodeAdapter.js.map +1 -0
  16. package/dist/adapters/ClineAdapter.d.ts +4 -0
  17. package/dist/adapters/ClineAdapter.js +20 -0
  18. package/dist/adapters/ClineAdapter.js.map +1 -0
  19. package/dist/adapters/CodexAdapter.d.ts +15 -0
  20. package/dist/adapters/CodexAdapter.js +160 -0
  21. package/dist/adapters/CodexAdapter.js.map +1 -0
  22. package/dist/adapters/CursorAdapter.d.ts +14 -0
  23. package/dist/adapters/CursorAdapter.js +171 -0
  24. package/dist/adapters/CursorAdapter.js.map +1 -0
  25. package/dist/adapters/DeepSeekTuiAdapter.d.ts +19 -0
  26. package/dist/adapters/DeepSeekTuiAdapter.js +263 -0
  27. package/dist/adapters/DeepSeekTuiAdapter.js.map +1 -0
  28. package/dist/adapters/DoubaoAdapter.d.ts +14 -0
  29. package/dist/adapters/DoubaoAdapter.js +184 -0
  30. package/dist/adapters/DoubaoAdapter.js.map +1 -0
  31. package/dist/adapters/GeminiAdapter.d.ts +14 -0
  32. package/dist/adapters/GeminiAdapter.js +163 -0
  33. package/dist/adapters/GeminiAdapter.js.map +1 -0
  34. package/dist/adapters/GenericProjectAgentAdapter.d.ts +29 -0
  35. package/dist/adapters/GenericProjectAgentAdapter.js +204 -0
  36. package/dist/adapters/GenericProjectAgentAdapter.js.map +1 -0
  37. package/dist/adapters/HermesAdapter.d.ts +14 -0
  38. package/dist/adapters/HermesAdapter.js +163 -0
  39. package/dist/adapters/HermesAdapter.js.map +1 -0
  40. package/dist/adapters/JCodeAdapter.d.ts +4 -0
  41. package/dist/adapters/JCodeAdapter.js +19 -0
  42. package/dist/adapters/JCodeAdapter.js.map +1 -0
  43. package/dist/adapters/KiloCodeAdapter.d.ts +4 -0
  44. package/dist/adapters/KiloCodeAdapter.js +20 -0
  45. package/dist/adapters/KiloCodeAdapter.js.map +1 -0
  46. package/dist/adapters/KimiAdapter.d.ts +14 -0
  47. package/dist/adapters/KimiAdapter.js +183 -0
  48. package/dist/adapters/KimiAdapter.js.map +1 -0
  49. package/dist/adapters/KiroAdapter.d.ts +14 -0
  50. package/dist/adapters/KiroAdapter.js +180 -0
  51. package/dist/adapters/KiroAdapter.js.map +1 -0
  52. package/dist/adapters/OpenClawAdapter.d.ts +14 -0
  53. package/dist/adapters/OpenClawAdapter.js +163 -0
  54. package/dist/adapters/OpenClawAdapter.js.map +1 -0
  55. package/dist/adapters/OpenCodeAdapter.d.ts +14 -0
  56. package/dist/adapters/OpenCodeAdapter.js +172 -0
  57. package/dist/adapters/OpenCodeAdapter.js.map +1 -0
  58. package/dist/adapters/QCoderAdapter.d.ts +14 -0
  59. package/dist/adapters/QCoderAdapter.js +159 -0
  60. package/dist/adapters/QCoderAdapter.js.map +1 -0
  61. package/dist/adapters/QoderAdapter.d.ts +4 -0
  62. package/dist/adapters/QoderAdapter.js +21 -0
  63. package/dist/adapters/QoderAdapter.js.map +1 -0
  64. package/dist/adapters/TraeAdapter.d.ts +14 -0
  65. package/dist/adapters/TraeAdapter.js +159 -0
  66. package/dist/adapters/TraeAdapter.js.map +1 -0
  67. package/dist/adapters/VSCAdapter.d.ts +14 -0
  68. package/dist/adapters/VSCAdapter.js +159 -0
  69. package/dist/adapters/VSCAdapter.js.map +1 -0
  70. package/dist/adapters/WindsurfAdapter.d.ts +14 -0
  71. package/dist/adapters/WindsurfAdapter.js +185 -0
  72. package/dist/adapters/WindsurfAdapter.js.map +1 -0
  73. package/dist/adapters/WorkBuddyAdapter.d.ts +14 -0
  74. package/dist/adapters/WorkBuddyAdapter.js +159 -0
  75. package/dist/adapters/WorkBuddyAdapter.js.map +1 -0
  76. package/dist/adapters/index.d.ts +32 -0
  77. package/dist/adapters/index.js +87 -0
  78. package/dist/adapters/index.js.map +1 -0
  79. package/dist/agents/AgentChannel.d.ts +43 -0
  80. package/dist/agents/AgentChannel.js +136 -0
  81. package/dist/agents/AgentChannel.js.map +1 -0
  82. package/dist/agents/AgentCoordinator.d.ts +29 -0
  83. package/dist/agents/AgentCoordinator.js +136 -0
  84. package/dist/agents/AgentCoordinator.js.map +1 -0
  85. package/dist/agents/AgentDispatcher.d.ts +24 -0
  86. package/dist/agents/AgentDispatcher.js +112 -0
  87. package/dist/agents/AgentDispatcher.js.map +1 -0
  88. package/dist/agents/AgentManager.d.ts +14 -0
  89. package/dist/agents/AgentManager.js +85 -0
  90. package/dist/agents/AgentManager.js.map +1 -0
  91. package/dist/agents/AgentPool.d.ts +59 -0
  92. package/dist/agents/AgentPool.js +192 -0
  93. package/dist/agents/AgentPool.js.map +1 -0
  94. package/dist/agents/AgentRegistry.d.ts +20 -0
  95. package/dist/agents/AgentRegistry.js +36 -0
  96. package/dist/agents/AgentRegistry.js.map +1 -0
  97. package/dist/agents/AgentSourceLoader.d.ts +73 -0
  98. package/dist/agents/AgentSourceLoader.js +103 -0
  99. package/dist/agents/AgentSourceLoader.js.map +1 -0
  100. package/dist/agents/IAgent.d.ts +53 -0
  101. package/dist/agents/IAgent.js +4 -0
  102. package/dist/agents/IAgent.js.map +1 -0
  103. package/dist/agents/LeadershipPresets.d.ts +16 -0
  104. package/dist/agents/LeadershipPresets.js +152 -0
  105. package/dist/agents/LeadershipPresets.js.map +1 -0
  106. package/dist/agents/definitions/debugger.d.ts +2 -0
  107. package/dist/agents/definitions/debugger.js +6 -0
  108. package/dist/agents/definitions/debugger.js.map +1 -0
  109. package/dist/agents/definitions/doc-writer.d.ts +2 -0
  110. package/dist/agents/definitions/doc-writer.js +6 -0
  111. package/dist/agents/definitions/doc-writer.js.map +1 -0
  112. package/dist/agents/definitions/implementer.d.ts +2 -0
  113. package/dist/agents/definitions/implementer.js +6 -0
  114. package/dist/agents/definitions/implementer.js.map +1 -0
  115. package/dist/agents/definitions/planner.d.ts +2 -0
  116. package/dist/agents/definitions/planner.js +6 -0
  117. package/dist/agents/definitions/planner.js.map +1 -0
  118. package/dist/agents/definitions/researcher.d.ts +2 -0
  119. package/dist/agents/definitions/researcher.js +6 -0
  120. package/dist/agents/definitions/researcher.js.map +1 -0
  121. package/dist/agents/definitions/reviewer.d.ts +2 -0
  122. package/dist/agents/definitions/reviewer.js +6 -0
  123. package/dist/agents/definitions/reviewer.js.map +1 -0
  124. package/dist/agents/definitions/security.d.ts +2 -0
  125. package/dist/agents/definitions/security.js +6 -0
  126. package/dist/agents/definitions/security.js.map +1 -0
  127. package/dist/agents/definitions/tester.d.ts +2 -0
  128. package/dist/agents/definitions/tester.js +6 -0
  129. package/dist/agents/definitions/tester.js.map +1 -0
  130. package/dist/agents/index.d.ts +23 -0
  131. package/dist/agents/index.js +44 -0
  132. package/dist/agents/index.js.map +1 -0
  133. package/dist/agents/profiles.d.ts +26 -0
  134. package/dist/agents/profiles.js +197 -0
  135. package/dist/agents/profiles.js.map +1 -0
  136. package/dist/agents/types.d.ts +262 -0
  137. package/dist/agents/types.js +4 -0
  138. package/dist/agents/types.js.map +1 -0
  139. package/dist/api/cli.d.ts +2 -0
  140. package/dist/api/cli.js +6678 -0
  141. package/dist/api/cli.js.map +1 -0
  142. package/dist/api/doctor.d.ts +83 -0
  143. package/dist/api/doctor.js +982 -0
  144. package/dist/api/doctor.js.map +1 -0
  145. package/dist/api/mcp.d.ts +32 -0
  146. package/dist/api/mcp.js +223 -0
  147. package/dist/api/mcp.js.map +1 -0
  148. package/dist/api/medscale.d.ts +2 -0
  149. package/dist/api/medscale.js +20 -0
  150. package/dist/api/medscale.js.map +1 -0
  151. package/dist/api/quickstart.d.ts +86 -0
  152. package/dist/api/quickstart.js +291 -0
  153. package/dist/api/quickstart.js.map +1 -0
  154. package/dist/artifact/fsm.d.ts +41 -0
  155. package/dist/artifact/fsm.js +221 -0
  156. package/dist/artifact/fsm.js.map +1 -0
  157. package/dist/artifact/fsmDefinitions.d.ts +18 -0
  158. package/dist/artifact/fsmDefinitions.js +296 -0
  159. package/dist/artifact/fsmDefinitions.js.map +1 -0
  160. package/dist/artifact/sqliteStore.d.ts +61 -0
  161. package/dist/artifact/sqliteStore.js +381 -0
  162. package/dist/artifact/sqliteStore.js.map +1 -0
  163. package/dist/artifact/store.d.ts +49 -0
  164. package/dist/artifact/store.js +116 -0
  165. package/dist/artifact/store.js.map +1 -0
  166. package/dist/artifact/types.d.ts +535 -0
  167. package/dist/artifact/types.js +74 -0
  168. package/dist/artifact/types.js.map +1 -0
  169. package/dist/bootstrap/DependencyBootstrap.d.ts +112 -0
  170. package/dist/bootstrap/DependencyBootstrap.js +1046 -0
  171. package/dist/bootstrap/DependencyBootstrap.js.map +1 -0
  172. package/dist/bootstrap/DependencyBootstrapRenderer.d.ts +3 -0
  173. package/dist/bootstrap/DependencyBootstrapRenderer.js +138 -0
  174. package/dist/bootstrap/DependencyBootstrapRenderer.js.map +1 -0
  175. package/dist/bridge/PythonBridge.d.ts +80 -0
  176. package/dist/bridge/PythonBridge.js +437 -0
  177. package/dist/bridge/PythonBridge.js.map +1 -0
  178. package/dist/bridge/index.d.ts +2 -0
  179. package/dist/bridge/index.js +7 -0
  180. package/dist/bridge/index.js.map +1 -0
  181. package/dist/bridge/medicalWorkflows.d.ts +29 -0
  182. package/dist/bridge/medicalWorkflows.js +156 -0
  183. package/dist/bridge/medicalWorkflows.js.map +1 -0
  184. package/dist/bridge/types.d.ts +381 -0
  185. package/dist/bridge/types.js +113 -0
  186. package/dist/bridge/types.js.map +1 -0
  187. package/dist/cache/ScanCache.d.ts +41 -0
  188. package/dist/cache/ScanCache.js +120 -0
  189. package/dist/cache/ScanCache.js.map +1 -0
  190. package/dist/capabilities/BrowserCapability.d.ts +30 -0
  191. package/dist/capabilities/BrowserCapability.js +73 -0
  192. package/dist/capabilities/BrowserCapability.js.map +1 -0
  193. package/dist/capabilities/BrowserQACapability.d.ts +165 -0
  194. package/dist/capabilities/BrowserQACapability.js +438 -0
  195. package/dist/capabilities/BrowserQACapability.js.map +1 -0
  196. package/dist/capabilities/CapabilityRegistry.d.ts +17 -0
  197. package/dist/capabilities/CapabilityRegistry.js +65 -0
  198. package/dist/capabilities/CapabilityRegistry.js.map +1 -0
  199. package/dist/capabilities/ComputerCapability.d.ts +28 -0
  200. package/dist/capabilities/ComputerCapability.js +40 -0
  201. package/dist/capabilities/ComputerCapability.js.map +1 -0
  202. package/dist/capabilities/InstalledSkillsIntegration.d.ts +69 -0
  203. package/dist/capabilities/InstalledSkillsIntegration.js +240 -0
  204. package/dist/capabilities/InstalledSkillsIntegration.js.map +1 -0
  205. package/dist/capabilities/SearchCapability.d.ts +46 -0
  206. package/dist/capabilities/SearchCapability.js +88 -0
  207. package/dist/capabilities/SearchCapability.js.map +1 -0
  208. package/dist/capabilities/index.d.ts +6 -0
  209. package/dist/capabilities/index.js +9 -0
  210. package/dist/capabilities/index.js.map +1 -0
  211. package/dist/capabilities/types.d.ts +92 -0
  212. package/dist/capabilities/types.js +7 -0
  213. package/dist/capabilities/types.js.map +1 -0
  214. package/dist/cli/autofixCommands.d.ts +22 -0
  215. package/dist/cli/autofixCommands.js +32 -0
  216. package/dist/cli/autofixCommands.js.map +1 -0
  217. package/dist/cli/cortexCommands.d.ts +71 -0
  218. package/dist/cli/cortexCommands.js +335 -0
  219. package/dist/cli/cortexCommands.js.map +1 -0
  220. package/dist/cli/costCommands.d.ts +13 -0
  221. package/dist/cli/costCommands.js +48 -0
  222. package/dist/cli/costCommands.js.map +1 -0
  223. package/dist/cli/evolutionCommands.d.ts +112 -0
  224. package/dist/cli/evolutionCommands.js +246 -0
  225. package/dist/cli/evolutionCommands.js.map +1 -0
  226. package/dist/cli/gateStatusCommands.d.ts +1 -0
  227. package/dist/cli/gateStatusCommands.js +52 -0
  228. package/dist/cli/gateStatusCommands.js.map +1 -0
  229. package/dist/cli/liteCommands.d.ts +81 -0
  230. package/dist/cli/liteCommands.js +148 -0
  231. package/dist/cli/liteCommands.js.map +1 -0
  232. package/dist/cli/orchCommands.d.ts +43 -0
  233. package/dist/cli/orchCommands.js +135 -0
  234. package/dist/cli/orchCommands.js.map +1 -0
  235. package/dist/cli/phaseCommands.d.ts +248 -0
  236. package/dist/cli/phaseCommands.js +1878 -0
  237. package/dist/cli/phaseCommands.js.map +1 -0
  238. package/dist/cli/promptCommands.d.ts +1 -0
  239. package/dist/cli/promptCommands.js +57 -0
  240. package/dist/cli/promptCommands.js.map +1 -0
  241. package/dist/cli/qaCommands.d.ts +22 -0
  242. package/dist/cli/qaCommands.js +84 -0
  243. package/dist/cli/qaCommands.js.map +1 -0
  244. package/dist/cli/quickstartCommands.d.ts +17 -0
  245. package/dist/cli/quickstartCommands.js +47 -0
  246. package/dist/cli/quickstartCommands.js.map +1 -0
  247. package/dist/cli/runCommand.d.ts +39 -0
  248. package/dist/cli/runCommand.js +113 -0
  249. package/dist/cli/runCommand.js.map +1 -0
  250. package/dist/cli/scoreCommands.d.ts +1 -0
  251. package/dist/cli/scoreCommands.js +112 -0
  252. package/dist/cli/scoreCommands.js.map +1 -0
  253. package/dist/cli/shieldCommands.d.ts +30 -0
  254. package/dist/cli/shieldCommands.js +212 -0
  255. package/dist/cli/shieldCommands.js.map +1 -0
  256. package/dist/cli/targetCommands.d.ts +552 -0
  257. package/dist/cli/targetCommands.js +3173 -0
  258. package/dist/cli/targetCommands.js.map +1 -0
  259. package/dist/cli/tuiCommands.d.ts +7 -0
  260. package/dist/cli/tuiCommands.js +33 -0
  261. package/dist/cli/tuiCommands.js.map +1 -0
  262. package/dist/cli/vibeCommands.d.ts +64 -0
  263. package/dist/cli/vibeCommands.js +221 -0
  264. package/dist/cli/vibeCommands.js.map +1 -0
  265. package/dist/codegraph/CodeIntelligence.d.ts +147 -0
  266. package/dist/codegraph/CodeIntelligence.js +681 -0
  267. package/dist/codegraph/CodeIntelligence.js.map +1 -0
  268. package/dist/config/profiles.d.ts +64 -0
  269. package/dist/config/profiles.js +223 -0
  270. package/dist/config/profiles.js.map +1 -0
  271. package/dist/context/AntiPatternRegistry.d.ts +38 -0
  272. package/dist/context/AntiPatternRegistry.js +203 -0
  273. package/dist/context/AntiPatternRegistry.js.map +1 -0
  274. package/dist/context/CavemanCompressor.d.ts +20 -0
  275. package/dist/context/CavemanCompressor.js +14 -0
  276. package/dist/context/CavemanCompressor.js.map +1 -0
  277. package/dist/context/ContextBudget.d.ts +128 -0
  278. package/dist/context/ContextBudget.js +423 -0
  279. package/dist/context/ContextBudget.js.map +1 -0
  280. package/dist/context/ContextBuilder.d.ts +71 -0
  281. package/dist/context/ContextBuilder.js +372 -0
  282. package/dist/context/ContextBuilder.js.map +1 -0
  283. package/dist/context/ContextCompiler.d.ts +34 -0
  284. package/dist/context/ContextCompiler.js +120 -0
  285. package/dist/context/ContextCompiler.js.map +1 -0
  286. package/dist/context/ProjectAnatomy.d.ts +18 -0
  287. package/dist/context/ProjectAnatomy.js +287 -0
  288. package/dist/context/ProjectAnatomy.js.map +1 -0
  289. package/dist/context/SessionStartSequence.d.ts +54 -0
  290. package/dist/context/SessionStartSequence.js +162 -0
  291. package/dist/context/SessionStartSequence.js.map +1 -0
  292. package/dist/core/ExternalCommand.d.ts +9 -0
  293. package/dist/core/ExternalCommand.js +70 -0
  294. package/dist/core/ExternalCommand.js.map +1 -0
  295. package/dist/core/GbrainRuntime.d.ts +25 -0
  296. package/dist/core/GbrainRuntime.js +270 -0
  297. package/dist/core/GbrainRuntime.js.map +1 -0
  298. package/dist/core/container.d.ts +14 -0
  299. package/dist/core/container.js +35 -0
  300. package/dist/core/container.js.map +1 -0
  301. package/dist/core/eventBus.d.ts +60 -0
  302. package/dist/core/eventBus.js +157 -0
  303. package/dist/core/eventBus.js.map +1 -0
  304. package/dist/core/logger.d.ts +5 -0
  305. package/dist/core/logger.js +51 -0
  306. package/dist/core/logger.js.map +1 -0
  307. package/dist/cortex/GovernanceMetrics.d.ts +66 -0
  308. package/dist/cortex/GovernanceMetrics.js +230 -0
  309. package/dist/cortex/GovernanceMetrics.js.map +1 -0
  310. package/dist/cortex/InstinctExtractor.d.ts +61 -0
  311. package/dist/cortex/InstinctExtractor.js +184 -0
  312. package/dist/cortex/InstinctExtractor.js.map +1 -0
  313. package/dist/cortex/InstinctStore.d.ts +54 -0
  314. package/dist/cortex/InstinctStore.js +266 -0
  315. package/dist/cortex/InstinctStore.js.map +1 -0
  316. package/dist/cortex/ReflexionEngine.d.ts +34 -0
  317. package/dist/cortex/ReflexionEngine.js +157 -0
  318. package/dist/cortex/ReflexionEngine.js.map +1 -0
  319. package/dist/cortex/SessionInjector.d.ts +44 -0
  320. package/dist/cortex/SessionInjector.js +127 -0
  321. package/dist/cortex/SessionInjector.js.map +1 -0
  322. package/dist/cortex/adapters/ClaudeAdapter.d.ts +17 -0
  323. package/dist/cortex/adapters/ClaudeAdapter.js +61 -0
  324. package/dist/cortex/adapters/ClaudeAdapter.js.map +1 -0
  325. package/dist/cortex/adapters/CodexAdapter.d.ts +10 -0
  326. package/dist/cortex/adapters/CodexAdapter.js +52 -0
  327. package/dist/cortex/adapters/CodexAdapter.js.map +1 -0
  328. package/dist/cortex/adapters/CursorAdapter.d.ts +10 -0
  329. package/dist/cortex/adapters/CursorAdapter.js +46 -0
  330. package/dist/cortex/adapters/CursorAdapter.js.map +1 -0
  331. package/dist/cortex/adapters/GeminiAdapter.d.ts +11 -0
  332. package/dist/cortex/adapters/GeminiAdapter.js +48 -0
  333. package/dist/cortex/adapters/GeminiAdapter.js.map +1 -0
  334. package/dist/dashboard/DashboardServer.d.ts +86 -0
  335. package/dist/dashboard/DashboardServer.js +380 -0
  336. package/dist/dashboard/DashboardServer.js.map +1 -0
  337. package/dist/dashboard/MedicalWorkflowData.d.ts +155 -0
  338. package/dist/dashboard/MedicalWorkflowData.js +664 -0
  339. package/dist/dashboard/MedicalWorkflowData.js.map +1 -0
  340. package/dist/dashboard/MetricsAggregator.d.ts +38 -0
  341. package/dist/dashboard/MetricsAggregator.js +99 -0
  342. package/dist/dashboard/MetricsAggregator.js.map +1 -0
  343. package/dist/dashboard/index.d.ts +4 -0
  344. package/dist/dashboard/index.js +3 -0
  345. package/dist/dashboard/index.js.map +1 -0
  346. package/dist/dashboard/server.d.ts +52 -0
  347. package/dist/dashboard/server.js +84 -0
  348. package/dist/dashboard/server.js.map +1 -0
  349. package/dist/env/EnvironmentDoctor.d.ts +66 -0
  350. package/dist/env/EnvironmentDoctor.js +581 -0
  351. package/dist/env/EnvironmentDoctor.js.map +1 -0
  352. package/dist/eval/BenchmarkPublisher.d.ts +25 -0
  353. package/dist/eval/BenchmarkPublisher.js +27 -0
  354. package/dist/eval/BenchmarkPublisher.js.map +1 -0
  355. package/dist/eval/WorkflowEval.d.ts +161 -0
  356. package/dist/eval/WorkflowEval.js +377 -0
  357. package/dist/eval/WorkflowEval.js.map +1 -0
  358. package/dist/evolution/AutoDefectCreator.d.ts +43 -0
  359. package/dist/evolution/AutoDefectCreator.js +157 -0
  360. package/dist/evolution/AutoDefectCreator.js.map +1 -0
  361. package/dist/evolution/BehaviorTracker.d.ts +46 -0
  362. package/dist/evolution/BehaviorTracker.js +67 -0
  363. package/dist/evolution/BehaviorTracker.js.map +1 -0
  364. package/dist/evolution/EvolutionEngine.d.ts +102 -0
  365. package/dist/evolution/EvolutionEngine.js +326 -0
  366. package/dist/evolution/EvolutionEngine.js.map +1 -0
  367. package/dist/evolution/EvolutionEvaluator.d.ts +61 -0
  368. package/dist/evolution/EvolutionEvaluator.js +118 -0
  369. package/dist/evolution/EvolutionEvaluator.js.map +1 -0
  370. package/dist/evolution/LessonValidator.d.ts +36 -0
  371. package/dist/evolution/LessonValidator.js +132 -0
  372. package/dist/evolution/LessonValidator.js.map +1 -0
  373. package/dist/evolution/PatternExtractor.d.ts +40 -0
  374. package/dist/evolution/PatternExtractor.js +83 -0
  375. package/dist/evolution/PatternExtractor.js.map +1 -0
  376. package/dist/evolution/RuleMaturity.d.ts +39 -0
  377. package/dist/evolution/RuleMaturity.js +70 -0
  378. package/dist/evolution/RuleMaturity.js.map +1 -0
  379. package/dist/evolution/SessionLearnings.d.ts +70 -0
  380. package/dist/evolution/SessionLearnings.js +217 -0
  381. package/dist/evolution/SessionLearnings.js.map +1 -0
  382. package/dist/evolution/SkillCreator.d.ts +75 -0
  383. package/dist/evolution/SkillCreator.js +219 -0
  384. package/dist/evolution/SkillCreator.js.map +1 -0
  385. package/dist/fsm/FSMAgentBridge.d.ts +59 -0
  386. package/dist/fsm/FSMAgentBridge.js +193 -0
  387. package/dist/fsm/FSMAgentBridge.js.map +1 -0
  388. package/dist/fsm/index.d.ts +2 -0
  389. package/dist/fsm/index.js +3 -0
  390. package/dist/fsm/index.js.map +1 -0
  391. package/dist/governance/GovernanceRoi.d.ts +30 -0
  392. package/dist/governance/GovernanceRoi.js +102 -0
  393. package/dist/governance/GovernanceRoi.js.map +1 -0
  394. package/dist/governance/ProgressiveGovernance.d.ts +22 -0
  395. package/dist/governance/ProgressiveGovernance.js +159 -0
  396. package/dist/governance/ProgressiveGovernance.js.map +1 -0
  397. package/dist/guardrails/ActiveRedTeam.d.ts +46 -0
  398. package/dist/guardrails/ActiveRedTeam.js +203 -0
  399. package/dist/guardrails/ActiveRedTeam.js.map +1 -0
  400. package/dist/guardrails/DependencyAuditor.d.ts +68 -0
  401. package/dist/guardrails/DependencyAuditor.js +378 -0
  402. package/dist/guardrails/DependencyAuditor.js.map +1 -0
  403. package/dist/guardrails/DetectorEnhanced.d.ts +111 -0
  404. package/dist/guardrails/DetectorEnhanced.js +202 -0
  405. package/dist/guardrails/DetectorEnhanced.js.map +1 -0
  406. package/dist/guardrails/GateEvaluator.d.ts +18 -0
  407. package/dist/guardrails/GateEvaluator.js +129 -0
  408. package/dist/guardrails/GateEvaluator.js.map +1 -0
  409. package/dist/guardrails/Gateway.d.ts +26 -0
  410. package/dist/guardrails/Gateway.js +56 -0
  411. package/dist/guardrails/Gateway.js.map +1 -0
  412. package/dist/guardrails/OWASPDetector.d.ts +58 -0
  413. package/dist/guardrails/OWASPDetector.js +508 -0
  414. package/dist/guardrails/OWASPDetector.js.map +1 -0
  415. package/dist/guardrails/ReviewEnforcer.d.ts +52 -0
  416. package/dist/guardrails/ReviewEnforcer.js +117 -0
  417. package/dist/guardrails/ReviewEnforcer.js.map +1 -0
  418. package/dist/guardrails/advancedDetectors.d.ts +38 -0
  419. package/dist/guardrails/advancedDetectors.js +188 -0
  420. package/dist/guardrails/advancedDetectors.js.map +1 -0
  421. package/dist/guardrails/detectors.d.ts +34 -0
  422. package/dist/guardrails/detectors.js +332 -0
  423. package/dist/guardrails/detectors.js.map +1 -0
  424. package/dist/guardrails/roles.d.ts +4 -0
  425. package/dist/guardrails/roles.js +54 -0
  426. package/dist/guardrails/roles.js.map +1 -0
  427. package/dist/hooks/BugPatternDetector.d.ts +36 -0
  428. package/dist/hooks/BugPatternDetector.js +207 -0
  429. package/dist/hooks/BugPatternDetector.js.map +1 -0
  430. package/dist/hooks/HookDeployer.d.ts +44 -0
  431. package/dist/hooks/HookDeployer.js +144 -0
  432. package/dist/hooks/HookDeployer.js.map +1 -0
  433. package/dist/hooks/HookGeneratorEnhanced.d.ts +67 -0
  434. package/dist/hooks/HookGeneratorEnhanced.js +641 -0
  435. package/dist/hooks/HookGeneratorEnhanced.js.map +1 -0
  436. package/dist/hooks/WorkflowHooksManager.d.ts +30 -0
  437. package/dist/hooks/WorkflowHooksManager.js +160 -0
  438. package/dist/hooks/WorkflowHooksManager.js.map +1 -0
  439. package/dist/hooks/index.d.ts +6 -0
  440. package/dist/hooks/index.js +5 -0
  441. package/dist/hooks/index.js.map +1 -0
  442. package/dist/i18n/Language.d.ts +9 -0
  443. package/dist/i18n/Language.js +38 -0
  444. package/dist/i18n/Language.js.map +1 -0
  445. package/dist/index.d.ts +101 -0
  446. package/dist/index.js +104 -0
  447. package/dist/index.js.map +1 -0
  448. package/dist/knowledge/CerebrumManager.d.ts +25 -0
  449. package/dist/knowledge/CerebrumManager.js +127 -0
  450. package/dist/knowledge/CerebrumManager.js.map +1 -0
  451. package/dist/knowledge/GraphifyKnowledgeBase.d.ts +38 -0
  452. package/dist/knowledge/GraphifyKnowledgeBase.js +409 -0
  453. package/dist/knowledge/GraphifyKnowledgeBase.js.map +1 -0
  454. package/dist/knowledge/KnowledgeBase.d.ts +51 -0
  455. package/dist/knowledge/KnowledgeBase.js +182 -0
  456. package/dist/knowledge/KnowledgeBase.js.map +1 -0
  457. package/dist/knowledge/SQLiteKnowledgeBase.d.ts +29 -0
  458. package/dist/knowledge/SQLiteKnowledgeBase.js +203 -0
  459. package/dist/knowledge/SQLiteKnowledgeBase.js.map +1 -0
  460. package/dist/knowledge/TfidfIndex.d.ts +50 -0
  461. package/dist/knowledge/TfidfIndex.js +177 -0
  462. package/dist/knowledge/TfidfIndex.js.map +1 -0
  463. package/dist/knowledge/UbiquitousLanguageManager.d.ts +49 -0
  464. package/dist/knowledge/UbiquitousLanguageManager.js +133 -0
  465. package/dist/knowledge/UbiquitousLanguageManager.js.map +1 -0
  466. package/dist/memory/MemoryBrain.d.ts +146 -0
  467. package/dist/memory/MemoryBrain.js +679 -0
  468. package/dist/memory/MemoryBrain.js.map +1 -0
  469. package/dist/memory/MemoryFabric.d.ts +130 -0
  470. package/dist/memory/MemoryFabric.js +317 -0
  471. package/dist/memory/MemoryFabric.js.map +1 -0
  472. package/dist/memory/MemoryIntelligence.d.ts +42 -0
  473. package/dist/memory/MemoryIntelligence.js +215 -0
  474. package/dist/memory/MemoryIntelligence.js.map +1 -0
  475. package/dist/memory/MemoryLearning.d.ts +62 -0
  476. package/dist/memory/MemoryLearning.js +209 -0
  477. package/dist/memory/MemoryLearning.js.map +1 -0
  478. package/dist/memory/MemoryProviders.d.ts +165 -0
  479. package/dist/memory/MemoryProviders.js +940 -0
  480. package/dist/memory/MemoryProviders.js.map +1 -0
  481. package/dist/memory/MemoryReview.d.ts +65 -0
  482. package/dist/memory/MemoryReview.js +260 -0
  483. package/dist/memory/MemoryReview.js.map +1 -0
  484. package/dist/memory/index.d.ts +6 -0
  485. package/dist/memory/index.js +7 -0
  486. package/dist/memory/index.js.map +1 -0
  487. package/dist/orchestration/EffectsWiring.d.ts +8 -0
  488. package/dist/orchestration/EffectsWiring.js +87 -0
  489. package/dist/orchestration/EffectsWiring.js.map +1 -0
  490. package/dist/orchestrator/OrchestratorDaemon.d.ts +44 -0
  491. package/dist/orchestrator/OrchestratorDaemon.js +150 -0
  492. package/dist/orchestrator/OrchestratorDaemon.js.map +1 -0
  493. package/dist/orchestrator/PolicyLoader.d.ts +80 -0
  494. package/dist/orchestrator/PolicyLoader.js +229 -0
  495. package/dist/orchestrator/PolicyLoader.js.map +1 -0
  496. package/dist/orchestrator/ReconciliationLoop.d.ts +71 -0
  497. package/dist/orchestrator/ReconciliationLoop.js +266 -0
  498. package/dist/orchestrator/ReconciliationLoop.js.map +1 -0
  499. package/dist/orchestrator/TrackerAdapter.d.ts +60 -0
  500. package/dist/orchestrator/TrackerAdapter.js +147 -0
  501. package/dist/orchestrator/TrackerAdapter.js.map +1 -0
  502. package/dist/orchestrator/WorkspaceManager.d.ts +66 -0
  503. package/dist/orchestrator/WorkspaceManager.js +257 -0
  504. package/dist/orchestrator/WorkspaceManager.js.map +1 -0
  505. package/dist/output/BrandThemeLoader.d.ts +54 -0
  506. package/dist/output/BrandThemeLoader.js +340 -0
  507. package/dist/output/BrandThemeLoader.js.map +1 -0
  508. package/dist/output/GovernanceDashboard.d.ts +59 -0
  509. package/dist/output/GovernanceDashboard.js +281 -0
  510. package/dist/output/GovernanceDashboard.js.map +1 -0
  511. package/dist/output/HTMLArtifactLayer.d.ts +97 -0
  512. package/dist/output/HTMLArtifactLayer.js +576 -0
  513. package/dist/output/HTMLArtifactLayer.js.map +1 -0
  514. package/dist/output/HTMLDocumentRenderer.d.ts +83 -0
  515. package/dist/output/HTMLDocumentRenderer.js +718 -0
  516. package/dist/output/HTMLDocumentRenderer.js.map +1 -0
  517. package/dist/output/UIPrototypeRenderer.d.ts +61 -0
  518. package/dist/output/UIPrototypeRenderer.js +500 -0
  519. package/dist/output/UIPrototypeRenderer.js.map +1 -0
  520. package/dist/output/index.d.ts +10 -0
  521. package/dist/output/index.js +8 -0
  522. package/dist/output/index.js.map +1 -0
  523. package/dist/prompts/PhasePromptRegistry.d.ts +53 -0
  524. package/dist/prompts/PhasePromptRegistry.js +517 -0
  525. package/dist/prompts/PhasePromptRegistry.js.map +1 -0
  526. package/dist/prompts/PromptOptimizer.d.ts +42 -0
  527. package/dist/prompts/PromptOptimizer.js +309 -0
  528. package/dist/prompts/PromptOptimizer.js.map +1 -0
  529. package/dist/prompts/VibeTemplateGallery.d.ts +25 -0
  530. package/dist/prompts/VibeTemplateGallery.js +295 -0
  531. package/dist/prompts/VibeTemplateGallery.js.map +1 -0
  532. package/dist/qa/BrowserDaemon.d.ts +23 -0
  533. package/dist/qa/BrowserDaemon.js +79 -0
  534. package/dist/qa/BrowserDaemon.js.map +1 -0
  535. package/dist/qa/E2ETestOrchestrator.d.ts +14 -0
  536. package/dist/qa/E2ETestOrchestrator.js +19 -0
  537. package/dist/qa/E2ETestOrchestrator.js.map +1 -0
  538. package/dist/review/CrossModelReviewer.d.ts +35 -0
  539. package/dist/review/CrossModelReviewer.js +75 -0
  540. package/dist/review/CrossModelReviewer.js.map +1 -0
  541. package/dist/review/ReviewAggregator.d.ts +13 -0
  542. package/dist/review/ReviewAggregator.js +28 -0
  543. package/dist/review/ReviewAggregator.js.map +1 -0
  544. package/dist/review/reviewCommands.d.ts +15 -0
  545. package/dist/review/reviewCommands.js +24 -0
  546. package/dist/review/reviewCommands.js.map +1 -0
  547. package/dist/routing/LocalModelProvider.d.ts +11 -0
  548. package/dist/routing/LocalModelProvider.js +21 -0
  549. package/dist/routing/LocalModelProvider.js.map +1 -0
  550. package/dist/routing/ModelRouter.d.ts +42 -0
  551. package/dist/routing/ModelRouter.js +94 -0
  552. package/dist/routing/ModelRouter.js.map +1 -0
  553. package/dist/routing/PromptCachePolicy.d.ts +37 -0
  554. package/dist/routing/PromptCachePolicy.js +97 -0
  555. package/dist/routing/PromptCachePolicy.js.map +1 -0
  556. package/dist/runtime/AiOsRuntime.d.ts +485 -0
  557. package/dist/runtime/AiOsRuntime.js +1846 -0
  558. package/dist/runtime/AiOsRuntime.js.map +1 -0
  559. package/dist/runtime/CostAnalyzer.d.ts +53 -0
  560. package/dist/runtime/CostAnalyzer.js +160 -0
  561. package/dist/runtime/CostAnalyzer.js.map +1 -0
  562. package/dist/runtime/CostOptimizer.d.ts +11 -0
  563. package/dist/runtime/CostOptimizer.js +21 -0
  564. package/dist/runtime/CostOptimizer.js.map +1 -0
  565. package/dist/runtime/ExecutionLedger.d.ts +46 -0
  566. package/dist/runtime/ExecutionLedger.js +71 -0
  567. package/dist/runtime/ExecutionLedger.js.map +1 -0
  568. package/dist/runtime/FinalReportGuard.d.ts +16 -0
  569. package/dist/runtime/FinalReportGuard.js +14 -0
  570. package/dist/runtime/FinalReportGuard.js.map +1 -0
  571. package/dist/runtime/ModelUsageLedger.d.ts +101 -0
  572. package/dist/runtime/ModelUsageLedger.js +296 -0
  573. package/dist/runtime/ModelUsageLedger.js.map +1 -0
  574. package/dist/runtime/RuntimeDoctor.d.ts +23 -0
  575. package/dist/runtime/RuntimeDoctor.js +151 -0
  576. package/dist/runtime/RuntimeDoctor.js.map +1 -0
  577. package/dist/runtime/RuntimeEvidenceLedger.d.ts +50 -0
  578. package/dist/runtime/RuntimeEvidenceLedger.js +89 -0
  579. package/dist/runtime/RuntimeEvidenceLedger.js.map +1 -0
  580. package/dist/runtime/SessionLedger.d.ts +53 -0
  581. package/dist/runtime/SessionLedger.js +104 -0
  582. package/dist/runtime/SessionLedger.js.map +1 -0
  583. package/dist/runtime/index.d.ts +7 -0
  584. package/dist/runtime/index.js +8 -0
  585. package/dist/runtime/index.js.map +1 -0
  586. package/dist/setup/SetupVerification.d.ts +42 -0
  587. package/dist/setup/SetupVerification.js +180 -0
  588. package/dist/setup/SetupVerification.js.map +1 -0
  589. package/dist/setup/SetupWizard.d.ts +45 -0
  590. package/dist/setup/SetupWizard.js +216 -0
  591. package/dist/setup/SetupWizard.js.map +1 -0
  592. package/dist/shield/PolicyCompiler.d.ts +70 -0
  593. package/dist/shield/PolicyCompiler.js +540 -0
  594. package/dist/shield/PolicyCompiler.js.map +1 -0
  595. package/dist/shield/ProtectedPaths.d.ts +39 -0
  596. package/dist/shield/ProtectedPaths.js +179 -0
  597. package/dist/shield/ProtectedPaths.js.map +1 -0
  598. package/dist/shield/ShieldProtocol.d.ts +50 -0
  599. package/dist/shield/ShieldProtocol.js +103 -0
  600. package/dist/shield/ShieldProtocol.js.map +1 -0
  601. package/dist/skills/ExternalSkills.d.ts +3 -0
  602. package/dist/skills/ExternalSkills.js +27 -0
  603. package/dist/skills/ExternalSkills.js.map +1 -0
  604. package/dist/skills/GrillingSessionSkill.d.ts +65 -0
  605. package/dist/skills/GrillingSessionSkill.js +113 -0
  606. package/dist/skills/GrillingSessionSkill.js.map +1 -0
  607. package/dist/skills/GrillingTemplates.d.ts +7 -0
  608. package/dist/skills/GrillingTemplates.js +38 -0
  609. package/dist/skills/GrillingTemplates.js.map +1 -0
  610. package/dist/skills/RoleSkills.d.ts +20 -0
  611. package/dist/skills/RoleSkills.js +154 -0
  612. package/dist/skills/RoleSkills.js.map +1 -0
  613. package/dist/skills/SkillCatalog.d.ts +13 -0
  614. package/dist/skills/SkillCatalog.js +184 -0
  615. package/dist/skills/SkillCatalog.js.map +1 -0
  616. package/dist/skills/SkillDiscovery.d.ts +84 -0
  617. package/dist/skills/SkillDiscovery.js +402 -0
  618. package/dist/skills/SkillDiscovery.js.map +1 -0
  619. package/dist/skills/SkillDoctor.d.ts +37 -0
  620. package/dist/skills/SkillDoctor.js +267 -0
  621. package/dist/skills/SkillDoctor.js.map +1 -0
  622. package/dist/skills/SkillExecutor.d.ts +38 -0
  623. package/dist/skills/SkillExecutor.js +237 -0
  624. package/dist/skills/SkillExecutor.js.map +1 -0
  625. package/dist/skills/SkillFrontmatter.d.ts +28 -0
  626. package/dist/skills/SkillFrontmatter.js +152 -0
  627. package/dist/skills/SkillFrontmatter.js.map +1 -0
  628. package/dist/skills/SkillInstaller.d.ts +40 -0
  629. package/dist/skills/SkillInstaller.js +117 -0
  630. package/dist/skills/SkillInstaller.js.map +1 -0
  631. package/dist/skills/SkillMdStandard.d.ts +33 -0
  632. package/dist/skills/SkillMdStandard.js +88 -0
  633. package/dist/skills/SkillMdStandard.js.map +1 -0
  634. package/dist/skills/SkillRadar.d.ts +83 -0
  635. package/dist/skills/SkillRadar.js +404 -0
  636. package/dist/skills/SkillRadar.js.map +1 -0
  637. package/dist/skills/SkillRegistry.d.ts +112 -0
  638. package/dist/skills/SkillRegistry.js +161 -0
  639. package/dist/skills/SkillRegistry.js.map +1 -0
  640. package/dist/skills/SkillRepository.d.ts +71 -0
  641. package/dist/skills/SkillRepository.js +435 -0
  642. package/dist/skills/SkillRepository.js.map +1 -0
  643. package/dist/skills/TriggerEngine.d.ts +43 -0
  644. package/dist/skills/TriggerEngine.js +142 -0
  645. package/dist/skills/TriggerEngine.js.map +1 -0
  646. package/dist/skills/coreSkills.d.ts +6 -0
  647. package/dist/skills/coreSkills.js +41 -0
  648. package/dist/skills/coreSkills.js.map +1 -0
  649. package/dist/skills/index.d.ts +10 -0
  650. package/dist/skills/index.js +12 -0
  651. package/dist/skills/index.js.map +1 -0
  652. package/dist/skills/interop/GStackInterop.d.ts +15 -0
  653. package/dist/skills/interop/GStackInterop.js +34 -0
  654. package/dist/skills/interop/GStackInterop.js.map +1 -0
  655. package/dist/skills/interop/OMCInterop.d.ts +15 -0
  656. package/dist/skills/interop/OMCInterop.js +34 -0
  657. package/dist/skills/interop/OMCInterop.js.map +1 -0
  658. package/dist/skills/routing/SkillGate.d.ts +12 -0
  659. package/dist/skills/routing/SkillGate.js +117 -0
  660. package/dist/skills/routing/SkillGate.js.map +1 -0
  661. package/dist/skills/routing/SkillPlanner.d.ts +8 -0
  662. package/dist/skills/routing/SkillPlanner.js +179 -0
  663. package/dist/skills/routing/SkillPlanner.js.map +1 -0
  664. package/dist/skills/routing/SkillPolicy.d.ts +6 -0
  665. package/dist/skills/routing/SkillPolicy.js +336 -0
  666. package/dist/skills/routing/SkillPolicy.js.map +1 -0
  667. package/dist/skills/routing/SkillRoutingTypes.d.ts +89 -0
  668. package/dist/skills/routing/SkillRoutingTypes.js +2 -0
  669. package/dist/skills/routing/SkillRoutingTypes.js.map +1 -0
  670. package/dist/skills/routing/TaskIntentClassifier.d.ts +6 -0
  671. package/dist/skills/routing/TaskIntentClassifier.js +79 -0
  672. package/dist/skills/routing/TaskIntentClassifier.js.map +1 -0
  673. package/dist/skills/routing/index.d.ts +5 -0
  674. package/dist/skills/routing/index.js +6 -0
  675. package/dist/skills/routing/index.js.map +1 -0
  676. package/dist/tasks/IssueTriageFSM.d.ts +26 -0
  677. package/dist/tasks/IssueTriageFSM.js +107 -0
  678. package/dist/tasks/IssueTriageFSM.js.map +1 -0
  679. package/dist/tasks/TaskEngine.d.ts +97 -0
  680. package/dist/tasks/TaskEngine.js +289 -0
  681. package/dist/tasks/TaskEngine.js.map +1 -0
  682. package/dist/testing/DiffTestSelector.d.ts +22 -0
  683. package/dist/testing/DiffTestSelector.js +114 -0
  684. package/dist/testing/DiffTestSelector.js.map +1 -0
  685. package/dist/testing/index.d.ts +1 -0
  686. package/dist/testing/index.js +3 -0
  687. package/dist/testing/index.js.map +1 -0
  688. package/dist/tools/CommandOutputCompressor.d.ts +28 -0
  689. package/dist/tools/CommandOutputCompressor.js +242 -0
  690. package/dist/tools/CommandOutputCompressor.js.map +1 -0
  691. package/dist/tools/CommandRunLedger.d.ts +77 -0
  692. package/dist/tools/CommandRunLedger.js +111 -0
  693. package/dist/tools/CommandRunLedger.js.map +1 -0
  694. package/dist/tools/RtkRuntime.d.ts +9 -0
  695. package/dist/tools/RtkRuntime.js +43 -0
  696. package/dist/tools/RtkRuntime.js.map +1 -0
  697. package/dist/tools/SafeCommandRunner.d.ts +16 -0
  698. package/dist/tools/SafeCommandRunner.js +83 -0
  699. package/dist/tools/SafeCommandRunner.js.map +1 -0
  700. package/dist/tools/ToolCapabilityRegistry.d.ts +51 -0
  701. package/dist/tools/ToolCapabilityRegistry.js +295 -0
  702. package/dist/tools/ToolCapabilityRegistry.js.map +1 -0
  703. package/dist/tools/ToolEvidenceGate.d.ts +39 -0
  704. package/dist/tools/ToolEvidenceGate.js +117 -0
  705. package/dist/tools/ToolEvidenceGate.js.map +1 -0
  706. package/dist/tools/ToolEvidenceStore.d.ts +58 -0
  707. package/dist/tools/ToolEvidenceStore.js +129 -0
  708. package/dist/tools/ToolEvidenceStore.js.map +1 -0
  709. package/dist/tools/ToolOrchestrator.d.ts +67 -0
  710. package/dist/tools/ToolOrchestrator.js +252 -0
  711. package/dist/tools/ToolOrchestrator.js.map +1 -0
  712. package/dist/tools/ToolPolicy.d.ts +33 -0
  713. package/dist/tools/ToolPolicy.js +172 -0
  714. package/dist/tools/ToolPolicy.js.map +1 -0
  715. package/dist/tools/index.d.ts +7 -0
  716. package/dist/tools/index.js +8 -0
  717. package/dist/tools/index.js.map +1 -0
  718. package/dist/tui/TuiDashboard.d.ts +3 -0
  719. package/dist/tui/TuiDashboard.js +120 -0
  720. package/dist/tui/TuiDashboard.js.map +1 -0
  721. package/dist/version.d.ts +3 -0
  722. package/dist/version.js +15 -0
  723. package/dist/version.js.map +1 -0
  724. package/dist/workflow/AdaptiveWorkflowRouter.d.ts +38 -0
  725. package/dist/workflow/AdaptiveWorkflowRouter.js +214 -0
  726. package/dist/workflow/AdaptiveWorkflowRouter.js.map +1 -0
  727. package/dist/workflow/CommitDiscipline.d.ts +68 -0
  728. package/dist/workflow/CommitDiscipline.js +328 -0
  729. package/dist/workflow/CommitDiscipline.js.map +1 -0
  730. package/dist/workflow/ContextGovernance.d.ts +51 -0
  731. package/dist/workflow/ContextGovernance.js +233 -0
  732. package/dist/workflow/ContextGovernance.js.map +1 -0
  733. package/dist/workflow/CrossRepoOrchestrator.d.ts +92 -0
  734. package/dist/workflow/CrossRepoOrchestrator.js +408 -0
  735. package/dist/workflow/CrossRepoOrchestrator.js.map +1 -0
  736. package/dist/workflow/DiagnosticLoop.d.ts +40 -0
  737. package/dist/workflow/DiagnosticLoop.js +105 -0
  738. package/dist/workflow/DiagnosticLoop.js.map +1 -0
  739. package/dist/workflow/EngineeringStandards.d.ts +212 -0
  740. package/dist/workflow/EngineeringStandards.js +1113 -0
  741. package/dist/workflow/EngineeringStandards.js.map +1 -0
  742. package/dist/workflow/EvidenceStore.d.ts +20 -0
  743. package/dist/workflow/EvidenceStore.js +48 -0
  744. package/dist/workflow/EvidenceStore.js.map +1 -0
  745. package/dist/workflow/EvolutionShadowPromoter.d.ts +46 -0
  746. package/dist/workflow/EvolutionShadowPromoter.js +73 -0
  747. package/dist/workflow/EvolutionShadowPromoter.js.map +1 -0
  748. package/dist/workflow/GateCatalog.d.ts +63 -0
  749. package/dist/workflow/GateCatalog.js +268 -0
  750. package/dist/workflow/GateCatalog.js.map +1 -0
  751. package/dist/workflow/GovernanceLock.d.ts +35 -0
  752. package/dist/workflow/GovernanceLock.js +58 -0
  753. package/dist/workflow/GovernanceLock.js.map +1 -0
  754. package/dist/workflow/GovernanceRoi.d.ts +52 -0
  755. package/dist/workflow/GovernanceRoi.js +204 -0
  756. package/dist/workflow/GovernanceRoi.js.map +1 -0
  757. package/dist/workflow/GovernanceTemplatePacks.d.ts +24 -0
  758. package/dist/workflow/GovernanceTemplatePacks.js +2134 -0
  759. package/dist/workflow/GovernanceTemplatePacks.js.map +1 -0
  760. package/dist/workflow/GovernanceTemplates.d.ts +19 -0
  761. package/dist/workflow/GovernanceTemplates.js +1291 -0
  762. package/dist/workflow/GovernanceTemplates.js.map +1 -0
  763. package/dist/workflow/McpGovernance.d.ts +63 -0
  764. package/dist/workflow/McpGovernance.js +198 -0
  765. package/dist/workflow/McpGovernance.js.map +1 -0
  766. package/dist/workflow/OutOfScopeStore.d.ts +37 -0
  767. package/dist/workflow/OutOfScopeStore.js +164 -0
  768. package/dist/workflow/OutOfScopeStore.js.map +1 -0
  769. package/dist/workflow/PhaseMarkerTracker.d.ts +63 -0
  770. package/dist/workflow/PhaseMarkerTracker.js +291 -0
  771. package/dist/workflow/PhaseMarkerTracker.js.map +1 -0
  772. package/dist/workflow/ResourceGovernance.d.ts +120 -0
  773. package/dist/workflow/ResourceGovernance.js +531 -0
  774. package/dist/workflow/ResourceGovernance.js.map +1 -0
  775. package/dist/workflow/ReviewAnalyzer.d.ts +80 -0
  776. package/dist/workflow/ReviewAnalyzer.js +438 -0
  777. package/dist/workflow/ReviewAnalyzer.js.map +1 -0
  778. package/dist/workflow/ReviewStore.d.ts +36 -0
  779. package/dist/workflow/ReviewStore.js +42 -0
  780. package/dist/workflow/ReviewStore.js.map +1 -0
  781. package/dist/workflow/SecurityAudit.d.ts +27 -0
  782. package/dist/workflow/SecurityAudit.js +294 -0
  783. package/dist/workflow/SecurityAudit.js.map +1 -0
  784. package/dist/workflow/SessionCoordinator.d.ts +103 -0
  785. package/dist/workflow/SessionCoordinator.js +401 -0
  786. package/dist/workflow/SessionCoordinator.js.map +1 -0
  787. package/dist/workflow/SessionPreamble.d.ts +19 -0
  788. package/dist/workflow/SessionPreamble.js +130 -0
  789. package/dist/workflow/SessionPreamble.js.map +1 -0
  790. package/dist/workflow/SessionStateTracker.d.ts +74 -0
  791. package/dist/workflow/SessionStateTracker.js +270 -0
  792. package/dist/workflow/SessionStateTracker.js.map +1 -0
  793. package/dist/workflow/ShipPipeline.d.ts +30 -0
  794. package/dist/workflow/ShipPipeline.js +366 -0
  795. package/dist/workflow/ShipPipeline.js.map +1 -0
  796. package/dist/workflow/TaskArtifactScaffolder.d.ts +69 -0
  797. package/dist/workflow/TaskArtifactScaffolder.js +333 -0
  798. package/dist/workflow/TaskArtifactScaffolder.js.map +1 -0
  799. package/dist/workflow/TaskDependencyGraph.d.ts +73 -0
  800. package/dist/workflow/TaskDependencyGraph.js +245 -0
  801. package/dist/workflow/TaskDependencyGraph.js.map +1 -0
  802. package/dist/workflow/TaskLevelDetector.d.ts +41 -0
  803. package/dist/workflow/TaskLevelDetector.js +219 -0
  804. package/dist/workflow/TaskLevelDetector.js.map +1 -0
  805. package/dist/workflow/TaskMetricsStore.d.ts +49 -0
  806. package/dist/workflow/TaskMetricsStore.js +149 -0
  807. package/dist/workflow/TaskMetricsStore.js.map +1 -0
  808. package/dist/workflow/TaskScoreEngine.d.ts +42 -0
  809. package/dist/workflow/TaskScoreEngine.js +181 -0
  810. package/dist/workflow/TaskScoreEngine.js.map +1 -0
  811. package/dist/workflow/TddLoop.d.ts +49 -0
  812. package/dist/workflow/TddLoop.js +78 -0
  813. package/dist/workflow/TddLoop.js.map +1 -0
  814. package/dist/workflow/UpgradeManager.d.ts +178 -0
  815. package/dist/workflow/UpgradeManager.js +665 -0
  816. package/dist/workflow/UpgradeManager.js.map +1 -0
  817. package/dist/workflow/VerificationCommands.d.ts +36 -0
  818. package/dist/workflow/VerificationCommands.js +123 -0
  819. package/dist/workflow/VerificationCommands.js.map +1 -0
  820. package/dist/workflow/VerificationProfile.d.ts +67 -0
  821. package/dist/workflow/VerificationProfile.js +241 -0
  822. package/dist/workflow/VerificationProfile.js.map +1 -0
  823. package/dist/workflow/VerificationSchema.d.ts +46 -0
  824. package/dist/workflow/VerificationSchema.js +97 -0
  825. package/dist/workflow/VerificationSchema.js.map +1 -0
  826. package/dist/workflow/WorkflowArtifactWriter.d.ts +113 -0
  827. package/dist/workflow/WorkflowArtifactWriter.js +242 -0
  828. package/dist/workflow/WorkflowArtifactWriter.js.map +1 -0
  829. package/dist/workflow/WorkflowEngine.d.ts +83 -0
  830. package/dist/workflow/WorkflowEngine.js +183 -0
  831. package/dist/workflow/WorkflowEngine.js.map +1 -0
  832. package/dist/workflow/WorkflowGuidance.d.ts +30 -0
  833. package/dist/workflow/WorkflowGuidance.js +204 -0
  834. package/dist/workflow/WorkflowGuidance.js.map +1 -0
  835. package/dist/workflow/WorkflowOpenTasks.d.ts +16 -0
  836. package/dist/workflow/WorkflowOpenTasks.js +37 -0
  837. package/dist/workflow/WorkflowOpenTasks.js.map +1 -0
  838. package/dist/workflow/WorkflowOrchestrator.d.ts +59 -0
  839. package/dist/workflow/WorkflowOrchestrator.js +326 -0
  840. package/dist/workflow/WorkflowOrchestrator.js.map +1 -0
  841. package/dist/workflow/WorkflowTemplates.d.ts +38 -0
  842. package/dist/workflow/WorkflowTemplates.js +371 -0
  843. package/dist/workflow/WorkflowTemplates.js.map +1 -0
  844. package/dist/workflow/WorkspaceLifecycle.d.ts +71 -0
  845. package/dist/workflow/WorkspaceLifecycle.js +401 -0
  846. package/dist/workflow/WorkspaceLifecycle.js.map +1 -0
  847. package/dist/workflow/WorkspacePolicy.d.ts +46 -0
  848. package/dist/workflow/WorkspacePolicy.js +141 -0
  849. package/dist/workflow/WorkspacePolicy.js.map +1 -0
  850. package/dist/workflow/WorkspaceSafety.d.ts +9 -0
  851. package/dist/workflow/WorkspaceSafety.js +49 -0
  852. package/dist/workflow/WorkspaceSafety.js.map +1 -0
  853. package/dist/workflow/WorkspaceTopology.d.ts +58 -0
  854. package/dist/workflow/WorkspaceTopology.js +176 -0
  855. package/dist/workflow/WorkspaceTopology.js.map +1 -0
  856. package/dist/workflow/autofix/AutoFixEngine.d.ts +37 -0
  857. package/dist/workflow/autofix/AutoFixEngine.js +169 -0
  858. package/dist/workflow/autofix/AutoFixEngine.js.map +1 -0
  859. package/dist/workflow/autonomous/AutonomousDevLoop.d.ts +88 -0
  860. package/dist/workflow/autonomous/AutonomousDevLoop.js +381 -0
  861. package/dist/workflow/autonomous/AutonomousDevLoop.js.map +1 -0
  862. package/dist/workflow/autonomous/BackgroundHunter.d.ts +74 -0
  863. package/dist/workflow/autonomous/BackgroundHunter.js +220 -0
  864. package/dist/workflow/autonomous/BackgroundHunter.js.map +1 -0
  865. package/dist/workflow/autonomous/WorklogManager.d.ts +50 -0
  866. package/dist/workflow/autonomous/WorklogManager.js +264 -0
  867. package/dist/workflow/autonomous/WorklogManager.js.map +1 -0
  868. package/dist/workflow/autonomous/index.d.ts +3 -0
  869. package/dist/workflow/autonomous/index.js +5 -0
  870. package/dist/workflow/autonomous/index.js.map +1 -0
  871. package/dist/workflow/cognitive/AmbiguityScorer.d.ts +17 -0
  872. package/dist/workflow/cognitive/AmbiguityScorer.js +107 -0
  873. package/dist/workflow/cognitive/AmbiguityScorer.js.map +1 -0
  874. package/dist/workflow/cognitive/ConsensusPlanner.d.ts +26 -0
  875. package/dist/workflow/cognitive/ConsensusPlanner.js +141 -0
  876. package/dist/workflow/cognitive/ConsensusPlanner.js.map +1 -0
  877. package/dist/workflow/cognitive/SocraticQuestioner.d.ts +33 -0
  878. package/dist/workflow/cognitive/SocraticQuestioner.js +276 -0
  879. package/dist/workflow/cognitive/SocraticQuestioner.js.map +1 -0
  880. package/dist/workflow/evolution/LessonExtractor.d.ts +90 -0
  881. package/dist/workflow/evolution/LessonExtractor.js +317 -0
  882. package/dist/workflow/evolution/LessonExtractor.js.map +1 -0
  883. package/dist/workflow/evolution/SelfImproveEngine.d.ts +156 -0
  884. package/dist/workflow/evolution/SelfImproveEngine.js +361 -0
  885. package/dist/workflow/evolution/SelfImproveEngine.js.map +1 -0
  886. package/dist/workflow/execution/RalphEngine.d.ts +54 -0
  887. package/dist/workflow/execution/RalphEngine.js +145 -0
  888. package/dist/workflow/execution/RalphEngine.js.map +1 -0
  889. package/dist/workflow/execution/UltraworkEngine.d.ts +43 -0
  890. package/dist/workflow/execution/UltraworkEngine.js +135 -0
  891. package/dist/workflow/execution/UltraworkEngine.js.map +1 -0
  892. package/dist/workflow/gates/EnhancedGates.d.ts +74 -0
  893. package/dist/workflow/gates/EnhancedGates.js +653 -0
  894. package/dist/workflow/gates/EnhancedGates.js.map +1 -0
  895. package/dist/workflow/gates/GateSystem.d.ts +180 -0
  896. package/dist/workflow/gates/GateSystem.js +1279 -0
  897. package/dist/workflow/gates/GateSystem.js.map +1 -0
  898. package/dist/workflow/gates/MetaGovernanceGates.d.ts +70 -0
  899. package/dist/workflow/gates/MetaGovernanceGates.js +617 -0
  900. package/dist/workflow/gates/MetaGovernanceGates.js.map +1 -0
  901. package/dist/workflow/gates/VisualGate.d.ts +41 -0
  902. package/dist/workflow/gates/VisualGate.js +174 -0
  903. package/dist/workflow/gates/VisualGate.js.map +1 -0
  904. package/dist/workflow/index.d.ts +45 -0
  905. package/dist/workflow/index.js +47 -0
  906. package/dist/workflow/index.js.map +1 -0
  907. package/dist/workflow/qa/E2ETestRunner.d.ts +102 -0
  908. package/dist/workflow/qa/E2ETestRunner.js +227 -0
  909. package/dist/workflow/qa/E2ETestRunner.js.map +1 -0
  910. package/dist/workflow/quality/HonestDelivery.d.ts +19 -0
  911. package/dist/workflow/quality/HonestDelivery.js +77 -0
  912. package/dist/workflow/quality/HonestDelivery.js.map +1 -0
  913. package/dist/workflow/quality/KarpathyEvaluator.d.ts +18 -0
  914. package/dist/workflow/quality/KarpathyEvaluator.js +76 -0
  915. package/dist/workflow/quality/KarpathyEvaluator.js.map +1 -0
  916. package/dist/workflow/types.d.ts +151 -0
  917. package/dist/workflow/types.js +4 -0
  918. package/dist/workflow/types.js.map +1 -0
  919. package/dist/workflows/DAGBuilder.d.ts +52 -0
  920. package/dist/workflows/DAGBuilder.js +169 -0
  921. package/dist/workflows/DAGBuilder.js.map +1 -0
  922. package/dist/workflows/GateParser.d.ts +55 -0
  923. package/dist/workflows/GateParser.js +73 -0
  924. package/dist/workflows/GateParser.js.map +1 -0
  925. package/dist/workflows/WorkflowExecutor.d.ts +56 -0
  926. package/dist/workflows/WorkflowExecutor.js +143 -0
  927. package/dist/workflows/WorkflowExecutor.js.map +1 -0
  928. package/dist/workflows/WorkflowOrchestrator.d.ts +81 -0
  929. package/dist/workflows/WorkflowOrchestrator.js +337 -0
  930. package/dist/workflows/WorkflowOrchestrator.js.map +1 -0
  931. package/dist/workflows/index.d.ts +2 -0
  932. package/dist/workflows/index.js +5 -0
  933. package/dist/workflows/index.js.map +1 -0
  934. package/dist/workflows/presets.d.ts +34 -0
  935. package/dist/workflows/presets.js +224 -0
  936. package/dist/workflows/presets.js.map +1 -0
  937. package/docs/README.md +105 -0
  938. package/docs/guides/DEVELOPMENT_WORKFLOW.md +99 -0
  939. package/docs/guides/GETTING_STARTED.md +93 -0
  940. package/docs/guides/MEDICAL_AGENT_OPERATING_GUIDE.md +61 -0
  941. package/docs/guides/MEDICAL_RESEARCH_DELIVERY.md +217 -0
  942. package/docs/guides/MIGRATION.md +119 -0
  943. package/docs/reference/cli.md +2921 -0
  944. package/docs/start/README.md +79 -0
  945. package/docs/start/agent-governance-demo.md +107 -0
  946. package/docs/start/artifact-lifecycle.md +326 -0
  947. package/docs/start/quickstart.md +191 -0
  948. package/docs/start/workflow-upgrade.md +198 -0
  949. package/docs/workflow/GATES_AND_SCORE.md +89 -0
  950. package/docs/workflow/PROMPT_OPTIMIZATION.md +44 -0
  951. package/docs/workflow/README.md +123 -0
  952. package/docs/workflow/node-library.md +52 -0
  953. package/docs/workflow/templates/api-contract.md +29 -0
  954. package/docs/workflow/templates/architecture-review.md +23 -0
  955. package/docs/workflow/templates/db-change-plan.md +20 -0
  956. package/docs/workflow/templates/docs-impact.md +17 -0
  957. package/docs/workflow/templates/e2e-plan.md +20 -0
  958. package/docs/workflow/templates/explore.md +16 -0
  959. package/docs/workflow/templates/github-actions-scale-preflight.yml +32 -0
  960. package/docs/workflow/templates/mini-prd.md +16 -0
  961. package/docs/workflow/templates/plan.md +37 -0
  962. package/docs/workflow/templates/pre-push-scale-preflight.sh +8 -0
  963. package/docs/workflow/templates/product-smoke.md +61 -0
  964. package/docs/workflow/templates/reality-check.md +28 -0
  965. package/docs/workflow/templates/resource-cleanup.md +17 -0
  966. package/docs/workflow/templates/resource-impact.md +25 -0
  967. package/docs/workflow/templates/review.md +12 -0
  968. package/docs/workflow/templates/runtime.md +23 -0
  969. package/docs/workflow/templates/security-review.md +26 -0
  970. package/docs/workflow/templates/skill-evidence.md +33 -0
  971. package/docs/workflow/templates/skill-plan.md +39 -0
  972. package/docs/workflow/templates/spec.md +17 -0
  973. package/docs/workflow/templates/standards-impact.md +28 -0
  974. package/docs/workflow/templates/summary.md +16 -0
  975. package/docs/workflow/templates/tasks.md +8 -0
  976. package/docs/workflow/templates/ui-spec.md +29 -0
  977. package/docs/workflow/templates/verification.md +20 -0
  978. package/docs/workflow/templates/visual-review.md +20 -0
  979. package/docs/zh/quickstart.md +108 -0
  980. package/examples/demo-projects/agent-governance-demo/CONTEXT.md +14 -0
  981. package/examples/demo-projects/agent-governance-demo/README.md +48 -0
  982. package/examples/demo-projects/agent-governance-demo/docs/CONTEXT-MAP.md +14 -0
  983. package/examples/demo-projects/agent-governance-demo/package.json +22 -0
  984. package/examples/demo-projects/agent-governance-demo/src/oauth-state.ts +39 -0
  985. package/examples/demo-projects/agent-governance-demo/tests/oauth-state.test.ts +52 -0
  986. package/mcp-configs/_INDEX.md +55 -0
  987. package/mcp-configs/context7/config.json +9 -0
  988. package/mcp-configs/fetch/config.json +9 -0
  989. package/mcp-configs/filesystem/config.json +9 -0
  990. package/mcp-configs/github/config.json +11 -0
  991. package/mcp-configs/memory/config.json +9 -0
  992. package/mcp-configs/neon/config.json +11 -0
  993. package/mcp-configs/playwright/config.json +9 -0
  994. package/mcp-configs/postgres/config.json +11 -0
  995. package/mcp-configs/puppeteer/config.json +9 -0
  996. package/mcp-configs/sequential-thinking/config.json +9 -0
  997. package/package.json +113 -0
  998. package/scripts/workflow/lib/gbrain-runtime.mjs +185 -0
  999. package/scripts/workflow/lib/report-output.mjs +107 -0
  1000. package/scripts/workflow/medscale-release-smoke.mjs +338 -0
  1001. package/scripts/workflow/provider-rehearsal.mjs +597 -0
  1002. package/scripts/workflow/setup-smoke.mjs +433 -0
  1003. package/target-research-platform/bridge_runner.py +310 -0
  1004. package/target-research-platform/config.yaml +148 -0
  1005. package/target-research-platform/data/immune_infiltration/ACC.csv +201 -0
  1006. package/target-research-platform/data/immune_infiltration/BLCA.csv +201 -0
  1007. package/target-research-platform/data/immune_infiltration/BRCA.csv +201 -0
  1008. package/target-research-platform/data/immune_infiltration/CESC.csv +201 -0
  1009. package/target-research-platform/data/immune_infiltration/CHOL.csv +201 -0
  1010. package/target-research-platform/data/immune_infiltration/COAD.csv +201 -0
  1011. package/target-research-platform/data/immune_infiltration/DLBC.csv +201 -0
  1012. package/target-research-platform/data/immune_infiltration/ESCA.csv +201 -0
  1013. package/target-research-platform/data/immune_infiltration/GBM.csv +201 -0
  1014. package/target-research-platform/data/immune_infiltration/HNSC.csv +201 -0
  1015. package/target-research-platform/data/immune_infiltration/KICH.csv +201 -0
  1016. package/target-research-platform/data/immune_infiltration/KIRC.csv +201 -0
  1017. package/target-research-platform/data/immune_infiltration/KIRP.csv +201 -0
  1018. package/target-research-platform/data/immune_infiltration/LAML.csv +201 -0
  1019. package/target-research-platform/data/immune_infiltration/LGG.csv +201 -0
  1020. package/target-research-platform/data/immune_infiltration/LIHC.csv +201 -0
  1021. package/target-research-platform/data/immune_infiltration/LUAD.csv +201 -0
  1022. package/target-research-platform/data/immune_infiltration/LUSC.csv +201 -0
  1023. package/target-research-platform/data/immune_infiltration/MESO.csv +201 -0
  1024. package/target-research-platform/data/immune_infiltration/OV.csv +201 -0
  1025. package/target-research-platform/data/immune_infiltration/PAAD.csv +201 -0
  1026. package/target-research-platform/data/immune_infiltration/PCPG.csv +201 -0
  1027. package/target-research-platform/data/immune_infiltration/PRAD.csv +201 -0
  1028. package/target-research-platform/data/immune_infiltration/READ.csv +201 -0
  1029. package/target-research-platform/data/immune_infiltration/SARC.csv +201 -0
  1030. package/target-research-platform/data/immune_infiltration/SKCM.csv +201 -0
  1031. package/target-research-platform/data/immune_infiltration/STAD.csv +201 -0
  1032. package/target-research-platform/data/immune_infiltration/TGCT.csv +201 -0
  1033. package/target-research-platform/data/immune_infiltration/THCA.csv +201 -0
  1034. package/target-research-platform/data/immune_infiltration/THYM.csv +201 -0
  1035. package/target-research-platform/data/immune_infiltration/UCEC.csv +201 -0
  1036. package/target-research-platform/data/immune_infiltration/UCS.csv +201 -0
  1037. package/target-research-platform/data/immune_infiltration/UVM.csv +201 -0
  1038. package/target-research-platform/docs/JSON_SCHEMA.md +352 -0
  1039. package/target-research-platform/docs/PROGRESS_2026-06-09.md +140 -0
  1040. package/target-research-platform/main.py +755 -0
  1041. package/target-research-platform/pyproject.toml +54 -0
  1042. package/target-research-platform/requirements.txt +9 -0
  1043. package/target-research-platform/run_dashboard.py +5 -0
  1044. package/target-research-platform/run_real_medical_workflow.py +28 -0
  1045. package/target-research-platform/scripts/demo_report.py +481 -0
  1046. package/target-research-platform/scripts/generate_evidence_package.py +75 -0
  1047. package/target-research-platform/scripts/prepare_immune_data.py +386 -0
  1048. package/target-research-platform/src/__init__.py +4 -0
  1049. package/target-research-platform/src/analysis/__init__.py +3 -0
  1050. package/target-research-platform/src/analysis/stage1_expression/__init__.py +12 -0
  1051. package/target-research-platform/src/analysis/stage1_expression/immune_correlation.py +366 -0
  1052. package/target-research-platform/src/analysis/stage1_expression/pipeline.py +579 -0
  1053. package/target-research-platform/src/analysis/stage1_expression/survival_analysis.py +382 -0
  1054. package/target-research-platform/src/analysis/stage2_screening/__init__.py +12 -0
  1055. package/target-research-platform/src/analysis/stage2_screening/differential_expression.py +451 -0
  1056. package/target-research-platform/src/analysis/stage2_screening/druggability_score.py +477 -0
  1057. package/target-research-platform/src/analysis/stage2_screening/pipeline.py +822 -0
  1058. package/target-research-platform/src/analysis/stage3_deep_research/__init__.py +12 -0
  1059. package/target-research-platform/src/analysis/stage3_deep_research/competitive_landscape.py +479 -0
  1060. package/target-research-platform/src/analysis/stage3_deep_research/pipeline.py +763 -0
  1061. package/target-research-platform/src/analysis/stage3_deep_research/target_function.py +290 -0
  1062. package/target-research-platform/src/analysis/stage4_business/__init__.py +12 -0
  1063. package/target-research-platform/src/analysis/stage4_business/business_plan.py +816 -0
  1064. package/target-research-platform/src/analysis/stage4_business/milestone_planner.py +844 -0
  1065. package/target-research-platform/src/analysis/stage4_business/pipeline.py +284 -0
  1066. package/target-research-platform/src/api_clients/__init__.py +29 -0
  1067. package/target-research-platform/src/api_clients/aminer_client.py +163 -0
  1068. package/target-research-platform/src/api_clients/base_client.py +186 -0
  1069. package/target-research-platform/src/api_clients/clinicaltrials_client.py +411 -0
  1070. package/target-research-platform/src/api_clients/geo_client.py +1420 -0
  1071. package/target-research-platform/src/api_clients/gtex_client.py +209 -0
  1072. package/target-research-platform/src/api_clients/hpa_client.py +170 -0
  1073. package/target-research-platform/src/api_clients/immune_data_manager.py +247 -0
  1074. package/target-research-platform/src/api_clients/openalex_client.py +86 -0
  1075. package/target-research-platform/src/api_clients/opentargets_client.py +558 -0
  1076. package/target-research-platform/src/api_clients/pubmed_client.py +361 -0
  1077. package/target-research-platform/src/api_clients/tcga_client.py +712 -0
  1078. package/target-research-platform/src/api_clients/timer_client.py +169 -0
  1079. package/target-research-platform/src/dashboard/app.py +2283 -0
  1080. package/target-research-platform/src/dashboard/deliverables.py +710 -0
  1081. package/target-research-platform/src/dashboard/static/artifactPreview.js +96 -0
  1082. package/target-research-platform/src/dashboard/static/index.html +1292 -0
  1083. package/target-research-platform/src/dashboard/status_tracker.py +237 -0
  1084. package/target-research-platform/src/output/__init__.py +42 -0
  1085. package/target-research-platform/src/output/agent_llm_provider.py +171 -0
  1086. package/target-research-platform/src/output/chart_generator.py +550 -0
  1087. package/target-research-platform/src/output/data_exporter.py +215 -0
  1088. package/target-research-platform/src/output/delivery_packager.py +791 -0
  1089. package/target-research-platform/src/output/evidence_package.py +230 -0
  1090. package/target-research-platform/src/output/journal_templates.py +193 -0
  1091. package/target-research-platform/src/output/literature_enricher.py +395 -0
  1092. package/target-research-platform/src/output/literature_reviewer.py +420 -0
  1093. package/target-research-platform/src/output/manuscript_fact_checker.py +279 -0
  1094. package/target-research-platform/src/output/manuscript_generator.py +1189 -0
  1095. package/target-research-platform/src/output/manuscript_quality.py +401 -0
  1096. package/target-research-platform/src/output/medical_skills_bridge.py +140 -0
  1097. package/target-research-platform/src/output/report_generator.py +542 -0
  1098. package/target-research-platform/src/output/usage_envelope.py +193 -0
  1099. package/target-research-platform/src/utils/__init__.py +1 -0
  1100. package/target-research-platform/src/utils/config.py +125 -0
  1101. package/target-research-platform/src/utils/logger.py +71 -0
  1102. package/target-research-platform/src/validators/__init__.py +13 -0
  1103. package/target-research-platform/src/validators/cross_validator.py +394 -0
  1104. package/target-research-platform/src/validators/data_provenance.py +298 -0
@@ -0,0 +1,1113 @@
1
+ import { appendFileSync, existsSync, mkdirSync, readdirSync, readFileSync, statSync, writeFileSync } from 'node:fs';
2
+ import { extname, isAbsolute, join, relative, resolve, sep } from 'node:path';
3
+ const DEFAULT_SOURCE_DIRECTORIES = ['src', 'app', 'packages', 'services', 'cmd', 'internal', 'pkg'];
4
+ const DEFAULT_IGNORED_DIRECTORIES = [
5
+ '.git',
6
+ '.scale',
7
+ 'node_modules',
8
+ 'dist',
9
+ 'build',
10
+ 'coverage',
11
+ 'test-results',
12
+ 'playwright-report',
13
+ 'tmp',
14
+ 'temp',
15
+ 'docs',
16
+ 'tests',
17
+ '__tests__',
18
+ 'e2e',
19
+ ];
20
+ const DEFAULT_ALLOWED_CONSOLE_DIRECTORIES = ['src/api', 'src/cli', 'scripts'];
21
+ const DEFAULT_ALLOWED_CONSOLE_FILES = ['src/dashboard/DashboardServer.ts'];
22
+ const DEFAULT_SENSITIVE_FIELDS = [
23
+ 'password',
24
+ 'passwd',
25
+ 'token',
26
+ 'accessToken',
27
+ 'refreshToken',
28
+ 'secret',
29
+ 'authorization',
30
+ 'cookie',
31
+ 'apiKey',
32
+ 'credential',
33
+ 'privateKey',
34
+ ];
35
+ const SOURCE_EXTENSIONS = new Set([
36
+ '.ts',
37
+ '.tsx',
38
+ '.js',
39
+ '.jsx',
40
+ '.mjs',
41
+ '.cjs',
42
+ '.go',
43
+ '.py',
44
+ '.java',
45
+ '.cs',
46
+ '.kt',
47
+ '.php',
48
+ '.rb',
49
+ '.rs',
50
+ '.vue',
51
+ '.svelte',
52
+ ]);
53
+ export function engineeringStandardsPolicyPath(projectDir = process.cwd(), scaleDir = '.scale') {
54
+ return join(resolveScaleRoot(projectDir, scaleDir), 'engineering-standards.json');
55
+ }
56
+ export function frameworksCatalogPath(projectDir = process.cwd(), scaleDir = '.scale') {
57
+ return join(resolveScaleRoot(projectDir, scaleDir), 'frameworks.json');
58
+ }
59
+ export function engineeringStandardsBaselinePath(projectDir = process.cwd(), scaleDir = '.scale') {
60
+ return join(resolveScaleRoot(projectDir, scaleDir), 'engineering-standards-baseline.json');
61
+ }
62
+ export function engineeringStandardsPolicyTemplate() {
63
+ return JSON.stringify({
64
+ version: 1,
65
+ mode: 'warn',
66
+ sourceDirectories: DEFAULT_SOURCE_DIRECTORIES,
67
+ ignoredDirectories: DEFAULT_IGNORED_DIRECTORIES,
68
+ allowedConsoleDirectories: DEFAULT_ALLOWED_CONSOLE_DIRECTORIES,
69
+ allowedConsoleFiles: DEFAULT_ALLOWED_CONSOLE_FILES,
70
+ maxFileLines: 500,
71
+ logging: {
72
+ approvedLoggers: ['pino', 'winston', 'zap', 'zerolog', 'logrus', 'slog'],
73
+ sensitiveFields: DEFAULT_SENSITIVE_FIELDS,
74
+ },
75
+ architecture: {
76
+ enforceLayering: true,
77
+ },
78
+ blockingRules: [],
79
+ allowedFindingPatterns: [],
80
+ baselineFindings: [],
81
+ }, null, 2) + '\n';
82
+ }
83
+ export function engineeringStandardsBaselineTemplate() {
84
+ return JSON.stringify({
85
+ version: 1,
86
+ generatedAt: '',
87
+ scope: 'Legacy findings tracked separately. New findings and changed-file findings must still be fixed before completion.',
88
+ findings: [],
89
+ }, null, 2) + '\n';
90
+ }
91
+ export function frameworksCatalogTemplate() {
92
+ return JSON.stringify({
93
+ version: 1,
94
+ lastReviewedAt: '',
95
+ reviewIntervalDays: 90,
96
+ frameworks: [],
97
+ orm: [],
98
+ ui: {
99
+ designSystem: '',
100
+ componentLibrary: '',
101
+ visualReviewRequired: true,
102
+ },
103
+ architecture: {
104
+ layers: ['api', 'service', 'domain', 'repository', 'infrastructure'],
105
+ dependencyRule: 'outer layers depend inward through explicit interfaces',
106
+ },
107
+ bannedImports: [],
108
+ }, null, 2) + '\n';
109
+ }
110
+ export function loadEngineeringStandardsPolicy(projectDir = process.cwd(), scaleDir = '.scale') {
111
+ const path = engineeringStandardsPolicyPath(projectDir, scaleDir);
112
+ const warnings = [];
113
+ let parsed = {};
114
+ if (existsSync(path)) {
115
+ try {
116
+ parsed = JSON.parse(readFileSync(path, 'utf-8'));
117
+ }
118
+ catch (error) {
119
+ warnings.push(`Failed to read ${path}: ${error.message}; using built-in defaults.`);
120
+ }
121
+ }
122
+ else {
123
+ warnings.push(`No engineering standards policy found at ${path}; using built-in defaults.`);
124
+ }
125
+ return {
126
+ version: typeof parsed.version === 'number' ? parsed.version : 1,
127
+ mode: parsed.mode === 'block' ? 'block' : 'warn',
128
+ sourceDirectories: parsed.sourceDirectories ?? DEFAULT_SOURCE_DIRECTORIES,
129
+ ignoredDirectories: parsed.ignoredDirectories ?? DEFAULT_IGNORED_DIRECTORIES,
130
+ allowedConsoleDirectories: parsed.allowedConsoleDirectories ?? DEFAULT_ALLOWED_CONSOLE_DIRECTORIES,
131
+ allowedConsoleFiles: parsed.allowedConsoleFiles ?? DEFAULT_ALLOWED_CONSOLE_FILES,
132
+ maxFileLines: parsed.maxFileLines ?? 500,
133
+ logging: {
134
+ approvedLoggers: parsed.logging?.approvedLoggers ?? ['pino', 'winston', 'zap', 'zerolog', 'logrus', 'slog'],
135
+ sensitiveFields: parsed.logging?.sensitiveFields ?? DEFAULT_SENSITIVE_FIELDS,
136
+ },
137
+ architecture: {
138
+ enforceLayering: parsed.architecture?.enforceLayering ?? true,
139
+ },
140
+ blockingRules: Array.isArray(parsed.blockingRules)
141
+ ? parsed.blockingRules.filter(ruleId => typeof ruleId === 'string' && ruleId.length > 0)
142
+ : [],
143
+ allowedFindingPatterns: resolveAllowedFindingPatterns(parsed, warnings),
144
+ baselineFindings: Array.isArray(parsed.baselineFindings)
145
+ ? parsed.baselineFindings
146
+ .filter(item => typeof item.ruleId === 'string' && typeof item.path === 'string')
147
+ .map(item => ({
148
+ ...item,
149
+ line: typeof item.line === 'number' ? item.line : undefined,
150
+ }))
151
+ : [],
152
+ warnings,
153
+ };
154
+ }
155
+ export function loadEngineeringStandardsBaseline(projectDir = process.cwd(), scaleDir = '.scale') {
156
+ const path = engineeringStandardsBaselinePath(projectDir, scaleDir);
157
+ const warnings = [];
158
+ let parsed = {};
159
+ if (!existsSync(path))
160
+ return { findings: [], warnings };
161
+ try {
162
+ parsed = JSON.parse(readFileSync(path, 'utf-8'));
163
+ }
164
+ catch (error) {
165
+ warnings.push(`Failed to read ${path}: ${error.message}; external standards baseline ignored.`);
166
+ return { findings: [], warnings };
167
+ }
168
+ return {
169
+ findings: Array.isArray(parsed.findings)
170
+ ? parsed.findings
171
+ .filter(item => typeof item.ruleId === 'string' && typeof item.path === 'string')
172
+ .map(item => ({
173
+ ruleId: item.ruleId,
174
+ path: normalizePath(item.path),
175
+ line: typeof item.line === 'number' ? item.line : undefined,
176
+ reason: typeof item.reason === 'string' ? item.reason : undefined,
177
+ }))
178
+ : [],
179
+ warnings,
180
+ };
181
+ }
182
+ function resolveAllowedFindingPatterns(parsed, warnings) {
183
+ if (!Array.isArray(parsed.allowedFindingPatterns))
184
+ return [];
185
+ const patterns = [];
186
+ for (const item of parsed.allowedFindingPatterns) {
187
+ if (!item || typeof item !== 'object')
188
+ continue;
189
+ if (typeof item.ruleId !== 'string' || item.ruleId.length === 0)
190
+ continue;
191
+ if (typeof item.evidencePattern !== 'string' && typeof item.messagePattern !== 'string')
192
+ continue;
193
+ const validEvidencePattern = typeof item.evidencePattern !== 'string' || isValidRegex(item.evidencePattern);
194
+ const validMessagePattern = typeof item.messagePattern !== 'string' || isValidRegex(item.messagePattern);
195
+ if (!validEvidencePattern || !validMessagePattern) {
196
+ warnings.push(`Invalid allowedFindingPatterns entry for ${item.ruleId}; regex could not be compiled.`);
197
+ continue;
198
+ }
199
+ patterns.push({
200
+ ruleId: item.ruleId,
201
+ path: typeof item.path === 'string' ? item.path : undefined,
202
+ evidencePattern: typeof item.evidencePattern === 'string' ? item.evidencePattern : undefined,
203
+ messagePattern: typeof item.messagePattern === 'string' ? item.messagePattern : undefined,
204
+ reason: typeof item.reason === 'string' ? item.reason : undefined,
205
+ });
206
+ }
207
+ return patterns;
208
+ }
209
+ function isValidRegex(pattern) {
210
+ try {
211
+ new RegExp(pattern);
212
+ return true;
213
+ }
214
+ catch {
215
+ return false;
216
+ }
217
+ }
218
+ export function loadFrameworksCatalog(projectDir = process.cwd(), scaleDir = '.scale', now = new Date()) {
219
+ const path = frameworksCatalogPath(projectDir, scaleDir);
220
+ const warnings = [];
221
+ let parsed = {};
222
+ if (existsSync(path)) {
223
+ try {
224
+ parsed = JSON.parse(readFileSync(path, 'utf-8'));
225
+ }
226
+ catch (error) {
227
+ warnings.push({
228
+ ruleId: 'frameworks-catalog-warning',
229
+ message: `Failed to read ${path}: ${error.message}; using empty framework catalog.`,
230
+ });
231
+ }
232
+ }
233
+ const lastReviewedAt = typeof parsed.lastReviewedAt === 'string' ? parsed.lastReviewedAt : undefined;
234
+ const reviewIntervalDays = typeof parsed.reviewIntervalDays === 'number' ? parsed.reviewIntervalDays : undefined;
235
+ if (lastReviewedAt && reviewIntervalDays && isFrameworkCatalogStale(lastReviewedAt, reviewIntervalDays, now)) {
236
+ warnings.push({
237
+ ruleId: 'frameworks-catalog-stale',
238
+ message: `Framework catalog was last reviewed at ${lastReviewedAt}; review interval is ${reviewIntervalDays} days.`,
239
+ });
240
+ }
241
+ return {
242
+ version: typeof parsed.version === 'number' ? parsed.version : 1,
243
+ lastReviewedAt,
244
+ reviewIntervalDays,
245
+ bannedImports: Array.isArray(parsed.bannedImports)
246
+ ? parsed.bannedImports
247
+ .filter(rule => typeof rule.source === 'string' && rule.source.length > 0)
248
+ .map(rule => ({
249
+ source: rule.source,
250
+ severity: rule.severity === 'info' || rule.severity === 'warn' || rule.severity === 'fail'
251
+ ? rule.severity
252
+ : 'fail',
253
+ reason: typeof rule.reason === 'string' ? rule.reason : undefined,
254
+ replacement: typeof rule.replacement === 'string' ? rule.replacement : undefined,
255
+ }))
256
+ : [],
257
+ warnings,
258
+ };
259
+ }
260
+ export function scanEngineeringStandards(options = {}) {
261
+ const projectDir = options.projectDir ?? process.cwd();
262
+ const scaleDir = options.scaleDir ?? '.scale';
263
+ const policy = loadEngineeringStandardsPolicy(projectDir, scaleDir);
264
+ const externalBaseline = loadEngineeringStandardsBaseline(projectDir, scaleDir);
265
+ const baselineFindings = [...policy.baselineFindings, ...externalBaseline.findings];
266
+ const frameworks = loadFrameworksCatalog(projectDir, scaleDir, options.now);
267
+ const files = findSourceFiles(projectDir, policy, options.changedFiles);
268
+ const findings = files
269
+ .flatMap(file => scanFile(projectDir, file, policy, frameworks))
270
+ .map(finding => applyRuleSeverityPolicy(finding, policy))
271
+ .filter(finding => !isAllowedFindingPattern(finding, policy) &&
272
+ (options.includeBaselineFindings || !isBaselineFinding(finding, baselineFindings)));
273
+ return {
274
+ projectDir,
275
+ policyPath: engineeringStandardsPolicyPath(projectDir, scaleDir),
276
+ baselinePath: engineeringStandardsBaselinePath(projectDir, scaleDir),
277
+ frameworksPath: frameworksCatalogPath(projectDir, scaleDir),
278
+ policy,
279
+ frameworks,
280
+ findings,
281
+ summary: summarizeStandards(files.length, findings),
282
+ warnings: [...policy.warnings, ...externalBaseline.warnings, ...frameworks.warnings.map(warning => warning.message)],
283
+ };
284
+ }
285
+ export function doctorEngineeringStandards(options = {}) {
286
+ const scan = scanEngineeringStandards(options);
287
+ const policyWarningFindings = scan.policy.warnings.map(message => ({
288
+ severity: 'warn',
289
+ category: 'framework',
290
+ ruleId: 'standards-policy-warning',
291
+ path: scan.policyPath,
292
+ message,
293
+ fix: 'Run scale init or add .scale/engineering-standards.json.',
294
+ }));
295
+ const frameworkWarningFindings = scan.frameworks.warnings.map(warning => ({
296
+ severity: 'warn',
297
+ category: 'framework',
298
+ ruleId: warning.ruleId,
299
+ path: scan.frameworksPath,
300
+ message: warning.message,
301
+ fix: 'Fix .scale/frameworks.json or regenerate it with scale init.',
302
+ }));
303
+ const findings = [...policyWarningFindings, ...frameworkWarningFindings, ...scan.findings];
304
+ return {
305
+ ok: !findings.some(finding => finding.severity === 'fail'),
306
+ projectDir: scan.projectDir,
307
+ findings,
308
+ scan: { ...scan, findings },
309
+ };
310
+ }
311
+ export function settleEngineeringStandards(options = {}) {
312
+ const doctor = doctorEngineeringStandards(options);
313
+ const standardsImpactPath = options.artifactsDir
314
+ ? appendStandardsImpact({
315
+ projectDir: options.projectDir ?? process.cwd(),
316
+ artifactsDir: options.artifactsDir,
317
+ taskId: options.taskId,
318
+ doctor,
319
+ })
320
+ : undefined;
321
+ return {
322
+ ok: doctor.ok,
323
+ taskId: options.taskId,
324
+ standardsImpactPath,
325
+ doctor,
326
+ };
327
+ }
328
+ export function baselineEngineeringStandards(options = {}) {
329
+ const projectDir = options.projectDir ?? process.cwd();
330
+ const scaleDir = options.scaleDir ?? '.scale';
331
+ const reason = options.reason ?? 'legacy standards debt accepted for staged remediation';
332
+ const scan = scanEngineeringStandards({
333
+ ...options,
334
+ projectDir,
335
+ scaleDir,
336
+ changedFiles: undefined,
337
+ includeBaselineFindings: true,
338
+ });
339
+ const baselineEntries = baselineEntriesFromFindings(scan.findings, reason);
340
+ const debt = classifyStandardsDebt(scan.summary.filesScanned, scan.findings);
341
+ const baselinePath = engineeringStandardsBaselinePath(projectDir, scaleDir);
342
+ if (options.writeBaseline) {
343
+ writeStandardsBaselineFile({
344
+ projectDir,
345
+ scaleDir,
346
+ baselinePath,
347
+ taskId: options.taskId,
348
+ reason,
349
+ entries: baselineEntries,
350
+ });
351
+ }
352
+ const legacyDebtPath = options.artifactsDir
353
+ ? writeLegacyDebtReport({
354
+ projectDir,
355
+ artifactsDir: options.artifactsDir,
356
+ taskId: options.taskId,
357
+ wroteBaseline: Boolean(options.writeBaseline),
358
+ baselinePath,
359
+ baselineEntries,
360
+ debt,
361
+ findings: scan.findings,
362
+ maxFindingsInReport: options.maxFindingsInReport ?? 200,
363
+ })
364
+ : undefined;
365
+ return {
366
+ ok: true,
367
+ projectDir,
368
+ baselinePath,
369
+ legacyDebtPath,
370
+ wroteBaseline: Boolean(options.writeBaseline),
371
+ baselineEntries,
372
+ debt,
373
+ scan,
374
+ warnings: scan.warnings,
375
+ };
376
+ }
377
+ function scanFile(projectDir, absolutePath, policy, frameworks) {
378
+ const path = normalizePath(relative(projectDir, absolutePath));
379
+ const content = readFileSync(absolutePath, 'utf-8');
380
+ const lines = content.split(/\r?\n/);
381
+ const findings = [];
382
+ if (lines.length > policy.maxFileLines) {
383
+ findings.push({
384
+ severity: 'warn',
385
+ category: 'architecture',
386
+ ruleId: 'large-source-file',
387
+ path,
388
+ message: `Source file has ${lines.length} lines, above ${policy.maxFileLines}.`,
389
+ fix: 'Split responsibilities or document why this file is intentionally large.',
390
+ });
391
+ }
392
+ let insideTemplateLiteral = false;
393
+ for (let index = 0; index < lines.length; index += 1) {
394
+ const line = lines[index];
395
+ const startedInsideTemplateLiteral = insideTemplateLiteral;
396
+ insideTemplateLiteral = updateTemplateLiteralState(line, insideTemplateLiteral);
397
+ if (startedInsideTemplateLiteral || isNonExecutablePatternLine(line))
398
+ continue;
399
+ const lineNumber = index + 1;
400
+ findings.push(...scanLine(path, line, lineNumber, policy, frameworks));
401
+ }
402
+ findings.push(...findEmptyCatchBlocks(path, lines));
403
+ return dedupeFindings(findings);
404
+ }
405
+ function scanLine(path, line, lineNumber, policy, frameworks) {
406
+ const findings = [];
407
+ const sensitiveMatcher = sensitiveFieldPattern(policy);
408
+ const evidence = line.trim().slice(0, 160);
409
+ findings.push(...scanBannedImports(path, line, lineNumber, evidence, frameworks));
410
+ if (isHardcodedSecret(line, policy)) {
411
+ findings.push({
412
+ severity: 'fail',
413
+ category: 'security',
414
+ ruleId: 'hardcoded-secret',
415
+ path,
416
+ line: lineNumber,
417
+ message: 'Secret-like value appears to be hardcoded in source.',
418
+ evidence,
419
+ fix: 'Move secrets to approved secret storage or environment configuration and keep placeholders non-sensitive.',
420
+ });
421
+ }
422
+ if ((isLogCall(line) || isAdHocOutputCall(line)) && sensitiveMatcher.test(line)) {
423
+ findings.push({
424
+ severity: 'fail',
425
+ category: 'logging',
426
+ ruleId: 'sensitive-log',
427
+ path,
428
+ line: lineNumber,
429
+ message: 'Sensitive field appears in a log statement.',
430
+ evidence,
431
+ fix: 'Remove the field, mask it, or use an approved redaction helper before logging.',
432
+ });
433
+ }
434
+ else if (isAdHocOutputCall(line) && !isConsoleAllowed(path, policy)) {
435
+ findings.push({
436
+ severity: 'warn',
437
+ category: 'logging',
438
+ ruleId: 'ad-hoc-console-log',
439
+ path,
440
+ line: lineNumber,
441
+ message: 'Ad-hoc console logging was found outside approved CLI or script paths.',
442
+ evidence,
443
+ fix: 'Use the project logger, remove the debug print, or add an explicit policy exception.',
444
+ });
445
+ }
446
+ if (isRawSqlConstruction(line)) {
447
+ findings.push({
448
+ severity: 'fail',
449
+ category: 'database',
450
+ ruleId: 'raw-sql-construction',
451
+ path,
452
+ line: lineNumber,
453
+ message: 'SQL appears to be constructed with dynamic input.',
454
+ evidence,
455
+ fix: 'Use parameterized queries, ORM bind parameters, or a query builder with placeholders.',
456
+ });
457
+ }
458
+ if (/dangerouslySetInnerHTML|\.innerHTML\s*=|document\.write\s*\(/.test(line)) {
459
+ findings.push({
460
+ severity: 'fail',
461
+ category: 'security',
462
+ ruleId: 'unsafe-html-sink',
463
+ path,
464
+ line: lineNumber,
465
+ message: 'Unsafe HTML sink can create XSS risk.',
466
+ evidence,
467
+ fix: 'Use text rendering or sanitize trusted HTML with an approved sanitizer.',
468
+ });
469
+ }
470
+ if (/\beval\s*\(|new\s+Function\s*\(/.test(line)) {
471
+ findings.push({
472
+ severity: 'fail',
473
+ category: 'security',
474
+ ruleId: 'unsafe-code-execution',
475
+ path,
476
+ line: lineNumber,
477
+ message: 'Dynamic code execution was found.',
478
+ evidence,
479
+ fix: 'Replace eval or Function with a typed parser, dispatch table, or safe interpreter.',
480
+ });
481
+ }
482
+ if (/^\s*(?:\/\/|\/\*)\s*@ts-ignore\b/.test(line)) {
483
+ findings.push({
484
+ severity: 'fail',
485
+ category: 'code-quality',
486
+ ruleId: 'ts-ignore',
487
+ path,
488
+ line: lineNumber,
489
+ message: 'TypeScript errors are suppressed with @ts-ignore.',
490
+ evidence,
491
+ fix: 'Fix the type boundary or use a narrow typed adapter with a documented reason.',
492
+ });
493
+ }
494
+ if (/\bas\s+any\b|:\s*any\b|<any\b|Array<any>|Promise<any>|Record<[^>]+,\s*any>/.test(line)) {
495
+ findings.push({
496
+ severity: 'warn',
497
+ category: 'code-quality',
498
+ ruleId: 'type-escape',
499
+ path,
500
+ line: lineNumber,
501
+ message: 'New any-based type escape weakens interface contracts.',
502
+ evidence,
503
+ fix: 'Model the real type or isolate unknown input at the boundary.',
504
+ });
505
+ }
506
+ if (/Math\.random\s*\(\)/.test(line) && /\b(token|secret|session|password|credential|nonce)\b/i.test(line)) {
507
+ findings.push({
508
+ severity: 'fail',
509
+ category: 'security',
510
+ ruleId: 'weak-random-security-token',
511
+ path,
512
+ line: lineNumber,
513
+ message: 'Math.random is used for security-sensitive data.',
514
+ evidence,
515
+ fix: 'Use a cryptographically secure random source.',
516
+ });
517
+ }
518
+ if (policy.architecture.enforceLayering && isOuterLayerPath(path) && importsInnerPersistence(line)) {
519
+ findings.push({
520
+ severity: 'warn',
521
+ category: 'architecture',
522
+ ruleId: 'layer-boundary-bypass',
523
+ path,
524
+ line: lineNumber,
525
+ message: 'Outer layer appears to import persistence internals directly.',
526
+ evidence,
527
+ fix: 'Route through service/usecase interfaces and keep persistence behind a repository boundary.',
528
+ });
529
+ }
530
+ return findings;
531
+ }
532
+ function findEmptyCatchBlocks(path, lines) {
533
+ const findings = [];
534
+ for (let index = 0; index < lines.length; index += 1) {
535
+ const line = lines[index];
536
+ if (/catch\s*(?:\([^)]*\))?\s*\{\s*(?:\/\*.*?\*\/|\/\/.*)?\s*\}/.test(line)) {
537
+ findings.push(emptyCatchFinding(path, index + 1, line));
538
+ continue;
539
+ }
540
+ if (!/catch\s*(?:\([^)]*\))?\s*\{\s*$/.test(line))
541
+ continue;
542
+ for (const next of lines.slice(index + 1, index + 8)) {
543
+ const trimmed = next.trim();
544
+ if (trimmed === '' || trimmed.startsWith('//') || trimmed.startsWith('/*') || trimmed.startsWith('*'))
545
+ continue;
546
+ if (/^}\s*[),;]?$/.test(trimmed))
547
+ findings.push(emptyCatchFinding(path, index + 1, line));
548
+ break;
549
+ }
550
+ }
551
+ return findings;
552
+ }
553
+ function emptyCatchFinding(path, line, text) {
554
+ return {
555
+ severity: 'fail',
556
+ category: 'code-quality',
557
+ ruleId: 'empty-catch',
558
+ path,
559
+ line,
560
+ message: 'Empty or comment-only catch block hides failures.',
561
+ evidence: text.trim().slice(0, 160),
562
+ fix: 'Handle the error, return a typed failure, or log through the approved redacted logger.',
563
+ };
564
+ }
565
+ function findSourceFiles(projectDir, policy, changedFiles) {
566
+ if (changedFiles)
567
+ return findChangedSourceFiles(projectDir, policy, changedFiles);
568
+ const files = [];
569
+ for (const sourceDir of policy.sourceDirectories) {
570
+ const absolute = join(projectDir, sourceDir);
571
+ if (!existsSync(absolute))
572
+ continue;
573
+ walk(absolute, projectDir, policy, files);
574
+ }
575
+ return files;
576
+ }
577
+ function findChangedSourceFiles(projectDir, policy, changedFiles) {
578
+ const files = [];
579
+ const seen = new Set();
580
+ for (const changedFile of changedFiles) {
581
+ const normalized = normalizeChangedPath(projectDir, changedFile);
582
+ if (!normalized || seen.has(normalized))
583
+ continue;
584
+ seen.add(normalized);
585
+ if (!SOURCE_EXTENSIONS.has(extname(normalized).toLowerCase()))
586
+ continue;
587
+ if (!isUnderSourceDirectory(normalized, policy))
588
+ continue;
589
+ if (isIgnoredPath(normalized, policy))
590
+ continue;
591
+ const absolute = resolve(projectDir, ...normalized.split('/'));
592
+ if (!existsSync(absolute) || !statSync(absolute).isFile())
593
+ continue;
594
+ if (statSync(absolute).size <= 1024 * 1024)
595
+ files.push(absolute);
596
+ }
597
+ return files;
598
+ }
599
+ function normalizeChangedPath(projectDir, path) {
600
+ const relativePath = isAbsolute(path) ? relative(projectDir, path) : path;
601
+ const normalized = normalizePath(relativePath);
602
+ if (!normalized || normalized.startsWith('..'))
603
+ return '';
604
+ return normalized;
605
+ }
606
+ function isUnderSourceDirectory(path, policy) {
607
+ return policy.sourceDirectories
608
+ .map(normalizePath)
609
+ .some(sourceDir => path === sourceDir || path.startsWith(`${sourceDir}/`));
610
+ }
611
+ function isIgnoredPath(path, policy) {
612
+ return policy.ignoredDirectories
613
+ .map(normalizePath)
614
+ .some(ignored => path === ignored || path.startsWith(`${ignored}/`) || path.split('/').includes(ignored));
615
+ }
616
+ function walk(dir, projectDir, policy, files) {
617
+ for (const entry of readdirSync(dir, { withFileTypes: true })) {
618
+ const fullPath = join(dir, entry.name);
619
+ const rel = normalizePath(relative(projectDir, fullPath));
620
+ if (entry.isDirectory()) {
621
+ if (policy.ignoredDirectories.some(ignored => rel === normalizePath(ignored) || rel.startsWith(`${normalizePath(ignored)}/`) || entry.name === ignored))
622
+ continue;
623
+ walk(fullPath, projectDir, policy, files);
624
+ }
625
+ else if (entry.isFile() && SOURCE_EXTENSIONS.has(extname(entry.name).toLowerCase())) {
626
+ if (statSync(fullPath).size <= 1024 * 1024)
627
+ files.push(fullPath);
628
+ }
629
+ }
630
+ }
631
+ function appendStandardsImpact(options) {
632
+ const dir = isAbsolute(options.artifactsDir)
633
+ ? options.artifactsDir
634
+ : resolve(options.projectDir, options.artifactsDir);
635
+ if (!existsSync(dir))
636
+ mkdirSync(dir, { recursive: true });
637
+ const path = join(dir, 'standards-impact.md');
638
+ if (!existsSync(path))
639
+ writeFileSync(path, '# Standards Impact\n\n', 'utf-8');
640
+ appendFileSync(path, standardsSettlementMarkdown(options.taskId, options.doctor), 'utf-8');
641
+ return path;
642
+ }
643
+ function standardsSettlementMarkdown(taskId, doctor) {
644
+ const findings = doctor.findings.length
645
+ ? doctor.findings.map(finding => `| ${finding.severity.toUpperCase()} | ${finding.ruleId} | ${escapeCell(finding.path)} | ${finding.line ?? ''} | ${escapeCell(finding.message)} |`).join('\n')
646
+ : '| OK | no-findings | | | No engineering standards findings. |';
647
+ return `
648
+ ## SCALE Engineering Standards Settlement - ${new Date().toISOString()}
649
+
650
+ Task: ${taskId ?? 'unspecified'}
651
+ Status: ${doctor.ok ? 'passed' : 'blocked'}
652
+
653
+ | Metric | Value |
654
+ | --- | ---: |
655
+ | Files scanned | ${doctor.scan.summary.filesScanned} |
656
+ | Total findings | ${doctor.scan.summary.totalFindings} |
657
+ | Blocking findings | ${doctor.scan.summary.blockingFindings} |
658
+
659
+ | Severity | Rule | Path | Line | Message |
660
+ | --- | --- | --- | ---: | --- |
661
+ ${findings}
662
+ `;
663
+ }
664
+ function baselineEntriesFromFindings(findings, reason) {
665
+ const entries = new Map();
666
+ for (const finding of [...findings].sort(compareFindings)) {
667
+ const path = normalizePath(finding.path);
668
+ const key = `${finding.ruleId}\0${path}\0${finding.line ?? ''}`;
669
+ if (entries.has(key))
670
+ continue;
671
+ entries.set(key, {
672
+ ruleId: finding.ruleId,
673
+ path,
674
+ line: finding.line,
675
+ reason,
676
+ severity: finding.severity,
677
+ category: finding.category,
678
+ message: finding.message,
679
+ });
680
+ }
681
+ return [...entries.values()];
682
+ }
683
+ function writeStandardsBaselineFile(options) {
684
+ mkdirSync(resolveScaleRoot(options.projectDir, options.scaleDir), { recursive: true });
685
+ writeFileSync(options.baselinePath, JSON.stringify({
686
+ version: 1,
687
+ generatedAt: new Date().toISOString(),
688
+ taskId: options.taskId,
689
+ scope: 'Legacy findings tracked separately. New findings and changed-file findings must still be fixed before completion.',
690
+ reason: options.reason,
691
+ findings: options.entries.map(entry => ({
692
+ ruleId: entry.ruleId,
693
+ path: entry.path,
694
+ ...(entry.line === undefined ? {} : { line: entry.line }),
695
+ reason: entry.reason,
696
+ })),
697
+ }, null, 2) + '\n', 'utf-8');
698
+ }
699
+ function resolveScaleRoot(projectDir, scaleDir) {
700
+ return isAbsolute(scaleDir) ? scaleDir : join(projectDir, scaleDir);
701
+ }
702
+ function classifyStandardsDebt(filesScanned, findings) {
703
+ const bySeverity = { info: 0, warn: 0, fail: 0 };
704
+ const byCategory = emptyDebtCategorySummary();
705
+ const byScope = emptyDebtScopeSummary();
706
+ const byRule = {};
707
+ const byFile = new Map();
708
+ for (const finding of findings) {
709
+ bySeverity[finding.severity] += 1;
710
+ incrementDebtGroup(byCategory[finding.category], finding.severity);
711
+ incrementDebtGroup(byScope[classifyDebtScope(finding.path)], finding.severity);
712
+ byRule[finding.ruleId] ??= { ...emptyDebtGroup(), category: finding.category };
713
+ incrementDebtGroup(byRule[finding.ruleId], finding.severity);
714
+ const fileGroup = byFile.get(finding.path) ?? { ...emptyDebtGroup(), path: finding.path };
715
+ incrementDebtGroup(fileGroup, finding.severity);
716
+ byFile.set(finding.path, fileGroup);
717
+ }
718
+ return {
719
+ filesScanned,
720
+ totalFindings: findings.length,
721
+ blockingFindings: findings.filter(finding => finding.severity === 'fail').length,
722
+ bySeverity,
723
+ byScope,
724
+ byCategory,
725
+ byRule,
726
+ topFiles: [...byFile.values()]
727
+ .sort((a, b) => b.total - a.total || a.path.localeCompare(b.path))
728
+ .slice(0, 20),
729
+ };
730
+ }
731
+ function writeLegacyDebtReport(options) {
732
+ const dir = isAbsolute(options.artifactsDir)
733
+ ? options.artifactsDir
734
+ : resolve(options.projectDir, options.artifactsDir);
735
+ if (!existsSync(dir))
736
+ mkdirSync(dir, { recursive: true });
737
+ const path = join(dir, 'standards-legacy-debt.md');
738
+ writeFileSync(path, legacyDebtMarkdown(options), 'utf-8');
739
+ return path;
740
+ }
741
+ function legacyDebtMarkdown(options) {
742
+ const categories = Object.entries(options.debt.byCategory)
743
+ .filter(([, group]) => group.total > 0)
744
+ .map(([category, group]) => `| ${category} | ${group.total} | ${group.blocking} | ${group.warn} | ${group.info} |`)
745
+ .join('\n') || '| none | 0 | 0 | 0 | 0 |';
746
+ const scopes = Object.entries(options.debt.byScope)
747
+ .filter(([, group]) => group.total > 0)
748
+ .map(([scope, group]) => `| ${scope} | ${group.total} | ${group.blocking} | ${group.warn} | ${group.info} |`)
749
+ .join('\n') || '| none | 0 | 0 | 0 | 0 |';
750
+ const rules = Object.entries(options.debt.byRule)
751
+ .sort(([, a], [, b]) => b.total - a.total)
752
+ .map(([ruleId, group]) => `| ${ruleId} | ${group.category} | ${group.total} | ${group.blocking} | ${group.warn} | ${group.info} |`)
753
+ .join('\n') || '| none | none | 0 | 0 | 0 | 0 |';
754
+ const files = options.debt.topFiles
755
+ .map(group => `| ${escapeCell(group.path)} | ${group.total} | ${group.blocking} | ${group.warn} | ${group.info} |`)
756
+ .join('\n') || '| none | 0 | 0 | 0 | 0 |';
757
+ const detailLimit = Math.max(0, options.maxFindingsInReport);
758
+ const details = options.findings
759
+ .slice(0, detailLimit)
760
+ .map(finding => `| ${finding.severity.toUpperCase()} | ${finding.category} | ${finding.ruleId} | ${escapeCell(finding.path)} | ${finding.line ?? ''} | ${escapeCell(finding.message)} |`)
761
+ .join('\n') || '| OK | none | no-findings | | | No engineering standards findings. |';
762
+ const truncated = options.findings.length > detailLimit
763
+ ? `\n\nDetail rows truncated to ${detailLimit} of ${options.findings.length}. The baseline file contains the complete machine-readable list.\n`
764
+ : '';
765
+ return `# SCALE Engineering Standards Legacy Debt Classification
766
+
767
+ Generated: ${new Date().toISOString()}
768
+ Task: ${options.taskId ?? 'unspecified'}
769
+ Baseline written: ${options.wroteBaseline ? 'yes' : 'no'}
770
+ Baseline path: ${options.baselinePath}
771
+ Baseline entries: ${options.baselineEntries.length}
772
+
773
+ ## Summary
774
+
775
+ | Metric | Value |
776
+ | --- | ---: |
777
+ | Files scanned | ${options.debt.filesScanned} |
778
+ | Total findings | ${options.debt.totalFindings} |
779
+ | Blocking findings | ${options.debt.blockingFindings} |
780
+ | Warnings | ${options.debt.bySeverity.warn} |
781
+ | Info | ${options.debt.bySeverity.info} |
782
+
783
+ ## By Category
784
+
785
+ | Category | Total | Blocking | Warn | Info |
786
+ | --- | ---: | ---: | ---: | ---: |
787
+ ${categories}
788
+
789
+ ## By Scope
790
+
791
+ | Scope | Total | Blocking | Warn | Info |
792
+ | --- | ---: | ---: | ---: | ---: |
793
+ ${scopes}
794
+
795
+ ## By Rule
796
+
797
+ | Rule | Category | Total | Blocking | Warn | Info |
798
+ | --- | --- | ---: | ---: | ---: | ---: |
799
+ ${rules}
800
+
801
+ ## Top Files
802
+
803
+ | Path | Total | Blocking | Warn | Info |
804
+ | --- | ---: | ---: | ---: | ---: |
805
+ ${files}
806
+
807
+ ## Finding Details
808
+
809
+ | Severity | Category | Rule | Path | Line | Message |
810
+ | --- | --- | --- | --- | ---: | --- |
811
+ ${details}${truncated}
812
+ `;
813
+ }
814
+ function summarizeStandards(filesScanned, findings) {
815
+ const bySeverity = { info: 0, warn: 0, fail: 0 };
816
+ const byCategory = emptyCategorySummary();
817
+ for (const finding of findings) {
818
+ bySeverity[finding.severity] += 1;
819
+ byCategory[finding.category] += 1;
820
+ }
821
+ return {
822
+ filesScanned,
823
+ totalFindings: findings.length,
824
+ blockingFindings: findings.filter(finding => finding.severity === 'fail').length,
825
+ bySeverity,
826
+ byCategory,
827
+ };
828
+ }
829
+ function emptyCategorySummary() {
830
+ return {
831
+ logging: 0,
832
+ security: 0,
833
+ database: 0,
834
+ architecture: 0,
835
+ 'code-quality': 0,
836
+ framework: 0,
837
+ testing: 0,
838
+ uiux: 0,
839
+ };
840
+ }
841
+ function emptyDebtCategorySummary() {
842
+ return {
843
+ logging: emptyDebtGroup(),
844
+ security: emptyDebtGroup(),
845
+ database: emptyDebtGroup(),
846
+ architecture: emptyDebtGroup(),
847
+ 'code-quality': emptyDebtGroup(),
848
+ framework: emptyDebtGroup(),
849
+ testing: emptyDebtGroup(),
850
+ uiux: emptyDebtGroup(),
851
+ };
852
+ }
853
+ function emptyDebtScopeSummary() {
854
+ return {
855
+ production: emptyDebtGroup(),
856
+ test: emptyDebtGroup(),
857
+ generated: emptyDebtGroup(),
858
+ };
859
+ }
860
+ function emptyDebtGroup() {
861
+ return {
862
+ total: 0,
863
+ blocking: 0,
864
+ warn: 0,
865
+ info: 0,
866
+ };
867
+ }
868
+ function classifyDebtScope(path) {
869
+ const normalized = normalizePath(path).toLowerCase();
870
+ if (normalized.includes('/dist/') ||
871
+ normalized.includes('/build/') ||
872
+ normalized.includes('/coverage/') ||
873
+ normalized.includes('/vendor') ||
874
+ normalized.includes('/generated/') ||
875
+ normalized.includes('/assets/web-auth/js/vendor-') ||
876
+ normalized.includes('/auth/js/vendor-') ||
877
+ normalized.endsWith('.min.js') ||
878
+ normalized.endsWith('.bundle.js')) {
879
+ return 'generated';
880
+ }
881
+ if (/(^|\/)(__tests__|tests?|e2e|spec)(\/|$)/.test(normalized) ||
882
+ /\.(test|spec)\.[cm]?[jt]sx?$/.test(normalized) ||
883
+ normalized.endsWith('test.java') ||
884
+ normalized.endsWith('tests.java')) {
885
+ return 'test';
886
+ }
887
+ return 'production';
888
+ }
889
+ function incrementDebtGroup(group, severity) {
890
+ group.total += 1;
891
+ if (severity === 'fail')
892
+ group.blocking += 1;
893
+ if (severity === 'warn')
894
+ group.warn += 1;
895
+ if (severity === 'info')
896
+ group.info += 1;
897
+ }
898
+ function compareFindings(a, b) {
899
+ return a.path.localeCompare(b.path) ||
900
+ a.ruleId.localeCompare(b.ruleId) ||
901
+ (a.line ?? 0) - (b.line ?? 0) ||
902
+ a.message.localeCompare(b.message);
903
+ }
904
+ function applyRuleSeverityPolicy(finding, policy) {
905
+ if (finding.severity === 'fail' || !policy.blockingRules.includes(finding.ruleId))
906
+ return finding;
907
+ return {
908
+ ...finding,
909
+ severity: 'fail',
910
+ message: `${finding.message} This rule is configured as blocking.`,
911
+ };
912
+ }
913
+ function scanBannedImports(path, line, lineNumber, evidence, frameworks) {
914
+ if (!/\bimport\b|\brequire\s*\(/.test(line))
915
+ return [];
916
+ return frameworks.bannedImports
917
+ .filter(rule => importsSource(line, rule.source))
918
+ .map(rule => ({
919
+ severity: rule.severity ?? 'fail',
920
+ category: 'framework',
921
+ ruleId: 'banned-import',
922
+ path,
923
+ line: lineNumber,
924
+ message: `Import from "${rule.source}" violates the framework catalog.${rule.reason ? ` ${rule.reason}` : ''}`,
925
+ evidence,
926
+ fix: rule.replacement
927
+ ? `Use ${rule.replacement} instead.`
928
+ : 'Use the project-approved framework, ORM, component, or boundary from .scale/frameworks.json.',
929
+ }));
930
+ }
931
+ function importsSource(line, source) {
932
+ const escaped = escapeRegex(source);
933
+ const sourceBoundary = `(?:['"]|/)`;
934
+ return new RegExp(`\\bfrom\\s+['"]${escaped}${sourceBoundary}|\\brequire\\s*\\(\\s*['"]${escaped}${sourceBoundary}`).test(line);
935
+ }
936
+ function isFrameworkCatalogStale(lastReviewedAt, reviewIntervalDays, now) {
937
+ const reviewedAt = new Date(`${lastReviewedAt}T00:00:00Z`);
938
+ if (Number.isNaN(reviewedAt.getTime()) || reviewIntervalDays <= 0)
939
+ return false;
940
+ return now.getTime() - reviewedAt.getTime() > reviewIntervalDays * 24 * 60 * 60 * 1000;
941
+ }
942
+ function sensitiveFieldPattern(policy) {
943
+ const fields = policy.logging.sensitiveFields.map(escapeRegex).join('|');
944
+ return new RegExp(`\\b(?:${fields})\\b`, 'i');
945
+ }
946
+ function isLogCall(line) {
947
+ return /\b(?:console\.(?:log|debug|info|warn|error)|logger\.(?:trace|debug|info|warn|error|fatal)|log(?:ger)?\.(?:trace|debug|info|warn|error|fatal)|log[A-Za-z0-9_]*\s*\()\b/.test(line);
948
+ }
949
+ function isAdHocOutputCall(line) {
950
+ for (const match of line.matchAll(/\bconsole\.(?:log|debug|info|warn|error)\s*\(|\bfmt\.Print(?:f|ln)?\s*\(|\bprint(?:ln)?\s*\(|\bSystem\.out\.print(?:ln)?\s*\(|\bConsole\.Write(?:Line)?\s*\(|\bprintln!\s*\(/g)) {
951
+ if (match.index !== undefined &&
952
+ !isInsideQuotedString(line, match.index) &&
953
+ !isInsideRegexLiteral(line, match.index)) {
954
+ return true;
955
+ }
956
+ }
957
+ return false;
958
+ }
959
+ function isHardcodedSecret(line, policy) {
960
+ const fields = policy.logging.sensitiveFields.map(escapeRegex).join('|');
961
+ const match = new RegExp(`\\b\\w*(?:${fields})\\w*\\b\\s*[:=]\\s*(['"\`])([^'"\`]{12,})\\1`, 'i').exec(line);
962
+ if (!match)
963
+ return false;
964
+ return !/\b(example|sample|placeholder|changeme|replace-me|dummy|test-value)\b/i.test(match[2]);
965
+ }
966
+ function isRawSqlConstruction(line) {
967
+ return /\b(?:query|execute|exec|raw|rawQuery)\s*\(/i.test(line) &&
968
+ /\b(?:SELECT|INSERT|UPDATE|DELETE|DROP|TRUNCATE)\b/i.test(line) &&
969
+ (line.includes('+') || line.includes('${') || /\breq\./.test(line));
970
+ }
971
+ function isConsoleAllowed(path, policy) {
972
+ const normalized = normalizePath(path);
973
+ if (policy.allowedConsoleFiles.map(normalizePath).includes(normalized))
974
+ return true;
975
+ return policy.allowedConsoleDirectories
976
+ .map(normalizePath)
977
+ .some(prefix => normalized === prefix || normalized.startsWith(`${prefix}/`));
978
+ }
979
+ function isOuterLayerPath(path) {
980
+ return /(^|\/)(api|controller|controllers|handler|handlers|routes|pages)(\/|$)/i.test(path);
981
+ }
982
+ function importsInnerPersistence(line) {
983
+ return /\bimport\b.*(?:repository|repositories|dao|model|models|entity|entities|infra|infrastructure)|\bfrom\s+['"].*(?:repository|repositories|dao|model|models|entity|entities|infra|infrastructure)/i.test(line);
984
+ }
985
+ function isNonExecutablePatternLine(line) {
986
+ const trimmed = line.trim();
987
+ if (trimmed.includes('String.raw`') || trimmed.startsWith('templateBody:'))
988
+ return true;
989
+ return /^\/.*\/[dgimsuy]*,?$/.test(trimmed) ||
990
+ /^\/.*\/[dgimsuy]*,?\s*\/\/.*$/.test(trimmed) ||
991
+ /^\/.*\/[dgimsuy]*\.(?:test|exec)\(/.test(trimmed) ||
992
+ /^return\s+\/.*\/[dgimsuy]*\.(?:test|exec)\(/.test(trimmed) ||
993
+ /=\s*\/.*\/[dgimsuy]*\s*(?:[),;]|$)/.test(trimmed) ||
994
+ /^pattern:\s*\/.*\/[dgimsuy]*,?$/.test(trimmed) ||
995
+ /\(\s*\/.*\/[dgimsuy]*\.(?:test|exec)\(/.test(trimmed);
996
+ }
997
+ function updateTemplateLiteralState(line, currentlyInside) {
998
+ let inside = currentlyInside;
999
+ let escaped = false;
1000
+ for (let index = 0; index < line.length; index += 1) {
1001
+ const char = line[index];
1002
+ const next = line[index + 1];
1003
+ if (!inside && char === '/' && next === '/')
1004
+ break;
1005
+ if (escaped) {
1006
+ escaped = false;
1007
+ continue;
1008
+ }
1009
+ if (char === '\\') {
1010
+ escaped = true;
1011
+ continue;
1012
+ }
1013
+ if (char === '`')
1014
+ inside = !inside;
1015
+ }
1016
+ return inside;
1017
+ }
1018
+ function isInsideQuotedString(line, targetIndex) {
1019
+ let quote = null;
1020
+ let escaped = false;
1021
+ for (let index = 0; index < targetIndex; index += 1) {
1022
+ const char = line[index];
1023
+ const next = line[index + 1];
1024
+ if (!quote && char === '/' && next === '/')
1025
+ break;
1026
+ if (escaped) {
1027
+ escaped = false;
1028
+ continue;
1029
+ }
1030
+ if (char === '\\') {
1031
+ escaped = true;
1032
+ continue;
1033
+ }
1034
+ if (quote) {
1035
+ if (char === quote)
1036
+ quote = null;
1037
+ continue;
1038
+ }
1039
+ if (char === '"' || char === "'" || char === '`')
1040
+ quote = char;
1041
+ }
1042
+ return quote !== null;
1043
+ }
1044
+ function isInsideRegexLiteral(line, targetIndex) {
1045
+ let quote = null;
1046
+ let escaped = false;
1047
+ let regexOpen = false;
1048
+ for (let index = 0; index < targetIndex; index += 1) {
1049
+ const char = line[index];
1050
+ const next = line[index + 1];
1051
+ if (!quote && !regexOpen && char === '/' && next === '/')
1052
+ break;
1053
+ if (escaped) {
1054
+ escaped = false;
1055
+ continue;
1056
+ }
1057
+ if (char === '\\') {
1058
+ escaped = true;
1059
+ continue;
1060
+ }
1061
+ if (quote) {
1062
+ if (char === quote)
1063
+ quote = null;
1064
+ continue;
1065
+ }
1066
+ if (!regexOpen && (char === '"' || char === "'" || char === '`')) {
1067
+ quote = char;
1068
+ continue;
1069
+ }
1070
+ if (char === '/') {
1071
+ regexOpen = !regexOpen;
1072
+ }
1073
+ }
1074
+ return regexOpen;
1075
+ }
1076
+ function isAllowedFindingPattern(finding, policy) {
1077
+ return policy.allowedFindingPatterns.some(item => {
1078
+ if (item.ruleId !== finding.ruleId)
1079
+ return false;
1080
+ if (item.path && normalizePath(item.path) !== normalizePath(finding.path))
1081
+ return false;
1082
+ if (item.evidencePattern && !new RegExp(item.evidencePattern).test(finding.evidence ?? ''))
1083
+ return false;
1084
+ if (item.messagePattern && !new RegExp(item.messagePattern).test(finding.message))
1085
+ return false;
1086
+ return true;
1087
+ });
1088
+ }
1089
+ function isBaselineFinding(finding, baselineFindings) {
1090
+ return baselineFindings.some(item => item.ruleId === finding.ruleId &&
1091
+ normalizePath(item.path) === normalizePath(finding.path) &&
1092
+ (item.line === undefined || item.line === finding.line));
1093
+ }
1094
+ function dedupeFindings(findings) {
1095
+ const seen = new Set();
1096
+ return findings.filter(finding => {
1097
+ const key = `${finding.ruleId}:${finding.path}:${finding.line ?? 0}`;
1098
+ if (seen.has(key))
1099
+ return false;
1100
+ seen.add(key);
1101
+ return true;
1102
+ });
1103
+ }
1104
+ function normalizePath(path) {
1105
+ return path.split(sep).join('/').replace(/^\.\//, '');
1106
+ }
1107
+ function escapeRegex(value) {
1108
+ return value.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
1109
+ }
1110
+ function escapeCell(value) {
1111
+ return value.replace(/\|/g, '\\|').replace(/\r?\n/g, ' ');
1112
+ }
1113
+ //# sourceMappingURL=EngineeringStandards.js.map