@viewportai/daemon 0.2.0 → 0.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (818) hide show
  1. package/README.md +18 -6
  2. package/bin/vpd.js +0 -1
  3. package/dist/adapters/claude-message-normalizer.d.ts +24 -0
  4. package/dist/adapters/claude-message-normalizer.d.ts.map +1 -0
  5. package/dist/adapters/claude-message-normalizer.js +192 -0
  6. package/dist/adapters/claude-message-normalizer.js.map +1 -0
  7. package/dist/adapters/claude.d.ts +1 -23
  8. package/dist/adapters/claude.d.ts.map +1 -1
  9. package/dist/adapters/claude.js +20 -215
  10. package/dist/adapters/claude.js.map +1 -1
  11. package/dist/adapters/codex-sdk-loader.d.ts +1 -0
  12. package/dist/adapters/codex-sdk-loader.d.ts.map +1 -1
  13. package/dist/adapters/codex.d.ts +6 -2
  14. package/dist/adapters/codex.d.ts.map +1 -1
  15. package/dist/adapters/codex.js +44 -19
  16. package/dist/adapters/codex.js.map +1 -1
  17. package/dist/adapters/gemini-cli.js +2 -2
  18. package/dist/adapters/gemini-cli.js.map +1 -1
  19. package/dist/adapters/pty.d.ts.map +1 -1
  20. package/dist/adapters/pty.js +12 -10
  21. package/dist/adapters/pty.js.map +1 -1
  22. package/dist/agents/codex-defaults.d.ts +2 -0
  23. package/dist/agents/codex-defaults.d.ts.map +1 -0
  24. package/dist/agents/codex-defaults.js +2 -0
  25. package/dist/agents/codex-defaults.js.map +1 -0
  26. package/dist/agents/codex.d.ts.map +1 -1
  27. package/dist/agents/codex.js +15 -3
  28. package/dist/agents/codex.js.map +1 -1
  29. package/dist/cli/agent-commands.d.ts.map +1 -1
  30. package/dist/cli/agent-commands.js +12 -2
  31. package/dist/cli/agent-commands.js.map +1 -1
  32. package/dist/cli/command-shared.d.ts +30 -2
  33. package/dist/cli/command-shared.d.ts.map +1 -1
  34. package/dist/cli/command-shared.js +25 -27
  35. package/dist/cli/command-shared.js.map +1 -1
  36. package/dist/cli/commands.d.ts +7 -2
  37. package/dist/cli/commands.d.ts.map +1 -1
  38. package/dist/cli/commands.js +7 -2
  39. package/dist/cli/commands.js.map +1 -1
  40. package/dist/cli/context-access-command.d.ts +9 -0
  41. package/dist/cli/context-access-command.d.ts.map +1 -0
  42. package/dist/cli/context-access-command.js +133 -0
  43. package/dist/cli/context-access-command.js.map +1 -0
  44. package/dist/cli/context-add-command.d.ts +2 -0
  45. package/dist/cli/context-add-command.d.ts.map +1 -0
  46. package/dist/cli/context-add-command.js +74 -0
  47. package/dist/cli/context-add-command.js.map +1 -0
  48. package/dist/cli/context-candidate-preview-command.d.ts +2 -0
  49. package/dist/cli/context-candidate-preview-command.d.ts.map +1 -0
  50. package/dist/cli/context-candidate-preview-command.js +52 -0
  51. package/dist/cli/context-candidate-preview-command.js.map +1 -0
  52. package/dist/cli/context-command-parsers.d.ts +4 -0
  53. package/dist/cli/context-command-parsers.d.ts.map +1 -0
  54. package/dist/cli/context-command-parsers.js +32 -0
  55. package/dist/cli/context-command-parsers.js.map +1 -0
  56. package/dist/cli/context-command.d.ts +2 -0
  57. package/dist/cli/context-command.d.ts.map +1 -0
  58. package/dist/cli/context-command.js +323 -0
  59. package/dist/cli/context-command.js.map +1 -0
  60. package/dist/cli/context-provider-command.d.ts +4 -0
  61. package/dist/cli/context-provider-command.d.ts.map +1 -0
  62. package/dist/cli/context-provider-command.js +268 -0
  63. package/dist/cli/context-provider-command.js.map +1 -0
  64. package/dist/cli/context-provider-propose.d.ts +22 -0
  65. package/dist/cli/context-provider-propose.d.ts.map +1 -0
  66. package/dist/cli/context-provider-propose.js +26 -0
  67. package/dist/cli/context-provider-propose.js.map +1 -0
  68. package/dist/cli/context-provider-resolve.d.ts +11 -0
  69. package/dist/cli/context-provider-resolve.d.ts.map +1 -0
  70. package/dist/cli/context-provider-resolve.js +22 -0
  71. package/dist/cli/context-provider-resolve.js.map +1 -0
  72. package/dist/cli/context-sync-target.d.ts +12 -0
  73. package/dist/cli/context-sync-target.d.ts.map +1 -0
  74. package/dist/cli/context-sync-target.js +63 -0
  75. package/dist/cli/context-sync-target.js.map +1 -0
  76. package/dist/cli/context-vault-metadata-command.d.ts +3 -0
  77. package/dist/cli/context-vault-metadata-command.d.ts.map +1 -0
  78. package/dist/cli/context-vault-metadata-command.js +239 -0
  79. package/dist/cli/context-vault-metadata-command.js.map +1 -0
  80. package/dist/cli/context-vault-use-command.d.ts +2 -0
  81. package/dist/cli/context-vault-use-command.d.ts.map +1 -0
  82. package/dist/cli/context-vault-use-command.js +35 -0
  83. package/dist/cli/context-vault-use-command.js.map +1 -0
  84. package/dist/cli/contract-authorization.d.ts +25 -0
  85. package/dist/cli/contract-authorization.d.ts.map +1 -0
  86. package/dist/cli/contract-authorization.js +99 -0
  87. package/dist/cli/contract-authorization.js.map +1 -0
  88. package/dist/cli/daemon-client.d.ts.map +1 -1
  89. package/dist/cli/daemon-client.js +49 -14
  90. package/dist/cli/daemon-client.js.map +1 -1
  91. package/dist/cli/daemon-lifecycle.d.ts +2 -33
  92. package/dist/cli/daemon-lifecycle.d.ts.map +1 -1
  93. package/dist/cli/daemon-lifecycle.js +42 -16
  94. package/dist/cli/daemon-lifecycle.js.map +1 -1
  95. package/dist/cli/daemon-runtime-state.d.ts +47 -0
  96. package/dist/cli/daemon-runtime-state.d.ts.map +1 -0
  97. package/dist/cli/daemon-runtime-state.js +2 -0
  98. package/dist/cli/daemon-runtime-state.js.map +1 -0
  99. package/dist/cli/daemon-settings.d.ts.map +1 -1
  100. package/dist/cli/daemon-settings.js +24 -5
  101. package/dist/cli/daemon-settings.js.map +1 -1
  102. package/dist/cli/directory-commands.js +1 -1
  103. package/dist/cli/directory-commands.js.map +1 -1
  104. package/dist/cli/global-flags.d.ts +2 -0
  105. package/dist/cli/global-flags.d.ts.map +1 -0
  106. package/dist/cli/global-flags.js +8 -0
  107. package/dist/cli/global-flags.js.map +1 -0
  108. package/dist/cli/guard-command.d.ts +34 -0
  109. package/dist/cli/guard-command.d.ts.map +1 -0
  110. package/dist/cli/guard-command.js +161 -0
  111. package/dist/cli/guard-command.js.map +1 -0
  112. package/dist/cli/hook-command.d.ts +3 -1
  113. package/dist/cli/hook-command.d.ts.map +1 -1
  114. package/dist/cli/hook-command.js +33 -3
  115. package/dist/cli/hook-command.js.map +1 -1
  116. package/dist/cli/lifecycle-commands.d.ts +7 -2
  117. package/dist/cli/lifecycle-commands.d.ts.map +1 -1
  118. package/dist/cli/lifecycle-commands.js +169 -339
  119. package/dist/cli/lifecycle-commands.js.map +1 -1
  120. package/dist/cli/lifecycle-doctor-command.d.ts +2 -0
  121. package/dist/cli/lifecycle-doctor-command.d.ts.map +1 -0
  122. package/dist/cli/lifecycle-doctor-command.js +100 -0
  123. package/dist/cli/lifecycle-doctor-command.js.map +1 -0
  124. package/dist/cli/lifecycle-pair-command.d.ts +6 -0
  125. package/dist/cli/lifecycle-pair-command.d.ts.map +1 -0
  126. package/dist/cli/lifecycle-pair-command.js +286 -0
  127. package/dist/cli/lifecycle-pair-command.js.map +1 -0
  128. package/dist/cli/lifecycle-pair-server.d.ts +26 -0
  129. package/dist/cli/lifecycle-pair-server.d.ts.map +1 -0
  130. package/dist/cli/lifecycle-pair-server.js +166 -0
  131. package/dist/cli/lifecycle-pair-server.js.map +1 -0
  132. package/dist/cli/lifecycle-status-command.d.ts +2 -0
  133. package/dist/cli/lifecycle-status-command.d.ts.map +1 -0
  134. package/dist/cli/lifecycle-status-command.js +184 -0
  135. package/dist/cli/lifecycle-status-command.js.map +1 -0
  136. package/dist/cli/lifecycle-update-command.d.ts +2 -0
  137. package/dist/cli/lifecycle-update-command.d.ts.map +1 -0
  138. package/dist/cli/lifecycle-update-command.js +71 -0
  139. package/dist/cli/lifecycle-update-command.js.map +1 -0
  140. package/dist/cli/local-tls.d.ts +9 -0
  141. package/dist/cli/local-tls.d.ts.map +1 -0
  142. package/dist/cli/local-tls.js +84 -0
  143. package/dist/cli/local-tls.js.map +1 -0
  144. package/dist/cli/network.d.ts +11 -0
  145. package/dist/cli/network.d.ts.map +1 -0
  146. package/dist/cli/network.js +172 -0
  147. package/dist/cli/network.js.map +1 -0
  148. package/dist/cli/pairing-name-resolver.d.ts +2 -0
  149. package/dist/cli/pairing-name-resolver.d.ts.map +1 -0
  150. package/dist/cli/pairing-name-resolver.js +48 -0
  151. package/dist/cli/pairing-name-resolver.js.map +1 -0
  152. package/dist/cli/permission-commands.d.ts.map +1 -1
  153. package/dist/cli/permission-commands.js +11 -1
  154. package/dist/cli/permission-commands.js.map +1 -1
  155. package/dist/cli/relay-diagnostics.d.ts +8 -0
  156. package/dist/cli/relay-diagnostics.d.ts.map +1 -0
  157. package/dist/cli/relay-diagnostics.js +45 -0
  158. package/dist/cli/relay-diagnostics.js.map +1 -0
  159. package/dist/cli/remote-commands.d.ts.map +1 -1
  160. package/dist/cli/remote-commands.js +151 -85
  161. package/dist/cli/remote-commands.js.map +1 -1
  162. package/dist/cli/resource-config-command.d.ts +9 -0
  163. package/dist/cli/resource-config-command.d.ts.map +1 -0
  164. package/dist/cli/resource-config-command.js +292 -0
  165. package/dist/cli/resource-config-command.js.map +1 -0
  166. package/dist/cli/service-commands.d.ts +2 -0
  167. package/dist/cli/service-commands.d.ts.map +1 -1
  168. package/dist/cli/service-commands.js +23 -1
  169. package/dist/cli/service-commands.js.map +1 -1
  170. package/dist/cli/session-commands.d.ts +2 -0
  171. package/dist/cli/session-commands.d.ts.map +1 -1
  172. package/dist/cli/session-commands.js +94 -3
  173. package/dist/cli/session-commands.js.map +1 -1
  174. package/dist/cli/skills-command.d.ts +2 -0
  175. package/dist/cli/skills-command.d.ts.map +1 -0
  176. package/dist/cli/skills-command.js +170 -0
  177. package/dist/cli/skills-command.js.map +1 -0
  178. package/dist/cli/supervisor-protocol.d.ts +6 -1
  179. package/dist/cli/supervisor-protocol.d.ts.map +1 -1
  180. package/dist/cli/supervisor-runtime-config.d.ts +4 -0
  181. package/dist/cli/supervisor-runtime-config.d.ts.map +1 -0
  182. package/dist/cli/supervisor-runtime-config.js +67 -0
  183. package/dist/cli/supervisor-runtime-config.js.map +1 -0
  184. package/dist/cli/supervisor.d.ts.map +1 -1
  185. package/dist/cli/supervisor.js +81 -77
  186. package/dist/cli/supervisor.js.map +1 -1
  187. package/dist/cli/workflow-commands.d.ts +3 -0
  188. package/dist/cli/workflow-commands.d.ts.map +1 -0
  189. package/dist/cli/workflow-commands.js +271 -0
  190. package/dist/cli/workflow-commands.js.map +1 -0
  191. package/dist/cli/workflow-contract-resolver.d.ts +13 -0
  192. package/dist/cli/workflow-contract-resolver.d.ts.map +1 -0
  193. package/dist/cli/workflow-contract-resolver.js +68 -0
  194. package/dist/cli/workflow-contract-resolver.js.map +1 -0
  195. package/dist/cli/workflow-run-json.d.ts +34 -0
  196. package/dist/cli/workflow-run-json.d.ts.map +1 -0
  197. package/dist/cli/workflow-run-json.js +118 -0
  198. package/dist/cli/workflow-run-json.js.map +1 -0
  199. package/dist/cli/worktree-commands.d.ts.map +1 -1
  200. package/dist/cli/worktree-commands.js +12 -2
  201. package/dist/cli/worktree-commands.js.map +1 -1
  202. package/dist/cli/ws-client.js +22 -2
  203. package/dist/cli/ws-client.js.map +1 -1
  204. package/dist/config-resolution/approval-rules.d.ts +5 -0
  205. package/dist/config-resolution/approval-rules.d.ts.map +1 -0
  206. package/dist/config-resolution/approval-rules.js +14 -0
  207. package/dist/config-resolution/approval-rules.js.map +1 -0
  208. package/dist/config-resolution/config-writer.d.ts +18 -0
  209. package/dist/config-resolution/config-writer.d.ts.map +1 -0
  210. package/dist/config-resolution/config-writer.js +97 -0
  211. package/dist/config-resolution/config-writer.js.map +1 -0
  212. package/dist/config-resolution/discovery.d.ts +18 -0
  213. package/dist/config-resolution/discovery.d.ts.map +1 -0
  214. package/dist/config-resolution/discovery.js +225 -0
  215. package/dist/config-resolution/discovery.js.map +1 -0
  216. package/dist/config-resolution/index.d.ts +4 -0
  217. package/dist/config-resolution/index.d.ts.map +1 -0
  218. package/dist/config-resolution/index.js +4 -0
  219. package/dist/config-resolution/index.js.map +1 -0
  220. package/dist/config-resolution/resolver.d.ts +16 -0
  221. package/dist/config-resolution/resolver.d.ts.map +1 -0
  222. package/dist/config-resolution/resolver.js +327 -0
  223. package/dist/config-resolution/resolver.js.map +1 -0
  224. package/dist/config-resolution/schema.d.ts +112 -0
  225. package/dist/config-resolution/schema.d.ts.map +1 -0
  226. package/dist/config-resolution/schema.js +177 -0
  227. package/dist/config-resolution/schema.js.map +1 -0
  228. package/dist/config-resolution/stable-json.d.ts +3 -0
  229. package/dist/config-resolution/stable-json.d.ts.map +1 -0
  230. package/dist/config-resolution/stable-json.js +18 -0
  231. package/dist/config-resolution/stable-json.js.map +1 -0
  232. package/dist/config-resolution/types.d.ts +120 -0
  233. package/dist/config-resolution/types.d.ts.map +1 -0
  234. package/dist/config-resolution/types.js +5 -0
  235. package/dist/config-resolution/types.js.map +1 -0
  236. package/dist/context/local-edge-candidates.d.ts +41 -0
  237. package/dist/context/local-edge-candidates.d.ts.map +1 -0
  238. package/dist/context/local-edge-candidates.js +224 -0
  239. package/dist/context/local-edge-candidates.js.map +1 -0
  240. package/dist/context/local-edge-crypto.d.ts +28 -0
  241. package/dist/context/local-edge-crypto.d.ts.map +1 -0
  242. package/dist/context/local-edge-crypto.js +76 -0
  243. package/dist/context/local-edge-crypto.js.map +1 -0
  244. package/dist/context/local-edge-decision-applications.d.ts +13 -0
  245. package/dist/context/local-edge-decision-applications.d.ts.map +1 -0
  246. package/dist/context/local-edge-decision-applications.js +78 -0
  247. package/dist/context/local-edge-decision-applications.js.map +1 -0
  248. package/dist/context/local-edge-decision-signature.d.ts +3 -0
  249. package/dist/context/local-edge-decision-signature.d.ts.map +1 -0
  250. package/dist/context/local-edge-decision-signature.js +67 -0
  251. package/dist/context/local-edge-decision-signature.js.map +1 -0
  252. package/dist/context/local-edge-engine.d.ts +38 -0
  253. package/dist/context/local-edge-engine.d.ts.map +1 -0
  254. package/dist/context/local-edge-engine.js +138 -0
  255. package/dist/context/local-edge-engine.js.map +1 -0
  256. package/dist/context/local-edge-key-store.d.ts +4 -0
  257. package/dist/context/local-edge-key-store.d.ts.map +1 -0
  258. package/dist/context/local-edge-key-store.js +21 -0
  259. package/dist/context/local-edge-key-store.js.map +1 -0
  260. package/dist/context/local-edge-metadata.d.ts +8 -0
  261. package/dist/context/local-edge-metadata.d.ts.map +1 -0
  262. package/dist/context/local-edge-metadata.js +95 -0
  263. package/dist/context/local-edge-metadata.js.map +1 -0
  264. package/dist/context/local-edge-paths.d.ts +4 -0
  265. package/dist/context/local-edge-paths.d.ts.map +1 -0
  266. package/dist/context/local-edge-paths.js +11 -0
  267. package/dist/context/local-edge-paths.js.map +1 -0
  268. package/dist/context/local-edge-store.d.ts +115 -0
  269. package/dist/context/local-edge-store.d.ts.map +1 -0
  270. package/dist/context/local-edge-store.js +233 -0
  271. package/dist/context/local-edge-store.js.map +1 -0
  272. package/dist/context/local-edge-sync.d.ts +39 -0
  273. package/dist/context/local-edge-sync.d.ts.map +1 -0
  274. package/dist/context/local-edge-sync.js +192 -0
  275. package/dist/context/local-edge-sync.js.map +1 -0
  276. package/dist/context/local-edge-types.d.ts +309 -0
  277. package/dist/context/local-edge-types.d.ts.map +1 -0
  278. package/dist/context/local-edge-types.js +5 -0
  279. package/dist/context/local-edge-types.js.map +1 -0
  280. package/dist/context-providers/registry.d.ts +5 -0
  281. package/dist/context-providers/registry.d.ts.map +1 -0
  282. package/dist/context-providers/registry.js +10 -0
  283. package/dist/context-providers/registry.js.map +1 -0
  284. package/dist/context-providers/repo-docs-provider.d.ts +19 -0
  285. package/dist/context-providers/repo-docs-provider.d.ts.map +1 -0
  286. package/dist/context-providers/repo-docs-provider.js +188 -0
  287. package/dist/context-providers/repo-docs-provider.js.map +1 -0
  288. package/dist/context-providers/types.d.ts +53 -0
  289. package/dist/context-providers/types.d.ts.map +1 -0
  290. package/dist/context-providers/types.js +2 -0
  291. package/dist/context-providers/types.js.map +1 -0
  292. package/dist/context-providers/viewport-vault-provider.d.ts +3 -0
  293. package/dist/context-providers/viewport-vault-provider.d.ts.map +1 -0
  294. package/dist/context-providers/viewport-vault-provider.js +73 -0
  295. package/dist/context-providers/viewport-vault-provider.js.map +1 -0
  296. package/dist/core/agent-registry.d.ts +2 -0
  297. package/dist/core/agent-registry.d.ts.map +1 -1
  298. package/dist/core/agent-registry.js +1 -1
  299. package/dist/core/agent-registry.js.map +1 -1
  300. package/dist/core/config-schema.d.ts +18 -4
  301. package/dist/core/config-schema.d.ts.map +1 -1
  302. package/dist/core/config-schema.js +16 -4
  303. package/dist/core/config-schema.js.map +1 -1
  304. package/dist/core/config.d.ts +42 -12
  305. package/dist/core/config.d.ts.map +1 -1
  306. package/dist/core/config.js +181 -18
  307. package/dist/core/config.js.map +1 -1
  308. package/dist/core/daemon.d.ts +18 -0
  309. package/dist/core/daemon.d.ts.map +1 -1
  310. package/dist/core/daemon.js +71 -19
  311. package/dist/core/daemon.js.map +1 -1
  312. package/dist/core/discovered-sessions.d.ts.map +1 -1
  313. package/dist/core/discovered-sessions.js +5 -0
  314. package/dist/core/discovered-sessions.js.map +1 -1
  315. package/dist/core/error-codes.d.ts +1 -0
  316. package/dist/core/error-codes.d.ts.map +1 -1
  317. package/dist/core/error-codes.js +1 -0
  318. package/dist/core/error-codes.js.map +1 -1
  319. package/dist/core/errors.js +2 -0
  320. package/dist/core/errors.js.map +1 -1
  321. package/dist/core/events.d.ts +30 -0
  322. package/dist/core/events.d.ts.map +1 -1
  323. package/dist/core/events.js.map +1 -1
  324. package/dist/core/interfaces.d.ts +15 -0
  325. package/dist/core/interfaces.d.ts.map +1 -1
  326. package/dist/core/machine-name.d.ts +3 -0
  327. package/dist/core/machine-name.d.ts.map +1 -0
  328. package/dist/core/machine-name.js +11 -0
  329. package/dist/core/machine-name.js.map +1 -0
  330. package/dist/core/package-meta.d.ts +12 -0
  331. package/dist/core/package-meta.d.ts.map +1 -0
  332. package/dist/core/package-meta.js +87 -0
  333. package/dist/core/package-meta.js.map +1 -0
  334. package/dist/core/runtime-identity.d.ts +45 -0
  335. package/dist/core/runtime-identity.d.ts.map +1 -0
  336. package/dist/core/runtime-identity.js +130 -0
  337. package/dist/core/runtime-identity.js.map +1 -0
  338. package/dist/core/session-context-prompt.d.ts +5 -0
  339. package/dist/core/session-context-prompt.d.ts.map +1 -0
  340. package/dist/core/session-context-prompt.js +85 -0
  341. package/dist/core/session-context-prompt.js.map +1 -0
  342. package/dist/core/session-discovery-runner.d.ts +11 -0
  343. package/dist/core/session-discovery-runner.d.ts.map +1 -0
  344. package/dist/core/session-discovery-runner.js +37 -0
  345. package/dist/core/session-discovery-runner.js.map +1 -0
  346. package/dist/core/session-manager.d.ts +6 -0
  347. package/dist/core/session-manager.d.ts.map +1 -1
  348. package/dist/core/session-manager.js +32 -0
  349. package/dist/core/session-manager.js.map +1 -1
  350. package/dist/core/types.d.ts +2 -0
  351. package/dist/core/types.d.ts.map +1 -1
  352. package/dist/core/workflow-linked-discovery.d.ts +17 -0
  353. package/dist/core/workflow-linked-discovery.d.ts.map +1 -0
  354. package/dist/core/workflow-linked-discovery.js +53 -0
  355. package/dist/core/workflow-linked-discovery.js.map +1 -0
  356. package/dist/directories/manager.d.ts +1 -0
  357. package/dist/directories/manager.d.ts.map +1 -1
  358. package/dist/directories/manager.js +46 -3
  359. package/dist/directories/manager.js.map +1 -1
  360. package/dist/discovery/claude.js +1 -0
  361. package/dist/discovery/claude.js.map +1 -1
  362. package/dist/discovery/codex-parser.d.ts +10 -0
  363. package/dist/discovery/codex-parser.d.ts.map +1 -0
  364. package/dist/discovery/codex-parser.js +246 -0
  365. package/dist/discovery/codex-parser.js.map +1 -0
  366. package/dist/discovery/codex-summary.d.ts +6 -0
  367. package/dist/discovery/codex-summary.d.ts.map +1 -0
  368. package/dist/discovery/codex-summary.js +27 -0
  369. package/dist/discovery/codex-summary.js.map +1 -0
  370. package/dist/discovery/codex.d.ts +23 -2
  371. package/dist/discovery/codex.d.ts.map +1 -1
  372. package/dist/discovery/codex.js +65 -271
  373. package/dist/discovery/codex.js.map +1 -1
  374. package/dist/discovery/dedupe.d.ts +3 -0
  375. package/dist/discovery/dedupe.d.ts.map +1 -0
  376. package/dist/discovery/dedupe.js +13 -0
  377. package/dist/discovery/dedupe.js.map +1 -0
  378. package/dist/discovery/jsonl-entry-parser.d.ts +36 -0
  379. package/dist/discovery/jsonl-entry-parser.d.ts.map +1 -0
  380. package/dist/discovery/jsonl-entry-parser.js +332 -0
  381. package/dist/discovery/jsonl-entry-parser.js.map +1 -0
  382. package/dist/discovery/jsonl-paths.d.ts +17 -0
  383. package/dist/discovery/jsonl-paths.d.ts.map +1 -0
  384. package/dist/discovery/jsonl-paths.js +56 -0
  385. package/dist/discovery/jsonl-paths.js.map +1 -0
  386. package/dist/discovery/jsonl-reader.d.ts +37 -48
  387. package/dist/discovery/jsonl-reader.d.ts.map +1 -1
  388. package/dist/discovery/jsonl-reader.js +103 -315
  389. package/dist/discovery/jsonl-reader.js.map +1 -1
  390. package/dist/hooks/capabilities.d.ts +17 -0
  391. package/dist/hooks/capabilities.d.ts.map +1 -0
  392. package/dist/hooks/capabilities.js +114 -0
  393. package/dist/hooks/capabilities.js.map +1 -0
  394. package/dist/hooks/index.d.ts +2 -0
  395. package/dist/hooks/index.d.ts.map +1 -1
  396. package/dist/hooks/index.js +1 -0
  397. package/dist/hooks/index.js.map +1 -1
  398. package/dist/hooks/plan-extractor.d.ts +20 -0
  399. package/dist/hooks/plan-extractor.d.ts.map +1 -0
  400. package/dist/hooks/plan-extractor.js +123 -0
  401. package/dist/hooks/plan-extractor.js.map +1 -0
  402. package/dist/hooks/platform-plan-sync.d.ts +19 -0
  403. package/dist/hooks/platform-plan-sync.d.ts.map +1 -0
  404. package/dist/hooks/platform-plan-sync.js +57 -0
  405. package/dist/hooks/platform-plan-sync.js.map +1 -0
  406. package/dist/hooks/router.d.ts +1 -0
  407. package/dist/hooks/router.d.ts.map +1 -1
  408. package/dist/hooks/router.js +28 -75
  409. package/dist/hooks/router.js.map +1 -1
  410. package/dist/hooks/specific-events.d.ts +11 -0
  411. package/dist/hooks/specific-events.d.ts.map +1 -0
  412. package/dist/hooks/specific-events.js +125 -0
  413. package/dist/hooks/specific-events.js.map +1 -0
  414. package/dist/hooks/types.d.ts +17 -1
  415. package/dist/hooks/types.d.ts.map +1 -1
  416. package/dist/hooks/types.js +29 -0
  417. package/dist/hooks/types.js.map +1 -1
  418. package/dist/index.d.ts +6 -0
  419. package/dist/index.d.ts.map +1 -1
  420. package/dist/index.js +77 -4
  421. package/dist/index.js.map +1 -1
  422. package/dist/relay/bridge-connections.d.ts +26 -0
  423. package/dist/relay/bridge-connections.d.ts.map +1 -0
  424. package/dist/relay/bridge-connections.js +34 -0
  425. package/dist/relay/bridge-connections.js.map +1 -0
  426. package/dist/relay/bridge-crypto.d.ts +1 -0
  427. package/dist/relay/bridge-crypto.d.ts.map +1 -1
  428. package/dist/relay/bridge-crypto.js +9 -0
  429. package/dist/relay/bridge-crypto.js.map +1 -1
  430. package/dist/relay/bridge-daemon-key-registration.d.ts +16 -0
  431. package/dist/relay/bridge-daemon-key-registration.d.ts.map +1 -0
  432. package/dist/relay/bridge-daemon-key-registration.js +70 -0
  433. package/dist/relay/bridge-daemon-key-registration.js.map +1 -0
  434. package/dist/relay/bridge-errors.d.ts +2 -0
  435. package/dist/relay/bridge-errors.d.ts.map +1 -1
  436. package/dist/relay/bridge-errors.js +14 -0
  437. package/dist/relay/bridge-errors.js.map +1 -1
  438. package/dist/relay/bridge-frame-logger.d.ts +2 -0
  439. package/dist/relay/bridge-frame-logger.d.ts.map +1 -0
  440. package/dist/relay/bridge-frame-logger.js +37 -0
  441. package/dist/relay/bridge-frame-logger.js.map +1 -0
  442. package/dist/relay/bridge-handshake-profile.d.ts +3 -0
  443. package/dist/relay/bridge-handshake-profile.d.ts.map +1 -0
  444. package/dist/relay/bridge-handshake-profile.js +7 -0
  445. package/dist/relay/bridge-handshake-profile.js.map +1 -0
  446. package/dist/relay/bridge-identity-store.d.ts +9 -0
  447. package/dist/relay/bridge-identity-store.d.ts.map +1 -0
  448. package/dist/relay/bridge-identity-store.js +73 -0
  449. package/dist/relay/bridge-identity-store.js.map +1 -0
  450. package/dist/relay/bridge-key-exchange.d.ts +3 -6
  451. package/dist/relay/bridge-key-exchange.d.ts.map +1 -1
  452. package/dist/relay/bridge-key-exchange.js +4 -52
  453. package/dist/relay/bridge-key-exchange.js.map +1 -1
  454. package/dist/relay/bridge-noise-v3.d.ts.map +1 -1
  455. package/dist/relay/bridge-noise-v3.js +7 -4
  456. package/dist/relay/bridge-noise-v3.js.map +1 -1
  457. package/dist/relay/bridge-pairing-channel.d.ts +12 -0
  458. package/dist/relay/bridge-pairing-channel.d.ts.map +1 -0
  459. package/dist/relay/bridge-pairing-channel.js +30 -0
  460. package/dist/relay/bridge-pairing-channel.js.map +1 -0
  461. package/dist/relay/bridge-pairing-control-handler.d.ts +26 -0
  462. package/dist/relay/bridge-pairing-control-handler.d.ts.map +1 -0
  463. package/dist/relay/bridge-pairing-control-handler.js +136 -0
  464. package/dist/relay/bridge-pairing-control-handler.js.map +1 -0
  465. package/dist/relay/bridge-relay-sessions.d.ts +45 -0
  466. package/dist/relay/bridge-relay-sessions.d.ts.map +1 -0
  467. package/dist/relay/bridge-relay-sessions.js +88 -0
  468. package/dist/relay/bridge-relay-sessions.js.map +1 -0
  469. package/dist/relay/bridge-token-issuer.d.ts +32 -0
  470. package/dist/relay/bridge-token-issuer.d.ts.map +1 -0
  471. package/dist/relay/bridge-token-issuer.js +173 -0
  472. package/dist/relay/bridge-token-issuer.js.map +1 -0
  473. package/dist/relay/daemon-relay-bridge.d.ts +7 -11
  474. package/dist/relay/daemon-relay-bridge.d.ts.map +1 -1
  475. package/dist/relay/daemon-relay-bridge.js +67 -531
  476. package/dist/relay/daemon-relay-bridge.js.map +1 -1
  477. package/dist/relay/relay-control-frames.d.ts +31 -0
  478. package/dist/relay/relay-control-frames.d.ts.map +1 -0
  479. package/dist/relay/relay-control-frames.js +65 -0
  480. package/dist/relay/relay-control-frames.js.map +1 -0
  481. package/dist/server/auth.d.ts +3 -2
  482. package/dist/server/auth.d.ts.map +1 -1
  483. package/dist/server/auth.js +5 -3
  484. package/dist/server/auth.js.map +1 -1
  485. package/dist/server/discovered-session-window.d.ts +4 -0
  486. package/dist/server/discovered-session-window.d.ts.map +1 -0
  487. package/dist/server/discovered-session-window.js +5 -0
  488. package/dist/server/discovered-session-window.js.map +1 -0
  489. package/dist/server/hello-builder.d.ts +66 -3
  490. package/dist/server/hello-builder.d.ts.map +1 -1
  491. package/dist/server/hello-builder.js +145 -20
  492. package/dist/server/hello-builder.js.map +1 -1
  493. package/dist/server/http-context-routes.d.ts +3 -0
  494. package/dist/server/http-context-routes.d.ts.map +1 -0
  495. package/dist/server/http-context-routes.js +154 -0
  496. package/dist/server/http-context-routes.js.map +1 -0
  497. package/dist/server/http-health-routes.d.ts +10 -0
  498. package/dist/server/http-health-routes.d.ts.map +1 -0
  499. package/dist/server/http-health-routes.js +58 -0
  500. package/dist/server/http-health-routes.js.map +1 -0
  501. package/dist/server/http-lifecycle-routes.d.ts +6 -0
  502. package/dist/server/http-lifecycle-routes.d.ts.map +1 -0
  503. package/dist/server/http-lifecycle-routes.js +17 -0
  504. package/dist/server/http-lifecycle-routes.js.map +1 -0
  505. package/dist/server/http-pairing-routes.d.ts +14 -0
  506. package/dist/server/http-pairing-routes.d.ts.map +1 -0
  507. package/dist/server/http-pairing-routes.js +110 -0
  508. package/dist/server/http-pairing-routes.js.map +1 -0
  509. package/dist/server/http-request-schemas.d.ts +114 -0
  510. package/dist/server/http-request-schemas.d.ts.map +1 -0
  511. package/dist/server/http-request-schemas.js +137 -0
  512. package/dist/server/http-request-schemas.js.map +1 -0
  513. package/dist/server/http-route-types.d.ts +11 -0
  514. package/dist/server/http-route-types.d.ts.map +1 -0
  515. package/dist/server/http-route-types.js +2 -0
  516. package/dist/server/http-route-types.js.map +1 -0
  517. package/dist/server/http-server.d.ts +4 -15
  518. package/dist/server/http-server.d.ts.map +1 -1
  519. package/dist/server/http-server.js +135 -418
  520. package/dist/server/http-server.js.map +1 -1
  521. package/dist/server/http-session-routes.d.ts +4 -0
  522. package/dist/server/http-session-routes.d.ts.map +1 -0
  523. package/dist/server/http-session-routes.js +234 -0
  524. package/dist/server/http-session-routes.js.map +1 -0
  525. package/dist/server/pairing-file-store.d.ts +10 -0
  526. package/dist/server/pairing-file-store.d.ts.map +1 -0
  527. package/dist/server/pairing-file-store.js +69 -0
  528. package/dist/server/pairing-file-store.js.map +1 -0
  529. package/dist/server/pairing-identity-store.d.ts +5 -0
  530. package/dist/server/pairing-identity-store.d.ts.map +1 -0
  531. package/dist/server/pairing-identity-store.js +121 -0
  532. package/dist/server/pairing-identity-store.js.map +1 -0
  533. package/dist/server/pairing-offer-types.d.ts +98 -0
  534. package/dist/server/pairing-offer-types.d.ts.map +1 -0
  535. package/dist/server/pairing-offer-types.js +2 -0
  536. package/dist/server/pairing-offer-types.js.map +1 -0
  537. package/dist/server/pairing-offers.d.ts +4 -54
  538. package/dist/server/pairing-offers.d.ts.map +1 -1
  539. package/dist/server/pairing-offers.js +24 -409
  540. package/dist/server/pairing-offers.js.map +1 -1
  541. package/dist/server/pairing-peer-bindings.d.ts +18 -0
  542. package/dist/server/pairing-peer-bindings.d.ts.map +1 -0
  543. package/dist/server/pairing-peer-bindings.js +198 -0
  544. package/dist/server/pairing-peer-bindings.js.map +1 -0
  545. package/dist/server/rate-limiter.d.ts.map +1 -1
  546. package/dist/server/rate-limiter.js +4 -1
  547. package/dist/server/rate-limiter.js.map +1 -1
  548. package/dist/server/replay-events.d.ts +6 -0
  549. package/dist/server/replay-events.d.ts.map +1 -0
  550. package/dist/server/replay-events.js +104 -0
  551. package/dist/server/replay-events.js.map +1 -0
  552. package/dist/server/replay-persistence.d.ts +18 -0
  553. package/dist/server/replay-persistence.d.ts.map +1 -0
  554. package/dist/server/replay-persistence.js +123 -0
  555. package/dist/server/replay-persistence.js.map +1 -0
  556. package/dist/server/replay-types.d.ts +25 -0
  557. package/dist/server/replay-types.d.ts.map +1 -0
  558. package/dist/server/replay-types.js +2 -0
  559. package/dist/server/replay-types.js.map +1 -0
  560. package/dist/server/ring-buffer.d.ts +3 -30
  561. package/dist/server/ring-buffer.d.ts.map +1 -1
  562. package/dist/server/ring-buffer.js +10 -221
  563. package/dist/server/ring-buffer.js.map +1 -1
  564. package/dist/server/session-message-reader.d.ts +15 -0
  565. package/dist/server/session-message-reader.d.ts.map +1 -0
  566. package/dist/server/session-message-reader.js +107 -0
  567. package/dist/server/session-message-reader.js.map +1 -0
  568. package/dist/server/ws-command-handlers.d.ts +4 -1
  569. package/dist/server/ws-command-handlers.d.ts.map +1 -1
  570. package/dist/server/ws-command-handlers.js +25 -74
  571. package/dist/server/ws-command-handlers.js.map +1 -1
  572. package/dist/server/ws-daemon-event-bridge.d.ts.map +1 -1
  573. package/dist/server/ws-daemon-event-bridge.js +52 -3
  574. package/dist/server/ws-daemon-event-bridge.js.map +1 -1
  575. package/dist/server/ws-protocol.d.ts +178 -5
  576. package/dist/server/ws-protocol.d.ts.map +1 -1
  577. package/dist/server/ws-protocol.js +114 -5
  578. package/dist/server/ws-protocol.js.map +1 -1
  579. package/dist/server/ws-server.d.ts.map +1 -1
  580. package/dist/server/ws-server.js +1 -0
  581. package/dist/server/ws-server.js.map +1 -1
  582. package/dist/server/ws-session-command-handlers.d.ts +29 -0
  583. package/dist/server/ws-session-command-handlers.d.ts.map +1 -0
  584. package/dist/server/ws-session-command-handlers.js +276 -0
  585. package/dist/server/ws-session-command-handlers.js.map +1 -0
  586. package/dist/server/ws-workflow-command-handlers.d.ts +17 -0
  587. package/dist/server/ws-workflow-command-handlers.d.ts.map +1 -0
  588. package/dist/server/ws-workflow-command-handlers.js +68 -0
  589. package/dist/server/ws-workflow-command-handlers.js.map +1 -0
  590. package/dist/session-enrichment/git.d.ts +9 -0
  591. package/dist/session-enrichment/git.d.ts.map +1 -0
  592. package/dist/session-enrichment/git.js +48 -0
  593. package/dist/session-enrichment/git.js.map +1 -0
  594. package/dist/startup.d.ts +9 -0
  595. package/dist/startup.d.ts.map +1 -1
  596. package/dist/startup.js +109 -49
  597. package/dist/startup.js.map +1 -1
  598. package/dist/workflows/approval-on-reject.d.ts +17 -0
  599. package/dist/workflows/approval-on-reject.d.ts.map +1 -0
  600. package/dist/workflows/approval-on-reject.js +62 -0
  601. package/dist/workflows/approval-on-reject.js.map +1 -0
  602. package/dist/workflows/artifact-collector.d.ts +11 -0
  603. package/dist/workflows/artifact-collector.d.ts.map +1 -0
  604. package/dist/workflows/artifact-collector.js +59 -0
  605. package/dist/workflows/artifact-collector.js.map +1 -0
  606. package/dist/workflows/contract-binding.d.ts +3 -0
  607. package/dist/workflows/contract-binding.d.ts.map +1 -0
  608. package/dist/workflows/contract-binding.js +19 -0
  609. package/dist/workflows/contract-binding.js.map +1 -0
  610. package/dist/workflows/daemon-session.d.ts +36 -0
  611. package/dist/workflows/daemon-session.d.ts.map +1 -0
  612. package/dist/workflows/daemon-session.js +115 -0
  613. package/dist/workflows/daemon-session.js.map +1 -0
  614. package/dist/workflows/event-types.d.ts +10 -0
  615. package/dist/workflows/event-types.d.ts.map +1 -0
  616. package/dist/workflows/event-types.js +2 -0
  617. package/dist/workflows/event-types.js.map +1 -0
  618. package/dist/workflows/expression.d.ts +74 -0
  619. package/dist/workflows/expression.d.ts.map +1 -0
  620. package/dist/workflows/expression.js +132 -0
  621. package/dist/workflows/expression.js.map +1 -0
  622. package/dist/workflows/hook-registry.d.ts +24 -0
  623. package/dist/workflows/hook-registry.d.ts.map +1 -0
  624. package/dist/workflows/hook-registry.js +52 -0
  625. package/dist/workflows/hook-registry.js.map +1 -0
  626. package/dist/workflows/hook-types.d.ts +21 -0
  627. package/dist/workflows/hook-types.d.ts.map +1 -0
  628. package/dist/workflows/hook-types.js +2 -0
  629. package/dist/workflows/hook-types.js.map +1 -0
  630. package/dist/workflows/inline-agent-types.d.ts +21 -0
  631. package/dist/workflows/inline-agent-types.d.ts.map +1 -0
  632. package/dist/workflows/inline-agent-types.js +2 -0
  633. package/dist/workflows/inline-agent-types.js.map +1 -0
  634. package/dist/workflows/inline-agents.d.ts +5 -0
  635. package/dist/workflows/inline-agents.d.ts.map +1 -0
  636. package/dist/workflows/inline-agents.js +89 -0
  637. package/dist/workflows/inline-agents.js.map +1 -0
  638. package/dist/workflows/loop-executor.d.ts +17 -0
  639. package/dist/workflows/loop-executor.d.ts.map +1 -0
  640. package/dist/workflows/loop-executor.js +173 -0
  641. package/dist/workflows/loop-executor.js.map +1 -0
  642. package/dist/workflows/node-executor.d.ts +12 -0
  643. package/dist/workflows/node-executor.d.ts.map +1 -0
  644. package/dist/workflows/node-executor.js +179 -0
  645. package/dist/workflows/node-executor.js.map +1 -0
  646. package/dist/workflows/node-registry.d.ts +42 -0
  647. package/dist/workflows/node-registry.d.ts.map +1 -0
  648. package/dist/workflows/node-registry.js +124 -0
  649. package/dist/workflows/node-registry.js.map +1 -0
  650. package/dist/workflows/parser.d.ts +17 -0
  651. package/dist/workflows/parser.d.ts.map +1 -0
  652. package/dist/workflows/parser.js +250 -0
  653. package/dist/workflows/parser.js.map +1 -0
  654. package/dist/workflows/platform-command-applier.d.ts +11 -0
  655. package/dist/workflows/platform-command-applier.d.ts.map +1 -0
  656. package/dist/workflows/platform-command-applier.js +41 -0
  657. package/dist/workflows/platform-command-applier.js.map +1 -0
  658. package/dist/workflows/platform-runtime-command.d.ts +12 -0
  659. package/dist/workflows/platform-runtime-command.d.ts.map +1 -0
  660. package/dist/workflows/platform-runtime-command.js +37 -0
  661. package/dist/workflows/platform-runtime-command.js.map +1 -0
  662. package/dist/workflows/platform-sync.d.ts +37 -0
  663. package/dist/workflows/platform-sync.d.ts.map +1 -0
  664. package/dist/workflows/platform-sync.js +306 -0
  665. package/dist/workflows/platform-sync.js.map +1 -0
  666. package/dist/workflows/plugin-loader.d.ts +28 -0
  667. package/dist/workflows/plugin-loader.d.ts.map +1 -0
  668. package/dist/workflows/plugin-loader.js +134 -0
  669. package/dist/workflows/plugin-loader.js.map +1 -0
  670. package/dist/workflows/preflight.d.ts +9 -0
  671. package/dist/workflows/preflight.d.ts.map +1 -0
  672. package/dist/workflows/preflight.js +147 -0
  673. package/dist/workflows/preflight.js.map +1 -0
  674. package/dist/workflows/prompt-output.d.ts +6 -0
  675. package/dist/workflows/prompt-output.d.ts.map +1 -0
  676. package/dist/workflows/prompt-output.js +78 -0
  677. package/dist/workflows/prompt-output.js.map +1 -0
  678. package/dist/workflows/retry-classifier.d.ts +18 -0
  679. package/dist/workflows/retry-classifier.d.ts.map +1 -0
  680. package/dist/workflows/retry-classifier.js +30 -0
  681. package/dist/workflows/retry-classifier.js.map +1 -0
  682. package/dist/workflows/review-packet.d.ts +3 -0
  683. package/dist/workflows/review-packet.d.ts.map +1 -0
  684. package/dist/workflows/review-packet.js +149 -0
  685. package/dist/workflows/review-packet.js.map +1 -0
  686. package/dist/workflows/run-types.d.ts +191 -0
  687. package/dist/workflows/run-types.d.ts.map +1 -0
  688. package/dist/workflows/run-types.js +2 -0
  689. package/dist/workflows/run-types.js.map +1 -0
  690. package/dist/workflows/runner-canceler.d.ts +22 -0
  691. package/dist/workflows/runner-canceler.d.ts.map +1 -0
  692. package/dist/workflows/runner-canceler.js +91 -0
  693. package/dist/workflows/runner-canceler.js.map +1 -0
  694. package/dist/workflows/runner-reconciler.d.ts +19 -0
  695. package/dist/workflows/runner-reconciler.d.ts.map +1 -0
  696. package/dist/workflows/runner-reconciler.js +109 -0
  697. package/dist/workflows/runner-reconciler.js.map +1 -0
  698. package/dist/workflows/runner-resumer.d.ts +33 -0
  699. package/dist/workflows/runner-resumer.d.ts.map +1 -0
  700. package/dist/workflows/runner-resumer.js +81 -0
  701. package/dist/workflows/runner-resumer.js.map +1 -0
  702. package/dist/workflows/runner-scheduler.d.ts +35 -0
  703. package/dist/workflows/runner-scheduler.d.ts.map +1 -0
  704. package/dist/workflows/runner-scheduler.js +211 -0
  705. package/dist/workflows/runner-scheduler.js.map +1 -0
  706. package/dist/workflows/runner-shared.d.ts +21 -0
  707. package/dist/workflows/runner-shared.d.ts.map +1 -0
  708. package/dist/workflows/runner-shared.js +59 -0
  709. package/dist/workflows/runner-shared.js.map +1 -0
  710. package/dist/workflows/runner.d.ts +36 -0
  711. package/dist/workflows/runner.d.ts.map +1 -0
  712. package/dist/workflows/runner.js +289 -0
  713. package/dist/workflows/runner.js.map +1 -0
  714. package/dist/workflows/runtime-helpers.d.ts +40 -0
  715. package/dist/workflows/runtime-helpers.d.ts.map +1 -0
  716. package/dist/workflows/runtime-helpers.js +170 -0
  717. package/dist/workflows/runtime-helpers.js.map +1 -0
  718. package/dist/workflows/session-completion.d.ts +7 -0
  719. package/dist/workflows/session-completion.d.ts.map +1 -0
  720. package/dist/workflows/session-completion.js +89 -0
  721. package/dist/workflows/session-completion.js.map +1 -0
  722. package/dist/workflows/session-links.d.ts +21 -0
  723. package/dist/workflows/session-links.d.ts.map +1 -0
  724. package/dist/workflows/session-links.js +77 -0
  725. package/dist/workflows/session-links.js.map +1 -0
  726. package/dist/workflows/session-output.d.ts +21 -0
  727. package/dist/workflows/session-output.d.ts.map +1 -0
  728. package/dist/workflows/session-output.js +75 -0
  729. package/dist/workflows/session-output.js.map +1 -0
  730. package/dist/workflows/shell-abort-registry.d.ts +11 -0
  731. package/dist/workflows/shell-abort-registry.d.ts.map +1 -0
  732. package/dist/workflows/shell-abort-registry.js +35 -0
  733. package/dist/workflows/shell-abort-registry.js.map +1 -0
  734. package/dist/workflows/store.d.ts +14 -0
  735. package/dist/workflows/store.d.ts.map +1 -0
  736. package/dist/workflows/store.js +160 -0
  737. package/dist/workflows/store.js.map +1 -0
  738. package/dist/workflows/structured-outputs.d.ts +19 -0
  739. package/dist/workflows/structured-outputs.d.ts.map +1 -0
  740. package/dist/workflows/structured-outputs.js +95 -0
  741. package/dist/workflows/structured-outputs.js.map +1 -0
  742. package/dist/workflows/subflow-executor.d.ts +15 -0
  743. package/dist/workflows/subflow-executor.d.ts.map +1 -0
  744. package/dist/workflows/subflow-executor.js +177 -0
  745. package/dist/workflows/subflow-executor.js.map +1 -0
  746. package/dist/workflows/trigger-rule.d.ts +22 -0
  747. package/dist/workflows/trigger-rule.d.ts.map +1 -0
  748. package/dist/workflows/trigger-rule.js +57 -0
  749. package/dist/workflows/trigger-rule.js.map +1 -0
  750. package/dist/workflows/types.d.ts +240 -0
  751. package/dist/workflows/types.d.ts.map +1 -0
  752. package/dist/workflows/types.js +2 -0
  753. package/dist/workflows/types.js.map +1 -0
  754. package/dist/workflows/workflow-executor-schema.d.ts +51 -0
  755. package/dist/workflows/workflow-executor-schema.d.ts.map +1 -0
  756. package/dist/workflows/workflow-executor-schema.js +81 -0
  757. package/dist/workflows/workflow-executor-schema.js.map +1 -0
  758. package/dist/workflows/workflow-schema.d.ts +573 -0
  759. package/dist/workflows/workflow-schema.d.ts.map +1 -0
  760. package/dist/workflows/workflow-schema.js +294 -0
  761. package/dist/workflows/workflow-schema.js.map +1 -0
  762. package/dist/workflows/workflow-source.d.ts +3 -0
  763. package/dist/workflows/workflow-source.d.ts.map +1 -0
  764. package/dist/workflows/workflow-source.js +29 -0
  765. package/dist/workflows/workflow-source.js.map +1 -0
  766. package/docs/configuration.md +51 -26
  767. package/docs/developer-workflows.md +18 -2
  768. package/docs/protocol-matrix.json +120 -11
  769. package/docs/releasing.md +19 -51
  770. package/docs/security.md +6 -9
  771. package/docs/testing.md +3 -3
  772. package/node_modules/@viewportai/context-engine/README.md +33 -0
  773. package/node_modules/@viewportai/context-engine/fixtures/protocol-vectors/README.md +37 -0
  774. package/node_modules/@viewportai/context-engine/fixtures/protocol-vectors/bundle-manifest.json +50 -0
  775. package/node_modules/@viewportai/context-engine/fixtures/protocol-vectors/erase-receipt.json +10 -0
  776. package/node_modules/@viewportai/context-engine/fixtures/protocol-vectors/event.json +29 -0
  777. package/node_modules/@viewportai/context-engine/fixtures/protocol-vectors/hpke-key-grant.json +24 -0
  778. package/node_modules/@viewportai/context-engine/fixtures/protocol-vectors/key-grant.json +21 -0
  779. package/node_modules/@viewportai/context-engine/fixtures/protocol-vectors/profile.json +12 -0
  780. package/node_modules/@viewportai/context-engine/fixtures/protocol-vectors/signed-event.json +28 -0
  781. package/node_modules/@viewportai/context-engine/fixtures/protocol-vectors/standalone-decoder.mjs +124 -0
  782. package/node_modules/@viewportai/context-engine/package.json +11 -0
  783. package/node_modules/@viewportai/context-engine/schemas/context_bundle_manifest_v1.schema.json +134 -0
  784. package/node_modules/@viewportai/context-engine/schemas/context_erase_receipt_v1.schema.json +27 -0
  785. package/node_modules/@viewportai/context-engine/schemas/context_event_v1.schema.json +214 -0
  786. package/node_modules/@viewportai/context-engine/schemas/context_key_grant_hpke_draft_01.schema.json +27 -0
  787. package/node_modules/@viewportai/context-engine/schemas/context_key_grant_v1.schema.json +24 -0
  788. package/node_modules/@viewportai/context-engine/schemas/context_profile_v1.schema.json +24 -0
  789. package/node_modules/@viewportai/context-engine/src/cli.js +177 -0
  790. package/node_modules/@viewportai/context-engine/src/crypto/canonical.js +21 -0
  791. package/node_modules/@viewportai/context-engine/src/crypto/envelope.js +37 -0
  792. package/node_modules/@viewportai/context-engine/src/crypto/hpke-grants.js +298 -0
  793. package/node_modules/@viewportai/context-engine/src/crypto/keys.js +122 -0
  794. package/node_modules/@viewportai/context-engine/src/crypto/signatures.js +23 -0
  795. package/node_modules/@viewportai/context-engine/src/index.js +12 -0
  796. package/node_modules/@viewportai/context-engine/src/protocol/schemas.js +50 -0
  797. package/node_modules/@viewportai/context-engine/src/repo/access-model.js +170 -0
  798. package/node_modules/@viewportai/context-engine/src/repo/bundles.js +180 -0
  799. package/node_modules/@viewportai/context-engine/src/repo/candidates.js +205 -0
  800. package/node_modules/@viewportai/context-engine/src/repo/devices.js +141 -0
  801. package/node_modules/@viewportai/context-engine/src/repo/events.js +87 -0
  802. package/node_modules/@viewportai/context-engine/src/repo/files.js +33 -0
  803. package/node_modules/@viewportai/context-engine/src/repo/identities.js +128 -0
  804. package/node_modules/@viewportai/context-engine/src/repo/key-store.js +126 -0
  805. package/node_modules/@viewportai/context-engine/src/repo/materializer.js +299 -0
  806. package/node_modules/@viewportai/context-engine/src/repo/membership.js +177 -0
  807. package/node_modules/@viewportai/context-engine/src/repo/paths.js +25 -0
  808. package/node_modules/@viewportai/context-engine/src/repo/profiles.js +54 -0
  809. package/node_modules/@viewportai/context-engine/src/repo/receipts.js +68 -0
  810. package/node_modules/@viewportai/context-engine/src/repo/sync.js +163 -0
  811. package/node_modules/@viewportai/context-engine/src/repo/users.js +134 -0
  812. package/node_modules/@viewportai/context-engine/src/repo/vault.js +527 -0
  813. package/node_modules/@viewportai/context-engine/src/store/local-semantic.js +69 -0
  814. package/node_modules/@viewportai/context-engine/src/store/search.js +25 -0
  815. package/node_modules/@viewportai/context-engine/src/store/sqlite.js +76 -0
  816. package/package.json +22 -7
  817. package/schemas/viewport-config-v1.schema.json +209 -0
  818. package/schemas/workflow-v1.schema.json +245 -0
@@ -0,0 +1,26 @@
1
+ import type { RelayPairingOfferRequestFrame, RelayPairingRedeemRequestFrame } from './relay-control-frames.js';
2
+ export interface PairingChannelKey {
3
+ key: Buffer;
4
+ createdAt: number;
5
+ }
6
+ export type PairingChannelKeyStore = Map<string, PairingChannelKey>;
7
+ export type RelayPairingControlReply = (payload: Record<string, unknown>) => void;
8
+ interface PairingControlBaseOptions {
9
+ pairingChannelKeys: PairingChannelKeyStore;
10
+ reply: RelayPairingControlReply;
11
+ maxAgeMs: number;
12
+ maxEntries: number;
13
+ }
14
+ interface PairingOfferControlOptions extends PairingControlBaseOptions {
15
+ frame: RelayPairingOfferRequestFrame;
16
+ workspaceId: string;
17
+ daemonWsUrl: string;
18
+ }
19
+ interface PairingRedeemControlOptions extends PairingControlBaseOptions {
20
+ frame: RelayPairingRedeemRequestFrame;
21
+ }
22
+ export declare function handleRelayPairingOfferRequest({ frame, reply, pairingChannelKeys, workspaceId, daemonWsUrl, maxAgeMs, maxEntries, }: PairingOfferControlOptions): Promise<void>;
23
+ export declare function handleRelayPairingRedeemRequest({ frame, reply, pairingChannelKeys, maxAgeMs, maxEntries, }: PairingRedeemControlOptions): Promise<void>;
24
+ export declare function pruneRelayPairingChannelKeys(pairingChannelKeys: PairingChannelKeyStore, now: number, maxAgeMs: number, maxEntries: number): void;
25
+ export {};
26
+ //# sourceMappingURL=bridge-pairing-control-handler.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bridge-pairing-control-handler.d.ts","sourceRoot":"","sources":["../../src/relay/bridge-pairing-control-handler.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EACV,6BAA6B,EAC7B,8BAA8B,EAC/B,MAAM,2BAA2B,CAAC;AAGnC,MAAM,WAAW,iBAAiB;IAChC,GAAG,EAAE,MAAM,CAAC;IACZ,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,MAAM,sBAAsB,GAAG,GAAG,CAAC,MAAM,EAAE,iBAAiB,CAAC,CAAC;AACpE,MAAM,MAAM,wBAAwB,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,IAAI,CAAC;AAElF,UAAU,yBAAyB;IACjC,kBAAkB,EAAE,sBAAsB,CAAC;IAC3C,KAAK,EAAE,wBAAwB,CAAC;IAChC,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,UAAU,0BAA2B,SAAQ,yBAAyB;IACpE,KAAK,EAAE,6BAA6B,CAAC;IACrC,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,UAAU,2BAA4B,SAAQ,yBAAyB;IACrE,KAAK,EAAE,8BAA8B,CAAC;CACvC;AAED,wBAAsB,8BAA8B,CAAC,EACnD,KAAK,EACL,KAAK,EACL,kBAAkB,EAClB,WAAW,EACX,WAAW,EACX,QAAQ,EACR,UAAU,GACX,EAAE,0BAA0B,GAAG,OAAO,CAAC,IAAI,CAAC,CAuD5C;AAED,wBAAsB,+BAA+B,CAAC,EACpD,KAAK,EACL,KAAK,EACL,kBAAkB,EAClB,QAAQ,EACR,UAAU,GACX,EAAE,2BAA2B,GAAG,OAAO,CAAC,IAAI,CAAC,CAgF7C;AAED,wBAAgB,4BAA4B,CAC1C,kBAAkB,EAAE,sBAAsB,EAC1C,GAAG,EAAE,MAAM,EACX,QAAQ,EAAE,MAAM,EAChB,UAAU,EAAE,MAAM,GACjB,IAAI,CAgBN"}
@@ -0,0 +1,136 @@
1
+ import crypto from 'node:crypto';
2
+ import { fromBase64Url, toBase64Url } from './bridge-crypto.js';
3
+ import { decryptPairingPayload, derivePairingChannelKey, encryptPairingPayload, } from './bridge-pairing-channel.js';
4
+ import { issuePairingOffer, redeemPairingOffer } from '../server/pairing-offers.js';
5
+ export async function handleRelayPairingOfferRequest({ frame, reply, pairingChannelKeys, workspaceId, daemonWsUrl, maxAgeMs, maxEntries, }) {
6
+ const requestId = frame.requestId;
7
+ try {
8
+ pruneRelayPairingChannelKeys(pairingChannelKeys, Date.now(), maxAgeMs, maxEntries);
9
+ const clientChannelPublicKey = fromBase64Url(frame.clientChannelPublicKey);
10
+ if (clientChannelPublicKey.length !== 65) {
11
+ throw new Error('invalid clientChannelPublicKey');
12
+ }
13
+ const daemonChannel = crypto.createECDH('prime256v1');
14
+ daemonChannel.generateKeys();
15
+ const shared = daemonChannel.computeSecret(clientChannelPublicKey);
16
+ const channelKey = derivePairingChannelKey(shared, `offer:${frame.requestId}`);
17
+ const daemonUrl = new URL(daemonWsUrl);
18
+ const issued = await issuePairingOffer({
19
+ ttlSeconds: frame.ttlSeconds ?? 600,
20
+ connection: {
21
+ host: daemonUrl.hostname || '127.0.0.1',
22
+ port: daemonUrl.port ? Number(daemonUrl.port) : 7070,
23
+ listen: `relay:${workspaceId}`,
24
+ profile: 'relay',
25
+ },
26
+ });
27
+ pairingChannelKeys.set(issued.offerId, { key: channelKey, createdAt: Date.now() });
28
+ const encryptedOffer = encryptPairingPayload(channelKey, JSON.stringify({
29
+ offerId: issued.offerId,
30
+ createdAt: issued.createdAt,
31
+ expiresAt: issued.expiresAt,
32
+ redeemSecret: issued.redeemSecret,
33
+ trustAnchor: issued.trustAnchor,
34
+ daemonDeviceId: issued.daemonDeviceId,
35
+ daemonPublicKey: issued.daemonPublicKey,
36
+ }), `offer:${frame.requestId}`);
37
+ reply({
38
+ type: 'relay_pairing_offer_response',
39
+ requestId,
40
+ ok: true,
41
+ daemonChannelPublicKey: toBase64Url(daemonChannel.getPublicKey()),
42
+ ...encryptedOffer,
43
+ });
44
+ }
45
+ catch (error) {
46
+ const message = error instanceof Error ? error.message : String(error);
47
+ reply({
48
+ type: 'relay_pairing_offer_response',
49
+ requestId,
50
+ ok: false,
51
+ errorCode: 'PAIRING_OFFER_FAILED',
52
+ error: message,
53
+ });
54
+ }
55
+ }
56
+ export async function handleRelayPairingRedeemRequest({ frame, reply, pairingChannelKeys, maxAgeMs, maxEntries, }) {
57
+ const requestId = frame.requestId;
58
+ try {
59
+ pruneRelayPairingChannelKeys(pairingChannelKeys, Date.now(), maxAgeMs, maxEntries);
60
+ const channel = pairingChannelKeys.get(frame.offerId);
61
+ if (!channel) {
62
+ throw new Error('pairing channel missing or expired');
63
+ }
64
+ const decrypted = decryptPairingPayload(channel.key, {
65
+ encIv: frame.encIv,
66
+ encTag: frame.encTag,
67
+ encCiphertext: frame.encCiphertext,
68
+ }, `redeem:${frame.requestId}:${frame.offerId}`);
69
+ const parsed = JSON.parse(decrypted);
70
+ if (typeof parsed.redeemSecret !== 'string' ||
71
+ typeof parsed.trustAnchor !== 'string' ||
72
+ typeof parsed.clientPublicKey !== 'string' ||
73
+ typeof parsed.clientProof !== 'string' ||
74
+ parsed.redeemSecret.trim().length === 0 ||
75
+ parsed.trustAnchor.trim().length === 0 ||
76
+ parsed.clientPublicKey.trim().length === 0 ||
77
+ parsed.clientProof.trim().length === 0) {
78
+ throw new Error('invalid encrypted pairing payload');
79
+ }
80
+ const redeemed = await redeemPairingOffer(frame.offerId, parsed.redeemSecret, parsed.trustAnchor, parsed.clientPublicKey, parsed.clientProof);
81
+ if (!redeemed) {
82
+ reply({
83
+ type: 'relay_pairing_redeem_response',
84
+ requestId,
85
+ ok: false,
86
+ errorCode: 'PAIRING_REDEEM_FAILED',
87
+ error: 'offer not found or no longer valid',
88
+ });
89
+ return;
90
+ }
91
+ reply({
92
+ type: 'relay_pairing_redeem_response',
93
+ requestId,
94
+ ok: true,
95
+ redeemed: {
96
+ offerId: redeemed.offerId,
97
+ createdAt: redeemed.createdAt,
98
+ expiresAt: redeemed.expiresAt,
99
+ peerId: redeemed.peerId,
100
+ daemonDeviceId: redeemed.daemonDeviceId,
101
+ daemonPublicKey: redeemed.daemonPublicKey,
102
+ relayPairingPeerId: redeemed.relayPairingPeerId,
103
+ serverSignature: redeemed.serverSignature,
104
+ },
105
+ });
106
+ pairingChannelKeys.delete(frame.offerId);
107
+ }
108
+ catch (error) {
109
+ const message = error instanceof Error ? error.message : String(error);
110
+ reply({
111
+ type: 'relay_pairing_redeem_response',
112
+ requestId,
113
+ ok: false,
114
+ errorCode: 'PAIRING_REDEEM_FAILED',
115
+ error: message,
116
+ });
117
+ }
118
+ }
119
+ export function pruneRelayPairingChannelKeys(pairingChannelKeys, now, maxAgeMs, maxEntries) {
120
+ for (const [offerId, channel] of pairingChannelKeys.entries()) {
121
+ if (now - channel.createdAt > maxAgeMs) {
122
+ pairingChannelKeys.delete(offerId);
123
+ }
124
+ }
125
+ const overflow = pairingChannelKeys.size - maxEntries;
126
+ if (overflow <= 0) {
127
+ return;
128
+ }
129
+ const oldest = Array.from(pairingChannelKeys.entries())
130
+ .sort((a, b) => a[1].createdAt - b[1].createdAt)
131
+ .slice(0, overflow);
132
+ for (const [offerId] of oldest) {
133
+ pairingChannelKeys.delete(offerId);
134
+ }
135
+ }
136
+ //# sourceMappingURL=bridge-pairing-control-handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bridge-pairing-control-handler.js","sourceRoot":"","sources":["../../src/relay/bridge-pairing-control-handler.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,45 @@
1
+ import type { RelayHandshakeProfile } from './bridge-key-exchange.js';
2
+ export interface RelaySessionState {
3
+ key: Buffer;
4
+ profile: RelayHandshakeProfile;
5
+ sessionId: string;
6
+ epoch: number;
7
+ txSeq: number;
8
+ rxHighestSeq: number;
9
+ rxSeenSeq: Set<number>;
10
+ lastActivityAt: number;
11
+ keyRotationRequested: boolean;
12
+ }
13
+ export interface RelaySessionSeed {
14
+ key: Buffer;
15
+ profile: RelayHandshakeProfile;
16
+ sessionId: string;
17
+ epoch: number;
18
+ }
19
+ export interface RelaySessionSocket {
20
+ send(payload: string): void;
21
+ }
22
+ export declare function createRelaySessionState(seed: RelaySessionSeed, now?: number): RelaySessionState;
23
+ export declare function acceptInboundRelaySeq(session: RelaySessionState, seq: number): boolean;
24
+ export declare function pruneIdleRelaySessions(sessions: Map<string, RelaySessionState>, now?: number, idleTtlMs?: number): string[];
25
+ export declare function enforceRelaySessionCapacity(options: {
26
+ sessions: Map<string, RelaySessionState>;
27
+ maxEntries: number;
28
+ now?: number;
29
+ idleTtlMs?: number;
30
+ }): string[];
31
+ export declare function sendToRelaySession(options: {
32
+ relayWs: RelaySessionSocket;
33
+ session: RelaySessionState;
34
+ payload: string;
35
+ now?: number;
36
+ }): void;
37
+ export declare function sendToAllRelaySessions(options: {
38
+ relayWs: RelaySessionSocket;
39
+ sessions: Map<string, RelaySessionState>;
40
+ payload: string;
41
+ keyRotateAfterMessages: number;
42
+ now?: number;
43
+ idleTtlMs?: number;
44
+ }): void;
45
+ //# sourceMappingURL=bridge-relay-sessions.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bridge-relay-sessions.d.ts","sourceRoot":"","sources":["../../src/relay/bridge-relay-sessions.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AAGtE,MAAM,WAAW,iBAAiB;IAChC,GAAG,EAAE,MAAM,CAAC;IACZ,OAAO,EAAE,qBAAqB,CAAC;IAC/B,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,YAAY,EAAE,MAAM,CAAC;IACrB,SAAS,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;IACvB,cAAc,EAAE,MAAM,CAAC;IACvB,oBAAoB,EAAE,OAAO,CAAC;CAC/B;AAED,MAAM,WAAW,gBAAgB;IAC/B,GAAG,EAAE,MAAM,CAAC;IACZ,OAAO,EAAE,qBAAqB,CAAC;IAC/B,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,kBAAkB;IACjC,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;CAC7B;AAED,wBAAgB,uBAAuB,CACrC,IAAI,EAAE,gBAAgB,EACtB,GAAG,SAAa,GACf,iBAAiB,CASnB;AAED,wBAAgB,qBAAqB,CAAC,OAAO,EAAE,iBAAiB,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAetF;AAED,wBAAgB,sBAAsB,CACpC,QAAQ,EAAE,GAAG,CAAC,MAAM,EAAE,iBAAiB,CAAC,EACxC,GAAG,SAAa,EAChB,SAAS,SAA4B,GACpC,MAAM,EAAE,CASV;AAED,wBAAgB,2BAA2B,CAAC,OAAO,EAAE;IACnD,QAAQ,EAAE,GAAG,CAAC,MAAM,EAAE,iBAAiB,CAAC,CAAC;IACzC,UAAU,EAAE,MAAM,CAAC;IACnB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,GAAG,MAAM,EAAE,CAWX;AAED,wBAAgB,kBAAkB,CAAC,OAAO,EAAE;IAC1C,OAAO,EAAE,kBAAkB,CAAC;IAC5B,OAAO,EAAE,iBAAiB,CAAC;IAC3B,OAAO,EAAE,MAAM,CAAC;IAChB,GAAG,CAAC,EAAE,MAAM,CAAC;CACd,GAAG,IAAI,CAUP;AAED,wBAAgB,sBAAsB,CAAC,OAAO,EAAE;IAC9C,OAAO,EAAE,kBAAkB,CAAC;IAC5B,QAAQ,EAAE,GAAG,CAAC,MAAM,EAAE,iBAAiB,CAAC,CAAC;IACzC,OAAO,EAAE,MAAM,CAAC;IAChB,sBAAsB,EAAE,MAAM,CAAC;IAC/B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,GAAG,IAAI,CAuBP"}
@@ -0,0 +1,88 @@
1
+ import { RELAY_REPLAY_WINDOW, RELAY_SESSION_IDLE_TTL_MS } from './bridge-constants.js';
2
+ import { encryptEnvelope } from './bridge-crypto.js';
3
+ export function createRelaySessionState(seed, now = Date.now()) {
4
+ return {
5
+ ...seed,
6
+ txSeq: 0,
7
+ rxHighestSeq: 0,
8
+ rxSeenSeq: new Set(),
9
+ lastActivityAt: now,
10
+ keyRotationRequested: false,
11
+ };
12
+ }
13
+ export function acceptInboundRelaySeq(session, seq) {
14
+ if (seq < 1)
15
+ return false;
16
+ if (session.rxSeenSeq.has(seq))
17
+ return false;
18
+ if (seq > session.rxHighestSeq + RELAY_REPLAY_WINDOW)
19
+ return false;
20
+ const minimumAllowed = Math.max(1, session.rxHighestSeq - RELAY_REPLAY_WINDOW + 1);
21
+ if (seq < minimumAllowed)
22
+ return false;
23
+ session.rxSeenSeq.add(seq);
24
+ if (seq > session.rxHighestSeq)
25
+ session.rxHighestSeq = seq;
26
+ const pruneBelow = Math.max(1, session.rxHighestSeq - RELAY_REPLAY_WINDOW + 1);
27
+ for (const seen of session.rxSeenSeq) {
28
+ if (seen < pruneBelow)
29
+ session.rxSeenSeq.delete(seen);
30
+ }
31
+ return true;
32
+ }
33
+ export function pruneIdleRelaySessions(sessions, now = Date.now(), idleTtlMs = RELAY_SESSION_IDLE_TTL_MS) {
34
+ const pruned = [];
35
+ for (const [sessionId, session] of sessions.entries()) {
36
+ if (now - session.lastActivityAt > idleTtlMs) {
37
+ sessions.delete(sessionId);
38
+ pruned.push(sessionId);
39
+ }
40
+ }
41
+ return pruned;
42
+ }
43
+ export function enforceRelaySessionCapacity(options) {
44
+ pruneIdleRelaySessions(options.sessions, options.now, options.idleTtlMs);
45
+ const evicted = [];
46
+ while (options.sessions.size > options.maxEntries) {
47
+ const oldestSessionId = options.sessions.keys().next().value;
48
+ if (!oldestSessionId)
49
+ break;
50
+ options.sessions.delete(oldestSessionId);
51
+ evicted.push(oldestSessionId);
52
+ }
53
+ return evicted;
54
+ }
55
+ export function sendToRelaySession(options) {
56
+ options.session.txSeq += 1;
57
+ options.session.lastActivityAt = options.now ?? Date.now();
58
+ const envelope = encryptEnvelope(options.session.key, options.payload, {
59
+ profile: options.session.profile,
60
+ sessionId: options.session.sessionId,
61
+ epoch: options.session.epoch,
62
+ seq: options.session.txSeq,
63
+ });
64
+ options.relayWs.send(envelope);
65
+ }
66
+ export function sendToAllRelaySessions(options) {
67
+ const now = options.now ?? Date.now();
68
+ pruneIdleRelaySessions(options.sessions, now, options.idleTtlMs);
69
+ for (const session of options.sessions.values()) {
70
+ sendToRelaySession({
71
+ relayWs: options.relayWs,
72
+ session,
73
+ payload: options.payload,
74
+ now,
75
+ });
76
+ if (!session.keyRotationRequested && session.txSeq >= options.keyRotateAfterMessages) {
77
+ const rotateNotice = {
78
+ type: 'relay_key_update_required',
79
+ sessionId: session.sessionId,
80
+ nextEpoch: session.epoch + 1,
81
+ reason: 'message_threshold',
82
+ };
83
+ options.relayWs.send(JSON.stringify(rotateNotice));
84
+ session.keyRotationRequested = true;
85
+ }
86
+ }
87
+ }
88
+ //# sourceMappingURL=bridge-relay-sessions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bridge-relay-sessions.js","sourceRoot":"","sources":["../../src/relay/bridge-relay-sessions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,yBAAyB,EAAE,MAAM,uBAAuB,CAAC;AACvF,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AA2BrD,MAAM,UAAU,uBAAuB,CACrC,IAAsB,EACtB,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE;IAEhB,OAAO;QACL,GAAG,IAAI;QACP,KAAK,EAAE,CAAC;QACR,YAAY,EAAE,CAAC;QACf,SAAS,EAAE,IAAI,GAAG,EAAU;QAC5B,cAAc,EAAE,GAAG;QACnB,oBAAoB,EAAE,KAAK;KAC5B,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,qBAAqB,CAAC,OAA0B,EAAE,GAAW;IAC3E,IAAI,GAAG,GAAG,CAAC;QAAE,OAAO,KAAK,CAAC;IAC1B,IAAI,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC;QAAE,OAAO,KAAK,CAAC;IAC7C,IAAI,GAAG,GAAG,OAAO,CAAC,YAAY,GAAG,mBAAmB;QAAE,OAAO,KAAK,CAAC;IACnE,MAAM,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,CAAC,YAAY,GAAG,mBAAmB,GAAG,CAAC,CAAC,CAAC;IACnF,IAAI,GAAG,GAAG,cAAc;QAAE,OAAO,KAAK,CAAC;IAEvC,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IAC3B,IAAI,GAAG,GAAG,OAAO,CAAC,YAAY;QAAE,OAAO,CAAC,YAAY,GAAG,GAAG,CAAC;IAE3D,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,CAAC,YAAY,GAAG,mBAAmB,GAAG,CAAC,CAAC,CAAC;IAC/E,KAAK,MAAM,IAAI,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;QACrC,IAAI,IAAI,GAAG,UAAU;YAAE,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IACxD,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAED,MAAM,UAAU,sBAAsB,CACpC,QAAwC,EACxC,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,EAChB,SAAS,GAAG,yBAAyB;IAErC,MAAM,MAAM,GAAa,EAAE,CAAC;IAC5B,KAAK,MAAM,CAAC,SAAS,EAAE,OAAO,CAAC,IAAI,QAAQ,CAAC,OAAO,EAAE,EAAE,CAAC;QACtD,IAAI,GAAG,GAAG,OAAO,CAAC,cAAc,GAAG,SAAS,EAAE,CAAC;YAC7C,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;YAC3B,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACzB,CAAC;IACH,CAAC;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,MAAM,UAAU,2BAA2B,CAAC,OAK3C;IACC,sBAAsB,CAAC,OAAO,CAAC,QAAQ,EAAE,OAAO,CAAC,GAAG,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC;IAEzE,MAAM,OAAO,GAAa,EAAE,CAAC;IAC7B,OAAO,OAAO,CAAC,QAAQ,CAAC,IAAI,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;QAClD,MAAM,eAAe,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC;QAC7D,IAAI,CAAC,eAAe;YAAE,MAAM;QAC5B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;QACzC,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IAChC,CAAC;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,OAKlC;IACC,OAAO,CAAC,OAAO,CAAC,KAAK,IAAI,CAAC,CAAC;IAC3B,OAAO,CAAC,OAAO,CAAC,cAAc,GAAG,OAAO,CAAC,GAAG,IAAI,IAAI,CAAC,GAAG,EAAE,CAAC;IAC3D,MAAM,QAAQ,GAAG,eAAe,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,EAAE,OAAO,CAAC,OAAO,EAAE;QACrE,OAAO,EAAE,OAAO,CAAC,OAAO,CAAC,OAAO;QAChC,SAAS,EAAE,OAAO,CAAC,OAAO,CAAC,SAAS;QACpC,KAAK,EAAE,OAAO,CAAC,OAAO,CAAC,KAAK;QAC5B,GAAG,EAAE,OAAO,CAAC,OAAO,CAAC,KAAK;KAC3B,CAAC,CAAC;IACH,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;AACjC,CAAC;AAED,MAAM,UAAU,sBAAsB,CAAC,OAOtC;IACC,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,IAAI,IAAI,CAAC,GAAG,EAAE,CAAC;IACtC,sBAAsB,CAAC,OAAO,CAAC,QAAQ,EAAE,GAAG,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC;IAEjE,KAAK,MAAM,OAAO,IAAI,OAAO,CAAC,QAAQ,CAAC,MAAM,EAAE,EAAE,CAAC;QAChD,kBAAkB,CAAC;YACjB,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,OAAO;YACP,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,GAAG;SACJ,CAAC,CAAC;QAEH,IAAI,CAAC,OAAO,CAAC,oBAAoB,IAAI,OAAO,CAAC,KAAK,IAAI,OAAO,CAAC,sBAAsB,EAAE,CAAC;YACrF,MAAM,YAAY,GAAgC;gBAChD,IAAI,EAAE,2BAA2B;gBACjC,SAAS,EAAE,OAAO,CAAC,SAAS;gBAC5B,SAAS,EAAE,OAAO,CAAC,KAAK,GAAG,CAAC;gBAC5B,MAAM,EAAE,mBAAmB;aAC5B,CAAC;YACF,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,CAAC;YACnD,OAAO,CAAC,oBAAoB,GAAG,IAAI,CAAC;QACtC,CAAC;IACH,CAAC;AACH,CAAC"}
@@ -0,0 +1,32 @@
1
+ import { type RelayHandshakeProfile } from './bridge-key-exchange.js';
2
+ export interface RelayTokenIssuerOptions {
3
+ relayServerUrl: string;
4
+ workspaceId: string;
5
+ runtimeTargetId?: string;
6
+ relayTlsVerify?: 'auto' | '0' | '1';
7
+ relayCaCertPath?: string;
8
+ relayTlsPins?: string[];
9
+ relayTokenIssuer?: string;
10
+ relayTokenAudience?: string;
11
+ relayTokenJwksUrl?: string;
12
+ relayTokenSigningKeys?: Record<string, string>;
13
+ relayTokenClockSkewSec?: number;
14
+ }
15
+ export declare class RelayTokenIssuer {
16
+ private readonly options;
17
+ private daemonIssueToken;
18
+ private readonly relayTokenJwksUrl;
19
+ private readonly relayTokenSigningKeys;
20
+ private jwksCacheExpiresAt;
21
+ private jwksCacheKeys;
22
+ constructor(options: RelayTokenIssuerOptions, daemonIssueToken: string | null);
23
+ setDaemonIssueToken(token: string | null): void;
24
+ issue(): Promise<{
25
+ relayToken: string;
26
+ profile: RelayHandshakeProfile;
27
+ }>;
28
+ private verifyIssueResponseToken;
29
+ private verifyTokenClaims;
30
+ private resolveRelayTokenVerificationKeys;
31
+ }
32
+ //# sourceMappingURL=bridge-token-issuer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bridge-token-issuer.d.ts","sourceRoot":"","sources":["../../src/relay/bridge-token-issuer.ts"],"names":[],"mappings":"AAIA,OAAO,EAA8B,KAAK,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AAclG,MAAM,WAAW,uBAAuB;IACtC,cAAc,EAAE,MAAM,CAAC;IACvB,WAAW,EAAE,MAAM,CAAC;IACpB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,cAAc,CAAC,EAAE,MAAM,GAAG,GAAG,GAAG,GAAG,CAAC;IACpC,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IACxB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,qBAAqB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC/C,sBAAsB,CAAC,EAAE,MAAM,CAAC;CACjC;AAED,qBAAa,gBAAgB;IAOzB,OAAO,CAAC,QAAQ,CAAC,OAAO;IACxB,OAAO,CAAC,gBAAgB;IAP1B,OAAO,CAAC,QAAQ,CAAC,iBAAiB,CAAqB;IACvD,OAAO,CAAC,QAAQ,CAAC,qBAAqB,CAAyB;IAC/D,OAAO,CAAC,kBAAkB,CAAK;IAC/B,OAAO,CAAC,aAAa,CAA8B;gBAGhC,OAAO,EAAE,uBAAuB,EACzC,gBAAgB,EAAE,MAAM,GAAG,IAAI;IAMzC,mBAAmB,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,GAAG,IAAI;IAIzC,KAAK,IAAI,OAAO,CAAC;QACrB,UAAU,EAAE,MAAM,CAAC;QACnB,OAAO,EAAE,qBAAqB,CAAC;KAChC,CAAC;YAkDY,wBAAwB;IAkBtC,OAAO,CAAC,iBAAiB;YAYX,iCAAiC;CAqDhD"}
@@ -0,0 +1,173 @@
1
+ import crypto from 'node:crypto';
2
+ import { transportFetch } from '../cli/network.js';
3
+ import { BridgeError } from './bridge-errors.js';
4
+ import { verifyRelayTokenClaims } from './bridge-jwt.js';
5
+ import { parseRelayHandshakeProfile } from './bridge-key-exchange.js';
6
+ const MAX_JWKS_KEYS = 64;
7
+ export class RelayTokenIssuer {
8
+ options;
9
+ daemonIssueToken;
10
+ relayTokenJwksUrl;
11
+ relayTokenSigningKeys;
12
+ jwksCacheExpiresAt = 0;
13
+ jwksCacheKeys = {};
14
+ constructor(options, daemonIssueToken) {
15
+ this.options = options;
16
+ this.daemonIssueToken = daemonIssueToken;
17
+ this.relayTokenJwksUrl = options.relayTokenJwksUrl;
18
+ this.relayTokenSigningKeys = options.relayTokenSigningKeys ?? {};
19
+ }
20
+ setDaemonIssueToken(token) {
21
+ this.daemonIssueToken = token;
22
+ }
23
+ async issue() {
24
+ const url = `${this.options.relayServerUrl.replace(/\/+$/, '')}/api/runtime/relay-token`;
25
+ const controller = new AbortController();
26
+ const timeout = setTimeout(() => controller.abort(), 8_000);
27
+ let res;
28
+ if (!this.daemonIssueToken) {
29
+ throw new BridgeError('TOKEN_ISSUE_FAILED', 'missing daemon issue token');
30
+ }
31
+ try {
32
+ res = await transportFetch(url, {
33
+ method: 'POST',
34
+ headers: { 'content-type': 'application/json' },
35
+ body: JSON.stringify({
36
+ role: 'workspace-daemon',
37
+ workspaceId: this.options.workspaceId,
38
+ runtimeTargetId: this.options.runtimeTargetId,
39
+ credential: this.daemonIssueToken,
40
+ }),
41
+ signal: controller.signal,
42
+ tlsVerify: this.options.relayTlsVerify ?? 'auto',
43
+ caCertPath: this.options.relayCaCertPath,
44
+ tlsPins: this.options.relayTlsPins,
45
+ });
46
+ }
47
+ catch (error) {
48
+ clearTimeout(timeout);
49
+ throw new BridgeError('TOKEN_ISSUE_FAILED', error instanceof Error ? error.message : String(error));
50
+ }
51
+ clearTimeout(timeout);
52
+ const parsed = await parseRelayIssueResponse(res);
53
+ if (!res.ok || !parsed.ok || !parsed.relayToken) {
54
+ const reason = parsed.reason ?? parsed.error ?? `HTTP ${res.status}`;
55
+ throw new BridgeError('TOKEN_ISSUE_FAILED', `issue relay token failed: ${reason}`);
56
+ }
57
+ const tokenClaims = await this.verifyIssueResponseToken(parsed.relayToken);
58
+ const profile = parseRelayHandshakeProfile(tokenClaims.e2eeProfile ?? 'noise-ik');
59
+ if (!profile) {
60
+ throw new BridgeError('TOKEN_RESPONSE_INVALID', 'missing/invalid e2eeProfile claim');
61
+ }
62
+ return {
63
+ relayToken: parsed.relayToken,
64
+ profile,
65
+ };
66
+ }
67
+ async verifyIssueResponseToken(relayToken) {
68
+ let verificationKeys = await this.resolveRelayTokenVerificationKeys(false);
69
+ try {
70
+ return this.verifyTokenClaims(relayToken, verificationKeys);
71
+ }
72
+ catch (error) {
73
+ if (this.relayTokenJwksUrl &&
74
+ error instanceof BridgeError &&
75
+ error.code === 'TOKEN_RESPONSE_INVALID' &&
76
+ error.message.includes('is not trusted')) {
77
+ verificationKeys = await this.resolveRelayTokenVerificationKeys(true);
78
+ return this.verifyTokenClaims(relayToken, verificationKeys);
79
+ }
80
+ throw error;
81
+ }
82
+ }
83
+ verifyTokenClaims(relayToken, signingKeys) {
84
+ return verifyRelayTokenClaims(relayToken, {
85
+ issuer: this.options.relayTokenIssuer ?? 'viewport-server',
86
+ audience: this.options.relayTokenAudience ?? 'viewport-relay',
87
+ signingKeys,
88
+ clockSkewSec: this.options.relayTokenClockSkewSec ?? 30,
89
+ });
90
+ }
91
+ async resolveRelayTokenVerificationKeys(forceRefresh) {
92
+ if (!this.relayTokenJwksUrl) {
93
+ return this.relayTokenSigningKeys;
94
+ }
95
+ const now = Date.now();
96
+ if (!forceRefresh && now < this.jwksCacheExpiresAt && Object.keys(this.jwksCacheKeys).length) {
97
+ return this.jwksCacheKeys;
98
+ }
99
+ const controller = new AbortController();
100
+ const timeout = setTimeout(() => controller.abort(), 8_000);
101
+ let res;
102
+ try {
103
+ res = await transportFetch(this.relayTokenJwksUrl, {
104
+ method: 'GET',
105
+ headers: { accept: 'application/json' },
106
+ signal: controller.signal,
107
+ tlsVerify: this.options.relayTlsVerify ?? 'auto',
108
+ caCertPath: this.options.relayCaCertPath,
109
+ tlsPins: this.options.relayTlsPins,
110
+ });
111
+ }
112
+ catch (error) {
113
+ clearTimeout(timeout);
114
+ throw new BridgeError('TOKEN_RESPONSE_INVALID', `failed to fetch JWKS: ${error instanceof Error ? error.message : String(error)}`);
115
+ }
116
+ clearTimeout(timeout);
117
+ if (!res.ok) {
118
+ throw new BridgeError('TOKEN_RESPONSE_INVALID', `JWKS endpoint returned HTTP ${res.status}`);
119
+ }
120
+ const parsed = (await res.json().catch(() => null));
121
+ if (!parsed || !Array.isArray(parsed.keys)) {
122
+ throw new BridgeError('TOKEN_RESPONSE_INVALID', 'JWKS response missing keys array');
123
+ }
124
+ if (parsed.keys.length > MAX_JWKS_KEYS) {
125
+ throw new BridgeError('TOKEN_RESPONSE_INVALID', `JWKS response contains too many keys (${parsed.keys.length} > ${MAX_JWKS_KEYS})`);
126
+ }
127
+ const keys = parseJwksSigningKeys(parsed.keys);
128
+ this.jwksCacheKeys = keys;
129
+ this.jwksCacheExpiresAt = Date.now() + 5 * 60_000;
130
+ return keys;
131
+ }
132
+ }
133
+ async function parseRelayIssueResponse(res) {
134
+ const json = (await res.json().catch(() => null));
135
+ if (!json) {
136
+ return {
137
+ ok: false,
138
+ reason: `relay token endpoint returned non-JSON (${res.status})`,
139
+ };
140
+ }
141
+ return json;
142
+ }
143
+ function parseJwksSigningKeys(entries) {
144
+ const keys = {};
145
+ for (const entry of entries) {
146
+ if (!entry || typeof entry !== 'object' || Array.isArray(entry))
147
+ continue;
148
+ const kid = typeof entry['kid'] === 'string' ? entry['kid'].trim() : '';
149
+ const kty = typeof entry['kty'] === 'string' ? entry['kty'] : '';
150
+ const alg = typeof entry['alg'] === 'string' ? entry['alg'] : '';
151
+ const n = typeof entry['n'] === 'string' ? entry['n'] : '';
152
+ const e = typeof entry['e'] === 'string' ? entry['e'] : '';
153
+ if (!kid || kty !== 'RSA' || !n || !e)
154
+ continue;
155
+ if (alg && alg !== 'RS256')
156
+ continue;
157
+ try {
158
+ const keyObject = crypto.createPublicKey({
159
+ key: { kty: 'RSA', n, e },
160
+ format: 'jwk',
161
+ });
162
+ keys[kid] = keyObject.export({ format: 'pem', type: 'spki' }).toString();
163
+ }
164
+ catch {
165
+ continue;
166
+ }
167
+ }
168
+ if (Object.keys(keys).length === 0) {
169
+ throw new BridgeError('TOKEN_RESPONSE_INVALID', 'JWKS contained no usable signing keys');
170
+ }
171
+ return keys;
172
+ }
173
+ //# sourceMappingURL=bridge-token-issuer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bridge-token-issuer.js","sourceRoot":"","sources":["../../src/relay/bridge-token-issuer.ts"],"names":[],"mappings":"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"}
@@ -5,10 +5,14 @@ export interface DaemonRelayBridgeOptions {
5
5
  relayEndpoint: string;
6
6
  relayServerUrl: string;
7
7
  workspaceId: string;
8
- enrollToken: string;
8
+ runtimeTargetId?: string;
9
+ machineId?: string;
9
10
  issueToken?: string;
10
11
  daemonWsUrl: string;
11
12
  daemonAuthToken?: string;
13
+ daemonTlsVerify?: 'auto' | '0' | '1';
14
+ daemonCaCertPath?: string;
15
+ daemonTlsPins?: string[];
12
16
  relayTlsVerify?: 'auto' | '0' | '1';
13
17
  relayCaCertPath?: string;
14
18
  relayTlsPins?: string[];
@@ -46,10 +50,7 @@ export declare class DaemonRelayBridge {
46
50
  private daemonIdentity;
47
51
  private daemonIssueToken;
48
52
  private requiredProfile;
49
- private readonly relayTokenJwksUrl;
50
- private readonly relayTokenSigningKeys;
51
- private jwksCacheExpiresAt;
52
- private jwksCacheKeys;
53
+ private readonly relayTokenIssuer;
53
54
  private readonly relaySessions;
54
55
  private readonly pairingChannelKeys;
55
56
  private consecutiveIssueFailures;
@@ -69,24 +70,19 @@ export declare class DaemonRelayBridge {
69
70
  stop(): Promise<void>;
70
71
  private ensureKeyMaterial;
71
72
  private registerDaemonPublicKey;
72
- private persistIssueToken;
73
73
  private connectLoop;
74
74
  private installSocketHandlers;
75
75
  private sendToAllRelaySessions;
76
- private acceptInboundSeq;
77
- private pruneIdleSessions;
78
76
  private enforceRelaySessionCapacity;
79
77
  private handleRelayControlFrame;
80
78
  private handleKeyExchangeInit;
81
79
  private handleKeyExchangeInitV3;
82
80
  private handlePairingOfferRequest;
83
81
  private handlePairingRedeemRequest;
84
- private prunePairingChannelKeys;
82
+ prunePairingChannelKeys(now?: number, maxAgeMs?: number, maxEntries?: number): void;
85
83
  private flushPendingOutbound;
86
84
  private resolvePolicyCPairingSecret;
87
85
  private issueRelayToken;
88
- private resolveRelayTokenVerificationKeys;
89
- private normalizeError;
90
86
  private recordError;
91
87
  private reportStatus;
92
88
  }
@@ -1 +1 @@
1
- {"version":3,"file":"daemon-relay-bridge.d.ts","sourceRoot":"","sources":["../../src/relay/daemon-relay-bridge.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"daemon-relay-bridge.d.ts","sourceRoot":"","sources":["../../src/relay/daemon-relay-bridge.ts"],"names":[],"mappings":"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"}