reviewflow 3.31.0 → 3.33.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 (377) hide show
  1. package/CHANGELOG.md +20 -0
  2. package/dist/main/routes.d.ts.map +1 -1
  3. package/dist/main/routes.js +55 -2
  4. package/dist/main/routes.js.map +1 -1
  5. package/dist/main/server.d.ts.map +1 -1
  6. package/dist/main/server.js +5 -1
  7. package/dist/main/server.js.map +1 -1
  8. package/dist/modules/ember-chat/entities/emberMemory/emberMemory.gateway.d.ts +8 -0
  9. package/dist/modules/ember-chat/entities/emberMemory/emberMemory.gateway.d.ts.map +1 -0
  10. package/dist/modules/ember-chat/entities/emberMemory/emberMemory.gateway.js +2 -0
  11. package/dist/modules/ember-chat/entities/emberMemory/emberMemory.gateway.js.map +1 -0
  12. package/dist/modules/ember-chat/entities/emberMemory/emberMemory.guard.d.ts +8 -0
  13. package/dist/modules/ember-chat/entities/emberMemory/emberMemory.guard.d.ts.map +1 -0
  14. package/dist/modules/ember-chat/entities/emberMemory/emberMemory.guard.js +4 -0
  15. package/dist/modules/ember-chat/entities/emberMemory/emberMemory.guard.js.map +1 -0
  16. package/dist/modules/ember-chat/entities/emberMemory/emberMemory.schema.d.ts +17 -0
  17. package/dist/modules/ember-chat/entities/emberMemory/emberMemory.schema.d.ts.map +1 -0
  18. package/dist/modules/ember-chat/entities/emberMemory/emberMemory.schema.js +11 -0
  19. package/dist/modules/ember-chat/entities/emberMemory/emberMemory.schema.js.map +1 -0
  20. package/dist/modules/ember-chat/interface-adapters/controllers/http/emberChat.routes.d.ts +2 -0
  21. package/dist/modules/ember-chat/interface-adapters/controllers/http/emberChat.routes.d.ts.map +1 -1
  22. package/dist/modules/ember-chat/interface-adapters/controllers/http/emberChat.routes.js +7 -1
  23. package/dist/modules/ember-chat/interface-adapters/controllers/http/emberChat.routes.js.map +1 -1
  24. package/dist/modules/ember-chat/interface-adapters/gateways/emberMemory.fileSystem.gateway.d.ts +22 -0
  25. package/dist/modules/ember-chat/interface-adapters/gateways/emberMemory.fileSystem.gateway.d.ts.map +1 -0
  26. package/dist/modules/ember-chat/interface-adapters/gateways/emberMemory.fileSystem.gateway.js +55 -0
  27. package/dist/modules/ember-chat/interface-adapters/gateways/emberMemory.fileSystem.gateway.js.map +1 -0
  28. package/dist/modules/ember-chat/services/emberSystemPrompt.d.ts +2 -0
  29. package/dist/modules/ember-chat/services/emberSystemPrompt.d.ts.map +1 -1
  30. package/dist/modules/ember-chat/services/emberSystemPrompt.js +41 -8
  31. package/dist/modules/ember-chat/services/emberSystemPrompt.js.map +1 -1
  32. package/dist/modules/ember-chat/usecases/askEmber/askEmber.usecase.d.ts +2 -0
  33. package/dist/modules/ember-chat/usecases/askEmber/askEmber.usecase.d.ts.map +1 -1
  34. package/dist/modules/ember-chat/usecases/askEmber/askEmber.usecase.js +32 -2
  35. package/dist/modules/ember-chat/usecases/askEmber/askEmber.usecase.js.map +1 -1
  36. package/dist/modules/ember-chat/usecases/clearEmberMemory/clearEmberMemory.usecase.d.ts +7 -0
  37. package/dist/modules/ember-chat/usecases/clearEmberMemory/clearEmberMemory.usecase.d.ts.map +1 -0
  38. package/dist/modules/ember-chat/usecases/clearEmberMemory/clearEmberMemory.usecase.js +4 -0
  39. package/dist/modules/ember-chat/usecases/clearEmberMemory/clearEmberMemory.usecase.js.map +1 -0
  40. package/dist/modules/platform-integration/entities/egressScan/egressScan.defaults.d.ts +3 -0
  41. package/dist/modules/platform-integration/entities/egressScan/egressScan.defaults.d.ts.map +1 -0
  42. package/dist/modules/platform-integration/entities/egressScan/egressScan.defaults.js +9 -0
  43. package/dist/modules/platform-integration/entities/egressScan/egressScan.defaults.js.map +1 -0
  44. package/dist/modules/platform-integration/entities/egressScan/egressScan.gateway.d.ts +28 -0
  45. package/dist/modules/platform-integration/entities/egressScan/egressScan.gateway.d.ts.map +1 -0
  46. package/dist/modules/platform-integration/entities/egressScan/egressScan.gateway.js +2 -0
  47. package/dist/modules/platform-integration/entities/egressScan/egressScan.gateway.js.map +1 -0
  48. package/dist/modules/platform-integration/entities/egressScan/egressScan.scanner.d.ts +11 -0
  49. package/dist/modules/platform-integration/entities/egressScan/egressScan.scanner.d.ts.map +1 -0
  50. package/dist/modules/platform-integration/entities/egressScan/egressScan.scanner.js +70 -0
  51. package/dist/modules/platform-integration/entities/egressScan/egressScan.scanner.js.map +1 -0
  52. package/dist/modules/platform-integration/entities/egressScan/egressTrace.gateway.d.ts +5 -0
  53. package/dist/modules/platform-integration/entities/egressScan/egressTrace.gateway.d.ts.map +1 -0
  54. package/dist/modules/platform-integration/entities/egressScan/egressTrace.gateway.js +2 -0
  55. package/dist/modules/platform-integration/entities/egressScan/egressTrace.gateway.js.map +1 -0
  56. package/dist/modules/platform-integration/entities/executorToken/executorCapability.d.ts +9 -0
  57. package/dist/modules/platform-integration/entities/executorToken/executorCapability.d.ts.map +1 -0
  58. package/dist/modules/platform-integration/entities/executorToken/executorCapability.js +10 -0
  59. package/dist/modules/platform-integration/entities/executorToken/executorCapability.js.map +1 -0
  60. package/dist/modules/platform-integration/entities/idempotency/idempotencyStore.gateway.d.ts +4 -0
  61. package/dist/modules/platform-integration/entities/idempotency/idempotencyStore.gateway.d.ts.map +1 -0
  62. package/dist/modules/platform-integration/entities/idempotency/idempotencyStore.gateway.js +2 -0
  63. package/dist/modules/platform-integration/entities/idempotency/idempotencyStore.gateway.js.map +1 -0
  64. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.d.ts +27 -0
  65. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.d.ts.map +1 -0
  66. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.gateway.d.ts +13 -0
  67. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.gateway.d.ts.map +1 -0
  68. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.gateway.js +2 -0
  69. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.gateway.js.map +1 -0
  70. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.js +21 -0
  71. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.js.map +1 -0
  72. package/dist/modules/platform-integration/entities/transport/cidr.d.ts +2 -0
  73. package/dist/modules/platform-integration/entities/transport/cidr.d.ts.map +1 -0
  74. package/dist/modules/platform-integration/entities/transport/cidr.js +36 -0
  75. package/dist/modules/platform-integration/entities/transport/cidr.js.map +1 -0
  76. package/dist/modules/platform-integration/entities/transport/clientIpResolver.gateway.d.ts +8 -0
  77. package/dist/modules/platform-integration/entities/transport/clientIpResolver.gateway.d.ts.map +1 -0
  78. package/dist/modules/platform-integration/entities/transport/clientIpResolver.gateway.js +2 -0
  79. package/dist/modules/platform-integration/entities/transport/clientIpResolver.gateway.js.map +1 -0
  80. package/dist/modules/platform-integration/entities/transport/transportContext.d.ts +16 -0
  81. package/dist/modules/platform-integration/entities/transport/transportContext.d.ts.map +1 -0
  82. package/dist/modules/platform-integration/entities/transport/transportContext.js +2 -0
  83. package/dist/modules/platform-integration/entities/transport/transportContext.js.map +1 -0
  84. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/github.controller.d.ts.map +1 -1
  85. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/github.controller.js +4 -4
  86. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/github.controller.js.map +1 -1
  87. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/gitlab.controller.d.ts +5 -1
  88. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/gitlab.controller.d.ts.map +1 -1
  89. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/gitlab.controller.js +112 -18
  90. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/gitlab.controller.js.map +1 -1
  91. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/transportGuard.middleware.d.ts +25 -0
  92. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/transportGuard.middleware.d.ts.map +1 -0
  93. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/transportGuard.middleware.js +26 -0
  94. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/transportGuard.middleware.js.map +1 -0
  95. package/dist/modules/platform-integration/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.d.ts +14 -0
  96. package/dist/modules/platform-integration/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.d.ts.map +1 -0
  97. package/dist/modules/platform-integration/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.js +34 -0
  98. package/dist/modules/platform-integration/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.js.map +1 -0
  99. package/dist/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.gateway.d.ts +14 -0
  100. package/dist/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.gateway.d.ts.map +1 -0
  101. package/dist/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.gateway.js +27 -0
  102. package/dist/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.gateway.js.map +1 -0
  103. package/dist/modules/platform-integration/interface-adapters/gateways/loggerEgressTrace.gateway.d.ts +9 -0
  104. package/dist/modules/platform-integration/interface-adapters/gateways/loggerEgressTrace.gateway.d.ts.map +1 -0
  105. package/dist/modules/platform-integration/interface-adapters/gateways/loggerEgressTrace.gateway.js +14 -0
  106. package/dist/modules/platform-integration/interface-adapters/gateways/loggerEgressTrace.gateway.js.map +1 -0
  107. package/dist/modules/platform-integration/interface-adapters/gateways/memberAccess.gitlab.cli.gateway.d.ts +31 -0
  108. package/dist/modules/platform-integration/interface-adapters/gateways/memberAccess.gitlab.cli.gateway.d.ts.map +1 -0
  109. package/dist/modules/platform-integration/interface-adapters/gateways/memberAccess.gitlab.cli.gateway.js +83 -0
  110. package/dist/modules/platform-integration/interface-adapters/gateways/memberAccess.gitlab.cli.gateway.js.map +1 -0
  111. package/dist/modules/platform-integration/interface-adapters/gateways/scopedGitLabExecutor.d.ts +17 -0
  112. package/dist/modules/platform-integration/interface-adapters/gateways/scopedGitLabExecutor.d.ts.map +1 -0
  113. package/dist/modules/platform-integration/interface-adapters/gateways/scopedGitLabExecutor.js +17 -0
  114. package/dist/modules/platform-integration/interface-adapters/gateways/scopedGitLabExecutor.js.map +1 -0
  115. package/dist/modules/platform-integration/interface-adapters/gateways/threadFetch.gitlab.gateway.d.ts +6 -0
  116. package/dist/modules/platform-integration/interface-adapters/gateways/threadFetch.gitlab.gateway.d.ts.map +1 -1
  117. package/dist/modules/platform-integration/interface-adapters/gateways/threadFetch.gitlab.gateway.js +28 -1
  118. package/dist/modules/platform-integration/interface-adapters/gateways/threadFetch.gitlab.gateway.js.map +1 -1
  119. package/dist/modules/platform-integration/interface-adapters/gateways/transport/clientIpResolver.forwardedFor.gateway.d.ts +5 -0
  120. package/dist/modules/platform-integration/interface-adapters/gateways/transport/clientIpResolver.forwardedFor.gateway.d.ts.map +1 -0
  121. package/dist/modules/platform-integration/interface-adapters/gateways/transport/clientIpResolver.forwardedFor.gateway.js +16 -0
  122. package/dist/modules/platform-integration/interface-adapters/gateways/transport/clientIpResolver.forwardedFor.gateway.js.map +1 -0
  123. package/dist/modules/platform-integration/services/autoExecutorActionFilter.d.ts +9 -0
  124. package/dist/modules/platform-integration/services/autoExecutorActionFilter.d.ts.map +1 -0
  125. package/dist/modules/platform-integration/services/autoExecutorActionFilter.js +33 -0
  126. package/dist/modules/platform-integration/services/autoExecutorActionFilter.js.map +1 -0
  127. package/dist/modules/platform-integration/services/pinnedThreadFetchTarget.d.ts +23 -0
  128. package/dist/modules/platform-integration/services/pinnedThreadFetchTarget.d.ts.map +1 -0
  129. package/dist/modules/platform-integration/services/pinnedThreadFetchTarget.js +21 -0
  130. package/dist/modules/platform-integration/services/pinnedThreadFetchTarget.js.map +1 -0
  131. package/dist/modules/platform-integration/services/scopedExecutorEnvironment.d.ts +21 -0
  132. package/dist/modules/platform-integration/services/scopedExecutorEnvironment.d.ts.map +1 -0
  133. package/dist/modules/platform-integration/services/scopedExecutorEnvironment.js +39 -0
  134. package/dist/modules/platform-integration/services/scopedExecutorEnvironment.js.map +1 -0
  135. package/dist/modules/platform-integration/usecases/isTrustedActor.usecase.d.ts +17 -0
  136. package/dist/modules/platform-integration/usecases/isTrustedActor.usecase.d.ts.map +1 -0
  137. package/dist/modules/platform-integration/usecases/isTrustedActor.usecase.js +23 -0
  138. package/dist/modules/platform-integration/usecases/isTrustedActor.usecase.js.map +1 -0
  139. package/dist/modules/platform-integration/usecases/transport/evaluateTransport.usecase.d.ts +3 -0
  140. package/dist/modules/platform-integration/usecases/transport/evaluateTransport.usecase.d.ts.map +1 -0
  141. package/dist/modules/platform-integration/usecases/transport/evaluateTransport.usecase.js +18 -0
  142. package/dist/modules/platform-integration/usecases/transport/evaluateTransport.usecase.js.map +1 -0
  143. package/dist/modules/review-execution/entities/actionProvenance/actionProvenance.d.ts +9 -0
  144. package/dist/modules/review-execution/entities/actionProvenance/actionProvenance.d.ts.map +1 -0
  145. package/dist/modules/review-execution/entities/actionProvenance/actionProvenance.js +11 -0
  146. package/dist/modules/review-execution/entities/actionProvenance/actionProvenance.js.map +1 -0
  147. package/dist/modules/review-execution/entities/threadInventory/threadInventory.gateway.d.ts +13 -0
  148. package/dist/modules/review-execution/entities/threadInventory/threadInventory.gateway.d.ts.map +1 -0
  149. package/dist/modules/review-execution/entities/threadInventory/threadInventory.gateway.js +2 -0
  150. package/dist/modules/review-execution/entities/threadInventory/threadInventory.gateway.js.map +1 -0
  151. package/dist/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.d.ts +14 -0
  152. package/dist/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.d.ts.map +1 -0
  153. package/dist/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.js +31 -0
  154. package/dist/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.js.map +1 -0
  155. package/dist/modules/review-execution/services/constrainActionSurface.d.ts +19 -0
  156. package/dist/modules/review-execution/services/constrainActionSurface.d.ts.map +1 -0
  157. package/dist/modules/review-execution/services/constrainActionSurface.js +49 -0
  158. package/dist/modules/review-execution/services/constrainActionSurface.js.map +1 -0
  159. package/dist/modules/review-execution/services/contextActionsExecutor.d.ts +2 -1
  160. package/dist/modules/review-execution/services/contextActionsExecutor.d.ts.map +1 -1
  161. package/dist/modules/review-execution/services/contextActionsExecutor.js +20 -2
  162. package/dist/modules/review-execution/services/contextActionsExecutor.js.map +1 -1
  163. package/dist/modules/review-execution/services/dispatchConstrainedActions.d.ts +30 -0
  164. package/dist/modules/review-execution/services/dispatchConstrainedActions.d.ts.map +1 -0
  165. package/dist/modules/review-execution/services/dispatchConstrainedActions.js +20 -0
  166. package/dist/modules/review-execution/services/dispatchConstrainedActions.js.map +1 -0
  167. package/dist/modules/review-execution/services/publicOutputExecutor.d.ts +10 -0
  168. package/dist/modules/review-execution/services/publicOutputExecutor.d.ts.map +1 -0
  169. package/dist/modules/review-execution/services/publicOutputExecutor.js +27 -0
  170. package/dist/modules/review-execution/services/publicOutputExecutor.js.map +1 -0
  171. package/dist/modules/review-execution/services/resolveThreadInventory.d.ts +19 -0
  172. package/dist/modules/review-execution/services/resolveThreadInventory.d.ts.map +1 -0
  173. package/dist/modules/review-execution/services/resolveThreadInventory.js +39 -0
  174. package/dist/modules/review-execution/services/resolveThreadInventory.js.map +1 -0
  175. package/dist/modules/review-execution/services/threadActionsExecutor.d.ts +11 -1
  176. package/dist/modules/review-execution/services/threadActionsExecutor.d.ts.map +1 -1
  177. package/dist/modules/review-execution/services/threadActionsExecutor.js +24 -2
  178. package/dist/modules/review-execution/services/threadActionsExecutor.js.map +1 -1
  179. package/dist/modules/review-execution/usecases/gateClaudeInvocation.usecase.d.ts +6 -0
  180. package/dist/modules/review-execution/usecases/gateClaudeInvocation.usecase.d.ts.map +1 -1
  181. package/dist/modules/review-execution/usecases/gateClaudeInvocation.usecase.js +2 -1
  182. package/dist/modules/review-execution/usecases/gateClaudeInvocation.usecase.js.map +1 -1
  183. package/dist/security/gitlabWebhookTokenSource.d.ts +9 -0
  184. package/dist/security/gitlabWebhookTokenSource.d.ts.map +1 -0
  185. package/dist/security/gitlabWebhookTokenSource.js +15 -0
  186. package/dist/security/gitlabWebhookTokenSource.js.map +1 -0
  187. package/dist/security/transportGuardConfig.d.ts +16 -0
  188. package/dist/security/transportGuardConfig.d.ts.map +1 -0
  189. package/dist/security/transportGuardConfig.js +38 -0
  190. package/dist/security/transportGuardConfig.js.map +1 -0
  191. package/dist/security/verifier.d.ts +9 -2
  192. package/dist/security/verifier.d.ts.map +1 -1
  193. package/dist/security/verifier.js +27 -10
  194. package/dist/security/verifier.js.map +1 -1
  195. package/dist/tests/acceptance/190-ember-live-answers-subscription.acceptance.test.js +7 -0
  196. package/dist/tests/acceptance/190-ember-live-answers-subscription.acceptance.test.js.map +1 -1
  197. package/dist/tests/acceptance/192-ember-ondemand-grounding-and-memory.acceptance.test.d.ts +2 -0
  198. package/dist/tests/acceptance/192-ember-ondemand-grounding-and-memory.acceptance.test.d.ts.map +1 -0
  199. package/dist/tests/acceptance/192-ember-ondemand-grounding-and-memory.acceptance.test.js +261 -0
  200. package/dist/tests/acceptance/192-ember-ondemand-grounding-and-memory.acceptance.test.js.map +1 -0
  201. package/dist/tests/factories/emberMemory.factory.d.ts +8 -0
  202. package/dist/tests/factories/emberMemory.factory.d.ts.map +1 -0
  203. package/dist/tests/factories/emberMemory.factory.js +19 -0
  204. package/dist/tests/factories/emberMemory.factory.js.map +1 -0
  205. package/dist/tests/factories/transportContext.factory.d.ts +5 -0
  206. package/dist/tests/factories/transportContext.factory.d.ts.map +1 -0
  207. package/dist/tests/factories/transportContext.factory.js +14 -0
  208. package/dist/tests/factories/transportContext.factory.js.map +1 -0
  209. package/dist/tests/stubs/egressScan.stub.d.ts +16 -0
  210. package/dist/tests/stubs/egressScan.stub.d.ts.map +1 -0
  211. package/dist/tests/stubs/egressScan.stub.js +28 -0
  212. package/dist/tests/stubs/egressScan.stub.js.map +1 -0
  213. package/dist/tests/stubs/emberMemory.stub.d.ts +25 -0
  214. package/dist/tests/stubs/emberMemory.stub.d.ts.map +1 -0
  215. package/dist/tests/stubs/emberMemory.stub.js +61 -0
  216. package/dist/tests/stubs/emberMemory.stub.js.map +1 -0
  217. package/dist/tests/stubs/idempotencyStore.stub.d.ts +9 -0
  218. package/dist/tests/stubs/idempotencyStore.stub.d.ts.map +1 -0
  219. package/dist/tests/stubs/idempotencyStore.stub.js +19 -0
  220. package/dist/tests/stubs/idempotencyStore.stub.js.map +1 -0
  221. package/dist/tests/stubs/memberAccess.stub.d.ts +24 -0
  222. package/dist/tests/stubs/memberAccess.stub.d.ts.map +1 -0
  223. package/dist/tests/stubs/memberAccess.stub.js +28 -0
  224. package/dist/tests/stubs/memberAccess.stub.js.map +1 -0
  225. package/dist/tests/units/entities/egressScan/egressScan.scanner.test.d.ts +2 -0
  226. package/dist/tests/units/entities/egressScan/egressScan.scanner.test.d.ts.map +1 -0
  227. package/dist/tests/units/entities/egressScan/egressScan.scanner.test.js +136 -0
  228. package/dist/tests/units/entities/egressScan/egressScan.scanner.test.js.map +1 -0
  229. package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.js +114 -0
  230. package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.js.map +1 -1
  231. package/dist/tests/units/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.test.d.ts +2 -0
  232. package/dist/tests/units/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.test.d.ts.map +1 -0
  233. package/dist/tests/units/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.test.js +116 -0
  234. package/dist/tests/units/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.test.js.map +1 -0
  235. package/dist/tests/units/modules/ember-chat/controllers/emberChat.routes.test.js +14 -0
  236. package/dist/tests/units/modules/ember-chat/controllers/emberChat.routes.test.js.map +1 -1
  237. package/dist/tests/units/modules/ember-chat/entities/emberMemory.guard.test.d.ts +2 -0
  238. package/dist/tests/units/modules/ember-chat/entities/emberMemory.guard.test.d.ts.map +1 -0
  239. package/dist/tests/units/modules/ember-chat/entities/emberMemory.guard.test.js +51 -0
  240. package/dist/tests/units/modules/ember-chat/entities/emberMemory.guard.test.js.map +1 -0
  241. package/dist/tests/units/modules/ember-chat/gateways/emberMemory.fileSystem.gateway.test.d.ts +2 -0
  242. package/dist/tests/units/modules/ember-chat/gateways/emberMemory.fileSystem.gateway.test.d.ts.map +1 -0
  243. package/dist/tests/units/modules/ember-chat/gateways/emberMemory.fileSystem.gateway.test.js +82 -0
  244. package/dist/tests/units/modules/ember-chat/gateways/emberMemory.fileSystem.gateway.test.js.map +1 -0
  245. package/dist/tests/units/modules/ember-chat/services/emberSystemPrompt.test.js +74 -2
  246. package/dist/tests/units/modules/ember-chat/services/emberSystemPrompt.test.js.map +1 -1
  247. package/dist/tests/units/modules/ember-chat/usecases/askEmber.usecase.test.js +56 -1
  248. package/dist/tests/units/modules/ember-chat/usecases/askEmber.usecase.test.js.map +1 -1
  249. package/dist/tests/units/modules/ember-chat/usecases/clearEmberMemory.usecase.test.d.ts +2 -0
  250. package/dist/tests/units/modules/ember-chat/usecases/clearEmberMemory.usecase.test.d.ts.map +1 -0
  251. package/dist/tests/units/modules/ember-chat/usecases/clearEmberMemory.usecase.test.js +14 -0
  252. package/dist/tests/units/modules/ember-chat/usecases/clearEmberMemory.usecase.test.js.map +1 -0
  253. package/dist/tests/units/modules/platform-integration/controllers/gitlabProcessorProvenance.test.d.ts +2 -0
  254. package/dist/tests/units/modules/platform-integration/controllers/gitlabProcessorProvenance.test.d.ts.map +1 -0
  255. package/dist/tests/units/modules/platform-integration/controllers/gitlabProcessorProvenance.test.js +69 -0
  256. package/dist/tests/units/modules/platform-integration/controllers/gitlabProcessorProvenance.test.js.map +1 -0
  257. package/dist/tests/units/modules/platform-integration/entities/executorCapability.test.d.ts +2 -0
  258. package/dist/tests/units/modules/platform-integration/entities/executorCapability.test.d.ts.map +1 -0
  259. package/dist/tests/units/modules/platform-integration/entities/executorCapability.test.js +28 -0
  260. package/dist/tests/units/modules/platform-integration/entities/executorCapability.test.js.map +1 -0
  261. package/dist/tests/units/modules/platform-integration/entities/memberAccess/memberAccess.test.d.ts +2 -0
  262. package/dist/tests/units/modules/platform-integration/entities/memberAccess/memberAccess.test.d.ts.map +1 -0
  263. package/dist/tests/units/modules/platform-integration/entities/memberAccess/memberAccess.test.js +18 -0
  264. package/dist/tests/units/modules/platform-integration/entities/memberAccess/memberAccess.test.js.map +1 -0
  265. package/dist/tests/units/modules/platform-integration/gateways/defaultGitLabExecutor.test.d.ts +2 -0
  266. package/dist/tests/units/modules/platform-integration/gateways/defaultGitLabExecutor.test.d.ts.map +1 -0
  267. package/dist/tests/units/modules/platform-integration/gateways/defaultGitLabExecutor.test.js +13 -0
  268. package/dist/tests/units/modules/platform-integration/gateways/defaultGitLabExecutor.test.js.map +1 -0
  269. package/dist/tests/units/modules/platform-integration/gateways/memberAccess.gitlab.cli.gateway.test.d.ts +2 -0
  270. package/dist/tests/units/modules/platform-integration/gateways/memberAccess.gitlab.cli.gateway.test.d.ts.map +1 -0
  271. package/dist/tests/units/modules/platform-integration/gateways/memberAccess.gitlab.cli.gateway.test.js +105 -0
  272. package/dist/tests/units/modules/platform-integration/gateways/memberAccess.gitlab.cli.gateway.test.js.map +1 -0
  273. package/dist/tests/units/modules/platform-integration/gateways/scopedGitLabExecutor.test.d.ts +2 -0
  274. package/dist/tests/units/modules/platform-integration/gateways/scopedGitLabExecutor.test.d.ts.map +1 -0
  275. package/dist/tests/units/modules/platform-integration/gateways/scopedGitLabExecutor.test.js +85 -0
  276. package/dist/tests/units/modules/platform-integration/gateways/scopedGitLabExecutor.test.js.map +1 -0
  277. package/dist/tests/units/modules/platform-integration/interface-adapters/controllers/webhook/gitlabIdempotency.controller.test.d.ts +2 -0
  278. package/dist/tests/units/modules/platform-integration/interface-adapters/controllers/webhook/gitlabIdempotency.controller.test.d.ts.map +1 -0
  279. package/dist/tests/units/modules/platform-integration/interface-adapters/controllers/webhook/gitlabIdempotency.controller.test.js +216 -0
  280. package/dist/tests/units/modules/platform-integration/interface-adapters/controllers/webhook/gitlabIdempotency.controller.test.js.map +1 -0
  281. package/dist/tests/units/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.test.d.ts +2 -0
  282. package/dist/tests/units/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.test.d.ts.map +1 -0
  283. package/dist/tests/units/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.test.js +48 -0
  284. package/dist/tests/units/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.test.js.map +1 -0
  285. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/clientIpResolver.forwardedFor.gateway.test.d.ts +2 -0
  286. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/clientIpResolver.forwardedFor.gateway.test.d.ts.map +1 -0
  287. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/clientIpResolver.forwardedFor.gateway.test.js +29 -0
  288. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/clientIpResolver.forwardedFor.gateway.test.js.map +1 -0
  289. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/transportGuard.middleware.test.d.ts +2 -0
  290. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/transportGuard.middleware.test.d.ts.map +1 -0
  291. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/transportGuard.middleware.test.js +66 -0
  292. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/transportGuard.middleware.test.js.map +1 -0
  293. package/dist/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.d.ts +2 -0
  294. package/dist/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.d.ts.map +1 -0
  295. package/dist/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.js +38 -0
  296. package/dist/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.js.map +1 -0
  297. package/dist/tests/units/modules/platform-integration/services/autoExecutorCapabilityGate.test.d.ts +2 -0
  298. package/dist/tests/units/modules/platform-integration/services/autoExecutorCapabilityGate.test.d.ts.map +1 -0
  299. package/dist/tests/units/modules/platform-integration/services/autoExecutorCapabilityGate.test.js +40 -0
  300. package/dist/tests/units/modules/platform-integration/services/autoExecutorCapabilityGate.test.js.map +1 -0
  301. package/dist/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.d.ts +2 -0
  302. package/dist/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.d.ts.map +1 -0
  303. package/dist/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.js +76 -0
  304. package/dist/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.js.map +1 -0
  305. package/dist/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.d.ts +2 -0
  306. package/dist/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.d.ts.map +1 -0
  307. package/dist/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.js +120 -0
  308. package/dist/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.js.map +1 -0
  309. package/dist/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.d.ts +2 -0
  310. package/dist/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.d.ts.map +1 -0
  311. package/dist/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.js +33 -0
  312. package/dist/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.js.map +1 -0
  313. package/dist/tests/units/modules/platform-integration/usecases/transport/evaluateTransport.usecase.test.d.ts +2 -0
  314. package/dist/tests/units/modules/platform-integration/usecases/transport/evaluateTransport.usecase.test.d.ts.map +1 -0
  315. package/dist/tests/units/modules/platform-integration/usecases/transport/evaluateTransport.usecase.test.js +69 -0
  316. package/dist/tests/units/modules/platform-integration/usecases/transport/evaluateTransport.usecase.test.js.map +1 -0
  317. package/dist/tests/units/modules/review-execution/entities/actionProvenance/actionProvenance.test.d.ts +2 -0
  318. package/dist/tests/units/modules/review-execution/entities/actionProvenance/actionProvenance.test.d.ts.map +1 -0
  319. package/dist/tests/units/modules/review-execution/entities/actionProvenance/actionProvenance.test.js +26 -0
  320. package/dist/tests/units/modules/review-execution/entities/actionProvenance/actionProvenance.test.js.map +1 -0
  321. package/dist/tests/units/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.test.d.ts +2 -0
  322. package/dist/tests/units/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.test.d.ts.map +1 -0
  323. package/dist/tests/units/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.test.js +44 -0
  324. package/dist/tests/units/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.test.js.map +1 -0
  325. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.parity.test.d.ts +2 -0
  326. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.parity.test.d.ts.map +1 -0
  327. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.parity.test.js +29 -0
  328. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.parity.test.js.map +1 -0
  329. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.test.d.ts +2 -0
  330. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.test.d.ts.map +1 -0
  331. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.test.js +115 -0
  332. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.test.js.map +1 -0
  333. package/dist/tests/units/modules/review-execution/services/contextActionsExecutor.autopath.test.d.ts +2 -0
  334. package/dist/tests/units/modules/review-execution/services/contextActionsExecutor.autopath.test.d.ts.map +1 -0
  335. package/dist/tests/units/modules/review-execution/services/contextActionsExecutor.autopath.test.js +52 -0
  336. package/dist/tests/units/modules/review-execution/services/contextActionsExecutor.autopath.test.js.map +1 -0
  337. package/dist/tests/units/modules/review-execution/services/dispatchConstrainedActions.test.d.ts +2 -0
  338. package/dist/tests/units/modules/review-execution/services/dispatchConstrainedActions.test.d.ts.map +1 -0
  339. package/dist/tests/units/modules/review-execution/services/dispatchConstrainedActions.test.js +124 -0
  340. package/dist/tests/units/modules/review-execution/services/dispatchConstrainedActions.test.js.map +1 -0
  341. package/dist/tests/units/modules/review-execution/services/resolveThreadInventory.test.d.ts +2 -0
  342. package/dist/tests/units/modules/review-execution/services/resolveThreadInventory.test.d.ts.map +1 -0
  343. package/dist/tests/units/modules/review-execution/services/resolveThreadInventory.test.js +67 -0
  344. package/dist/tests/units/modules/review-execution/services/resolveThreadInventory.test.js.map +1 -0
  345. package/dist/tests/units/modules/review-execution/usecases/gateClaudeInvocation.usecase.test.js +42 -0
  346. package/dist/tests/units/modules/review-execution/usecases/gateClaudeInvocation.usecase.test.js.map +1 -1
  347. package/dist/tests/units/security/gitlabTokenRotation.test.d.ts +2 -0
  348. package/dist/tests/units/security/gitlabTokenRotation.test.d.ts.map +1 -0
  349. package/dist/tests/units/security/gitlabTokenRotation.test.js +39 -0
  350. package/dist/tests/units/security/gitlabTokenRotation.test.js.map +1 -0
  351. package/dist/tests/units/security/noSpoofableTransportGuard.test.d.ts +2 -0
  352. package/dist/tests/units/security/noSpoofableTransportGuard.test.d.ts.map +1 -0
  353. package/dist/tests/units/security/noSpoofableTransportGuard.test.js +30 -0
  354. package/dist/tests/units/security/noSpoofableTransportGuard.test.js.map +1 -0
  355. package/dist/tests/units/security/transportGuardConfig.test.d.ts +2 -0
  356. package/dist/tests/units/security/transportGuardConfig.test.d.ts.map +1 -0
  357. package/dist/tests/units/security/transportGuardConfig.test.js +38 -0
  358. package/dist/tests/units/security/transportGuardConfig.test.js.map +1 -0
  359. package/dist/tests/units/security/verifier.test.js +33 -2
  360. package/dist/tests/units/security/verifier.test.js.map +1 -1
  361. package/dist/tests/units/services/contextActionsExecutor.egress.test.d.ts +2 -0
  362. package/dist/tests/units/services/contextActionsExecutor.egress.test.d.ts.map +1 -0
  363. package/dist/tests/units/services/contextActionsExecutor.egress.test.js +117 -0
  364. package/dist/tests/units/services/contextActionsExecutor.egress.test.js.map +1 -0
  365. package/dist/tests/units/services/contextActionsExecutor.test.js +24 -31
  366. package/dist/tests/units/services/contextActionsExecutor.test.js.map +1 -1
  367. package/dist/tests/units/services/publicOutputExecutor.test.d.ts +2 -0
  368. package/dist/tests/units/services/publicOutputExecutor.test.d.ts.map +1 -0
  369. package/dist/tests/units/services/publicOutputExecutor.test.js +72 -0
  370. package/dist/tests/units/services/publicOutputExecutor.test.js.map +1 -0
  371. package/dist/tests/units/services/threadActionsExecutor.egress.test.d.ts +2 -0
  372. package/dist/tests/units/services/threadActionsExecutor.egress.test.d.ts.map +1 -0
  373. package/dist/tests/units/services/threadActionsExecutor.egress.test.js +113 -0
  374. package/dist/tests/units/services/threadActionsExecutor.egress.test.js.map +1 -0
  375. package/dist/tests/units/services/threadActionsExecutor.test.js +32 -96
  376. package/dist/tests/units/services/threadActionsExecutor.test.js.map +1 -1
  377. package/package.json +1 -1
@@ -31,12 +31,38 @@ function boundInsights(insights) {
31
31
  function mostRecent(items, limit) {
32
32
  return items.slice(Math.max(0, items.length - limit));
33
33
  }
34
+ function conversationMemorySection(memory) {
35
+ if (memory === null || memory.turns.length === 0) {
36
+ return '';
37
+ }
38
+ const turns = memory.turns
39
+ .map((turn, index) => `${index + 1}. Question : ${turn.question}\n Réponse : ${turn.answer}`)
40
+ .join('\n');
41
+ return [
42
+ '',
43
+ 'MÉMOIRE — conversation précédente sur ce projet (tours antérieurs) :',
44
+ "Sers-t'en pour comprendre une question de suivi sans répéter le sujet.",
45
+ turns,
46
+ ].join('\n');
47
+ }
48
+ function recurringInsightsSection(memory) {
49
+ if (memory === null || memory.insights.length === 0) {
50
+ return '';
51
+ }
52
+ const insights = memory.insights.map((insight) => `- ${insight}`).join('\n');
53
+ return [
54
+ '',
55
+ 'CONSTATS RÉCURRENTS — déjà dérivés des données de review de ce projet :',
56
+ 'Réutilise-les tels quels plutôt que de les recalculer.',
57
+ insights,
58
+ ].join('\n');
59
+ }
34
60
  function reviewCountSummary(stats) {
35
61
  if (stats === null || stats.reviews.length <= MAX_RECENT_REVIEWS) {
36
62
  return '';
37
63
  }
38
64
  const olderCount = stats.reviews.length - MAX_RECENT_REVIEWS;
39
- return `… et ${olderCount} reviews plus anciennes (résumé agrégé seulement).`;
65
+ return `… et ${olderCount} reviews plus anciennes que tu peux lire à la demande dans les données du projet.`;
40
66
  }
41
67
  export function buildEmberSystemPrompt(grounding) {
42
68
  const reviewScores = boundReviewScores(grounding.reviewScores);
@@ -44,10 +70,14 @@ export function buildEmberSystemPrompt(grounding) {
44
70
  return [
45
71
  "Tu es Ember, l'assistant conversationnel du tableau de bord ReviewFlow.",
46
72
  '',
47
- 'TES SEULES SOURCES DE DONNÉES sont ces données de review du projet, fournies ci-dessous.',
48
- "Tu n'as aucun autre accès : ni système de fichiers, ni outil, ni réseau.",
73
+ 'Ces données de review du projet, fournies ci-dessous, sont ton point de départ :',
74
+ 'un instantané des éléments les plus récents, fourni pour te faire gagner du temps.',
75
+ "Ce n'est PAS une limite. Tu peux lire à la demande les données de review du projet",
76
+ 'sur disque pour répondre au sujet de n\'importe quel élément, récent ou ancien,',
77
+ 'même au-delà de cet instantané. Ne refuse jamais une question au seul motif',
78
+ "qu'un élément se trouve hors de cet instantané récent.",
49
79
  '',
50
- 'reviewScores (scores et statistiques de review) :',
80
+ 'reviewScores (scores et statistiques de review, instantané récent) :',
51
81
  JSON.stringify(reviewScores),
52
82
  olderReviewsNote,
53
83
  '',
@@ -59,14 +89,17 @@ export function buildEmberSystemPrompt(grounding) {
59
89
  '',
60
90
  'worktrees (état des worktrees) :',
61
91
  JSON.stringify(mostRecent(grounding.worktrees, MAX_WORKTREES)),
92
+ recurringInsightsSection(grounding.memory),
93
+ conversationMemorySection(grounding.memory),
62
94
  '',
63
- 'GROUNDING : réponds uniquement à partir de ces données de review.',
64
- "Si la question sort de ces données, dis que tu ne sais répondre qu'à propos des reviews",
65
- "plutôt que d'inventer une réponse. N'invente jamais.",
95
+ 'GROUNDING : réponds uniquement à partir des données de review du projet,',
96
+ "qu'elles soient dans cet instantané ou lues à la demande sur disque.",
97
+ "Si la réponse ne se trouve dans aucune de ces données, dis que tu ne sais répondre",
98
+ "qu'à propos des reviews plutôt que d'inventer une réponse. N'invente jamais.",
66
99
  '',
67
100
  'LECTURE SEULE : tu ne modifies, ne crées et ne supprimes rien. Si on te demande',
68
101
  "d'écrire, de créer ou de modifier quelque chose (par exemple un quality gate),",
69
- "explique que cela arrivera en Phase B et n'effectue aucune écriture.",
102
+ "explique que tu restes en lecture seule et n'effectue aucune écriture.",
70
103
  ].join('\n');
71
104
  }
72
105
  //# sourceMappingURL=emberSystemPrompt.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"emberSystemPrompt.js","sourceRoot":"","sources":["../../../../src/modules/ember-chat/services/emberSystemPrompt.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"emberSystemPrompt.js","sourceRoot":"","sources":["../../../../src/modules/ember-chat/services/emberSystemPrompt.ts"],"names":[],"mappings":"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"}
@@ -1,6 +1,7 @@
1
1
  import type { EnvironmentGateway } from '../../../../modules/claude-invocation/entities/billingState/environment.gateway.js';
2
2
  import type { EmberMessage } from '../../../../modules/ember-chat/entities/emberMessage/emberMessage.schema.js';
3
3
  import type { EmberReadDataGateway } from '../../../../modules/ember-chat/entities/emberTool/emberTool.gateway.js';
4
+ import type { EmberMemoryGateway } from '../../../../modules/ember-chat/entities/emberMemory/emberMemory.gateway.js';
4
5
  import type { EmberAnswerTransportGateway } from '../../../../modules/ember-chat/entities/emberAnswer/emberAnswerTransport.gateway.js';
5
6
  import type { EmberStreamSubscriber } from '../../../../modules/ember-chat/usecases/askEmber/emberStream.js';
6
7
  export type { EmberStatus, EmberStreamSubscriber } from '../../../../modules/ember-chat/usecases/askEmber/emberStream.js';
@@ -8,6 +9,7 @@ export interface AskEmberDependencies {
8
9
  transport: EmberAnswerTransportGateway;
9
10
  environment: EnvironmentGateway;
10
11
  readData: EmberReadDataGateway;
12
+ memory: EmberMemoryGateway;
11
13
  projectPath: string;
12
14
  }
13
15
  export type AskEmberResult = {
@@ -1 +1 @@
1
- {"version":3,"file":"askEmber.usecase.d.ts","sourceRoot":"","sources":["../../../../../src/modules/ember-chat/usecases/askEmber/askEmber.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,0EAA0E,CAAC;AACnH,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,mEAAmE,CAAC;AACtG,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,8DAA8D,CAAC;AACzG,OAAO,KAAK,EAEV,2BAA2B,EAC5B,MAAM,2EAA2E,CAAC;AACnF,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,uDAAuD,CAAC;AAGnG,YAAY,EAAE,WAAW,EAAE,qBAAqB,EAAE,MAAM,uDAAuD,CAAC;AAEhH,MAAM,WAAW,oBAAoB;IACnC,SAAS,EAAE,2BAA2B,CAAC;IACvC,WAAW,EAAE,kBAAkB,CAAC;IAChC,QAAQ,EAAE,oBAAoB,CAAC;IAC/B,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,MAAM,cAAc,GACtB;IACE,MAAM,EAAE,WAAW,CAAC;IACpB,SAAS,EAAE,CAAC,UAAU,EAAE,qBAAqB,KAAK,IAAI,CAAC;IACvD,MAAM,EAAE,MAAM,IAAI,CAAC;CACpB,GACD;IAAE,MAAM,EAAE,aAAa,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,GACzC;IAAE,MAAM,EAAE,8BAA8B,CAAA;CAAE,CAAC;AA2D/C,wBAAsB,QAAQ,CAC5B,OAAO,EAAE,YAAY,EACrB,YAAY,EAAE,oBAAoB,GACjC,OAAO,CAAC,cAAc,CAAC,CA4BzB"}
1
+ {"version":3,"file":"askEmber.usecase.d.ts","sourceRoot":"","sources":["../../../../../src/modules/ember-chat/usecases/askEmber/askEmber.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,0EAA0E,CAAC;AACnH,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,mEAAmE,CAAC;AACtG,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,8DAA8D,CAAC;AACzG,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,kEAAkE,CAAC;AAE3G,OAAO,KAAK,EAEV,2BAA2B,EAC5B,MAAM,2EAA2E,CAAC;AACnF,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,uDAAuD,CAAC;AAGnG,YAAY,EAAE,WAAW,EAAE,qBAAqB,EAAE,MAAM,uDAAuD,CAAC;AAEhH,MAAM,WAAW,oBAAoB;IACnC,SAAS,EAAE,2BAA2B,CAAC;IACvC,WAAW,EAAE,kBAAkB,CAAC;IAChC,QAAQ,EAAE,oBAAoB,CAAC;IAC/B,MAAM,EAAE,kBAAkB,CAAC;IAC3B,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,MAAM,cAAc,GACtB;IACE,MAAM,EAAE,WAAW,CAAC;IACpB,SAAS,EAAE,CAAC,UAAU,EAAE,qBAAqB,KAAK,IAAI,CAAC;IACvD,MAAM,EAAE,MAAM,IAAI,CAAC;CACpB,GACD;IAAE,MAAM,EAAE,aAAa,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,GACzC;IAAE,MAAM,EAAE,8BAA8B,CAAA;CAAE,CAAC;AA4F/C,wBAAsB,QAAQ,CAC5B,OAAO,EAAE,YAAY,EACrB,YAAY,EAAE,oBAAoB,GACjC,OAAO,CAAC,cAAc,CAAC,CA+BzB"}
@@ -1,8 +1,13 @@
1
1
  import { buildEmberSystemPrompt } from '../../../../modules/ember-chat/services/emberSystemPrompt.js';
2
2
  class AnswerRelay {
3
+ onAnswered;
3
4
  target = null;
4
5
  bufferedChunks = [];
5
6
  terminal = null;
7
+ answer = '';
8
+ constructor(onAnswered) {
9
+ this.onAnswered = onAnswered;
10
+ }
6
11
  attach(subscriber) {
7
12
  this.target = subscriber;
8
13
  subscriber.onStatus('working');
@@ -15,6 +20,7 @@ class AnswerRelay {
15
20
  }
16
21
  }
17
22
  onChunk(text) {
23
+ this.answer += text;
18
24
  if (this.target === null) {
19
25
  this.bufferedChunks.push(text);
20
26
  return;
@@ -22,6 +28,7 @@ class AnswerRelay {
22
28
  this.target.onChunk(text);
23
29
  }
24
30
  onDone() {
31
+ this.onAnswered(this.answer);
25
32
  const terminal = { kind: 'done' };
26
33
  if (this.target === null) {
27
34
  this.terminal = terminal;
@@ -50,18 +57,41 @@ class AnswerRelay {
50
57
  this.target.onError(terminal.message);
51
58
  }
52
59
  }
60
+ async function loadMemorySafely(memory, projectPath) {
61
+ try {
62
+ return await memory.load(projectPath);
63
+ }
64
+ catch {
65
+ // A corrupted or unreadable memory must never block an answer.
66
+ return null;
67
+ }
68
+ }
69
+ async function rememberTurn(memory, projectPath, question, answer) {
70
+ if (answer.trim().length === 0) {
71
+ return;
72
+ }
73
+ try {
74
+ await memory.appendTurn(projectPath, { question, answer });
75
+ }
76
+ catch {
77
+ // Best-effort: a memory write failure must never break answering.
78
+ }
79
+ }
53
80
  export async function askEmber(message, dependencies) {
54
81
  if (dependencies.environment.hasAnthropicApiKey()) {
55
82
  return { status: 'billing-regression-prevented' };
56
83
  }
57
- const { readData, projectPath, transport } = dependencies;
84
+ const { readData, memory, projectPath, transport } = dependencies;
58
85
  const systemPrompt = buildEmberSystemPrompt({
59
86
  reviewScores: await readData.reviewScores(projectPath),
60
87
  insights: await readData.insights(projectPath),
61
88
  jobHistory: await readData.jobHistory(projectPath),
62
89
  worktrees: await readData.worktrees(),
90
+ memory: await loadMemorySafely(memory, projectPath),
91
+ });
92
+ const relay = new AnswerRelay((answer) => {
93
+ void rememberTurn(memory, projectPath, message.question, answer);
63
94
  });
64
- const relay = new AnswerRelay();
65
95
  const started = transport.start({ question: message.question, systemPrompt, projectPath }, relay);
66
96
  if (started.status === 'failed') {
67
97
  return { status: 'unavailable', reason: started.reason };
@@ -1 +1 @@
1
- {"version":3,"file":"askEmber.usecase.js","sourceRoot":"","sources":["../../../../../src/modules/ember-chat/usecases/askEmber/askEmber.usecase.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,sBAAsB,EAAE,MAAM,oDAAoD,CAAC;AAoB5F,MAAM,WAAW;IACP,MAAM,GAAiC,IAAI,CAAC;IACnC,cAAc,GAAa,EAAE,CAAC;IACvC,QAAQ,GAAiE,IAAI,CAAC;IAEtF,MAAM,CAAC,UAAiC;QACtC,IAAI,CAAC,MAAM,GAAG,UAAU,CAAC;QACzB,UAAU,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QAC/B,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxC,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAC5B,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC;QAC/B,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,EAAE,CAAC;YAC3B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACpC,CAAC;IACH,CAAC;IAED,OAAO,CAAC,IAAY;QAClB,IAAI,IAAI,CAAC,MAAM,KAAK,IAAI,EAAE,CAAC;YACzB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC/B,OAAO;QACT,CAAC;QACD,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;IAED,MAAM;QACJ,MAAM,QAAQ,GAAG,EAAE,IAAI,EAAE,MAAM,EAAW,CAAC;QAC3C,IAAI,IAAI,CAAC,MAAM,KAAK,IAAI,EAAE,CAAC;YACzB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;YACzB,OAAO;QACT,CAAC;QACD,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;IAC/B,CAAC;IAED,OAAO,CAAC,OAAe;QACrB,MAAM,QAAQ,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAW,CAAC;QACrD,IAAI,IAAI,CAAC,MAAM,KAAK,IAAI,EAAE,CAAC;YACzB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;YACzB,OAAO;QACT,CAAC;QACD,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;IAC/B,CAAC;IAEO,aAAa,CAAC,QAA+D;QACnF,IAAI,IAAI,CAAC,MAAM,KAAK,IAAI,EAAE,CAAC;YACzB,OAAO;QACT,CAAC;QACD,IAAI,QAAQ,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;YAC7B,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;YAC7B,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;YACrB,OAAO;QACT,CAAC;QACD,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QAC9B,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;IACxC,CAAC;CACF;AAED,MAAM,CAAC,KAAK,UAAU,QAAQ,CAC5B,OAAqB,EACrB,YAAkC;IAElC,IAAI,YAAY,CAAC,WAAW,CAAC,kBAAkB,EAAE,EAAE,CAAC;QAClD,OAAO,EAAE,MAAM,EAAE,8BAA8B,EAAE,CAAC;IACpD,CAAC;IAED,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,SAAS,EAAE,GAAG,YAAY,CAAC;IAC1D,MAAM,YAAY,GAAG,sBAAsB,CAAC;QAC1C,YAAY,EAAE,MAAM,QAAQ,CAAC,YAAY,CAAC,WAAW,CAAC;QACtD,QAAQ,EAAE,MAAM,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC;QAC9C,UAAU,EAAE,MAAM,QAAQ,CAAC,UAAU,CAAC,WAAW,CAAC;QAClD,SAAS,EAAE,MAAM,QAAQ,CAAC,SAAS,EAAE;KACtC,CAAC,CAAC;IAEH,MAAM,KAAK,GAAG,IAAI,WAAW,EAAE,CAAC;IAChC,MAAM,OAAO,GAAG,SAAS,CAAC,KAAK,CAC7B,EAAE,QAAQ,EAAE,OAAO,CAAC,QAAQ,EAAE,YAAY,EAAE,WAAW,EAAE,EACzD,KAAK,CACN,CAAC;IAEF,IAAI,OAAO,CAAC,MAAM,KAAK,QAAQ,EAAE,CAAC;QAChC,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE,CAAC;IAC3D,CAAC;IAED,OAAO;QACL,MAAM,EAAE,WAAW;QACnB,SAAS,EAAE,CAAC,UAAU,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC;QACnD,MAAM,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE;KACnC,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"askEmber.usecase.js","sourceRoot":"","sources":["../../../../../src/modules/ember-chat/usecases/askEmber/askEmber.usecase.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ import type { EmberMemoryGateway } from '../../../../modules/ember-chat/entities/emberMemory/emberMemory.gateway.js';
2
+ export interface ClearEmberMemoryDependencies {
3
+ memory: EmberMemoryGateway;
4
+ projectPath: string;
5
+ }
6
+ export declare function clearEmberMemory(dependencies: ClearEmberMemoryDependencies): Promise<void>;
7
+ //# sourceMappingURL=clearEmberMemory.usecase.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"clearEmberMemory.usecase.d.ts","sourceRoot":"","sources":["../../../../../src/modules/ember-chat/usecases/clearEmberMemory/clearEmberMemory.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,kEAAkE,CAAC;AAE3G,MAAM,WAAW,4BAA4B;IAC3C,MAAM,EAAE,kBAAkB,CAAC;IAC3B,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,wBAAsB,gBAAgB,CACpC,YAAY,EAAE,4BAA4B,GACzC,OAAO,CAAC,IAAI,CAAC,CAEf"}
@@ -0,0 +1,4 @@
1
+ export async function clearEmberMemory(dependencies) {
2
+ await dependencies.memory.clear(dependencies.projectPath);
3
+ }
4
+ //# sourceMappingURL=clearEmberMemory.usecase.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"clearEmberMemory.usecase.js","sourceRoot":"","sources":["../../../../../src/modules/ember-chat/usecases/clearEmberMemory/clearEmberMemory.usecase.ts"],"names":[],"mappings":"AAOA,MAAM,CAAC,KAAK,UAAU,gBAAgB,CACpC,YAA0C;IAE1C,MAAM,YAAY,CAAC,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;AAC5D,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { EgressScanConfig } from '../../../../modules/platform-integration/entities/egressScan/egressScan.scanner.js';
2
+ export declare const defaultEgressScanConfig: EgressScanConfig;
3
+ //# sourceMappingURL=egressScan.defaults.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"egressScan.defaults.d.ts","sourceRoot":"","sources":["../../../../../src/modules/platform-integration/entities/egressScan/egressScan.defaults.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,0EAA0E,CAAC;AAEjH,eAAO,MAAM,uBAAuB,EAAE,gBAOrC,CAAC"}
@@ -0,0 +1,9 @@
1
+ export const defaultEgressScanConfig = {
2
+ secretShapeMode: 'redact',
3
+ lengthMode: 'redact',
4
+ outOfScopeMode: 'allow',
5
+ maxBodyLength: 65536,
6
+ redactionMarker: '[redacted]',
7
+ truncationMarker: '\n\n…[truncated]',
8
+ };
9
+ //# sourceMappingURL=egressScan.defaults.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"egressScan.defaults.js","sourceRoot":"","sources":["../../../../../src/modules/platform-integration/entities/egressScan/egressScan.defaults.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,uBAAuB,GAAqB;IACvD,eAAe,EAAE,QAAQ;IACzB,UAAU,EAAE,QAAQ;IACpB,cAAc,EAAE,OAAO;IACvB,aAAa,EAAE,KAAK;IACpB,eAAe,EAAE,YAAY;IAC7B,gBAAgB,EAAE,kBAAkB;CACrC,CAAC"}
@@ -0,0 +1,28 @@
1
+ export type EgressScanMode = 'allow' | 'redact' | 'block';
2
+ export type EgressChannel = 'postComment' | 'THREAD_REPLY' | 'POST_COMMENT';
3
+ export type EgressMatchCategory = 'secret-shape' | 'length-cap' | 'out-of-scope';
4
+ export interface EgressScanInput {
5
+ body: string;
6
+ channel: EgressChannel;
7
+ projectPath: string;
8
+ }
9
+ export interface EgressScanTrace {
10
+ channel: EgressChannel;
11
+ mode: EgressScanMode;
12
+ matchCategoryCounts: Record<EgressMatchCategory, number>;
13
+ }
14
+ export type EgressScanResult = {
15
+ decision: 'pass';
16
+ body: string;
17
+ } | {
18
+ decision: 'redact';
19
+ body: string;
20
+ trace: EgressScanTrace;
21
+ } | {
22
+ decision: 'block';
23
+ trace: EgressScanTrace;
24
+ };
25
+ export interface EgressScanGateway {
26
+ scan(input: EgressScanInput): EgressScanResult;
27
+ }
28
+ //# sourceMappingURL=egressScan.gateway.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"egressScan.gateway.d.ts","sourceRoot":"","sources":["../../../../../src/modules/platform-integration/entities/egressScan/egressScan.gateway.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,cAAc,GAAG,OAAO,GAAG,QAAQ,GAAG,OAAO,CAAC;AAE1D,MAAM,MAAM,aAAa,GAAG,aAAa,GAAG,cAAc,GAAG,cAAc,CAAC;AAE5E,MAAM,MAAM,mBAAmB,GAAG,cAAc,GAAG,YAAY,GAAG,cAAc,CAAC;AAEjF,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,aAAa,CAAC;IACvB,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,eAAe;IAC9B,OAAO,EAAE,aAAa,CAAC;IACvB,IAAI,EAAE,cAAc,CAAC;IACrB,mBAAmB,EAAE,MAAM,CAAC,mBAAmB,EAAE,MAAM,CAAC,CAAC;CAC1D;AAED,MAAM,MAAM,gBAAgB,GACxB;IAAE,QAAQ,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,GAClC;IAAE,QAAQ,EAAE,QAAQ,CAAC;IAAC,IAAI,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,eAAe,CAAA;CAAE,GAC5D;IAAE,QAAQ,EAAE,OAAO,CAAC;IAAC,KAAK,EAAE,eAAe,CAAA;CAAE,CAAC;AAElD,MAAM,WAAW,iBAAiB;IAChC,IAAI,CAAC,KAAK,EAAE,eAAe,GAAG,gBAAgB,CAAC;CAChD"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=egressScan.gateway.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"egressScan.gateway.js","sourceRoot":"","sources":["../../../../../src/modules/platform-integration/entities/egressScan/egressScan.gateway.ts"],"names":[],"mappings":""}
@@ -0,0 +1,11 @@
1
+ import type { EgressScanGateway, EgressScanMode } from '../../../../modules/platform-integration/entities/egressScan/egressScan.gateway.js';
2
+ export interface EgressScanConfig {
3
+ secretShapeMode: EgressScanMode;
4
+ lengthMode: EgressScanMode;
5
+ outOfScopeMode: EgressScanMode;
6
+ maxBodyLength: number;
7
+ redactionMarker: string;
8
+ truncationMarker: string;
9
+ }
10
+ export declare function createEgressScanner(config: EgressScanConfig): EgressScanGateway;
11
+ //# sourceMappingURL=egressScan.scanner.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"egressScan.scanner.d.ts","sourceRoot":"","sources":["../../../../../src/modules/platform-integration/entities/egressScan/egressScan.scanner.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,iBAAiB,EAEjB,cAAc,EAGf,MAAM,0EAA0E,CAAC;AAElF,MAAM,WAAW,gBAAgB;IAC/B,eAAe,EAAE,cAAc,CAAC;IAChC,UAAU,EAAE,cAAc,CAAC;IAC3B,cAAc,EAAE,cAAc,CAAC;IAC/B,aAAa,EAAE,MAAM,CAAC;IACtB,eAAe,EAAE,MAAM,CAAC;IACxB,gBAAgB,EAAE,MAAM,CAAC;CAC1B;AAeD,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,gBAAgB,GAAG,iBAAiB,CAkE/E"}
@@ -0,0 +1,70 @@
1
+ const SECRET_SHAPE_PATTERN = /\b(?:glpat-[A-Za-z0-9_-]{20,}|gh[pousr]_[A-Za-z0-9]{20,}|sk-[A-Za-z0-9]{20,}|AKIA[0-9A-Z]{16}|eyJ[A-Za-z0-9_-]{10,}\.[A-Za-z0-9_-]{10,}\.[A-Za-z0-9_-]{10,})\b/g;
2
+ const PROJECT_REFERENCE_PATTERN = /\b[A-Za-z0-9][A-Za-z0-9._-]*\/[A-Za-z0-9][A-Za-z0-9._/-]*\b/g;
3
+ function emptyCounts() {
4
+ return { 'secret-shape': 0, 'length-cap': 0, 'out-of-scope': 0 };
5
+ }
6
+ function isOutOfScope(reference, projectPath) {
7
+ return reference !== projectPath && !reference.startsWith(`${projectPath}/`);
8
+ }
9
+ export function createEgressScanner(config) {
10
+ return {
11
+ scan(input) {
12
+ const counts = emptyCounts();
13
+ let body = input.body;
14
+ let blocked = false;
15
+ let mutated = false;
16
+ const secretMatches = body.match(SECRET_SHAPE_PATTERN) ?? [];
17
+ if (secretMatches.length > 0) {
18
+ counts['secret-shape'] = secretMatches.length;
19
+ if (config.secretShapeMode === 'block') {
20
+ blocked = true;
21
+ }
22
+ else if (config.secretShapeMode === 'redact') {
23
+ body = body.replace(SECRET_SHAPE_PATTERN, config.redactionMarker);
24
+ mutated = true;
25
+ }
26
+ }
27
+ const outOfScopeMatches = (body.match(PROJECT_REFERENCE_PATTERN) ?? []).filter((reference) => isOutOfScope(reference, input.projectPath));
28
+ if (outOfScopeMatches.length > 0) {
29
+ counts['out-of-scope'] = outOfScopeMatches.length;
30
+ if (config.outOfScopeMode === 'block') {
31
+ blocked = true;
32
+ }
33
+ else if (config.outOfScopeMode === 'redact') {
34
+ for (const reference of outOfScopeMatches) {
35
+ body = body.split(reference).join(config.redactionMarker);
36
+ }
37
+ mutated = true;
38
+ }
39
+ }
40
+ if (body.length > config.maxBodyLength) {
41
+ counts['length-cap'] = 1;
42
+ if (config.lengthMode === 'block') {
43
+ blocked = true;
44
+ }
45
+ else if (config.lengthMode === 'redact') {
46
+ const room = config.maxBodyLength - config.truncationMarker.length;
47
+ const head = room > 0 ? body.slice(0, room) : '';
48
+ body = `${head}${config.truncationMarker}`;
49
+ mutated = true;
50
+ }
51
+ }
52
+ const mode = blocked ? 'block' : mutated ? 'redact' : 'allow';
53
+ if (blocked) {
54
+ return {
55
+ decision: 'block',
56
+ trace: { channel: input.channel, mode, matchCategoryCounts: counts },
57
+ };
58
+ }
59
+ if (mutated) {
60
+ return {
61
+ decision: 'redact',
62
+ body,
63
+ trace: { channel: input.channel, mode, matchCategoryCounts: counts },
64
+ };
65
+ }
66
+ return { decision: 'pass', body };
67
+ },
68
+ };
69
+ }
70
+ //# sourceMappingURL=egressScan.scanner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"egressScan.scanner.js","sourceRoot":"","sources":["../../../../../src/modules/platform-integration/entities/egressScan/egressScan.scanner.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ import type { EgressScanTrace } from '../../../../modules/platform-integration/entities/egressScan/egressScan.gateway.js';
2
+ export interface EgressTraceGateway {
3
+ record(trace: EgressScanTrace): void;
4
+ }
5
+ //# sourceMappingURL=egressTrace.gateway.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"egressTrace.gateway.d.ts","sourceRoot":"","sources":["../../../../../src/modules/platform-integration/entities/egressScan/egressTrace.gateway.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,0EAA0E,CAAC;AAEhH,MAAM,WAAW,kBAAkB;IACjC,MAAM,CAAC,KAAK,EAAE,eAAe,GAAG,IAAI,CAAC;CACtC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=egressTrace.gateway.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"egressTrace.gateway.js","sourceRoot":"","sources":["../../../../../src/modules/platform-integration/entities/egressScan/egressTrace.gateway.ts"],"names":[],"mappings":""}
@@ -0,0 +1,9 @@
1
+ export type ExecutorCapability = 'readMr' | 'postComment' | 'threadResolve' | 'revoke';
2
+ export type GitLabRole = 'reporter' | 'developer';
3
+ export interface CapabilityDeclaration {
4
+ readonly minRole: GitLabRole;
5
+ readonly autoPath: boolean;
6
+ }
7
+ export declare const EXECUTOR_CAPABILITY_TABLE: Readonly<Record<ExecutorCapability, CapabilityDeclaration>>;
8
+ export declare const AUTO_EXECUTOR_CAPABILITIES: ReadonlySet<ExecutorCapability>;
9
+ //# sourceMappingURL=executorCapability.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"executorCapability.d.ts","sourceRoot":"","sources":["../../../../../src/modules/platform-integration/entities/executorToken/executorCapability.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,kBAAkB,GAAG,QAAQ,GAAG,aAAa,GAAG,eAAe,GAAG,QAAQ,CAAA;AAEtF,MAAM,MAAM,UAAU,GAAG,UAAU,GAAG,WAAW,CAAA;AAEjD,MAAM,WAAW,qBAAqB;IACpC,QAAQ,CAAC,OAAO,EAAE,UAAU,CAAA;IAC5B,QAAQ,CAAC,QAAQ,EAAE,OAAO,CAAA;CAC3B;AAED,eAAO,MAAM,yBAAyB,EAAE,QAAQ,CAC9C,MAAM,CAAC,kBAAkB,EAAE,qBAAqB,CAAC,CAMlD,CAAA;AAED,eAAO,MAAM,0BAA0B,EAAE,WAAW,CAAC,kBAAkB,CAItE,CAAA"}
@@ -0,0 +1,10 @@
1
+ export const EXECUTOR_CAPABILITY_TABLE = {
2
+ readMr: { minRole: 'reporter', autoPath: true },
3
+ postComment: { minRole: 'reporter', autoPath: true },
4
+ threadResolve: { minRole: 'developer', autoPath: false },
5
+ revoke: { minRole: 'developer', autoPath: false },
6
+ };
7
+ export const AUTO_EXECUTOR_CAPABILITIES = new Set(Object.entries(EXECUTOR_CAPABILITY_TABLE)
8
+ .filter(([, declaration]) => declaration.autoPath)
9
+ .map(([capability]) => capability));
10
+ //# sourceMappingURL=executorCapability.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"executorCapability.js","sourceRoot":"","sources":["../../../../../src/modules/platform-integration/entities/executorToken/executorCapability.ts"],"names":[],"mappings":"AASA,MAAM,CAAC,MAAM,yBAAyB,GAElC;IACF,MAAM,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,IAAI,EAAE;IAC/C,WAAW,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,IAAI,EAAE;IACpD,aAAa,EAAE,EAAE,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,KAAK,EAAE;IACxD,MAAM,EAAE,EAAE,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,KAAK,EAAE;CAClD,CAAA;AAED,MAAM,CAAC,MAAM,0BAA0B,GAAoC,IAAI,GAAG,CAC/E,MAAM,CAAC,OAAO,CAAC,yBAAyB,CAAmD;KACzF,MAAM,CAAC,CAAC,CAAC,EAAE,WAAW,CAAC,EAAE,EAAE,CAAC,WAAW,CAAC,QAAQ,CAAC;KACjD,GAAG,CAAC,CAAC,CAAC,UAAU,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,CACrC,CAAA"}
@@ -0,0 +1,4 @@
1
+ export interface IdempotencyStore {
2
+ recordIfAbsent(eventKey: string): Promise<boolean>;
3
+ }
4
+ //# sourceMappingURL=idempotencyStore.gateway.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"idempotencyStore.gateway.d.ts","sourceRoot":"","sources":["../../../../../src/modules/platform-integration/entities/idempotency/idempotencyStore.gateway.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,gBAAgB;IAC/B,cAAc,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;CACpD"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=idempotencyStore.gateway.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"idempotencyStore.gateway.js","sourceRoot":"","sources":["../../../../../src/modules/platform-integration/entities/idempotency/idempotencyStore.gateway.ts"],"names":[],"mappings":""}
@@ -0,0 +1,27 @@
1
+ /**
2
+ * GitLab project membership access levels, mirroring the numeric scale returned by
3
+ * the GitLab Members API. Only the ordering matters for trust decisions: Developer
4
+ * and above is trusted, everything below is not.
5
+ *
6
+ * See SPEC-197: trust = access level >= Developer.
7
+ */
8
+ export declare const MEMBER_ACCESS_LEVELS: {
9
+ readonly noAccess: 0;
10
+ readonly minimalAccess: 5;
11
+ readonly guest: 10;
12
+ readonly reporter: 20;
13
+ readonly developer: 30;
14
+ readonly maintainer: 40;
15
+ readonly owner: 50;
16
+ };
17
+ export type MemberAccessLevel = (typeof MEMBER_ACCESS_LEVELS)[keyof typeof MEMBER_ACCESS_LEVELS];
18
+ export declare const DEVELOPER_ACCESS_LEVEL: MemberAccessLevel;
19
+ /**
20
+ * A resolved access level (the actor is a member at some level) or `null` when the
21
+ * actor could not be resolved as a trusted member. Per SPEC-197 the gateway is
22
+ * fail-closed: lookup error / timeout / ambiguous / unknown username all collapse
23
+ * to `null` (non-trusted).
24
+ */
25
+ export type ResolvedAccessLevel = MemberAccessLevel | null;
26
+ export declare function isDeveloperOrAbove(accessLevel: ResolvedAccessLevel): boolean;
27
+ //# sourceMappingURL=memberAccess.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"memberAccess.d.ts","sourceRoot":"","sources":["../../../../../src/modules/platform-integration/entities/memberAccess/memberAccess.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AACH,eAAO,MAAM,oBAAoB;;;;;;;;CAQvB,CAAC;AAEX,MAAM,MAAM,iBAAiB,GAAG,CAAC,OAAO,oBAAoB,CAAC,CAAC,MAAM,OAAO,oBAAoB,CAAC,CAAC;AAEjG,eAAO,MAAM,sBAAsB,EAAE,iBAAkD,CAAC;AAExF;;;;;GAKG;AACH,MAAM,MAAM,mBAAmB,GAAG,iBAAiB,GAAG,IAAI,CAAC;AAE3D,wBAAgB,kBAAkB,CAAC,WAAW,EAAE,mBAAmB,GAAG,OAAO,CAE5E"}
@@ -0,0 +1,13 @@
1
+ import type { ResolvedAccessLevel } from '../../../../modules/platform-integration/entities/memberAccess/memberAccess.js';
2
+ /**
3
+ * Resolves a GitLab actor's access level on a target project, keyed by username.
4
+ *
5
+ * Implementations MUST be fail-closed (SPEC-197 AC4): any lookup error, timeout,
6
+ * ambiguous result, or unknown username resolves to `null` (non-trusted). The
7
+ * resolution keys on `username` (the only identity exposed by the parsed webhook
8
+ * guards) and never widens trust across usernames (AC5).
9
+ */
10
+ export interface MemberAccessGateway {
11
+ resolve(projectPath: string, username: string): Promise<ResolvedAccessLevel>;
12
+ }
13
+ //# sourceMappingURL=memberAccess.gateway.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"memberAccess.gateway.d.ts","sourceRoot":"","sources":["../../../../../src/modules/platform-integration/entities/memberAccess/memberAccess.gateway.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,sEAAsE,CAAC;AAEhH;;;;;;;GAOG;AACH,MAAM,WAAW,mBAAmB;IAClC,OAAO,CAAC,WAAW,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,mBAAmB,CAAC,CAAC;CAC9E"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=memberAccess.gateway.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"memberAccess.gateway.js","sourceRoot":"","sources":["../../../../../src/modules/platform-integration/entities/memberAccess/memberAccess.gateway.ts"],"names":[],"mappings":""}
@@ -0,0 +1,21 @@
1
+ /**
2
+ * GitLab project membership access levels, mirroring the numeric scale returned by
3
+ * the GitLab Members API. Only the ordering matters for trust decisions: Developer
4
+ * and above is trusted, everything below is not.
5
+ *
6
+ * See SPEC-197: trust = access level >= Developer.
7
+ */
8
+ export const MEMBER_ACCESS_LEVELS = {
9
+ noAccess: 0,
10
+ minimalAccess: 5,
11
+ guest: 10,
12
+ reporter: 20,
13
+ developer: 30,
14
+ maintainer: 40,
15
+ owner: 50,
16
+ };
17
+ export const DEVELOPER_ACCESS_LEVEL = MEMBER_ACCESS_LEVELS.developer;
18
+ export function isDeveloperOrAbove(accessLevel) {
19
+ return accessLevel !== null && accessLevel >= DEVELOPER_ACCESS_LEVEL;
20
+ }
21
+ //# sourceMappingURL=memberAccess.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"memberAccess.js","sourceRoot":"","sources":["../../../../../src/modules/platform-integration/entities/memberAccess/memberAccess.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AACH,MAAM,CAAC,MAAM,oBAAoB,GAAG;IAClC,QAAQ,EAAE,CAAC;IACX,aAAa,EAAE,CAAC;IAChB,KAAK,EAAE,EAAE;IACT,QAAQ,EAAE,EAAE;IACZ,SAAS,EAAE,EAAE;IACb,UAAU,EAAE,EAAE;IACd,KAAK,EAAE,EAAE;CACD,CAAC;AAIX,MAAM,CAAC,MAAM,sBAAsB,GAAsB,oBAAoB,CAAC,SAAS,CAAC;AAUxF,MAAM,UAAU,kBAAkB,CAAC,WAAgC;IACjE,OAAO,WAAW,KAAK,IAAI,IAAI,WAAW,IAAI,sBAAsB,CAAC;AACvE,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function isIpInCidr(ip: string, cidr: string): boolean;
2
+ //# sourceMappingURL=cidr.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cidr.d.ts","sourceRoot":"","sources":["../../../../../src/modules/platform-integration/entities/transport/cidr.ts"],"names":[],"mappings":"AAoBA,wBAAgB,UAAU,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAmB5D"}
@@ -0,0 +1,36 @@
1
+ function ipv4ToInteger(ip) {
2
+ const octets = ip.split('.');
3
+ if (octets.length !== 4) {
4
+ return null;
5
+ }
6
+ let value = 0;
7
+ for (const octet of octets) {
8
+ if (!/^\d{1,3}$/.test(octet)) {
9
+ return null;
10
+ }
11
+ const part = Number(octet);
12
+ if (part > 255) {
13
+ return null;
14
+ }
15
+ value = value * 256 + part;
16
+ }
17
+ return value >>> 0;
18
+ }
19
+ export function isIpInCidr(ip, cidr) {
20
+ const [rangeIp, prefixText] = cidr.split('/');
21
+ const prefix = Number(prefixText);
22
+ if (!Number.isInteger(prefix) || prefix < 0 || prefix > 32) {
23
+ return false;
24
+ }
25
+ const ipValue = ipv4ToInteger(ip);
26
+ const rangeValue = ipv4ToInteger(rangeIp);
27
+ if (ipValue === null || rangeValue === null) {
28
+ return false;
29
+ }
30
+ if (prefix === 0) {
31
+ return true;
32
+ }
33
+ const mask = (0xffffffff << (32 - prefix)) >>> 0;
34
+ return (ipValue & mask) === (rangeValue & mask);
35
+ }
36
+ //# sourceMappingURL=cidr.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cidr.js","sourceRoot":"","sources":["../../../../../src/modules/platform-integration/entities/transport/cidr.ts"],"names":[],"mappings":"AAAA,SAAS,aAAa,CAAC,EAAU;IAC/B,MAAM,MAAM,GAAG,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAC7B,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACxB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAI,KAAK,GAAG,CAAC,CAAC;IACd,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;QAC3B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;YAC7B,OAAO,IAAI,CAAC;QACd,CAAC;QACD,MAAM,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAC3B,IAAI,IAAI,GAAG,GAAG,EAAE,CAAC;YACf,OAAO,IAAI,CAAC;QACd,CAAC;QACD,KAAK,GAAG,KAAK,GAAG,GAAG,GAAG,IAAI,CAAC;IAC7B,CAAC;IACD,OAAO,KAAK,KAAK,CAAC,CAAC;AACrB,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,EAAU,EAAE,IAAY;IACjD,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAC9C,MAAM,MAAM,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;IAClC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,MAAM,GAAG,CAAC,IAAI,MAAM,GAAG,EAAE,EAAE,CAAC;QAC3D,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,OAAO,GAAG,aAAa,CAAC,EAAE,CAAC,CAAC;IAClC,MAAM,UAAU,GAAG,aAAa,CAAC,OAAO,CAAC,CAAC;IAC1C,IAAI,OAAO,KAAK,IAAI,IAAI,UAAU,KAAK,IAAI,EAAE,CAAC;QAC5C,OAAO,KAAK,CAAC;IACf,CAAC;IAED,IAAI,MAAM,KAAK,CAAC,EAAE,CAAC;QACjB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,IAAI,GAAG,CAAC,UAAU,IAAI,CAAC,EAAE,GAAG,MAAM,CAAC,CAAC,KAAK,CAAC,CAAC;IACjD,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,IAAI,CAAC,CAAC;AAClD,CAAC"}
@@ -0,0 +1,8 @@
1
+ export interface ClientIpResolutionInput {
2
+ socketTrusted: boolean;
3
+ forwardedFor: string | null;
4
+ }
5
+ export interface ClientIpResolver {
6
+ resolve(input: ClientIpResolutionInput): string | null;
7
+ }
8
+ //# sourceMappingURL=clientIpResolver.gateway.d.ts.map