codehere 0.1.0 → 0.3.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.

Potentially problematic release.


This version of codehere might be problematic. Click here for more details.

Files changed (671) hide show
  1. package/README.md +51 -25
  2. package/dist/agents/base.d.ts +107 -0
  3. package/dist/agents/base.d.ts.map +1 -0
  4. package/dist/agents/base.js +101 -0
  5. package/dist/agents/base.js.map +1 -0
  6. package/dist/agents/orchestrator-model-driven.d.ts +41 -0
  7. package/dist/agents/orchestrator-model-driven.d.ts.map +1 -0
  8. package/dist/agents/orchestrator-model-driven.js +141 -0
  9. package/dist/agents/orchestrator-model-driven.js.map +1 -0
  10. package/dist/agents/react-orchestrator-agent.d.ts +15 -0
  11. package/dist/agents/react-orchestrator-agent.d.ts.map +1 -0
  12. package/dist/agents/react-orchestrator-agent.js +54 -0
  13. package/dist/agents/react-orchestrator-agent.js.map +1 -0
  14. package/dist/application/agents/execution-agent.d.ts +68 -0
  15. package/dist/application/agents/execution-agent.d.ts.map +1 -0
  16. package/dist/application/agents/execution-agent.js +299 -0
  17. package/dist/application/agents/execution-agent.js.map +1 -0
  18. package/dist/application/agents/multi-agent-orchestrator.d.ts +65 -0
  19. package/dist/application/agents/multi-agent-orchestrator.d.ts.map +1 -0
  20. package/dist/application/agents/multi-agent-orchestrator.js +209 -0
  21. package/dist/application/agents/multi-agent-orchestrator.js.map +1 -0
  22. package/dist/application/agents/planning-agent.d.ts +61 -0
  23. package/dist/application/agents/planning-agent.d.ts.map +1 -0
  24. package/dist/application/agents/planning-agent.js +357 -0
  25. package/dist/application/agents/planning-agent.js.map +1 -0
  26. package/dist/application/agents/validation-agent.d.ts +64 -0
  27. package/dist/application/agents/validation-agent.d.ts.map +1 -0
  28. package/dist/application/agents/validation-agent.js +182 -0
  29. package/dist/application/agents/validation-agent.js.map +1 -0
  30. package/dist/application/architectures/plan-and-act.d.ts +94 -0
  31. package/dist/application/architectures/plan-and-act.d.ts.map +1 -0
  32. package/dist/application/architectures/plan-and-act.js +242 -0
  33. package/dist/application/architectures/plan-and-act.js.map +1 -0
  34. package/dist/application/index.d.ts +12 -0
  35. package/dist/application/index.d.ts.map +1 -0
  36. package/dist/application/index.js +12 -0
  37. package/dist/application/index.js.map +1 -0
  38. package/dist/application/services/agent-factory.d.ts +9 -0
  39. package/dist/application/services/agent-factory.d.ts.map +1 -0
  40. package/dist/application/services/agent-factory.js +28 -0
  41. package/dist/application/services/agent-factory.js.map +1 -0
  42. package/dist/application/services/dependency-container.d.ts +143 -0
  43. package/dist/application/services/dependency-container.d.ts.map +1 -0
  44. package/dist/application/services/dependency-container.js +426 -0
  45. package/dist/application/services/dependency-container.js.map +1 -0
  46. package/dist/application/services/git-context-service.d.ts +30 -0
  47. package/dist/application/services/git-context-service.d.ts.map +1 -0
  48. package/dist/application/services/git-context-service.js +83 -0
  49. package/dist/application/services/git-context-service.js.map +1 -0
  50. package/dist/application/services/intelligent-router.d.ts +74 -0
  51. package/dist/application/services/intelligent-router.d.ts.map +1 -0
  52. package/dist/application/services/intelligent-router.js +711 -0
  53. package/dist/application/services/intelligent-router.js.map +1 -0
  54. package/dist/application/services/tool-executor-service.d.ts +14 -0
  55. package/dist/application/services/tool-executor-service.d.ts.map +1 -0
  56. package/dist/application/services/tool-executor-service.js +94 -0
  57. package/dist/application/services/tool-executor-service.js.map +1 -0
  58. package/dist/application/use-cases/ask-question-use-case.d.ts +48 -0
  59. package/dist/application/use-cases/ask-question-use-case.d.ts.map +1 -0
  60. package/dist/application/use-cases/ask-question-use-case.js +270 -0
  61. package/dist/application/use-cases/ask-question-use-case.js.map +1 -0
  62. package/dist/application/use-cases/edit-file-use-case.d.ts +76 -0
  63. package/dist/application/use-cases/edit-file-use-case.d.ts.map +1 -0
  64. package/dist/application/use-cases/edit-file-use-case.js +752 -0
  65. package/dist/application/use-cases/edit-file-use-case.js.map +1 -0
  66. package/dist/application/use-cases/explain-file-use-case.d.ts +21 -0
  67. package/dist/application/use-cases/explain-file-use-case.d.ts.map +1 -0
  68. package/dist/application/use-cases/explain-file-use-case.js +50 -0
  69. package/dist/application/use-cases/explain-file-use-case.js.map +1 -0
  70. package/dist/application/use-cases/index-codebase-use-case.d.ts +46 -0
  71. package/dist/application/use-cases/index-codebase-use-case.d.ts.map +1 -0
  72. package/dist/application/use-cases/index-codebase-use-case.js +113 -0
  73. package/dist/application/use-cases/index-codebase-use-case.js.map +1 -0
  74. package/dist/application/use-cases/planning-use-case.d.ts +46 -0
  75. package/dist/application/use-cases/planning-use-case.d.ts.map +1 -0
  76. package/dist/application/use-cases/planning-use-case.js +276 -0
  77. package/dist/application/use-cases/planning-use-case.js.map +1 -0
  78. package/dist/application/use-cases/react-orchestration-use-case.d.ts +51 -0
  79. package/dist/application/use-cases/react-orchestration-use-case.d.ts.map +1 -0
  80. package/dist/application/use-cases/react-orchestration-use-case.js +329 -0
  81. package/dist/application/use-cases/react-orchestration-use-case.js.map +1 -0
  82. package/dist/application/use-cases/reflexion-use-case.d.ts +24 -0
  83. package/dist/application/use-cases/reflexion-use-case.d.ts.map +1 -0
  84. package/dist/application/use-cases/reflexion-use-case.js +30 -0
  85. package/dist/application/use-cases/reflexion-use-case.js.map +1 -0
  86. package/dist/application/workflows/deterministic-workflows.d.ts +61 -0
  87. package/dist/application/workflows/deterministic-workflows.d.ts.map +1 -0
  88. package/dist/application/workflows/deterministic-workflows.js +189 -0
  89. package/dist/application/workflows/deterministic-workflows.js.map +1 -0
  90. package/dist/cache.d.ts.map +1 -1
  91. package/dist/cache.js +1 -3
  92. package/dist/cache.js.map +1 -1
  93. package/dist/chat.js +10 -10
  94. package/dist/chat.js.map +1 -1
  95. package/dist/docs.d.ts.map +1 -1
  96. package/dist/docs.js +1 -2
  97. package/dist/docs.js.map +1 -1
  98. package/dist/domain/entities/code-chunk.d.ts +26 -0
  99. package/dist/domain/entities/code-chunk.d.ts.map +1 -0
  100. package/dist/domain/entities/code-chunk.js +6 -0
  101. package/dist/domain/entities/code-chunk.js.map +1 -0
  102. package/dist/domain/entities/decision.d.ts +37 -0
  103. package/dist/domain/entities/decision.d.ts.map +1 -0
  104. package/dist/domain/entities/decision.js +9 -0
  105. package/dist/domain/entities/decision.js.map +1 -0
  106. package/dist/domain/entities/edit.d.ts +35 -0
  107. package/dist/domain/entities/edit.d.ts.map +1 -0
  108. package/dist/domain/entities/edit.js +6 -0
  109. package/dist/domain/entities/edit.js.map +1 -0
  110. package/dist/domain/entities/knowledge-node.d.ts +83 -0
  111. package/dist/domain/entities/knowledge-node.d.ts.map +1 -0
  112. package/dist/domain/entities/knowledge-node.js +9 -0
  113. package/dist/domain/entities/knowledge-node.js.map +1 -0
  114. package/dist/domain/entities/knowledge-preservation.d.ts +42 -0
  115. package/dist/domain/entities/knowledge-preservation.d.ts.map +1 -0
  116. package/dist/domain/entities/knowledge-preservation.js +10 -0
  117. package/dist/domain/entities/knowledge-preservation.js.map +1 -0
  118. package/dist/domain/entities/memory.d.ts +36 -0
  119. package/dist/domain/entities/memory.d.ts.map +1 -0
  120. package/dist/domain/entities/memory.js +6 -0
  121. package/dist/domain/entities/memory.js.map +1 -0
  122. package/dist/domain/entities/pattern.d.ts +49 -0
  123. package/dist/domain/entities/pattern.d.ts.map +1 -0
  124. package/dist/domain/entities/pattern.js +7 -0
  125. package/dist/domain/entities/pattern.js.map +1 -0
  126. package/dist/domain/entities/plan.d.ts +42 -0
  127. package/dist/domain/entities/plan.d.ts.map +1 -0
  128. package/dist/domain/entities/plan.js +6 -0
  129. package/dist/domain/entities/plan.js.map +1 -0
  130. package/dist/domain/entities/query.d.ts +17 -0
  131. package/dist/domain/entities/query.d.ts.map +1 -0
  132. package/dist/domain/entities/query.js +6 -0
  133. package/dist/domain/entities/query.js.map +1 -0
  134. package/dist/domain/index.d.ts +16 -0
  135. package/dist/domain/index.d.ts.map +1 -0
  136. package/dist/domain/index.js +19 -0
  137. package/dist/domain/index.js.map +1 -0
  138. package/dist/domain/interfaces/ai-service.interface.d.ts +62 -0
  139. package/dist/domain/interfaces/ai-service.interface.d.ts.map +1 -0
  140. package/dist/domain/interfaces/ai-service.interface.js +6 -0
  141. package/dist/domain/interfaces/ai-service.interface.js.map +1 -0
  142. package/dist/domain/interfaces/code-analyzer.interface.d.ts +38 -0
  143. package/dist/domain/interfaces/code-analyzer.interface.d.ts.map +1 -0
  144. package/dist/domain/interfaces/code-analyzer.interface.js +6 -0
  145. package/dist/domain/interfaces/code-analyzer.interface.js.map +1 -0
  146. package/dist/domain/interfaces/decision-repository.interface.d.ts +51 -0
  147. package/dist/domain/interfaces/decision-repository.interface.d.ts.map +1 -0
  148. package/dist/domain/interfaces/decision-repository.interface.js +9 -0
  149. package/dist/domain/interfaces/decision-repository.interface.js.map +1 -0
  150. package/dist/domain/interfaces/embedding-repository.interface.d.ts +28 -0
  151. package/dist/domain/interfaces/embedding-repository.interface.d.ts.map +1 -0
  152. package/dist/domain/interfaces/embedding-repository.interface.js +6 -0
  153. package/dist/domain/interfaces/embedding-repository.interface.js.map +1 -0
  154. package/dist/domain/interfaces/knowledge-graph-repository.interface.d.ts +91 -0
  155. package/dist/domain/interfaces/knowledge-graph-repository.interface.d.ts.map +1 -0
  156. package/dist/domain/interfaces/knowledge-graph-repository.interface.js +9 -0
  157. package/dist/domain/interfaces/knowledge-graph-repository.interface.js.map +1 -0
  158. package/dist/domain/interfaces/knowledge-preservation-repository.interface.d.ts +50 -0
  159. package/dist/domain/interfaces/knowledge-preservation-repository.interface.d.ts.map +1 -0
  160. package/dist/domain/interfaces/knowledge-preservation-repository.interface.js +8 -0
  161. package/dist/domain/interfaces/knowledge-preservation-repository.interface.js.map +1 -0
  162. package/dist/domain/interfaces/memory-repository.interface.d.ts +49 -0
  163. package/dist/domain/interfaces/memory-repository.interface.d.ts.map +1 -0
  164. package/dist/domain/interfaces/memory-repository.interface.js +6 -0
  165. package/dist/domain/interfaces/memory-repository.interface.js.map +1 -0
  166. package/dist/domain/interfaces/pattern-repository.interface.d.ts +48 -0
  167. package/dist/domain/interfaces/pattern-repository.interface.d.ts.map +1 -0
  168. package/dist/domain/interfaces/pattern-repository.interface.js +6 -0
  169. package/dist/domain/interfaces/pattern-repository.interface.js.map +1 -0
  170. package/dist/domain/interfaces/verification-service.interface.d.ts +20 -0
  171. package/dist/domain/interfaces/verification-service.interface.d.ts.map +1 -0
  172. package/dist/domain/interfaces/verification-service.interface.js +6 -0
  173. package/dist/domain/interfaces/verification-service.interface.js.map +1 -0
  174. package/dist/domain/services/codebase-detector.d.ts +18 -0
  175. package/dist/domain/services/codebase-detector.d.ts.map +1 -0
  176. package/dist/domain/services/codebase-detector.js +91 -0
  177. package/dist/domain/services/codebase-detector.js.map +1 -0
  178. package/dist/domain/services/cross-team-pattern-sharing.d.ts +65 -0
  179. package/dist/domain/services/cross-team-pattern-sharing.d.ts.map +1 -0
  180. package/dist/domain/services/cross-team-pattern-sharing.js +125 -0
  181. package/dist/domain/services/cross-team-pattern-sharing.js.map +1 -0
  182. package/dist/domain/services/decision-recorder.d.ts +76 -0
  183. package/dist/domain/services/decision-recorder.d.ts.map +1 -0
  184. package/dist/domain/services/decision-recorder.js +223 -0
  185. package/dist/domain/services/decision-recorder.js.map +1 -0
  186. package/dist/domain/services/decision-retriever.d.ts +75 -0
  187. package/dist/domain/services/decision-retriever.d.ts.map +1 -0
  188. package/dist/domain/services/decision-retriever.js +133 -0
  189. package/dist/domain/services/decision-retriever.js.map +1 -0
  190. package/dist/domain/services/graded-memory-activation.d.ts +37 -0
  191. package/dist/domain/services/graded-memory-activation.d.ts.map +1 -0
  192. package/dist/domain/services/graded-memory-activation.js +69 -0
  193. package/dist/domain/services/graded-memory-activation.js.map +1 -0
  194. package/dist/domain/services/knowledge-access.d.ts +63 -0
  195. package/dist/domain/services/knowledge-access.d.ts.map +1 -0
  196. package/dist/domain/services/knowledge-access.js +132 -0
  197. package/dist/domain/services/knowledge-access.js.map +1 -0
  198. package/dist/domain/services/knowledge-extractor.d.ts +54 -0
  199. package/dist/domain/services/knowledge-extractor.d.ts.map +1 -0
  200. package/dist/domain/services/knowledge-extractor.js +247 -0
  201. package/dist/domain/services/knowledge-extractor.js.map +1 -0
  202. package/dist/domain/services/knowledge-graph-builder.d.ts +70 -0
  203. package/dist/domain/services/knowledge-graph-builder.d.ts.map +1 -0
  204. package/dist/domain/services/knowledge-graph-builder.js +268 -0
  205. package/dist/domain/services/knowledge-graph-builder.js.map +1 -0
  206. package/dist/domain/services/knowledge-graph-query.d.ts +69 -0
  207. package/dist/domain/services/knowledge-graph-query.d.ts.map +1 -0
  208. package/dist/domain/services/knowledge-graph-query.js +187 -0
  209. package/dist/domain/services/knowledge-graph-query.js.map +1 -0
  210. package/dist/domain/services/memory-retriever.d.ts +30 -0
  211. package/dist/domain/services/memory-retriever.d.ts.map +1 -0
  212. package/dist/domain/services/memory-retriever.js +82 -0
  213. package/dist/domain/services/memory-retriever.js.map +1 -0
  214. package/dist/domain/services/memory-synthesizer.d.ts +57 -0
  215. package/dist/domain/services/memory-synthesizer.d.ts.map +1 -0
  216. package/dist/domain/services/memory-synthesizer.js +91 -0
  217. package/dist/domain/services/memory-synthesizer.js.map +1 -0
  218. package/dist/domain/services/pattern-extractor.d.ts +108 -0
  219. package/dist/domain/services/pattern-extractor.d.ts.map +1 -0
  220. package/dist/domain/services/pattern-extractor.js +442 -0
  221. package/dist/domain/services/pattern-extractor.js.map +1 -0
  222. package/dist/domain/services/query-intent-classifier.d.ts +16 -0
  223. package/dist/domain/services/query-intent-classifier.d.ts.map +1 -0
  224. package/dist/domain/services/query-intent-classifier.js +140 -0
  225. package/dist/domain/services/query-intent-classifier.js.map +1 -0
  226. package/dist/domain/services/react-loop.d.ts +52 -0
  227. package/dist/domain/services/react-loop.d.ts.map +1 -0
  228. package/dist/domain/services/react-loop.js +186 -0
  229. package/dist/domain/services/react-loop.js.map +1 -0
  230. package/dist/edit.d.ts +0 -12
  231. package/dist/edit.d.ts.map +1 -1
  232. package/dist/edit.js +76 -351
  233. package/dist/edit.js.map +1 -1
  234. package/dist/embed.d.ts +0 -4
  235. package/dist/embed.d.ts.map +1 -1
  236. package/dist/embed.js +100 -174
  237. package/dist/embed.js.map +1 -1
  238. package/dist/error-handler.d.ts +1 -0
  239. package/dist/error-handler.d.ts.map +1 -1
  240. package/dist/error-handler.js +46 -3
  241. package/dist/error-handler.js.map +1 -1
  242. package/dist/formatter.d.ts +2 -2
  243. package/dist/formatter.d.ts.map +1 -1
  244. package/dist/formatter.js +30 -17
  245. package/dist/formatter.js.map +1 -1
  246. package/dist/index.js +355 -239
  247. package/dist/index.js.map +1 -1
  248. package/dist/infrastructure/ai/cohere-ai-service.d.ts +56 -0
  249. package/dist/infrastructure/ai/cohere-ai-service.d.ts.map +1 -0
  250. package/dist/infrastructure/ai/cohere-ai-service.js +594 -0
  251. package/dist/infrastructure/ai/cohere-ai-service.js.map +1 -0
  252. package/dist/infrastructure/ai/command-r-evaluation.d.ts +42 -0
  253. package/dist/infrastructure/ai/command-r-evaluation.d.ts.map +1 -0
  254. package/dist/infrastructure/ai/command-r-evaluation.js +206 -0
  255. package/dist/infrastructure/ai/command-r-evaluation.js.map +1 -0
  256. package/dist/infrastructure/ai/model-config.d.ts +47 -0
  257. package/dist/infrastructure/ai/model-config.d.ts.map +1 -0
  258. package/dist/infrastructure/ai/model-config.js +84 -0
  259. package/dist/infrastructure/ai/model-config.js.map +1 -0
  260. package/dist/infrastructure/cache/embedding-cache.d.ts +46 -0
  261. package/dist/infrastructure/cache/embedding-cache.d.ts.map +1 -0
  262. package/dist/infrastructure/cache/embedding-cache.js +104 -0
  263. package/dist/infrastructure/cache/embedding-cache.js.map +1 -0
  264. package/dist/infrastructure/cache/query-result-cache.d.ts +68 -0
  265. package/dist/infrastructure/cache/query-result-cache.d.ts.map +1 -0
  266. package/dist/infrastructure/cache/query-result-cache.js +138 -0
  267. package/dist/infrastructure/cache/query-result-cache.js.map +1 -0
  268. package/dist/infrastructure/cache/security-scan-cache.d.ts +57 -0
  269. package/dist/infrastructure/cache/security-scan-cache.d.ts.map +1 -0
  270. package/dist/infrastructure/cache/security-scan-cache.js +124 -0
  271. package/dist/infrastructure/cache/security-scan-cache.js.map +1 -0
  272. package/dist/infrastructure/chunking/ast-code-chunker.d.ts +12 -0
  273. package/dist/infrastructure/chunking/ast-code-chunker.d.ts.map +1 -0
  274. package/dist/infrastructure/chunking/ast-code-chunker.js +19 -0
  275. package/dist/infrastructure/chunking/ast-code-chunker.js.map +1 -0
  276. package/dist/infrastructure/chunking/code-aware-chunker.d.ts +63 -0
  277. package/dist/infrastructure/chunking/code-aware-chunker.d.ts.map +1 -0
  278. package/dist/infrastructure/chunking/code-aware-chunker.js +397 -0
  279. package/dist/infrastructure/chunking/code-aware-chunker.js.map +1 -0
  280. package/dist/infrastructure/completion/bash-completion.d.ts +8 -0
  281. package/dist/infrastructure/completion/bash-completion.d.ts.map +1 -0
  282. package/dist/infrastructure/completion/bash-completion.js +101 -0
  283. package/dist/infrastructure/completion/bash-completion.js.map +1 -0
  284. package/dist/infrastructure/completion/completion-generator.d.ts +42 -0
  285. package/dist/infrastructure/completion/completion-generator.d.ts.map +1 -0
  286. package/dist/infrastructure/completion/completion-generator.js +184 -0
  287. package/dist/infrastructure/completion/completion-generator.js.map +1 -0
  288. package/dist/infrastructure/completion/fish-completion.d.ts +8 -0
  289. package/dist/infrastructure/completion/fish-completion.d.ts.map +1 -0
  290. package/dist/infrastructure/completion/fish-completion.js +65 -0
  291. package/dist/infrastructure/completion/fish-completion.js.map +1 -0
  292. package/dist/infrastructure/completion/zsh-completion.d.ts +8 -0
  293. package/dist/infrastructure/completion/zsh-completion.d.ts.map +1 -0
  294. package/dist/infrastructure/completion/zsh-completion.js +85 -0
  295. package/dist/infrastructure/completion/zsh-completion.js.map +1 -0
  296. package/dist/infrastructure/config/config-manager.d.ts +79 -0
  297. package/dist/infrastructure/config/config-manager.d.ts.map +1 -0
  298. package/dist/infrastructure/config/config-manager.js +162 -0
  299. package/dist/infrastructure/config/config-manager.js.map +1 -0
  300. package/dist/infrastructure/context/context-compressor.d.ts +94 -0
  301. package/dist/infrastructure/context/context-compressor.d.ts.map +1 -0
  302. package/dist/infrastructure/context/context-compressor.js +329 -0
  303. package/dist/infrastructure/context/context-compressor.js.map +1 -0
  304. package/dist/infrastructure/cost/cost-tracker.d.ts +90 -0
  305. package/dist/infrastructure/cost/cost-tracker.d.ts.map +1 -0
  306. package/dist/infrastructure/cost/cost-tracker.js +353 -0
  307. package/dist/infrastructure/cost/cost-tracker.js.map +1 -0
  308. package/dist/infrastructure/file-scanner/file-scanner.d.ts +31 -0
  309. package/dist/infrastructure/file-scanner/file-scanner.d.ts.map +1 -0
  310. package/dist/infrastructure/file-scanner/file-scanner.js +106 -0
  311. package/dist/infrastructure/file-scanner/file-scanner.js.map +1 -0
  312. package/dist/infrastructure/governance/nist-ai-rmf.d.ts +107 -0
  313. package/dist/infrastructure/governance/nist-ai-rmf.d.ts.map +1 -0
  314. package/dist/infrastructure/governance/nist-ai-rmf.js +294 -0
  315. package/dist/infrastructure/governance/nist-ai-rmf.js.map +1 -0
  316. package/dist/infrastructure/governance/policy-as-code.d.ts +90 -0
  317. package/dist/infrastructure/governance/policy-as-code.d.ts.map +1 -0
  318. package/dist/infrastructure/governance/policy-as-code.js +259 -0
  319. package/dist/infrastructure/governance/policy-as-code.js.map +1 -0
  320. package/dist/infrastructure/governance/prompt-to-code-lineage.d.ts +138 -0
  321. package/dist/infrastructure/governance/prompt-to-code-lineage.d.ts.map +1 -0
  322. package/dist/infrastructure/governance/prompt-to-code-lineage.js +241 -0
  323. package/dist/infrastructure/governance/prompt-to-code-lineage.js.map +1 -0
  324. package/dist/infrastructure/index.d.ts +7 -0
  325. package/dist/infrastructure/index.d.ts.map +1 -0
  326. package/dist/infrastructure/index.js +7 -0
  327. package/dist/infrastructure/index.js.map +1 -0
  328. package/dist/infrastructure/observability/execution-tracer.d.ts +108 -0
  329. package/dist/infrastructure/observability/execution-tracer.d.ts.map +1 -0
  330. package/dist/infrastructure/observability/execution-tracer.js +227 -0
  331. package/dist/infrastructure/observability/execution-tracer.js.map +1 -0
  332. package/dist/infrastructure/observability/prompt-versioner.d.ts +67 -0
  333. package/dist/infrastructure/observability/prompt-versioner.d.ts.map +1 -0
  334. package/dist/infrastructure/observability/prompt-versioner.js +145 -0
  335. package/dist/infrastructure/observability/prompt-versioner.js.map +1 -0
  336. package/dist/infrastructure/protocols/a2a-metadata.d.ts +278 -0
  337. package/dist/infrastructure/protocols/a2a-metadata.d.ts.map +1 -0
  338. package/dist/infrastructure/protocols/a2a-metadata.js +137 -0
  339. package/dist/infrastructure/protocols/a2a-metadata.js.map +1 -0
  340. package/dist/infrastructure/protocols/a2a-protocol.d.ts +132 -0
  341. package/dist/infrastructure/protocols/a2a-protocol.d.ts.map +1 -0
  342. package/dist/infrastructure/protocols/a2a-protocol.js +314 -0
  343. package/dist/infrastructure/protocols/a2a-protocol.js.map +1 -0
  344. package/dist/infrastructure/protocols/mcp-oauth.d.ts +91 -0
  345. package/dist/infrastructure/protocols/mcp-oauth.d.ts.map +1 -0
  346. package/dist/infrastructure/protocols/mcp-oauth.js +184 -0
  347. package/dist/infrastructure/protocols/mcp-oauth.js.map +1 -0
  348. package/dist/infrastructure/protocols/mcp-server.d.ts +126 -0
  349. package/dist/infrastructure/protocols/mcp-server.d.ts.map +1 -0
  350. package/dist/infrastructure/protocols/mcp-server.js +333 -0
  351. package/dist/infrastructure/protocols/mcp-server.js.map +1 -0
  352. package/dist/infrastructure/protocols/streaming-handler.d.ts +57 -0
  353. package/dist/infrastructure/protocols/streaming-handler.d.ts.map +1 -0
  354. package/dist/infrastructure/protocols/streaming-handler.js +103 -0
  355. package/dist/infrastructure/protocols/streaming-handler.js.map +1 -0
  356. package/dist/infrastructure/security/ai-sast-scanner.d.ts +59 -0
  357. package/dist/infrastructure/security/ai-sast-scanner.d.ts.map +1 -0
  358. package/dist/infrastructure/security/ai-sast-scanner.js +241 -0
  359. package/dist/infrastructure/security/ai-sast-scanner.js.map +1 -0
  360. package/dist/infrastructure/security/docker-sandbox.d.ts +57 -0
  361. package/dist/infrastructure/security/docker-sandbox.d.ts.map +1 -0
  362. package/dist/infrastructure/security/docker-sandbox.js +178 -0
  363. package/dist/infrastructure/security/docker-sandbox.js.map +1 -0
  364. package/dist/infrastructure/security/enhanced-security-gate.d.ts +53 -0
  365. package/dist/infrastructure/security/enhanced-security-gate.d.ts.map +1 -0
  366. package/dist/infrastructure/security/enhanced-security-gate.js +151 -0
  367. package/dist/infrastructure/security/enhanced-security-gate.js.map +1 -0
  368. package/dist/infrastructure/security/input-validator.d.ts +33 -0
  369. package/dist/infrastructure/security/input-validator.d.ts.map +1 -0
  370. package/dist/infrastructure/security/input-validator.js +152 -0
  371. package/dist/infrastructure/security/input-validator.js.map +1 -0
  372. package/dist/infrastructure/security/license-scanner.d.ts +55 -0
  373. package/dist/infrastructure/security/license-scanner.d.ts.map +1 -0
  374. package/dist/infrastructure/security/license-scanner.js +167 -0
  375. package/dist/infrastructure/security/license-scanner.js.map +1 -0
  376. package/dist/infrastructure/security/provider-bias-detector.d.ts +53 -0
  377. package/dist/infrastructure/security/provider-bias-detector.d.ts.map +1 -0
  378. package/dist/infrastructure/security/provider-bias-detector.js +164 -0
  379. package/dist/infrastructure/security/provider-bias-detector.js.map +1 -0
  380. package/dist/infrastructure/security/sandbox-executor.d.ts +34 -0
  381. package/dist/infrastructure/security/sandbox-executor.d.ts.map +1 -0
  382. package/dist/infrastructure/security/sandbox-executor.js +64 -0
  383. package/dist/infrastructure/security/sandbox-executor.js.map +1 -0
  384. package/dist/infrastructure/storage/memory-stream-service.d.ts +47 -0
  385. package/dist/infrastructure/storage/memory-stream-service.d.ts.map +1 -0
  386. package/dist/infrastructure/storage/memory-stream-service.js +204 -0
  387. package/dist/infrastructure/storage/memory-stream-service.js.map +1 -0
  388. package/dist/infrastructure/storage/plan-repository.d.ts +38 -0
  389. package/dist/infrastructure/storage/plan-repository.d.ts.map +1 -0
  390. package/dist/infrastructure/storage/plan-repository.js +133 -0
  391. package/dist/infrastructure/storage/plan-repository.js.map +1 -0
  392. package/dist/infrastructure/storage/sqlite-decision-repository.d.ts +29 -0
  393. package/dist/infrastructure/storage/sqlite-decision-repository.d.ts.map +1 -0
  394. package/dist/infrastructure/storage/sqlite-decision-repository.js +232 -0
  395. package/dist/infrastructure/storage/sqlite-decision-repository.js.map +1 -0
  396. package/dist/infrastructure/storage/sqlite-embedding-repository.d.ts +35 -0
  397. package/dist/infrastructure/storage/sqlite-embedding-repository.d.ts.map +1 -0
  398. package/dist/infrastructure/storage/sqlite-embedding-repository.js +277 -0
  399. package/dist/infrastructure/storage/sqlite-embedding-repository.js.map +1 -0
  400. package/dist/infrastructure/storage/sqlite-knowledge-graph-repository.d.ts +41 -0
  401. package/dist/infrastructure/storage/sqlite-knowledge-graph-repository.d.ts.map +1 -0
  402. package/dist/infrastructure/storage/sqlite-knowledge-graph-repository.js +417 -0
  403. package/dist/infrastructure/storage/sqlite-knowledge-graph-repository.js.map +1 -0
  404. package/dist/infrastructure/storage/sqlite-knowledge-preservation-repository.d.ts +29 -0
  405. package/dist/infrastructure/storage/sqlite-knowledge-preservation-repository.d.ts.map +1 -0
  406. package/dist/infrastructure/storage/sqlite-knowledge-preservation-repository.js +230 -0
  407. package/dist/infrastructure/storage/sqlite-knowledge-preservation-repository.js.map +1 -0
  408. package/dist/infrastructure/storage/sqlite-memory-repository.d.ts +40 -0
  409. package/dist/infrastructure/storage/sqlite-memory-repository.d.ts.map +1 -0
  410. package/dist/infrastructure/storage/sqlite-memory-repository.js +229 -0
  411. package/dist/infrastructure/storage/sqlite-memory-repository.js.map +1 -0
  412. package/dist/infrastructure/storage/sqlite-pattern-repository.d.ts +25 -0
  413. package/dist/infrastructure/storage/sqlite-pattern-repository.d.ts.map +1 -0
  414. package/dist/infrastructure/storage/sqlite-pattern-repository.js +249 -0
  415. package/dist/infrastructure/storage/sqlite-pattern-repository.js.map +1 -0
  416. package/dist/infrastructure/ux/appropriate-friction.d.ts +77 -0
  417. package/dist/infrastructure/ux/appropriate-friction.d.ts.map +1 -0
  418. package/dist/infrastructure/ux/appropriate-friction.js +213 -0
  419. package/dist/infrastructure/ux/appropriate-friction.js.map +1 -0
  420. package/dist/infrastructure/ux/bi-directional-learning.d.ts +109 -0
  421. package/dist/infrastructure/ux/bi-directional-learning.d.ts.map +1 -0
  422. package/dist/infrastructure/ux/bi-directional-learning.js +200 -0
  423. package/dist/infrastructure/ux/bi-directional-learning.js.map +1 -0
  424. package/dist/infrastructure/ux/contextual-feature-discovery.d.ts +24 -0
  425. package/dist/infrastructure/ux/contextual-feature-discovery.d.ts.map +1 -0
  426. package/dist/infrastructure/ux/contextual-feature-discovery.js +144 -0
  427. package/dist/infrastructure/ux/contextual-feature-discovery.js.map +1 -0
  428. package/dist/infrastructure/ux/expectation-management.d.ts +98 -0
  429. package/dist/infrastructure/ux/expectation-management.d.ts.map +1 -0
  430. package/dist/infrastructure/ux/expectation-management.js +327 -0
  431. package/dist/infrastructure/ux/expectation-management.js.map +1 -0
  432. package/dist/infrastructure/ux/feature-discovery.d.ts +47 -0
  433. package/dist/infrastructure/ux/feature-discovery.d.ts.map +1 -0
  434. package/dist/infrastructure/ux/feature-discovery.js +190 -0
  435. package/dist/infrastructure/ux/feature-discovery.js.map +1 -0
  436. package/dist/infrastructure/ux/hitl-review-portal.d.ts +47 -0
  437. package/dist/infrastructure/ux/hitl-review-portal.d.ts.map +1 -0
  438. package/dist/infrastructure/ux/hitl-review-portal.js +225 -0
  439. package/dist/infrastructure/ux/hitl-review-portal.js.map +1 -0
  440. package/dist/infrastructure/ux/hitl-validation.d.ts +104 -0
  441. package/dist/infrastructure/ux/hitl-validation.d.ts.map +1 -0
  442. package/dist/infrastructure/ux/hitl-validation.js +211 -0
  443. package/dist/infrastructure/ux/hitl-validation.js.map +1 -0
  444. package/dist/infrastructure/ux/progress-indicator.d.ts +54 -0
  445. package/dist/infrastructure/ux/progress-indicator.d.ts.map +1 -0
  446. package/dist/infrastructure/ux/progress-indicator.js +121 -0
  447. package/dist/infrastructure/ux/progress-indicator.js.map +1 -0
  448. package/dist/infrastructure/ux/progressive-disclosure.d.ts +84 -0
  449. package/dist/infrastructure/ux/progressive-disclosure.d.ts.map +1 -0
  450. package/dist/infrastructure/ux/progressive-disclosure.js +236 -0
  451. package/dist/infrastructure/ux/progressive-disclosure.js.map +1 -0
  452. package/dist/infrastructure/ux/review-checkpoint.d.ts +35 -0
  453. package/dist/infrastructure/ux/review-checkpoint.d.ts.map +1 -0
  454. package/dist/infrastructure/ux/review-checkpoint.js +119 -0
  455. package/dist/infrastructure/ux/review-checkpoint.js.map +1 -0
  456. package/dist/infrastructure/ux/staged-feature-intro.d.ts +47 -0
  457. package/dist/infrastructure/ux/staged-feature-intro.d.ts.map +1 -0
  458. package/dist/infrastructure/ux/staged-feature-intro.js +144 -0
  459. package/dist/infrastructure/ux/staged-feature-intro.js.map +1 -0
  460. package/dist/infrastructure/ux/syntax-highlighter.d.ts +21 -0
  461. package/dist/infrastructure/ux/syntax-highlighter.d.ts.map +1 -0
  462. package/dist/infrastructure/ux/syntax-highlighter.js +172 -0
  463. package/dist/infrastructure/ux/syntax-highlighter.js.map +1 -0
  464. package/dist/infrastructure/ux/team-standards.d.ts +94 -0
  465. package/dist/infrastructure/ux/team-standards.d.ts.map +1 -0
  466. package/dist/infrastructure/ux/team-standards.js +196 -0
  467. package/dist/infrastructure/ux/team-standards.js.map +1 -0
  468. package/dist/infrastructure/verification/verification-service.d.ts +12 -0
  469. package/dist/infrastructure/verification/verification-service.d.ts.map +1 -0
  470. package/dist/infrastructure/verification/verification-service.js +47 -0
  471. package/dist/infrastructure/verification/verification-service.js.map +1 -0
  472. package/dist/infrastructure/xai/attention-visualizer.d.ts +73 -0
  473. package/dist/infrastructure/xai/attention-visualizer.d.ts.map +1 -0
  474. package/dist/infrastructure/xai/attention-visualizer.js +174 -0
  475. package/dist/infrastructure/xai/attention-visualizer.js.map +1 -0
  476. package/dist/infrastructure/xai/cot-visualizer.d.ts +106 -0
  477. package/dist/infrastructure/xai/cot-visualizer.d.ts.map +1 -0
  478. package/dist/infrastructure/xai/cot-visualizer.js +286 -0
  479. package/dist/infrastructure/xai/cot-visualizer.js.map +1 -0
  480. package/dist/infrastructure/xai/decision-tree-log.d.ts +104 -0
  481. package/dist/infrastructure/xai/decision-tree-log.d.ts.map +1 -0
  482. package/dist/infrastructure/xai/decision-tree-log.js +216 -0
  483. package/dist/infrastructure/xai/decision-tree-log.js.map +1 -0
  484. package/dist/infrastructure/xai/interactive-xai.d.ts +106 -0
  485. package/dist/infrastructure/xai/interactive-xai.d.ts.map +1 -0
  486. package/dist/infrastructure/xai/interactive-xai.js +262 -0
  487. package/dist/infrastructure/xai/interactive-xai.js.map +1 -0
  488. package/dist/infrastructure/xai/uncertainty-quantifier.d.ts +80 -0
  489. package/dist/infrastructure/xai/uncertainty-quantifier.d.ts.map +1 -0
  490. package/dist/infrastructure/xai/uncertainty-quantifier.js +201 -0
  491. package/dist/infrastructure/xai/uncertainty-quantifier.js.map +1 -0
  492. package/dist/intelligent-retrieval.d.ts.map +1 -1
  493. package/dist/intelligent-retrieval.js +8 -1
  494. package/dist/intelligent-retrieval.js.map +1 -1
  495. package/dist/intent/classifier.d.ts +6 -0
  496. package/dist/intent/classifier.d.ts.map +1 -0
  497. package/dist/intent/classifier.js +2 -0
  498. package/dist/intent/classifier.js.map +1 -0
  499. package/dist/intent/context.d.ts +4 -0
  500. package/dist/intent/context.d.ts.map +1 -0
  501. package/dist/intent/context.js +2 -0
  502. package/dist/intent/context.js.map +1 -0
  503. package/dist/iterative-refinement.d.ts.map +1 -1
  504. package/dist/iterative-refinement.js +20 -3
  505. package/dist/iterative-refinement.js.map +1 -1
  506. package/dist/learning.d.ts.map +1 -1
  507. package/dist/learning.js +1 -2
  508. package/dist/learning.js.map +1 -1
  509. package/dist/monitoring.d.ts.map +1 -1
  510. package/dist/monitoring.js +1 -2
  511. package/dist/monitoring.js.map +1 -1
  512. package/dist/parallel-processor.d.ts +3 -2
  513. package/dist/parallel-processor.d.ts.map +1 -1
  514. package/dist/parallel-processor.js +183 -56
  515. package/dist/parallel-processor.js.map +1 -1
  516. package/dist/presentation/cli/commands/ask-command.d.ts +8 -0
  517. package/dist/presentation/cli/commands/ask-command.d.ts.map +1 -0
  518. package/dist/presentation/cli/commands/ask-command.js +190 -0
  519. package/dist/presentation/cli/commands/ask-command.js.map +1 -0
  520. package/dist/presentation/cli/commands/config-command.d.ts +9 -0
  521. package/dist/presentation/cli/commands/config-command.d.ts.map +1 -0
  522. package/dist/presentation/cli/commands/config-command.js +123 -0
  523. package/dist/presentation/cli/commands/config-command.js.map +1 -0
  524. package/dist/presentation/cli/commands/cost-command.d.ts +8 -0
  525. package/dist/presentation/cli/commands/cost-command.d.ts.map +1 -0
  526. package/dist/presentation/cli/commands/cost-command.js +191 -0
  527. package/dist/presentation/cli/commands/cost-command.js.map +1 -0
  528. package/dist/presentation/cli/commands/decision-command.d.ts +12 -0
  529. package/dist/presentation/cli/commands/decision-command.d.ts.map +1 -0
  530. package/dist/presentation/cli/commands/decision-command.js +207 -0
  531. package/dist/presentation/cli/commands/decision-command.js.map +1 -0
  532. package/dist/presentation/cli/commands/help-command.d.ts +9 -0
  533. package/dist/presentation/cli/commands/help-command.d.ts.map +1 -0
  534. package/dist/presentation/cli/commands/help-command.js +281 -0
  535. package/dist/presentation/cli/commands/help-command.js.map +1 -0
  536. package/dist/presentation/cli/commands/knowledge-command.d.ts +13 -0
  537. package/dist/presentation/cli/commands/knowledge-command.d.ts.map +1 -0
  538. package/dist/presentation/cli/commands/knowledge-command.js +129 -0
  539. package/dist/presentation/cli/commands/knowledge-command.js.map +1 -0
  540. package/dist/presentation/cli/commands/learning-dashboard-command.d.ts +8 -0
  541. package/dist/presentation/cli/commands/learning-dashboard-command.d.ts.map +1 -0
  542. package/dist/presentation/cli/commands/learning-dashboard-command.js +183 -0
  543. package/dist/presentation/cli/commands/learning-dashboard-command.js.map +1 -0
  544. package/dist/presentation/cli/commands/orchestrate-command.d.ts +9 -0
  545. package/dist/presentation/cli/commands/orchestrate-command.d.ts.map +1 -0
  546. package/dist/presentation/cli/commands/orchestrate-command.js +146 -0
  547. package/dist/presentation/cli/commands/orchestrate-command.js.map +1 -0
  548. package/dist/presentation/cli/commands/plan-command.d.ts +8 -0
  549. package/dist/presentation/cli/commands/plan-command.d.ts.map +1 -0
  550. package/dist/presentation/cli/commands/plan-command.js +166 -0
  551. package/dist/presentation/cli/commands/plan-command.js.map +1 -0
  552. package/dist/presentation/cli/commands/react-command.d.ts +8 -0
  553. package/dist/presentation/cli/commands/react-command.d.ts.map +1 -0
  554. package/dist/presentation/cli/commands/react-command.js +179 -0
  555. package/dist/presentation/cli/commands/react-command.js.map +1 -0
  556. package/dist/presentation/cli/commands/setup-command.d.ts +10 -0
  557. package/dist/presentation/cli/commands/setup-command.d.ts.map +1 -0
  558. package/dist/presentation/cli/commands/setup-command.js +286 -0
  559. package/dist/presentation/cli/commands/setup-command.js.map +1 -0
  560. package/dist/presentation/cli/commands/smart-command.d.ts +6 -0
  561. package/dist/presentation/cli/commands/smart-command.d.ts.map +1 -0
  562. package/dist/presentation/cli/commands/smart-command.js +330 -0
  563. package/dist/presentation/cli/commands/smart-command.js.map +1 -0
  564. package/dist/presentation/cli/commands/trace-command.d.ts +8 -0
  565. package/dist/presentation/cli/commands/trace-command.d.ts.map +1 -0
  566. package/dist/presentation/cli/commands/trace-command.js +129 -0
  567. package/dist/presentation/cli/commands/trace-command.js.map +1 -0
  568. package/dist/presentation/cli/commands/undo-command.d.ts +8 -0
  569. package/dist/presentation/cli/commands/undo-command.d.ts.map +1 -0
  570. package/dist/presentation/cli/commands/undo-command.js +150 -0
  571. package/dist/presentation/cli/commands/undo-command.js.map +1 -0
  572. package/dist/presentation/cli/error-display.d.ts +25 -0
  573. package/dist/presentation/cli/error-display.d.ts.map +1 -0
  574. package/dist/presentation/cli/error-display.js +297 -0
  575. package/dist/presentation/cli/error-display.js.map +1 -0
  576. package/dist/presentation/cli/keyboard-shortcuts.d.ts +27 -0
  577. package/dist/presentation/cli/keyboard-shortcuts.d.ts.map +1 -0
  578. package/dist/presentation/cli/keyboard-shortcuts.js +77 -0
  579. package/dist/presentation/cli/keyboard-shortcuts.js.map +1 -0
  580. package/dist/refactor.d.ts.map +1 -1
  581. package/dist/refactor.js +2 -4
  582. package/dist/refactor.js.map +1 -1
  583. package/dist/search.d.ts.map +1 -1
  584. package/dist/search.js +2 -63
  585. package/dist/search.js.map +1 -1
  586. package/dist/session.d.ts.map +1 -1
  587. package/dist/session.js +72 -3
  588. package/dist/session.js.map +1 -1
  589. package/dist/testgen.d.ts.map +1 -1
  590. package/dist/testgen.js +1 -2
  591. package/dist/testgen.js.map +1 -1
  592. package/dist/tools/bash.d.ts +53 -0
  593. package/dist/tools/bash.d.ts.map +1 -0
  594. package/dist/tools/bash.js +213 -0
  595. package/dist/tools/bash.js.map +1 -0
  596. package/dist/tools/edit.d.ts +48 -0
  597. package/dist/tools/edit.d.ts.map +1 -0
  598. package/dist/tools/edit.js +235 -0
  599. package/dist/tools/edit.js.map +1 -0
  600. package/dist/tools/executor.d.ts +29 -0
  601. package/dist/tools/executor.d.ts.map +1 -0
  602. package/dist/tools/executor.js +153 -0
  603. package/dist/tools/executor.js.map +1 -0
  604. package/dist/tools/git-tool.d.ts +87 -0
  605. package/dist/tools/git-tool.d.ts.map +1 -0
  606. package/dist/tools/git-tool.js +292 -0
  607. package/dist/tools/git-tool.js.map +1 -0
  608. package/dist/tools/parser.d.ts +33 -0
  609. package/dist/tools/parser.d.ts.map +1 -0
  610. package/dist/tools/parser.js +158 -0
  611. package/dist/tools/parser.js.map +1 -0
  612. package/dist/tools/registry.d.ts +74 -0
  613. package/dist/tools/registry.d.ts.map +1 -0
  614. package/dist/tools/registry.js +302 -0
  615. package/dist/tools/registry.js.map +1 -0
  616. package/dist/tools/search.d.ts +41 -0
  617. package/dist/tools/search.d.ts.map +1 -0
  618. package/dist/tools/search.js +100 -0
  619. package/dist/tools/search.js.map +1 -0
  620. package/dist/ui.d.ts.map +1 -1
  621. package/dist/ui.js +4 -2
  622. package/dist/ui.js.map +1 -1
  623. package/dist/utils/check-api-status.d.ts +12 -0
  624. package/dist/utils/check-api-status.d.ts.map +1 -0
  625. package/dist/utils/check-api-status.js +82 -0
  626. package/dist/utils/check-api-status.js.map +1 -0
  627. package/dist/utils/diff-parser.d.ts +22 -0
  628. package/dist/utils/diff-parser.d.ts.map +1 -0
  629. package/dist/utils/diff-parser.js +160 -0
  630. package/dist/utils/diff-parser.js.map +1 -0
  631. package/dist/utils/logger.d.ts +34 -0
  632. package/dist/utils/logger.d.ts.map +1 -0
  633. package/dist/utils/logger.js +56 -0
  634. package/dist/utils/logger.js.map +1 -0
  635. package/dist/utils/version.d.ts +21 -0
  636. package/dist/utils/version.d.ts.map +1 -0
  637. package/dist/utils/version.js +52 -0
  638. package/dist/utils/version.js.map +1 -0
  639. package/dist/verification/backup.d.ts +30 -0
  640. package/dist/verification/backup.d.ts.map +1 -0
  641. package/dist/verification/backup.js +259 -0
  642. package/dist/verification/backup.js.map +1 -0
  643. package/dist/verification/compiler.d.ts +20 -0
  644. package/dist/verification/compiler.d.ts.map +1 -0
  645. package/dist/verification/compiler.js +263 -0
  646. package/dist/verification/compiler.js.map +1 -0
  647. package/dist/verification/index.d.ts +59 -0
  648. package/dist/verification/index.d.ts.map +1 -0
  649. package/dist/verification/index.js +273 -0
  650. package/dist/verification/index.js.map +1 -0
  651. package/dist/verification/test-runner.d.ts +27 -0
  652. package/dist/verification/test-runner.d.ts.map +1 -0
  653. package/dist/verification/test-runner.js +379 -0
  654. package/dist/verification/test-runner.js.map +1 -0
  655. package/package.json +39 -14
  656. package/ARCHITECTURE.md +0 -240
  657. package/CHANGELOG.md +0 -44
  658. package/CONTRIBUTING.md +0 -171
  659. package/dist/benchmark.d.ts +0 -39
  660. package/dist/benchmark.d.ts.map +0 -1
  661. package/dist/benchmark.js +0 -195
  662. package/dist/benchmark.js.map +0 -1
  663. package/dist/scaffold.d.ts +0 -14
  664. package/dist/scaffold.d.ts.map +0 -1
  665. package/dist/scaffold.js +0 -85
  666. package/dist/scaffold.js.map +0 -1
  667. package/templates/next-page/app/layout.tsx +0 -19
  668. package/templates/next-page/app/page.tsx +0 -10
  669. package/templates/next-page/package.json +0 -22
  670. package/templates/node-api/index.js +0 -57
  671. package/templates/node-api/package.json +0 -13
@@ -0,0 +1,59 @@
1
+ /**
2
+ * Infrastructure: AI SAST Scanner
3
+ * AI-driven Static Application Security Testing
4
+ * Detects security vulnerabilities in generated code
5
+ *
6
+ * Based on enterprise architecture: AI SAST for security gates
7
+ */
8
+ import type { IAIService } from '../../domain/interfaces/ai-service.interface.js';
9
+ export interface SASTFinding {
10
+ severity: 'critical' | 'high' | 'medium' | 'low';
11
+ category: string;
12
+ description: string;
13
+ filepath: string;
14
+ line: number;
15
+ recommendation: string;
16
+ cwe?: string;
17
+ }
18
+ export interface SASTResult {
19
+ findings: SASTFinding[];
20
+ totalFindings: number;
21
+ criticalCount: number;
22
+ highCount: number;
23
+ mediumCount: number;
24
+ lowCount: number;
25
+ passed: boolean;
26
+ }
27
+ export declare class AISASTScanner {
28
+ private aiService;
29
+ constructor(aiService: IAIService);
30
+ /**
31
+ * Fast security check on instruction text (before expensive operations)
32
+ * This is a quick heuristic check to reject dangerous instructions early
33
+ */
34
+ scanInstruction(instruction: string): Promise<SASTResult | null>;
35
+ /**
36
+ * Fast pattern-based check for dangerous code patterns
37
+ */
38
+ private checkDangerousPatterns;
39
+ /**
40
+ * Scan code for security vulnerabilities
41
+ */
42
+ scan(filepath: string, code: string): Promise<SASTResult>;
43
+ /**
44
+ * Scan multiple files
45
+ */
46
+ scanFiles(files: Array<{
47
+ filepath: string;
48
+ code: string;
49
+ }>): Promise<SASTResult>;
50
+ /**
51
+ * Analyze code with AI for security vulnerabilities
52
+ */
53
+ private analyzeWithAI;
54
+ /**
55
+ * Check if code passes security gates
56
+ */
57
+ passesSecurityGates(filepath: string, code: string): Promise<boolean>;
58
+ }
59
+ //# sourceMappingURL=ai-sast-scanner.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ai-sast-scanner.d.ts","sourceRoot":"","sources":["../../../src/infrastructure/security/ai-sast-scanner.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iDAAiD,CAAC;AAGlF,MAAM,WAAW,WAAW;IAC1B,QAAQ,EAAE,UAAU,GAAG,MAAM,GAAG,QAAQ,GAAG,KAAK,CAAC;IACjD,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,cAAc,EAAE,MAAM,CAAC;IACvB,GAAG,CAAC,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,UAAU;IACzB,QAAQ,EAAE,WAAW,EAAE,CAAC;IACxB,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,MAAM,CAAC;IACtB,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,OAAO,CAAC;CACjB;AAED,qBAAa,aAAa;IACZ,OAAO,CAAC,SAAS;gBAAT,SAAS,EAAE,UAAU;IAEzC;;;OAGG;IACG,eAAe,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;IA6CtE;;OAEG;IACH,OAAO,CAAC,sBAAsB;IA2D9B;;OAEG;IACG,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC;IA+C/D;;OAEG;IACG,SAAS,CAAC,KAAK,EAAE,KAAK,CAAC;QAAE,QAAQ,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC,GAAG,OAAO,CAAC,UAAU,CAAC;IA0BtF;;OAEG;YACW,aAAa;IAoD3B;;OAEG;IACG,mBAAmB,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;CAI5E"}
@@ -0,0 +1,241 @@
1
+ /**
2
+ * Infrastructure: AI SAST Scanner
3
+ * AI-driven Static Application Security Testing
4
+ * Detects security vulnerabilities in generated code
5
+ *
6
+ * Based on enterprise architecture: AI SAST for security gates
7
+ */
8
+ export class AISASTScanner {
9
+ aiService;
10
+ constructor(aiService) {
11
+ this.aiService = aiService;
12
+ }
13
+ /**
14
+ * Fast security check on instruction text (before expensive operations)
15
+ * This is a quick heuristic check to reject dangerous instructions early
16
+ */
17
+ async scanInstruction(instruction) {
18
+ // Fast pattern-based check for obvious security issues
19
+ const lower = instruction.toLowerCase();
20
+ // Dangerous patterns that should be blocked immediately
21
+ const dangerousPatterns = [
22
+ { pattern: /execute.*user.*input|eval.*user|exec.*user/i, severity: 'critical', category: 'Code Injection' },
23
+ { pattern: /shell.*command|system.*call|process\.exec/i, severity: 'critical', category: 'Command Injection' },
24
+ { pattern: /sql.*injection|raw.*sql.*query/i, severity: 'high', category: 'SQL Injection' },
25
+ { pattern: /bypass.*security|disable.*security|remove.*validation/i, severity: 'critical', category: 'Security Bypass' },
26
+ { pattern: /hardcode.*password|store.*password|plaintext.*password/i, severity: 'high', category: 'Password Exposure' },
27
+ ];
28
+ const findings = [];
29
+ for (const { pattern, severity, category } of dangerousPatterns) {
30
+ if (pattern.test(instruction)) {
31
+ findings.push({
32
+ severity: severity,
33
+ category,
34
+ description: `Instruction contains dangerous pattern: ${category}`,
35
+ filepath: 'instruction',
36
+ line: 0,
37
+ recommendation: `Review instruction for security vulnerabilities. Pattern detected: ${category}`,
38
+ });
39
+ }
40
+ }
41
+ if (findings.length === 0) {
42
+ return null; // No issues found, allow to proceed
43
+ }
44
+ const criticalCount = findings.filter(f => f.severity === 'critical').length;
45
+ const highCount = findings.filter(f => f.severity === 'high').length;
46
+ return {
47
+ findings,
48
+ totalFindings: findings.length,
49
+ criticalCount,
50
+ highCount,
51
+ mediumCount: 0,
52
+ lowCount: 0,
53
+ passed: criticalCount === 0 && highCount === 0,
54
+ };
55
+ }
56
+ /**
57
+ * Fast pattern-based check for dangerous code patterns
58
+ */
59
+ checkDangerousPatterns(code) {
60
+ const findings = [];
61
+ const dangerousPatterns = [
62
+ {
63
+ pattern: /\beval\s*\(/gi,
64
+ category: 'Code Injection',
65
+ description: 'Use of eval() allows arbitrary code execution',
66
+ severity: 'critical',
67
+ cwe: 'CWE-95',
68
+ },
69
+ {
70
+ pattern: /\bFunction\s*\(/gi,
71
+ category: 'Code Injection',
72
+ description: 'Use of Function() constructor allows arbitrary code execution',
73
+ severity: 'critical',
74
+ cwe: 'CWE-95',
75
+ },
76
+ {
77
+ pattern: /\.innerHTML\s*=\s*[^=]/gi,
78
+ category: 'Cross-Site Scripting',
79
+ description: 'Direct innerHTML assignment can lead to XSS',
80
+ severity: 'high',
81
+ cwe: 'CWE-79',
82
+ },
83
+ {
84
+ pattern: /setTimeout\s*\(\s*[^,)]+\s*\)/gi,
85
+ category: 'Code Injection',
86
+ description: 'setTimeout with user input can execute arbitrary code',
87
+ severity: 'high',
88
+ cwe: 'CWE-95',
89
+ },
90
+ {
91
+ pattern: /setInterval\s*\(\s*[^,)]+\s*\)/gi,
92
+ category: 'Code Injection',
93
+ description: 'setInterval with user input can execute arbitrary code',
94
+ severity: 'high',
95
+ cwe: 'CWE-95',
96
+ },
97
+ ];
98
+ dangerousPatterns.forEach(({ pattern, category, description, severity, cwe }) => {
99
+ const matches = code.matchAll(pattern);
100
+ for (const match of matches) {
101
+ const line = code.substring(0, match.index || 0).split('\n').length;
102
+ findings.push({
103
+ severity,
104
+ category,
105
+ description,
106
+ line,
107
+ recommendation: `Avoid ${category.toLowerCase()}. Use safer alternatives.`,
108
+ cwe,
109
+ filepath: '', // Will be set by caller
110
+ });
111
+ }
112
+ });
113
+ return findings;
114
+ }
115
+ /**
116
+ * Scan code for security vulnerabilities
117
+ */
118
+ async scan(filepath, code) {
119
+ const findings = [];
120
+ // Fast pattern-based checks first (before expensive AI analysis)
121
+ const patternFindings = this.checkDangerousPatterns(code);
122
+ // Set filepath for pattern findings
123
+ patternFindings.forEach(f => { f.filepath = filepath; });
124
+ findings.push(...patternFindings);
125
+ // If critical patterns found, return early (don't need AI analysis)
126
+ const criticalPatternFindings = patternFindings.filter(f => f.severity === 'critical');
127
+ if (criticalPatternFindings.length > 0) {
128
+ return {
129
+ findings,
130
+ totalFindings: findings.length,
131
+ criticalCount: criticalPatternFindings.length,
132
+ highCount: findings.filter(f => f.severity === 'high').length,
133
+ mediumCount: findings.filter(f => f.severity === 'medium').length,
134
+ lowCount: findings.filter(f => f.severity === 'low').length,
135
+ passed: false,
136
+ };
137
+ }
138
+ // AI-based analysis (only if no critical patterns found)
139
+ const aiFindings = await this.analyzeWithAI(filepath, code);
140
+ findings.push(...aiFindings);
141
+ // Count by severity
142
+ const criticalCount = findings.filter(f => f.severity === 'critical').length;
143
+ const highCount = findings.filter(f => f.severity === 'high').length;
144
+ const mediumCount = findings.filter(f => f.severity === 'medium').length;
145
+ const lowCount = findings.filter(f => f.severity === 'low').length;
146
+ // Pass if no critical or high severity findings
147
+ const passed = criticalCount === 0 && highCount === 0;
148
+ return {
149
+ findings,
150
+ totalFindings: findings.length,
151
+ criticalCount,
152
+ highCount,
153
+ mediumCount,
154
+ lowCount,
155
+ passed,
156
+ };
157
+ }
158
+ /**
159
+ * Scan multiple files
160
+ */
161
+ async scanFiles(files) {
162
+ const allFindings = [];
163
+ for (const file of files) {
164
+ const result = await this.scan(file.filepath, file.code);
165
+ allFindings.push(...result.findings);
166
+ }
167
+ const criticalCount = allFindings.filter(f => f.severity === 'critical').length;
168
+ const highCount = allFindings.filter(f => f.severity === 'high').length;
169
+ const mediumCount = allFindings.filter(f => f.severity === 'medium').length;
170
+ const lowCount = allFindings.filter(f => f.severity === 'low').length;
171
+ const passed = criticalCount === 0 && highCount === 0;
172
+ return {
173
+ findings: allFindings,
174
+ totalFindings: allFindings.length,
175
+ criticalCount,
176
+ highCount,
177
+ mediumCount,
178
+ lowCount,
179
+ passed,
180
+ };
181
+ }
182
+ /**
183
+ * Analyze code with AI for security vulnerabilities
184
+ */
185
+ async analyzeWithAI(filepath, code) {
186
+ const prompt = `Analyze the following code for security vulnerabilities. Focus on:
187
+ - SQL Injection (CWE-89)
188
+ - Cross-Site Scripting / XSS (CWE-79)
189
+ - Code Injection (CWE-94, CWE-95) - including eval(), Function(), setTimeout/setInterval with user input
190
+ - Command Injection (CWE-78)
191
+ - Path Traversal (CWE-22)
192
+ - Insecure Deserialization (CWE-502)
193
+ - Authentication/Authorization flaws
194
+ - Sensitive data exposure
195
+ - Insecure dependencies
196
+ - Dangerous JavaScript patterns: eval(), Function(), innerHTML with user input, dangerous regex
197
+
198
+ Code from ${filepath}:
199
+ \`\`\`
200
+ ${code}
201
+ \`\`\`
202
+
203
+ Respond with a JSON array of findings. Each finding should have:
204
+ - severity: "critical" | "high" | "medium" | "low"
205
+ - category: e.g., "SQL Injection"
206
+ - description: Brief description of the vulnerability
207
+ - line: Line number (approximate)
208
+ - recommendation: How to fix it
209
+ - cwe: CWE identifier if applicable
210
+
211
+ If no vulnerabilities found, return empty array [].
212
+
213
+ JSON only, no other text:`;
214
+ try {
215
+ const response = await this.aiService.chat(prompt, []);
216
+ // Extract JSON from response
217
+ const jsonMatch = response.match(/\[[\s\S]*\]/);
218
+ if (!jsonMatch) {
219
+ return [];
220
+ }
221
+ const findings = JSON.parse(jsonMatch[0]);
222
+ // Add filepath to each finding
223
+ return findings.map(f => ({
224
+ ...f,
225
+ filepath,
226
+ }));
227
+ }
228
+ catch (error) {
229
+ console.warn('AI SAST analysis failed:', error);
230
+ return [];
231
+ }
232
+ }
233
+ /**
234
+ * Check if code passes security gates
235
+ */
236
+ async passesSecurityGates(filepath, code) {
237
+ const result = await this.scan(filepath, code);
238
+ return result.passed;
239
+ }
240
+ }
241
+ //# sourceMappingURL=ai-sast-scanner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ai-sast-scanner.js","sourceRoot":"","sources":["../../../src/infrastructure/security/ai-sast-scanner.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,57 @@
1
+ /**
2
+ * Infrastructure: Docker Sandbox Executor
3
+ * Executes code in isolated Docker containers for security
4
+ *
5
+ * MANDATORY: All code execution must use this for security
6
+ */
7
+ export interface SandboxOptions {
8
+ timeout?: number;
9
+ memoryLimit?: string;
10
+ cpuLimit?: string;
11
+ networkAccess?: boolean;
12
+ allowedPaths?: string[];
13
+ }
14
+ export interface SandboxResult {
15
+ success: boolean;
16
+ output: string;
17
+ error?: string;
18
+ exitCode?: number;
19
+ duration: number;
20
+ }
21
+ export declare class DockerSandbox {
22
+ private readonly DEFAULT_TIMEOUT;
23
+ private readonly DEFAULT_MEMORY;
24
+ private readonly DEFAULT_CPU;
25
+ private readonly SANDBOX_IMAGE;
26
+ private readonly TEMP_DIR;
27
+ constructor();
28
+ /**
29
+ * Execute code in isolated Docker container
30
+ */
31
+ execute(code: string, language?: 'javascript' | 'typescript' | 'python' | 'bash', options?: SandboxOptions): Promise<SandboxResult>;
32
+ /**
33
+ * Execute bash command in sandbox
34
+ */
35
+ executeBash(command: string, options?: SandboxOptions): Promise<SandboxResult>;
36
+ /**
37
+ * Build Docker command with security restrictions
38
+ */
39
+ private buildDockerCommand;
40
+ /**
41
+ * Get file extension for language
42
+ */
43
+ private getFileExtension;
44
+ /**
45
+ * Create timeout promise
46
+ */
47
+ private createTimeout;
48
+ /**
49
+ * Cleanup container and temp files
50
+ */
51
+ private cleanup;
52
+ /**
53
+ * Check if Docker is available
54
+ */
55
+ isAvailable(): Promise<boolean>;
56
+ }
57
+ //# sourceMappingURL=docker-sandbox.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"docker-sandbox.d.ts","sourceRoot":"","sources":["../../../src/infrastructure/security/docker-sandbox.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAWH,MAAM,WAAW,cAAc;IAC7B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;CACzB;AAED,MAAM,WAAW,aAAa;IAC5B,OAAO,EAAE,OAAO,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,qBAAa,aAAa;IACxB,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAS;IACzC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAU;IACzC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAS;IACrC,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAoB;IAClD,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAA2B;;IASpD;;OAEG;IACG,OAAO,CACX,IAAI,EAAE,MAAM,EACZ,QAAQ,GAAE,YAAY,GAAG,YAAY,GAAG,QAAQ,GAAG,MAAe,EAClE,OAAO,GAAE,cAAmB,GAC3B,OAAO,CAAC,aAAa,CAAC;IAyDzB;;OAEG;IACG,WAAW,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,GAAE,cAAmB,GAAG,OAAO,CAAC,aAAa,CAAC;IAKxF;;OAEG;IACH,OAAO,CAAC,kBAAkB;IA8C1B;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAUxB;;OAEG;IACH,OAAO,CAAC,aAAa;IAMrB;;OAEG;YACW,OAAO;IAmBrB;;OAEG;IACG,WAAW,IAAI,OAAO,CAAC,OAAO,CAAC;CAQtC"}
@@ -0,0 +1,178 @@
1
+ /**
2
+ * Infrastructure: Docker Sandbox Executor
3
+ * Executes code in isolated Docker containers for security
4
+ *
5
+ * MANDATORY: All code execution must use this for security
6
+ */
7
+ import { exec } from 'child_process';
8
+ import { promisify } from 'util';
9
+ import { randomUUID } from 'crypto';
10
+ import { writeFileSync, unlinkSync, existsSync, mkdirSync } from 'fs';
11
+ import { join } from 'path';
12
+ const execAsync = promisify(exec);
13
+ export class DockerSandbox {
14
+ DEFAULT_TIMEOUT = 30000; // 30 seconds
15
+ DEFAULT_MEMORY = '512m';
16
+ DEFAULT_CPU = '0.5';
17
+ SANDBOX_IMAGE = 'node:18-alpine'; // Lightweight Node.js image
18
+ TEMP_DIR = '/tmp/codehere-sandbox';
19
+ constructor() {
20
+ // Ensure temp directory exists
21
+ if (!existsSync(this.TEMP_DIR)) {
22
+ mkdirSync(this.TEMP_DIR, { recursive: true });
23
+ }
24
+ }
25
+ /**
26
+ * Execute code in isolated Docker container
27
+ */
28
+ async execute(code, language = 'bash', options = {}) {
29
+ const startTime = Date.now();
30
+ const containerId = randomUUID().substring(0, 8);
31
+ const timeout = options.timeout || this.DEFAULT_TIMEOUT;
32
+ try {
33
+ // Create temporary file with code
34
+ const tempFile = join(this.TEMP_DIR, `${containerId}.${this.getFileExtension(language)}`);
35
+ writeFileSync(tempFile, code, 'utf-8');
36
+ // Build Docker run command with security restrictions
37
+ const dockerCommand = this.buildDockerCommand(containerId, tempFile, language, options);
38
+ // Execute in Docker container with timeout
39
+ const { stdout, stderr } = await Promise.race([
40
+ execAsync(dockerCommand, { timeout }),
41
+ this.createTimeout(timeout),
42
+ ]);
43
+ // Cleanup
44
+ this.cleanup(containerId, tempFile);
45
+ const duration = Date.now() - startTime;
46
+ return {
47
+ success: !stderr || stderr.length === 0,
48
+ output: stdout,
49
+ error: stderr || undefined,
50
+ exitCode: 0,
51
+ duration,
52
+ };
53
+ }
54
+ catch (error) {
55
+ // Cleanup on error
56
+ this.cleanup(containerId, join(this.TEMP_DIR, `${containerId}.${this.getFileExtension(language)}`));
57
+ const duration = Date.now() - startTime;
58
+ if (error.code === 'ETIMEDOUT' || error.signal === 'SIGTERM') {
59
+ return {
60
+ success: false,
61
+ output: '',
62
+ error: `Execution timed out after ${timeout}ms`,
63
+ exitCode: 124,
64
+ duration,
65
+ };
66
+ }
67
+ return {
68
+ success: false,
69
+ output: '',
70
+ error: error.message || String(error),
71
+ exitCode: error.code || 1,
72
+ duration,
73
+ };
74
+ }
75
+ }
76
+ /**
77
+ * Execute bash command in sandbox
78
+ */
79
+ async executeBash(command, options = {}) {
80
+ // Use execute method with bash language
81
+ return await this.execute(command, 'bash', options);
82
+ }
83
+ /**
84
+ * Build Docker command with security restrictions
85
+ */
86
+ buildDockerCommand(containerId, codeFile, language, options) {
87
+ const memory = options.memoryLimit || this.DEFAULT_MEMORY;
88
+ const cpu = options.cpuLimit || this.DEFAULT_CPU;
89
+ const network = options.networkAccess ? '' : '--network none';
90
+ const readOnly = '--read-only';
91
+ const tmpfs = '--tmpfs /tmp:rw,noexec,nosuid,size=100m';
92
+ // Determine execution command based on language
93
+ let execCommand;
94
+ switch (language) {
95
+ case 'javascript':
96
+ case 'typescript':
97
+ execCommand = `node /code/${containerId}.js`;
98
+ break;
99
+ case 'python':
100
+ execCommand = `python /code/${containerId}.py`;
101
+ break;
102
+ case 'bash':
103
+ default:
104
+ execCommand = `sh /code/${containerId}.sh`;
105
+ break;
106
+ }
107
+ // Copy code file into container and execute
108
+ const dockerCommand = `docker run --rm \
109
+ --name codehere-sandbox-${containerId} \
110
+ --memory ${memory} \
111
+ --cpus ${cpu} \
112
+ ${network} \
113
+ ${readOnly} \
114
+ ${tmpfs} \
115
+ --security-opt no-new-privileges:true \
116
+ --cap-drop ALL \
117
+ --user 1000:1000 \
118
+ -v ${codeFile}:/code/${containerId}.${this.getFileExtension(language)}:ro \
119
+ ${this.SANDBOX_IMAGE} \
120
+ ${execCommand}`;
121
+ return dockerCommand;
122
+ }
123
+ /**
124
+ * Get file extension for language
125
+ */
126
+ getFileExtension(language) {
127
+ const extensions = {
128
+ javascript: 'js',
129
+ typescript: 'ts',
130
+ python: 'py',
131
+ bash: 'sh',
132
+ };
133
+ return extensions[language] || 'sh';
134
+ }
135
+ /**
136
+ * Create timeout promise
137
+ */
138
+ createTimeout(ms) {
139
+ return new Promise((_, reject) => {
140
+ setTimeout(() => reject(new Error('Timeout')), ms);
141
+ });
142
+ }
143
+ /**
144
+ * Cleanup container and temp files
145
+ */
146
+ async cleanup(containerId, tempFile) {
147
+ try {
148
+ // Try to stop container if still running
149
+ try {
150
+ await execAsync(`docker stop codehere-sandbox-${containerId} 2>/dev/null || true`);
151
+ }
152
+ catch {
153
+ // Container already stopped or doesn't exist
154
+ }
155
+ // Remove temp file
156
+ if (existsSync(tempFile)) {
157
+ unlinkSync(tempFile);
158
+ }
159
+ }
160
+ catch (error) {
161
+ // Log but don't fail on cleanup errors
162
+ console.warn('Sandbox cleanup warning:', error);
163
+ }
164
+ }
165
+ /**
166
+ * Check if Docker is available
167
+ */
168
+ async isAvailable() {
169
+ try {
170
+ await execAsync('docker --version');
171
+ return true;
172
+ }
173
+ catch {
174
+ return false;
175
+ }
176
+ }
177
+ }
178
+ //# sourceMappingURL=docker-sandbox.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"docker-sandbox.js","sourceRoot":"","sources":["../../../src/infrastructure/security/docker-sandbox.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,53 @@
1
+ /**
2
+ * Infrastructure: Enhanced Security Gate
3
+ * Comprehensive security validation combining all security scanners
4
+ *
5
+ * Research-Driven Security:
6
+ * - AI SAST Scanner (existing) - 45% of AI code has flaws
7
+ * - License Scanner - 35% license contamination risk
8
+ * - Provider Bias Detector - Vendor lock-in prevention
9
+ * - Uncertainty Quantifier - Hallucination risk
10
+ *
11
+ * All checks must pass before code generation/editing
12
+ */
13
+ import { AISASTScanner, type SASTResult } from './ai-sast-scanner.js';
14
+ import { LicenseScanner, type LicenseScanResult } from './license-scanner.js';
15
+ import { ProviderBiasDetector, type ProviderBiasResult } from './provider-bias-detector.js';
16
+ import { UncertaintyQuantifier, type UncertaintyResult } from '../xai/uncertainty-quantifier.js';
17
+ export interface EnhancedSecurityResult {
18
+ passed: boolean;
19
+ sast: SASTResult;
20
+ license: LicenseScanResult;
21
+ providerBias: ProviderBiasResult;
22
+ uncertainty?: UncertaintyResult;
23
+ errors: string[];
24
+ warnings: string[];
25
+ }
26
+ /**
27
+ * Enhanced Security Gate
28
+ * Orchestrates all security scanners
29
+ */
30
+ export declare class EnhancedSecurityGate {
31
+ private sastScanner;
32
+ private licenseScanner;
33
+ private providerBiasDetector;
34
+ private uncertaintyQuantifier?;
35
+ private scanCache;
36
+ constructor(sastScanner: AISASTScanner, licenseScanner: LicenseScanner, providerBiasDetector: ProviderBiasDetector, uncertaintyQuantifier?: UncertaintyQuantifier | undefined);
37
+ /**
38
+ * Comprehensive security scan
39
+ * PERFORMANCE OPTIMIZATION: Parallelizes independent scans for ~3x speedup
40
+ */
41
+ scan(filepath: string, code: string, instruction?: string, context?: {
42
+ query?: string;
43
+ chunks?: any[];
44
+ }): Promise<EnhancedSecurityResult>;
45
+ /**
46
+ * Fast pre-check on instruction (before expensive operations)
47
+ */
48
+ fastCheck(instruction: string): Promise<{
49
+ allowed: boolean;
50
+ findings: string[];
51
+ }>;
52
+ }
53
+ //# sourceMappingURL=enhanced-security-gate.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"enhanced-security-gate.d.ts","sourceRoot":"","sources":["../../../src/infrastructure/security/enhanced-security-gate.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAEH,OAAO,EAAE,aAAa,EAAE,KAAK,UAAU,EAAE,MAAM,sBAAsB,CAAC;AACtE,OAAO,EAAE,cAAc,EAAE,KAAK,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AAC9E,OAAO,EAAE,oBAAoB,EAAE,KAAK,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AAC5F,OAAO,EAAE,qBAAqB,EAAE,KAAK,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AAGjG,MAAM,WAAW,sBAAsB;IACrC,MAAM,EAAE,OAAO,CAAC;IAChB,IAAI,EAAE,UAAU,CAAC;IACjB,OAAO,EAAE,iBAAiB,CAAC;IAC3B,YAAY,EAAE,kBAAkB,CAAC;IACjC,WAAW,CAAC,EAAE,iBAAiB,CAAC;IAChC,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,QAAQ,EAAE,MAAM,EAAE,CAAC;CACpB;AAED;;;GAGG;AACH,qBAAa,oBAAoB;IAI7B,OAAO,CAAC,WAAW;IACnB,OAAO,CAAC,cAAc;IACtB,OAAO,CAAC,oBAAoB;IAC5B,OAAO,CAAC,qBAAqB,CAAC;IANhC,OAAO,CAAC,SAAS,CAA0B;gBAGjC,WAAW,EAAE,aAAa,EAC1B,cAAc,EAAE,cAAc,EAC9B,oBAAoB,EAAE,oBAAoB,EAC1C,qBAAqB,CAAC,EAAE,qBAAqB,YAAA;IAGvD;;;OAGG;IACG,IAAI,CACR,QAAQ,EAAE,MAAM,EAChB,IAAI,EAAE,MAAM,EACZ,WAAW,CAAC,EAAE,MAAM,EACpB,OAAO,CAAC,EAAE;QAAE,KAAK,CAAC,EAAE,MAAM,CAAC;QAAC,MAAM,CAAC,EAAE,GAAG,EAAE,CAAA;KAAE,GAC3C,OAAO,CAAC,sBAAsB,CAAC;IAkIlC;;OAEG;IACG,SAAS,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,OAAO,EAAE,OAAO,CAAC;QAAC,QAAQ,EAAE,MAAM,EAAE,CAAA;KAAE,CAAC;CAaxF"}