devchain-cli 0.14.0 → 0.15.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 (410) hide show
  1. package/README.md +6 -4
  2. package/dist/cli.js +5 -11
  3. package/dist/drizzle/0065_next_lady_bullseye.sql +11 -0
  4. package/dist/drizzle/meta/0065_snapshot.json +5691 -0
  5. package/dist/drizzle/meta/_journal.json +7 -0
  6. package/dist/node_modules/@devchain/codebase-overview/tsconfig.tsbuildinfo +1 -1
  7. package/dist/node_modules/@devchain/codebase-overview/types.d.ts.map +1 -1
  8. package/dist/node_modules/@devchain/shared/__fixtures__/phase2-frames.d.ts +20 -0
  9. package/dist/node_modules/@devchain/shared/__fixtures__/phase2-frames.d.ts.map +1 -0
  10. package/dist/node_modules/@devchain/shared/__fixtures__/phase2-frames.js +77 -0
  11. package/dist/node_modules/@devchain/shared/__fixtures__/phase2-frames.js.map +1 -0
  12. package/dist/node_modules/@devchain/shared/device-key/index.d.ts +2 -0
  13. package/dist/node_modules/@devchain/shared/device-key/index.d.ts.map +1 -0
  14. package/dist/node_modules/@devchain/shared/device-key/index.js +2 -0
  15. package/dist/node_modules/@devchain/shared/device-key/index.js.map +1 -0
  16. package/dist/node_modules/@devchain/shared/device-key/keypair.d.ts +23 -0
  17. package/dist/node_modules/@devchain/shared/device-key/keypair.d.ts.map +1 -0
  18. package/dist/node_modules/@devchain/shared/device-key/keypair.js +54 -0
  19. package/dist/node_modules/@devchain/shared/device-key/keypair.js.map +1 -0
  20. package/dist/node_modules/@devchain/shared/e2ee/aad.d.ts +3 -0
  21. package/dist/node_modules/@devchain/shared/e2ee/aad.d.ts.map +1 -0
  22. package/dist/node_modules/@devchain/shared/e2ee/aad.js +0 -0
  23. package/dist/node_modules/@devchain/shared/e2ee/aad.js.map +1 -0
  24. package/dist/node_modules/@devchain/shared/e2ee/base64.d.ts +6 -0
  25. package/dist/node_modules/@devchain/shared/e2ee/base64.d.ts.map +1 -0
  26. package/dist/node_modules/@devchain/shared/e2ee/base64.js +69 -0
  27. package/dist/node_modules/@devchain/shared/e2ee/base64.js.map +1 -0
  28. package/dist/node_modules/@devchain/shared/e2ee/crypto-envelope.service.d.ts +9 -0
  29. package/dist/node_modules/@devchain/shared/e2ee/crypto-envelope.service.d.ts.map +1 -0
  30. package/dist/node_modules/@devchain/shared/e2ee/crypto-envelope.service.js +78 -0
  31. package/dist/node_modules/@devchain/shared/e2ee/crypto-envelope.service.js.map +1 -0
  32. package/dist/node_modules/@devchain/shared/e2ee/envelope.d.ts +63 -0
  33. package/dist/node_modules/@devchain/shared/e2ee/envelope.d.ts.map +1 -0
  34. package/dist/node_modules/@devchain/shared/e2ee/envelope.js +64 -0
  35. package/dist/node_modules/@devchain/shared/e2ee/envelope.js.map +1 -0
  36. package/dist/node_modules/@devchain/shared/e2ee/index.d.ts +10 -0
  37. package/dist/node_modules/@devchain/shared/e2ee/index.d.ts.map +1 -0
  38. package/dist/node_modules/@devchain/shared/e2ee/index.js +10 -0
  39. package/dist/node_modules/@devchain/shared/e2ee/index.js.map +1 -0
  40. package/dist/node_modules/@devchain/shared/e2ee/key-exchange.d.ts +17 -0
  41. package/dist/node_modules/@devchain/shared/e2ee/key-exchange.d.ts.map +1 -0
  42. package/dist/node_modules/@devchain/shared/e2ee/key-exchange.js +72 -0
  43. package/dist/node_modules/@devchain/shared/e2ee/key-exchange.js.map +1 -0
  44. package/dist/node_modules/@devchain/shared/e2ee/keypair.d.ts +13 -0
  45. package/dist/node_modules/@devchain/shared/e2ee/keypair.d.ts.map +1 -0
  46. package/dist/node_modules/@devchain/shared/e2ee/keypair.js +34 -0
  47. package/dist/node_modules/@devchain/shared/e2ee/keypair.js.map +1 -0
  48. package/dist/node_modules/@devchain/shared/e2ee/negotiation.d.ts +30 -0
  49. package/dist/node_modules/@devchain/shared/e2ee/negotiation.d.ts.map +1 -0
  50. package/dist/node_modules/@devchain/shared/e2ee/negotiation.js +70 -0
  51. package/dist/node_modules/@devchain/shared/e2ee/negotiation.js.map +1 -0
  52. package/dist/node_modules/@devchain/shared/e2ee/safety-number.d.ts +3 -0
  53. package/dist/node_modules/@devchain/shared/e2ee/safety-number.d.ts.map +1 -0
  54. package/dist/node_modules/@devchain/shared/e2ee/safety-number.js +33 -0
  55. package/dist/node_modules/@devchain/shared/e2ee/safety-number.js.map +1 -0
  56. package/dist/node_modules/@devchain/shared/e2ee/trust.d.ts +22 -0
  57. package/dist/node_modules/@devchain/shared/e2ee/trust.d.ts.map +1 -0
  58. package/dist/node_modules/@devchain/shared/e2ee/trust.js +25 -0
  59. package/dist/node_modules/@devchain/shared/e2ee/trust.js.map +1 -0
  60. package/dist/node_modules/@devchain/shared/index.d.ts +3 -0
  61. package/dist/node_modules/@devchain/shared/index.d.ts.map +1 -1
  62. package/dist/node_modules/@devchain/shared/index.js +3 -0
  63. package/dist/node_modules/@devchain/shared/index.js.map +1 -1
  64. package/dist/node_modules/@devchain/shared/schemas/export-schema.d.ts +14 -6
  65. package/dist/node_modules/@devchain/shared/schemas/export-schema.d.ts.map +1 -1
  66. package/dist/node_modules/@devchain/shared/schemas/export-schema.js +1 -0
  67. package/dist/node_modules/@devchain/shared/schemas/export-schema.js.map +1 -1
  68. package/dist/node_modules/@devchain/shared/tsconfig.tsbuildinfo +1 -1
  69. package/dist/node_modules/@devchain/shared/tunnel-protocol.d.ts +99 -0
  70. package/dist/node_modules/@devchain/shared/tunnel-protocol.d.ts.map +1 -0
  71. package/dist/node_modules/@devchain/shared/tunnel-protocol.js +148 -0
  72. package/dist/node_modules/@devchain/shared/tunnel-protocol.js.map +1 -0
  73. package/dist/server/app.main.module.js +2 -0
  74. package/dist/server/app.main.module.js.map +1 -1
  75. package/dist/server/app.normal.module.js +2 -0
  76. package/dist/server/app.normal.module.js.map +1 -1
  77. package/dist/server/common/config/env.config.js +5 -7
  78. package/dist/server/common/config/env.config.js.map +1 -1
  79. package/dist/server/common/test/app-bootstrap.helper.js +5 -1
  80. package/dist/server/common/test/app-bootstrap.helper.js.map +1 -1
  81. package/dist/server/modules/agent-message-delivery/adapters/legacy-delivery-formatter.adapter.js +4 -0
  82. package/dist/server/modules/agent-message-delivery/adapters/legacy-delivery-formatter.adapter.js.map +1 -1
  83. package/dist/server/modules/agent-message-delivery/agent-message-delivery.service.d.ts +3 -1
  84. package/dist/server/modules/agent-message-delivery/agent-message-delivery.service.js +16 -3
  85. package/dist/server/modules/agent-message-delivery/agent-message-delivery.service.js.map +1 -1
  86. package/dist/server/modules/agent-message-delivery/dtos/delivery.types.d.ts +4 -0
  87. package/dist/server/modules/agents/agents.module.js +2 -1
  88. package/dist/server/modules/agents/agents.module.js.map +1 -1
  89. package/dist/server/modules/agents/controllers/agents.controller.d.ts +3 -1
  90. package/dist/server/modules/agents/controllers/agents.controller.js +12 -2
  91. package/dist/server/modules/agents/controllers/agents.controller.js.map +1 -1
  92. package/dist/server/modules/cloud/cloud.module.js +8 -1
  93. package/dist/server/modules/cloud/cloud.module.js.map +1 -1
  94. package/dist/server/modules/cloud/controllers/auth-callback.controller.js +5 -4
  95. package/dist/server/modules/cloud/controllers/auth-callback.controller.js.map +1 -1
  96. package/dist/server/modules/cloud/controllers/devices-proxy.controller.js +1 -1
  97. package/dist/server/modules/cloud/controllers/devices-proxy.controller.js.map +1 -1
  98. package/dist/server/modules/cloud/controllers/preferences-proxy.controller.js +1 -1
  99. package/dist/server/modules/cloud/controllers/preferences-proxy.controller.js.map +1 -1
  100. package/dist/server/modules/cloud/controllers/qr-initiate-proxy.controller.js +1 -1
  101. package/dist/server/modules/cloud/controllers/qr-initiate-proxy.controller.js.map +1 -1
  102. package/dist/server/modules/cloud/controllers/store-tokens-error.d.ts +4 -0
  103. package/dist/server/modules/cloud/controllers/store-tokens-error.js +103 -0
  104. package/dist/server/modules/cloud/controllers/store-tokens-error.js.map +1 -0
  105. package/dist/server/modules/cloud/services/cloud-session-manager.service.js +18 -8
  106. package/dist/server/modules/cloud/services/cloud-session-manager.service.js.map +1 -1
  107. package/dist/server/modules/cloud/services/egress-queue.service.js +2 -2
  108. package/dist/server/modules/cloud/services/egress-queue.service.js.map +1 -1
  109. package/dist/server/modules/cloud/services/event-mapper.service.d.ts +9 -1
  110. package/dist/server/modules/cloud/services/event-mapper.service.js +18 -2
  111. package/dist/server/modules/cloud/services/event-mapper.service.js.map +1 -1
  112. package/dist/server/modules/cloud/services/project-activity-reporter.service.js +1 -1
  113. package/dist/server/modules/cloud/services/project-activity-reporter.service.js.map +1 -1
  114. package/dist/server/modules/cloud-tunnel/cloud-tunnel.module.js +57 -2
  115. package/dist/server/modules/cloud-tunnel/cloud-tunnel.module.js.map +1 -1
  116. package/dist/server/modules/cloud-tunnel/services/ask-user-question-push-gate.service.d.ts +20 -0
  117. package/dist/server/modules/cloud-tunnel/services/ask-user-question-push-gate.service.js +84 -0
  118. package/dist/server/modules/cloud-tunnel/services/ask-user-question-push-gate.service.js.map +1 -0
  119. package/dist/server/modules/cloud-tunnel/services/epic-dto.util.d.ts +3 -0
  120. package/dist/server/modules/cloud-tunnel/services/epic-dto.util.js +43 -0
  121. package/dist/server/modules/cloud-tunnel/services/epic-dto.util.js.map +1 -0
  122. package/dist/server/modules/cloud-tunnel/services/jsonrpc-error.util.d.ts +11 -0
  123. package/dist/server/modules/cloud-tunnel/services/jsonrpc-error.util.js +32 -0
  124. package/dist/server/modules/cloud-tunnel/services/jsonrpc-error.util.js.map +1 -0
  125. package/dist/server/modules/cloud-tunnel/services/lifecycle-operation-tracker.d.ts +30 -0
  126. package/dist/server/modules/cloud-tunnel/services/lifecycle-operation-tracker.js +80 -0
  127. package/dist/server/modules/cloud-tunnel/services/lifecycle-operation-tracker.js.map +1 -0
  128. package/dist/server/modules/cloud-tunnel/services/mobile-board-rpc.service.d.ts +16 -0
  129. package/dist/server/modules/cloud-tunnel/services/mobile-board-rpc.service.js +78 -0
  130. package/dist/server/modules/cloud-tunnel/services/mobile-board-rpc.service.js.map +1 -0
  131. package/dist/server/modules/cloud-tunnel/services/mobile-chat-rpc.service.d.ts +112 -0
  132. package/dist/server/modules/cloud-tunnel/services/mobile-chat-rpc.service.js +457 -0
  133. package/dist/server/modules/cloud-tunnel/services/mobile-chat-rpc.service.js.map +1 -0
  134. package/dist/server/modules/cloud-tunnel/services/tunnel-client.service.d.ts +28 -2
  135. package/dist/server/modules/cloud-tunnel/services/tunnel-client.service.js +143 -5
  136. package/dist/server/modules/cloud-tunnel/services/tunnel-client.service.js.map +1 -1
  137. package/dist/server/modules/cloud-tunnel/services/tunnel-event-forwarder.service.d.ts +21 -0
  138. package/dist/server/modules/cloud-tunnel/services/tunnel-event-forwarder.service.js +171 -0
  139. package/dist/server/modules/cloud-tunnel/services/tunnel-event-forwarder.service.js.map +1 -0
  140. package/dist/server/modules/cloud-tunnel/services/tunnel-handler.service.d.ts +9 -4
  141. package/dist/server/modules/cloud-tunnel/services/tunnel-handler.service.js +194 -52
  142. package/dist/server/modules/cloud-tunnel/services/tunnel-handler.service.js.map +1 -1
  143. package/dist/server/modules/cloud-tunnel/services/tunnel-push-crypto.service.d.ts +21 -0
  144. package/dist/server/modules/cloud-tunnel/services/tunnel-push-crypto.service.js +117 -0
  145. package/dist/server/modules/cloud-tunnel/services/tunnel-push-crypto.service.js.map +1 -0
  146. package/dist/server/modules/cloud-tunnel/services/tunnel-rpc-crypto.service.d.ts +41 -0
  147. package/dist/server/modules/cloud-tunnel/services/tunnel-rpc-crypto.service.js +116 -0
  148. package/dist/server/modules/cloud-tunnel/services/tunnel-rpc-crypto.service.js.map +1 -0
  149. package/dist/server/modules/cloud-tunnel/services/tunnel-viewport-crypto.service.d.ts +20 -0
  150. package/dist/server/modules/cloud-tunnel/services/tunnel-viewport-crypto.service.js +114 -0
  151. package/dist/server/modules/cloud-tunnel/services/tunnel-viewport-crypto.service.js.map +1 -0
  152. package/dist/server/modules/cloud-tunnel/services/viewport-frame-sink.d.ts +6 -0
  153. package/dist/server/modules/cloud-tunnel/services/viewport-frame-sink.js +7 -0
  154. package/dist/server/modules/cloud-tunnel/services/viewport-frame-sink.js.map +1 -0
  155. package/dist/server/modules/cloud-tunnel/services/viewport-streamer.service.d.ts +30 -0
  156. package/dist/server/modules/cloud-tunnel/services/viewport-streamer.service.js +228 -0
  157. package/dist/server/modules/cloud-tunnel/services/viewport-streamer.service.js.map +1 -0
  158. package/dist/server/modules/e2ee/controllers/e2ee-pairing.controller.d.ts +18 -0
  159. package/dist/server/modules/e2ee/controllers/e2ee-pairing.controller.js +62 -0
  160. package/dist/server/modules/e2ee/controllers/e2ee-pairing.controller.js.map +1 -0
  161. package/dist/server/modules/e2ee/controllers/e2ee-trust.controller.d.ts +19 -0
  162. package/dist/server/modules/e2ee/controllers/e2ee-trust.controller.js +85 -0
  163. package/dist/server/modules/e2ee/controllers/e2ee-trust.controller.js.map +1 -0
  164. package/dist/server/modules/e2ee/e2ee.module.d.ts +2 -0
  165. package/dist/server/modules/e2ee/e2ee.module.js +27 -0
  166. package/dist/server/modules/e2ee/e2ee.module.js.map +1 -0
  167. package/dist/server/modules/e2ee/services/e2ee-device-store.service.d.ts +29 -0
  168. package/dist/server/modules/e2ee/services/e2ee-device-store.service.js +138 -0
  169. package/dist/server/modules/e2ee/services/e2ee-device-store.service.js.map +1 -0
  170. package/dist/server/modules/e2ee/services/e2ee-keypair.service.d.ts +21 -0
  171. package/dist/server/modules/e2ee/services/e2ee-keypair.service.js +152 -0
  172. package/dist/server/modules/e2ee/services/e2ee-keypair.service.js.map +1 -0
  173. package/dist/server/modules/e2ee/services/e2ee-pairing.service.d.ts +28 -0
  174. package/dist/server/modules/e2ee/services/e2ee-pairing.service.js +107 -0
  175. package/dist/server/modules/e2ee/services/e2ee-pairing.service.js.map +1 -0
  176. package/dist/server/modules/e2ee/services/e2ee-trust.service.d.ts +36 -0
  177. package/dist/server/modules/e2ee/services/e2ee-trust.service.js +118 -0
  178. package/dist/server/modules/e2ee/services/e2ee-trust.service.js.map +1 -0
  179. package/dist/server/modules/epics/services/epics.service.d.ts +1 -0
  180. package/dist/server/modules/epics/services/epics.service.js +10 -0
  181. package/dist/server/modules/epics/services/epics.service.js.map +1 -1
  182. package/dist/server/modules/events/catalog/broadcast-metadata.d.ts +6 -2
  183. package/dist/server/modules/events/catalog/broadcast-registry.d.ts +2 -2
  184. package/dist/server/modules/events/catalog/broadcast-registry.js +58 -1
  185. package/dist/server/modules/events/catalog/broadcast-registry.js.map +1 -1
  186. package/dist/server/modules/events/catalog/claude.hooks.ask_user_question.pending.d.ts +122 -0
  187. package/dist/server/modules/events/catalog/claude.hooks.ask_user_question.pending.js +28 -0
  188. package/dist/server/modules/events/catalog/claude.hooks.ask_user_question.pending.js.map +1 -0
  189. package/dist/server/modules/events/catalog/claude.hooks.ask_user_question.resolved.d.ts +18 -0
  190. package/dist/server/modules/events/catalog/claude.hooks.ask_user_question.resolved.js +13 -0
  191. package/dist/server/modules/events/catalog/claude.hooks.ask_user_question.resolved.js.map +1 -0
  192. package/dist/server/modules/events/catalog/index.d.ts +90 -0
  193. package/dist/server/modules/events/catalog/index.js +4 -0
  194. package/dist/server/modules/events/catalog/index.js.map +1 -1
  195. package/dist/server/modules/events/catalog/project-broadcast.d.ts +7 -0
  196. package/dist/server/modules/events/catalog/project-broadcast.js +10 -0
  197. package/dist/server/modules/events/catalog/project-broadcast.js.map +1 -0
  198. package/dist/server/modules/events/catalog/session.transcript.discovered.d.ts +3 -0
  199. package/dist/server/modules/events/catalog/session.transcript.discovered.js +1 -0
  200. package/dist/server/modules/events/catalog/session.transcript.discovered.js.map +1 -1
  201. package/dist/server/modules/events/services/catalog-broadcaster.service.js +3 -4
  202. package/dist/server/modules/events/services/catalog-broadcaster.service.js.map +1 -1
  203. package/dist/server/modules/hooks/dtos/ask-user-question.dto.d.ts +5 -0
  204. package/dist/server/modules/hooks/dtos/ask-user-question.dto.js +51 -0
  205. package/dist/server/modules/hooks/dtos/ask-user-question.dto.js.map +1 -0
  206. package/dist/server/modules/hooks/dtos/hook-event.dto.d.ts +206 -5
  207. package/dist/server/modules/hooks/dtos/hook-event.dto.js +40 -8
  208. package/dist/server/modules/hooks/dtos/hook-event.dto.js.map +1 -1
  209. package/dist/server/modules/hooks/hooks.module.js +3 -2
  210. package/dist/server/modules/hooks/hooks.module.js.map +1 -1
  211. package/dist/server/modules/hooks/services/hooks-config.service.d.ts +1 -0
  212. package/dist/server/modules/hooks/services/hooks-config.service.js +52 -33
  213. package/dist/server/modules/hooks/services/hooks-config.service.js.map +1 -1
  214. package/dist/server/modules/hooks/services/hooks.service.d.ts +5 -1
  215. package/dist/server/modules/hooks/services/hooks.service.js +68 -2
  216. package/dist/server/modules/hooks/services/hooks.service.js.map +1 -1
  217. package/dist/server/modules/hooks/services/pending-ask-user-question.service.d.ts +38 -0
  218. package/dist/server/modules/hooks/services/pending-ask-user-question.service.js +105 -0
  219. package/dist/server/modules/hooks/services/pending-ask-user-question.service.js.map +1 -0
  220. package/dist/server/modules/orchestrator/worktrees/services/worktrees.service.js +3 -0
  221. package/dist/server/modules/orchestrator/worktrees/services/worktrees.service.js.map +1 -1
  222. package/dist/server/modules/projects/controllers/projects.controller.d.ts +7 -0
  223. package/dist/server/modules/projects/dtos/export.dto.d.ts +8 -0
  224. package/dist/server/modules/projects/dtos/export.dto.js +1 -0
  225. package/dist/server/modules/projects/dtos/export.dto.js.map +1 -1
  226. package/dist/server/modules/projects/helpers/project-export.d.ts +1 -0
  227. package/dist/server/modules/projects/helpers/project-export.js +19 -5
  228. package/dist/server/modules/projects/helpers/project-export.js.map +1 -1
  229. package/dist/server/modules/projects/helpers/project-import-sessions.d.ts +11 -0
  230. package/dist/server/modules/projects/helpers/project-import-sessions.js +47 -0
  231. package/dist/server/modules/projects/helpers/project-import-sessions.js.map +1 -0
  232. package/dist/server/modules/projects/helpers/project-import.d.ts +4 -0
  233. package/dist/server/modules/projects/helpers/project-import.js +12 -2
  234. package/dist/server/modules/projects/helpers/project-import.js.map +1 -1
  235. package/dist/server/modules/projects/services/projects.service.d.ts +5 -0
  236. package/dist/server/modules/providers/adapters/claude.adapter.d.ts +1 -0
  237. package/dist/server/modules/providers/adapters/claude.adapter.js +1 -0
  238. package/dist/server/modules/providers/adapters/claude.adapter.js.map +1 -1
  239. package/dist/server/modules/providers/adapters/opencode.adapter.d.ts +4 -1
  240. package/dist/server/modules/providers/adapters/opencode.adapter.js +3 -0
  241. package/dist/server/modules/providers/adapters/opencode.adapter.js.map +1 -1
  242. package/dist/server/modules/providers/adapters/provider-adapter.interface.d.ts +2 -0
  243. package/dist/server/modules/providers/controllers/providers.controller.d.ts +50 -3
  244. package/dist/server/modules/providers/controllers/providers.controller.js +12 -3
  245. package/dist/server/modules/providers/controllers/providers.controller.js.map +1 -1
  246. package/dist/server/modules/providers/services/provider-state-manager.service.d.ts +2 -1
  247. package/dist/server/modules/providers/services/provider-state-manager.service.js +43 -1
  248. package/dist/server/modules/providers/services/provider-state-manager.service.js.map +1 -1
  249. package/dist/server/modules/registry/controllers/templates.controller.d.ts +2 -1
  250. package/dist/server/modules/registry/services/template-cache.service.d.ts +2 -0
  251. package/dist/server/modules/registry/services/template-cache.service.js +5 -0
  252. package/dist/server/modules/registry/services/template-cache.service.js.map +1 -1
  253. package/dist/server/modules/registry/services/unified-template.service.d.ts +1 -0
  254. package/dist/server/modules/registry/services/unified-template.service.js +9 -1
  255. package/dist/server/modules/registry/services/unified-template.service.js.map +1 -1
  256. package/dist/server/modules/session-reader/__fixtures__/opencode-fixture-db.d.ts +44 -0
  257. package/dist/server/modules/session-reader/__fixtures__/opencode-fixture-db.js +85 -0
  258. package/dist/server/modules/session-reader/__fixtures__/opencode-fixture-db.js.map +1 -0
  259. package/dist/server/modules/session-reader/adapters/opencode-session-reader.adapter.d.ts +23 -0
  260. package/dist/server/modules/session-reader/adapters/opencode-session-reader.adapter.js +150 -0
  261. package/dist/server/modules/session-reader/adapters/opencode-session-reader.adapter.js.map +1 -0
  262. package/dist/server/modules/session-reader/adapters/session-reader-adapter.interface.d.ts +16 -2
  263. package/dist/server/modules/session-reader/adapters/session-reader-adapter.interface.js +39 -0
  264. package/dist/server/modules/session-reader/adapters/session-reader-adapter.interface.js.map +1 -1
  265. package/dist/server/modules/session-reader/adapters/utils/coalesce-turns.d.ts +11 -0
  266. package/dist/server/modules/session-reader/adapters/utils/coalesce-turns.js +81 -0
  267. package/dist/server/modules/session-reader/adapters/utils/coalesce-turns.js.map +1 -0
  268. package/dist/server/modules/session-reader/adapters/utils/tool-result-fold.d.ts +2 -0
  269. package/dist/server/modules/session-reader/adapters/utils/tool-result-fold.js +9 -0
  270. package/dist/server/modules/session-reader/adapters/utils/tool-result-fold.js.map +1 -0
  271. package/dist/server/modules/session-reader/builders/chunk-builder.js +0 -2
  272. package/dist/server/modules/session-reader/builders/chunk-builder.js.map +1 -1
  273. package/dist/server/modules/session-reader/builders/semantic-step-extractor.js +2 -0
  274. package/dist/server/modules/session-reader/builders/semantic-step-extractor.js.map +1 -1
  275. package/dist/server/modules/session-reader/controllers/session-reader.controller.d.ts +1 -0
  276. package/dist/server/modules/session-reader/data/pricing.json +387 -34
  277. package/dist/server/modules/session-reader/dtos/unified-message.types.d.ts +1 -0
  278. package/dist/server/modules/session-reader/dtos/unified-session.types.js.map +1 -1
  279. package/dist/server/modules/session-reader/parsers/claude-jsonl.parser.js +46 -0
  280. package/dist/server/modules/session-reader/parsers/claude-jsonl.parser.js.map +1 -1
  281. package/dist/server/modules/session-reader/parsers/codex-jsonl.parser.js +35 -17
  282. package/dist/server/modules/session-reader/parsers/codex-jsonl.parser.js.map +1 -1
  283. package/dist/server/modules/session-reader/readers/opencode-sqlite.reader.d.ts +69 -0
  284. package/dist/server/modules/session-reader/readers/opencode-sqlite.reader.js +378 -0
  285. package/dist/server/modules/session-reader/readers/opencode-sqlite.reader.js.map +1 -0
  286. package/dist/server/modules/session-reader/services/session-cache.service.d.ts +12 -3
  287. package/dist/server/modules/session-reader/services/session-cache.service.js +104 -19
  288. package/dist/server/modules/session-reader/services/session-cache.service.js.map +1 -1
  289. package/dist/server/modules/session-reader/services/session-reader.service.d.ts +5 -0
  290. package/dist/server/modules/session-reader/services/session-reader.service.js +51 -16
  291. package/dist/server/modules/session-reader/services/session-reader.service.js.map +1 -1
  292. package/dist/server/modules/session-reader/services/transcript-path-validator.service.js +1 -0
  293. package/dist/server/modules/session-reader/services/transcript-path-validator.service.js.map +1 -1
  294. package/dist/server/modules/session-reader/services/transcript-persistence.listener.d.ts +3 -0
  295. package/dist/server/modules/session-reader/services/transcript-persistence.listener.js +70 -1
  296. package/dist/server/modules/session-reader/services/transcript-persistence.listener.js.map +1 -1
  297. package/dist/server/modules/session-reader/services/transcript-watcher-rehydrator.service.d.ts +10 -0
  298. package/dist/server/modules/session-reader/services/transcript-watcher-rehydrator.service.js +47 -0
  299. package/dist/server/modules/session-reader/services/transcript-watcher-rehydrator.service.js.map +1 -0
  300. package/dist/server/modules/session-reader/services/transcript-watcher.service.d.ts +7 -1
  301. package/dist/server/modules/session-reader/services/transcript-watcher.service.js +177 -28
  302. package/dist/server/modules/session-reader/services/transcript-watcher.service.js.map +1 -1
  303. package/dist/server/modules/session-reader/session-reader.module.d.ts +3 -1
  304. package/dist/server/modules/session-reader/session-reader.module.js +10 -2
  305. package/dist/server/modules/session-reader/session-reader.module.js.map +1 -1
  306. package/dist/server/modules/sessions/controllers/sessions.controller.js +2 -22
  307. package/dist/server/modules/sessions/controllers/sessions.controller.js.map +1 -1
  308. package/dist/server/modules/sessions/dtos/sessions.dto.d.ts +1 -0
  309. package/dist/server/modules/sessions/dtos/sessions.dto.js.map +1 -1
  310. package/dist/server/modules/sessions/services/active-session-lookup.service.d.ts +5 -0
  311. package/dist/server/modules/sessions/services/active-session-lookup.service.js +12 -0
  312. package/dist/server/modules/sessions/services/active-session-lookup.service.js.map +1 -1
  313. package/dist/server/modules/sessions/services/message-enqueue.service.d.ts +2 -0
  314. package/dist/server/modules/sessions/services/message-enqueue.service.js +2 -0
  315. package/dist/server/modules/sessions/services/message-enqueue.service.js.map +1 -1
  316. package/dist/server/modules/sessions/services/message-pool.types.d.ts +2 -0
  317. package/dist/server/modules/sessions/services/provider-launch-config/provider-launch-config.service.js +1 -1
  318. package/dist/server/modules/sessions/services/provider-launch-config/provider-launch-config.service.js.map +1 -1
  319. package/dist/server/modules/sessions/services/session-lifecycle-facade.service.d.ts +18 -0
  320. package/dist/server/modules/sessions/services/session-lifecycle-facade.service.js +74 -0
  321. package/dist/server/modules/sessions/services/session-lifecycle-facade.service.js.map +1 -0
  322. package/dist/server/modules/sessions/services/session-runtime/__test-utils__/pipeline-harness.d.ts +4 -2
  323. package/dist/server/modules/sessions/services/session-runtime/__test-utils__/pipeline-harness.js +4 -2
  324. package/dist/server/modules/sessions/services/session-runtime/__test-utils__/pipeline-harness.js.map +1 -1
  325. package/dist/server/modules/sessions/services/session-runtime/session-launch-pipeline.service.js +2 -2
  326. package/dist/server/modules/sessions/services/session-runtime/session-launch-pipeline.service.js.map +1 -1
  327. package/dist/server/modules/sessions/services/session-runtime/session-restore-pipeline.service.js +2 -2
  328. package/dist/server/modules/sessions/services/session-runtime/session-restore-pipeline.service.js.map +1 -1
  329. package/dist/server/modules/sessions/services/sessions-message-pool.service.js +15 -3
  330. package/dist/server/modules/sessions/services/sessions-message-pool.service.js.map +1 -1
  331. package/dist/server/modules/sessions/services/sessions.service.d.ts +8 -0
  332. package/dist/server/modules/sessions/services/sessions.service.js +52 -1
  333. package/dist/server/modules/sessions/services/sessions.service.js.map +1 -1
  334. package/dist/server/modules/sessions/sessions-lifecycle.module.d.ts +2 -0
  335. package/dist/server/modules/sessions/sessions-lifecycle.module.js +23 -0
  336. package/dist/server/modules/sessions/sessions-lifecycle.module.js.map +1 -0
  337. package/dist/server/modules/settings/local/delegates/core-settings.delegate.js.map +1 -1
  338. package/dist/server/modules/settings/local/delegates/preset-settings.delegate.d.ts +1 -0
  339. package/dist/server/modules/settings/local/delegates/preset-settings.delegate.js +36 -0
  340. package/dist/server/modules/settings/local/delegates/preset-settings.delegate.js.map +1 -1
  341. package/dist/server/modules/settings/services/settings.service.d.ts +1 -0
  342. package/dist/server/modules/settings/services/settings.service.js +3 -0
  343. package/dist/server/modules/settings/services/settings.service.js.map +1 -1
  344. package/dist/server/modules/storage/db/schema.d.ts +83 -0
  345. package/dist/server/modules/storage/db/schema.js +15 -2
  346. package/dist/server/modules/storage/db/schema.js.map +1 -1
  347. package/dist/server/modules/storage/interfaces/storage.interface.d.ts +13 -2
  348. package/dist/server/modules/storage/interfaces/storage.interface.js.map +1 -1
  349. package/dist/server/modules/storage/local/delegates/epic.delegate.d.ts +1 -0
  350. package/dist/server/modules/storage/local/delegates/epic.delegate.js +8 -0
  351. package/dist/server/modules/storage/local/delegates/epic.delegate.js.map +1 -1
  352. package/dist/server/modules/storage/local/delegates/provider.delegate.d.ts +5 -1
  353. package/dist/server/modules/storage/local/delegates/provider.delegate.js +122 -0
  354. package/dist/server/modules/storage/local/delegates/provider.delegate.js.map +1 -1
  355. package/dist/server/modules/storage/local/delegates/session.delegate.d.ts +9 -0
  356. package/dist/server/modules/storage/local/delegates/session.delegate.js +115 -0
  357. package/dist/server/modules/storage/local/delegates/session.delegate.js.map +1 -0
  358. package/dist/server/modules/storage/local/local-storage.service.d.ts +10 -0
  359. package/dist/server/modules/storage/local/local-storage.service.js +20 -0
  360. package/dist/server/modules/storage/local/local-storage.service.js.map +1 -1
  361. package/dist/server/modules/storage/models/domain.models.d.ts +1 -0
  362. package/dist/server/modules/subscribers/services/automation-scheduler.service.js.map +1 -1
  363. package/dist/server/modules/teams/services/teams.service.d.ts +31 -3
  364. package/dist/server/modules/teams/services/teams.service.js +193 -2
  365. package/dist/server/modules/teams/services/teams.service.js.map +1 -1
  366. package/dist/server/modules/teams/storage/teams.store.d.ts +5 -0
  367. package/dist/server/modules/teams/storage/teams.store.js +34 -0
  368. package/dist/server/modules/teams/storage/teams.store.js.map +1 -1
  369. package/dist/server/modules/teams/teams.module.js +2 -1
  370. package/dist/server/modules/teams/teams.module.js.map +1 -1
  371. package/dist/server/modules/terminal/gateways/terminal.gateway.d.ts +5 -0
  372. package/dist/server/modules/terminal/gateways/terminal.gateway.js +45 -7
  373. package/dist/server/modules/terminal/gateways/terminal.gateway.js.map +1 -1
  374. package/dist/server/modules/terminal/services/pty.service.js +11 -3
  375. package/dist/server/modules/terminal/services/pty.service.js.map +1 -1
  376. package/dist/server/modules/terminal/services/terminal-io/terminal-io.service.d.ts +1 -1
  377. package/dist/server/modules/terminal/services/terminal-io/terminal-io.service.js +9 -2
  378. package/dist/server/modules/terminal/services/terminal-io/terminal-io.service.js.map +1 -1
  379. package/dist/server/modules/terminal/services/terminal-io/viewport-capture.d.ts +12 -0
  380. package/dist/server/modules/terminal/services/terminal-io/viewport-capture.js +50 -0
  381. package/dist/server/modules/terminal/services/terminal-io/viewport-capture.js.map +1 -0
  382. package/dist/server/modules/terminal/services/terminal-seed.service.js +1 -1
  383. package/dist/server/modules/terminal/services/terminal-seed.service.js.map +1 -1
  384. package/dist/server/modules/terminal/services/terminal-session/terminal-session.d.ts +9 -0
  385. package/dist/server/modules/terminal/services/terminal-session/terminal-session.js +24 -7
  386. package/dist/server/modules/terminal/services/terminal-session/terminal-session.js.map +1 -1
  387. package/dist/server/modules/terminal/services/terminal-viewport/terminal-viewport.facade.d.ts +12 -0
  388. package/dist/server/modules/terminal/services/terminal-viewport/terminal-viewport.facade.js +55 -0
  389. package/dist/server/modules/terminal/services/terminal-viewport/terminal-viewport.facade.js.map +1 -0
  390. package/dist/server/modules/terminal/terminal-viewport.module.d.ts +2 -0
  391. package/dist/server/modules/terminal/terminal-viewport.module.js +24 -0
  392. package/dist/server/modules/terminal/terminal-viewport.module.js.map +1 -0
  393. package/dist/server/modules/terminal/utils/normalize-line-endings.d.ts +1 -0
  394. package/dist/server/modules/terminal/utils/normalize-line-endings.js +8 -0
  395. package/dist/server/modules/terminal/utils/normalize-line-endings.js.map +1 -1
  396. package/dist/server/templates/3-agents-dev.json +33 -28
  397. package/dist/server/templates/teams-dev.json +189 -261
  398. package/dist/server/tsconfig.tsbuildinfo +1 -1
  399. package/dist/server/ui/assets/{ReviewDetailPage-C_XRFo7X.js → ReviewDetailPage-BpPjTAgL.js} +1 -1
  400. package/dist/server/ui/assets/{ReviewsPage-DUxJp7iE.js → ReviewsPage-CAs14WVx.js} +1 -1
  401. package/dist/server/ui/assets/index-CzMrWNAV.css +32 -0
  402. package/dist/server/ui/assets/index-DhGz-UAr.js +1100 -0
  403. package/dist/server/ui/assets/{useReviewSubscription-DJzltHrV.js → useReviewSubscription-CscSQD7B.js} +1 -1
  404. package/dist/server/ui/favicon.svg +2 -16
  405. package/dist/server/ui/index.html +2 -2
  406. package/dist/templates/3-agents-dev.json +33 -28
  407. package/dist/templates/teams-dev.json +189 -261
  408. package/package.json +28 -8
  409. package/dist/server/ui/assets/index-C_ZOt0it.css +0 -32
  410. package/dist/server/ui/assets/index-DS51wECY.js +0 -1095
@@ -8,18 +8,73 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
8
8
  Object.defineProperty(exports, "__esModule", { value: true });
9
9
  exports.CloudTunnelModule = void 0;
10
10
  const common_1 = require("@nestjs/common");
11
+ const core_1 = require("@nestjs/core");
11
12
  const cloud_module_1 = require("../cloud/cloud.module");
12
13
  const storage_module_1 = require("../storage/storage.module");
14
+ const sessions_read_module_1 = require("../sessions/sessions-read.module");
15
+ const sessions_lifecycle_module_1 = require("../sessions/sessions-lifecycle.module");
16
+ const session_reader_module_1 = require("../session-reader/session-reader.module");
17
+ const agent_message_delivery_module_1 = require("../agent-message-delivery/agent-message-delivery.module");
18
+ const teams_module_1 = require("../teams/teams.module");
19
+ const epics_module_1 = require("../epics/epics.module");
20
+ const hooks_module_1 = require("../hooks/hooks.module");
21
+ const terminal_viewport_module_1 = require("../terminal/terminal-viewport.module");
22
+ const e2ee_module_1 = require("../e2ee/e2ee.module");
13
23
  const tunnel_keypair_service_1 = require("./services/tunnel-keypair.service");
14
24
  const tunnel_handler_service_1 = require("./services/tunnel-handler.service");
25
+ const tunnel_rpc_crypto_service_1 = require("./services/tunnel-rpc-crypto.service");
26
+ const tunnel_push_crypto_service_1 = require("./services/tunnel-push-crypto.service");
27
+ const tunnel_viewport_crypto_service_1 = require("./services/tunnel-viewport-crypto.service");
15
28
  const tunnel_client_service_1 = require("./services/tunnel-client.service");
29
+ const tunnel_event_forwarder_service_1 = require("./services/tunnel-event-forwarder.service");
30
+ const ask_user_question_push_gate_service_1 = require("./services/ask-user-question-push-gate.service");
31
+ const mobile_chat_rpc_service_1 = require("./services/mobile-chat-rpc.service");
32
+ const mobile_board_rpc_service_1 = require("./services/mobile-board-rpc.service");
33
+ const lifecycle_operation_tracker_1 = require("./services/lifecycle-operation-tracker");
34
+ const viewport_streamer_service_1 = require("./services/viewport-streamer.service");
35
+ const viewport_frame_sink_1 = require("./services/viewport-frame-sink");
16
36
  let CloudTunnelModule = class CloudTunnelModule {
17
37
  };
18
38
  exports.CloudTunnelModule = CloudTunnelModule;
19
39
  exports.CloudTunnelModule = CloudTunnelModule = __decorate([
20
40
  (0, common_1.Module)({
21
- imports: [cloud_module_1.CloudModule, storage_module_1.StorageModule],
22
- providers: [tunnel_keypair_service_1.TunnelKeypairService, tunnel_handler_service_1.TunnelHandlerService, tunnel_client_service_1.TunnelClientService],
41
+ imports: [
42
+ cloud_module_1.CloudModule,
43
+ storage_module_1.StorageModule,
44
+ sessions_read_module_1.SessionsReadModule,
45
+ sessions_lifecycle_module_1.SessionsLifecycleModule,
46
+ session_reader_module_1.SessionReaderModule,
47
+ agent_message_delivery_module_1.AgentMessageDeliveryModule,
48
+ teams_module_1.TeamsModule,
49
+ epics_module_1.EpicsModule,
50
+ hooks_module_1.HooksModule,
51
+ terminal_viewport_module_1.TerminalViewportModule,
52
+ e2ee_module_1.E2eeModule,
53
+ ],
54
+ providers: [
55
+ tunnel_keypair_service_1.TunnelKeypairService,
56
+ tunnel_handler_service_1.TunnelHandlerService,
57
+ tunnel_rpc_crypto_service_1.TunnelRpcCryptoService,
58
+ tunnel_push_crypto_service_1.TunnelPushCryptoService,
59
+ tunnel_viewport_crypto_service_1.TunnelViewportCryptoService,
60
+ { provide: tunnel_rpc_crypto_service_1.E2EE_REQUIRED_POLICY, useFactory: () => process.env.E2EE_REQUIRED === 'true' },
61
+ tunnel_client_service_1.TunnelClientService,
62
+ tunnel_event_forwarder_service_1.TunnelEventForwarderService,
63
+ ask_user_question_push_gate_service_1.AskUserQuestionPushGateService,
64
+ mobile_chat_rpc_service_1.MobileChatRpcService,
65
+ mobile_board_rpc_service_1.MobileBoardRpcService,
66
+ lifecycle_operation_tracker_1.LifecycleOperationTracker,
67
+ viewport_streamer_service_1.ViewportStreamerService,
68
+ {
69
+ provide: viewport_frame_sink_1.ViewportFrameSink,
70
+ useFactory: (moduleRef) => ({
71
+ sendViewport: (frame) => moduleRef.get(tunnel_client_service_1.TunnelClientService, { strict: false }).sendViewport(frame),
72
+ onPushReady: (listener) => moduleRef.get(tunnel_client_service_1.TunnelClientService, { strict: false }).onPushReady(listener),
73
+ getInstanceId: () => moduleRef.get(tunnel_client_service_1.TunnelClientService, { strict: false }).getInstanceId(),
74
+ }),
75
+ inject: [core_1.ModuleRef],
76
+ },
77
+ ],
23
78
  })
24
79
  ], CloudTunnelModule);
25
80
  //# sourceMappingURL=cloud-tunnel.module.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"cloud-tunnel.module.js","sourceRoot":"","sources":["../../../src/modules/cloud-tunnel/cloud-tunnel.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,wDAAoD;AACpD,8DAA0D;AAC1D,8EAAyE;AACzE,8EAAyE;AACzE,4EAAuE;AAMhE,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;CAAG,CAAA;AAApB,8CAAiB;4BAAjB,iBAAiB;IAJ7B,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,0BAAW,EAAE,8BAAa,CAAC;QACrC,SAAS,EAAE,CAAC,6CAAoB,EAAE,6CAAoB,EAAE,2CAAmB,CAAC;KAC7E,CAAC;GACW,iBAAiB,CAAG"}
1
+ {"version":3,"file":"cloud-tunnel.module.js","sourceRoot":"","sources":["../../../src/modules/cloud-tunnel/cloud-tunnel.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,uCAAyC;AACzC,wDAAoD;AACpD,8DAA0D;AAC1D,2EAAsE;AACtE,qFAAgF;AAChF,mFAA8E;AAC9E,2GAAqG;AACrG,wDAAoD;AACpD,wDAAoD;AACpD,wDAAoD;AACpD,mFAA8E;AAC9E,qDAAiD;AACjD,8EAAyE;AACzE,8EAAyE;AACzE,oFAAoG;AACpG,sFAAgF;AAChF,8FAAwF;AACxF,4EAAuE;AACvE,8FAAwF;AACxF,wGAAgG;AAChG,gFAA0E;AAC1E,kFAA4E;AAC5E,wFAAmF;AACnF,oFAA+E;AAC/E,wEAAmE;AAgF5D,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;CAAG,CAAA;AAApB,8CAAiB;4BAAjB,iBAAiB;IA9E7B,IAAA,eAAM,EAAC;QASN,OAAO,EAAE;YACP,0BAAW;YACX,8BAAa;YACb,yCAAkB;YAClB,mDAAuB;YACvB,2CAAmB;YACnB,0DAA0B;YAC1B,0BAAW;YAIX,0BAAW;YAMX,0BAAW;YAIX,iDAAsB;YAItB,wBAAU;SACX;QACD,SAAS,EAAE;YACT,6CAAoB;YACpB,6CAAoB;YAGpB,kDAAsB;YAItB,oDAAuB;YAGvB,4DAA2B;YAI3B,EAAE,OAAO,EAAE,gDAAoB,EAAE,UAAU,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,aAAa,KAAK,MAAM,EAAE;YACzF,2CAAmB;YACnB,4DAA2B;YAC3B,oEAA8B;YAC9B,8CAAoB;YACpB,gDAAqB;YACrB,uDAAyB;YACzB,mDAAuB;YAMvB;gBACE,OAAO,EAAE,uCAAiB;gBAC1B,UAAU,EAAE,CAAC,SAAoB,EAAqB,EAAE,CAAC,CAAC;oBACxD,YAAY,EAAE,CAAC,KAAK,EAAE,EAAE,CACtB,SAAS,CAAC,GAAG,CAAC,2CAAmB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC;oBAC3E,WAAW,EAAE,CAAC,QAAQ,EAAE,EAAE,CACxB,SAAS,CAAC,GAAG,CAAC,2CAAmB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,WAAW,CAAC,QAAQ,CAAC;oBAC7E,aAAa,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,2CAAmB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,aAAa,EAAE;iBAC3F,CAAC;gBACF,MAAM,EAAE,CAAC,gBAAS,CAAC;aACpB;SACF;KACF,CAAC;GACW,iBAAiB,CAAG"}
@@ -0,0 +1,20 @@
1
+ import { OnModuleDestroy } from '@nestjs/common';
2
+ import { CloudSessionManagerService } from '../../cloud/services/cloud-session-manager.service';
3
+ import { EgressQueueService } from '../../cloud/services/egress-queue.service';
4
+ import { EventMapperService } from '../../cloud/services/event-mapper.service';
5
+ import { ProjectEgressConfigService } from '../../cloud/services/project-egress-config.service';
6
+ import type { ClaudeHooksAskUserQuestionPendingEventPayload } from '../../events/catalog/claude.hooks.ask_user_question.pending';
7
+ import { TunnelClientService } from './tunnel-client.service';
8
+ export declare const AUQ_NATIVE_PUSH_GRACE_MS = 12000;
9
+ export declare class AskUserQuestionPushGateService implements OnModuleDestroy {
10
+ private readonly cloudSession;
11
+ private readonly egressQueue;
12
+ private readonly eventMapper;
13
+ private readonly projectConfig;
14
+ private readonly tunnelClient;
15
+ private readonly pendingTimers;
16
+ constructor(cloudSession: CloudSessionManagerService, egressQueue: EgressQueueService, eventMapper: EventMapperService, projectConfig: ProjectEgressConfigService, tunnelClient: TunnelClientService);
17
+ onPending(payload: ClaudeHooksAskUserQuestionPendingEventPayload): Promise<void>;
18
+ private decide;
19
+ onModuleDestroy(): void;
20
+ }
@@ -0,0 +1,84 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.AskUserQuestionPushGateService = exports.AUQ_NATIVE_PUSH_GRACE_MS = void 0;
13
+ const common_1 = require("@nestjs/common");
14
+ const event_emitter_1 = require("@nestjs/event-emitter");
15
+ const logger_1 = require("../../../common/logging/logger");
16
+ const cloud_session_manager_service_1 = require("../../cloud/services/cloud-session-manager.service");
17
+ const egress_queue_service_1 = require("../../cloud/services/egress-queue.service");
18
+ const event_mapper_service_1 = require("../../cloud/services/event-mapper.service");
19
+ const project_egress_config_service_1 = require("../../cloud/services/project-egress-config.service");
20
+ const tunnel_client_service_1 = require("./tunnel-client.service");
21
+ const logger = (0, logger_1.createLogger)('AskUserQuestionPushGate');
22
+ exports.AUQ_NATIVE_PUSH_GRACE_MS = 12_000;
23
+ let AskUserQuestionPushGateService = class AskUserQuestionPushGateService {
24
+ constructor(cloudSession, egressQueue, eventMapper, projectConfig, tunnelClient) {
25
+ this.cloudSession = cloudSession;
26
+ this.egressQueue = egressQueue;
27
+ this.eventMapper = eventMapper;
28
+ this.projectConfig = projectConfig;
29
+ this.tunnelClient = tunnelClient;
30
+ this.pendingTimers = new Set();
31
+ }
32
+ async onPending(payload) {
33
+ const status = this.cloudSession.getStatus();
34
+ if (!status.connected || !status.userId)
35
+ return;
36
+ if (!this.projectConfig.isEnabled(payload.projectId))
37
+ return;
38
+ const sourceEventId = `auq.pending:${payload.toolUseId}`;
39
+ const ingestPayload = this.eventMapper.mapToIngestPayload({ name: 'claude.hooks.ask_user_question.pending', payload }, sourceEventId, status.userId, { instanceId: this.tunnelClient.getInstanceId() });
40
+ const timer = setTimeout(() => {
41
+ this.pendingTimers.delete(timer);
42
+ void this.decide(ingestPayload, payload.toolUseId);
43
+ }, exports.AUQ_NATIVE_PUSH_GRACE_MS);
44
+ if (typeof timer.unref === 'function')
45
+ timer.unref();
46
+ this.pendingTimers.add(timer);
47
+ }
48
+ async decide(ingestPayload, toolUseId) {
49
+ let live = false;
50
+ try {
51
+ ({ live } = await this.tunnelClient.querySseLiveness());
52
+ }
53
+ catch {
54
+ live = false;
55
+ }
56
+ if (live) {
57
+ logger.debug({ toolUseId }, 'SSE live — suppressing AskUserQuestion native push');
58
+ return;
59
+ }
60
+ this.egressQueue.enqueue(ingestPayload);
61
+ logger.debug({ toolUseId }, 'SSE down — enqueued AskUserQuestion native push');
62
+ }
63
+ onModuleDestroy() {
64
+ for (const timer of this.pendingTimers)
65
+ clearTimeout(timer);
66
+ this.pendingTimers.clear();
67
+ }
68
+ };
69
+ exports.AskUserQuestionPushGateService = AskUserQuestionPushGateService;
70
+ __decorate([
71
+ (0, event_emitter_1.OnEvent)('claude.hooks.ask_user_question.pending', { async: true }),
72
+ __metadata("design:type", Function),
73
+ __metadata("design:paramtypes", [Object]),
74
+ __metadata("design:returntype", Promise)
75
+ ], AskUserQuestionPushGateService.prototype, "onPending", null);
76
+ exports.AskUserQuestionPushGateService = AskUserQuestionPushGateService = __decorate([
77
+ (0, common_1.Injectable)(),
78
+ __metadata("design:paramtypes", [cloud_session_manager_service_1.CloudSessionManagerService,
79
+ egress_queue_service_1.EgressQueueService,
80
+ event_mapper_service_1.EventMapperService,
81
+ project_egress_config_service_1.ProjectEgressConfigService,
82
+ tunnel_client_service_1.TunnelClientService])
83
+ ], AskUserQuestionPushGateService);
84
+ //# sourceMappingURL=ask-user-question-push-gate.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ask-user-question-push-gate.service.js","sourceRoot":"","sources":["../../../../src/modules/cloud-tunnel/services/ask-user-question-push-gate.service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ export declare function toStatusDto(status: Record<string, unknown>): Record<string, unknown>;
2
+ export declare function toStatusMap(statuses: Array<Record<string, unknown>>): Map<string, Record<string, unknown>>;
3
+ export declare function toEpicDto(epic: Record<string, unknown>, statusMap?: Map<string, Record<string, unknown>>, agentNameById?: Map<string, string>): Record<string, unknown>;
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.toStatusDto = toStatusDto;
4
+ exports.toStatusMap = toStatusMap;
5
+ exports.toEpicDto = toEpicDto;
6
+ function toStatusDto(status) {
7
+ return {
8
+ id: status.id,
9
+ name: status.name ?? status.label,
10
+ color: status.color,
11
+ position: status.position,
12
+ };
13
+ }
14
+ function toStatusMap(statuses) {
15
+ return new Map(statuses
16
+ .filter((status) => typeof status.id === 'string')
17
+ .map((status) => [status.id, toStatusDto(status)]));
18
+ }
19
+ function toEpicDto(epic, statusMap, agentNameById) {
20
+ const statusId = epic.statusId;
21
+ const status = statusId ? statusMap?.get(statusId) : undefined;
22
+ const agentId = epic.agentId ?? null;
23
+ const resolvedAgentName = (agentId ? agentNameById?.get(agentId) : undefined) ?? epic.agentName;
24
+ return {
25
+ id: epic.id,
26
+ projectId: epic.projectId,
27
+ title: epic.title,
28
+ statusId,
29
+ statusName: status?.name,
30
+ statusColor: status?.color,
31
+ statusPosition: status?.position,
32
+ status,
33
+ agentId,
34
+ agentName: resolvedAgentName,
35
+ parentId: epic.parentId,
36
+ version: epic.version,
37
+ updatedAt: epic.updatedAt,
38
+ description: epic.description,
39
+ createdAt: epic.createdAt,
40
+ tags: epic.tags,
41
+ };
42
+ }
43
+ //# sourceMappingURL=epic-dto.util.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"epic-dto.util.js","sourceRoot":"","sources":["../../../../src/modules/cloud-tunnel/services/epic-dto.util.ts"],"names":[],"mappings":";;AAmBA,kCAOC;AAGD,kCAQC;AAED,8BA6BC;AAjDD,SAAgB,WAAW,CAAC,MAA+B;IACzD,OAAO;QACL,EAAE,EAAE,MAAM,CAAC,EAAE;QACb,IAAI,EAAE,MAAM,CAAC,IAAI,IAAI,MAAM,CAAC,KAAK;QACjC,KAAK,EAAE,MAAM,CAAC,KAAK;QACnB,QAAQ,EAAE,MAAM,CAAC,QAAQ;KAC1B,CAAC;AACJ,CAAC;AAGD,SAAgB,WAAW,CACzB,QAAwC;IAExC,OAAO,IAAI,GAAG,CACZ,QAAQ;SACL,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,OAAO,MAAM,CAAC,EAAE,KAAK,QAAQ,CAAC;SACjD,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,EAAY,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,CAC/D,CAAC;AACJ,CAAC;AAED,SAAgB,SAAS,CACvB,IAA6B,EAC7B,SAAgD,EAChD,aAAmC;IAEnC,MAAM,QAAQ,GAAG,IAAI,CAAC,QAA8B,CAAC;IACrD,MAAM,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IAC/D,MAAM,OAAO,GAAI,IAAI,CAAC,OAAqC,IAAI,IAAI,CAAC;IACpE,MAAM,iBAAiB,GACrB,CAAC,OAAO,CAAC,CAAC,CAAC,aAAa,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,IAAK,IAAI,CAAC,SAAgC,CAAC;IAEhG,OAAO;QACL,EAAE,EAAE,IAAI,CAAC,EAAE;QACX,SAAS,EAAE,IAAI,CAAC,SAAS;QACzB,KAAK,EAAE,IAAI,CAAC,KAAK;QACjB,QAAQ;QACR,UAAU,EAAE,MAAM,EAAE,IAAI;QACxB,WAAW,EAAE,MAAM,EAAE,KAAK;QAC1B,cAAc,EAAE,MAAM,EAAE,QAAQ;QAChC,MAAM;QACN,OAAO;QACP,SAAS,EAAE,iBAAiB;QAC5B,QAAQ,EAAE,IAAI,CAAC,QAAQ;QACvB,OAAO,EAAE,IAAI,CAAC,OAAO;QACrB,SAAS,EAAE,IAAI,CAAC,SAAS;QACzB,WAAW,EAAE,IAAI,CAAC,WAAW;QAC7B,SAAS,EAAE,IAAI,CAAC,SAAS;QACzB,IAAI,EAAE,IAAI,CAAC,IAAI;KAChB,CAAC;AACJ,CAAC"}
@@ -0,0 +1,11 @@
1
+ export interface JsonRpcError {
2
+ code: number;
3
+ message: string;
4
+ data?: {
5
+ code: string;
6
+ details?: unknown;
7
+ };
8
+ }
9
+ export declare const JSON_RPC_INVALID_PARAMS = -32602;
10
+ export declare const JSON_RPC_INTERNAL_ERROR = -32603;
11
+ export declare function toJsonRpcError(err: unknown): JsonRpcError;
@@ -0,0 +1,32 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.JSON_RPC_INTERNAL_ERROR = exports.JSON_RPC_INVALID_PARAMS = void 0;
4
+ exports.toJsonRpcError = toJsonRpcError;
5
+ const zod_1 = require("zod");
6
+ const error_types_1 = require("../../../common/errors/error-types");
7
+ exports.JSON_RPC_INVALID_PARAMS = -32602;
8
+ exports.JSON_RPC_INTERNAL_ERROR = -32603;
9
+ function appErrorToRpcCode(err) {
10
+ return err.statusCode === 400 ? exports.JSON_RPC_INVALID_PARAMS : exports.JSON_RPC_INTERNAL_ERROR;
11
+ }
12
+ function toJsonRpcError(err) {
13
+ if (err instanceof zod_1.ZodError) {
14
+ return {
15
+ code: exports.JSON_RPC_INVALID_PARAMS,
16
+ message: 'Invalid params',
17
+ data: { code: 'validation_error', details: err.format() },
18
+ };
19
+ }
20
+ if (err instanceof error_types_1.AppError) {
21
+ const data = { code: err.code };
22
+ if (err.details !== undefined) {
23
+ data.details = err.details;
24
+ }
25
+ return { code: appErrorToRpcCode(err), message: err.message, data };
26
+ }
27
+ return {
28
+ code: exports.JSON_RPC_INTERNAL_ERROR,
29
+ message: err instanceof Error ? err.message : 'Internal error',
30
+ };
31
+ }
32
+ //# sourceMappingURL=jsonrpc-error.util.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jsonrpc-error.util.js","sourceRoot":"","sources":["../../../../src/modules/cloud-tunnel/services/jsonrpc-error.util.ts"],"names":[],"mappings":";;;AAsCA,wCAqBC;AA3DD,6BAA+B;AAC/B,oEAA8D;AAkBjD,QAAA,uBAAuB,GAAG,CAAC,KAAK,CAAC;AACjC,QAAA,uBAAuB,GAAG,CAAC,KAAK,CAAC;AAO9C,SAAS,iBAAiB,CAAC,GAAa;IACtC,OAAO,GAAG,CAAC,UAAU,KAAK,GAAG,CAAC,CAAC,CAAC,+BAAuB,CAAC,CAAC,CAAC,+BAAuB,CAAC;AACpF,CAAC;AASD,SAAgB,cAAc,CAAC,GAAY;IACzC,IAAI,GAAG,YAAY,cAAQ,EAAE,CAAC;QAC5B,OAAO;YACL,IAAI,EAAE,+BAAuB;YAC7B,OAAO,EAAE,gBAAgB;YACzB,IAAI,EAAE,EAAE,IAAI,EAAE,kBAAkB,EAAE,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,EAAE;SAC1D,CAAC;IACJ,CAAC;IAED,IAAI,GAAG,YAAY,sBAAQ,EAAE,CAAC;QAC5B,MAAM,IAAI,GAAyB,EAAE,IAAI,EAAE,GAAG,CAAC,IAAI,EAAE,CAAC;QACtD,IAAI,GAAG,CAAC,OAAO,KAAK,SAAS,EAAE,CAAC;YAC9B,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC,OAAO,CAAC;QAC7B,CAAC;QACD,OAAO,EAAE,IAAI,EAAE,iBAAiB,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,GAAG,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC;IACtE,CAAC;IAED,OAAO;QACL,IAAI,EAAE,+BAAuB;QAC7B,OAAO,EAAE,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,gBAAgB;KAC/D,CAAC;AACJ,CAAC"}
@@ -0,0 +1,30 @@
1
+ export type LifecycleOperationType = 'launch' | 'restart' | 'restore';
2
+ export type LifecycleOperationStatus = 'pending' | 'running' | 'succeeded' | 'failed';
3
+ export interface LifecycleOperation {
4
+ operationId: string;
5
+ type: LifecycleOperationType;
6
+ agentId: string | null;
7
+ sessionId: string | null;
8
+ projectId: string;
9
+ status: LifecycleOperationStatus;
10
+ errorCode?: string;
11
+ errorMessage?: string;
12
+ createdAt: string;
13
+ updatedAt: string;
14
+ }
15
+ export declare class LifecycleOperationTracker {
16
+ private readonly operations;
17
+ create(input: {
18
+ type: LifecycleOperationType;
19
+ projectId: string;
20
+ agentId?: string | null;
21
+ sessionId?: string | null;
22
+ }): LifecycleOperation;
23
+ markRunning(operationId: string): void;
24
+ succeed(operationId: string, sessionId?: string | null): void;
25
+ fail(operationId: string, errorCode: string, errorMessage: string): void;
26
+ get(operationId: string): LifecycleOperation | undefined;
27
+ latestForAgent(agentId: string): LifecycleOperation | undefined;
28
+ private patch;
29
+ private evictIfNeeded;
30
+ }
@@ -0,0 +1,80 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.LifecycleOperationTracker = void 0;
10
+ const common_1 = require("@nestjs/common");
11
+ const node_crypto_1 = require("node:crypto");
12
+ const MAX_OPERATIONS = 500;
13
+ let LifecycleOperationTracker = class LifecycleOperationTracker {
14
+ constructor() {
15
+ this.operations = new Map();
16
+ }
17
+ create(input) {
18
+ const now = new Date().toISOString();
19
+ const op = {
20
+ operationId: (0, node_crypto_1.randomUUID)(),
21
+ type: input.type,
22
+ agentId: input.agentId ?? null,
23
+ sessionId: input.sessionId ?? null,
24
+ projectId: input.projectId,
25
+ status: 'pending',
26
+ createdAt: now,
27
+ updatedAt: now,
28
+ };
29
+ this.operations.set(op.operationId, op);
30
+ this.evictIfNeeded();
31
+ return op;
32
+ }
33
+ markRunning(operationId) {
34
+ this.patch(operationId, { status: 'running' });
35
+ }
36
+ succeed(operationId, sessionId) {
37
+ this.patch(operationId, {
38
+ status: 'succeeded',
39
+ ...(sessionId ? { sessionId } : {}),
40
+ });
41
+ }
42
+ fail(operationId, errorCode, errorMessage) {
43
+ this.patch(operationId, { status: 'failed', errorCode, errorMessage });
44
+ }
45
+ get(operationId) {
46
+ return this.operations.get(operationId);
47
+ }
48
+ latestForAgent(agentId) {
49
+ let latest;
50
+ for (const op of this.operations.values()) {
51
+ if (op.agentId === agentId && (!latest || op.createdAt >= latest.createdAt)) {
52
+ latest = op;
53
+ }
54
+ }
55
+ return latest;
56
+ }
57
+ patch(operationId, fields) {
58
+ const existing = this.operations.get(operationId);
59
+ if (!existing)
60
+ return;
61
+ this.operations.set(operationId, {
62
+ ...existing,
63
+ ...fields,
64
+ updatedAt: new Date().toISOString(),
65
+ });
66
+ }
67
+ evictIfNeeded() {
68
+ while (this.operations.size > MAX_OPERATIONS) {
69
+ const oldest = this.operations.keys().next().value;
70
+ if (oldest === undefined)
71
+ break;
72
+ this.operations.delete(oldest);
73
+ }
74
+ }
75
+ };
76
+ exports.LifecycleOperationTracker = LifecycleOperationTracker;
77
+ exports.LifecycleOperationTracker = LifecycleOperationTracker = __decorate([
78
+ (0, common_1.Injectable)()
79
+ ], LifecycleOperationTracker);
80
+ //# sourceMappingURL=lifecycle-operation-tracker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lifecycle-operation-tracker.js","sourceRoot":"","sources":["../../../../src/modules/cloud-tunnel/services/lifecycle-operation-tracker.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,16 @@
1
+ import { type StorageService } from '../../storage/interfaces/storage.interface';
2
+ import { EpicsService } from '../../epics/services/epics.service';
3
+ import type { EpicComment } from '../../storage/models/domain.models';
4
+ import type { ListResult } from '../../storage/interfaces/storage.interface';
5
+ export declare class MobileBoardRpcService {
6
+ private readonly storage;
7
+ private readonly epicsService;
8
+ constructor(storage: StorageService, epicsService: EpicsService);
9
+ updateEpicAssignment(params: Record<string, unknown>): Promise<Record<string, unknown>>;
10
+ listEpicComments(params: Record<string, unknown>): Promise<ListResult<EpicComment>>;
11
+ addEpicComment(params: Record<string, unknown>): Promise<EpicComment>;
12
+ deleteEpicComment(params: Record<string, unknown>): Promise<{
13
+ deleted: true;
14
+ }>;
15
+ private assertEpicInProject;
16
+ }
@@ -0,0 +1,78 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.MobileBoardRpcService = void 0;
16
+ const common_1 = require("@nestjs/common");
17
+ const storage_interface_1 = require("../../storage/interfaces/storage.interface");
18
+ const epics_service_1 = require("../../epics/services/epics.service");
19
+ const error_types_1 = require("../../../common/errors/error-types");
20
+ const epic_dto_util_1 = require("./epic-dto.util");
21
+ let MobileBoardRpcService = class MobileBoardRpcService {
22
+ constructor(storage, epicsService) {
23
+ this.storage = storage;
24
+ this.epicsService = epicsService;
25
+ }
26
+ async updateEpicAssignment(params) {
27
+ const projectId = params['projectId'];
28
+ const epicId = params['epicId'];
29
+ const agentId = params['agentId'];
30
+ const version = params['version'];
31
+ await this.assertEpicInProject(epicId, projectId);
32
+ const updated = await this.epicsService.updateEpic(epicId, { agentId }, version);
33
+ const [statusesResult, assignee] = await Promise.all([
34
+ this.storage.listStatuses(projectId, { limit: 1000, offset: 0 }),
35
+ updated.agentId ? this.storage.getAgent(updated.agentId) : Promise.resolve(null),
36
+ ]);
37
+ const statusMap = (0, epic_dto_util_1.toStatusMap)(statusesResult.items);
38
+ const agentNameById = assignee ? new Map([[assignee.id, assignee.name]]) : undefined;
39
+ return (0, epic_dto_util_1.toEpicDto)(updated, statusMap, agentNameById);
40
+ }
41
+ async listEpicComments(params) {
42
+ const projectId = params['projectId'];
43
+ const epicId = params['epicId'];
44
+ const limit = params['limit'];
45
+ const offset = params['offset'];
46
+ await this.assertEpicInProject(epicId, projectId);
47
+ return this.storage.listEpicComments(epicId, { limit, offset });
48
+ }
49
+ async addEpicComment(params) {
50
+ const projectId = params['projectId'];
51
+ const epicId = params['epicId'];
52
+ const authorName = params['authorName'];
53
+ const content = params['content'];
54
+ await this.assertEpicInProject(epicId, projectId);
55
+ return this.epicsService.addEpicCommentFromRest(epicId, authorName, content);
56
+ }
57
+ async deleteEpicComment(params) {
58
+ const projectId = params['projectId'];
59
+ const epicId = params['epicId'];
60
+ const commentId = params['commentId'];
61
+ await this.epicsService.deleteEpicComment(projectId, epicId, commentId);
62
+ return { deleted: true };
63
+ }
64
+ async assertEpicInProject(epicId, projectId) {
65
+ const epic = await this.storage.getEpic(epicId);
66
+ if (epic.projectId !== projectId) {
67
+ throw new error_types_1.NotFoundError('Epic', epicId);
68
+ }
69
+ return epic;
70
+ }
71
+ };
72
+ exports.MobileBoardRpcService = MobileBoardRpcService;
73
+ exports.MobileBoardRpcService = MobileBoardRpcService = __decorate([
74
+ (0, common_1.Injectable)(),
75
+ __param(0, (0, common_1.Inject)(storage_interface_1.STORAGE_SERVICE)),
76
+ __metadata("design:paramtypes", [Object, epics_service_1.EpicsService])
77
+ ], MobileBoardRpcService);
78
+ //# sourceMappingURL=mobile-board-rpc.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mobile-board-rpc.service.js","sourceRoot":"","sources":["../../../../src/modules/cloud-tunnel/services/mobile-board-rpc.service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,112 @@
1
+ import { StorageService } from '../../storage/interfaces/storage.interface';
2
+ import { ActiveSessionLookup } from '../../sessions/services/active-session-lookup.service';
3
+ import { SessionLifecycleFacade } from '../../sessions/services/session-lifecycle-facade.service';
4
+ import type { SessionDto, SessionHistoryResponseDto } from '../../sessions/dtos/sessions.dto';
5
+ import { SessionReaderService, type TranscriptSummaryWithCursor, type UnifiedChunkedResponse, type TranscriptTailResponse } from '../../session-reader/services/session-reader.service';
6
+ import { TranscriptWatcherService } from '../../session-reader/services/transcript-watcher.service';
7
+ import { AgentMessageDeliveryService } from '../../agent-message-delivery/agent-message-delivery.service';
8
+ import { TeamsService } from '../../teams/services/teams.service';
9
+ import { PendingAskUserQuestionService } from '../../hooks/services/pending-ask-user-question.service';
10
+ import type { NormalizedAskUserQuestion } from '../../events/catalog/claude.hooks.ask_user_question.pending';
11
+ import { LifecycleOperationTracker, type LifecycleOperation } from './lifecycle-operation-tracker';
12
+ export interface MobileChatAgent {
13
+ id: string;
14
+ name: string;
15
+ type: 'agent';
16
+ profileName?: string;
17
+ providerName?: string;
18
+ providerConfigName?: string;
19
+ online: boolean;
20
+ sessionId?: string;
21
+ activityState?: 'idle' | 'busy' | null;
22
+ latestMessageCount?: number;
23
+ }
24
+ export interface MobileChatTeam {
25
+ id: string;
26
+ name: string;
27
+ teamLeadAgentId: string | null;
28
+ memberAgentIds: string[];
29
+ memberCount?: number;
30
+ }
31
+ export interface MobileChatProfile {
32
+ id: string;
33
+ name: string;
34
+ familySlug?: string | null;
35
+ }
36
+ export interface MobileChatProviderConfig {
37
+ id: string;
38
+ profileId: string;
39
+ providerId: string;
40
+ providerName?: string;
41
+ name: string;
42
+ position: number;
43
+ }
44
+ export interface MobileChatCreatedAgent {
45
+ id: string;
46
+ name: string;
47
+ profileId: string;
48
+ providerConfigId: string;
49
+ description: string | null;
50
+ teamId: string | null;
51
+ }
52
+ export interface SendMessageResult {
53
+ status: 'queued' | 'delivered';
54
+ }
55
+ export interface LifecycleStartResult {
56
+ operationId: string;
57
+ status: 'launching' | 'restarting' | 'restoring';
58
+ }
59
+ export interface TerminateResult {
60
+ status: 'terminated';
61
+ }
62
+ export interface PendingAskUserQuestionItem {
63
+ toolUseId: string;
64
+ questions: NormalizedAskUserQuestion[];
65
+ createdAt: number;
66
+ expiresAt: number;
67
+ }
68
+ export declare class MobileChatRpcService {
69
+ private readonly storage;
70
+ private readonly activeSessions;
71
+ private readonly sessionReader;
72
+ private readonly transcriptWatcher;
73
+ private readonly agentMessageDelivery;
74
+ private readonly sessionLifecycle;
75
+ private readonly operationTracker;
76
+ private readonly teamsService;
77
+ private readonly pendingAskUserQuestion;
78
+ constructor(storage: StorageService, activeSessions: ActiveSessionLookup, sessionReader: SessionReaderService, transcriptWatcher: TranscriptWatcherService, agentMessageDelivery: AgentMessageDeliveryService, sessionLifecycle: SessionLifecycleFacade, operationTracker: LifecycleOperationTracker, teamsService: TeamsService, pendingAskUserQuestion: PendingAskUserQuestionService);
79
+ listAgents(params: Record<string, unknown>): Promise<MobileChatAgent[]>;
80
+ listTeams(params: Record<string, unknown>): Promise<MobileChatTeam[]>;
81
+ listProfiles(params: Record<string, unknown>): Promise<MobileChatProfile[]>;
82
+ listProfileConfigs(params: Record<string, unknown>): Promise<MobileChatProviderConfig[]>;
83
+ createTeamAgent(params: Record<string, unknown>): Promise<MobileChatCreatedAgent>;
84
+ createIndependentAgent(params: Record<string, unknown>): Promise<MobileChatCreatedAgent>;
85
+ deleteAgent(params: Record<string, unknown>): Promise<{
86
+ deleted: true;
87
+ }>;
88
+ private toCreatedAgent;
89
+ getTranscriptSummary(params: Record<string, unknown>): Promise<TranscriptSummaryWithCursor>;
90
+ getTranscriptChunks(params: Record<string, unknown>): Promise<UnifiedChunkedResponse>;
91
+ getTranscriptTail(params: Record<string, unknown>): Promise<TranscriptTailResponse | null>;
92
+ sendMessage(params: Record<string, unknown>): Promise<SendMessageResult>;
93
+ launchAgent(params: Record<string, unknown>): Promise<LifecycleStartResult>;
94
+ restartAgent(params: Record<string, unknown>): Promise<LifecycleStartResult>;
95
+ restoreSession(params: Record<string, unknown>): Promise<LifecycleStartResult>;
96
+ terminateSession(params: Record<string, unknown>): Promise<TerminateResult>;
97
+ getOperationStatus(params: Record<string, unknown>): Promise<LifecycleOperation>;
98
+ getAgentStatus(params: Record<string, unknown>): Promise<LifecycleOperation | null>;
99
+ listPendingAskQuestions(params: Record<string, unknown>): Promise<PendingAskUserQuestionItem[]>;
100
+ listSessions(params: Record<string, unknown>): Promise<SessionHistoryResponseDto>;
101
+ deleteSessionRecord(params: Record<string, unknown>): Promise<{
102
+ deleted: boolean;
103
+ }>;
104
+ renameSession(params: Record<string, unknown>): Promise<SessionDto>;
105
+ private assertAgentInProject;
106
+ private assertProfileInProject;
107
+ private runOperation;
108
+ private assertSessionInProject;
109
+ private resolveProviderConfigInfo;
110
+ private resolveProfileNames;
111
+ private distinct;
112
+ }