@planu/cli 0.30.1 → 0.32.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 (658) hide show
  1. package/dist/config/ide-registry.json +204 -0
  2. package/dist/config/injection-patterns.json +30 -0
  3. package/dist/config/known-cves.json +41 -0
  4. package/dist/config/license-plans.json +26 -2
  5. package/dist/config/llm-providers.json +198 -0
  6. package/dist/config/model-equivalences.json +41 -0
  7. package/dist/config/model-language-affinity.json +16 -0
  8. package/dist/config/orchestration-templates.json +76 -0
  9. package/dist/config/orchestration-topologies.json +36 -0
  10. package/dist/config/plugin-marketplace.json +59 -0
  11. package/dist/config/security-runtime-config.json +26 -0
  12. package/dist/config/workers-registry.json +100 -0
  13. package/dist/engine/deleter/audit-logger.d.ts +11 -0
  14. package/dist/engine/deleter/audit-logger.d.ts.map +1 -0
  15. package/dist/engine/deleter/audit-logger.js +30 -0
  16. package/dist/engine/deleter/audit-logger.js.map +1 -0
  17. package/dist/engine/deleter/core.d.ts +39 -0
  18. package/dist/engine/deleter/core.d.ts.map +1 -0
  19. package/dist/engine/deleter/core.js +267 -0
  20. package/dist/engine/deleter/core.js.map +1 -0
  21. package/dist/engine/deleter/trash-manager.d.ts +18 -0
  22. package/dist/engine/deleter/trash-manager.d.ts.map +1 -0
  23. package/dist/engine/deleter/trash-manager.js +92 -0
  24. package/dist/engine/deleter/trash-manager.js.map +1 -0
  25. package/dist/engine/github/adapters/bitbucket-adapter.d.ts +12 -0
  26. package/dist/engine/github/adapters/bitbucket-adapter.d.ts.map +1 -0
  27. package/dist/engine/github/adapters/bitbucket-adapter.js +32 -0
  28. package/dist/engine/github/adapters/bitbucket-adapter.js.map +1 -0
  29. package/dist/engine/github/adapters/github-adapter.d.ts +20 -0
  30. package/dist/engine/github/adapters/github-adapter.d.ts.map +1 -0
  31. package/dist/engine/github/adapters/github-adapter.js +221 -0
  32. package/dist/engine/github/adapters/github-adapter.js.map +1 -0
  33. package/dist/engine/github/adapters/gitlab-adapter.d.ts +12 -0
  34. package/dist/engine/github/adapters/gitlab-adapter.d.ts.map +1 -0
  35. package/dist/engine/github/adapters/gitlab-adapter.js +32 -0
  36. package/dist/engine/github/adapters/gitlab-adapter.js.map +1 -0
  37. package/dist/engine/github/adapters/index.d.ts +4 -0
  38. package/dist/engine/github/adapters/index.d.ts.map +1 -0
  39. package/dist/engine/github/adapters/index.js +5 -0
  40. package/dist/engine/github/adapters/index.js.map +1 -0
  41. package/dist/engine/github/auth.d.ts +13 -0
  42. package/dist/engine/github/auth.d.ts.map +1 -0
  43. package/dist/engine/github/auth.js +59 -0
  44. package/dist/engine/github/auth.js.map +1 -0
  45. package/dist/engine/github/changelog.d.ts +26 -0
  46. package/dist/engine/github/changelog.d.ts.map +1 -0
  47. package/dist/engine/github/changelog.js +117 -0
  48. package/dist/engine/github/changelog.js.map +1 -0
  49. package/dist/engine/github/ci-status.d.ts +13 -0
  50. package/dist/engine/github/ci-status.d.ts.map +1 -0
  51. package/dist/engine/github/ci-status.js +32 -0
  52. package/dist/engine/github/ci-status.js.map +1 -0
  53. package/dist/engine/github/client.d.ts +18 -0
  54. package/dist/engine/github/client.d.ts.map +1 -0
  55. package/dist/engine/github/client.js +55 -0
  56. package/dist/engine/github/client.js.map +1 -0
  57. package/dist/engine/github/gh-cli.d.ts +22 -0
  58. package/dist/engine/github/gh-cli.d.ts.map +1 -0
  59. package/dist/engine/github/gh-cli.js +53 -0
  60. package/dist/engine/github/gh-cli.js.map +1 -0
  61. package/dist/engine/github/index.d.ts +9 -0
  62. package/dist/engine/github/index.d.ts.map +1 -0
  63. package/dist/engine/github/index.js +10 -0
  64. package/dist/engine/github/index.js.map +1 -0
  65. package/dist/engine/github/pr-template.d.ts +17 -0
  66. package/dist/engine/github/pr-template.d.ts.map +1 -0
  67. package/dist/engine/github/pr-template.js +79 -0
  68. package/dist/engine/github/pr-template.js.map +1 -0
  69. package/dist/engine/github/review-analyzer.d.ts +19 -0
  70. package/dist/engine/github/review-analyzer.d.ts.map +1 -0
  71. package/dist/engine/github/review-analyzer.js +146 -0
  72. package/dist/engine/github/review-analyzer.js.map +1 -0
  73. package/dist/engine/github/spec-linker.d.ts +18 -0
  74. package/dist/engine/github/spec-linker.d.ts.map +1 -0
  75. package/dist/engine/github/spec-linker.js +54 -0
  76. package/dist/engine/github/spec-linker.js.map +1 -0
  77. package/dist/engine/ide-config/core.d.ts +14 -0
  78. package/dist/engine/ide-config/core.d.ts.map +1 -0
  79. package/dist/engine/ide-config/core.js +103 -0
  80. package/dist/engine/ide-config/core.js.map +1 -0
  81. package/dist/engine/ide-config/detector.d.ts +18 -0
  82. package/dist/engine/ide-config/detector.d.ts.map +1 -0
  83. package/dist/engine/ide-config/detector.js +97 -0
  84. package/dist/engine/ide-config/detector.js.map +1 -0
  85. package/dist/engine/ide-config/generators.d.ts +6 -0
  86. package/dist/engine/ide-config/generators.d.ts.map +1 -0
  87. package/dist/engine/ide-config/generators.js +146 -0
  88. package/dist/engine/ide-config/generators.js.map +1 -0
  89. package/dist/engine/ide-config/index.d.ts +6 -0
  90. package/dist/engine/ide-config/index.d.ts.map +1 -0
  91. package/dist/engine/ide-config/index.js +7 -0
  92. package/dist/engine/ide-config/index.js.map +1 -0
  93. package/dist/engine/ide-config/path-resolver.d.ts +23 -0
  94. package/dist/engine/ide-config/path-resolver.d.ts.map +1 -0
  95. package/dist/engine/ide-config/path-resolver.js +55 -0
  96. package/dist/engine/ide-config/path-resolver.js.map +1 -0
  97. package/dist/engine/ide-config/validator.d.ts +7 -0
  98. package/dist/engine/ide-config/validator.d.ts.map +1 -0
  99. package/dist/engine/ide-config/validator.js +55 -0
  100. package/dist/engine/ide-config/validator.js.map +1 -0
  101. package/dist/engine/license-validator/lemon-squeezy.d.ts.map +1 -1
  102. package/dist/engine/license-validator/lemon-squeezy.js +16 -12
  103. package/dist/engine/license-validator/lemon-squeezy.js.map +1 -1
  104. package/dist/engine/llm-providers/cost-optimizer.d.ts +26 -0
  105. package/dist/engine/llm-providers/cost-optimizer.d.ts.map +1 -0
  106. package/dist/engine/llm-providers/cost-optimizer.js +101 -0
  107. package/dist/engine/llm-providers/cost-optimizer.js.map +1 -0
  108. package/dist/engine/llm-providers/cost-tracker.d.ts +26 -0
  109. package/dist/engine/llm-providers/cost-tracker.d.ts.map +1 -0
  110. package/dist/engine/llm-providers/cost-tracker.js +75 -0
  111. package/dist/engine/llm-providers/cost-tracker.js.map +1 -0
  112. package/dist/engine/llm-providers/failover-chain.d.ts +23 -0
  113. package/dist/engine/llm-providers/failover-chain.d.ts.map +1 -0
  114. package/dist/engine/llm-providers/failover-chain.js +88 -0
  115. package/dist/engine/llm-providers/failover-chain.js.map +1 -0
  116. package/dist/engine/llm-providers/health-checker.d.ts +18 -0
  117. package/dist/engine/llm-providers/health-checker.d.ts.map +1 -0
  118. package/dist/engine/llm-providers/health-checker.js +45 -0
  119. package/dist/engine/llm-providers/health-checker.js.map +1 -0
  120. package/dist/engine/llm-providers/index.d.ts +10 -0
  121. package/dist/engine/llm-providers/index.d.ts.map +1 -0
  122. package/dist/engine/llm-providers/index.js +11 -0
  123. package/dist/engine/llm-providers/index.js.map +1 -0
  124. package/dist/engine/llm-providers/key-manager.d.ts +23 -0
  125. package/dist/engine/llm-providers/key-manager.d.ts.map +1 -0
  126. package/dist/engine/llm-providers/key-manager.js +47 -0
  127. package/dist/engine/llm-providers/key-manager.js.map +1 -0
  128. package/dist/engine/llm-providers/load-balancer.d.ts +13 -0
  129. package/dist/engine/llm-providers/load-balancer.d.ts.map +1 -0
  130. package/dist/engine/llm-providers/load-balancer.js +94 -0
  131. package/dist/engine/llm-providers/load-balancer.js.map +1 -0
  132. package/dist/engine/llm-providers/provider-adapter.d.ts +25 -0
  133. package/dist/engine/llm-providers/provider-adapter.d.ts.map +1 -0
  134. package/dist/engine/llm-providers/provider-adapter.js +86 -0
  135. package/dist/engine/llm-providers/provider-adapter.js.map +1 -0
  136. package/dist/engine/llm-providers/rate-limiter.d.ts +29 -0
  137. package/dist/engine/llm-providers/rate-limiter.d.ts.map +1 -0
  138. package/dist/engine/llm-providers/rate-limiter.js +70 -0
  139. package/dist/engine/llm-providers/rate-limiter.js.map +1 -0
  140. package/dist/engine/orchestrator/agent-spawner.d.ts +22 -0
  141. package/dist/engine/orchestrator/agent-spawner.d.ts.map +1 -0
  142. package/dist/engine/orchestrator/agent-spawner.js +117 -0
  143. package/dist/engine/orchestrator/agent-spawner.js.map +1 -0
  144. package/dist/engine/orchestrator/conflict-resolver.d.ts +11 -0
  145. package/dist/engine/orchestrator/conflict-resolver.d.ts.map +1 -0
  146. package/dist/engine/orchestrator/conflict-resolver.js +81 -0
  147. package/dist/engine/orchestrator/conflict-resolver.js.map +1 -0
  148. package/dist/engine/orchestrator/file-ownership.d.ts +25 -0
  149. package/dist/engine/orchestrator/file-ownership.d.ts.map +1 -0
  150. package/dist/engine/orchestrator/file-ownership.js +62 -0
  151. package/dist/engine/orchestrator/file-ownership.js.map +1 -0
  152. package/dist/engine/orchestrator/handoff-generator.d.ts +20 -0
  153. package/dist/engine/orchestrator/handoff-generator.d.ts.map +1 -0
  154. package/dist/engine/orchestrator/handoff-generator.js +95 -0
  155. package/dist/engine/orchestrator/handoff-generator.js.map +1 -0
  156. package/dist/engine/orchestrator/index.d.ts +10 -0
  157. package/dist/engine/orchestrator/index.d.ts.map +1 -0
  158. package/dist/engine/orchestrator/index.js +11 -0
  159. package/dist/engine/orchestrator/index.js.map +1 -0
  160. package/dist/engine/orchestrator/progress-tracker.d.ts +32 -0
  161. package/dist/engine/orchestrator/progress-tracker.d.ts.map +1 -0
  162. package/dist/engine/orchestrator/progress-tracker.js +102 -0
  163. package/dist/engine/orchestrator/progress-tracker.js.map +1 -0
  164. package/dist/engine/orchestrator/result-collector.d.ts +23 -0
  165. package/dist/engine/orchestrator/result-collector.d.ts.map +1 -0
  166. package/dist/engine/orchestrator/result-collector.js +124 -0
  167. package/dist/engine/orchestrator/result-collector.js.map +1 -0
  168. package/dist/engine/orchestrator/runtime.d.ts +21 -0
  169. package/dist/engine/orchestrator/runtime.d.ts.map +1 -0
  170. package/dist/engine/orchestrator/runtime.js +231 -0
  171. package/dist/engine/orchestrator/runtime.js.map +1 -0
  172. package/dist/engine/orchestrator/task-distributor.d.ts +8 -0
  173. package/dist/engine/orchestrator/task-distributor.d.ts.map +1 -0
  174. package/dist/engine/orchestrator/task-distributor.js +106 -0
  175. package/dist/engine/orchestrator/task-distributor.js.map +1 -0
  176. package/dist/engine/orchestrator/topologies.d.ts +30 -0
  177. package/dist/engine/orchestrator/topologies.d.ts.map +1 -0
  178. package/dist/engine/orchestrator/topologies.js +89 -0
  179. package/dist/engine/orchestrator/topologies.js.map +1 -0
  180. package/dist/engine/plugins/compatibility.d.ts +24 -0
  181. package/dist/engine/plugins/compatibility.d.ts.map +1 -0
  182. package/dist/engine/plugins/compatibility.js +140 -0
  183. package/dist/engine/plugins/compatibility.js.map +1 -0
  184. package/dist/engine/plugins/doc-generator.d.ts +6 -0
  185. package/dist/engine/plugins/doc-generator.d.ts.map +1 -0
  186. package/dist/engine/plugins/doc-generator.js +79 -0
  187. package/dist/engine/plugins/doc-generator.js.map +1 -0
  188. package/dist/engine/plugins/extensions/analyzer-extension.d.ts +26 -0
  189. package/dist/engine/plugins/extensions/analyzer-extension.d.ts.map +1 -0
  190. package/dist/engine/plugins/extensions/analyzer-extension.js +100 -0
  191. package/dist/engine/plugins/extensions/analyzer-extension.js.map +1 -0
  192. package/dist/engine/plugins/extensions/template-extension.d.ts +25 -0
  193. package/dist/engine/plugins/extensions/template-extension.d.ts.map +1 -0
  194. package/dist/engine/plugins/extensions/template-extension.js +65 -0
  195. package/dist/engine/plugins/extensions/template-extension.js.map +1 -0
  196. package/dist/engine/plugins/extensions/tool-extension.d.ts +34 -0
  197. package/dist/engine/plugins/extensions/tool-extension.d.ts.map +1 -0
  198. package/dist/engine/plugins/extensions/tool-extension.js +80 -0
  199. package/dist/engine/plugins/extensions/tool-extension.js.map +1 -0
  200. package/dist/engine/plugins/extensions/worker-extension.d.ts +24 -0
  201. package/dist/engine/plugins/extensions/worker-extension.d.ts.map +1 -0
  202. package/dist/engine/plugins/extensions/worker-extension.js +88 -0
  203. package/dist/engine/plugins/extensions/worker-extension.js.map +1 -0
  204. package/dist/engine/plugins/index.d.ts +11 -0
  205. package/dist/engine/plugins/index.d.ts.map +1 -0
  206. package/dist/engine/plugins/index.js +12 -0
  207. package/dist/engine/plugins/index.js.map +1 -0
  208. package/dist/engine/plugins/lifecycle.d.ts +26 -0
  209. package/dist/engine/plugins/lifecycle.d.ts.map +1 -0
  210. package/dist/engine/plugins/lifecycle.js +208 -0
  211. package/dist/engine/plugins/lifecycle.js.map +1 -0
  212. package/dist/engine/plugins/loader.d.ts +17 -0
  213. package/dist/engine/plugins/loader.d.ts.map +1 -0
  214. package/dist/engine/plugins/loader.js +113 -0
  215. package/dist/engine/plugins/loader.js.map +1 -0
  216. package/dist/engine/plugins/sandbox.d.ts +20 -0
  217. package/dist/engine/plugins/sandbox.d.ts.map +1 -0
  218. package/dist/engine/plugins/sandbox.js +111 -0
  219. package/dist/engine/plugins/sandbox.js.map +1 -0
  220. package/dist/engine/plugins/validator.d.ts +18 -0
  221. package/dist/engine/plugins/validator.d.ts.map +1 -0
  222. package/dist/engine/plugins/validator.js +125 -0
  223. package/dist/engine/plugins/validator.js.map +1 -0
  224. package/dist/engine/runtime-security/audit-logger.d.ts +7 -0
  225. package/dist/engine/runtime-security/audit-logger.d.ts.map +1 -0
  226. package/dist/engine/runtime-security/audit-logger.js +120 -0
  227. package/dist/engine/runtime-security/audit-logger.js.map +1 -0
  228. package/dist/engine/runtime-security/checkers/command-injection.d.ts +3 -0
  229. package/dist/engine/runtime-security/checkers/command-injection.d.ts.map +1 -0
  230. package/dist/engine/runtime-security/checkers/command-injection.js +91 -0
  231. package/dist/engine/runtime-security/checkers/command-injection.js.map +1 -0
  232. package/dist/engine/runtime-security/checkers/content-security.d.ts +3 -0
  233. package/dist/engine/runtime-security/checkers/content-security.d.ts.map +1 -0
  234. package/dist/engine/runtime-security/checkers/content-security.js +106 -0
  235. package/dist/engine/runtime-security/checkers/content-security.js.map +1 -0
  236. package/dist/engine/runtime-security/checkers/dependency-vuln.d.ts +4 -0
  237. package/dist/engine/runtime-security/checkers/dependency-vuln.d.ts.map +1 -0
  238. package/dist/engine/runtime-security/checkers/dependency-vuln.js +93 -0
  239. package/dist/engine/runtime-security/checkers/dependency-vuln.js.map +1 -0
  240. package/dist/engine/runtime-security/checkers/file-permissions.d.ts +3 -0
  241. package/dist/engine/runtime-security/checkers/file-permissions.d.ts.map +1 -0
  242. package/dist/engine/runtime-security/checkers/file-permissions.js +60 -0
  243. package/dist/engine/runtime-security/checkers/file-permissions.js.map +1 -0
  244. package/dist/engine/runtime-security/checkers/input-sanitizer.d.ts +4 -0
  245. package/dist/engine/runtime-security/checkers/input-sanitizer.d.ts.map +1 -0
  246. package/dist/engine/runtime-security/checkers/input-sanitizer.js +101 -0
  247. package/dist/engine/runtime-security/checkers/input-sanitizer.js.map +1 -0
  248. package/dist/engine/runtime-security/checkers/path-traversal.d.ts +3 -0
  249. package/dist/engine/runtime-security/checkers/path-traversal.d.ts.map +1 -0
  250. package/dist/engine/runtime-security/checkers/path-traversal.js +102 -0
  251. package/dist/engine/runtime-security/checkers/path-traversal.js.map +1 -0
  252. package/dist/engine/runtime-security/checkers/prompt-injection.d.ts +7 -0
  253. package/dist/engine/runtime-security/checkers/prompt-injection.d.ts.map +1 -0
  254. package/dist/engine/runtime-security/checkers/prompt-injection.js +103 -0
  255. package/dist/engine/runtime-security/checkers/prompt-injection.js.map +1 -0
  256. package/dist/engine/runtime-security/checkers/sensitive-data.d.ts +3 -0
  257. package/dist/engine/runtime-security/checkers/sensitive-data.d.ts.map +1 -0
  258. package/dist/engine/runtime-security/checkers/sensitive-data.js +71 -0
  259. package/dist/engine/runtime-security/checkers/sensitive-data.js.map +1 -0
  260. package/dist/engine/runtime-security/index.d.ts +12 -0
  261. package/dist/engine/runtime-security/index.d.ts.map +1 -0
  262. package/dist/engine/runtime-security/index.js +13 -0
  263. package/dist/engine/runtime-security/index.js.map +1 -0
  264. package/dist/engine/runtime-security/rate-limiter.d.ts +5 -0
  265. package/dist/engine/runtime-security/rate-limiter.d.ts.map +1 -0
  266. package/dist/engine/runtime-security/rate-limiter.js +91 -0
  267. package/dist/engine/runtime-security/rate-limiter.js.map +1 -0
  268. package/dist/engine/runtime-security/validator.d.ts +9 -0
  269. package/dist/engine/runtime-security/validator.d.ts.map +1 -0
  270. package/dist/engine/runtime-security/validator.js +118 -0
  271. package/dist/engine/runtime-security/validator.js.map +1 -0
  272. package/dist/engine/session/auto-save.d.ts +18 -0
  273. package/dist/engine/session/auto-save.d.ts.map +1 -0
  274. package/dist/engine/session/auto-save.js +96 -0
  275. package/dist/engine/session/auto-save.js.map +1 -0
  276. package/dist/engine/session/context-snapshot.d.ts +8 -0
  277. package/dist/engine/session/context-snapshot.d.ts.map +1 -0
  278. package/dist/engine/session/context-snapshot.js +49 -0
  279. package/dist/engine/session/context-snapshot.js.map +1 -0
  280. package/dist/engine/session/index.d.ts +6 -0
  281. package/dist/engine/session/index.d.ts.map +1 -0
  282. package/dist/engine/session/index.js +7 -0
  283. package/dist/engine/session/index.js.map +1 -0
  284. package/dist/engine/session/memory-sync.d.ts +12 -0
  285. package/dist/engine/session/memory-sync.d.ts.map +1 -0
  286. package/dist/engine/session/memory-sync.js +34 -0
  287. package/dist/engine/session/memory-sync.js.map +1 -0
  288. package/dist/engine/session/session-diff.d.ts +11 -0
  289. package/dist/engine/session/session-diff.d.ts.map +1 -0
  290. package/dist/engine/session/session-diff.js +42 -0
  291. package/dist/engine/session/session-diff.js.map +1 -0
  292. package/dist/engine/session/session-merge.d.ts +12 -0
  293. package/dist/engine/session/session-merge.d.ts.map +1 -0
  294. package/dist/engine/session/session-merge.js +55 -0
  295. package/dist/engine/session/session-merge.js.map +1 -0
  296. package/dist/engine/spec-templates/fintech-compliance.d.ts +4 -0
  297. package/dist/engine/spec-templates/fintech-compliance.d.ts.map +1 -0
  298. package/dist/engine/spec-templates/fintech-compliance.js +111 -0
  299. package/dist/engine/spec-templates/fintech-compliance.js.map +1 -0
  300. package/dist/engine/spec-templates/fintech-kyc.d.ts +4 -0
  301. package/dist/engine/spec-templates/fintech-kyc.d.ts.map +1 -0
  302. package/dist/engine/spec-templates/fintech-kyc.js +125 -0
  303. package/dist/engine/spec-templates/fintech-kyc.js.map +1 -0
  304. package/dist/engine/spec-templates/fintech-transactions.d.ts +4 -0
  305. package/dist/engine/spec-templates/fintech-transactions.d.ts.map +1 -0
  306. package/dist/engine/spec-templates/fintech-transactions.js +120 -0
  307. package/dist/engine/spec-templates/fintech-transactions.js.map +1 -0
  308. package/dist/engine/spec-templates/templates-industry-fintech.d.ts +3 -7
  309. package/dist/engine/spec-templates/templates-industry-fintech.d.ts.map +1 -1
  310. package/dist/engine/spec-templates/templates-industry-fintech.js +4 -348
  311. package/dist/engine/spec-templates/templates-industry-fintech.js.map +1 -1
  312. package/dist/engine/token-optimizer/batcher.d.ts +34 -0
  313. package/dist/engine/token-optimizer/batcher.d.ts.map +1 -0
  314. package/dist/engine/token-optimizer/batcher.js +89 -0
  315. package/dist/engine/token-optimizer/batcher.js.map +1 -0
  316. package/dist/engine/token-optimizer/budget.d.ts +54 -0
  317. package/dist/engine/token-optimizer/budget.d.ts.map +1 -0
  318. package/dist/engine/token-optimizer/budget.js +102 -0
  319. package/dist/engine/token-optimizer/budget.js.map +1 -0
  320. package/dist/engine/token-optimizer/context-compressor.d.ts +16 -0
  321. package/dist/engine/token-optimizer/context-compressor.d.ts.map +1 -0
  322. package/dist/engine/token-optimizer/context-compressor.js +148 -0
  323. package/dist/engine/token-optimizer/context-compressor.js.map +1 -0
  324. package/dist/engine/token-optimizer/counter.d.ts +16 -0
  325. package/dist/engine/token-optimizer/counter.d.ts.map +1 -0
  326. package/dist/engine/token-optimizer/counter.js +68 -0
  327. package/dist/engine/token-optimizer/counter.js.map +1 -0
  328. package/dist/engine/token-optimizer/deduplicator.d.ts +32 -0
  329. package/dist/engine/token-optimizer/deduplicator.d.ts.map +1 -0
  330. package/dist/engine/token-optimizer/deduplicator.js +102 -0
  331. package/dist/engine/token-optimizer/deduplicator.js.map +1 -0
  332. package/dist/engine/token-optimizer/incremental.d.ts +30 -0
  333. package/dist/engine/token-optimizer/incremental.d.ts.map +1 -0
  334. package/dist/engine/token-optimizer/incremental.js +88 -0
  335. package/dist/engine/token-optimizer/incremental.js.map +1 -0
  336. package/dist/engine/token-optimizer/index.d.ts +10 -0
  337. package/dist/engine/token-optimizer/index.d.ts.map +1 -0
  338. package/dist/engine/token-optimizer/index.js +11 -0
  339. package/dist/engine/token-optimizer/index.js.map +1 -0
  340. package/dist/engine/token-optimizer/optimizer.d.ts +47 -0
  341. package/dist/engine/token-optimizer/optimizer.d.ts.map +1 -0
  342. package/dist/engine/token-optimizer/optimizer.js +126 -0
  343. package/dist/engine/token-optimizer/optimizer.js.map +1 -0
  344. package/dist/engine/token-optimizer/reporter.d.ts +51 -0
  345. package/dist/engine/token-optimizer/reporter.d.ts.map +1 -0
  346. package/dist/engine/token-optimizer/reporter.js +143 -0
  347. package/dist/engine/token-optimizer/reporter.js.map +1 -0
  348. package/dist/engine/token-optimizer/response-cache.d.ts +49 -0
  349. package/dist/engine/token-optimizer/response-cache.d.ts.map +1 -0
  350. package/dist/engine/token-optimizer/response-cache.js +158 -0
  351. package/dist/engine/token-optimizer/response-cache.js.map +1 -0
  352. package/dist/engine/workers/handlers/code-map.d.ts +3 -0
  353. package/dist/engine/workers/handlers/code-map.d.ts.map +1 -0
  354. package/dist/engine/workers/handlers/code-map.js +227 -0
  355. package/dist/engine/workers/handlers/code-map.js.map +1 -0
  356. package/dist/engine/workers/handlers/dependency-health.d.ts +3 -0
  357. package/dist/engine/workers/handlers/dependency-health.d.ts.map +1 -0
  358. package/dist/engine/workers/handlers/dependency-health.js +254 -0
  359. package/dist/engine/workers/handlers/dependency-health.js.map +1 -0
  360. package/dist/engine/workers/handlers/documentation.d.ts +3 -0
  361. package/dist/engine/workers/handlers/documentation.d.ts.map +1 -0
  362. package/dist/engine/workers/handlers/documentation.js +207 -0
  363. package/dist/engine/workers/handlers/documentation.js.map +1 -0
  364. package/dist/engine/workers/handlers/optimization.d.ts +3 -0
  365. package/dist/engine/workers/handlers/optimization.d.ts.map +1 -0
  366. package/dist/engine/workers/handlers/optimization.js +161 -0
  367. package/dist/engine/workers/handlers/optimization.js.map +1 -0
  368. package/dist/engine/workers/handlers/security-audit.d.ts +3 -0
  369. package/dist/engine/workers/handlers/security-audit.d.ts.map +1 -0
  370. package/dist/engine/workers/handlers/security-audit.js +222 -0
  371. package/dist/engine/workers/handlers/security-audit.js.map +1 -0
  372. package/dist/engine/workers/handlers/test-gaps.d.ts +3 -0
  373. package/dist/engine/workers/handlers/test-gaps.d.ts.map +1 -0
  374. package/dist/engine/workers/handlers/test-gaps.js +186 -0
  375. package/dist/engine/workers/handlers/test-gaps.js.map +1 -0
  376. package/dist/engine/workers/index.d.ts +8 -0
  377. package/dist/engine/workers/index.d.ts.map +1 -0
  378. package/dist/engine/workers/index.js +9 -0
  379. package/dist/engine/workers/index.js.map +1 -0
  380. package/dist/engine/workers/worker-engine.d.ts +24 -0
  381. package/dist/engine/workers/worker-engine.d.ts.map +1 -0
  382. package/dist/engine/workers/worker-engine.js +233 -0
  383. package/dist/engine/workers/worker-engine.js.map +1 -0
  384. package/dist/index.js +20 -0
  385. package/dist/index.js.map +1 -1
  386. package/dist/storage/index.d.ts +1 -0
  387. package/dist/storage/index.d.ts.map +1 -1
  388. package/dist/storage/index.js +1 -0
  389. package/dist/storage/index.js.map +1 -1
  390. package/dist/storage/session-store.d.ts +20 -0
  391. package/dist/storage/session-store.d.ts.map +1 -0
  392. package/dist/storage/session-store.js +118 -0
  393. package/dist/storage/session-store.js.map +1 -0
  394. package/dist/storage/token-cache-store.d.ts +10 -0
  395. package/dist/storage/token-cache-store.d.ts.map +1 -0
  396. package/dist/storage/token-cache-store.js +67 -0
  397. package/dist/storage/token-cache-store.js.map +1 -0
  398. package/dist/storage/trash-store.d.ts +35 -0
  399. package/dist/storage/trash-store.d.ts.map +1 -0
  400. package/dist/storage/trash-store.js +163 -0
  401. package/dist/storage/trash-store.js.map +1 -0
  402. package/dist/storage/worker-store.d.ts +11 -0
  403. package/dist/storage/worker-store.d.ts.map +1 -0
  404. package/dist/storage/worker-store.js +120 -0
  405. package/dist/storage/worker-store.js.map +1 -0
  406. package/dist/tools/agent-swarm-status.d.ts +7 -0
  407. package/dist/tools/agent-swarm-status.d.ts.map +1 -0
  408. package/dist/tools/agent-swarm-status.js +94 -0
  409. package/dist/tools/agent-swarm-status.js.map +1 -0
  410. package/dist/tools/configure-llm-providers-handler.d.ts +18 -0
  411. package/dist/tools/configure-llm-providers-handler.d.ts.map +1 -0
  412. package/dist/tools/configure-llm-providers-handler.js +127 -0
  413. package/dist/tools/configure-llm-providers-handler.js.map +1 -0
  414. package/dist/tools/configure-workers-handler.d.ts +3 -0
  415. package/dist/tools/configure-workers-handler.d.ts.map +1 -0
  416. package/dist/tools/configure-workers-handler.js +116 -0
  417. package/dist/tools/configure-workers-handler.js.map +1 -0
  418. package/dist/tools/delete-decision.d.ts +7 -0
  419. package/dist/tools/delete-decision.d.ts.map +1 -0
  420. package/dist/tools/delete-decision.js +54 -0
  421. package/dist/tools/delete-decision.js.map +1 -0
  422. package/dist/tools/delete-pattern.d.ts +7 -0
  423. package/dist/tools/delete-pattern.d.ts.map +1 -0
  424. package/dist/tools/delete-pattern.js +54 -0
  425. package/dist/tools/delete-pattern.js.map +1 -0
  426. package/dist/tools/delete-project.d.ts +7 -0
  427. package/dist/tools/delete-project.d.ts.map +1 -0
  428. package/dist/tools/delete-project.js +53 -0
  429. package/dist/tools/delete-project.js.map +1 -0
  430. package/dist/tools/delete-spec.d.ts +7 -0
  431. package/dist/tools/delete-spec.d.ts.map +1 -0
  432. package/dist/tools/delete-spec.js +54 -0
  433. package/dist/tools/delete-spec.js.map +1 -0
  434. package/dist/tools/export-session.d.ts +3 -0
  435. package/dist/tools/export-session.d.ts.map +1 -0
  436. package/dist/tools/export-session.js +87 -0
  437. package/dist/tools/export-session.js.map +1 -0
  438. package/dist/tools/github-pr-handler.d.ts +13 -0
  439. package/dist/tools/github-pr-handler.d.ts.map +1 -0
  440. package/dist/tools/github-pr-handler.js +109 -0
  441. package/dist/tools/github-pr-handler.js.map +1 -0
  442. package/dist/tools/github-release-handler.d.ts +14 -0
  443. package/dist/tools/github-release-handler.d.ts.map +1 -0
  444. package/dist/tools/github-release-handler.js +55 -0
  445. package/dist/tools/github-release-handler.js.map +1 -0
  446. package/dist/tools/github-review-handler.d.ts +7 -0
  447. package/dist/tools/github-review-handler.d.ts.map +1 -0
  448. package/dist/tools/github-review-handler.js +61 -0
  449. package/dist/tools/github-review-handler.js.map +1 -0
  450. package/dist/tools/ide-config-handler.d.ts +11 -0
  451. package/dist/tools/ide-config-handler.d.ts.map +1 -0
  452. package/dist/tools/ide-config-handler.js +56 -0
  453. package/dist/tools/ide-config-handler.js.map +1 -0
  454. package/dist/tools/list-sessions.d.ts +3 -0
  455. package/dist/tools/list-sessions.d.ts.map +1 -0
  456. package/dist/tools/list-sessions.js +28 -0
  457. package/dist/tools/list-sessions.js.map +1 -0
  458. package/dist/tools/llm-provider-status-handler.d.ts +7 -0
  459. package/dist/tools/llm-provider-status-handler.d.ts.map +1 -0
  460. package/dist/tools/llm-provider-status-handler.js +63 -0
  461. package/dist/tools/llm-provider-status-handler.js.map +1 -0
  462. package/dist/tools/manage-plugins-handler.d.ts +6 -0
  463. package/dist/tools/manage-plugins-handler.d.ts.map +1 -0
  464. package/dist/tools/manage-plugins-handler.js +128 -0
  465. package/dist/tools/manage-plugins-handler.js.map +1 -0
  466. package/dist/tools/manage-trash.d.ts +7 -0
  467. package/dist/tools/manage-trash.d.ts.map +1 -0
  468. package/dist/tools/manage-trash.js +54 -0
  469. package/dist/tools/manage-trash.js.map +1 -0
  470. package/dist/tools/orchestrate-runtime.d.ts +7 -0
  471. package/dist/tools/orchestrate-runtime.d.ts.map +1 -0
  472. package/dist/tools/orchestrate-runtime.js +72 -0
  473. package/dist/tools/orchestrate-runtime.js.map +1 -0
  474. package/dist/tools/register-delete-tools.d.ts +6 -0
  475. package/dist/tools/register-delete-tools.d.ts.map +1 -0
  476. package/dist/tools/register-delete-tools.js +95 -0
  477. package/dist/tools/register-delete-tools.js.map +1 -0
  478. package/dist/tools/register-github-tools.d.ts +3 -0
  479. package/dist/tools/register-github-tools.d.ts.map +1 -0
  480. package/dist/tools/register-github-tools.js +47 -0
  481. package/dist/tools/register-github-tools.js.map +1 -0
  482. package/dist/tools/register-ide-tools.d.ts +3 -0
  483. package/dist/tools/register-ide-tools.d.ts.map +1 -0
  484. package/dist/tools/register-ide-tools.js +28 -0
  485. package/dist/tools/register-ide-tools.js.map +1 -0
  486. package/dist/tools/register-llm-provider-tools.d.ts +3 -0
  487. package/dist/tools/register-llm-provider-tools.d.ts.map +1 -0
  488. package/dist/tools/register-llm-provider-tools.js +73 -0
  489. package/dist/tools/register-llm-provider-tools.js.map +1 -0
  490. package/dist/tools/register-orchestrator-tools.d.ts +3 -0
  491. package/dist/tools/register-orchestrator-tools.d.ts.map +1 -0
  492. package/dist/tools/register-orchestrator-tools.js +68 -0
  493. package/dist/tools/register-orchestrator-tools.js.map +1 -0
  494. package/dist/tools/register-plugin-tools.d.ts +3 -0
  495. package/dist/tools/register-plugin-tools.d.ts.map +1 -0
  496. package/dist/tools/register-plugin-tools.js +27 -0
  497. package/dist/tools/register-plugin-tools.js.map +1 -0
  498. package/dist/tools/register-runtime-security-tools.d.ts +3 -0
  499. package/dist/tools/register-runtime-security-tools.d.ts.map +1 -0
  500. package/dist/tools/register-runtime-security-tools.js +19 -0
  501. package/dist/tools/register-runtime-security-tools.js.map +1 -0
  502. package/dist/tools/register-session-tools.d.ts +3 -0
  503. package/dist/tools/register-session-tools.d.ts.map +1 -0
  504. package/dist/tools/register-session-tools.js +34 -0
  505. package/dist/tools/register-session-tools.js.map +1 -0
  506. package/dist/tools/register-token-tools.d.ts +3 -0
  507. package/dist/tools/register-token-tools.d.ts.map +1 -0
  508. package/dist/tools/register-token-tools.js +17 -0
  509. package/dist/tools/register-token-tools.js.map +1 -0
  510. package/dist/tools/register-worker-tools.d.ts +3 -0
  511. package/dist/tools/register-worker-tools.d.ts.map +1 -0
  512. package/dist/tools/register-worker-tools.js +31 -0
  513. package/dist/tools/register-worker-tools.js.map +1 -0
  514. package/dist/tools/restore-session.d.ts +3 -0
  515. package/dist/tools/restore-session.d.ts.map +1 -0
  516. package/dist/tools/restore-session.js +60 -0
  517. package/dist/tools/restore-session.js.map +1 -0
  518. package/dist/tools/scaffold-plugin-handler.d.ts +6 -0
  519. package/dist/tools/scaffold-plugin-handler.d.ts.map +1 -0
  520. package/dist/tools/scaffold-plugin-handler.js +208 -0
  521. package/dist/tools/scaffold-plugin-handler.js.map +1 -0
  522. package/dist/tools/schemas/delete.d.ts +19 -0
  523. package/dist/tools/schemas/delete.d.ts.map +1 -0
  524. package/dist/tools/schemas/delete.js +12 -0
  525. package/dist/tools/schemas/delete.js.map +1 -0
  526. package/dist/tools/schemas/github.d.ts +51 -0
  527. package/dist/tools/schemas/github.d.ts.map +1 -0
  528. package/dist/tools/schemas/github.js +52 -0
  529. package/dist/tools/schemas/github.js.map +1 -0
  530. package/dist/tools/schemas/ide-config.d.ts +36 -0
  531. package/dist/tools/schemas/ide-config.d.ts.map +1 -0
  532. package/dist/tools/schemas/ide-config.js +27 -0
  533. package/dist/tools/schemas/ide-config.js.map +1 -0
  534. package/dist/tools/schemas/index.d.ts +9 -0
  535. package/dist/tools/schemas/index.d.ts.map +1 -1
  536. package/dist/tools/schemas/index.js +9 -0
  537. package/dist/tools/schemas/index.js.map +1 -1
  538. package/dist/tools/schemas/llm-provider-schemas.d.ts +26 -0
  539. package/dist/tools/schemas/llm-provider-schemas.d.ts.map +1 -0
  540. package/dist/tools/schemas/llm-provider-schemas.js +16 -0
  541. package/dist/tools/schemas/llm-provider-schemas.js.map +1 -0
  542. package/dist/tools/schemas/plugins-schemas.d.ts +40 -0
  543. package/dist/tools/schemas/plugins-schemas.d.ts.map +1 -0
  544. package/dist/tools/schemas/plugins-schemas.js +29 -0
  545. package/dist/tools/schemas/plugins-schemas.js.map +1 -0
  546. package/dist/tools/schemas/runtime-security.d.ts +12 -0
  547. package/dist/tools/schemas/runtime-security.d.ts.map +1 -0
  548. package/dist/tools/schemas/runtime-security.js +9 -0
  549. package/dist/tools/schemas/runtime-security.js.map +1 -0
  550. package/dist/tools/schemas/session.d.ts +22 -0
  551. package/dist/tools/schemas/session.d.ts.map +1 -0
  552. package/dist/tools/schemas/session.js +25 -0
  553. package/dist/tools/schemas/session.js.map +1 -0
  554. package/dist/tools/schemas/token-optimization.d.ts +12 -0
  555. package/dist/tools/schemas/token-optimization.d.ts.map +1 -0
  556. package/dist/tools/schemas/token-optimization.js +9 -0
  557. package/dist/tools/schemas/token-optimization.js.map +1 -0
  558. package/dist/tools/schemas/workers-schema.d.ts +75 -0
  559. package/dist/tools/schemas/workers-schema.d.ts.map +1 -0
  560. package/dist/tools/schemas/workers-schema.js +63 -0
  561. package/dist/tools/schemas/workers-schema.js.map +1 -0
  562. package/dist/tools/security-report-handler.d.ts +3 -0
  563. package/dist/tools/security-report-handler.d.ts.map +1 -0
  564. package/dist/tools/security-report-handler.js +66 -0
  565. package/dist/tools/security-report-handler.js.map +1 -0
  566. package/dist/tools/token-usage-handler.d.ts +15 -0
  567. package/dist/tools/token-usage-handler.d.ts.map +1 -0
  568. package/dist/tools/token-usage-handler.js +53 -0
  569. package/dist/tools/token-usage-handler.js.map +1 -0
  570. package/dist/tools/worker-status-handler.d.ts +3 -0
  571. package/dist/tools/worker-status-handler.d.ts.map +1 -0
  572. package/dist/tools/worker-status-handler.js +93 -0
  573. package/dist/tools/worker-status-handler.js.map +1 -0
  574. package/dist/types/delete.d.ts +68 -0
  575. package/dist/types/delete.d.ts.map +1 -0
  576. package/dist/types/delete.js +3 -0
  577. package/dist/types/delete.js.map +1 -0
  578. package/dist/types/github.d.ts +156 -0
  579. package/dist/types/github.d.ts.map +1 -0
  580. package/dist/types/github.js +11 -0
  581. package/dist/types/github.js.map +1 -0
  582. package/dist/types/ide.d.ts +70 -0
  583. package/dist/types/ide.d.ts.map +1 -0
  584. package/dist/types/ide.js +3 -0
  585. package/dist/types/ide.js.map +1 -0
  586. package/dist/types/index.d.ts +10 -0
  587. package/dist/types/index.d.ts.map +1 -1
  588. package/dist/types/index.js +10 -0
  589. package/dist/types/index.js.map +1 -1
  590. package/dist/types/llm-providers.d.ts +140 -0
  591. package/dist/types/llm-providers.d.ts.map +1 -0
  592. package/dist/types/llm-providers.js +3 -0
  593. package/dist/types/llm-providers.js.map +1 -0
  594. package/dist/types/orchestration-runtime.d.ts +198 -0
  595. package/dist/types/orchestration-runtime.d.ts.map +1 -0
  596. package/dist/types/orchestration-runtime.js +4 -0
  597. package/dist/types/orchestration-runtime.js.map +1 -0
  598. package/dist/types/plugins.d.ts +144 -0
  599. package/dist/types/plugins.d.ts.map +1 -0
  600. package/dist/types/plugins.js +3 -0
  601. package/dist/types/plugins.js.map +1 -0
  602. package/dist/types/project/agent.d.ts +12 -0
  603. package/dist/types/project/agent.d.ts.map +1 -0
  604. package/dist/types/project/agent.js +3 -0
  605. package/dist/types/project/agent.js.map +1 -0
  606. package/dist/types/project/architecture-detection.d.ts +23 -0
  607. package/dist/types/project/architecture-detection.d.ts.map +1 -0
  608. package/dist/types/project/architecture-detection.js +2 -0
  609. package/dist/types/project/architecture-detection.js.map +1 -0
  610. package/dist/types/project/config-metrics.d.ts +29 -0
  611. package/dist/types/project/config-metrics.d.ts.map +1 -0
  612. package/dist/types/project/config-metrics.js +2 -0
  613. package/dist/types/project/config-metrics.js.map +1 -0
  614. package/dist/types/project/constitution.d.ts +31 -0
  615. package/dist/types/project/constitution.d.ts.map +1 -0
  616. package/dist/types/project/constitution.js +3 -0
  617. package/dist/types/project/constitution.js.map +1 -0
  618. package/dist/types/project/core.d.ts +18 -163
  619. package/dist/types/project/core.d.ts.map +1 -1
  620. package/dist/types/project/core.js +7 -1
  621. package/dist/types/project/core.js.map +1 -1
  622. package/dist/types/project/mfe-detection.d.ts +18 -0
  623. package/dist/types/project/mfe-detection.d.ts.map +1 -0
  624. package/dist/types/project/mfe-detection.js +3 -0
  625. package/dist/types/project/mfe-detection.js.map +1 -0
  626. package/dist/types/project/planu-config.d.ts +55 -0
  627. package/dist/types/project/planu-config.d.ts.map +1 -0
  628. package/dist/types/project/planu-config.js +2 -0
  629. package/dist/types/project/planu-config.js.map +1 -0
  630. package/dist/types/runtime-security.d.ts +110 -0
  631. package/dist/types/runtime-security.d.ts.map +1 -0
  632. package/dist/types/runtime-security.js +4 -0
  633. package/dist/types/runtime-security.js.map +1 -0
  634. package/dist/types/session.d.ts +82 -0
  635. package/dist/types/session.d.ts.map +1 -0
  636. package/dist/types/session.js +3 -0
  637. package/dist/types/session.js.map +1 -0
  638. package/dist/types/token-optimization.d.ts +121 -0
  639. package/dist/types/token-optimization.d.ts.map +1 -0
  640. package/dist/types/token-optimization.js +3 -0
  641. package/dist/types/token-optimization.js.map +1 -0
  642. package/dist/types/workers.d.ts +132 -0
  643. package/dist/types/workers.d.ts.map +1 -0
  644. package/dist/types/workers.js +3 -0
  645. package/dist/types/workers.js.map +1 -0
  646. package/package.json +1 -1
  647. package/src/config/ide-registry.json +204 -0
  648. package/src/config/injection-patterns.json +30 -0
  649. package/src/config/known-cves.json +41 -0
  650. package/src/config/license-plans.json +26 -2
  651. package/src/config/llm-providers.json +198 -0
  652. package/src/config/model-equivalences.json +41 -0
  653. package/src/config/model-language-affinity.json +16 -0
  654. package/src/config/orchestration-templates.json +76 -0
  655. package/src/config/orchestration-topologies.json +36 -0
  656. package/src/config/plugin-marketplace.json +59 -0
  657. package/src/config/security-runtime-config.json +26 -0
  658. package/src/config/workers-registry.json +100 -0
@@ -0,0 +1,103 @@
1
+ // engine/runtime-security/checkers/prompt-injection.ts — SPEC-084 AC-03
2
+ // Detects prompt injection patterns in text inputs using regex + heuristics.
3
+ import { readFileSync } from 'node:fs';
4
+ import { resolve, dirname } from 'node:path';
5
+ import { fileURLToPath } from 'node:url';
6
+ const MODULE_DIR = dirname(fileURLToPath(import.meta.url));
7
+ const PATTERNS_PATH = resolve(MODULE_DIR, '../../../config/injection-patterns.json');
8
+ let cachedPatterns = null;
9
+ function loadPatterns() {
10
+ if (cachedPatterns) {
11
+ return cachedPatterns;
12
+ }
13
+ try {
14
+ const raw = readFileSync(PATTERNS_PATH, 'utf-8');
15
+ const parsed = JSON.parse(raw);
16
+ cachedPatterns = parsed.patterns;
17
+ return cachedPatterns;
18
+ }
19
+ catch {
20
+ return [];
21
+ }
22
+ }
23
+ // Unicode homoglyph detection: characters that look like ASCII but aren't
24
+ const HOMOGLYPH_RANGES = /[\u0400-\u04FF\u2000-\u206F\uFF00-\uFFEF\u200B-\u200F\u202A-\u202E]/;
25
+ // Role delimiter patterns used by various LLM APIs
26
+ const ROLE_DELIMITERS = [
27
+ /<\|im_start\|>/i,
28
+ /<\|im_end\|>/i,
29
+ /\[INST\]/i,
30
+ /\[\/INST\]/i,
31
+ /<<SYS>>/i,
32
+ /<\/SYS>>/i,
33
+ /\bsystem\s*:/i,
34
+ /\bassistant\s*:/i,
35
+ /\buser\s*:/i,
36
+ ];
37
+ function computeInjectionScore(text, patterns, customPatterns) {
38
+ let score = 0;
39
+ const lowerText = text.toLowerCase();
40
+ // Check configurable patterns
41
+ const allPatterns = [...patterns, ...customPatterns];
42
+ for (const p of allPatterns) {
43
+ if (lowerText.includes(p.toLowerCase())) {
44
+ score += 0.25;
45
+ }
46
+ }
47
+ // Check role delimiters (higher weight)
48
+ for (const regex of ROLE_DELIMITERS) {
49
+ if (regex.test(text)) {
50
+ score += 0.35;
51
+ }
52
+ }
53
+ // Check homoglyphs
54
+ if (HOMOGLYPH_RANGES.test(text)) {
55
+ score += 0.15;
56
+ }
57
+ return Math.min(score, 1.0);
58
+ }
59
+ function isTextInput(value) {
60
+ return typeof value === 'string' && value.length > 10;
61
+ }
62
+ export const promptInjectionChecker = {
63
+ type: 'prompt-injection',
64
+ check(_toolName, inputs, config) {
65
+ const threats = [];
66
+ const patterns = loadPatterns();
67
+ const customPatterns = config.customInjectionPatterns;
68
+ for (const [key, value] of Object.entries(inputs)) {
69
+ if (!isTextInput(value)) {
70
+ continue;
71
+ }
72
+ const score = computeInjectionScore(value, patterns, customPatterns);
73
+ if (score > 0.7) {
74
+ threats.push({
75
+ type: 'prompt-injection',
76
+ severity: 'critical',
77
+ message: `High-risk prompt injection detected (score: ${score.toFixed(2)})`,
78
+ field: key,
79
+ });
80
+ }
81
+ else if (score > 0.3) {
82
+ threats.push({
83
+ type: 'prompt-injection',
84
+ severity: 'warning',
85
+ message: `Possible prompt injection detected (score: ${score.toFixed(2)})`,
86
+ field: key,
87
+ });
88
+ }
89
+ else if (score > 0) {
90
+ threats.push({
91
+ type: 'prompt-injection',
92
+ severity: 'info',
93
+ message: `Low-risk injection pattern detected (score: ${score.toFixed(2)})`,
94
+ field: key,
95
+ });
96
+ }
97
+ }
98
+ return threats;
99
+ },
100
+ };
101
+ /** Exported for testing */
102
+ export { computeInjectionScore, loadPatterns };
103
+ //# sourceMappingURL=prompt-injection.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prompt-injection.js","sourceRoot":"","sources":["../../../../src/engine/runtime-security/checkers/prompt-injection.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { RuntimeSecurityChecker } from '../../../types/index.js';
2
+ export declare const sensitiveDataChecker: RuntimeSecurityChecker;
3
+ //# sourceMappingURL=sensitive-data.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sensitive-data.d.ts","sourceRoot":"","sources":["../../../../src/engine/runtime-security/checkers/sensitive-data.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,sBAAsB,EAIvB,MAAM,yBAAyB,CAAC;AA0DjC,eAAO,MAAM,oBAAoB,EAAE,sBAwBlC,CAAC"}
@@ -0,0 +1,71 @@
1
+ // engine/runtime-security/checkers/sensitive-data.ts — SPEC-084 AC-08
2
+ // Detects PII, API keys, passwords, and private keys in tool inputs.
3
+ const SENSITIVE_PATTERNS = [
4
+ // PII
5
+ { name: 'email', regex: /[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}/g, category: 'pii' },
6
+ { name: 'phone', regex: /(?:\+?1[-.\s]?)?\(?\d{3}\)?[-.\s]?\d{3}[-.\s]?\d{4}/g, category: 'pii' },
7
+ { name: 'ssn', regex: /\b\d{3}-\d{2}-\d{4}\b/g, category: 'pii' },
8
+ { name: 'ip-address', regex: /\b(?:\d{1,3}\.){3}\d{1,3}\b/g, category: 'pii' },
9
+ // API Keys
10
+ { name: 'aws-key', regex: /AKIA[0-9A-Z]{16}/g, category: 'secret' },
11
+ { name: 'gcp-key', regex: /AIza[0-9A-Za-z_-]{35}/g, category: 'secret' },
12
+ { name: 'openai-key', regex: /sk-[a-zA-Z0-9]{20,}/g, category: 'secret' },
13
+ { name: 'anthropic-key', regex: /sk-ant-[a-zA-Z0-9]{20,}/g, category: 'secret' },
14
+ { name: 'github-token', regex: /gh[pousr]_[A-Za-z0-9_]{36,}/g, category: 'secret' },
15
+ { name: 'stripe-key', regex: /sk_(?:live|test)_[A-Za-z0-9]{24,}/g, category: 'secret' },
16
+ { name: 'azure-key', regex: /[a-zA-Z0-9/+=]{44}/g, category: 'secret' },
17
+ // Passwords and tokens in plaintext
18
+ {
19
+ name: 'password-field',
20
+ regex: /(?:password|passwd|pwd|secret|token)\s*[=:]\s*\S+/gi,
21
+ category: 'secret',
22
+ },
23
+ {
24
+ name: 'private-key',
25
+ regex: /-----BEGIN (?:RSA |EC |DSA )?PRIVATE KEY-----/g,
26
+ category: 'secret',
27
+ },
28
+ // URLs with embedded credentials
29
+ {
30
+ name: 'credential-url',
31
+ regex: /https?:\/\/[^:\s]+:[^@\s]+@[^\s]+/g,
32
+ category: 'credential-url',
33
+ },
34
+ ];
35
+ function checkStringForSensitiveData(value, field) {
36
+ const threats = [];
37
+ for (const pattern of SENSITIVE_PATTERNS) {
38
+ // Reset regex lastIndex
39
+ pattern.regex.lastIndex = 0;
40
+ if (pattern.regex.test(value)) {
41
+ threats.push({
42
+ type: 'sensitive-data',
43
+ severity: 'warning',
44
+ message: `Sensitive data detected: ${pattern.name} (${pattern.category})`,
45
+ field,
46
+ pattern: pattern.name,
47
+ });
48
+ }
49
+ }
50
+ return threats;
51
+ }
52
+ export const sensitiveDataChecker = {
53
+ type: 'sensitive-data',
54
+ check(_toolName, inputs, _config) {
55
+ const threats = [];
56
+ for (const [key, value] of Object.entries(inputs)) {
57
+ if (typeof value === 'string' && value.length > 5) {
58
+ threats.push(...checkStringForSensitiveData(value, key));
59
+ }
60
+ if (Array.isArray(value)) {
61
+ for (const item of value) {
62
+ if (typeof item === 'string' && item.length > 5) {
63
+ threats.push(...checkStringForSensitiveData(item, key));
64
+ }
65
+ }
66
+ }
67
+ }
68
+ return threats;
69
+ },
70
+ };
71
+ //# sourceMappingURL=sensitive-data.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sensitive-data.js","sourceRoot":"","sources":["../../../../src/engine/runtime-security/checkers/sensitive-data.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,12 @@
1
+ export { validateToolInput, loadSecurityConfig, getSecurityConfig, getProjectConfig, resetConfigCache, } from './validator.js';
2
+ export { checkRateLimit, resetRateLimits } from './rate-limiter.js';
3
+ export { logAuditEntry, getAuditSummary } from './audit-logger.js';
4
+ export { pathTraversalChecker } from './checkers/path-traversal.js';
5
+ export { promptInjectionChecker } from './checkers/prompt-injection.js';
6
+ export { commandInjectionChecker } from './checkers/command-injection.js';
7
+ export { inputSanitizerChecker, sanitizeString } from './checkers/input-sanitizer.js';
8
+ export { sensitiveDataChecker } from './checkers/sensitive-data.js';
9
+ export { filePermissionsChecker } from './checkers/file-permissions.js';
10
+ export { contentSecurityChecker } from './checkers/content-security.js';
11
+ export { dependencyVulnChecker, checkDependencies } from './checkers/dependency-vuln.js';
12
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/engine/runtime-security/index.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,iBAAiB,EACjB,kBAAkB,EAClB,iBAAiB,EACjB,gBAAgB,EAChB,gBAAgB,GACjB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,8BAA8B,CAAC;AACpE,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,EAAE,uBAAuB,EAAE,MAAM,iCAAiC,CAAC;AAC1E,OAAO,EAAE,qBAAqB,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AACtF,OAAO,EAAE,oBAAoB,EAAE,MAAM,8BAA8B,CAAC;AACpE,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,EAAE,qBAAqB,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC"}
@@ -0,0 +1,13 @@
1
+ // engine/runtime-security/index.ts — SPEC-084 barrel export
2
+ export { validateToolInput, loadSecurityConfig, getSecurityConfig, getProjectConfig, resetConfigCache, } from './validator.js';
3
+ export { checkRateLimit, resetRateLimits } from './rate-limiter.js';
4
+ export { logAuditEntry, getAuditSummary } from './audit-logger.js';
5
+ export { pathTraversalChecker } from './checkers/path-traversal.js';
6
+ export { promptInjectionChecker } from './checkers/prompt-injection.js';
7
+ export { commandInjectionChecker } from './checkers/command-injection.js';
8
+ export { inputSanitizerChecker, sanitizeString } from './checkers/input-sanitizer.js';
9
+ export { sensitiveDataChecker } from './checkers/sensitive-data.js';
10
+ export { filePermissionsChecker } from './checkers/file-permissions.js';
11
+ export { contentSecurityChecker } from './checkers/content-security.js';
12
+ export { dependencyVulnChecker, checkDependencies } from './checkers/dependency-vuln.js';
13
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/engine/runtime-security/index.ts"],"names":[],"mappings":"AAAA,4DAA4D;AAE5D,OAAO,EACL,iBAAiB,EACjB,kBAAkB,EAClB,iBAAiB,EACjB,gBAAgB,EAChB,gBAAgB,GACjB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,8BAA8B,CAAC;AACpE,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,EAAE,uBAAuB,EAAE,MAAM,iCAAiC,CAAC;AAC1E,OAAO,EAAE,qBAAqB,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AACtF,OAAO,EAAE,oBAAoB,EAAE,MAAM,8BAA8B,CAAC;AACpE,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,EAAE,qBAAqB,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC"}
@@ -0,0 +1,5 @@
1
+ import type { RuntimeRateLimitResult, RuntimeSecurityConfig } from '../../types/index.js';
2
+ export declare function checkRateLimit(toolName: string, config: RuntimeSecurityConfig, now?: number): RuntimeRateLimitResult;
3
+ /** Reset all rate limit state (for testing) */
4
+ export declare function resetRateLimits(): void;
5
+ //# sourceMappingURL=rate-limiter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rate-limiter.d.ts","sourceRoot":"","sources":["../../../src/engine/runtime-security/rate-limiter.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAGV,sBAAsB,EACtB,qBAAqB,EACtB,MAAM,sBAAsB,CAAC;AAgE9B,wBAAgB,cAAc,CAC5B,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,qBAAqB,EAC7B,GAAG,CAAC,EAAE,MAAM,GACX,sBAAsB,CAkDxB;AAED,+CAA+C;AAC/C,wBAAgB,eAAe,IAAI,IAAI,CAEtC"}
@@ -0,0 +1,91 @@
1
+ // engine/runtime-security/rate-limiter.ts — SPEC-084 AC-06
2
+ // Token bucket rate limiting per tool name, in-memory only.
3
+ // Tool categories for rate limiting
4
+ const READ_TOOLS = new Set([
5
+ 'list_specs',
6
+ 'validate',
7
+ 'check_readiness',
8
+ 'security_report',
9
+ 'audit_spec',
10
+ 'estimate',
11
+ 'semantic_search',
12
+ 'list_groups',
13
+ 'license_status',
14
+ 'usage_stats',
15
+ 'usage_report',
16
+ 'spec_history',
17
+ ]);
18
+ const DESTRUCTIVE_TOOLS = new Set(['delete_spec', 'delete_project', 'empty_trash']);
19
+ const buckets = new Map();
20
+ function getToolCategory(toolName) {
21
+ if (DESTRUCTIVE_TOOLS.has(toolName)) {
22
+ return 'destructive';
23
+ }
24
+ if (READ_TOOLS.has(toolName)) {
25
+ return 'read';
26
+ }
27
+ return 'write';
28
+ }
29
+ function getRateLimitConfig(toolName, config) {
30
+ const category = getToolCategory(toolName);
31
+ return config.rateLimits[category];
32
+ }
33
+ function computeRefill(bucket, rlConfig, now) {
34
+ const elapsed = (now - bucket.lastRefill) / 1000;
35
+ const refilled = elapsed * rlConfig.refillRatePerSecond;
36
+ return {
37
+ tokens: Math.min(rlConfig.maxTokens, bucket.tokens + refilled),
38
+ lastRefill: now,
39
+ };
40
+ }
41
+ function isBurstActive(bucket, rlConfig, now) {
42
+ if (bucket.burstStart === null) {
43
+ return false;
44
+ }
45
+ return now - bucket.burstStart < rlConfig.burstDurationMs;
46
+ }
47
+ export function checkRateLimit(toolName, config, now) {
48
+ const currentTime = now ?? Date.now();
49
+ const rlConfig = getRateLimitConfig(toolName, config);
50
+ const existing = buckets.get(toolName);
51
+ const bucket = existing ?? {
52
+ tokens: rlConfig.maxTokens,
53
+ lastRefill: currentTime,
54
+ burstStart: null,
55
+ };
56
+ // Refill tokens
57
+ const refill = computeRefill(bucket, rlConfig, currentTime);
58
+ // Check burst allowance
59
+ const effectiveMax = isBurstActive(bucket, rlConfig, currentTime)
60
+ ? rlConfig.maxTokens * rlConfig.burstMultiplier
61
+ : rlConfig.maxTokens;
62
+ let tokens = Math.min(refill.tokens, effectiveMax);
63
+ let burstStart = bucket.burstStart;
64
+ if (tokens >= 1) {
65
+ tokens -= 1;
66
+ // Activate burst if near empty (below 20% of max)
67
+ if (tokens < rlConfig.maxTokens * 0.2 && burstStart === null) {
68
+ burstStart = currentTime;
69
+ }
70
+ buckets.set(toolName, { tokens, lastRefill: refill.lastRefill, burstStart });
71
+ return {
72
+ allowed: true,
73
+ retryAfterMs: 0,
74
+ remainingTokens: Math.floor(tokens),
75
+ };
76
+ }
77
+ buckets.set(toolName, { tokens, lastRefill: refill.lastRefill, burstStart });
78
+ // Calculate retry time
79
+ const tokensNeeded = 1 - tokens;
80
+ const retryAfterMs = Math.ceil((tokensNeeded / rlConfig.refillRatePerSecond) * 1000);
81
+ return {
82
+ allowed: false,
83
+ retryAfterMs,
84
+ remainingTokens: 0,
85
+ };
86
+ }
87
+ /** Reset all rate limit state (for testing) */
88
+ export function resetRateLimits() {
89
+ buckets.clear();
90
+ }
91
+ //# sourceMappingURL=rate-limiter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rate-limiter.js","sourceRoot":"","sources":["../../../src/engine/runtime-security/rate-limiter.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ import type { RuntimeSecurityConfig, RuntimeSecurityValidationResult } from '../../types/index.js';
2
+ export declare function loadSecurityConfig(configPath?: string): RuntimeSecurityConfig;
3
+ export declare function getSecurityConfig(): RuntimeSecurityConfig;
4
+ /** Load project-level override config if it exists */
5
+ export declare function getProjectConfig(projectPath: string): RuntimeSecurityConfig;
6
+ /** Reset cached config (for testing) */
7
+ export declare function resetConfigCache(): void;
8
+ export declare function validateToolInput(toolName: string, inputs: Record<string, unknown>, config?: RuntimeSecurityConfig): RuntimeSecurityValidationResult;
9
+ //# sourceMappingURL=validator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validator.d.ts","sourceRoot":"","sources":["../../../src/engine/runtime-security/validator.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAEV,qBAAqB,EACrB,+BAA+B,EAChC,MAAM,sBAAsB,CAAC;AA2B9B,wBAAgB,kBAAkB,CAAC,UAAU,CAAC,EAAE,MAAM,GAAG,qBAAqB,CA4B7E;AAED,wBAAgB,iBAAiB,IAAI,qBAAqB,CAGzD;AAED,sDAAsD;AACtD,wBAAgB,gBAAgB,CAAC,WAAW,EAAE,MAAM,GAAG,qBAAqB,CAM3E;AAED,wCAAwC;AACxC,wBAAgB,gBAAgB,IAAI,IAAI,CAEvC;AAcD,wBAAgB,iBAAiB,CAC/B,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC/B,MAAM,CAAC,EAAE,qBAAqB,GAC7B,+BAA+B,CAmCjC"}
@@ -0,0 +1,118 @@
1
+ // engine/runtime-security/validator.ts — SPEC-084 AC-01
2
+ // Orchestrates all security checkers over tool inputs (OCP — add checkers without modifying).
3
+ import { readFileSync, existsSync } from 'node:fs';
4
+ import { resolve, dirname } from 'node:path';
5
+ import { fileURLToPath } from 'node:url';
6
+ import { pathTraversalChecker } from './checkers/path-traversal.js';
7
+ import { promptInjectionChecker } from './checkers/prompt-injection.js';
8
+ import { commandInjectionChecker } from './checkers/command-injection.js';
9
+ import { inputSanitizerChecker, sanitizeString } from './checkers/input-sanitizer.js';
10
+ import { sensitiveDataChecker } from './checkers/sensitive-data.js';
11
+ import { filePermissionsChecker } from './checkers/file-permissions.js';
12
+ import { contentSecurityChecker } from './checkers/content-security.js';
13
+ import { dependencyVulnChecker } from './checkers/dependency-vuln.js';
14
+ const MODULE_DIR = dirname(fileURLToPath(import.meta.url));
15
+ const DEFAULT_CONFIG_PATH = resolve(MODULE_DIR, '../../config/security-runtime-config.json');
16
+ // Registry of all checkers (OCP — add new checkers here without modifying orchestration logic)
17
+ const defaultCheckers = [
18
+ pathTraversalChecker,
19
+ promptInjectionChecker,
20
+ commandInjectionChecker,
21
+ inputSanitizerChecker,
22
+ sensitiveDataChecker,
23
+ filePermissionsChecker,
24
+ contentSecurityChecker,
25
+ dependencyVulnChecker,
26
+ ];
27
+ let cachedConfig = null;
28
+ export function loadSecurityConfig(configPath) {
29
+ const path = configPath ?? DEFAULT_CONFIG_PATH;
30
+ try {
31
+ const raw = readFileSync(path, 'utf-8');
32
+ return JSON.parse(raw);
33
+ }
34
+ catch {
35
+ return {
36
+ level: 'standard',
37
+ rateLimits: {
38
+ read: { maxTokens: 60, refillRatePerSecond: 1, burstMultiplier: 2, burstDurationMs: 5000 },
39
+ write: {
40
+ maxTokens: 30,
41
+ refillRatePerSecond: 0.5,
42
+ burstMultiplier: 2,
43
+ burstDurationMs: 5000,
44
+ },
45
+ destructive: {
46
+ maxTokens: 10,
47
+ refillRatePerSecond: 0.167,
48
+ burstMultiplier: 2,
49
+ burstDurationMs: 5000,
50
+ },
51
+ },
52
+ allowedDirectories: [],
53
+ customInjectionPatterns: [],
54
+ disabledCheckers: [],
55
+ };
56
+ }
57
+ }
58
+ export function getSecurityConfig() {
59
+ cachedConfig ??= loadSecurityConfig();
60
+ return cachedConfig;
61
+ }
62
+ /** Load project-level override config if it exists */
63
+ export function getProjectConfig(projectPath) {
64
+ const projectConfigPath = resolve(projectPath, 'security-config.json');
65
+ if (existsSync(projectConfigPath)) {
66
+ return loadSecurityConfig(projectConfigPath);
67
+ }
68
+ return getSecurityConfig();
69
+ }
70
+ /** Reset cached config (for testing) */
71
+ export function resetConfigCache() {
72
+ cachedConfig = null;
73
+ }
74
+ function sanitizeInputs(inputs) {
75
+ const sanitized = {};
76
+ for (const [key, value] of Object.entries(inputs)) {
77
+ if (typeof value === 'string') {
78
+ sanitized[key] = sanitizeString(value);
79
+ }
80
+ else {
81
+ sanitized[key] = value;
82
+ }
83
+ }
84
+ return sanitized;
85
+ }
86
+ export function validateToolInput(toolName, inputs, config) {
87
+ const effectiveConfig = config ?? getSecurityConfig();
88
+ const allThreats = [];
89
+ // Run all enabled checkers
90
+ for (const checker of defaultCheckers) {
91
+ if (effectiveConfig.disabledCheckers.includes(checker.type)) {
92
+ continue;
93
+ }
94
+ const threats = checker.check(toolName, inputs, effectiveConfig);
95
+ allThreats.push(...threats);
96
+ }
97
+ // Determine safety based on security level
98
+ const hasCritical = allThreats.some((t) => t.severity === 'critical');
99
+ const hasWarning = allThreats.some((t) => t.severity === 'warning');
100
+ let safe;
101
+ switch (effectiveConfig.level) {
102
+ case 'strict':
103
+ safe = !hasCritical && !hasWarning;
104
+ break;
105
+ case 'standard':
106
+ safe = !hasCritical;
107
+ break;
108
+ case 'permissive':
109
+ safe = true;
110
+ break;
111
+ }
112
+ return {
113
+ safe,
114
+ threats: allThreats,
115
+ sanitizedInputs: sanitizeInputs(inputs),
116
+ };
117
+ }
118
+ //# sourceMappingURL=validator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validator.js","sourceRoot":"","sources":["../../../src/engine/runtime-security/validator.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ import type { Session, SessionDecision, SessionFile, SessionActiveSpec } from '../../types/index.js';
2
+ /** Get the current in-memory session (may be null if none started). */
3
+ export declare function getCurrentSession(): Session | null;
4
+ /** Reset module state (for testing). */
5
+ export declare function resetSessionState(): void;
6
+ /** Start or resume a session for a project. */
7
+ export declare function startSession(projectId: string, existingSession?: Session): Session;
8
+ /** Record a tool call and maybe persist (debounce). */
9
+ export declare function onToolCall(projectId: string): Promise<void>;
10
+ /** Add an active spec to the current session. */
11
+ export declare function addActiveSpec(spec: SessionActiveSpec): void;
12
+ /** Add a decision to the current session. */
13
+ export declare function addDecision(decision: SessionDecision): void;
14
+ /** Add a modified file to the current session. */
15
+ export declare function addModifiedFile(file: SessionFile): void;
16
+ /** Force-save the current session to disk (bypasses debounce). */
17
+ export declare function persistCurrentSession(): Promise<void>;
18
+ //# sourceMappingURL=auto-save.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auto-save.d.ts","sourceRoot":"","sources":["../../../src/engine/session/auto-save.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACV,OAAO,EACP,eAAe,EACf,WAAW,EACX,iBAAiB,EAClB,MAAM,sBAAsB,CAAC;AAe9B,uEAAuE;AACvE,wBAAgB,iBAAiB,IAAI,OAAO,GAAG,IAAI,CAElD;AAED,wCAAwC;AACxC,wBAAgB,iBAAiB,IAAI,IAAI,CAGxC;AAED,+CAA+C;AAC/C,wBAAgB,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,eAAe,CAAC,EAAE,OAAO,GAAG,OAAO,CAmBlF;AAED,uDAAuD;AACvD,wBAAsB,UAAU,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAYjE;AAED,iDAAiD;AACjD,wBAAgB,aAAa,CAAC,IAAI,EAAE,iBAAiB,GAAG,IAAI,CAQ3D;AAED,6CAA6C;AAC7C,wBAAgB,WAAW,CAAC,QAAQ,EAAE,eAAe,GAAG,IAAI,CAK3D;AAED,kDAAkD;AAClD,wBAAgB,eAAe,CAAC,IAAI,EAAE,WAAW,GAAG,IAAI,CAUvD;AAED,kEAAkE;AAClE,wBAAsB,qBAAqB,IAAI,OAAO,CAAC,IAAI,CAAC,CAU3D"}
@@ -0,0 +1,96 @@
1
+ import * as sessionStore from '../../storage/session-store.js';
2
+ import { randomUUID } from 'node:crypto';
3
+ import { buildContextSnapshot } from './context-snapshot.js';
4
+ import { updateCrossConversationMemory } from './memory-sync.js';
5
+ // --- module state ---
6
+ let currentSession = null;
7
+ let lastSaveTimestamp = 0;
8
+ const DEBOUNCE_MS = 30_000; // 30 seconds
9
+ // --- public API ---
10
+ /** Get the current in-memory session (may be null if none started). */
11
+ export function getCurrentSession() {
12
+ return currentSession;
13
+ }
14
+ /** Reset module state (for testing). */
15
+ export function resetSessionState() {
16
+ currentSession = null;
17
+ lastSaveTimestamp = 0;
18
+ }
19
+ /** Start or resume a session for a project. */
20
+ export function startSession(projectId, existingSession) {
21
+ if (existingSession) {
22
+ currentSession = { ...existingSession };
23
+ return currentSession;
24
+ }
25
+ const now = new Date().toISOString();
26
+ currentSession = {
27
+ id: randomUUID(),
28
+ projectId,
29
+ startedAt: now,
30
+ lastSavedAt: now,
31
+ activeSpecs: [],
32
+ decisions: [],
33
+ modifiedFiles: [],
34
+ contextSummary: '',
35
+ toolCallCount: 0,
36
+ metadata: {},
37
+ };
38
+ return currentSession;
39
+ }
40
+ /** Record a tool call and maybe persist (debounce). */
41
+ export async function onToolCall(projectId) {
42
+ if (!currentSession) {
43
+ startSession(projectId);
44
+ }
45
+ if (currentSession) {
46
+ currentSession.toolCallCount++;
47
+ const now = Date.now();
48
+ if (now - lastSaveTimestamp >= DEBOUNCE_MS) {
49
+ await persistCurrentSession();
50
+ lastSaveTimestamp = now;
51
+ }
52
+ }
53
+ }
54
+ /** Add an active spec to the current session. */
55
+ export function addActiveSpec(spec) {
56
+ if (!currentSession) {
57
+ return;
58
+ }
59
+ const exists = currentSession.activeSpecs.some((s) => s.specId === spec.specId);
60
+ if (!exists) {
61
+ currentSession.activeSpecs.push(spec);
62
+ }
63
+ }
64
+ /** Add a decision to the current session. */
65
+ export function addDecision(decision) {
66
+ if (!currentSession) {
67
+ return;
68
+ }
69
+ currentSession.decisions.push(decision);
70
+ }
71
+ /** Add a modified file to the current session. */
72
+ export function addModifiedFile(file) {
73
+ if (!currentSession) {
74
+ return;
75
+ }
76
+ const idx = currentSession.modifiedFiles.findIndex((f) => f.path === file.path);
77
+ if (idx >= 0) {
78
+ currentSession.modifiedFiles[idx] = file;
79
+ }
80
+ else {
81
+ currentSession.modifiedFiles.push(file);
82
+ }
83
+ }
84
+ /** Force-save the current session to disk (bypasses debounce). */
85
+ export async function persistCurrentSession() {
86
+ if (!currentSession) {
87
+ return;
88
+ }
89
+ currentSession.lastSavedAt = new Date().toISOString();
90
+ currentSession.contextSummary = buildContextSnapshot(currentSession);
91
+ await sessionStore.save(currentSession);
92
+ await updateCrossConversationMemory(currentSession);
93
+ // Fire-and-forget cleanup
94
+ void sessionStore.cleanup(currentSession.projectId);
95
+ }
96
+ //# sourceMappingURL=auto-save.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auto-save.js","sourceRoot":"","sources":["../../../src/engine/session/auto-save.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ import type { Session } from '../../types/index.js';
2
+ /**
3
+ * Build a markdown context summary from the current session state.
4
+ * Includes: specs in progress, last 5 modified files, last 3 decisions.
5
+ * Truncated to 2000 chars max.
6
+ */
7
+ export declare function buildContextSnapshot(session: Session): string;
8
+ //# sourceMappingURL=context-snapshot.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"context-snapshot.d.ts","sourceRoot":"","sources":["../../../src/engine/session/context-snapshot.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAIpD;;;;GAIG;AACH,wBAAgB,oBAAoB,CAAC,OAAO,EAAE,OAAO,GAAG,MAAM,CA8C7D"}