@cavi-ai/api-client 0.1.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 (665) hide show
  1. package/ARCHITECTURE.md +12 -0
  2. package/CHANGELOG.md +80 -0
  3. package/CONTRIBUTING.md +158 -0
  4. package/LICENSE +21 -0
  5. package/README.md +618 -0
  6. package/SECURITY.md +48 -0
  7. package/dist/contracts/index.d.ts +5 -0
  8. package/dist/contracts/index.d.ts.map +1 -0
  9. package/dist/contracts/index.js +4 -0
  10. package/dist/contracts/paths.d.ts +154 -0
  11. package/dist/contracts/paths.d.ts.map +1 -0
  12. package/dist/contracts/paths.js +89 -0
  13. package/dist/contracts/resolve.d.ts +7 -0
  14. package/dist/contracts/resolve.d.ts.map +1 -0
  15. package/dist/contracts/resolve.js +22 -0
  16. package/dist/contracts/surfaces.d.ts +13 -0
  17. package/dist/contracts/surfaces.d.ts.map +1 -0
  18. package/dist/contracts/surfaces.js +332 -0
  19. package/dist/contracts/team-manifest.d.ts +200 -0
  20. package/dist/contracts/team-manifest.d.ts.map +1 -0
  21. package/dist/contracts/team-manifest.js +951 -0
  22. package/dist/core/data/guards.d.ts +6 -0
  23. package/dist/core/data/guards.d.ts.map +1 -0
  24. package/dist/core/data/guards.js +22 -0
  25. package/dist/core/data/index.d.ts +2 -0
  26. package/dist/core/data/index.d.ts.map +1 -0
  27. package/dist/core/data/index.js +1 -0
  28. package/dist/core/env/config.d.ts +40 -0
  29. package/dist/core/env/config.d.ts.map +1 -0
  30. package/dist/core/env/config.js +44 -0
  31. package/dist/core/env/index.d.ts +3 -0
  32. package/dist/core/env/index.d.ts.map +1 -0
  33. package/dist/core/env/index.js +2 -0
  34. package/dist/core/env/repo-root.d.ts +11 -0
  35. package/dist/core/env/repo-root.d.ts.map +1 -0
  36. package/dist/core/env/repo-root.js +36 -0
  37. package/dist/core/gateway/agent/commands.d.ts +93 -0
  38. package/dist/core/gateway/agent/commands.d.ts.map +1 -0
  39. package/dist/core/gateway/agent/commands.js +351 -0
  40. package/dist/core/gateway/agent/config.d.ts +158 -0
  41. package/dist/core/gateway/agent/config.d.ts.map +1 -0
  42. package/dist/core/gateway/agent/config.js +536 -0
  43. package/dist/core/gateway/agent/index.d.ts +4 -0
  44. package/dist/core/gateway/agent/index.d.ts.map +1 -0
  45. package/dist/core/gateway/agent/index.js +3 -0
  46. package/dist/core/gateway/agent/voice-config.d.ts +20 -0
  47. package/dist/core/gateway/agent/voice-config.d.ts.map +1 -0
  48. package/dist/core/gateway/agent/voice-config.js +65 -0
  49. package/dist/core/gateway/client/capabilities.d.ts +28 -0
  50. package/dist/core/gateway/client/capabilities.d.ts.map +1 -0
  51. package/dist/core/gateway/client/capabilities.js +288 -0
  52. package/dist/core/gateway/client/client.d.ts +106 -0
  53. package/dist/core/gateway/client/client.d.ts.map +1 -0
  54. package/dist/core/gateway/client/client.js +41 -0
  55. package/dist/core/gateway/client/error-details.d.ts +17 -0
  56. package/dist/core/gateway/client/error-details.d.ts.map +1 -0
  57. package/dist/core/gateway/client/error-details.js +50 -0
  58. package/dist/core/gateway/client/fetch.d.ts +24 -0
  59. package/dist/core/gateway/client/fetch.d.ts.map +1 -0
  60. package/dist/core/gateway/client/fetch.js +98 -0
  61. package/dist/core/gateway/client/index.d.ts +6 -0
  62. package/dist/core/gateway/client/index.d.ts.map +1 -0
  63. package/dist/core/gateway/client/index.js +5 -0
  64. package/dist/core/gateway/client/runtime-targets.d.ts +11 -0
  65. package/dist/core/gateway/client/runtime-targets.d.ts.map +1 -0
  66. package/dist/core/gateway/client/runtime-targets.js +86 -0
  67. package/dist/core/gateway/envelope/envelope.d.ts +25 -0
  68. package/dist/core/gateway/envelope/envelope.d.ts.map +1 -0
  69. package/dist/core/gateway/envelope/envelope.js +141 -0
  70. package/dist/core/gateway/envelope/index.d.ts +3 -0
  71. package/dist/core/gateway/envelope/index.d.ts.map +1 -0
  72. package/dist/core/gateway/envelope/index.js +1 -0
  73. package/dist/core/gateway/envelope/types.d.ts +32 -0
  74. package/dist/core/gateway/envelope/types.d.ts.map +1 -0
  75. package/dist/core/gateway/envelope/types.js +1 -0
  76. package/dist/core/gateway/index.d.ts +11 -0
  77. package/dist/core/gateway/index.d.ts.map +1 -0
  78. package/dist/core/gateway/index.js +10 -0
  79. package/dist/core/gateway/jobs.d.ts +44 -0
  80. package/dist/core/gateway/jobs.d.ts.map +1 -0
  81. package/dist/core/gateway/jobs.js +104 -0
  82. package/dist/core/gateway/portal/config-patch.d.ts +42 -0
  83. package/dist/core/gateway/portal/config-patch.d.ts.map +1 -0
  84. package/dist/core/gateway/portal/config-patch.js +99 -0
  85. package/dist/core/gateway/portal/index.d.ts +2 -0
  86. package/dist/core/gateway/portal/index.d.ts.map +1 -0
  87. package/dist/core/gateway/portal/index.js +1 -0
  88. package/dist/core/gateway/providers/factory.d.ts +18 -0
  89. package/dist/core/gateway/providers/factory.d.ts.map +1 -0
  90. package/dist/core/gateway/providers/factory.js +40 -0
  91. package/dist/core/gateway/providers/index.d.ts +5 -0
  92. package/dist/core/gateway/providers/index.d.ts.map +1 -0
  93. package/dist/core/gateway/providers/index.js +4 -0
  94. package/dist/core/gateway/providers/normalize.d.ts +2 -0
  95. package/dist/core/gateway/providers/normalize.d.ts.map +1 -0
  96. package/dist/core/gateway/providers/normalize.js +6 -0
  97. package/dist/core/gateway/providers/registry.d.ts +5 -0
  98. package/dist/core/gateway/providers/registry.d.ts.map +1 -0
  99. package/dist/core/gateway/providers/registry.js +76 -0
  100. package/dist/core/gateway/providers/types.d.ts +42 -0
  101. package/dist/core/gateway/providers/types.d.ts.map +1 -0
  102. package/dist/core/gateway/providers/types.js +4 -0
  103. package/dist/core/gateway/resources/index.d.ts +3 -0
  104. package/dist/core/gateway/resources/index.d.ts.map +1 -0
  105. package/dist/core/gateway/resources/index.js +2 -0
  106. package/dist/core/gateway/resources/media.d.ts +165 -0
  107. package/dist/core/gateway/resources/media.d.ts.map +1 -0
  108. package/dist/core/gateway/resources/media.js +170 -0
  109. package/dist/core/gateway/resources/wiki.d.ts +136 -0
  110. package/dist/core/gateway/resources/wiki.d.ts.map +1 -0
  111. package/dist/core/gateway/resources/wiki.js +72 -0
  112. package/dist/core/gateway/rpc/client.d.ts +150 -0
  113. package/dist/core/gateway/rpc/client.d.ts.map +1 -0
  114. package/dist/core/gateway/rpc/client.js +675 -0
  115. package/dist/core/gateway/rpc/device-crypto.d.ts +19 -0
  116. package/dist/core/gateway/rpc/device-crypto.d.ts.map +1 -0
  117. package/dist/core/gateway/rpc/device-crypto.js +75 -0
  118. package/dist/core/gateway/rpc/device-store.d.ts +8 -0
  119. package/dist/core/gateway/rpc/device-store.d.ts.map +1 -0
  120. package/dist/core/gateway/rpc/device-store.js +113 -0
  121. package/dist/core/gateway/rpc/error.d.ts +5 -0
  122. package/dist/core/gateway/rpc/error.d.ts.map +1 -0
  123. package/dist/core/gateway/rpc/error.js +9 -0
  124. package/dist/core/gateway/rpc/index.d.ts +6 -0
  125. package/dist/core/gateway/rpc/index.d.ts.map +1 -0
  126. package/dist/core/gateway/rpc/index.js +5 -0
  127. package/dist/core/gateway/rpc/preauth-handshake.d.ts +39 -0
  128. package/dist/core/gateway/rpc/preauth-handshake.d.ts.map +1 -0
  129. package/dist/core/gateway/rpc/preauth-handshake.js +58 -0
  130. package/dist/core/gateway/run/contracts.d.ts +126 -0
  131. package/dist/core/gateway/run/contracts.d.ts.map +1 -0
  132. package/dist/core/gateway/run/contracts.js +23 -0
  133. package/dist/core/gateway/run/event-stream.d.ts +106 -0
  134. package/dist/core/gateway/run/event-stream.d.ts.map +1 -0
  135. package/dist/core/gateway/run/event-stream.js +264 -0
  136. package/dist/core/gateway/run/index.d.ts +5 -0
  137. package/dist/core/gateway/run/index.d.ts.map +1 -0
  138. package/dist/core/gateway/run/index.js +4 -0
  139. package/dist/core/gateway/run/sse-run-event-provider.d.ts +55 -0
  140. package/dist/core/gateway/run/sse-run-event-provider.d.ts.map +1 -0
  141. package/dist/core/gateway/run/sse-run-event-provider.js +394 -0
  142. package/dist/core/gateway/run/stream-failure.d.ts +11 -0
  143. package/dist/core/gateway/run/stream-failure.d.ts.map +1 -0
  144. package/dist/core/gateway/run/stream-failure.js +101 -0
  145. package/dist/core/gateway/snapshots/cache.d.ts +7 -0
  146. package/dist/core/gateway/snapshots/cache.d.ts.map +1 -0
  147. package/dist/core/gateway/snapshots/cache.js +13 -0
  148. package/dist/core/gateway/snapshots/contracts.d.ts +279 -0
  149. package/dist/core/gateway/snapshots/contracts.d.ts.map +1 -0
  150. package/dist/core/gateway/snapshots/contracts.js +1 -0
  151. package/dist/core/gateway/snapshots/index.d.ts +7 -0
  152. package/dist/core/gateway/snapshots/index.d.ts.map +1 -0
  153. package/dist/core/gateway/snapshots/index.js +6 -0
  154. package/dist/core/gateway/snapshots/loaders.d.ts +76 -0
  155. package/dist/core/gateway/snapshots/loaders.d.ts.map +1 -0
  156. package/dist/core/gateway/snapshots/loaders.js +515 -0
  157. package/dist/core/gateway/snapshots/session-loaders.d.ts +116 -0
  158. package/dist/core/gateway/snapshots/session-loaders.d.ts.map +1 -0
  159. package/dist/core/gateway/snapshots/session-loaders.js +310 -0
  160. package/dist/core/gateway/snapshots/system-loaders.d.ts +16 -0
  161. package/dist/core/gateway/snapshots/system-loaders.d.ts.map +1 -0
  162. package/dist/core/gateway/snapshots/system-loaders.js +61 -0
  163. package/dist/core/gateway/snapshots/transforms.d.ts +38 -0
  164. package/dist/core/gateway/snapshots/transforms.d.ts.map +1 -0
  165. package/dist/core/gateway/snapshots/transforms.js +328 -0
  166. package/dist/core/http/client-id.d.ts +6 -0
  167. package/dist/core/http/client-id.d.ts.map +1 -0
  168. package/dist/core/http/client-id.js +29 -0
  169. package/dist/core/http/client.d.ts +25 -0
  170. package/dist/core/http/client.d.ts.map +1 -0
  171. package/dist/core/http/client.js +234 -0
  172. package/dist/core/http/contracts.d.ts +3 -0
  173. package/dist/core/http/contracts.d.ts.map +1 -0
  174. package/dist/core/http/contracts.js +5 -0
  175. package/dist/core/http/errors.d.ts +17 -0
  176. package/dist/core/http/errors.d.ts.map +1 -0
  177. package/dist/core/http/errors.js +16 -0
  178. package/dist/core/http/gateway-error.d.ts +15 -0
  179. package/dist/core/http/gateway-error.d.ts.map +1 -0
  180. package/dist/core/http/gateway-error.js +15 -0
  181. package/dist/core/http/index.d.ts +10 -0
  182. package/dist/core/http/index.d.ts.map +1 -0
  183. package/dist/core/http/index.js +9 -0
  184. package/dist/core/http/json-client.d.ts +17 -0
  185. package/dist/core/http/json-client.d.ts.map +1 -0
  186. package/dist/core/http/json-client.js +62 -0
  187. package/dist/core/http/raw-client.d.ts +16 -0
  188. package/dist/core/http/raw-client.d.ts.map +1 -0
  189. package/dist/core/http/raw-client.js +36 -0
  190. package/dist/core/http/redaction.d.ts +20 -0
  191. package/dist/core/http/redaction.d.ts.map +1 -0
  192. package/dist/core/http/redaction.js +58 -0
  193. package/dist/core/http/types.d.ts +44 -0
  194. package/dist/core/http/types.d.ts.map +1 -0
  195. package/dist/core/http/types.js +3 -0
  196. package/dist/core/runtime/index.d.ts +2 -0
  197. package/dist/core/runtime/index.d.ts.map +1 -0
  198. package/dist/core/runtime/index.js +1 -0
  199. package/dist/core/runtime/paths.d.ts +5 -0
  200. package/dist/core/runtime/paths.d.ts.map +1 -0
  201. package/dist/core/runtime/paths.js +29 -0
  202. package/dist/core/sse/index.d.ts +2 -0
  203. package/dist/core/sse/index.d.ts.map +1 -0
  204. package/dist/core/sse/index.js +1 -0
  205. package/dist/core/sse/stream.d.ts +17 -0
  206. package/dist/core/sse/stream.d.ts.map +1 -0
  207. package/dist/core/sse/stream.js +106 -0
  208. package/dist/core/ws/close.d.ts +11 -0
  209. package/dist/core/ws/close.d.ts.map +1 -0
  210. package/dist/core/ws/close.js +34 -0
  211. package/dist/core/ws/gateway-websocket.d.ts +2 -0
  212. package/dist/core/ws/gateway-websocket.d.ts.map +1 -0
  213. package/dist/core/ws/gateway-websocket.js +1 -0
  214. package/dist/core/ws/index.d.ts +4 -0
  215. package/dist/core/ws/index.d.ts.map +1 -0
  216. package/dist/core/ws/index.js +3 -0
  217. package/dist/core/ws/targets.d.ts +21 -0
  218. package/dist/core/ws/targets.d.ts.map +1 -0
  219. package/dist/core/ws/targets.js +61 -0
  220. package/dist/extensions/cavi/adapters/cavi-control-adapters/gateway-ws-loaders.d.ts +21 -0
  221. package/dist/extensions/cavi/adapters/cavi-control-adapters/gateway-ws-loaders.d.ts.map +1 -0
  222. package/dist/extensions/cavi/adapters/cavi-control-adapters/gateway-ws-loaders.js +22 -0
  223. package/dist/extensions/cavi/adapters/cavi-control-adapters/gateway-ws-snapshot-loaders.d.ts +30 -0
  224. package/dist/extensions/cavi/adapters/cavi-control-adapters/gateway-ws-snapshot-loaders.d.ts.map +1 -0
  225. package/dist/extensions/cavi/adapters/cavi-control-adapters/gateway-ws-snapshot-loaders.js +72 -0
  226. package/dist/extensions/cavi/adapters/cavi-control-adapters/library-live.d.ts +4 -0
  227. package/dist/extensions/cavi/adapters/cavi-control-adapters/library-live.d.ts.map +1 -0
  228. package/dist/extensions/cavi/adapters/cavi-control-adapters/library-live.js +66 -0
  229. package/dist/extensions/cavi/adapters/cavi-control-adapters/operator-control-live.d.ts +7 -0
  230. package/dist/extensions/cavi/adapters/cavi-control-adapters/operator-control-live.d.ts.map +1 -0
  231. package/dist/extensions/cavi/adapters/cavi-control-adapters/operator-control-live.js +318 -0
  232. package/dist/extensions/cavi/adapters/create-cavi-control-adapters.d.ts +88 -0
  233. package/dist/extensions/cavi/adapters/create-cavi-control-adapters.d.ts.map +1 -0
  234. package/dist/extensions/cavi/adapters/create-cavi-control-adapters.js +172 -0
  235. package/dist/extensions/cavi/client.d.ts +72 -0
  236. package/dist/extensions/cavi/client.d.ts.map +1 -0
  237. package/dist/extensions/cavi/client.js +19 -0
  238. package/dist/extensions/cavi/contracts/index.d.ts +6 -0
  239. package/dist/extensions/cavi/contracts/index.d.ts.map +1 -0
  240. package/dist/extensions/cavi/contracts/index.js +5 -0
  241. package/dist/extensions/cavi/contracts/mobile.d.ts +441 -0
  242. package/dist/extensions/cavi/contracts/mobile.d.ts.map +1 -0
  243. package/dist/extensions/cavi/contracts/mobile.js +467 -0
  244. package/dist/extensions/cavi/contracts/paths.d.ts +121 -0
  245. package/dist/extensions/cavi/contracts/paths.d.ts.map +1 -0
  246. package/dist/extensions/cavi/contracts/paths.js +197 -0
  247. package/dist/extensions/cavi/contracts/portals.d.ts +78 -0
  248. package/dist/extensions/cavi/contracts/portals.d.ts.map +1 -0
  249. package/dist/extensions/cavi/contracts/portals.js +70 -0
  250. package/dist/extensions/cavi/contracts/resolve.d.ts +3 -0
  251. package/dist/extensions/cavi/contracts/resolve.d.ts.map +1 -0
  252. package/dist/extensions/cavi/contracts/resolve.js +4 -0
  253. package/dist/extensions/cavi/contracts/surfaces.d.ts +5 -0
  254. package/dist/extensions/cavi/contracts/surfaces.d.ts.map +1 -0
  255. package/dist/extensions/cavi/contracts/surfaces.js +551 -0
  256. package/dist/extensions/cavi/discourse/contracts.d.ts +5 -0
  257. package/dist/extensions/cavi/discourse/contracts.d.ts.map +1 -0
  258. package/dist/extensions/cavi/discourse/contracts.js +7 -0
  259. package/dist/extensions/cavi/discourse/fallback.d.ts +3 -0
  260. package/dist/extensions/cavi/discourse/fallback.d.ts.map +1 -0
  261. package/dist/extensions/cavi/discourse/fallback.js +364 -0
  262. package/dist/extensions/cavi/discourse/live.d.ts +5 -0
  263. package/dist/extensions/cavi/discourse/live.d.ts.map +1 -0
  264. package/dist/extensions/cavi/discourse/live.js +22 -0
  265. package/dist/extensions/cavi/discourse/normalize-helpers.d.ts +11 -0
  266. package/dist/extensions/cavi/discourse/normalize-helpers.d.ts.map +1 -0
  267. package/dist/extensions/cavi/discourse/normalize-helpers.js +155 -0
  268. package/dist/extensions/cavi/discourse/normalize.d.ts +4 -0
  269. package/dist/extensions/cavi/discourse/normalize.d.ts.map +1 -0
  270. package/dist/extensions/cavi/discourse/normalize.js +287 -0
  271. package/dist/extensions/cavi/domain/discourse.d.ts +161 -0
  272. package/dist/extensions/cavi/domain/discourse.d.ts.map +1 -0
  273. package/dist/extensions/cavi/domain/discourse.js +1 -0
  274. package/dist/extensions/cavi/domain/index.d.ts +6 -0
  275. package/dist/extensions/cavi/domain/index.d.ts.map +1 -0
  276. package/dist/extensions/cavi/domain/index.js +5 -0
  277. package/dist/extensions/cavi/domain/library.d.ts +80 -0
  278. package/dist/extensions/cavi/domain/library.d.ts.map +1 -0
  279. package/dist/extensions/cavi/domain/library.js +2 -0
  280. package/dist/extensions/cavi/domain/observability.d.ts +34 -0
  281. package/dist/extensions/cavi/domain/observability.d.ts.map +1 -0
  282. package/dist/extensions/cavi/domain/observability.js +1 -0
  283. package/dist/extensions/cavi/domain/operator.d.ts +420 -0
  284. package/dist/extensions/cavi/domain/operator.d.ts.map +1 -0
  285. package/dist/extensions/cavi/domain/operator.js +1 -0
  286. package/dist/extensions/cavi/domain/project-board.d.ts +96 -0
  287. package/dist/extensions/cavi/domain/project-board.d.ts.map +1 -0
  288. package/dist/extensions/cavi/domain/project-board.js +1 -0
  289. package/dist/extensions/cavi/fallbacks/provider.d.ts +13 -0
  290. package/dist/extensions/cavi/fallbacks/provider.d.ts.map +1 -0
  291. package/dist/extensions/cavi/fallbacks/provider.js +23 -0
  292. package/dist/extensions/cavi/fallbacks/snapshots/agent-memory.d.ts +3 -0
  293. package/dist/extensions/cavi/fallbacks/snapshots/agent-memory.d.ts.map +1 -0
  294. package/dist/extensions/cavi/fallbacks/snapshots/agent-memory.js +6 -0
  295. package/dist/extensions/cavi/fallbacks/snapshots/cost-history.d.ts +3 -0
  296. package/dist/extensions/cavi/fallbacks/snapshots/cost-history.d.ts.map +1 -0
  297. package/dist/extensions/cavi/fallbacks/snapshots/cost-history.js +73 -0
  298. package/dist/extensions/cavi/fallbacks/snapshots/incidents.d.ts +3 -0
  299. package/dist/extensions/cavi/fallbacks/snapshots/incidents.d.ts.map +1 -0
  300. package/dist/extensions/cavi/fallbacks/snapshots/incidents.js +50 -0
  301. package/dist/extensions/cavi/fallbacks/snapshots/index.d.ts +10 -0
  302. package/dist/extensions/cavi/fallbacks/snapshots/index.d.ts.map +1 -0
  303. package/dist/extensions/cavi/fallbacks/snapshots/index.js +9 -0
  304. package/dist/extensions/cavi/fallbacks/snapshots/library.d.ts +3 -0
  305. package/dist/extensions/cavi/fallbacks/snapshots/library.d.ts.map +1 -0
  306. package/dist/extensions/cavi/fallbacks/snapshots/library.js +110 -0
  307. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/defaults.d.ts +8 -0
  308. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/defaults.d.ts.map +1 -0
  309. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/defaults.js +29 -0
  310. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/index.d.ts +4 -0
  311. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/index.d.ts.map +1 -0
  312. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/index.js +3 -0
  313. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-memory.d.ts +3 -0
  314. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-memory.d.ts.map +1 -0
  315. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-memory.js +63 -0
  316. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-registry-detail.d.ts +3 -0
  317. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-registry-detail.d.ts.map +1 -0
  318. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-registry-detail.js +716 -0
  319. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-section-status.d.ts +3 -0
  320. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-section-status.d.ts.map +1 -0
  321. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-section-status.js +38 -0
  322. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-status.d.ts +3 -0
  323. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-status.d.ts.map +1 -0
  324. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-status.js +84 -0
  325. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-tasks.d.ts +3 -0
  326. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-tasks.d.ts.map +1 -0
  327. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-tasks.js +111 -0
  328. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-worker-ready.d.ts +3 -0
  329. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-worker-ready.d.ts.map +1 -0
  330. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-worker-ready.js +16 -0
  331. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-worker-tasks.d.ts +3 -0
  332. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-worker-tasks.d.ts.map +1 -0
  333. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-worker-tasks.js +43 -0
  334. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot.d.ts +3 -0
  335. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot.d.ts.map +1 -0
  336. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/snapshot.js +16 -0
  337. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/transports.d.ts +4 -0
  338. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/transports.d.ts.map +1 -0
  339. package/dist/extensions/cavi/fallbacks/snapshots/operator-control/transports.js +65 -0
  340. package/dist/extensions/cavi/fallbacks/snapshots/overview.d.ts +3 -0
  341. package/dist/extensions/cavi/fallbacks/snapshots/overview.d.ts.map +1 -0
  342. package/dist/extensions/cavi/fallbacks/snapshots/overview.js +40 -0
  343. package/dist/extensions/cavi/fallbacks/snapshots/routing.d.ts +3 -0
  344. package/dist/extensions/cavi/fallbacks/snapshots/routing.d.ts.map +1 -0
  345. package/dist/extensions/cavi/fallbacks/snapshots/routing.js +36 -0
  346. package/dist/extensions/cavi/fallbacks/snapshots/runs.d.ts +4 -0
  347. package/dist/extensions/cavi/fallbacks/snapshots/runs.d.ts.map +1 -0
  348. package/dist/extensions/cavi/fallbacks/snapshots/runs.js +133 -0
  349. package/dist/extensions/cavi/fallbacks/snapshots/shared.d.ts +2 -0
  350. package/dist/extensions/cavi/fallbacks/snapshots/shared.d.ts.map +1 -0
  351. package/dist/extensions/cavi/fallbacks/snapshots/shared.js +1 -0
  352. package/dist/extensions/cavi/index.d.ts +27 -0
  353. package/dist/extensions/cavi/index.d.ts.map +1 -0
  354. package/dist/extensions/cavi/index.js +26 -0
  355. package/dist/extensions/cavi/library/api.d.ts +18 -0
  356. package/dist/extensions/cavi/library/api.d.ts.map +1 -0
  357. package/dist/extensions/cavi/library/api.js +67 -0
  358. package/dist/extensions/cavi/library/client.d.ts +51 -0
  359. package/dist/extensions/cavi/library/client.d.ts.map +1 -0
  360. package/dist/extensions/cavi/library/client.js +23 -0
  361. package/dist/extensions/cavi/library/clip.d.ts +93 -0
  362. package/dist/extensions/cavi/library/clip.d.ts.map +1 -0
  363. package/dist/extensions/cavi/library/clip.js +272 -0
  364. package/dist/extensions/cavi/operator-control/constants.d.ts +4 -0
  365. package/dist/extensions/cavi/operator-control/constants.d.ts.map +1 -0
  366. package/dist/extensions/cavi/operator-control/constants.js +3 -0
  367. package/dist/extensions/cavi/operator-control/defaults.d.ts +11 -0
  368. package/dist/extensions/cavi/operator-control/defaults.d.ts.map +1 -0
  369. package/dist/extensions/cavi/operator-control/defaults.js +243 -0
  370. package/dist/extensions/cavi/operator-control/load-section.d.ts +24 -0
  371. package/dist/extensions/cavi/operator-control/load-section.d.ts.map +1 -0
  372. package/dist/extensions/cavi/operator-control/load-section.js +46 -0
  373. package/dist/extensions/cavi/portal/client.d.ts +16 -0
  374. package/dist/extensions/cavi/portal/client.d.ts.map +1 -0
  375. package/dist/extensions/cavi/portal/client.js +38 -0
  376. package/dist/extensions/cavi/portal/tts.d.ts +69 -0
  377. package/dist/extensions/cavi/portal/tts.d.ts.map +1 -0
  378. package/dist/extensions/cavi/portal/tts.js +116 -0
  379. package/dist/extensions/cavi/project-board/constants.d.ts +68 -0
  380. package/dist/extensions/cavi/project-board/constants.d.ts.map +1 -0
  381. package/dist/extensions/cavi/project-board/constants.js +9 -0
  382. package/dist/extensions/cavi/project-board/fallback.d.ts +3 -0
  383. package/dist/extensions/cavi/project-board/fallback.d.ts.map +1 -0
  384. package/dist/extensions/cavi/project-board/fallback.js +127 -0
  385. package/dist/extensions/cavi/project-board/live.d.ts +16 -0
  386. package/dist/extensions/cavi/project-board/live.d.ts.map +1 -0
  387. package/dist/extensions/cavi/project-board/live.js +86 -0
  388. package/dist/extensions/cavi/project-board/mutations.d.ts +43 -0
  389. package/dist/extensions/cavi/project-board/mutations.d.ts.map +1 -0
  390. package/dist/extensions/cavi/project-board/mutations.js +210 -0
  391. package/dist/extensions/cavi/project-board/normalize.d.ts +23 -0
  392. package/dist/extensions/cavi/project-board/normalize.d.ts.map +1 -0
  393. package/dist/extensions/cavi/project-board/normalize.js +410 -0
  394. package/dist/extensions/cavi/project-board/trace-id.d.ts +2 -0
  395. package/dist/extensions/cavi/project-board/trace-id.d.ts.map +1 -0
  396. package/dist/extensions/cavi/project-board/trace-id.js +7 -0
  397. package/dist/extensions/cavi/registry/canonical-team-registry.d.ts +41 -0
  398. package/dist/extensions/cavi/registry/canonical-team-registry.d.ts.map +1 -0
  399. package/dist/extensions/cavi/registry/canonical-team-registry.js +102 -0
  400. package/dist/extensions/cavi/registry/portal-library-registry.d.ts +6 -0
  401. package/dist/extensions/cavi/registry/portal-library-registry.d.ts.map +1 -0
  402. package/dist/extensions/cavi/registry/portal-library-registry.js +17 -0
  403. package/dist/extensions/cavi/registry/session-keys.d.ts +16 -0
  404. package/dist/extensions/cavi/registry/session-keys.d.ts.map +1 -0
  405. package/dist/extensions/cavi/registry/session-keys.js +68 -0
  406. package/dist/extensions/cavi/registry/team-registry-config.d.ts +6 -0
  407. package/dist/extensions/cavi/registry/team-registry-config.d.ts.map +1 -0
  408. package/dist/extensions/cavi/registry/team-registry-config.js +23 -0
  409. package/dist/extensions/cavi/registry/team-registry.d.ts +49 -0
  410. package/dist/extensions/cavi/registry/team-registry.d.ts.map +1 -0
  411. package/dist/extensions/cavi/registry/team-registry.js +290 -0
  412. package/dist/extensions/cavi/runtime/env-config.d.ts +35 -0
  413. package/dist/extensions/cavi/runtime/env-config.d.ts.map +1 -0
  414. package/dist/extensions/cavi/runtime/env-config.js +74 -0
  415. package/dist/extensions/cavi/runtime/paths.d.ts +11 -0
  416. package/dist/extensions/cavi/runtime/paths.d.ts.map +1 -0
  417. package/dist/extensions/cavi/runtime/paths.js +43 -0
  418. package/dist/extensions/cavi/runtime/standalone-mode.d.ts +3 -0
  419. package/dist/extensions/cavi/runtime/standalone-mode.d.ts.map +1 -0
  420. package/dist/extensions/cavi/runtime/standalone-mode.js +15 -0
  421. package/dist/index.d.ts +70 -0
  422. package/dist/index.d.ts.map +1 -0
  423. package/dist/index.js +75 -0
  424. package/dist/providers/hermes/agent-config.d.ts +36 -0
  425. package/dist/providers/hermes/agent-config.d.ts.map +1 -0
  426. package/dist/providers/hermes/agent-config.js +242 -0
  427. package/dist/providers/hermes/chat-run.d.ts +106 -0
  428. package/dist/providers/hermes/chat-run.d.ts.map +1 -0
  429. package/dist/providers/hermes/chat-run.js +221 -0
  430. package/dist/providers/hermes/client.d.ts +13 -0
  431. package/dist/providers/hermes/client.d.ts.map +1 -0
  432. package/dist/providers/hermes/client.js +6 -0
  433. package/dist/providers/hermes/env-config.d.ts +18 -0
  434. package/dist/providers/hermes/env-config.d.ts.map +1 -0
  435. package/dist/providers/hermes/env-config.js +38 -0
  436. package/dist/providers/hermes/index.d.ts +12 -0
  437. package/dist/providers/hermes/index.d.ts.map +1 -0
  438. package/dist/providers/hermes/index.js +11 -0
  439. package/dist/providers/hermes/media.d.ts +6 -0
  440. package/dist/providers/hermes/media.d.ts.map +1 -0
  441. package/dist/providers/hermes/media.js +10 -0
  442. package/dist/providers/hermes/provider-module.d.ts +3 -0
  443. package/dist/providers/hermes/provider-module.d.ts.map +1 -0
  444. package/dist/providers/hermes/provider-module.js +22 -0
  445. package/dist/providers/hermes/sse-run-event-provider.d.ts +24 -0
  446. package/dist/providers/hermes/sse-run-event-provider.d.ts.map +1 -0
  447. package/dist/providers/hermes/sse-run-event-provider.js +32 -0
  448. package/dist/providers/hermes/team-registry-config.d.ts +3 -0
  449. package/dist/providers/hermes/team-registry-config.d.ts.map +1 -0
  450. package/dist/providers/hermes/team-registry-config.js +1 -0
  451. package/dist/providers/hermes/team-registry.d.ts +3 -0
  452. package/dist/providers/hermes/team-registry.d.ts.map +1 -0
  453. package/dist/providers/hermes/team-registry.js +5 -0
  454. package/dist/providers/hermes/websocket.d.ts +6 -0
  455. package/dist/providers/hermes/websocket.d.ts.map +1 -0
  456. package/dist/providers/hermes/websocket.js +6 -0
  457. package/dist/providers/hermes/wiki.d.ts +6 -0
  458. package/dist/providers/hermes/wiki.d.ts.map +1 -0
  459. package/dist/providers/hermes/wiki.js +10 -0
  460. package/dist/providers/openclaw/agent-config.d.ts +6 -0
  461. package/dist/providers/openclaw/agent-config.d.ts.map +1 -0
  462. package/dist/providers/openclaw/agent-config.js +10 -0
  463. package/dist/providers/openclaw/client.d.ts +13 -0
  464. package/dist/providers/openclaw/client.d.ts.map +1 -0
  465. package/dist/providers/openclaw/client.js +6 -0
  466. package/dist/providers/openclaw/index.d.ts +10 -0
  467. package/dist/providers/openclaw/index.d.ts.map +1 -0
  468. package/dist/providers/openclaw/index.js +9 -0
  469. package/dist/providers/openclaw/media.d.ts +6 -0
  470. package/dist/providers/openclaw/media.d.ts.map +1 -0
  471. package/dist/providers/openclaw/media.js +10 -0
  472. package/dist/providers/openclaw/provider-module.d.ts +3 -0
  473. package/dist/providers/openclaw/provider-module.d.ts.map +1 -0
  474. package/dist/providers/openclaw/provider-module.js +16 -0
  475. package/dist/providers/openclaw/sse-run-event-provider.d.ts +6 -0
  476. package/dist/providers/openclaw/sse-run-event-provider.d.ts.map +1 -0
  477. package/dist/providers/openclaw/sse-run-event-provider.js +10 -0
  478. package/dist/providers/openclaw/team-registry-config.d.ts +3 -0
  479. package/dist/providers/openclaw/team-registry-config.d.ts.map +1 -0
  480. package/dist/providers/openclaw/team-registry-config.js +1 -0
  481. package/dist/providers/openclaw/team-registry.d.ts +3 -0
  482. package/dist/providers/openclaw/team-registry.d.ts.map +1 -0
  483. package/dist/providers/openclaw/team-registry.js +5 -0
  484. package/dist/providers/openclaw/websocket.d.ts +6 -0
  485. package/dist/providers/openclaw/websocket.d.ts.map +1 -0
  486. package/dist/providers/openclaw/websocket.js +28 -0
  487. package/dist/providers/openclaw/wiki.d.ts +6 -0
  488. package/dist/providers/openclaw/wiki.d.ts.map +1 -0
  489. package/dist/providers/openclaw/wiki.js +10 -0
  490. package/dist/react/gateway-provider.d.ts +142 -0
  491. package/dist/react/gateway-provider.d.ts.map +1 -0
  492. package/dist/react/gateway-provider.js +569 -0
  493. package/dist/react/index.d.ts +2 -0
  494. package/dist/react/index.d.ts.map +1 -0
  495. package/dist/react/index.js +1 -0
  496. package/docs/assets/api-client-hero.svg +73 -0
  497. package/docs/cavi-team-manifest.example.ts +219 -0
  498. package/docs/team-manifest.consumer.template.ts +248 -0
  499. package/docs/team-manifest.md +252 -0
  500. package/package.json +152 -0
  501. package/src/contracts/index.ts +4 -0
  502. package/src/contracts/paths.ts +126 -0
  503. package/src/contracts/resolve.ts +42 -0
  504. package/src/contracts/surfaces.ts +366 -0
  505. package/src/contracts/team-manifest.ts +1402 -0
  506. package/src/core/data/guards.ts +26 -0
  507. package/src/core/data/index.ts +1 -0
  508. package/src/core/env/config.ts +97 -0
  509. package/src/core/env/index.ts +2 -0
  510. package/src/core/env/repo-root.ts +59 -0
  511. package/src/core/gateway/README.md +35 -0
  512. package/src/core/gateway/agent/commands.ts +482 -0
  513. package/src/core/gateway/agent/config.ts +786 -0
  514. package/src/core/gateway/agent/index.ts +3 -0
  515. package/src/core/gateway/agent/voice-config.ts +91 -0
  516. package/src/core/gateway/client/capabilities.ts +385 -0
  517. package/src/core/gateway/client/client.ts +137 -0
  518. package/src/core/gateway/client/error-details.ts +74 -0
  519. package/src/core/gateway/client/fetch.ts +180 -0
  520. package/src/core/gateway/client/index.ts +5 -0
  521. package/src/core/gateway/client/runtime-targets.ts +132 -0
  522. package/src/core/gateway/envelope/envelope.ts +204 -0
  523. package/src/core/gateway/envelope/index.ts +2 -0
  524. package/src/core/gateway/envelope/types.ts +48 -0
  525. package/src/core/gateway/index.ts +10 -0
  526. package/src/core/gateway/jobs.ts +178 -0
  527. package/src/core/gateway/portal/config-patch.ts +136 -0
  528. package/src/core/gateway/portal/index.ts +1 -0
  529. package/src/core/gateway/providers/factory.ts +77 -0
  530. package/src/core/gateway/providers/index.ts +4 -0
  531. package/src/core/gateway/providers/normalize.ts +7 -0
  532. package/src/core/gateway/providers/registry.ts +96 -0
  533. package/src/core/gateway/providers/types.ts +73 -0
  534. package/src/core/gateway/resources/index.ts +2 -0
  535. package/src/core/gateway/resources/media.ts +474 -0
  536. package/src/core/gateway/resources/wiki.ts +301 -0
  537. package/src/core/gateway/rpc/client.ts +1067 -0
  538. package/src/core/gateway/rpc/device-crypto.ts +101 -0
  539. package/src/core/gateway/rpc/device-store.ts +147 -0
  540. package/src/core/gateway/rpc/error.ts +11 -0
  541. package/src/core/gateway/rpc/index.ts +5 -0
  542. package/src/core/gateway/rpc/preauth-handshake.ts +99 -0
  543. package/src/core/gateway/run/contracts.ts +155 -0
  544. package/src/core/gateway/run/event-stream.ts +373 -0
  545. package/src/core/gateway/run/index.ts +4 -0
  546. package/src/core/gateway/run/sse-run-event-provider.ts +513 -0
  547. package/src/core/gateway/run/stream-failure.ts +135 -0
  548. package/src/core/gateway/snapshots/cache.ts +22 -0
  549. package/src/core/gateway/snapshots/contracts.ts +293 -0
  550. package/src/core/gateway/snapshots/index.ts +6 -0
  551. package/src/core/gateway/snapshots/loaders.ts +738 -0
  552. package/src/core/gateway/snapshots/session-loaders.ts +534 -0
  553. package/src/core/gateway/snapshots/system-loaders.ts +93 -0
  554. package/src/core/gateway/snapshots/transforms.ts +508 -0
  555. package/src/core/http/client-id.ts +40 -0
  556. package/src/core/http/client.ts +271 -0
  557. package/src/core/http/contracts.ts +9 -0
  558. package/src/core/http/errors.ts +26 -0
  559. package/src/core/http/gateway-error.ts +38 -0
  560. package/src/core/http/index.ts +9 -0
  561. package/src/core/http/json-client.ts +90 -0
  562. package/src/core/http/raw-client.ts +57 -0
  563. package/src/core/http/redaction.ts +78 -0
  564. package/src/core/http/types.ts +59 -0
  565. package/src/core/runtime/index.ts +1 -0
  566. package/src/core/runtime/paths.ts +44 -0
  567. package/src/core/sse/index.ts +1 -0
  568. package/src/core/sse/stream.ts +118 -0
  569. package/src/core/ws/close.ts +51 -0
  570. package/src/core/ws/gateway-websocket.ts +8 -0
  571. package/src/core/ws/index.ts +3 -0
  572. package/src/core/ws/targets.ts +74 -0
  573. package/src/extensions/README.md +16 -0
  574. package/src/extensions/cavi/adapters/cavi-control-adapters/gateway-ws-loaders.ts +33 -0
  575. package/src/extensions/cavi/adapters/cavi-control-adapters/gateway-ws-snapshot-loaders.ts +152 -0
  576. package/src/extensions/cavi/adapters/cavi-control-adapters/library-live.ts +120 -0
  577. package/src/extensions/cavi/adapters/cavi-control-adapters/operator-control-live.ts +422 -0
  578. package/src/extensions/cavi/adapters/create-cavi-control-adapters.ts +350 -0
  579. package/src/extensions/cavi/client.ts +25 -0
  580. package/src/extensions/cavi/contracts/index.ts +5 -0
  581. package/src/extensions/cavi/contracts/mobile.ts +528 -0
  582. package/src/extensions/cavi/contracts/paths.ts +242 -0
  583. package/src/extensions/cavi/contracts/portals.ts +165 -0
  584. package/src/extensions/cavi/contracts/resolve.ts +6 -0
  585. package/src/extensions/cavi/contracts/surfaces.ts +567 -0
  586. package/src/extensions/cavi/discourse/contracts.ts +9 -0
  587. package/src/extensions/cavi/discourse/fallback.ts +387 -0
  588. package/src/extensions/cavi/discourse/live.ts +36 -0
  589. package/src/extensions/cavi/discourse/normalize-helpers.ts +202 -0
  590. package/src/extensions/cavi/discourse/normalize.ts +415 -0
  591. package/src/extensions/cavi/domain/discourse.ts +209 -0
  592. package/src/extensions/cavi/domain/index.ts +5 -0
  593. package/src/extensions/cavi/domain/library.ts +96 -0
  594. package/src/extensions/cavi/domain/observability.ts +36 -0
  595. package/src/extensions/cavi/domain/operator.ts +486 -0
  596. package/src/extensions/cavi/domain/project-board.ts +107 -0
  597. package/src/extensions/cavi/fallbacks/provider.ts +57 -0
  598. package/src/extensions/cavi/fallbacks/snapshots/agent-memory.ts +8 -0
  599. package/src/extensions/cavi/fallbacks/snapshots/cost-history.ts +101 -0
  600. package/src/extensions/cavi/fallbacks/snapshots/incidents.ts +56 -0
  601. package/src/extensions/cavi/fallbacks/snapshots/index.ts +9 -0
  602. package/src/extensions/cavi/fallbacks/snapshots/library.ts +112 -0
  603. package/src/extensions/cavi/fallbacks/snapshots/operator-control/defaults.ts +57 -0
  604. package/src/extensions/cavi/fallbacks/snapshots/operator-control/index.ts +3 -0
  605. package/src/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-memory.ts +65 -0
  606. package/src/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-registry-detail.ts +735 -0
  607. package/src/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-section-status.ts +41 -0
  608. package/src/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-status.ts +87 -0
  609. package/src/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-tasks.ts +113 -0
  610. package/src/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-worker-ready.ts +19 -0
  611. package/src/extensions/cavi/fallbacks/snapshots/operator-control/snapshot-worker-tasks.ts +46 -0
  612. package/src/extensions/cavi/fallbacks/snapshots/operator-control/snapshot.ts +18 -0
  613. package/src/extensions/cavi/fallbacks/snapshots/operator-control/transports.ts +81 -0
  614. package/src/extensions/cavi/fallbacks/snapshots/overview.ts +42 -0
  615. package/src/extensions/cavi/fallbacks/snapshots/routing.ts +38 -0
  616. package/src/extensions/cavi/fallbacks/snapshots/runs.ts +141 -0
  617. package/src/extensions/cavi/fallbacks/snapshots/shared.ts +1 -0
  618. package/src/extensions/cavi/index.ts +52 -0
  619. package/src/extensions/cavi/library/api.ts +120 -0
  620. package/src/extensions/cavi/library/client.ts +54 -0
  621. package/src/extensions/cavi/library/clip.ts +389 -0
  622. package/src/extensions/cavi/operator-control/constants.ts +3 -0
  623. package/src/extensions/cavi/operator-control/defaults.ts +254 -0
  624. package/src/extensions/cavi/operator-control/load-section.ts +92 -0
  625. package/src/extensions/cavi/portal/client.ts +63 -0
  626. package/src/extensions/cavi/portal/tts.ts +213 -0
  627. package/src/extensions/cavi/project-board/constants.ts +84 -0
  628. package/src/extensions/cavi/project-board/fallback.ts +129 -0
  629. package/src/extensions/cavi/project-board/live.ts +121 -0
  630. package/src/extensions/cavi/project-board/mutations.ts +306 -0
  631. package/src/extensions/cavi/project-board/normalize.ts +552 -0
  632. package/src/extensions/cavi/project-board/trace-id.ts +9 -0
  633. package/src/extensions/cavi/registry/canonical-team-registry.ts +193 -0
  634. package/src/extensions/cavi/registry/portal-library-registry.ts +24 -0
  635. package/src/extensions/cavi/registry/session-keys.ts +92 -0
  636. package/src/extensions/cavi/registry/team-registry-config.ts +36 -0
  637. package/src/extensions/cavi/registry/team-registry.ts +414 -0
  638. package/src/extensions/cavi/runtime/env-config.ts +114 -0
  639. package/src/extensions/cavi/runtime/paths.ts +82 -0
  640. package/src/extensions/cavi/runtime/standalone-mode.ts +28 -0
  641. package/src/index.ts +576 -0
  642. package/src/providers/hermes/agent-config.ts +322 -0
  643. package/src/providers/hermes/chat-run.ts +340 -0
  644. package/src/providers/hermes/client.ts +21 -0
  645. package/src/providers/hermes/env-config.ts +58 -0
  646. package/src/providers/hermes/index.ts +11 -0
  647. package/src/providers/hermes/media.ts +12 -0
  648. package/src/providers/hermes/provider-module.ts +26 -0
  649. package/src/providers/hermes/sse-run-event-provider.ts +47 -0
  650. package/src/providers/hermes/team-registry-config.ts +2 -0
  651. package/src/providers/hermes/team-registry.ts +12 -0
  652. package/src/providers/hermes/websocket.ts +16 -0
  653. package/src/providers/hermes/wiki.ts +12 -0
  654. package/src/providers/openclaw/agent-config.ts +12 -0
  655. package/src/providers/openclaw/client.ts +21 -0
  656. package/src/providers/openclaw/index.ts +9 -0
  657. package/src/providers/openclaw/media.ts +12 -0
  658. package/src/providers/openclaw/provider-module.ts +20 -0
  659. package/src/providers/openclaw/sse-run-event-provider.ts +16 -0
  660. package/src/providers/openclaw/team-registry-config.ts +2 -0
  661. package/src/providers/openclaw/team-registry.ts +12 -0
  662. package/src/providers/openclaw/websocket.ts +56 -0
  663. package/src/providers/openclaw/wiki.ts +12 -0
  664. package/src/react/gateway-provider.tsx +835 -0
  665. package/src/react/index.ts +1 -0
@@ -0,0 +1,786 @@
1
+ import { GATEWAY_AGENT_CONFIG_API_ENDPOINTS } from "../../../contracts/paths.js";
2
+ import { BaseHttpApiClient } from "../../http/client.js";
3
+ import { isSensitiveKey } from "../../http/redaction.js";
4
+ import type { HttpApiClientOptions } from "../../http/types.js";
5
+ import { parseAgentVoiceConfig, type AgentVoiceConfig } from "./voice-config.js";
6
+
7
+ export const AGENT_PROFILE_CONFIG_CONTRACT = "AGENT_PROFILE_CONFIG_V1";
8
+ export const AGENT_PROFILE_CONFIG_PATCH_CONTRACT = "AGENT_PROFILE_CONFIG_PATCH_V1";
9
+
10
+ export type AgentConfigFieldValue =
11
+ | string
12
+ | number
13
+ | boolean
14
+ | null
15
+ | readonly unknown[]
16
+ | Record<string, unknown>;
17
+
18
+ export type AgentConfigFieldKind =
19
+ | { type: "text"; placeholder?: string }
20
+ | { type: "multiline"; placeholder?: string; minRows?: number }
21
+ | { type: "number"; min?: number; max?: number; step?: number }
22
+ | { type: "toggle" }
23
+ | { type: "select"; options: readonly { value: string; label: string }[] }
24
+ | { type: "chips"; suggestions?: readonly string[] }
25
+ | { type: "list"; placeholder?: string; suggestions?: readonly string[] }
26
+ | { type: "json"; minRows?: number };
27
+
28
+ export type AgentConfigField = {
29
+ key: string;
30
+ label: string;
31
+ description?: string;
32
+ kind: AgentConfigFieldKind;
33
+ value: AgentConfigFieldValue;
34
+ editable?: boolean;
35
+ sourcePath?: readonly string[];
36
+ };
37
+
38
+ export type AgentConfigSectionId = string;
39
+
40
+ export type AgentConfigSection = {
41
+ id: AgentConfigSectionId;
42
+ label: string;
43
+ fields: readonly AgentConfigField[];
44
+ };
45
+
46
+ export type AgentConfig = {
47
+ agentId: string;
48
+ agentName: string;
49
+ sourcePath?: string;
50
+ etag?: string;
51
+ sections: readonly AgentConfigSection[];
52
+ voice?: AgentVoiceConfig;
53
+ fetchedAt: number;
54
+ };
55
+
56
+ export type AgentConfigDraftDiff = Record<string, AgentConfigFieldValue>;
57
+
58
+ export type GatewayConfigSchemaField = {
59
+ type?: string;
60
+ description?: string;
61
+ category?: string;
62
+ options?: readonly unknown[];
63
+ min?: number;
64
+ max?: number;
65
+ step?: number;
66
+ };
67
+
68
+ export type GatewayConfigSchemaPayload = {
69
+ fields?: Record<string, GatewayConfigSchemaField | unknown>;
70
+ category_order?: readonly string[];
71
+ };
72
+
73
+ export type AgentProfileSummary = {
74
+ agentId: string;
75
+ agentName: string;
76
+ sourcePath?: string;
77
+ isActive?: boolean;
78
+ isDefault?: boolean;
79
+ model?: string | null;
80
+ provider?: string | null;
81
+ };
82
+
83
+ export type AgentProfileSourcePathResolver = (agentId: string) => string;
84
+
85
+ export type AgentProfileConfigPatchBody = {
86
+ contract: typeof AGENT_PROFILE_CONFIG_PATCH_CONTRACT;
87
+ version: 1;
88
+ agentId: string;
89
+ profile: string;
90
+ source: "profile-config-yaml";
91
+ sourcePath: string;
92
+ patch: AgentConfigDraftDiff;
93
+ baseEtag?: string;
94
+ };
95
+
96
+ export class GatewayAgentConfigApiError extends Error {
97
+ readonly status?: number;
98
+ readonly path?: string;
99
+
100
+ constructor(message: string, options?: { status?: number; path?: string }) {
101
+ super(message);
102
+ this.name = "GatewayAgentConfigApiError";
103
+ this.status = options?.status;
104
+ this.path = options?.path;
105
+ }
106
+ }
107
+
108
+ const AGENT_PROFILE_ID_RE = /^(?:default|[a-z0-9][a-z0-9_-]{0,63})$/u;
109
+
110
+ const REASONING_EFFORT_OPTIONS = [
111
+ { value: "", label: "Default" },
112
+ { value: "none", label: "None" },
113
+ { value: "minimal", label: "Minimal" },
114
+ { value: "low", label: "Low" },
115
+ { value: "medium", label: "Medium" },
116
+ { value: "high", label: "High" },
117
+ { value: "xhigh", label: "Extra high" },
118
+ ] as const;
119
+
120
+ const CLI_TOOLSET_SUGGESTIONS = [
121
+ "browser",
122
+ "clarify",
123
+ "code_execution",
124
+ "cronjob",
125
+ "delegation",
126
+ "file",
127
+ "image_gen",
128
+ "memory",
129
+ "session_search",
130
+ "skills",
131
+ "terminal",
132
+ "todo",
133
+ "web",
134
+ "webhook",
135
+ ] as const;
136
+
137
+ function cleanString(value: unknown): string {
138
+ return typeof value === "string" ? value.trim() : "";
139
+ }
140
+
141
+ function asRecord(value: unknown): Record<string, unknown> {
142
+ return value !== null && typeof value === "object" && !Array.isArray(value)
143
+ ? (value as Record<string, unknown>)
144
+ : {};
145
+ }
146
+
147
+ function asArray(value: unknown): readonly unknown[] {
148
+ return Array.isArray(value) ? value : [];
149
+ }
150
+
151
+ function asStringArray(value: unknown): string[] {
152
+ if (!Array.isArray(value)) return [];
153
+ return value.map(cleanString).filter(Boolean);
154
+ }
155
+
156
+ function asNumber(value: unknown): number | null {
157
+ return typeof value === "number" && Number.isFinite(value) ? value : null;
158
+ }
159
+
160
+ function asBoolean(value: unknown): boolean | null {
161
+ return typeof value === "boolean" ? value : null;
162
+ }
163
+
164
+ function pathSegments(path: string): readonly string[] {
165
+ return path.split(".").map((segment) => segment.trim()).filter(Boolean);
166
+ }
167
+
168
+ function getPathValue(config: Record<string, unknown>, path: string): unknown {
169
+ let current: unknown = config;
170
+ for (const segment of pathSegments(path)) {
171
+ const record = asRecord(current);
172
+ if (!(segment in record)) return undefined;
173
+ current = record[segment];
174
+ }
175
+ return current;
176
+ }
177
+
178
+ function cloneJsonRecord(config: Record<string, unknown>): Record<string, unknown> {
179
+ return JSON.parse(JSON.stringify(config)) as Record<string, unknown>;
180
+ }
181
+
182
+ export function setAgentConfigPathValue(
183
+ config: Record<string, unknown>,
184
+ path: string,
185
+ value: AgentConfigFieldValue,
186
+ ): Record<string, unknown> {
187
+ const segments = pathSegments(path);
188
+ if (segments.length === 0) return config;
189
+ const next = cloneJsonRecord(config);
190
+ let cursor: Record<string, unknown> = next;
191
+ for (const segment of segments.slice(0, -1)) {
192
+ const existing = cursor[segment];
193
+ if (existing === null || typeof existing !== "object" || Array.isArray(existing)) {
194
+ cursor[segment] = {};
195
+ }
196
+ cursor = cursor[segment] as Record<string, unknown>;
197
+ }
198
+ cursor[segments[segments.length - 1]] = value;
199
+ return next;
200
+ }
201
+
202
+ function flattenConfigPaths(
203
+ value: unknown,
204
+ prefix = "",
205
+ out: Record<string, unknown> = {},
206
+ ): Record<string, unknown> {
207
+ if (value === null || typeof value !== "object" || Array.isArray(value)) {
208
+ if (prefix) out[prefix] = value;
209
+ return out;
210
+ }
211
+
212
+ const record = asRecord(value);
213
+ const keys = Object.keys(record);
214
+ if (prefix && keys.length === 0) {
215
+ out[prefix] = record;
216
+ return out;
217
+ }
218
+ for (const key of keys) {
219
+ const nextPrefix = prefix ? `${prefix}.${key}` : key;
220
+ flattenConfigPaths(record[key], nextPrefix, out);
221
+ }
222
+ return out;
223
+ }
224
+
225
+ function configFieldValue(value: unknown): AgentConfigFieldValue {
226
+ if (
227
+ value === null ||
228
+ typeof value === "string" ||
229
+ typeof value === "number" ||
230
+ typeof value === "boolean"
231
+ ) {
232
+ return value;
233
+ }
234
+ if (Array.isArray(value)) {
235
+ return value as readonly unknown[];
236
+ }
237
+ if (typeof value === "object") {
238
+ return value as Record<string, unknown>;
239
+ }
240
+ return String(value ?? "");
241
+ }
242
+
243
+ function titleCase(value: string): string {
244
+ return value
245
+ .replace(/[_-]+/gu, " ")
246
+ .replace(/([a-z0-9])([A-Z])/gu, "$1 $2")
247
+ .trim()
248
+ .replace(/\s+/gu, " ")
249
+ .replace(/\b\w/gu, (char) => char.toUpperCase());
250
+ }
251
+
252
+ function labelFromPath(path: string): string {
253
+ const segments = pathSegments(path);
254
+ const leaf = segments.length > 0 ? segments[segments.length - 1] : path;
255
+ return titleCase(leaf);
256
+ }
257
+
258
+ function normalizeSchemaField(value: unknown): GatewayConfigSchemaField {
259
+ const record = asRecord(value);
260
+ const type = cleanString(record.type);
261
+ const description = cleanString(record.description);
262
+ const category = cleanString(record.category);
263
+ const options = Array.isArray(record.options) ? record.options : undefined;
264
+ return {
265
+ ...(type ? { type } : {}),
266
+ ...(description ? { description } : {}),
267
+ ...(category ? { category } : {}),
268
+ ...(options ? { options } : {}),
269
+ ...(asNumber(record.min) !== null ? { min: asNumber(record.min) ?? undefined } : {}),
270
+ ...(asNumber(record.max) !== null ? { max: asNumber(record.max) ?? undefined } : {}),
271
+ ...(asNumber(record.step) !== null ? { step: asNumber(record.step) ?? undefined } : {}),
272
+ ...(!type ? { type: "string" } : {}),
273
+ };
274
+ }
275
+
276
+ function inferSchemaType(value: unknown): string {
277
+ if (typeof value === "boolean") return "boolean";
278
+ if (typeof value === "number") return "number";
279
+ if (Array.isArray(value)) return "list";
280
+ if (value !== null && typeof value === "object") return "object";
281
+ return "string";
282
+ }
283
+
284
+ function normalizeSchemaOptions(
285
+ options: readonly unknown[] | undefined,
286
+ currentValue: unknown,
287
+ ): readonly { value: string; label: string }[] {
288
+ const normalized = (options ?? [])
289
+ .map((option) => {
290
+ const optionRecord = asRecord(option);
291
+ const value =
292
+ cleanString(optionRecord.value) ||
293
+ cleanString(optionRecord.id) ||
294
+ cleanString(optionRecord.name) ||
295
+ (typeof option === "string" || typeof option === "number" || typeof option === "boolean"
296
+ ? String(option)
297
+ : "");
298
+ if (!value) return null;
299
+ const label =
300
+ cleanString(optionRecord.label) ||
301
+ cleanString(optionRecord.name) ||
302
+ value;
303
+ return { value, label };
304
+ })
305
+ .filter((option): option is { value: string; label: string } => option !== null);
306
+ return withOption(
307
+ normalized,
308
+ String(currentValue ?? ""),
309
+ currentValue === null ? "Unset" : undefined,
310
+ );
311
+ }
312
+
313
+ export function assertAgentProfileId(agentId: string): string {
314
+ const clean = cleanString(agentId);
315
+ if (!AGENT_PROFILE_ID_RE.test(clean)) {
316
+ throw new GatewayAgentConfigApiError(
317
+ `Invalid agent profile id "${agentId}". Expected "default" or [a-z0-9][a-z0-9_-]{0,63}.`,
318
+ );
319
+ }
320
+ return clean;
321
+ }
322
+
323
+ export function agentProfileConfigPath(agentId: string): string {
324
+ return GATEWAY_AGENT_CONFIG_API_ENDPOINTS.agentConfig(assertAgentProfileId(agentId));
325
+ }
326
+
327
+ export function agentProfileConfigSourcePath(agentId: string): string {
328
+ const id = assertAgentProfileId(agentId);
329
+ return id === "default"
330
+ ? "profiles/default/config.yaml"
331
+ : `profiles/${id}/config.yaml`;
332
+ }
333
+
334
+ export function isMissingAgentConfigRouteError(error: unknown): boolean {
335
+ const status = Number((error as { status?: unknown })?.status);
336
+ return status === 404 || status === 405 || status === 501;
337
+ }
338
+
339
+ function field(input: {
340
+ key: string;
341
+ label: string;
342
+ description?: string;
343
+ kind: AgentConfigFieldKind;
344
+ value: AgentConfigFieldValue;
345
+ editable?: boolean;
346
+ sourcePath?: readonly string[];
347
+ }): AgentConfigField {
348
+ return input;
349
+ }
350
+
351
+ function section(
352
+ id: AgentConfigSectionId,
353
+ label: string,
354
+ fields: AgentConfigField[],
355
+ ): AgentConfigSection | null {
356
+ return fields.length > 0 ? { id, label, fields } : null;
357
+ }
358
+
359
+ function withOption(
360
+ options: readonly { value: string; label: string }[],
361
+ value: string,
362
+ label?: string,
363
+ ): readonly { value: string; label: string }[] {
364
+ if ((!value && !label) || options.some((option) => option.value === value)) return options;
365
+ return [{ value, label: label || value }, ...options];
366
+ }
367
+
368
+ export function normalizeAgentProfiles(payload: unknown): AgentProfileSummary[] {
369
+ const root = asRecord(payload);
370
+ const profiles: AgentProfileSummary[] = [];
371
+ for (const value of asArray(root.profiles)) {
372
+ const profile = asRecord(value);
373
+ const agentId = cleanString(profile.name);
374
+ if (!agentId) continue;
375
+ const sourcePath = cleanString(profile.path);
376
+ const isActive = asBoolean(profile.is_active);
377
+ const isDefault = asBoolean(profile.is_default);
378
+ profiles.push({
379
+ agentId,
380
+ agentName: agentId,
381
+ ...(sourcePath ? { sourcePath } : {}),
382
+ ...(isActive !== null ? { isActive } : {}),
383
+ ...(isDefault !== null ? { isDefault } : {}),
384
+ model: cleanString(profile.model) || null,
385
+ provider: cleanString(profile.provider) || null,
386
+ });
387
+ }
388
+ return profiles;
389
+ }
390
+
391
+ export function findAgentProfile(
392
+ profiles: readonly AgentProfileSummary[],
393
+ agentId: string,
394
+ ): AgentProfileSummary | null {
395
+ return profiles.find((profile) => profile.agentId === agentId) ?? null;
396
+ }
397
+
398
+ function sourcePathForProfile(
399
+ profile: AgentProfileSummary | null,
400
+ agentId: string,
401
+ defaultSourcePath: AgentProfileSourcePathResolver,
402
+ ): string {
403
+ if (profile?.sourcePath) {
404
+ const path = profile.sourcePath.trim().replace(/\/+$/u, "");
405
+ return path.endsWith(".yaml") || path.endsWith(".yml")
406
+ ? path
407
+ : `${path}/config.yaml`;
408
+ }
409
+ return defaultSourcePath(agentId);
410
+ }
411
+
412
+ function normalizeSchemaPayload(payload: unknown): {
413
+ fields: Record<string, GatewayConfigSchemaField>;
414
+ categoryOrder: readonly string[];
415
+ } {
416
+ const root = asRecord(payload);
417
+ const fields: Record<string, GatewayConfigSchemaField> = {};
418
+ for (const [path, schemaField] of Object.entries(asRecord(root.fields))) {
419
+ if (!path || isSensitiveKey(path)) continue;
420
+ fields[path] = normalizeSchemaField(schemaField);
421
+ }
422
+ return {
423
+ fields,
424
+ categoryOrder: asStringArray(root.category_order),
425
+ };
426
+ }
427
+
428
+ function categoryForPath(path: string, schema?: GatewayConfigSchemaField): string {
429
+ return cleanString(schema?.category) || pathSegments(path)[0] || "general";
430
+ }
431
+
432
+ function kindForSchemaField(
433
+ path: string,
434
+ schema: GatewayConfigSchemaField | undefined,
435
+ value: unknown,
436
+ ): AgentConfigFieldKind {
437
+ const type = cleanString(schema?.type).toLowerCase() || inferSchemaType(value);
438
+ if (path === "agent.reasoning_effort") {
439
+ return {
440
+ type: "select",
441
+ options: withOption(REASONING_EFFORT_OPTIONS, String(value ?? "")),
442
+ };
443
+ }
444
+ if (type === "boolean" || type === "bool") return { type: "toggle" };
445
+ if (type === "number" || type === "integer" || type === "float") {
446
+ return {
447
+ type: "number",
448
+ ...(schema?.min !== undefined ? { min: schema.min } : {}),
449
+ ...(schema?.max !== undefined ? { max: schema.max } : {}),
450
+ ...(schema?.step !== undefined ? { step: schema.step } : {}),
451
+ };
452
+ }
453
+ if (type === "select") {
454
+ const options = normalizeSchemaOptions(schema?.options, value);
455
+ return options.length > 0
456
+ ? { type: "select", options }
457
+ : { type: "text", placeholder: path };
458
+ }
459
+ if (type === "list" || Array.isArray(value)) {
460
+ if (path === "platform_toolsets.cli") {
461
+ return { type: "chips", suggestions: CLI_TOOLSET_SUGGESTIONS };
462
+ }
463
+ if (
464
+ Array.isArray(value) &&
465
+ value.every((item) => typeof item === "string" || typeof item === "number")
466
+ ) {
467
+ return { type: "list", placeholder: "comma-separated values" };
468
+ }
469
+ return { type: "json", minRows: 5 };
470
+ }
471
+ if (type === "object" || (value !== null && typeof value === "object")) {
472
+ return { type: "json", minRows: 6 };
473
+ }
474
+ if (
475
+ type === "text" ||
476
+ path.toLowerCase().includes("prompt") ||
477
+ (typeof value === "string" && value.length > 120)
478
+ ) {
479
+ return { type: "multiline", minRows: 4 };
480
+ }
481
+ return { type: "text", placeholder: path };
482
+ }
483
+
484
+ function defaultValueForKind(kind: AgentConfigFieldKind): AgentConfigFieldValue {
485
+ if (kind.type === "toggle") return false;
486
+ if (kind.type === "number") return 0;
487
+ if (kind.type === "chips" || kind.type === "list") return [];
488
+ if (kind.type === "json") return {};
489
+ return "";
490
+ }
491
+
492
+ function compareConfigPaths(
493
+ a: string,
494
+ b: string,
495
+ fields: Record<string, GatewayConfigSchemaField>,
496
+ categoryOrder: readonly string[],
497
+ ): number {
498
+ const aCategory = categoryForPath(a, fields[a]);
499
+ const bCategory = categoryForPath(b, fields[b]);
500
+ const aCategoryIndex = categoryOrder.indexOf(aCategory);
501
+ const bCategoryIndex = categoryOrder.indexOf(bCategory);
502
+ const safeAIndex = aCategoryIndex === -1 ? Number.MAX_SAFE_INTEGER : aCategoryIndex;
503
+ const safeBIndex = bCategoryIndex === -1 ? Number.MAX_SAFE_INTEGER : bCategoryIndex;
504
+ if (safeAIndex !== safeBIndex) return safeAIndex - safeBIndex;
505
+ if (aCategory !== bCategory) return aCategory.localeCompare(bCategory);
506
+ return a.localeCompare(b);
507
+ }
508
+
509
+ export function buildAgentConfigFromConfigSnapshot(input: {
510
+ agentId: string;
511
+ config: unknown;
512
+ schema?: unknown;
513
+ defaults?: unknown;
514
+ profile?: AgentProfileSummary | null;
515
+ defaultSourcePath?: AgentProfileSourcePathResolver;
516
+ fetchedAt?: number;
517
+ etag?: string;
518
+ }): AgentConfig {
519
+ const agentId = assertAgentProfileId(input.agentId);
520
+ const profile = input.profile ?? null;
521
+ const sourcePath = sourcePathForProfile(
522
+ profile,
523
+ agentId,
524
+ input.defaultSourcePath ?? agentProfileConfigSourcePath,
525
+ );
526
+ const config = asRecord(input.config);
527
+ const defaults = asRecord(input.defaults);
528
+ const { fields, categoryOrder } = normalizeSchemaPayload(input.schema ?? {});
529
+ const paths = new Set<string>();
530
+
531
+ for (const path of Object.keys(fields)) {
532
+ if (!isSensitiveKey(path)) paths.add(path);
533
+ }
534
+ for (const path of Object.keys(flattenConfigPaths(config))) {
535
+ if (!path.startsWith("_") && !isSensitiveKey(path)) paths.add(path);
536
+ }
537
+
538
+ const sectionMap = new Map<string, AgentConfigField[]>();
539
+ for (const path of [...paths].sort((a, b) => compareConfigPaths(a, b, fields, categoryOrder))) {
540
+ const schema = fields[path];
541
+ const configValue = getPathValue(config, path);
542
+ const defaultValue = getPathValue(defaults, path);
543
+ const rawResolvedValue = configValue !== undefined ? configValue : defaultValue;
544
+ const kind = kindForSchemaField(path, schema, rawResolvedValue);
545
+ const resolvedValue =
546
+ rawResolvedValue === undefined
547
+ ? defaultValueForKind(kind)
548
+ : configFieldValue(rawResolvedValue);
549
+ const category = categoryForPath(path, schema);
550
+ const bucket = sectionMap.get(category) ?? [];
551
+ bucket.push(field({
552
+ key: path,
553
+ label: labelFromPath(path),
554
+ description: cleanString(schema?.description) || path,
555
+ kind,
556
+ value: resolvedValue,
557
+ sourcePath: pathSegments(path),
558
+ }));
559
+ sectionMap.set(category, bucket);
560
+ }
561
+
562
+ const identitySection = section("profile", "Profile", [
563
+ field({
564
+ key: "profile.name",
565
+ label: "Profile",
566
+ description: "Profile that owns this config",
567
+ kind: { type: "text" },
568
+ value: profile?.agentName || agentId,
569
+ editable: false,
570
+ sourcePath: ["profile", "name"],
571
+ }),
572
+ field({
573
+ key: "profile.configPath",
574
+ label: "Config source",
575
+ description: "Profile config source",
576
+ kind: { type: "text" },
577
+ value: sourcePath,
578
+ editable: false,
579
+ sourcePath: ["profile", "config.yaml"],
580
+ }),
581
+ ]);
582
+
583
+ const sectionOrder = [
584
+ ...categoryOrder,
585
+ ...[...sectionMap.keys()].filter((category) => !categoryOrder.includes(category)).sort(),
586
+ ];
587
+ const configSections = sectionOrder
588
+ .map((category) => section(category, titleCase(category), sectionMap.get(category) ?? []))
589
+ .filter((value): value is AgentConfigSection => value !== null);
590
+
591
+ const voice = parseAgentVoiceConfig(config);
592
+
593
+ return {
594
+ agentId,
595
+ agentName: profile?.agentName || agentId,
596
+ sourcePath,
597
+ ...(input.etag ? { etag: input.etag } : {}),
598
+ sections: [identitySection, ...configSections]
599
+ .filter((value): value is AgentConfigSection => value !== null),
600
+ ...(voice.voices.length > 0 ? { voice } : {}),
601
+ fetchedAt: input.fetchedAt ?? Date.now(),
602
+ };
603
+ }
604
+
605
+ function normalizeNativeConfigResponse(
606
+ payload: unknown,
607
+ agentId: string,
608
+ defaultSourcePath: AgentProfileSourcePathResolver,
609
+ ): AgentConfig | null {
610
+ const root = asRecord(payload);
611
+ const candidate = asRecord(root.config).sections ? asRecord(root.config) : root;
612
+ if (Array.isArray(candidate.sections)) {
613
+ const voice = parseAgentVoiceConfig(candidate);
614
+ return {
615
+ agentId: cleanString(candidate.agentId) || agentId,
616
+ agentName: cleanString(candidate.agentName) || cleanString(candidate.name) || agentId,
617
+ ...(cleanString(candidate.sourcePath) ? { sourcePath: cleanString(candidate.sourcePath) } : {}),
618
+ ...(cleanString(candidate.etag) ? { etag: cleanString(candidate.etag) } : {}),
619
+ sections: candidate.sections as AgentConfigSection[],
620
+ ...(voice.voices.length > 0 ? { voice } : {}),
621
+ fetchedAt: asNumber(candidate.fetchedAt) ?? Date.now(),
622
+ };
623
+ }
624
+
625
+ if (Object.keys(asRecord(root.schema)).length > 0 || Object.keys(asRecord(root.defaults)).length > 0) {
626
+ return buildAgentConfigFromConfigSnapshot({
627
+ agentId,
628
+ config: asRecord(root.config),
629
+ schema: root.schema,
630
+ defaults: root.defaults,
631
+ defaultSourcePath,
632
+ profile: asRecord(root.profile).name
633
+ ? {
634
+ agentId,
635
+ agentName: cleanString(asRecord(root.profile).name) || agentId,
636
+ sourcePath: cleanString(asRecord(root.profile).path),
637
+ }
638
+ : null,
639
+ fetchedAt: asNumber(root.fetchedAt) ?? Date.now(),
640
+ etag: cleanString(root.etag),
641
+ });
642
+ }
643
+
644
+ const rawConfig =
645
+ asRecord(root.rawConfig).model || asRecord(root.rawConfig).agent
646
+ ? asRecord(root.rawConfig)
647
+ : asRecord(root.config);
648
+ if (Object.keys(rawConfig).length > 0) {
649
+ return buildAgentConfigFromConfigSnapshot({
650
+ agentId,
651
+ config: rawConfig,
652
+ defaultSourcePath,
653
+ profile: asRecord(root.profile).name
654
+ ? {
655
+ agentId,
656
+ agentName: cleanString(asRecord(root.profile).name) || agentId,
657
+ sourcePath: cleanString(asRecord(root.profile).path),
658
+ }
659
+ : null,
660
+ fetchedAt: asNumber(root.fetchedAt) ?? Date.now(),
661
+ etag: cleanString(root.etag),
662
+ });
663
+ }
664
+
665
+ return null;
666
+ }
667
+
668
+ export function buildAgentProfileConfigPatchBody(params: {
669
+ agentId: string;
670
+ diff: AgentConfigDraftDiff;
671
+ baseEtag?: string;
672
+ sourcePath?: string;
673
+ defaultSourcePath?: AgentProfileSourcePathResolver;
674
+ }): AgentProfileConfigPatchBody {
675
+ const agentId = assertAgentProfileId(params.agentId);
676
+ const patch = Object.fromEntries(
677
+ Object.entries(params.diff).filter(([, value]) => value !== undefined),
678
+ ) as AgentConfigDraftDiff;
679
+ return {
680
+ contract: AGENT_PROFILE_CONFIG_PATCH_CONTRACT,
681
+ version: 1,
682
+ agentId,
683
+ profile: agentId,
684
+ source: "profile-config-yaml",
685
+ sourcePath:
686
+ cleanString(params.sourcePath) ||
687
+ (params.defaultSourcePath ?? agentProfileConfigSourcePath)(agentId),
688
+ patch,
689
+ ...(params.baseEtag ? { baseEtag: params.baseEtag } : {}),
690
+ };
691
+ }
692
+
693
+ export type GatewayAgentConfigEndpointMap = {
694
+ profiles: string;
695
+ config: string;
696
+ configDefaults: string;
697
+ configSchema: string;
698
+ agentConfigs: string;
699
+ agentConfig: (agentId: string) => string;
700
+ };
701
+
702
+ export type GatewayAgentConfigApiClientOptions = {
703
+ endpoints?: GatewayAgentConfigEndpointMap;
704
+ surface?: string;
705
+ defaultSourcePath?: AgentProfileSourcePathResolver;
706
+ };
707
+
708
+ export type PatchProfileConfigOptions = {
709
+ baseEtag?: string;
710
+ sourcePath?: string;
711
+ };
712
+
713
+ export interface GatewayAgentConfigClient {
714
+ listProfiles(): Promise<AgentProfileSummary[]>;
715
+ getProfileConfig(agentId: string): Promise<AgentConfig>;
716
+ patchProfileConfig(
717
+ agentId: string,
718
+ diff: AgentConfigDraftDiff,
719
+ options?: PatchProfileConfigOptions,
720
+ ): Promise<AgentConfig>;
721
+ }
722
+
723
+ export class GatewayAgentConfigApiClient
724
+ extends BaseHttpApiClient
725
+ implements GatewayAgentConfigClient
726
+ {
727
+ readonly endpoints: GatewayAgentConfigEndpointMap;
728
+ protected readonly defaultSourcePath: AgentProfileSourcePathResolver;
729
+
730
+ constructor(
731
+ options: HttpApiClientOptions,
732
+ configOptions: GatewayAgentConfigApiClientOptions = {},
733
+ ) {
734
+ super(configOptions.surface ?? "gateway-agent-config-api", options);
735
+ this.endpoints = configOptions.endpoints ?? GATEWAY_AGENT_CONFIG_API_ENDPOINTS;
736
+ this.defaultSourcePath = configOptions.defaultSourcePath ?? agentProfileConfigSourcePath;
737
+ }
738
+
739
+ async listProfiles(): Promise<AgentProfileSummary[]> {
740
+ try {
741
+ const nativePayload = await this.requestJson<unknown>(this.endpoints.agentConfigs);
742
+ const root = asRecord(nativePayload);
743
+ const nativeProfiles = normalizeAgentProfiles({ profiles: root.agents ?? root.profiles });
744
+ if (nativeProfiles.length > 0) return nativeProfiles;
745
+ } catch (error) {
746
+ if (!isMissingAgentConfigRouteError(error)) throw error;
747
+ }
748
+ return normalizeAgentProfiles(await this.requestJson<unknown>(this.endpoints.profiles));
749
+ }
750
+
751
+ async getProfileConfig(agentId: string): Promise<AgentConfig> {
752
+ const id = assertAgentProfileId(agentId);
753
+ const payload = await this.requestJson<unknown>(this.endpoints.agentConfig(id));
754
+ const config = normalizeNativeConfigResponse(payload, id, this.defaultSourcePath);
755
+ if (!config) {
756
+ throw new GatewayAgentConfigApiError(
757
+ "Agent config API returned an invalid config payload.",
758
+ { path: this.endpoints.agentConfig(id) },
759
+ );
760
+ }
761
+ return config;
762
+ }
763
+
764
+ async patchProfileConfig(
765
+ agentId: string,
766
+ diff: AgentConfigDraftDiff,
767
+ options: PatchProfileConfigOptions = {},
768
+ ): Promise<AgentConfig> {
769
+ const id = assertAgentProfileId(agentId);
770
+ const body = buildAgentProfileConfigPatchBody({
771
+ agentId: id,
772
+ diff,
773
+ baseEtag: options.baseEtag,
774
+ sourcePath: options.sourcePath,
775
+ defaultSourcePath: this.defaultSourcePath,
776
+ });
777
+
778
+ const payload = await this.requestJson<unknown>(this.endpoints.agentConfig(id), {
779
+ method: "PATCH",
780
+ body,
781
+ });
782
+ const config = normalizeNativeConfigResponse(payload, id, this.defaultSourcePath);
783
+ if (config) return config;
784
+ return this.getProfileConfig(id);
785
+ }
786
+ }