reviewflow 3.32.0 → 3.34.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 (392) hide show
  1. package/CHANGELOG.md +20 -0
  2. package/dist/main/routes.d.ts.map +1 -1
  3. package/dist/main/routes.js +56 -5
  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/claude-invocation/entities/claudeSession/claudeSession.guard.d.ts +1 -1
  9. package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.schema.d.ts +2 -0
  10. package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.schema.d.ts.map +1 -1
  11. package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.schema.js +1 -1
  12. package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.schema.js.map +1 -1
  13. package/dist/modules/{ember-chat/interface-adapters/gateways/emberStreamJson.parser.d.ts → claude-invocation/interface-adapters/gateways/transcriptStreamJson.parser.d.ts} +1 -1
  14. package/dist/modules/claude-invocation/interface-adapters/gateways/transcriptStreamJson.parser.d.ts.map +1 -0
  15. package/dist/modules/{ember-chat/interface-adapters/gateways/emberStreamJson.parser.js → claude-invocation/interface-adapters/gateways/transcriptStreamJson.parser.js} +1 -1
  16. package/dist/modules/claude-invocation/interface-adapters/gateways/transcriptStreamJson.parser.js.map +1 -0
  17. package/dist/modules/ember-chat/interface-adapters/gateways/emberAnswerTransport.claude.gateway.js +1 -1
  18. package/dist/modules/ember-chat/interface-adapters/gateways/emberAnswerTransport.claude.gateway.js.map +1 -1
  19. package/dist/modules/platform-integration/entities/egressScan/egressScan.defaults.d.ts +3 -0
  20. package/dist/modules/platform-integration/entities/egressScan/egressScan.defaults.d.ts.map +1 -0
  21. package/dist/modules/platform-integration/entities/egressScan/egressScan.defaults.js +9 -0
  22. package/dist/modules/platform-integration/entities/egressScan/egressScan.defaults.js.map +1 -0
  23. package/dist/modules/platform-integration/entities/egressScan/egressScan.gateway.d.ts +28 -0
  24. package/dist/modules/platform-integration/entities/egressScan/egressScan.gateway.d.ts.map +1 -0
  25. package/dist/modules/platform-integration/entities/egressScan/egressScan.gateway.js +2 -0
  26. package/dist/modules/platform-integration/entities/egressScan/egressScan.gateway.js.map +1 -0
  27. package/dist/modules/platform-integration/entities/egressScan/egressScan.scanner.d.ts +11 -0
  28. package/dist/modules/platform-integration/entities/egressScan/egressScan.scanner.d.ts.map +1 -0
  29. package/dist/modules/platform-integration/entities/egressScan/egressScan.scanner.js +70 -0
  30. package/dist/modules/platform-integration/entities/egressScan/egressScan.scanner.js.map +1 -0
  31. package/dist/modules/platform-integration/entities/egressScan/egressTrace.gateway.d.ts +5 -0
  32. package/dist/modules/platform-integration/entities/egressScan/egressTrace.gateway.d.ts.map +1 -0
  33. package/dist/modules/platform-integration/entities/egressScan/egressTrace.gateway.js +2 -0
  34. package/dist/modules/platform-integration/entities/egressScan/egressTrace.gateway.js.map +1 -0
  35. package/dist/modules/platform-integration/entities/executorToken/executorCapability.d.ts +9 -0
  36. package/dist/modules/platform-integration/entities/executorToken/executorCapability.d.ts.map +1 -0
  37. package/dist/modules/platform-integration/entities/executorToken/executorCapability.js +10 -0
  38. package/dist/modules/platform-integration/entities/executorToken/executorCapability.js.map +1 -0
  39. package/dist/modules/platform-integration/entities/idempotency/idempotencyStore.gateway.d.ts +4 -0
  40. package/dist/modules/platform-integration/entities/idempotency/idempotencyStore.gateway.d.ts.map +1 -0
  41. package/dist/modules/platform-integration/entities/idempotency/idempotencyStore.gateway.js +2 -0
  42. package/dist/modules/platform-integration/entities/idempotency/idempotencyStore.gateway.js.map +1 -0
  43. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.d.ts +27 -0
  44. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.d.ts.map +1 -0
  45. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.gateway.d.ts +13 -0
  46. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.gateway.d.ts.map +1 -0
  47. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.gateway.js +2 -0
  48. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.gateway.js.map +1 -0
  49. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.js +21 -0
  50. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.js.map +1 -0
  51. package/dist/modules/platform-integration/entities/transport/cidr.d.ts +2 -0
  52. package/dist/modules/platform-integration/entities/transport/cidr.d.ts.map +1 -0
  53. package/dist/modules/platform-integration/entities/transport/cidr.js +36 -0
  54. package/dist/modules/platform-integration/entities/transport/cidr.js.map +1 -0
  55. package/dist/modules/platform-integration/entities/transport/clientIpResolver.gateway.d.ts +8 -0
  56. package/dist/modules/platform-integration/entities/transport/clientIpResolver.gateway.d.ts.map +1 -0
  57. package/dist/modules/platform-integration/entities/transport/clientIpResolver.gateway.js +2 -0
  58. package/dist/modules/platform-integration/entities/transport/clientIpResolver.gateway.js.map +1 -0
  59. package/dist/modules/platform-integration/entities/transport/transportContext.d.ts +16 -0
  60. package/dist/modules/platform-integration/entities/transport/transportContext.d.ts.map +1 -0
  61. package/dist/modules/platform-integration/entities/transport/transportContext.js +2 -0
  62. package/dist/modules/platform-integration/entities/transport/transportContext.js.map +1 -0
  63. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/github.controller.d.ts.map +1 -1
  64. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/github.controller.js +4 -4
  65. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/github.controller.js.map +1 -1
  66. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/gitlab.controller.d.ts +5 -1
  67. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/gitlab.controller.d.ts.map +1 -1
  68. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/gitlab.controller.js +112 -18
  69. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/gitlab.controller.js.map +1 -1
  70. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/transportGuard.middleware.d.ts +25 -0
  71. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/transportGuard.middleware.d.ts.map +1 -0
  72. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/transportGuard.middleware.js +26 -0
  73. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/transportGuard.middleware.js.map +1 -0
  74. package/dist/modules/platform-integration/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.d.ts +14 -0
  75. package/dist/modules/platform-integration/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.d.ts.map +1 -0
  76. package/dist/modules/platform-integration/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.js +34 -0
  77. package/dist/modules/platform-integration/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.js.map +1 -0
  78. package/dist/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.gateway.d.ts +14 -0
  79. package/dist/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.gateway.d.ts.map +1 -0
  80. package/dist/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.gateway.js +27 -0
  81. package/dist/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.gateway.js.map +1 -0
  82. package/dist/modules/platform-integration/interface-adapters/gateways/loggerEgressTrace.gateway.d.ts +9 -0
  83. package/dist/modules/platform-integration/interface-adapters/gateways/loggerEgressTrace.gateway.d.ts.map +1 -0
  84. package/dist/modules/platform-integration/interface-adapters/gateways/loggerEgressTrace.gateway.js +14 -0
  85. package/dist/modules/platform-integration/interface-adapters/gateways/loggerEgressTrace.gateway.js.map +1 -0
  86. package/dist/modules/platform-integration/interface-adapters/gateways/memberAccess.gitlab.cli.gateway.d.ts +31 -0
  87. package/dist/modules/platform-integration/interface-adapters/gateways/memberAccess.gitlab.cli.gateway.d.ts.map +1 -0
  88. package/dist/modules/platform-integration/interface-adapters/gateways/memberAccess.gitlab.cli.gateway.js +83 -0
  89. package/dist/modules/platform-integration/interface-adapters/gateways/memberAccess.gitlab.cli.gateway.js.map +1 -0
  90. package/dist/modules/platform-integration/interface-adapters/gateways/scopedGitLabExecutor.d.ts +17 -0
  91. package/dist/modules/platform-integration/interface-adapters/gateways/scopedGitLabExecutor.d.ts.map +1 -0
  92. package/dist/modules/platform-integration/interface-adapters/gateways/scopedGitLabExecutor.js +17 -0
  93. package/dist/modules/platform-integration/interface-adapters/gateways/scopedGitLabExecutor.js.map +1 -0
  94. package/dist/modules/platform-integration/interface-adapters/gateways/threadFetch.gitlab.gateway.d.ts +6 -0
  95. package/dist/modules/platform-integration/interface-adapters/gateways/threadFetch.gitlab.gateway.d.ts.map +1 -1
  96. package/dist/modules/platform-integration/interface-adapters/gateways/threadFetch.gitlab.gateway.js +28 -1
  97. package/dist/modules/platform-integration/interface-adapters/gateways/threadFetch.gitlab.gateway.js.map +1 -1
  98. package/dist/modules/platform-integration/interface-adapters/gateways/transport/clientIpResolver.forwardedFor.gateway.d.ts +5 -0
  99. package/dist/modules/platform-integration/interface-adapters/gateways/transport/clientIpResolver.forwardedFor.gateway.d.ts.map +1 -0
  100. package/dist/modules/platform-integration/interface-adapters/gateways/transport/clientIpResolver.forwardedFor.gateway.js +16 -0
  101. package/dist/modules/platform-integration/interface-adapters/gateways/transport/clientIpResolver.forwardedFor.gateway.js.map +1 -0
  102. package/dist/modules/platform-integration/services/autoExecutorActionFilter.d.ts +9 -0
  103. package/dist/modules/platform-integration/services/autoExecutorActionFilter.d.ts.map +1 -0
  104. package/dist/modules/platform-integration/services/autoExecutorActionFilter.js +33 -0
  105. package/dist/modules/platform-integration/services/autoExecutorActionFilter.js.map +1 -0
  106. package/dist/modules/platform-integration/services/pinnedThreadFetchTarget.d.ts +23 -0
  107. package/dist/modules/platform-integration/services/pinnedThreadFetchTarget.d.ts.map +1 -0
  108. package/dist/modules/platform-integration/services/pinnedThreadFetchTarget.js +21 -0
  109. package/dist/modules/platform-integration/services/pinnedThreadFetchTarget.js.map +1 -0
  110. package/dist/modules/platform-integration/services/scopedExecutorEnvironment.d.ts +21 -0
  111. package/dist/modules/platform-integration/services/scopedExecutorEnvironment.d.ts.map +1 -0
  112. package/dist/modules/platform-integration/services/scopedExecutorEnvironment.js +39 -0
  113. package/dist/modules/platform-integration/services/scopedExecutorEnvironment.js.map +1 -0
  114. package/dist/modules/platform-integration/usecases/isTrustedActor.usecase.d.ts +17 -0
  115. package/dist/modules/platform-integration/usecases/isTrustedActor.usecase.d.ts.map +1 -0
  116. package/dist/modules/platform-integration/usecases/isTrustedActor.usecase.js +23 -0
  117. package/dist/modules/platform-integration/usecases/isTrustedActor.usecase.js.map +1 -0
  118. package/dist/modules/platform-integration/usecases/transport/evaluateTransport.usecase.d.ts +3 -0
  119. package/dist/modules/platform-integration/usecases/transport/evaluateTransport.usecase.d.ts.map +1 -0
  120. package/dist/modules/platform-integration/usecases/transport/evaluateTransport.usecase.js +18 -0
  121. package/dist/modules/platform-integration/usecases/transport/evaluateTransport.usecase.js.map +1 -0
  122. package/dist/modules/review-execution/entities/actionProvenance/actionProvenance.d.ts +9 -0
  123. package/dist/modules/review-execution/entities/actionProvenance/actionProvenance.d.ts.map +1 -0
  124. package/dist/modules/review-execution/entities/actionProvenance/actionProvenance.js +11 -0
  125. package/dist/modules/review-execution/entities/actionProvenance/actionProvenance.js.map +1 -0
  126. package/dist/modules/review-execution/entities/threadInventory/threadInventory.gateway.d.ts +13 -0
  127. package/dist/modules/review-execution/entities/threadInventory/threadInventory.gateway.d.ts.map +1 -0
  128. package/dist/modules/review-execution/entities/threadInventory/threadInventory.gateway.js +2 -0
  129. package/dist/modules/review-execution/entities/threadInventory/threadInventory.gateway.js.map +1 -0
  130. package/dist/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.d.ts +14 -0
  131. package/dist/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.d.ts.map +1 -0
  132. package/dist/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.js +31 -0
  133. package/dist/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.js.map +1 -0
  134. package/dist/modules/review-execution/services/constrainActionSurface.d.ts +19 -0
  135. package/dist/modules/review-execution/services/constrainActionSurface.d.ts.map +1 -0
  136. package/dist/modules/review-execution/services/constrainActionSurface.js +49 -0
  137. package/dist/modules/review-execution/services/constrainActionSurface.js.map +1 -0
  138. package/dist/modules/review-execution/services/contextActionsExecutor.d.ts +2 -1
  139. package/dist/modules/review-execution/services/contextActionsExecutor.d.ts.map +1 -1
  140. package/dist/modules/review-execution/services/contextActionsExecutor.js +20 -2
  141. package/dist/modules/review-execution/services/contextActionsExecutor.js.map +1 -1
  142. package/dist/modules/review-execution/services/dispatchConstrainedActions.d.ts +30 -0
  143. package/dist/modules/review-execution/services/dispatchConstrainedActions.d.ts.map +1 -0
  144. package/dist/modules/review-execution/services/dispatchConstrainedActions.js +20 -0
  145. package/dist/modules/review-execution/services/dispatchConstrainedActions.js.map +1 -0
  146. package/dist/modules/review-execution/services/publicOutputExecutor.d.ts +10 -0
  147. package/dist/modules/review-execution/services/publicOutputExecutor.d.ts.map +1 -0
  148. package/dist/modules/review-execution/services/publicOutputExecutor.js +27 -0
  149. package/dist/modules/review-execution/services/publicOutputExecutor.js.map +1 -0
  150. package/dist/modules/review-execution/services/resolveThreadInventory.d.ts +19 -0
  151. package/dist/modules/review-execution/services/resolveThreadInventory.d.ts.map +1 -0
  152. package/dist/modules/review-execution/services/resolveThreadInventory.js +39 -0
  153. package/dist/modules/review-execution/services/resolveThreadInventory.js.map +1 -0
  154. package/dist/modules/review-execution/services/threadActionsExecutor.d.ts +11 -1
  155. package/dist/modules/review-execution/services/threadActionsExecutor.d.ts.map +1 -1
  156. package/dist/modules/review-execution/services/threadActionsExecutor.js +24 -2
  157. package/dist/modules/review-execution/services/threadActionsExecutor.js.map +1 -1
  158. package/dist/modules/review-execution/usecases/gateClaudeInvocation.usecase.d.ts +6 -0
  159. package/dist/modules/review-execution/usecases/gateClaudeInvocation.usecase.d.ts.map +1 -1
  160. package/dist/modules/review-execution/usecases/gateClaudeInvocation.usecase.js +2 -1
  161. package/dist/modules/review-execution/usecases/gateClaudeInvocation.usecase.js.map +1 -1
  162. package/dist/modules/statistics-insights/entities/insight/aiInsightsSession.gateway.d.ts +13 -0
  163. package/dist/modules/statistics-insights/entities/insight/aiInsightsSession.gateway.d.ts.map +1 -0
  164. package/dist/modules/statistics-insights/entities/insight/aiInsightsSession.gateway.js +2 -0
  165. package/dist/modules/statistics-insights/entities/insight/aiInsightsSession.gateway.js.map +1 -0
  166. package/dist/modules/statistics-insights/interface-adapters/controllers/http/insights.routes.d.ts +4 -2
  167. package/dist/modules/statistics-insights/interface-adapters/controllers/http/insights.routes.d.ts.map +1 -1
  168. package/dist/modules/statistics-insights/interface-adapters/controllers/http/insights.routes.js +6 -4
  169. package/dist/modules/statistics-insights/interface-adapters/controllers/http/insights.routes.js.map +1 -1
  170. package/dist/modules/statistics-insights/interface-adapters/gateways/aiInsightsSession.claude.gateway.d.ts +31 -0
  171. package/dist/modules/statistics-insights/interface-adapters/gateways/aiInsightsSession.claude.gateway.d.ts.map +1 -0
  172. package/dist/modules/statistics-insights/interface-adapters/gateways/aiInsightsSession.claude.gateway.js +105 -0
  173. package/dist/modules/statistics-insights/interface-adapters/gateways/aiInsightsSession.claude.gateway.js.map +1 -0
  174. package/dist/modules/statistics-insights/usecases/insights/{generateAiInsights.usecase.d.ts → generateAiInsightsViaSession.usecase.d.ts} +7 -13
  175. package/dist/modules/statistics-insights/usecases/insights/generateAiInsightsViaSession.usecase.d.ts.map +1 -0
  176. package/dist/modules/statistics-insights/usecases/insights/generateAiInsightsViaSession.usecase.js +49 -0
  177. package/dist/modules/statistics-insights/usecases/insights/generateAiInsightsViaSession.usecase.js.map +1 -0
  178. package/dist/modules/statistics-insights/usecases/insights/parseAiInsightsResponse.d.ts +3 -0
  179. package/dist/modules/statistics-insights/usecases/insights/parseAiInsightsResponse.d.ts.map +1 -0
  180. package/dist/modules/statistics-insights/usecases/insights/parseAiInsightsResponse.js +20 -0
  181. package/dist/modules/statistics-insights/usecases/insights/parseAiInsightsResponse.js.map +1 -0
  182. package/dist/modules/statistics-insights/usecases/insights/persistAiInsights.usecase.d.ts +12 -0
  183. package/dist/modules/statistics-insights/usecases/insights/persistAiInsights.usecase.d.ts.map +1 -0
  184. package/dist/modules/statistics-insights/usecases/insights/persistAiInsights.usecase.js +14 -0
  185. package/dist/modules/statistics-insights/usecases/insights/persistAiInsights.usecase.js.map +1 -0
  186. package/dist/security/gitlabWebhookTokenSource.d.ts +9 -0
  187. package/dist/security/gitlabWebhookTokenSource.d.ts.map +1 -0
  188. package/dist/security/gitlabWebhookTokenSource.js +15 -0
  189. package/dist/security/gitlabWebhookTokenSource.js.map +1 -0
  190. package/dist/security/transportGuardConfig.d.ts +16 -0
  191. package/dist/security/transportGuardConfig.d.ts.map +1 -0
  192. package/dist/security/transportGuardConfig.js +38 -0
  193. package/dist/security/transportGuardConfig.js.map +1 -0
  194. package/dist/security/verifier.d.ts +9 -2
  195. package/dist/security/verifier.d.ts.map +1 -1
  196. package/dist/security/verifier.js +27 -10
  197. package/dist/security/verifier.js.map +1 -1
  198. package/dist/tests/acceptance/191-team-insights-bg-migration.acceptance.test.d.ts +2 -0
  199. package/dist/tests/acceptance/191-team-insights-bg-migration.acceptance.test.d.ts.map +1 -0
  200. package/dist/tests/acceptance/191-team-insights-bg-migration.acceptance.test.js +121 -0
  201. package/dist/tests/acceptance/191-team-insights-bg-migration.acceptance.test.js.map +1 -0
  202. package/dist/tests/factories/transportContext.factory.d.ts +5 -0
  203. package/dist/tests/factories/transportContext.factory.d.ts.map +1 -0
  204. package/dist/tests/factories/transportContext.factory.js +14 -0
  205. package/dist/tests/factories/transportContext.factory.js.map +1 -0
  206. package/dist/tests/stubs/aiInsightsSession.stub.d.ts +8 -0
  207. package/dist/tests/stubs/aiInsightsSession.stub.d.ts.map +1 -0
  208. package/dist/tests/stubs/aiInsightsSession.stub.js +15 -0
  209. package/dist/tests/stubs/aiInsightsSession.stub.js.map +1 -0
  210. package/dist/tests/stubs/egressScan.stub.d.ts +16 -0
  211. package/dist/tests/stubs/egressScan.stub.d.ts.map +1 -0
  212. package/dist/tests/stubs/egressScan.stub.js +28 -0
  213. package/dist/tests/stubs/egressScan.stub.js.map +1 -0
  214. package/dist/tests/stubs/idempotencyStore.stub.d.ts +9 -0
  215. package/dist/tests/stubs/idempotencyStore.stub.d.ts.map +1 -0
  216. package/dist/tests/stubs/idempotencyStore.stub.js +19 -0
  217. package/dist/tests/stubs/idempotencyStore.stub.js.map +1 -0
  218. package/dist/tests/stubs/memberAccess.stub.d.ts +24 -0
  219. package/dist/tests/stubs/memberAccess.stub.d.ts.map +1 -0
  220. package/dist/tests/stubs/memberAccess.stub.js +28 -0
  221. package/dist/tests/stubs/memberAccess.stub.js.map +1 -0
  222. package/dist/tests/units/architecture/noClaudePInProduction.test.js +0 -1
  223. package/dist/tests/units/architecture/noClaudePInProduction.test.js.map +1 -1
  224. package/dist/tests/units/entities/egressScan/egressScan.scanner.test.d.ts +2 -0
  225. package/dist/tests/units/entities/egressScan/egressScan.scanner.test.d.ts.map +1 -0
  226. package/dist/tests/units/entities/egressScan/egressScan.scanner.test.js +136 -0
  227. package/dist/tests/units/entities/egressScan/egressScan.scanner.test.js.map +1 -0
  228. package/dist/tests/units/interface-adapters/controllers/http/insights.routes.test.js +6 -4
  229. package/dist/tests/units/interface-adapters/controllers/http/insights.routes.test.js.map +1 -1
  230. package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.js +114 -0
  231. package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.js.map +1 -1
  232. package/dist/tests/units/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.test.d.ts +2 -0
  233. package/dist/tests/units/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.test.d.ts.map +1 -0
  234. package/dist/tests/units/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.test.js +116 -0
  235. package/dist/tests/units/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.test.js.map +1 -0
  236. package/dist/tests/units/modules/claude-invocation/gateways/transcriptStreamJson.parser.test.d.ts +2 -0
  237. package/dist/tests/units/modules/claude-invocation/gateways/transcriptStreamJson.parser.test.d.ts.map +1 -0
  238. package/dist/tests/units/modules/{ember-chat/gateways/emberStreamJson.parser.test.js → claude-invocation/gateways/transcriptStreamJson.parser.test.js} +2 -2
  239. package/dist/tests/units/modules/claude-invocation/gateways/transcriptStreamJson.parser.test.js.map +1 -0
  240. package/dist/tests/units/modules/platform-integration/controllers/gitlabProcessorProvenance.test.d.ts +2 -0
  241. package/dist/tests/units/modules/platform-integration/controllers/gitlabProcessorProvenance.test.d.ts.map +1 -0
  242. package/dist/tests/units/modules/platform-integration/controllers/gitlabProcessorProvenance.test.js +69 -0
  243. package/dist/tests/units/modules/platform-integration/controllers/gitlabProcessorProvenance.test.js.map +1 -0
  244. package/dist/tests/units/modules/platform-integration/entities/executorCapability.test.d.ts +2 -0
  245. package/dist/tests/units/modules/platform-integration/entities/executorCapability.test.d.ts.map +1 -0
  246. package/dist/tests/units/modules/platform-integration/entities/executorCapability.test.js +28 -0
  247. package/dist/tests/units/modules/platform-integration/entities/executorCapability.test.js.map +1 -0
  248. package/dist/tests/units/modules/platform-integration/entities/memberAccess/memberAccess.test.d.ts +2 -0
  249. package/dist/tests/units/modules/platform-integration/entities/memberAccess/memberAccess.test.d.ts.map +1 -0
  250. package/dist/tests/units/modules/platform-integration/entities/memberAccess/memberAccess.test.js +18 -0
  251. package/dist/tests/units/modules/platform-integration/entities/memberAccess/memberAccess.test.js.map +1 -0
  252. package/dist/tests/units/modules/platform-integration/gateways/defaultGitLabExecutor.test.d.ts +2 -0
  253. package/dist/tests/units/modules/platform-integration/gateways/defaultGitLabExecutor.test.d.ts.map +1 -0
  254. package/dist/tests/units/modules/platform-integration/gateways/defaultGitLabExecutor.test.js +13 -0
  255. package/dist/tests/units/modules/platform-integration/gateways/defaultGitLabExecutor.test.js.map +1 -0
  256. package/dist/tests/units/modules/platform-integration/gateways/memberAccess.gitlab.cli.gateway.test.d.ts +2 -0
  257. package/dist/tests/units/modules/platform-integration/gateways/memberAccess.gitlab.cli.gateway.test.d.ts.map +1 -0
  258. package/dist/tests/units/modules/platform-integration/gateways/memberAccess.gitlab.cli.gateway.test.js +105 -0
  259. package/dist/tests/units/modules/platform-integration/gateways/memberAccess.gitlab.cli.gateway.test.js.map +1 -0
  260. package/dist/tests/units/modules/platform-integration/gateways/scopedGitLabExecutor.test.d.ts +2 -0
  261. package/dist/tests/units/modules/platform-integration/gateways/scopedGitLabExecutor.test.d.ts.map +1 -0
  262. package/dist/tests/units/modules/platform-integration/gateways/scopedGitLabExecutor.test.js +85 -0
  263. package/dist/tests/units/modules/platform-integration/gateways/scopedGitLabExecutor.test.js.map +1 -0
  264. package/dist/tests/units/modules/platform-integration/interface-adapters/controllers/webhook/gitlabIdempotency.controller.test.d.ts +2 -0
  265. package/dist/tests/units/modules/platform-integration/interface-adapters/controllers/webhook/gitlabIdempotency.controller.test.d.ts.map +1 -0
  266. package/dist/tests/units/modules/platform-integration/interface-adapters/controllers/webhook/gitlabIdempotency.controller.test.js +216 -0
  267. package/dist/tests/units/modules/platform-integration/interface-adapters/controllers/webhook/gitlabIdempotency.controller.test.js.map +1 -0
  268. package/dist/tests/units/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.test.d.ts +2 -0
  269. package/dist/tests/units/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.test.d.ts.map +1 -0
  270. package/dist/tests/units/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.test.js +48 -0
  271. package/dist/tests/units/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.test.js.map +1 -0
  272. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/clientIpResolver.forwardedFor.gateway.test.d.ts +2 -0
  273. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/clientIpResolver.forwardedFor.gateway.test.d.ts.map +1 -0
  274. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/clientIpResolver.forwardedFor.gateway.test.js +29 -0
  275. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/clientIpResolver.forwardedFor.gateway.test.js.map +1 -0
  276. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/transportGuard.middleware.test.d.ts +2 -0
  277. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/transportGuard.middleware.test.d.ts.map +1 -0
  278. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/transportGuard.middleware.test.js +66 -0
  279. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/transportGuard.middleware.test.js.map +1 -0
  280. package/dist/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.d.ts +2 -0
  281. package/dist/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.d.ts.map +1 -0
  282. package/dist/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.js +38 -0
  283. package/dist/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.js.map +1 -0
  284. package/dist/tests/units/modules/platform-integration/services/autoExecutorCapabilityGate.test.d.ts +2 -0
  285. package/dist/tests/units/modules/platform-integration/services/autoExecutorCapabilityGate.test.d.ts.map +1 -0
  286. package/dist/tests/units/modules/platform-integration/services/autoExecutorCapabilityGate.test.js +40 -0
  287. package/dist/tests/units/modules/platform-integration/services/autoExecutorCapabilityGate.test.js.map +1 -0
  288. package/dist/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.d.ts +2 -0
  289. package/dist/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.d.ts.map +1 -0
  290. package/dist/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.js +76 -0
  291. package/dist/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.js.map +1 -0
  292. package/dist/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.d.ts +2 -0
  293. package/dist/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.d.ts.map +1 -0
  294. package/dist/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.js +120 -0
  295. package/dist/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.js.map +1 -0
  296. package/dist/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.d.ts +2 -0
  297. package/dist/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.d.ts.map +1 -0
  298. package/dist/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.js +33 -0
  299. package/dist/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.js.map +1 -0
  300. package/dist/tests/units/modules/platform-integration/usecases/transport/evaluateTransport.usecase.test.d.ts +2 -0
  301. package/dist/tests/units/modules/platform-integration/usecases/transport/evaluateTransport.usecase.test.d.ts.map +1 -0
  302. package/dist/tests/units/modules/platform-integration/usecases/transport/evaluateTransport.usecase.test.js +69 -0
  303. package/dist/tests/units/modules/platform-integration/usecases/transport/evaluateTransport.usecase.test.js.map +1 -0
  304. package/dist/tests/units/modules/review-execution/entities/actionProvenance/actionProvenance.test.d.ts +2 -0
  305. package/dist/tests/units/modules/review-execution/entities/actionProvenance/actionProvenance.test.d.ts.map +1 -0
  306. package/dist/tests/units/modules/review-execution/entities/actionProvenance/actionProvenance.test.js +26 -0
  307. package/dist/tests/units/modules/review-execution/entities/actionProvenance/actionProvenance.test.js.map +1 -0
  308. package/dist/tests/units/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.test.d.ts +2 -0
  309. package/dist/tests/units/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.test.d.ts.map +1 -0
  310. package/dist/tests/units/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.test.js +44 -0
  311. package/dist/tests/units/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.test.js.map +1 -0
  312. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.parity.test.d.ts +2 -0
  313. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.parity.test.d.ts.map +1 -0
  314. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.parity.test.js +29 -0
  315. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.parity.test.js.map +1 -0
  316. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.test.d.ts +2 -0
  317. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.test.d.ts.map +1 -0
  318. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.test.js +115 -0
  319. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.test.js.map +1 -0
  320. package/dist/tests/units/modules/review-execution/services/contextActionsExecutor.autopath.test.d.ts +2 -0
  321. package/dist/tests/units/modules/review-execution/services/contextActionsExecutor.autopath.test.d.ts.map +1 -0
  322. package/dist/tests/units/modules/review-execution/services/contextActionsExecutor.autopath.test.js +52 -0
  323. package/dist/tests/units/modules/review-execution/services/contextActionsExecutor.autopath.test.js.map +1 -0
  324. package/dist/tests/units/modules/review-execution/services/dispatchConstrainedActions.test.d.ts +2 -0
  325. package/dist/tests/units/modules/review-execution/services/dispatchConstrainedActions.test.d.ts.map +1 -0
  326. package/dist/tests/units/modules/review-execution/services/dispatchConstrainedActions.test.js +124 -0
  327. package/dist/tests/units/modules/review-execution/services/dispatchConstrainedActions.test.js.map +1 -0
  328. package/dist/tests/units/modules/review-execution/services/resolveThreadInventory.test.d.ts +2 -0
  329. package/dist/tests/units/modules/review-execution/services/resolveThreadInventory.test.d.ts.map +1 -0
  330. package/dist/tests/units/modules/review-execution/services/resolveThreadInventory.test.js +67 -0
  331. package/dist/tests/units/modules/review-execution/services/resolveThreadInventory.test.js.map +1 -0
  332. package/dist/tests/units/modules/review-execution/usecases/gateClaudeInvocation.usecase.test.js +42 -0
  333. package/dist/tests/units/modules/review-execution/usecases/gateClaudeInvocation.usecase.test.js.map +1 -1
  334. package/dist/tests/units/security/gitlabTokenRotation.test.d.ts +2 -0
  335. package/dist/tests/units/security/gitlabTokenRotation.test.d.ts.map +1 -0
  336. package/dist/tests/units/security/gitlabTokenRotation.test.js +39 -0
  337. package/dist/tests/units/security/gitlabTokenRotation.test.js.map +1 -0
  338. package/dist/tests/units/security/noSpoofableTransportGuard.test.d.ts +2 -0
  339. package/dist/tests/units/security/noSpoofableTransportGuard.test.d.ts.map +1 -0
  340. package/dist/tests/units/security/noSpoofableTransportGuard.test.js +30 -0
  341. package/dist/tests/units/security/noSpoofableTransportGuard.test.js.map +1 -0
  342. package/dist/tests/units/security/transportGuardConfig.test.d.ts +2 -0
  343. package/dist/tests/units/security/transportGuardConfig.test.d.ts.map +1 -0
  344. package/dist/tests/units/security/transportGuardConfig.test.js +38 -0
  345. package/dist/tests/units/security/transportGuardConfig.test.js.map +1 -0
  346. package/dist/tests/units/security/verifier.test.js +33 -2
  347. package/dist/tests/units/security/verifier.test.js.map +1 -1
  348. package/dist/tests/units/services/contextActionsExecutor.egress.test.d.ts +2 -0
  349. package/dist/tests/units/services/contextActionsExecutor.egress.test.d.ts.map +1 -0
  350. package/dist/tests/units/services/contextActionsExecutor.egress.test.js +117 -0
  351. package/dist/tests/units/services/contextActionsExecutor.egress.test.js.map +1 -0
  352. package/dist/tests/units/services/contextActionsExecutor.test.js +24 -31
  353. package/dist/tests/units/services/contextActionsExecutor.test.js.map +1 -1
  354. package/dist/tests/units/services/publicOutputExecutor.test.d.ts +2 -0
  355. package/dist/tests/units/services/publicOutputExecutor.test.d.ts.map +1 -0
  356. package/dist/tests/units/services/publicOutputExecutor.test.js +72 -0
  357. package/dist/tests/units/services/publicOutputExecutor.test.js.map +1 -0
  358. package/dist/tests/units/services/threadActionsExecutor.egress.test.d.ts +2 -0
  359. package/dist/tests/units/services/threadActionsExecutor.egress.test.d.ts.map +1 -0
  360. package/dist/tests/units/services/threadActionsExecutor.egress.test.js +113 -0
  361. package/dist/tests/units/services/threadActionsExecutor.egress.test.js.map +1 -0
  362. package/dist/tests/units/services/threadActionsExecutor.test.js +32 -96
  363. package/dist/tests/units/services/threadActionsExecutor.test.js.map +1 -1
  364. package/dist/tests/units/usecases/insights/generateAiInsightsViaSession.usecase.test.d.ts +2 -0
  365. package/dist/tests/units/usecases/insights/generateAiInsightsViaSession.usecase.test.d.ts.map +1 -0
  366. package/dist/tests/units/usecases/insights/generateAiInsightsViaSession.usecase.test.js +114 -0
  367. package/dist/tests/units/usecases/insights/generateAiInsightsViaSession.usecase.test.js.map +1 -0
  368. package/dist/tests/units/usecases/insights/parseAiInsightsResponse.test.d.ts +2 -0
  369. package/dist/tests/units/usecases/insights/parseAiInsightsResponse.test.d.ts.map +1 -0
  370. package/dist/tests/units/usecases/insights/parseAiInsightsResponse.test.js +45 -0
  371. package/dist/tests/units/usecases/insights/parseAiInsightsResponse.test.js.map +1 -0
  372. package/dist/tests/units/usecases/insights/persistAiInsights.usecase.test.d.ts +2 -0
  373. package/dist/tests/units/usecases/insights/persistAiInsights.usecase.test.d.ts.map +1 -0
  374. package/dist/tests/units/usecases/insights/persistAiInsights.usecase.test.js +87 -0
  375. package/dist/tests/units/usecases/insights/persistAiInsights.usecase.test.js.map +1 -0
  376. package/package.json +9 -2
  377. package/dist/frameworks/claude/claudeInsightsInvoker.d.ts +0 -3
  378. package/dist/frameworks/claude/claudeInsightsInvoker.d.ts.map +0 -1
  379. package/dist/frameworks/claude/claudeInsightsInvoker.js +0 -58
  380. package/dist/frameworks/claude/claudeInsightsInvoker.js.map +0 -1
  381. package/dist/modules/ember-chat/interface-adapters/gateways/emberStreamJson.parser.d.ts.map +0 -1
  382. package/dist/modules/ember-chat/interface-adapters/gateways/emberStreamJson.parser.js.map +0 -1
  383. package/dist/modules/statistics-insights/usecases/insights/generateAiInsights.usecase.d.ts.map +0 -1
  384. package/dist/modules/statistics-insights/usecases/insights/generateAiInsights.usecase.js +0 -65
  385. package/dist/modules/statistics-insights/usecases/insights/generateAiInsights.usecase.js.map +0 -1
  386. package/dist/tests/units/modules/ember-chat/gateways/emberStreamJson.parser.test.d.ts +0 -2
  387. package/dist/tests/units/modules/ember-chat/gateways/emberStreamJson.parser.test.d.ts.map +0 -1
  388. package/dist/tests/units/modules/ember-chat/gateways/emberStreamJson.parser.test.js.map +0 -1
  389. package/dist/tests/units/usecases/insights/generateAiInsights.usecase.test.d.ts +0 -2
  390. package/dist/tests/units/usecases/insights/generateAiInsights.usecase.test.d.ts.map +0 -1
  391. package/dist/tests/units/usecases/insights/generateAiInsights.usecase.test.js +0 -253
  392. package/dist/tests/units/usecases/insights/generateAiInsights.usecase.test.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"clientIpResolver.forwardedFor.gateway.test.js","sourceRoot":"","sources":["../../../../../../../src/tests/units/modules/platform-integration/interface-adapters/transport/clientIpResolver.forwardedFor.gateway.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,4BAA4B,EAAE,MAAM,+GAA+G,CAAC;AAE7J,QAAQ,CAAC,8BAA8B,EAAE,GAAG,EAAE;IAC5C,EAAE,CAAC,0EAA0E,EAAE,GAAG,EAAE;QAClF,MAAM,QAAQ,GAAG,IAAI,4BAA4B,EAAE,CAAC;QAEpD,MAAM,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAC;YAChC,aAAa,EAAE,KAAK;YACpB,YAAY,EAAE,wBAAwB;SACvC,CAAC,CAAC;QAEH,MAAM,CAAC,QAAQ,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC9B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oEAAoE,EAAE,GAAG,EAAE;QAC5E,MAAM,QAAQ,GAAG,IAAI,4BAA4B,EAAE,CAAC;QAEpD,MAAM,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAC;YAChC,aAAa,EAAE,IAAI;YACnB,YAAY,EAAE,wBAAwB;SACvC,CAAC,CAAC;QAEH,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+DAA+D,EAAE,GAAG,EAAE;QACvE,MAAM,QAAQ,GAAG,IAAI,4BAA4B,EAAE,CAAC;QAEpD,MAAM,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAC;YAChC,aAAa,EAAE,IAAI;YACnB,YAAY,EAAE,IAAI;SACnB,CAAC,CAAC;QAEH,MAAM,CAAC,QAAQ,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC9B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=transportGuard.middleware.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transportGuard.middleware.test.d.ts","sourceRoot":"","sources":["../../../../../../../src/tests/units/modules/platform-integration/interface-adapters/transport/transportGuard.middleware.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,66 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { transportGuardMiddleware } from '../../../../../../modules/platform-integration/interface-adapters/controllers/webhook/transportGuard.middleware.js';
3
+ import { ForwardedForClientIpResolver } from '../../../../../../modules/platform-integration/interface-adapters/gateways/transport/clientIpResolver.forwardedFor.gateway.js';
4
+ const TRUSTED_HOP = '127.0.0.1';
5
+ const config = {
6
+ trustedHopAddress: TRUSTED_HOP,
7
+ allowedCidrRanges: ['10.20.30.0/24'],
8
+ };
9
+ class FakeResponse {
10
+ statusCode = null;
11
+ sent = false;
12
+ code(status) {
13
+ this.statusCode = status;
14
+ return this;
15
+ }
16
+ send() {
17
+ this.sent = true;
18
+ return this;
19
+ }
20
+ }
21
+ function buildRequest(overrides = {}) {
22
+ return {
23
+ socket: { remoteAddress: overrides.remoteAddress ?? TRUSTED_HOP },
24
+ headers: {
25
+ 'x-forwarded-proto': overrides.proto ?? 'https',
26
+ 'x-forwarded-for': overrides.forwardedFor ?? '10.20.30.40, 127.0.0.1',
27
+ },
28
+ };
29
+ }
30
+ describe('transportGuardMiddleware (AC5)', () => {
31
+ it('calls next on a fully valid transport and never sends a rejection', () => {
32
+ let nextCalled = false;
33
+ const request = buildRequest();
34
+ const reply = new FakeResponse();
35
+ transportGuardMiddleware({ request, reply, next: () => { nextCalled = true; }, resolver: new ForwardedForClientIpResolver() }, config);
36
+ expect(nextCalled).toBe(true);
37
+ expect(reply.statusCode).toBeNull();
38
+ expect(reply.sent).toBe(false);
39
+ });
40
+ it('rejects with 403 and never calls next when the socket is untrusted', () => {
41
+ let nextCalled = false;
42
+ const request = buildRequest({ remoteAddress: '203.0.113.7' });
43
+ const reply = new FakeResponse();
44
+ transportGuardMiddleware({ request, reply, next: () => { nextCalled = true; }, resolver: new ForwardedForClientIpResolver() }, config);
45
+ expect(nextCalled).toBe(false);
46
+ expect(reply.statusCode).toBe(403);
47
+ expect(reply.sent).toBe(true);
48
+ });
49
+ it('rejects with 403 when the forwarded protocol is not https', () => {
50
+ let nextCalled = false;
51
+ const request = buildRequest({ proto: 'http' });
52
+ const reply = new FakeResponse();
53
+ transportGuardMiddleware({ request, reply, next: () => { nextCalled = true; }, resolver: new ForwardedForClientIpResolver() }, config);
54
+ expect(nextCalled).toBe(false);
55
+ expect(reply.statusCode).toBe(403);
56
+ });
57
+ it('rejects with 403 when the resolved client ip is off the allowlist', () => {
58
+ let nextCalled = false;
59
+ const request = buildRequest({ forwardedFor: '192.168.1.1' });
60
+ const reply = new FakeResponse();
61
+ transportGuardMiddleware({ request, reply, next: () => { nextCalled = true; }, resolver: new ForwardedForClientIpResolver() }, config);
62
+ expect(nextCalled).toBe(false);
63
+ expect(reply.statusCode).toBe(403);
64
+ });
65
+ });
66
+ //# sourceMappingURL=transportGuard.middleware.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transportGuard.middleware.test.js","sourceRoot":"","sources":["../../../../../../../src/tests/units/modules/platform-integration/interface-adapters/transport/transportGuard.middleware.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=autoExecutorActionFilter.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"autoExecutorActionFilter.test.d.ts","sourceRoot":"","sources":["../../../../../../src/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,38 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { filterAutoExecutorActions, capabilityForAction, } from '../../../../../modules/platform-integration/services/autoExecutorActionFilter.js';
3
+ describe('auto executor action filter (AC6/AC7)', () => {
4
+ it('maps each action type to its required capability (AC5)', () => {
5
+ expect(capabilityForAction({ type: 'FETCH_THREADS' })).toBe('readMr');
6
+ expect(capabilityForAction({ type: 'POST_COMMENT', body: 'x' })).toBe('postComment');
7
+ expect(capabilityForAction({ type: 'THREAD_REPLY', threadId: '1', message: 'x' })).toBe('postComment');
8
+ expect(capabilityForAction({ type: 'POST_INLINE_COMMENT', filePath: 'a', line: 1, body: 'x' })).toBe('postComment');
9
+ expect(capabilityForAction({ type: 'THREAD_RESOLVE', threadId: '1' })).toBe('threadResolve');
10
+ expect(capabilityForAction({ type: 'ADD_LABEL', label: 'x' })).toBe('addLabel');
11
+ });
12
+ it('AC6: drops THREAD_RESOLVE from the auto action set', () => {
13
+ const actions = [
14
+ { type: 'POST_COMMENT', body: 'hello' },
15
+ { type: 'THREAD_RESOLVE', threadId: '42' },
16
+ ];
17
+ const { allowed, dropped } = filterAutoExecutorActions(actions);
18
+ expect(allowed).toEqual([{ type: 'POST_COMMENT', body: 'hello' }]);
19
+ expect(dropped).toEqual([{ type: 'THREAD_RESOLVE', threadId: '42' }]);
20
+ });
21
+ it('AC7: keeps POST_COMMENT and FETCH_THREADS, drops THREAD_RESOLVE, no throw', () => {
22
+ const actions = [
23
+ { type: 'POST_COMMENT', body: 'one' },
24
+ { type: 'THREAD_RESOLVE', threadId: '7' },
25
+ { type: 'FETCH_THREADS' },
26
+ ];
27
+ const { allowed, dropped } = filterAutoExecutorActions(actions);
28
+ expect(allowed).toEqual([{ type: 'POST_COMMENT', body: 'one' }, { type: 'FETCH_THREADS' }]);
29
+ expect(dropped).toEqual([{ type: 'THREAD_RESOLVE', threadId: '7' }]);
30
+ });
31
+ it('AC6: drops ADD_LABEL since it exceeds the read+postComment set', () => {
32
+ const actions = [{ type: 'ADD_LABEL', label: 'reviewed' }];
33
+ const { allowed, dropped } = filterAutoExecutorActions(actions);
34
+ expect(allowed).toEqual([]);
35
+ expect(dropped).toEqual([{ type: 'ADD_LABEL', label: 'reviewed' }]);
36
+ });
37
+ });
38
+ //# sourceMappingURL=autoExecutorActionFilter.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"autoExecutorActionFilter.test.js","sourceRoot":"","sources":["../../../../../../src/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=autoExecutorCapabilityGate.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"autoExecutorCapabilityGate.test.d.ts","sourceRoot":"","sources":["../../../../../../src/tests/units/modules/platform-integration/services/autoExecutorCapabilityGate.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,40 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { EXECUTOR_CAPABILITY_TABLE, AUTO_EXECUTOR_CAPABILITIES, } from '../../../../../modules/platform-integration/entities/executorToken/executorCapability.js';
3
+ import { capabilityForAction, filterAutoExecutorActions, } from '../../../../../modules/platform-integration/services/autoExecutorActionFilter.js';
4
+ import { reviewActionSchema } from '../../../../../modules/review-execution/entities/reviewAction/reviewAction.schema.js';
5
+ // AC8 — merge-blocking privilege contract gate.
6
+ // This structural test pins the production auto-executor capability set to exactly
7
+ // {readMr, postComment}. Re-wiring revoke/THREAD_RESOLVE into the auto path, or
8
+ // widening the token's capability set, turns this red.
9
+ describe('auto executor capability gate (AC8)', () => {
10
+ it('freezes the auto capability set to exactly {readMr, postComment}', () => {
11
+ expect([...AUTO_EXECUTOR_CAPABILITIES].sort()).toEqual(['postComment', 'readMr']);
12
+ });
13
+ it('keeps threadResolve and revoke declared as non-auto in the source-of-truth table', () => {
14
+ expect(EXECUTOR_CAPABILITY_TABLE.threadResolve.autoPath).toBe(false);
15
+ expect(EXECUTOR_CAPABILITY_TABLE.revoke.autoPath).toBe(false);
16
+ });
17
+ it('lets every parseable review action verb through the production filter only if its capability is auto', () => {
18
+ const sampleByType = {
19
+ FETCH_THREADS: { type: 'FETCH_THREADS' },
20
+ POST_COMMENT: { type: 'POST_COMMENT', body: 'b' },
21
+ THREAD_REPLY: { type: 'THREAD_REPLY', threadId: '1', message: 'm' },
22
+ POST_INLINE_COMMENT: { type: 'POST_INLINE_COMMENT', filePath: 'f', line: 1, body: 'b' },
23
+ THREAD_RESOLVE: { type: 'THREAD_RESOLVE', threadId: '1' },
24
+ ADD_LABEL: { type: 'ADD_LABEL', label: 'l' },
25
+ };
26
+ const allUnionTypes = reviewActionSchema.options.map(option => option.shape.type.value);
27
+ // Guard: the gate must cover every verb the schema can parse.
28
+ expect(Object.keys(sampleByType).sort()).toEqual([...allUnionTypes].sort());
29
+ const actions = Object.values(sampleByType);
30
+ const { allowed, dropped } = filterAutoExecutorActions(actions);
31
+ const autoVerbs = ['FETCH_THREADS', 'POST_COMMENT', 'THREAD_REPLY', 'POST_INLINE_COMMENT'];
32
+ const nonAutoVerbs = ['THREAD_RESOLVE', 'ADD_LABEL'];
33
+ expect(allowed.map(a => a.type).sort()).toEqual([...autoVerbs].sort());
34
+ expect(dropped.map(a => a.type).sort()).toEqual([...nonAutoVerbs].sort());
35
+ for (const action of allowed) {
36
+ expect(['readMr', 'postComment']).toContain(capabilityForAction(action));
37
+ }
38
+ });
39
+ });
40
+ //# sourceMappingURL=autoExecutorCapabilityGate.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"autoExecutorCapabilityGate.test.js","sourceRoot":"","sources":["../../../../../../src/tests/units/modules/platform-integration/services/autoExecutorCapabilityGate.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=pinnedThreadFetchTarget.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pinnedThreadFetchTarget.test.d.ts","sourceRoot":"","sources":["../../../../../../src/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,76 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { resolvePinnedThreadFetchTarget } from '../../../../../modules/platform-integration/services/pinnedThreadFetchTarget.js';
3
+ class RecordingThreadFetch {
4
+ calls = [];
5
+ fetchThreads = (projectPath, mrNumber) => {
6
+ this.calls.push({ projectPath, mrNumber });
7
+ return [];
8
+ };
9
+ }
10
+ describe('pinned thread-fetch target provenance (AC9)', () => {
11
+ it('resolves the validated pair when project is configured and mrNumber matches the gated MR', () => {
12
+ const target = resolvePinnedThreadFetchTarget({
13
+ payloadProjectPath: 'group/proj',
14
+ payloadMrNumber: 5,
15
+ findRepository: () => ({ projectPath: 'group/proj', localPath: '/repo' }),
16
+ gatedMrNumber: 5,
17
+ });
18
+ expect(target).toEqual({ projectPath: 'group/proj', mrNumber: 5 });
19
+ });
20
+ it('fails closed (null) when projectPath is not in the registry', () => {
21
+ const target = resolvePinnedThreadFetchTarget({
22
+ payloadProjectPath: 'attacker/unknown',
23
+ payloadMrNumber: 5,
24
+ findRepository: () => null,
25
+ gatedMrNumber: 5,
26
+ });
27
+ expect(target).toBeNull();
28
+ });
29
+ it('fails closed (null) when payload mrNumber differs from the gated MR', () => {
30
+ const target = resolvePinnedThreadFetchTarget({
31
+ payloadProjectPath: 'group/proj',
32
+ payloadMrNumber: 999,
33
+ findRepository: () => ({ projectPath: 'group/proj', localPath: '/repo' }),
34
+ gatedMrNumber: 5,
35
+ });
36
+ expect(target).toBeNull();
37
+ });
38
+ it('AC9(1): unrecognized project means fetchThreads is never called', () => {
39
+ const fetch = new RecordingThreadFetch();
40
+ const target = resolvePinnedThreadFetchTarget({
41
+ payloadProjectPath: 'attacker/unknown',
42
+ payloadMrNumber: 5,
43
+ findRepository: () => null,
44
+ gatedMrNumber: 5,
45
+ });
46
+ if (target)
47
+ fetch.fetchThreads(target.projectPath, target.mrNumber);
48
+ expect(fetch.calls).toHaveLength(0);
49
+ });
50
+ it('AC9(2): forged mrNumber never retargets fetchThreads at the foreign MR', () => {
51
+ const fetch = new RecordingThreadFetch();
52
+ const target = resolvePinnedThreadFetchTarget({
53
+ payloadProjectPath: 'group/proj',
54
+ payloadMrNumber: 999,
55
+ findRepository: () => ({ projectPath: 'group/proj', localPath: '/repo' }),
56
+ gatedMrNumber: 5,
57
+ });
58
+ if (target)
59
+ fetch.fetchThreads(target.projectPath, target.mrNumber);
60
+ expect(fetch.calls.find(c => c.mrNumber === 999)).toBeUndefined();
61
+ expect(fetch.calls).toHaveLength(0);
62
+ });
63
+ it('uses the configured projectPath, never the raw payload, to fetch', () => {
64
+ const fetch = new RecordingThreadFetch();
65
+ const target = resolvePinnedThreadFetchTarget({
66
+ payloadProjectPath: 'group/proj',
67
+ payloadMrNumber: 5,
68
+ findRepository: () => ({ projectPath: 'group/proj-canonical', localPath: '/repo' }),
69
+ gatedMrNumber: 5,
70
+ });
71
+ if (target)
72
+ fetch.fetchThreads(target.projectPath, target.mrNumber);
73
+ expect(fetch.calls).toEqual([{ projectPath: 'group/proj-canonical', mrNumber: 5 }]);
74
+ });
75
+ });
76
+ //# sourceMappingURL=pinnedThreadFetchTarget.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pinnedThreadFetchTarget.test.js","sourceRoot":"","sources":["../../../../../../src/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=scopedExecutorEnvironment.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scopedExecutorEnvironment.test.d.ts","sourceRoot":"","sources":["../../../../../../src/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,120 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { buildScopedExecutorEnvironment, ENV_ALLOWLIST, MissingExecutorTokenError, } from '../../../../../modules/platform-integration/services/scopedExecutorEnvironment.js';
3
+ class RecordingFileWriter {
4
+ writes = [];
5
+ write(path, contents) {
6
+ this.writes.push({ path, contents });
7
+ }
8
+ }
9
+ const TOKEN = 'glpat-service-token-xyz';
10
+ const TEMP_ROOT = '/tmp/reviewflow-executor-abc123';
11
+ describe('scoped executor environment (AC1/AC2/AC3/AC4)', () => {
12
+ it('AC1: throws fail-closed when the service token is absent', () => {
13
+ const fileWriter = new RecordingFileWriter();
14
+ expect(() => buildScopedExecutorEnvironment({
15
+ parentEnv: { PATH: '/usr/bin' },
16
+ isolatedDir: TEMP_ROOT,
17
+ fileWriter,
18
+ })).toThrow(MissingExecutorTokenError);
19
+ expect(fileWriter.writes).toHaveLength(0);
20
+ });
21
+ it('AC1: throws fail-closed when the service token is empty', () => {
22
+ const fileWriter = new RecordingFileWriter();
23
+ expect(() => buildScopedExecutorEnvironment({
24
+ parentEnv: { REVIEWFLOW_EXECUTOR_TOKEN: ' ' },
25
+ isolatedDir: TEMP_ROOT,
26
+ fileWriter,
27
+ })).toThrow(MissingExecutorTokenError);
28
+ expect(fileWriter.writes).toHaveLength(0);
29
+ });
30
+ it('AC1: returns a configured environment when the token is present', () => {
31
+ const fileWriter = new RecordingFileWriter();
32
+ const result = buildScopedExecutorEnvironment({
33
+ parentEnv: { REVIEWFLOW_EXECUTOR_TOKEN: TOKEN, PATH: '/usr/bin' },
34
+ isolatedDir: TEMP_ROOT,
35
+ fileWriter,
36
+ });
37
+ expect(result.env).toBeDefined();
38
+ expect(fileWriter.writes).toHaveLength(1);
39
+ });
40
+ it('AC2: child env keyset is a subset of the declared allowlist', () => {
41
+ const fileWriter = new RecordingFileWriter();
42
+ const { env } = buildScopedExecutorEnvironment({
43
+ parentEnv: {
44
+ REVIEWFLOW_EXECUTOR_TOKEN: TOKEN,
45
+ PATH: '/usr/bin',
46
+ LANG: 'en_US.UTF-8',
47
+ AMBIENT_ADMIN_TOKEN: 'canary',
48
+ },
49
+ isolatedDir: TEMP_ROOT,
50
+ fileWriter,
51
+ });
52
+ for (const key of Object.keys(env)) {
53
+ expect(ENV_ALLOWLIST).toContain(key);
54
+ }
55
+ });
56
+ it('AC2: a parent canary secret is absent from the child env', () => {
57
+ const fileWriter = new RecordingFileWriter();
58
+ const { env } = buildScopedExecutorEnvironment({
59
+ parentEnv: {
60
+ REVIEWFLOW_EXECUTOR_TOKEN: TOKEN,
61
+ PATH: '/usr/bin',
62
+ AMBIENT_ADMIN_TOKEN: 'canary',
63
+ },
64
+ isolatedDir: TEMP_ROOT,
65
+ fileWriter,
66
+ });
67
+ expect('AMBIENT_ADMIN_TOKEN' in env).toBe(false);
68
+ });
69
+ it('AC3: no child env value equals the token string', () => {
70
+ const fileWriter = new RecordingFileWriter();
71
+ const { env } = buildScopedExecutorEnvironment({
72
+ parentEnv: { REVIEWFLOW_EXECUTOR_TOKEN: TOKEN, PATH: '/usr/bin' },
73
+ isolatedDir: TEMP_ROOT,
74
+ fileWriter,
75
+ });
76
+ for (const value of Object.values(env)) {
77
+ expect(value).not.toBe(TOKEN);
78
+ }
79
+ });
80
+ it('AC3: the token appears only in the rendered config-file contents', () => {
81
+ const fileWriter = new RecordingFileWriter();
82
+ buildScopedExecutorEnvironment({
83
+ parentEnv: { REVIEWFLOW_EXECUTOR_TOKEN: TOKEN, PATH: '/usr/bin' },
84
+ isolatedDir: TEMP_ROOT,
85
+ fileWriter,
86
+ });
87
+ expect(fileWriter.writes[0]?.contents).toContain(TOKEN);
88
+ });
89
+ it('AC4: HOME and GLAB_CONFIG_DIR resolve under the isolated temp root', () => {
90
+ const fileWriter = new RecordingFileWriter();
91
+ const { env } = buildScopedExecutorEnvironment({
92
+ parentEnv: { REVIEWFLOW_EXECUTOR_TOKEN: TOKEN, PATH: '/usr/bin' },
93
+ isolatedDir: TEMP_ROOT,
94
+ fileWriter,
95
+ });
96
+ expect(env.HOME?.startsWith(TEMP_ROOT)).toBe(true);
97
+ expect(env.GLAB_CONFIG_DIR?.startsWith(TEMP_ROOT)).toBe(true);
98
+ });
99
+ it('AC4: the config file is written under GLAB_CONFIG_DIR/glab-cli/config.yml', () => {
100
+ const fileWriter = new RecordingFileWriter();
101
+ const { env } = buildScopedExecutorEnvironment({
102
+ parentEnv: { REVIEWFLOW_EXECUTOR_TOKEN: TOKEN, PATH: '/usr/bin' },
103
+ isolatedDir: TEMP_ROOT,
104
+ fileWriter,
105
+ });
106
+ expect(fileWriter.writes[0]?.path).toBe(`${env.GLAB_CONFIG_DIR}/glab-cli/config.yml`);
107
+ });
108
+ it('AC4: every written path stays under the isolated temp root', () => {
109
+ const fileWriter = new RecordingFileWriter();
110
+ buildScopedExecutorEnvironment({
111
+ parentEnv: { REVIEWFLOW_EXECUTOR_TOKEN: TOKEN, PATH: '/usr/bin' },
112
+ isolatedDir: TEMP_ROOT,
113
+ fileWriter,
114
+ });
115
+ for (const write of fileWriter.writes) {
116
+ expect(write.path.startsWith(TEMP_ROOT)).toBe(true);
117
+ }
118
+ });
119
+ });
120
+ //# sourceMappingURL=scopedExecutorEnvironment.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scopedExecutorEnvironment.test.js","sourceRoot":"","sources":["../../../../../../src/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=isTrustedActor.usecase.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isTrustedActor.usecase.test.d.ts","sourceRoot":"","sources":["../../../../../../src/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,33 @@
1
+ import { describe, it, expect, beforeEach } from 'vitest';
2
+ import { IsTrustedActorUseCase } from '../../../../../modules/platform-integration/usecases/isTrustedActor.usecase.js';
3
+ import { StubMemberAccessGateway } from '../../../../../tests/stubs/memberAccess.stub.js';
4
+ import { MEMBER_ACCESS_LEVELS } from '../../../../../modules/platform-integration/entities/memberAccess/memberAccess.js';
5
+ describe('IsTrustedActorUseCase', () => {
6
+ let gateway;
7
+ let useCase;
8
+ beforeEach(() => {
9
+ gateway = new StubMemberAccessGateway();
10
+ useCase = new IsTrustedActorUseCase(gateway);
11
+ });
12
+ it('trusts a Developer+ actor', async () => {
13
+ gateway.setAccess('alice', MEMBER_ACCESS_LEVELS.developer);
14
+ const trusted = await useCase.execute({ username: 'alice', projectPath: 'org/project' });
15
+ expect(trusted).toBe(true);
16
+ expect(gateway.calls).toEqual([{ projectPath: 'org/project', username: 'alice' }]);
17
+ });
18
+ it('does not trust an actor below Developer', async () => {
19
+ gateway.setAccess('bob', MEMBER_ACCESS_LEVELS.reporter);
20
+ const trusted = await useCase.execute({ username: 'bob', projectPath: 'org/project' });
21
+ expect(trusted).toBe(false);
22
+ });
23
+ it('does not trust an unknown username (fail-closed)', async () => {
24
+ const trusted = await useCase.execute({ username: 'stranger', projectPath: 'org/project' });
25
+ expect(trusted).toBe(false);
26
+ });
27
+ it('does not trust when the gateway throws (fail-closed)', async () => {
28
+ gateway.setShouldFail(true);
29
+ const trusted = await useCase.execute({ username: 'alice', projectPath: 'org/project' });
30
+ expect(trusted).toBe(false);
31
+ });
32
+ });
33
+ //# sourceMappingURL=isTrustedActor.usecase.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isTrustedActor.usecase.test.js","sourceRoot":"","sources":["../../../../../../src/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAC1D,OAAO,EAAE,qBAAqB,EAAE,MAAM,mEAAmE,CAAC;AAC1G,OAAO,EAAE,uBAAuB,EAAE,MAAM,oCAAoC,CAAC;AAC7E,OAAO,EAAE,oBAAoB,EAAE,MAAM,sEAAsE,CAAC;AAE5G,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,IAAI,OAAgC,CAAC;IACrC,IAAI,OAA8B,CAAC;IAEnC,UAAU,CAAC,GAAG,EAAE;QACd,OAAO,GAAG,IAAI,uBAAuB,EAAE,CAAC;QACxC,OAAO,GAAG,IAAI,qBAAqB,CAAC,OAAO,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE,KAAK,IAAI,EAAE;QACzC,OAAO,CAAC,SAAS,CAAC,OAAO,EAAE,oBAAoB,CAAC,SAAS,CAAC,CAAC;QAE3D,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,OAAO,CAAC,EAAE,QAAQ,EAAE,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,CAAC;QAEzF,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3B,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE,WAAW,EAAE,aAAa,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC;IACrF,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yCAAyC,EAAE,KAAK,IAAI,EAAE;QACvD,OAAO,CAAC,SAAS,CAAC,KAAK,EAAE,oBAAoB,CAAC,QAAQ,CAAC,CAAC;QAExD,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,OAAO,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,CAAC;QAEvF,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE,KAAK,IAAI,EAAE;QAChE,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,OAAO,CAAC,EAAE,QAAQ,EAAE,UAAU,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,CAAC;QAE5F,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sDAAsD,EAAE,KAAK,IAAI,EAAE;QACpE,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QAE5B,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,OAAO,CAAC,EAAE,QAAQ,EAAE,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,CAAC;QAEzF,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=evaluateTransport.usecase.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"evaluateTransport.usecase.test.d.ts","sourceRoot":"","sources":["../../../../../../../src/tests/units/modules/platform-integration/usecases/transport/evaluateTransport.usecase.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,69 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { evaluateTransport } from '../../../../../../modules/platform-integration/usecases/transport/evaluateTransport.usecase.js';
3
+ import { TransportContextFactory } from '../../../../../../tests/factories/transportContext.factory.js';
4
+ describe('evaluateTransport', () => {
5
+ describe('AC1 - untrusted socket', () => {
6
+ it('rejects with 403 when the direct socket address is not the trusted hop, ignoring headers', () => {
7
+ const context = TransportContextFactory.valid({
8
+ directSocketAddress: '203.0.113.7',
9
+ forwardedProto: 'https',
10
+ resolvedClientIp: '10.20.30.40',
11
+ });
12
+ const decision = evaluateTransport(context);
13
+ expect(decision).toEqual({ kind: 'reject', status: 403, reason: 'untrusted-socket' });
14
+ });
15
+ it('does not consult the protocol or client ip once the socket fails', () => {
16
+ const context = TransportContextFactory.valid({
17
+ directSocketAddress: '203.0.113.7',
18
+ forwardedProto: 'http',
19
+ resolvedClientIp: null,
20
+ allowedCidrRanges: [],
21
+ });
22
+ const decision = evaluateTransport(context);
23
+ expect(decision.kind).toBe('reject');
24
+ });
25
+ });
26
+ describe('AC2 - non-https', () => {
27
+ it('rejects with 403 when the forwarded protocol is not https', () => {
28
+ const context = TransportContextFactory.valid({ forwardedProto: 'http' });
29
+ const decision = evaluateTransport(context);
30
+ expect(decision).toEqual({ kind: 'reject', status: 403, reason: 'non-https' });
31
+ });
32
+ it('rejects with 403 when no forwarded protocol is present', () => {
33
+ const context = TransportContextFactory.valid({ forwardedProto: null });
34
+ const decision = evaluateTransport(context);
35
+ expect(decision).toEqual({ kind: 'reject', status: 403, reason: 'non-https' });
36
+ });
37
+ });
38
+ describe('AC3 - allowlisted, https, hop-trusted', () => {
39
+ it('accepts a fully valid transport context', () => {
40
+ const context = TransportContextFactory.valid();
41
+ const decision = evaluateTransport(context);
42
+ expect(decision).toEqual({ kind: 'accept' });
43
+ });
44
+ });
45
+ describe('AC4 - off-allowlist', () => {
46
+ it('rejects with 403 when the resolved client ip is outside every configured range', () => {
47
+ const context = TransportContextFactory.valid({
48
+ resolvedClientIp: '192.168.1.1',
49
+ allowedCidrRanges: ['10.20.30.0/24'],
50
+ });
51
+ const decision = evaluateTransport(context);
52
+ expect(decision).toEqual({ kind: 'reject', status: 403, reason: 'off-allowlist' });
53
+ });
54
+ it('rejects with 403 when the client ip could not be resolved', () => {
55
+ const context = TransportContextFactory.valid({ resolvedClientIp: null });
56
+ const decision = evaluateTransport(context);
57
+ expect(decision).toEqual({ kind: 'reject', status: 403, reason: 'off-allowlist' });
58
+ });
59
+ it('accepts when the resolved client ip falls inside one of several ranges', () => {
60
+ const context = TransportContextFactory.valid({
61
+ resolvedClientIp: '172.16.5.9',
62
+ allowedCidrRanges: ['10.0.0.0/8', '172.16.0.0/12'],
63
+ });
64
+ const decision = evaluateTransport(context);
65
+ expect(decision).toEqual({ kind: 'accept' });
66
+ });
67
+ });
68
+ });
69
+ //# sourceMappingURL=evaluateTransport.usecase.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"evaluateTransport.usecase.test.js","sourceRoot":"","sources":["../../../../../../../src/tests/units/modules/platform-integration/usecases/transport/evaluateTransport.usecase.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=actionProvenance.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"actionProvenance.test.d.ts","sourceRoot":"","sources":["../../../../../../../src/tests/units/modules/review-execution/entities/actionProvenance/actionProvenance.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,26 @@
1
+ import { resolveProvenance } from '../../../../../../modules/review-execution/entities/actionProvenance/actionProvenance.js';
2
+ describe('resolveProvenance (AC-1 fail-closed provenance)', () => {
3
+ const nonCanonical = [
4
+ undefined,
5
+ null,
6
+ '',
7
+ 'TRUSTED',
8
+ 'trusted ',
9
+ ' trusted',
10
+ 'Trusted',
11
+ 'untrusted',
12
+ 'admin',
13
+ {},
14
+ 0,
15
+ true,
16
+ ];
17
+ for (const input of nonCanonical) {
18
+ it(`resolves non-canonical input ${JSON.stringify(input)} to untrusted`, () => {
19
+ expect(resolveProvenance(input)).toBe('untrusted');
20
+ });
21
+ }
22
+ it('resolves the exact canonical token "trusted" to trusted', () => {
23
+ expect(resolveProvenance('trusted')).toBe('trusted');
24
+ });
25
+ });
26
+ //# sourceMappingURL=actionProvenance.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"actionProvenance.test.js","sourceRoot":"","sources":["../../../../../../../src/tests/units/modules/review-execution/entities/actionProvenance/actionProvenance.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,0EAA0E,CAAA;AAE5G,QAAQ,CAAC,iDAAiD,EAAE,GAAG,EAAE;IAC/D,MAAM,YAAY,GAAc;QAC9B,SAAS;QACT,IAAI;QACJ,EAAE;QACF,SAAS;QACT,UAAU;QACV,UAAU;QACV,SAAS;QACT,WAAW;QACX,OAAO;QACP,EAAE;QACF,CAAC;QACD,IAAI;KACL,CAAA;IAED,KAAK,MAAM,KAAK,IAAI,YAAY,EAAE,CAAC;QACjC,EAAE,CAAC,gCAAgC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,eAAe,EAAE,GAAG,EAAE;YAC5E,MAAM,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;QACpD,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,EAAE,CAAC,yDAAyD,EAAE,GAAG,EAAE;QACjE,MAAM,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;IACtD,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=threadInventory.gitlab.gateway.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"threadInventory.gitlab.gateway.test.d.ts","sourceRoot":"","sources":["../../../../../../../src/tests/units/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.test.ts"],"names":[],"mappings":""}