@elizaos/plugin-elizacloud 2.0.0-alpha.8 → 2.0.11-beta.7

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 (452) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +196 -0
  3. package/auto-enable.ts +22 -0
  4. package/dist/browser/index.browser.js +2 -21
  5. package/dist/browser/index.browser.js.map +5 -38
  6. package/dist/cjs/index.d.ts +2 -2
  7. package/dist/cjs/index.node.cjs +9112 -2265
  8. package/dist/cjs/index.node.js.map +68 -30
  9. package/dist/cloud/auth-service-types.d.ts +8 -0
  10. package/dist/cloud/auth-service-types.d.ts.map +1 -0
  11. package/dist/cloud/auth-service-types.js +36 -0
  12. package/dist/cloud/auth-service-types.js.map +10 -0
  13. package/dist/cloud/auth.d.ts +19 -0
  14. package/dist/cloud/auth.d.ts.map +1 -0
  15. package/dist/cloud/auth.js +283 -0
  16. package/dist/cloud/auth.js.map +12 -0
  17. package/dist/cloud/backup.d.ts +18 -0
  18. package/dist/cloud/backup.d.ts.map +1 -0
  19. package/dist/cloud/backup.js +63 -0
  20. package/dist/cloud/backup.js.map +10 -0
  21. package/dist/cloud/base-url.d.ts +7 -0
  22. package/dist/cloud/base-url.d.ts.map +1 -0
  23. package/dist/cloud/base-url.js +29 -0
  24. package/dist/cloud/base-url.js.map +10 -0
  25. package/dist/cloud/bridge-client.d.ts +126 -0
  26. package/dist/cloud/bridge-client.d.ts.map +1 -0
  27. package/dist/cloud/bridge-client.js +384 -0
  28. package/dist/cloud/bridge-client.js.map +11 -0
  29. package/dist/cloud/clack-observer.d.ts +35 -0
  30. package/dist/cloud/clack-observer.d.ts.map +1 -0
  31. package/dist/cloud/clack-observer.js +143 -0
  32. package/dist/cloud/clack-observer.js.map +10 -0
  33. package/dist/cloud/cloud-api-key.d.ts +26 -0
  34. package/dist/cloud/cloud-api-key.d.ts.map +1 -0
  35. package/dist/cloud/cloud-api-key.js +60 -0
  36. package/dist/cloud/cloud-api-key.js.map +10 -0
  37. package/dist/cloud/cloud-manager.d.ts +33 -0
  38. package/dist/cloud/cloud-manager.d.ts.map +1 -0
  39. package/dist/cloud/cloud-manager.js +806 -0
  40. package/dist/cloud/cloud-manager.js.map +16 -0
  41. package/dist/cloud/cloud-proxy.d.ts +20 -0
  42. package/dist/cloud/cloud-proxy.d.ts.map +1 -0
  43. package/dist/cloud/cloud-proxy.js +54 -0
  44. package/dist/cloud/cloud-proxy.js.map +10 -0
  45. package/dist/cloud/cloud-wallet.d.ts +94 -0
  46. package/dist/cloud/cloud-wallet.d.ts.map +1 -0
  47. package/dist/cloud/cloud-wallet.js +362 -0
  48. package/dist/cloud/cloud-wallet.js.map +13 -0
  49. package/dist/cloud/duffel-client.d.ts +181 -0
  50. package/dist/cloud/duffel-client.d.ts.map +1 -0
  51. package/dist/cloud/duffel-client.js +506 -0
  52. package/dist/cloud/duffel-client.js.map +11 -0
  53. package/dist/cloud/index.d.ts +15 -0
  54. package/dist/cloud/index.d.ts.map +1 -0
  55. package/dist/cloud/index.js +1811 -0
  56. package/dist/cloud/index.js.map +24 -0
  57. package/dist/cloud/lifeops-schedule-sync-client.d.ts +43 -0
  58. package/dist/cloud/lifeops-schedule-sync-client.d.ts.map +1 -0
  59. package/dist/cloud/lifeops-schedule-sync-client.js +180 -0
  60. package/dist/cloud/lifeops-schedule-sync-client.js.map +11 -0
  61. package/dist/cloud/lifeops-schedule-sync-contracts.d.ts +89 -0
  62. package/dist/cloud/lifeops-schedule-sync-contracts.d.ts.map +1 -0
  63. package/dist/cloud/lifeops-schedule-sync-contracts.js +39 -0
  64. package/dist/cloud/lifeops-schedule-sync-contracts.js.map +10 -0
  65. package/dist/cloud/managed-payment-clients.d.ts +166 -0
  66. package/dist/cloud/managed-payment-clients.d.ts.map +1 -0
  67. package/dist/cloud/managed-payment-clients.js +238 -0
  68. package/dist/cloud/managed-payment-clients.js.map +11 -0
  69. package/dist/cloud/null-observer.d.ts +35 -0
  70. package/dist/cloud/null-observer.d.ts.map +1 -0
  71. package/dist/cloud/null-observer.js +45 -0
  72. package/dist/cloud/null-observer.js.map +10 -0
  73. package/dist/cloud/reconnect.d.ts +26 -0
  74. package/dist/cloud/reconnect.d.ts.map +1 -0
  75. package/dist/cloud/reconnect.js +104 -0
  76. package/dist/cloud/reconnect.js.map +10 -0
  77. package/dist/cloud/setup-observer.d.ts +98 -0
  78. package/dist/cloud/setup-observer.d.ts.map +1 -0
  79. package/dist/cloud/setup-observer.js +2 -0
  80. package/dist/cloud/setup-observer.js.map +9 -0
  81. package/dist/cloud/validate-url.d.ts +2 -0
  82. package/dist/cloud/validate-url.d.ts.map +1 -0
  83. package/dist/cloud/validate-url.js +175 -0
  84. package/dist/cloud/validate-url.js.map +10 -0
  85. package/dist/cloud/x402-payment-handler.d.ts +85 -0
  86. package/dist/cloud/x402-payment-handler.d.ts.map +1 -0
  87. package/dist/cloud/x402-payment-handler.js +119 -0
  88. package/dist/cloud/x402-payment-handler.js.map +10 -0
  89. package/dist/cloud-providers/cloud-status.d.ts.map +1 -1
  90. package/dist/cloud-providers/cloud-status.js +78 -0
  91. package/dist/cloud-providers/cloud-status.js.map +10 -0
  92. package/dist/cloud-providers/container-health.d.ts.map +1 -1
  93. package/dist/cloud-providers/container-health.js +74 -0
  94. package/dist/cloud-providers/container-health.js.map +10 -0
  95. package/dist/cloud-providers/credit-balance.d.ts.map +1 -1
  96. package/dist/cloud-providers/credit-balance.js +85 -0
  97. package/dist/cloud-providers/credit-balance.js.map +10 -0
  98. package/dist/cloud-providers/index.d.ts.map +1 -1
  99. package/dist/cloud-providers/index.js +24 -0
  100. package/dist/cloud-providers/index.js.map +9 -0
  101. package/dist/cloud-providers/model-registry.d.ts.map +1 -1
  102. package/dist/cloud-providers/model-registry.js +71 -0
  103. package/dist/cloud-providers/model-registry.js.map +10 -0
  104. package/dist/cloud-setup.d.ts +36 -0
  105. package/dist/cloud-setup.d.ts.map +1 -0
  106. package/dist/cloud-setup.js +883 -0
  107. package/dist/cloud-setup.js.map +14 -0
  108. package/dist/cloud-voice-catalog.d.ts +65 -0
  109. package/dist/cloud-voice-catalog.d.ts.map +1 -0
  110. package/dist/cloud-voice-catalog.js +278 -0
  111. package/dist/cloud-voice-catalog.js.map +12 -0
  112. package/dist/index.browser.d.ts +15 -3
  113. package/dist/index.browser.d.ts.map +1 -1
  114. package/dist/index.d.ts +24 -0
  115. package/dist/index.d.ts.map +1 -1
  116. package/dist/index.js +9862 -0
  117. package/dist/index.js.map +77 -0
  118. package/dist/index.node.d.ts +21 -2
  119. package/dist/index.node.d.ts.map +1 -1
  120. package/dist/init.d.ts.map +1 -1
  121. package/dist/init.js +182 -0
  122. package/dist/init.js.map +12 -0
  123. package/dist/lib/cloud-connection.d.ts +77 -0
  124. package/dist/lib/cloud-connection.d.ts.map +1 -0
  125. package/dist/lib/cloud-connection.js +654 -0
  126. package/dist/lib/cloud-connection.js.map +14 -0
  127. package/dist/lib/cloud-secrets.d.ts +10 -0
  128. package/dist/lib/cloud-secrets.d.ts.map +1 -0
  129. package/dist/lib/cloud-secrets.js +36 -0
  130. package/dist/lib/cloud-secrets.js.map +10 -0
  131. package/dist/lib/config-env.d.ts +5 -0
  132. package/dist/lib/config-env.d.ts.map +1 -0
  133. package/dist/lib/config-env.js +191 -0
  134. package/dist/lib/config-env.js.map +11 -0
  135. package/dist/lib/config-like.d.ts +40 -0
  136. package/dist/lib/config-like.d.ts.map +1 -0
  137. package/dist/lib/config-like.js +103 -0
  138. package/dist/lib/config-like.js.map +10 -0
  139. package/dist/lib/credential-type-map.d.ts +53 -0
  140. package/dist/lib/credential-type-map.d.ts.map +1 -0
  141. package/dist/lib/credential-type-map.js +88 -0
  142. package/dist/lib/credential-type-map.js.map +10 -0
  143. package/dist/lib/feature-flags.d.ts +2 -0
  144. package/dist/lib/feature-flags.d.ts.map +1 -0
  145. package/dist/lib/feature-flags.js +40 -0
  146. package/dist/lib/feature-flags.js.map +10 -0
  147. package/dist/lib/http.d.ts +11 -0
  148. package/dist/lib/http.d.ts.map +1 -0
  149. package/dist/lib/http.js +107 -0
  150. package/dist/lib/http.js.map +10 -0
  151. package/dist/lib/server-cloud-tts.d.ts +21 -0
  152. package/dist/lib/server-cloud-tts.d.ts.map +1 -0
  153. package/dist/lib/server-cloud-tts.js +251 -0
  154. package/dist/lib/server-cloud-tts.js.map +10 -0
  155. package/dist/lib/state-paths.d.ts +4 -0
  156. package/dist/lib/state-paths.d.ts.map +1 -0
  157. package/dist/lib/state-paths.js +52 -0
  158. package/dist/lib/state-paths.js.map +10 -0
  159. package/dist/lib/tts-debug.d.ts +6 -0
  160. package/dist/lib/tts-debug.d.ts.map +1 -0
  161. package/dist/lib/tts-debug.js +24 -0
  162. package/dist/lib/tts-debug.js.map +9 -0
  163. package/dist/models/embeddings.d.ts.map +1 -1
  164. package/dist/models/embeddings.js +329 -0
  165. package/dist/models/embeddings.js.map +13 -0
  166. package/dist/models/image.d.ts.map +1 -1
  167. package/dist/models/image.js +401 -0
  168. package/dist/models/image.js.map +14 -0
  169. package/dist/models/index.d.ts +1 -2
  170. package/dist/models/index.d.ts.map +1 -1
  171. package/dist/models/index.js +1896 -0
  172. package/dist/models/index.js.map +19 -0
  173. package/dist/models/research.d.ts.map +1 -1
  174. package/dist/models/research.js +341 -0
  175. package/dist/models/research.js.map +13 -0
  176. package/dist/models/speech.d.ts +61 -3
  177. package/dist/models/speech.d.ts.map +1 -1
  178. package/dist/models/speech.js +429 -0
  179. package/dist/models/speech.js.map +13 -0
  180. package/dist/models/text.d.ts +111 -3
  181. package/dist/models/text.d.ts.map +1 -1
  182. package/dist/models/text.js +1173 -0
  183. package/dist/models/text.js.map +14 -0
  184. package/dist/models/tokenization.d.ts.map +1 -1
  185. package/dist/models/tokenization.js +65 -0
  186. package/dist/models/tokenization.js.map +10 -0
  187. package/dist/models/transcription.d.ts.map +1 -1
  188. package/dist/models/transcription.js +297 -0
  189. package/dist/models/transcription.js.map +13 -0
  190. package/dist/node/index.d.ts +2 -2
  191. package/dist/node/index.node.js +9189 -2295
  192. package/dist/node/index.node.js.map +68 -30
  193. package/dist/plugin.d.ts +20 -0
  194. package/dist/plugin.d.ts.map +1 -0
  195. package/dist/plugin.js +2937 -0
  196. package/dist/plugin.js.map +28 -0
  197. package/dist/providers/openai.d.ts.map +1 -1
  198. package/dist/providers/openai.js +136 -0
  199. package/dist/providers/openai.js.map +11 -0
  200. package/dist/register-routes.d.ts +2 -0
  201. package/dist/register-routes.d.ts.map +1 -0
  202. package/dist/register-routes.js +2938 -0
  203. package/dist/register-routes.js.map +29 -0
  204. package/dist/routes/cloud-billing-routes.d.ts +9 -0
  205. package/dist/routes/cloud-billing-routes.d.ts.map +1 -0
  206. package/dist/routes/cloud-billing-routes.js +764 -0
  207. package/dist/routes/cloud-billing-routes.js.map +15 -0
  208. package/dist/routes/cloud-coding-container-routes.d.ts +8 -0
  209. package/dist/routes/cloud-coding-container-routes.d.ts.map +1 -0
  210. package/dist/routes/cloud-coding-container-routes.js +214 -0
  211. package/dist/routes/cloud-coding-container-routes.js.map +11 -0
  212. package/dist/routes/cloud-compat-routes.d.ts +10 -0
  213. package/dist/routes/cloud-compat-routes.d.ts.map +1 -0
  214. package/dist/routes/cloud-compat-routes.js +495 -0
  215. package/dist/routes/cloud-compat-routes.js.map +15 -0
  216. package/dist/routes/cloud-features-routes.d.ts +9 -0
  217. package/dist/routes/cloud-features-routes.d.ts.map +1 -0
  218. package/dist/routes/cloud-features-routes.js +124 -0
  219. package/dist/routes/cloud-features-routes.js.map +11 -0
  220. package/dist/routes/cloud-provisioning.d.ts +14 -0
  221. package/dist/routes/cloud-provisioning.d.ts.map +1 -0
  222. package/dist/routes/cloud-provisioning.js +37 -0
  223. package/dist/routes/cloud-provisioning.js.map +10 -0
  224. package/dist/routes/cloud-relay-routes.d.ts +23 -0
  225. package/dist/routes/cloud-relay-routes.d.ts.map +1 -0
  226. package/dist/routes/cloud-relay-routes.js +142 -0
  227. package/dist/routes/cloud-relay-routes.js.map +11 -0
  228. package/dist/routes/cloud-routes-autonomous.d.ts +82 -0
  229. package/dist/routes/cloud-routes-autonomous.d.ts.map +1 -0
  230. package/dist/routes/cloud-routes-autonomous.js +1252 -0
  231. package/dist/routes/cloud-routes-autonomous.js.map +18 -0
  232. package/dist/routes/cloud-routes.d.ts +35 -0
  233. package/dist/routes/cloud-routes.d.ts.map +1 -0
  234. package/dist/routes/cloud-routes.js +2173 -0
  235. package/dist/routes/cloud-routes.js.map +23 -0
  236. package/dist/routes/cloud-status-routes-autonomous.d.ts +14 -0
  237. package/dist/routes/cloud-status-routes-autonomous.d.ts.map +1 -0
  238. package/dist/routes/cloud-status-routes-autonomous.js +349 -0
  239. package/dist/routes/cloud-status-routes-autonomous.js.map +13 -0
  240. package/dist/routes/cloud-status-routes.d.ts +4 -0
  241. package/dist/routes/cloud-status-routes.d.ts.map +1 -0
  242. package/dist/routes/cloud-status-routes.js +695 -0
  243. package/dist/routes/cloud-status-routes.js.map +15 -0
  244. package/dist/routes/home-remote-runner-access-url.d.ts +16 -0
  245. package/dist/routes/home-remote-runner-access-url.d.ts.map +1 -0
  246. package/dist/routes/home-remote-runner-access-url.js +91 -0
  247. package/dist/routes/home-remote-runner-access-url.js.map +10 -0
  248. package/dist/routes/travel-provider-relay-routes.d.ts +9 -0
  249. package/dist/routes/travel-provider-relay-routes.d.ts.map +1 -0
  250. package/dist/routes/travel-provider-relay-routes.js +358 -0
  251. package/dist/routes/travel-provider-relay-routes.js.map +14 -0
  252. package/dist/services/cloud-auth.d.ts +140 -5
  253. package/dist/services/cloud-auth.d.ts.map +1 -1
  254. package/dist/services/cloud-auth.js +368 -0
  255. package/dist/services/cloud-auth.js.map +12 -0
  256. package/dist/services/cloud-backup.d.ts.map +1 -1
  257. package/dist/services/cloud-backup.js +176 -0
  258. package/dist/services/cloud-backup.js.map +11 -0
  259. package/dist/services/cloud-bootstrap.d.ts +38 -0
  260. package/dist/services/cloud-bootstrap.d.ts.map +1 -0
  261. package/dist/services/cloud-bootstrap.js +84 -0
  262. package/dist/services/cloud-bootstrap.js.map +10 -0
  263. package/dist/services/cloud-bridge.d.ts +1 -1
  264. package/dist/services/cloud-bridge.d.ts.map +1 -1
  265. package/dist/services/cloud-bridge.js +308 -0
  266. package/dist/services/cloud-bridge.js.map +11 -0
  267. package/dist/services/cloud-container.d.ts +5 -1
  268. package/dist/services/cloud-container.d.ts.map +1 -1
  269. package/dist/services/cloud-container.js +292 -0
  270. package/dist/services/cloud-container.js.map +11 -0
  271. package/dist/services/cloud-credential-provider.d.ts +55 -0
  272. package/dist/services/cloud-credential-provider.d.ts.map +1 -0
  273. package/dist/services/cloud-credential-provider.js +190 -0
  274. package/dist/services/cloud-credential-provider.js.map +11 -0
  275. package/dist/services/cloud-managed-gateway-relay.d.ts +38 -0
  276. package/dist/services/cloud-managed-gateway-relay.d.ts.map +1 -0
  277. package/dist/services/cloud-managed-gateway-relay.js +479 -0
  278. package/dist/services/cloud-managed-gateway-relay.js.map +10 -0
  279. package/dist/services/cloud-model-registry.d.ts.map +1 -1
  280. package/dist/services/cloud-model-registry.js +175 -0
  281. package/dist/services/cloud-model-registry.js.map +10 -0
  282. package/dist/services/index.d.ts +3 -1
  283. package/dist/services/index.d.ts.map +1 -1
  284. package/dist/services/index.js +29 -0
  285. package/dist/services/index.js.map +9 -0
  286. package/dist/types/cloud.d.ts +42 -19
  287. package/dist/types/cloud.d.ts.map +1 -1
  288. package/dist/types/cloud.js +52 -0
  289. package/dist/types/cloud.js.map +10 -0
  290. package/dist/types/index.d.ts +1 -1
  291. package/dist/types/index.d.ts.map +1 -1
  292. package/dist/types/index.js +24 -0
  293. package/dist/types/index.js.map +9 -0
  294. package/dist/utils/cloud-api.d.ts +2 -27
  295. package/dist/utils/cloud-api.d.ts.map +1 -1
  296. package/dist/utils/cloud-api.js +33 -0
  297. package/dist/utils/cloud-api.js.map +10 -0
  298. package/dist/utils/cloud-sdk/client.d.ts +133 -0
  299. package/dist/utils/cloud-sdk/client.d.ts.map +1 -0
  300. package/dist/utils/cloud-sdk/client.js +3693 -0
  301. package/dist/utils/cloud-sdk/client.js.map +13 -0
  302. package/dist/utils/cloud-sdk/http.d.ts +37 -0
  303. package/dist/utils/cloud-sdk/http.d.ts.map +1 -0
  304. package/dist/utils/cloud-sdk/http.js +237 -0
  305. package/dist/utils/cloud-sdk/http.js.map +11 -0
  306. package/dist/utils/cloud-sdk/index.d.ts +6 -0
  307. package/dist/utils/cloud-sdk/index.d.ts.map +1 -0
  308. package/dist/utils/cloud-sdk/index.js +29 -0
  309. package/dist/utils/cloud-sdk/index.js.map +9 -0
  310. package/dist/utils/cloud-sdk/public-routes.d.ts +5563 -0
  311. package/dist/utils/cloud-sdk/public-routes.d.ts.map +1 -0
  312. package/dist/utils/cloud-sdk/public-routes.js +3048 -0
  313. package/dist/utils/cloud-sdk/public-routes.js.map +10 -0
  314. package/dist/utils/cloud-sdk/types.cloud-api.d.ts +101 -0
  315. package/dist/utils/cloud-sdk/types.cloud-api.d.ts.map +1 -0
  316. package/dist/utils/cloud-sdk/types.cloud-api.js +2 -0
  317. package/dist/utils/cloud-sdk/types.cloud-api.js.map +9 -0
  318. package/dist/utils/cloud-sdk/types.d.ts +653 -0
  319. package/dist/utils/cloud-sdk/types.d.ts.map +1 -0
  320. package/dist/utils/cloud-sdk/types.js +29 -0
  321. package/dist/utils/cloud-sdk/types.js.map +10 -0
  322. package/dist/utils/config.d.ts +16 -3
  323. package/dist/utils/config.d.ts.map +1 -1
  324. package/dist/utils/config.js +147 -0
  325. package/dist/utils/config.js.map +10 -0
  326. package/dist/utils/events.d.ts +23 -2
  327. package/dist/utils/events.d.ts.map +1 -1
  328. package/dist/utils/events.js +45 -0
  329. package/dist/utils/events.js.map +10 -0
  330. package/dist/utils/helpers.d.ts.map +1 -1
  331. package/dist/utils/helpers.js +103 -0
  332. package/dist/utils/helpers.js.map +10 -0
  333. package/dist/utils/responses-output.d.ts +13 -0
  334. package/dist/utils/responses-output.d.ts.map +1 -0
  335. package/dist/utils/responses-output.js +102 -0
  336. package/dist/utils/responses-output.js.map +10 -0
  337. package/dist/utils/sdk-client.d.ts +5 -0
  338. package/dist/utils/sdk-client.d.ts.map +1 -0
  339. package/dist/utils/sdk-client.js +157 -0
  340. package/dist/utils/sdk-client.js.map +11 -0
  341. package/dist/utils/waifu-metering.d.ts +108 -0
  342. package/dist/utils/waifu-metering.d.ts.map +1 -0
  343. package/dist/utils/waifu-metering.js +166 -0
  344. package/dist/utils/waifu-metering.js.map +10 -0
  345. package/package.json +139 -21
  346. package/src/cloud/auth-service-types.ts +24 -0
  347. package/src/cloud/auth.ts +175 -0
  348. package/src/cloud/backup.ts +46 -0
  349. package/src/cloud/base-url.ts +6 -0
  350. package/src/cloud/bridge-client.ts +602 -0
  351. package/src/cloud/clack-observer.ts +189 -0
  352. package/src/cloud/cloud-api-key.ts +80 -0
  353. package/src/cloud/cloud-manager.ts +163 -0
  354. package/src/cloud/cloud-proxy.ts +52 -0
  355. package/src/cloud/cloud-wallet.ts +341 -0
  356. package/src/cloud/duffel-client.ts +847 -0
  357. package/src/cloud/index.ts +38 -0
  358. package/src/cloud/lifeops-schedule-sync-client.ts +245 -0
  359. package/src/cloud/lifeops-schedule-sync-contracts.ts +124 -0
  360. package/src/cloud/managed-payment-clients.ts +374 -0
  361. package/src/cloud/null-observer.ts +45 -0
  362. package/src/cloud/reconnect.ts +111 -0
  363. package/src/cloud/setup-observer.ts +125 -0
  364. package/src/cloud/validate-url.ts +187 -0
  365. package/src/cloud/x402-payment-handler.ts +215 -0
  366. package/src/cloud-providers/cloud-status.ts +75 -0
  367. package/src/cloud-providers/container-health.ts +68 -0
  368. package/src/cloud-providers/credit-balance.ts +70 -0
  369. package/src/cloud-providers/index.ts +3 -0
  370. package/src/cloud-providers/model-registry.ts +74 -0
  371. package/src/cloud-setup.ts +531 -0
  372. package/src/cloud-voice-catalog.test.ts +254 -0
  373. package/src/cloud-voice-catalog.ts +246 -0
  374. package/src/index.browser.ts +39 -0
  375. package/src/index.node.ts +69 -0
  376. package/src/index.ts +419 -0
  377. package/src/init.ts +39 -0
  378. package/src/lib/cloud-connection.ts +661 -0
  379. package/src/lib/cloud-secrets.ts +14 -0
  380. package/src/lib/config-env.ts +168 -0
  381. package/src/lib/config-like.ts +149 -0
  382. package/src/lib/credential-type-map.ts +130 -0
  383. package/src/lib/feature-flags.ts +26 -0
  384. package/src/lib/http.ts +122 -0
  385. package/src/lib/server-cloud-tts.ts +301 -0
  386. package/src/lib/state-paths.ts +28 -0
  387. package/src/lib/tts-debug.ts +5 -0
  388. package/src/models/embeddings.ts +298 -0
  389. package/src/models/image.ts +234 -0
  390. package/src/models/index.ts +16 -0
  391. package/src/models/research.ts +275 -0
  392. package/src/models/speech.ts +324 -0
  393. package/src/models/text.ts +1493 -0
  394. package/src/models/tokenization.ts +67 -0
  395. package/src/models/transcription.ts +101 -0
  396. package/src/plugin.ts +281 -0
  397. package/src/providers/openai.ts +16 -0
  398. package/src/register-routes.ts +6 -0
  399. package/src/routes/cloud-billing-routes.ts +744 -0
  400. package/src/routes/cloud-coding-container-routes.ts +198 -0
  401. package/src/routes/cloud-compat-routes.ts +304 -0
  402. package/src/routes/cloud-features-routes.ts +57 -0
  403. package/src/routes/cloud-provisioning.ts +37 -0
  404. package/src/routes/cloud-relay-routes.ts +135 -0
  405. package/src/routes/cloud-routes-autonomous.ts +993 -0
  406. package/src/routes/cloud-routes.ts +637 -0
  407. package/src/routes/cloud-status-routes-autonomous.ts +238 -0
  408. package/src/routes/cloud-status-routes.ts +73 -0
  409. package/src/routes/home-remote-runner-access-url.ts +83 -0
  410. package/src/routes/travel-provider-relay-routes.ts +193 -0
  411. package/src/services/cloud-auth.ts +574 -0
  412. package/src/services/cloud-backup.ts +208 -0
  413. package/src/services/cloud-bootstrap.ts +106 -0
  414. package/src/services/cloud-bridge.ts +386 -0
  415. package/src/services/cloud-container.ts +390 -0
  416. package/src/services/cloud-credential-provider.ts +210 -0
  417. package/src/services/cloud-managed-gateway-relay.ts +663 -0
  418. package/src/services/cloud-model-registry.ts +202 -0
  419. package/src/services/index.ts +17 -0
  420. package/{types → src/types}/cloud.ts +74 -29
  421. package/{types → src/types}/index.ts +25 -0
  422. package/src/utils/cloud-api.ts +10 -0
  423. package/src/utils/cloud-sdk/client.ts +774 -0
  424. package/src/utils/cloud-sdk/http.ts +291 -0
  425. package/src/utils/cloud-sdk/index.ts +23 -0
  426. package/src/utils/cloud-sdk/public-routes.ts +5238 -0
  427. package/src/utils/cloud-sdk/types.cloud-api.ts +120 -0
  428. package/src/utils/cloud-sdk/types.ts +760 -0
  429. package/src/utils/config.ts +193 -0
  430. package/src/utils/events.ts +65 -0
  431. package/src/utils/helpers.ts +107 -0
  432. package/src/utils/responses-output.ts +115 -0
  433. package/src/utils/sdk-client.ts +41 -0
  434. package/src/utils/waifu-metering.ts +302 -0
  435. package/dist/actions/check-credits.d.ts +0 -6
  436. package/dist/actions/check-credits.d.ts.map +0 -1
  437. package/dist/actions/freeze-agent.d.ts +0 -9
  438. package/dist/actions/freeze-agent.d.ts.map +0 -1
  439. package/dist/actions/index.d.ts +0 -5
  440. package/dist/actions/index.d.ts.map +0 -1
  441. package/dist/actions/provision-agent.d.ts +0 -8
  442. package/dist/actions/provision-agent.d.ts.map +0 -1
  443. package/dist/actions/resume-agent.d.ts +0 -9
  444. package/dist/actions/resume-agent.d.ts.map +0 -1
  445. package/dist/build.d.ts +0 -3
  446. package/dist/build.d.ts.map +0 -1
  447. package/dist/generated/specs/specs.d.ts +0 -55
  448. package/dist/generated/specs/specs.d.ts.map +0 -1
  449. package/dist/models/object.d.ts +0 -4
  450. package/dist/models/object.d.ts.map +0 -1
  451. package/dist/utils/forwarded-settings.d.ts +0 -8
  452. package/dist/utils/forwarded-settings.d.ts.map +0 -1
@@ -0,0 +1,2173 @@
1
+ import { createRequire } from "node:module";
2
+ var __defProp = Object.defineProperty;
3
+ var __returnValue = (v) => v;
4
+ function __exportSetter(name, newValue) {
5
+ this[name] = __returnValue.bind(null, newValue);
6
+ }
7
+ var __export = (target, all) => {
8
+ for (var name in all)
9
+ __defProp(target, name, {
10
+ get: all[name],
11
+ enumerable: true,
12
+ configurable: true,
13
+ set: __exportSetter.bind(all, name)
14
+ });
15
+ };
16
+ var __esm = (fn, res) => () => (fn && (res = fn(fn = 0)), res);
17
+ var __require = /* @__PURE__ */ createRequire(import.meta.url);
18
+
19
+ // src/cloud/base-url.ts
20
+ import { normalizeCloudSiteUrl, resolveCloudApiBaseUrl } from "@elizaos/shared";
21
+ var init_base_url = () => {};
22
+
23
+ // src/cloud/validate-url.ts
24
+ import dns from "node:dns";
25
+ import net from "node:net";
26
+ import { promisify } from "node:util";
27
+ function normalizeHostLike(value) {
28
+ return value.trim().toLowerCase().replace(/^\[|\]$/g, "");
29
+ }
30
+ function decodeIpv6MappedHex(mapped) {
31
+ const parts = mapped.split(":");
32
+ if (parts.length < 1 || parts.length > 2)
33
+ return null;
34
+ const parsed = parts.map((part) => {
35
+ if (!/^[0-9a-f]{1,4}$/i.test(part))
36
+ return Number.NaN;
37
+ return Number.parseInt(part, 16);
38
+ });
39
+ if (parsed.some((value) => !Number.isFinite(value)))
40
+ return null;
41
+ const [hi, lo] = parsed.length === 1 ? [0, parsed[0]] : parsed;
42
+ const octets = [hi >> 8, hi & 255, lo >> 8, lo & 255];
43
+ return octets.join(".");
44
+ }
45
+ function canonicalizeIpv6(ip) {
46
+ try {
47
+ return new URL(`http://[${ip}]/`).hostname.replace(/^\[|\]$/g, "");
48
+ } catch {
49
+ return null;
50
+ }
51
+ }
52
+ function normalizeIpForPolicy(ip) {
53
+ const base = normalizeHostLike(ip).split("%")[0];
54
+ if (!base)
55
+ return base;
56
+ let normalized = base;
57
+ if (net.isIP(normalized) === 6) {
58
+ normalized = canonicalizeIpv6(normalized) ?? normalized;
59
+ }
60
+ let mapped = null;
61
+ if (normalized.startsWith("::ffff:")) {
62
+ mapped = normalized.slice("::ffff:".length);
63
+ } else if (normalized.startsWith("0:0:0:0:0:ffff:")) {
64
+ mapped = normalized.slice("0:0:0:0:0:ffff:".length);
65
+ }
66
+ if (!mapped)
67
+ return normalized;
68
+ if (net.isIP(mapped) === 4)
69
+ return mapped;
70
+ return decodeIpv6MappedHex(mapped) ?? normalized;
71
+ }
72
+ function cidrV4(base, prefix) {
73
+ const parsed = parseIpv4ToInt(base);
74
+ if (parsed === null) {
75
+ throw new Error(`Invalid CIDR base IPv4 address: ${base}`);
76
+ }
77
+ const shift = 32 - prefix;
78
+ const mask = shift === 32 ? 0 : 4294967295 << shift >>> 0;
79
+ return { base: parsed & mask, mask };
80
+ }
81
+ function parseIpv4ToInt(ip) {
82
+ const parts = ip.split(".");
83
+ if (parts.length !== 4)
84
+ return null;
85
+ let value = 0;
86
+ for (const part of parts) {
87
+ if (!/^\d{1,3}$/.test(part))
88
+ return null;
89
+ const octet = Number.parseInt(part, 10);
90
+ if (!Number.isInteger(octet) || octet < 0 || octet > 255)
91
+ return null;
92
+ value = value << 8 | octet;
93
+ }
94
+ return value >>> 0;
95
+ }
96
+ function isBlockedIpv4(ip) {
97
+ const asInt = parseIpv4ToInt(ip);
98
+ if (asInt === null)
99
+ return true;
100
+ return BLOCKED_IPV4_CIDRS.some((cidr) => (asInt & cidr.mask) === cidr.base);
101
+ }
102
+ function isBlockedIpv6(ip) {
103
+ const normalized = ip.toLowerCase();
104
+ return normalized === "::" || normalized === "::1" || /^fe[89ab][0-9a-f]:/.test(normalized) || /^f[cd][0-9a-f]{2}:/i.test(normalized) || normalized.startsWith("ff");
105
+ }
106
+ function isBlockedIp(ip) {
107
+ const normalized = normalizeIpForPolicy(ip);
108
+ const family = net.isIP(normalized);
109
+ if (family === 4)
110
+ return isBlockedIpv4(normalized);
111
+ if (family === 6)
112
+ return isBlockedIpv6(normalized);
113
+ return false;
114
+ }
115
+ async function validateCloudBaseUrl(rawUrl) {
116
+ let parsed;
117
+ try {
118
+ parsed = new URL(rawUrl);
119
+ } catch {
120
+ return `Invalid cloud base URL: "${rawUrl}"`;
121
+ }
122
+ if (parsed.protocol !== "https:") {
123
+ return `Cloud base URL must use HTTPS, got "${parsed.protocol}" in "${rawUrl}"`;
124
+ }
125
+ const hostname = normalizeHostLike(parsed.hostname);
126
+ if (!hostname) {
127
+ return `Invalid cloud base URL: "${rawUrl}"`;
128
+ }
129
+ if (hostname === "localhost" || hostname.endsWith(".localhost") || hostname.endsWith(".local")) {
130
+ return `Cloud base URL "${rawUrl}" points to a blocked local hostname.`;
131
+ }
132
+ const elizaDev = process.env.ELIZA_DEV?.trim().toLowerCase();
133
+ if (true) {
134
+ return null;
135
+ }
136
+ if (isBlockedIp(hostname)) {
137
+ return `Cloud base URL "${rawUrl}" points to a blocked address.`;
138
+ }
139
+ try {
140
+ const results = await dnsLookupAll(hostname, { all: true });
141
+ const addresses = Array.isArray(results) ? results : [results];
142
+ for (const entry of addresses) {
143
+ const ip = typeof entry === "string" ? entry : entry.address;
144
+ if (isBlockedIp(ip)) {
145
+ return `Cloud base URL "${rawUrl}" resolves to ${ip}, ` + "which is a blocked internal/metadata address.";
146
+ }
147
+ }
148
+ } catch {
149
+ return `Cloud base URL "${rawUrl}" could not be resolved via DNS.`;
150
+ }
151
+ return null;
152
+ }
153
+ var dnsLookupAll, BLOCKED_IPV4_CIDRS;
154
+ var init_validate_url = __esm(() => {
155
+ dnsLookupAll = promisify(dns.lookup);
156
+ BLOCKED_IPV4_CIDRS = [
157
+ cidrV4("0.0.0.0", 8),
158
+ cidrV4("10.0.0.0", 8),
159
+ cidrV4("172.16.0.0", 12),
160
+ cidrV4("192.168.0.0", 16),
161
+ cidrV4("100.64.0.0", 10),
162
+ cidrV4("127.0.0.0", 8),
163
+ cidrV4("169.254.0.0", 16),
164
+ cidrV4("192.0.0.0", 24),
165
+ cidrV4("198.18.0.0", 15),
166
+ cidrV4("192.0.2.0", 24),
167
+ cidrV4("198.51.100.0", 24),
168
+ cidrV4("203.0.113.0", 24),
169
+ cidrV4("224.0.0.0", 4),
170
+ cidrV4("240.0.0.0", 4)
171
+ ];
172
+ });
173
+
174
+ // src/lib/state-paths.ts
175
+ import fs from "node:fs";
176
+ import path from "node:path";
177
+ import {
178
+ getElizaNamespace,
179
+ resolveStateDir,
180
+ resolveUserPath
181
+ } from "@elizaos/core";
182
+ function resolveConfigPath(env = process.env, stateDirPath = resolveStateDir(env)) {
183
+ const override = env.ELIZA_CONFIG_PATH?.trim();
184
+ if (override)
185
+ return resolveUserPath(override);
186
+ const namespace = getElizaNamespace(env);
187
+ const primaryPath = path.join(stateDirPath, `${namespace}.json`);
188
+ if (fs.existsSync(primaryPath))
189
+ return primaryPath;
190
+ if (namespace !== "eliza") {
191
+ const legacyPath = path.join(stateDirPath, "eliza.json");
192
+ if (fs.existsSync(legacyPath))
193
+ return legacyPath;
194
+ }
195
+ return primaryPath;
196
+ }
197
+ var init_state_paths = () => {};
198
+
199
+ // src/lib/config-env.ts
200
+ import fs2 from "node:fs/promises";
201
+ import path2 from "node:path";
202
+ function parseConfigEnv(contents) {
203
+ const lines = contents.length === 0 ? [] : contents.split(/\r?\n/);
204
+ if (lines.length > 0 && lines[lines.length - 1] === "") {
205
+ lines.pop();
206
+ }
207
+ const index = new Map;
208
+ for (let i = 0;i < lines.length; i += 1) {
209
+ const line = lines[i] ?? "";
210
+ const trimmed = line.trim();
211
+ if (!trimmed || trimmed.startsWith("#"))
212
+ continue;
213
+ const eq = line.indexOf("=");
214
+ if (eq <= 0)
215
+ continue;
216
+ const key = line.slice(0, eq).trim();
217
+ if (KEY_PATTERN.test(key))
218
+ index.set(key, i);
219
+ }
220
+ return { lines, index };
221
+ }
222
+ function serialiseConfigEnv(parsed) {
223
+ return parsed.lines.length === 0 ? "" : `${parsed.lines.join(`
224
+ `)}
225
+ `;
226
+ }
227
+ function encodeValue(value) {
228
+ if (value === "")
229
+ return "";
230
+ const needsQuoting = /[\s#"'\\]|^\s|\s$/.test(value) || /\n|\r/.test(value);
231
+ if (!needsQuoting)
232
+ return value;
233
+ const escaped = value.replace(/\\/g, "\\\\").replace(/"/g, "\\\"").replace(/\n/g, "\\n").replace(/\r/g, "\\r");
234
+ return `"${escaped}"`;
235
+ }
236
+ function validateKey(key) {
237
+ if (!KEY_PATTERN.test(key)) {
238
+ throw new Error(`persistConfigEnv: invalid key "${key}" - must match /^[A-Z][A-Z0-9_]*$/`);
239
+ }
240
+ if (BLOCKED_CONFIG_ENV_KEYS.has(key)) {
241
+ throw new Error(`persistConfigEnv: key "${key}" is a shell/runtime hijack vector and cannot be written`);
242
+ }
243
+ }
244
+ async function readIfExists(filePath) {
245
+ try {
246
+ return await fs2.readFile(filePath, "utf8");
247
+ } catch (error) {
248
+ if (error.code === "ENOENT")
249
+ return null;
250
+ throw error;
251
+ }
252
+ }
253
+ async function writeAtomic(filePath, contents) {
254
+ const tmpPath = `${filePath}${TMP_SUFFIX}`;
255
+ const handle = await fs2.open(tmpPath, "w", 384);
256
+ try {
257
+ await handle.writeFile(contents, "utf8");
258
+ await handle.sync();
259
+ } finally {
260
+ await handle.close();
261
+ }
262
+ await fs2.rename(tmpPath, filePath);
263
+ }
264
+ function serialise(fn) {
265
+ const next = writeChain.then(fn, fn);
266
+ writeChain = next.catch(() => {
267
+ return;
268
+ });
269
+ return next;
270
+ }
271
+ function resolveConfigEnvPath(stateDir) {
272
+ return path2.join(stateDir ?? resolveStateDir(), CONFIG_ENV_FILENAME);
273
+ }
274
+ async function persistConfigEnv(key, value, opts = {}) {
275
+ validateKey(key);
276
+ await serialise(async () => {
277
+ const filePath = resolveConfigEnvPath(opts.stateDir);
278
+ await fs2.mkdir(path2.dirname(filePath), { recursive: true });
279
+ const existing = await readIfExists(filePath) ?? "";
280
+ const parsed = parseConfigEnv(existing);
281
+ const existingIdx = parsed.index.get(key);
282
+ const isDelete = value === "";
283
+ if (isDelete) {
284
+ if (existingIdx === undefined) {
285
+ delete process.env[key];
286
+ return;
287
+ }
288
+ parsed.lines.splice(existingIdx, 1);
289
+ } else {
290
+ const encoded = `${key}=${encodeValue(value)}`;
291
+ if (existingIdx === undefined) {
292
+ parsed.lines.push(encoded);
293
+ } else {
294
+ parsed.lines[existingIdx] = encoded;
295
+ }
296
+ }
297
+ if (existing.length > 0) {
298
+ await fs2.writeFile(`${filePath}${BAK_SUFFIX}`, existing, {
299
+ encoding: "utf8",
300
+ mode: 384
301
+ });
302
+ }
303
+ await writeAtomic(filePath, serialiseConfigEnv(parsed));
304
+ if (isDelete) {
305
+ delete process.env[key];
306
+ } else {
307
+ process.env[key] = value;
308
+ }
309
+ });
310
+ }
311
+ var CONFIG_ENV_FILENAME = "config.env", BAK_SUFFIX = ".bak", TMP_SUFFIX = ".tmp", KEY_PATTERN, BLOCKED_CONFIG_ENV_KEYS, writeChain;
312
+ var init_config_env = __esm(() => {
313
+ init_state_paths();
314
+ KEY_PATTERN = /^[A-Z][A-Z0-9_]*$/;
315
+ BLOCKED_CONFIG_ENV_KEYS = new Set([
316
+ "NODE_OPTIONS",
317
+ "NODE_EXTRA_CA_CERTS",
318
+ "NODE_TLS_REJECT_UNAUTHORIZED",
319
+ "NODE_PATH",
320
+ "LD_PRELOAD",
321
+ "LD_LIBRARY_PATH",
322
+ "DYLD_INSERT_LIBRARIES",
323
+ "DYLD_LIBRARY_PATH",
324
+ "DYLD_FRAMEWORK_PATH",
325
+ "DYLD_FALLBACK_FRAMEWORK_PATH",
326
+ "DYLD_FALLBACK_LIBRARY_PATH",
327
+ "PATH",
328
+ "HOME",
329
+ "SHELL",
330
+ "HTTP_PROXY",
331
+ "HTTPS_PROXY",
332
+ "ALL_PROXY",
333
+ "NO_PROXY",
334
+ "SSL_CERT_FILE",
335
+ "SSL_CERT_DIR",
336
+ "CURL_CA_BUNDLE"
337
+ ]);
338
+ writeChain = Promise.resolve();
339
+ });
340
+
341
+ // src/lib/feature-flags.ts
342
+ function readBoolFlag(name, fallback = false) {
343
+ const raw = process.env[name];
344
+ if (raw === undefined || raw === null || raw === "")
345
+ return fallback;
346
+ const trimmed = String(raw).trim().toLowerCase();
347
+ if (trimmed === "1" || trimmed === "true" || trimmed === "yes" || trimmed === "on") {
348
+ return true;
349
+ }
350
+ if (trimmed === "0" || trimmed === "false" || trimmed === "no" || trimmed === "off") {
351
+ return false;
352
+ }
353
+ return fallback;
354
+ }
355
+ function isCloudWalletEnabled() {
356
+ return readBoolFlag("ENABLE_CLOUD_WALLET");
357
+ }
358
+
359
+ // src/cloud/cloud-wallet.ts
360
+ import { generatePrivateKey, privateKeyToAccount } from "viem/accounts";
361
+ function ensureFlag() {
362
+ if (!isCloudWalletEnabled()) {
363
+ throw new CloudWalletFlagDisabledError;
364
+ }
365
+ }
366
+ function normalizePrivateKey(raw) {
367
+ const trimmed = raw.trim();
368
+ const hex = trimmed.startsWith("0x") ? trimmed.slice(2) : trimmed;
369
+ if (!/^[0-9a-fA-F]{64}$/.test(hex)) {
370
+ throw new Error(`Malformed ${ELIZA_CLOUD_CLIENT_ADDRESS_KEY_ENV}: expected 32-byte hex`);
371
+ }
372
+ return `0x${hex.toLowerCase()}`;
373
+ }
374
+ async function getOrCreateClientAddressKey(opts = {}) {
375
+ ensureFlag();
376
+ const existing = process.env[ELIZA_CLOUD_CLIENT_ADDRESS_KEY_ENV];
377
+ if (existing && existing.trim().length > 0) {
378
+ const privateKey2 = normalizePrivateKey(existing);
379
+ const account2 = privateKeyToAccount(privateKey2);
380
+ return { privateKey: privateKey2, address: account2.address, minted: false };
381
+ }
382
+ const privateKey = generatePrivateKey();
383
+ const account = privateKeyToAccount(privateKey);
384
+ process.env[ELIZA_CLOUD_CLIENT_ADDRESS_KEY_ENV] = privateKey;
385
+ await persistConfigEnv(ELIZA_CLOUD_CLIENT_ADDRESS_KEY_ENV, privateKey, {
386
+ stateDir: opts.stateDir
387
+ });
388
+ return { privateKey, address: account.address, minted: true };
389
+ }
390
+ function inflightKey(agentId, chain) {
391
+ return `${agentId}::${chain}`;
392
+ }
393
+ async function provisionOne(bridge, agentId, chain, clientAddress) {
394
+ try {
395
+ return await bridge.getAgentWallet(agentId, chain);
396
+ } catch (error) {
397
+ if (!isMissingCloudWalletError(error, chain)) {
398
+ throw error;
399
+ }
400
+ }
401
+ const provisioned = await bridge.provisionWallet({
402
+ chainType: chain,
403
+ clientAddress
404
+ });
405
+ return {
406
+ agentWalletId: provisioned.walletId,
407
+ walletAddress: provisioned.address,
408
+ walletProvider: provisioned.provider,
409
+ chainType: chain
410
+ };
411
+ }
412
+ function isMissingCloudWalletError(error, chain) {
413
+ if (error instanceof Error && new RegExp(`no cloud ${chain} wallet provisioned`, "i").test(error.message)) {
414
+ return true;
415
+ }
416
+ return typeof error === "object" && error !== null && "name" in error && error.name === "CloudBridgeError" && typeof error.status === "number" && error.status === 404;
417
+ }
418
+ function formatProvisionWarning(chain, error) {
419
+ const message = error instanceof Error ? error.message : String(error);
420
+ return `Cloud ${chain} wallet import failed: ${message}`;
421
+ }
422
+ async function provisionCloudWalletsBestEffort(bridge, opts) {
423
+ ensureFlag();
424
+ const chains = opts.chains ?? ["evm", "solana"];
425
+ const results = await Promise.all(chains.map((chain) => {
426
+ const key = inflightKey(opts.agentId, chain);
427
+ const pending = inflight.get(key);
428
+ if (pending) {
429
+ return pending.then((descriptor) => ({
430
+ chain,
431
+ ok: true,
432
+ descriptor
433
+ }), (error) => ({
434
+ chain,
435
+ ok: false,
436
+ error
437
+ }));
438
+ }
439
+ const p = provisionOne(bridge, opts.agentId, chain, opts.clientAddress).finally(() => {
440
+ inflight.delete(key);
441
+ });
442
+ inflight.set(key, p);
443
+ return p.then((descriptor) => ({
444
+ chain,
445
+ ok: true,
446
+ descriptor
447
+ }), (error) => ({
448
+ chain,
449
+ ok: false,
450
+ error
451
+ }));
452
+ }));
453
+ const out = {};
454
+ const failures = [];
455
+ for (const result of results) {
456
+ if ("descriptor" in result) {
457
+ out[result.chain] = result.descriptor;
458
+ continue;
459
+ }
460
+ failures.push({ chain: result.chain, error: result.error });
461
+ }
462
+ return {
463
+ descriptors: out,
464
+ failures,
465
+ warnings: failures.map(({ chain, error }) => formatProvisionWarning(chain, error))
466
+ };
467
+ }
468
+ async function provisionCloudWallets(bridge, opts) {
469
+ const result = await provisionCloudWalletsBestEffort(bridge, opts);
470
+ if (result.failures.length > 0 && Object.keys(result.descriptors).length === 0) {
471
+ const firstFailure = result.failures[0];
472
+ if (firstFailure?.error instanceof Error) {
473
+ throw firstFailure.error;
474
+ }
475
+ throw new Error(result.warnings[0] ?? "Failed to provision cloud wallets");
476
+ }
477
+ return result.descriptors;
478
+ }
479
+ function persistCloudWalletCache(config, descriptors) {
480
+ ensureFlag();
481
+ const wallet = config.wallet ?? {};
482
+ const cloud = { ...wallet.cloud ?? {} };
483
+ if (descriptors.evm)
484
+ cloud.evm = descriptors.evm;
485
+ if (descriptors.solana)
486
+ cloud.solana = descriptors.solana;
487
+ wallet.cloud = cloud;
488
+ config.wallet = wallet;
489
+ }
490
+ function __resetCloudWalletModuleForTests() {
491
+ inflight.clear();
492
+ delete process.env[ELIZA_CLOUD_CLIENT_ADDRESS_KEY_ENV];
493
+ }
494
+ var ELIZA_CLOUD_CLIENT_ADDRESS_KEY_ENV = "ELIZA_CLOUD_CLIENT_ADDRESS_KEY", CloudWalletFlagDisabledError, inflight;
495
+ var init_cloud_wallet = __esm(() => {
496
+ init_config_env();
497
+ CloudWalletFlagDisabledError = class CloudWalletFlagDisabledError extends Error {
498
+ constructor() {
499
+ super("ENABLE_CLOUD_WALLET is off; cloud wallet code paths are inactive");
500
+ this.name = "CloudWalletFlagDisabledError";
501
+ }
502
+ };
503
+ inflight = new Map;
504
+ });
505
+
506
+ // src/lib/http.ts
507
+ function scrubStackFields(value) {
508
+ if (value instanceof Error) {
509
+ return { error: value.message || "Internal error" };
510
+ }
511
+ if (Array.isArray(value)) {
512
+ return value.map(scrubStackFields);
513
+ }
514
+ if (value && typeof value === "object") {
515
+ const out = {};
516
+ for (const [key, nested] of Object.entries(value)) {
517
+ if (key === "stack" || key === "stackTrace")
518
+ continue;
519
+ out[key] = scrubStackFields(nested);
520
+ }
521
+ return out;
522
+ }
523
+ return value;
524
+ }
525
+ function sendJson(res, body, status = 200) {
526
+ if (res.headersSent)
527
+ return;
528
+ res.statusCode = status;
529
+ res.setHeader("content-type", "application/json; charset=utf-8");
530
+ res.end(JSON.stringify(scrubStackFields(body)));
531
+ }
532
+ function sendJsonError(res, message, status = 400) {
533
+ sendJson(res, { error: message }, status);
534
+ }
535
+ async function readRequestBody(req, options) {
536
+ const maxBytes = options.maxBytes ?? 1048576;
537
+ const chunks = [];
538
+ let size = 0;
539
+ for await (const chunk of req) {
540
+ const buffer = typeof chunk === "string" ? Buffer.from(chunk) : chunk;
541
+ size += buffer.length;
542
+ if (size > maxBytes) {
543
+ if (options.destroyOnTooLarge)
544
+ req.destroy();
545
+ throw new Error(options.tooLargeMessage ?? "Request body too large");
546
+ }
547
+ chunks.push(buffer);
548
+ }
549
+ if (chunks.length === 0)
550
+ return null;
551
+ return Buffer.concat(chunks).toString("utf8");
552
+ }
553
+ async function readJsonBody(req, res, options = {}) {
554
+ const cached = req.body;
555
+ if (cached !== undefined) {
556
+ if (options.requireObject !== false && (!cached || typeof cached !== "object" || Array.isArray(cached))) {
557
+ sendJsonError(res, "Request body must be a JSON object", 400);
558
+ return null;
559
+ }
560
+ return cached;
561
+ }
562
+ let raw;
563
+ try {
564
+ raw = await readRequestBody(req, options);
565
+ } catch (error) {
566
+ sendJsonError(res, error instanceof Error ? error.message : "Failed to read request body", 413);
567
+ return null;
568
+ }
569
+ if (!raw?.trim()) {
570
+ const empty = {};
571
+ req.body = empty;
572
+ return empty;
573
+ }
574
+ let parsed;
575
+ try {
576
+ parsed = JSON.parse(raw);
577
+ } catch {
578
+ sendJsonError(res, "Invalid JSON in request body", 400);
579
+ return null;
580
+ }
581
+ if (options.requireObject !== false && (!parsed || typeof parsed !== "object" || Array.isArray(parsed))) {
582
+ sendJsonError(res, "Request body must be a JSON object", 400);
583
+ return null;
584
+ }
585
+ req.body = parsed;
586
+ return parsed;
587
+ }
588
+
589
+ // src/routes/home-remote-runner-access-url.ts
590
+ import { normalizeCloudSiteUrl as normalizeCloudSiteUrl2 } from "@elizaos/shared";
591
+ function buildHomeRemoteRunnerAccessUrl(input) {
592
+ const sessionId = input.sessionId?.trim();
593
+ if (!sessionId)
594
+ return null;
595
+ try {
596
+ const url = new URL(normalizeCloudSiteUrl2(input.cloudBaseUrl ?? undefined));
597
+ url.pathname = "/dashboard/app";
598
+ url.search = "";
599
+ url.hash = "";
600
+ url.searchParams.set(HOME_REMOTE_RUNNER_ACCESS_SESSION_PARAM, sessionId);
601
+ return url.toString();
602
+ } catch {
603
+ return null;
604
+ }
605
+ }
606
+ function buildHomeRemoteRunnerSshTunnel(input) {
607
+ const sshTarget = normalizeSshTarget(input.sshTarget);
608
+ if (!sshTarget)
609
+ return null;
610
+ let parsed;
611
+ try {
612
+ parsed = new URL(input.remoteBaseUrl?.trim() ?? "");
613
+ } catch {
614
+ return null;
615
+ }
616
+ if (parsed.protocol !== "http:") {
617
+ return null;
618
+ }
619
+ const remotePort = parsed.port || "80";
620
+ const localPort = normalizePort(input.localPort) ?? remotePort;
621
+ const remoteHost = parsed.hostname === "localhost" || parsed.hostname === "127.0.0.1" ? "127.0.0.1" : parsed.hostname;
622
+ const identityArg = input.sshIdentity?.trim() ? ` -i ${quoteShellArg(input.sshIdentity.trim())}` : "";
623
+ const command = `ssh -N${identityArg} -L 127.0.0.1:${localPort}:${remoteHost}:${remotePort} ${sshTarget}`;
624
+ return {
625
+ command,
626
+ localUrl: `${parsed.protocol}//127.0.0.1:${localPort}`
627
+ };
628
+ }
629
+ function normalizePort(value) {
630
+ if (value === null || value === undefined)
631
+ return null;
632
+ const raw = String(value).trim();
633
+ if (!/^\d+$/.test(raw))
634
+ return null;
635
+ const port = Number(raw);
636
+ if (!Number.isInteger(port) || port < 1 || port > 65535)
637
+ return null;
638
+ return String(port);
639
+ }
640
+ function normalizeSshTarget(value) {
641
+ const target = value?.trim();
642
+ if (!target)
643
+ return null;
644
+ if (!/^[A-Za-z0-9._~%+-]+@[A-Za-z0-9.-]+$/.test(target))
645
+ return null;
646
+ return target;
647
+ }
648
+ function quoteShellArg(value) {
649
+ return `'${value.replace(/'/g, "'\\''")}'`;
650
+ }
651
+ var HOME_REMOTE_RUNNER_ACCESS_SESSION_PARAM = "homeRemoteRunnerSession";
652
+ var init_home_remote_runner_access_url = () => {};
653
+
654
+ // src/lib/config-like.ts
655
+ function ensureLinkedAccounts(config) {
656
+ config.linkedAccounts ??= {};
657
+ return config.linkedAccounts;
658
+ }
659
+ function ensureServiceRouting(config) {
660
+ config.serviceRouting ??= {};
661
+ return config.serviceRouting;
662
+ }
663
+ function persistDeploymentTarget(config, deploymentTarget) {
664
+ if (!deploymentTarget) {
665
+ delete config.deploymentTarget;
666
+ return;
667
+ }
668
+ config.deploymentTarget = { ...deploymentTarget };
669
+ }
670
+ function persistLinkedAccounts(config, linkedAccounts) {
671
+ if (!linkedAccounts)
672
+ return;
673
+ const existing = ensureLinkedAccounts(config);
674
+ for (const [accountId, account] of Object.entries(linkedAccounts)) {
675
+ if (!account || Object.keys(account).length === 0) {
676
+ delete existing[accountId];
677
+ continue;
678
+ }
679
+ existing[accountId] = {
680
+ ...existing[accountId],
681
+ ...account
682
+ };
683
+ }
684
+ if (Object.keys(existing).length === 0) {
685
+ delete config.linkedAccounts;
686
+ }
687
+ }
688
+ function persistServiceRouting(config, serviceRouting, clearRoutes = []) {
689
+ const existing = ensureServiceRouting(config);
690
+ for (const capability of clearRoutes) {
691
+ delete existing[capability];
692
+ }
693
+ if (serviceRouting) {
694
+ for (const [capability, route] of Object.entries(serviceRouting)) {
695
+ const serviceKey = capability;
696
+ if (!route || Object.keys(route).length === 0) {
697
+ delete existing[serviceKey];
698
+ continue;
699
+ }
700
+ existing[serviceKey] = { ...route };
701
+ }
702
+ }
703
+ if (Object.keys(existing).length === 0) {
704
+ delete config.serviceRouting;
705
+ }
706
+ }
707
+ function applyCanonicalSetupConfig(config, args) {
708
+ if (args.deploymentTarget !== undefined) {
709
+ persistDeploymentTarget(config, args.deploymentTarget);
710
+ }
711
+ if (args.linkedAccounts !== undefined) {
712
+ persistLinkedAccounts(config, args.linkedAccounts);
713
+ }
714
+ if (args.serviceRouting !== undefined || args.clearRoutes?.length) {
715
+ persistServiceRouting(config, args.serviceRouting, args.clearRoutes);
716
+ }
717
+ }
718
+ function normalizeEnvValue(value) {
719
+ if (typeof value !== "string")
720
+ return;
721
+ const trimmed = value.trim();
722
+ return trimmed || undefined;
723
+ }
724
+ function isTimeoutError(error) {
725
+ if (!(error instanceof Error))
726
+ return false;
727
+ if (error.name === "TimeoutError" || error.name === "AbortError")
728
+ return true;
729
+ const message = error.message.toLowerCase();
730
+ return message.includes("timed out") || message.includes("timeout");
731
+ }
732
+
733
+ // src/routes/cloud-routes-autonomous.ts
734
+ import fs3 from "node:fs/promises";
735
+ import path3 from "node:path";
736
+ import {
737
+ isCloudInferenceSelectedInConfig,
738
+ migrateLegacyRuntimeConfig
739
+ } from "@elizaos/core";
740
+ import { logger } from "@elizaos/core";
741
+ function extractAgentId(pathname) {
742
+ const id = pathname.split("/")[4];
743
+ return id && UUID_RE.test(id) ? id : null;
744
+ }
745
+ function replaceMutableRoot(target, snapshot) {
746
+ const targetRecord = target;
747
+ for (const key of Object.keys(targetRecord)) {
748
+ delete targetRecord[key];
749
+ }
750
+ Object.assign(targetRecord, structuredClone(snapshot));
751
+ }
752
+ function getCloudAuth(runtime) {
753
+ if (typeof runtime?.getService !== "function") {
754
+ return null;
755
+ }
756
+ const service = runtime.getService("CLOUD_AUTH");
757
+ return service && typeof service === "object" ? service : null;
758
+ }
759
+ function clearCloudAuth(runtime) {
760
+ const cloudAuth = getCloudAuth(runtime);
761
+ if (typeof cloudAuth?.clearAuth === "function") {
762
+ cloudAuth.clearAuth();
763
+ }
764
+ return cloudAuth;
765
+ }
766
+ async function captureConfigEnvRollbackSnapshot() {
767
+ const filePath = path3.join(resolveStateDir(), CONFIG_ENV_FILENAME2);
768
+ const bakPath = `${filePath}${CONFIG_ENV_BAK_SUFFIX}`;
769
+ let originalRaw = null;
770
+ try {
771
+ originalRaw = await fs3.readFile(filePath, "utf8");
772
+ } catch (err) {
773
+ if (err.code !== "ENOENT") {
774
+ throw err;
775
+ }
776
+ }
777
+ const previousEnv = Object.fromEntries(CLOUD_WALLET_ROLLBACK_ENV_KEYS.flatMap((key) => {
778
+ const value = process.env[key];
779
+ return typeof value === "string" ? [[key, value]] : [];
780
+ }));
781
+ return {
782
+ bakPath,
783
+ filePath,
784
+ originalRaw,
785
+ previousEnv
786
+ };
787
+ }
788
+ async function restoreConfigEnvRollbackSnapshot(snapshot) {
789
+ await fs3.mkdir(path3.dirname(snapshot.filePath), { recursive: true });
790
+ if (snapshot.originalRaw === null) {
791
+ await fs3.rm(snapshot.filePath, { force: true });
792
+ await fs3.rm(snapshot.bakPath, { force: true });
793
+ } else {
794
+ await fs3.writeFile(snapshot.filePath, snapshot.originalRaw, {
795
+ encoding: "utf8",
796
+ mode: 384
797
+ });
798
+ await fs3.writeFile(snapshot.bakPath, snapshot.originalRaw, {
799
+ encoding: "utf8",
800
+ mode: 384
801
+ });
802
+ }
803
+ for (const key of CLOUD_WALLET_ROLLBACK_ENV_KEYS) {
804
+ const previousValue = snapshot.previousEnv[key];
805
+ if (typeof previousValue === "string") {
806
+ process.env[key] = previousValue;
807
+ } else {
808
+ delete process.env[key];
809
+ }
810
+ }
811
+ }
812
+ function saveConfigOrThrow(state) {
813
+ if (!state.saveConfig) {
814
+ throw new Error("saveConfig not available");
815
+ }
816
+ state.saveConfig(state.config);
817
+ }
818
+ async function readJsonBody2(req, res) {
819
+ return await readJsonBody(req, res, {
820
+ maxBytes: 1048576,
821
+ tooLargeMessage: "Request body too large",
822
+ destroyOnTooLarge: true
823
+ });
824
+ }
825
+ function isRedirectResponse(response) {
826
+ return response.status >= 300 && response.status < 400;
827
+ }
828
+ function createNoopTelemetrySpan() {
829
+ return {
830
+ success: () => {},
831
+ failure: () => {}
832
+ };
833
+ }
834
+ function getTelemetrySpan(state, meta) {
835
+ return state.createTelemetrySpan?.(meta) ?? createNoopTelemetrySpan();
836
+ }
837
+ async function fetchWithTimeout(input, init, timeoutMs) {
838
+ return fetch(input, {
839
+ ...init,
840
+ redirect: "manual",
841
+ signal: AbortSignal.timeout(timeoutMs)
842
+ });
843
+ }
844
+ async function handleCloudRoute(req, res, pathname, method, state) {
845
+ if (method === "POST" && pathname === "/api/cloud/login") {
846
+ const baseUrl = normalizeCloudSiteUrl(state.config.cloud?.baseUrl);
847
+ const urlError = await validateCloudBaseUrl(baseUrl);
848
+ if (urlError) {
849
+ sendJsonError(res, urlError);
850
+ return true;
851
+ }
852
+ const sessionId = crypto.randomUUID();
853
+ const loginCreateSpan = getTelemetrySpan(state, {
854
+ boundary: "cloud",
855
+ operation: "login_create_session",
856
+ timeoutMs: CLOUD_LOGIN_CREATE_TIMEOUT_MS
857
+ });
858
+ let createRes;
859
+ try {
860
+ createRes = await fetchWithTimeout(`${baseUrl}/api/auth/cli-session`, {
861
+ method: "POST",
862
+ headers: { "Content-Type": "application/json" },
863
+ body: JSON.stringify({ sessionId })
864
+ }, CLOUD_LOGIN_CREATE_TIMEOUT_MS);
865
+ } catch (err) {
866
+ if (isTimeoutError(err)) {
867
+ loginCreateSpan.failure({ error: err, statusCode: 504 });
868
+ sendJsonError(res, "Eliza Cloud login request timed out", 504);
869
+ return true;
870
+ }
871
+ loginCreateSpan.failure({ error: err, statusCode: 502 });
872
+ sendJsonError(res, "Failed to reach Eliza Cloud", 502);
873
+ return true;
874
+ }
875
+ if (isRedirectResponse(createRes)) {
876
+ loginCreateSpan.failure({
877
+ statusCode: createRes.status,
878
+ errorKind: "redirect_response"
879
+ });
880
+ sendJsonError(res, "Eliza Cloud login request was redirected; redirects are not allowed", 502);
881
+ return true;
882
+ }
883
+ if (!createRes.ok) {
884
+ loginCreateSpan.failure({
885
+ statusCode: createRes.status,
886
+ errorKind: "http_error"
887
+ });
888
+ sendJsonError(res, "Failed to create auth session with Eliza Cloud", 502);
889
+ return true;
890
+ }
891
+ loginCreateSpan.success({ statusCode: createRes.status });
892
+ sendJson(res, {
893
+ ok: true,
894
+ sessionId,
895
+ browserUrl: `${baseUrl}/auth/cli-login?session=${encodeURIComponent(sessionId)}`
896
+ });
897
+ return true;
898
+ }
899
+ if (method === "GET" && pathname.startsWith("/api/cloud/login/status")) {
900
+ const url = new URL(req.url ?? "/", `http://${req.headers.host ?? "localhost"}`);
901
+ const sessionId = url.searchParams.get("sessionId");
902
+ if (!sessionId) {
903
+ sendJsonError(res, "sessionId query parameter is required");
904
+ return true;
905
+ }
906
+ const baseUrl = normalizeCloudSiteUrl(state.config.cloud?.baseUrl);
907
+ const urlError = await validateCloudBaseUrl(baseUrl);
908
+ if (urlError) {
909
+ sendJsonError(res, urlError);
910
+ return true;
911
+ }
912
+ const loginPollSpan = getTelemetrySpan(state, {
913
+ boundary: "cloud",
914
+ operation: "login_poll_status",
915
+ timeoutMs: CLOUD_LOGIN_POLL_TIMEOUT_MS
916
+ });
917
+ let pollRes;
918
+ try {
919
+ pollRes = await fetchWithTimeout(`${baseUrl}/api/auth/cli-session/${encodeURIComponent(sessionId)}`, {}, CLOUD_LOGIN_POLL_TIMEOUT_MS);
920
+ } catch (err) {
921
+ if (isTimeoutError(err)) {
922
+ loginPollSpan.failure({ error: err, statusCode: 504 });
923
+ sendJson(res, {
924
+ status: "error",
925
+ error: "Eliza Cloud status request timed out"
926
+ }, 504);
927
+ return true;
928
+ }
929
+ loginPollSpan.failure({ error: err, statusCode: 502 });
930
+ sendJson(res, {
931
+ status: "error",
932
+ error: "Failed to reach Eliza Cloud"
933
+ }, 502);
934
+ return true;
935
+ }
936
+ if (isRedirectResponse(pollRes)) {
937
+ loginPollSpan.failure({
938
+ statusCode: pollRes.status,
939
+ errorKind: "redirect_response"
940
+ });
941
+ sendJson(res, {
942
+ status: "error",
943
+ error: "Eliza Cloud status request was redirected; redirects are not allowed"
944
+ }, 502);
945
+ return true;
946
+ }
947
+ if (!pollRes.ok) {
948
+ loginPollSpan.failure({
949
+ statusCode: pollRes.status,
950
+ errorKind: "http_error"
951
+ });
952
+ sendJson(res, pollRes.status === 404 ? { status: "expired", error: "Session not found or expired" } : {
953
+ status: "error",
954
+ error: `Eliza Cloud returned HTTP ${pollRes.status}`
955
+ });
956
+ return true;
957
+ }
958
+ let data;
959
+ try {
960
+ data = await pollRes.json();
961
+ } catch (parseErr) {
962
+ loginPollSpan.failure({ error: parseErr, statusCode: pollRes.status });
963
+ sendJson(res, { status: "error", error: "Eliza Cloud returned invalid JSON" }, 502);
964
+ return true;
965
+ }
966
+ loginPollSpan.success({ statusCode: pollRes.status });
967
+ if (data.status === "authenticated" && data.apiKey) {
968
+ const organizationId = typeof data.organizationId === "string" ? data.organizationId.trim() : undefined;
969
+ const userId = typeof data.userId === "string" ? data.userId.trim() : undefined;
970
+ const cloudAuth = clearCloudAuth(state.runtime);
971
+ migrateLegacyRuntimeConfig(state.config);
972
+ const cloud = state.config.cloud ?? {};
973
+ cloud.apiKey = data.apiKey;
974
+ state.config.cloud = cloud;
975
+ applyCanonicalSetupConfig(state.config, {
976
+ linkedAccounts: {
977
+ elizacloud: {
978
+ status: "linked",
979
+ source: "api-key"
980
+ }
981
+ }
982
+ });
983
+ const cloudInferenceSelected = isCloudInferenceSelectedInConfig(state.config);
984
+ migrateLegacyRuntimeConfig(state.config);
985
+ try {
986
+ if (state.saveConfig) {
987
+ state.saveConfig(state.config);
988
+ } else {
989
+ logger.warn("[cloud-login] saveConfig not available — config not persisted");
990
+ }
991
+ logger.info("[cloud-login] API key saved to config file");
992
+ } catch (saveErr) {
993
+ logger.error(`[cloud-login] Failed to save config: ${String(saveErr)}`);
994
+ sendJson(res, { status: "error", error: "Authenticated but failed to save config" }, 500);
995
+ return true;
996
+ }
997
+ process.env.ELIZAOS_CLOUD_API_KEY = data.apiKey;
998
+ if (cloudInferenceSelected) {
999
+ process.env.ELIZAOS_CLOUD_ENABLED = "true";
1000
+ } else {
1001
+ delete process.env.ELIZAOS_CLOUD_ENABLED;
1002
+ }
1003
+ if (state.runtime) {
1004
+ const character = state.runtime.character ?? {};
1005
+ state.runtime.character = character;
1006
+ if (!character.secrets) {
1007
+ character.secrets = {};
1008
+ }
1009
+ const secrets = character.secrets;
1010
+ secrets.ELIZAOS_CLOUD_API_KEY = data.apiKey;
1011
+ if (userId) {
1012
+ secrets.ELIZA_CLOUD_USER_ID = userId;
1013
+ } else {
1014
+ delete secrets.ELIZA_CLOUD_USER_ID;
1015
+ }
1016
+ if (organizationId) {
1017
+ secrets.ELIZA_CLOUD_ORGANIZATION_ID = organizationId;
1018
+ } else {
1019
+ delete secrets.ELIZA_CLOUD_ORGANIZATION_ID;
1020
+ }
1021
+ if (cloudInferenceSelected) {
1022
+ secrets.ELIZAOS_CLOUD_ENABLED = "true";
1023
+ } else {
1024
+ delete secrets.ELIZAOS_CLOUD_ENABLED;
1025
+ }
1026
+ if (typeof state.runtime.setSetting === "function") {
1027
+ state.runtime.setSetting("ELIZA_CLOUD_USER_ID", userId ?? null);
1028
+ state.runtime.setSetting("ELIZA_CLOUD_ORGANIZATION_ID", organizationId ?? null);
1029
+ }
1030
+ if (typeof state.runtime.updateAgent === "function") {
1031
+ await state.runtime.updateAgent(state.runtime.agentId, {
1032
+ secrets: { ...secrets }
1033
+ });
1034
+ logger.info("[cloud-login] API key persisted to agent DB record");
1035
+ } else {
1036
+ logger.warn("[cloud-login] runtime.updateAgent not available — agent DB secrets not persisted");
1037
+ }
1038
+ }
1039
+ if (state.cloudManager && typeof state.cloudManager.replaceApiKey === "function") {
1040
+ await state.cloudManager.replaceApiKey(data.apiKey);
1041
+ } else if (state.cloudManager && !state.cloudManager.getClient() && typeof state.cloudManager.init === "function") {
1042
+ await state.cloudManager.init();
1043
+ }
1044
+ if (typeof cloudAuth?.authenticateWithApiKey === "function") {
1045
+ cloudAuth.authenticateWithApiKey({
1046
+ apiKey: data.apiKey,
1047
+ organizationId,
1048
+ userId
1049
+ });
1050
+ }
1051
+ if (isCloudWalletEnabled()) {
1052
+ const rollbackConfigSnapshot = structuredClone(state.config);
1053
+ const rollbackEnvSnapshot = await captureConfigEnvRollbackSnapshot();
1054
+ try {
1055
+ const bridge = state.cloudManager?.getClient();
1056
+ const agentId = state.runtime?.agentId;
1057
+ if (!bridge) {
1058
+ throw new Error("cloud-wallet bridge unavailable");
1059
+ }
1060
+ if (!agentId) {
1061
+ throw new Error("cloud-wallet runtime agentId missing");
1062
+ }
1063
+ const { address: clientAddress, minted } = await getOrCreateClientAddressKey();
1064
+ if (minted) {
1065
+ logger.info(`[cloud-login] cloud-wallet: minted client_address ${clientAddress}`);
1066
+ }
1067
+ const descriptors = await provisionCloudWallets(bridge, {
1068
+ agentId,
1069
+ clientAddress
1070
+ });
1071
+ persistCloudWalletCache(state.config, descriptors);
1072
+ const cloudCfg = state.config.cloud ?? {};
1073
+ cloudCfg.clientAddressPublicKey = clientAddress;
1074
+ state.config.cloud = cloudCfg;
1075
+ saveConfigOrThrow(state);
1076
+ if (descriptors.evm?.walletAddress) {
1077
+ process.env.ELIZA_CLOUD_EVM_ADDRESS = descriptors.evm.walletAddress;
1078
+ await persistConfigEnv("ELIZA_CLOUD_EVM_ADDRESS", descriptors.evm.walletAddress);
1079
+ }
1080
+ if (descriptors.solana?.walletAddress) {
1081
+ process.env.ELIZA_CLOUD_SOLANA_ADDRESS = descriptors.solana.walletAddress;
1082
+ await persistConfigEnv("ELIZA_CLOUD_SOLANA_ADDRESS", descriptors.solana.walletAddress);
1083
+ }
1084
+ if (descriptors.evm) {
1085
+ await persistConfigEnv("WALLET_SOURCE_EVM", "cloud");
1086
+ }
1087
+ if (descriptors.solana) {
1088
+ await persistConfigEnv("WALLET_SOURCE_SOLANA", "cloud");
1089
+ }
1090
+ const wallet = state.config.wallet ?? {};
1091
+ const primary = {
1092
+ ...wallet.primary ?? {}
1093
+ };
1094
+ if (descriptors.evm)
1095
+ primary.evm = "cloud";
1096
+ if (descriptors.solana)
1097
+ primary.solana = "cloud";
1098
+ wallet.primary = primary;
1099
+ state.config.wallet = wallet;
1100
+ saveConfigOrThrow(state);
1101
+ logger.info(`[cloud-login] cloud-wallet: provisioned ${Object.keys(descriptors).join(", ")} — applying runtime reload`);
1102
+ const restarted = state.restartRuntime ? await Promise.resolve(state.restartRuntime("cloud-wallet-bound")) : false;
1103
+ if (!restarted) {
1104
+ logger.warn("[cloud-login] cloud-wallet: restartRuntime not wired or restart declined — user must restart manually");
1105
+ }
1106
+ } catch (cloudWalletErr) {
1107
+ try {
1108
+ await restoreConfigEnvRollbackSnapshot(rollbackEnvSnapshot);
1109
+ } catch (rollbackErr) {
1110
+ logger.error(`[cloud-login] cloud-wallet rollback failed: ${String(rollbackErr)}`);
1111
+ }
1112
+ replaceMutableRoot(state.config, rollbackConfigSnapshot);
1113
+ try {
1114
+ saveConfigOrThrow(state);
1115
+ } catch (saveRollbackErr) {
1116
+ logger.error(`[cloud-login] cloud-wallet config rollback failed: ${String(saveRollbackErr)}`);
1117
+ }
1118
+ logger.error(`[cloud-login] cloud-wallet provision failed: ${String(cloudWalletErr)}`);
1119
+ }
1120
+ }
1121
+ logger.info(`[cloud-login] sending API key to loopback renderer (single-user desktop trust model)`);
1122
+ sendJson(res, {
1123
+ status: "authenticated",
1124
+ token: data.apiKey,
1125
+ keyPrefix: data.keyPrefix,
1126
+ organizationId,
1127
+ userId
1128
+ });
1129
+ } else {
1130
+ sendJson(res, { status: data.status });
1131
+ }
1132
+ return true;
1133
+ }
1134
+ if (method === "GET" && pathname === "/api/cloud/agents") {
1135
+ const client = state.cloudManager?.getClient();
1136
+ if (!client) {
1137
+ sendJsonError(res, "Not connected to Eliza Cloud", 401);
1138
+ return true;
1139
+ }
1140
+ sendJson(res, { ok: true, agents: await client.listAgents() });
1141
+ return true;
1142
+ }
1143
+ if (method === "POST" && pathname === "/api/cloud/agents") {
1144
+ const client = state.cloudManager?.getClient();
1145
+ if (!client) {
1146
+ sendJsonError(res, "Not connected to Eliza Cloud", 401);
1147
+ return true;
1148
+ }
1149
+ const body = await readJsonBody2(req, res);
1150
+ if (!body)
1151
+ return true;
1152
+ if (!body.agentName?.trim()) {
1153
+ sendJsonError(res, "agentName is required");
1154
+ return true;
1155
+ }
1156
+ let agent;
1157
+ try {
1158
+ agent = await client.createAgent({
1159
+ agentName: body.agentName,
1160
+ agentConfig: body.agentConfig,
1161
+ environmentVars: body.environmentVars
1162
+ });
1163
+ } catch (err) {
1164
+ logger.error(`[cloud] createAgent failed: ${String(err)}`);
1165
+ sendJson(res, { ok: false, error: `Cloud createAgent failed: ${String(err)}` }, 502);
1166
+ return true;
1167
+ }
1168
+ sendJson(res, { ok: true, agent }, 201);
1169
+ return true;
1170
+ }
1171
+ if (method === "POST" && pathname.startsWith("/api/cloud/agents/") && pathname.endsWith("/provision")) {
1172
+ const agentId = extractAgentId(pathname);
1173
+ if (!agentId || !state.cloudManager) {
1174
+ sendJsonError(res, "Invalid agent ID or cloud not connected", 400);
1175
+ return true;
1176
+ }
1177
+ let proxy;
1178
+ try {
1179
+ proxy = await state.cloudManager.connect(agentId);
1180
+ } catch (err) {
1181
+ logger.error(`[cloud] provision/connect failed: ${String(err)}`);
1182
+ sendJson(res, { ok: false, error: `Cloud provision failed: ${String(err)}` }, 502);
1183
+ return true;
1184
+ }
1185
+ sendJson(res, {
1186
+ ok: true,
1187
+ agentId,
1188
+ agentName: proxy.agentName,
1189
+ status: state.cloudManager.getStatus()
1190
+ });
1191
+ return true;
1192
+ }
1193
+ if (method === "POST" && pathname.startsWith("/api/cloud/agents/") && pathname.endsWith("/shutdown")) {
1194
+ const agentId = extractAgentId(pathname);
1195
+ if (!agentId || !state.cloudManager) {
1196
+ sendJsonError(res, "Invalid agent ID or cloud not connected", 400);
1197
+ return true;
1198
+ }
1199
+ const client = state.cloudManager.getClient();
1200
+ if (!client) {
1201
+ sendJsonError(res, "Not connected to Eliza Cloud", 401);
1202
+ return true;
1203
+ }
1204
+ try {
1205
+ if (state.cloudManager.getActiveAgentId() === agentId) {
1206
+ await state.cloudManager.disconnect();
1207
+ }
1208
+ await client.deleteAgent(agentId);
1209
+ } catch (err) {
1210
+ logger.error(`[cloud] shutdown/deleteAgent failed: ${String(err)}`);
1211
+ sendJson(res, { ok: false, error: `Cloud shutdown failed: ${String(err)}` }, 502);
1212
+ return true;
1213
+ }
1214
+ sendJson(res, { ok: true, agentId, status: "stopped" });
1215
+ return true;
1216
+ }
1217
+ if (method === "POST" && pathname.startsWith("/api/cloud/agents/") && pathname.endsWith("/connect")) {
1218
+ const agentId = extractAgentId(pathname);
1219
+ if (!agentId || !state.cloudManager) {
1220
+ sendJsonError(res, "Invalid agent ID or cloud not connected", 400);
1221
+ return true;
1222
+ }
1223
+ let proxy;
1224
+ try {
1225
+ if (state.cloudManager.getActiveAgentId()) {
1226
+ await state.cloudManager.disconnect();
1227
+ }
1228
+ proxy = await state.cloudManager.connect(agentId);
1229
+ } catch (err) {
1230
+ logger.error(`[cloud] connect failed: ${String(err)}`);
1231
+ sendJson(res, { ok: false, error: `Cloud connect failed: ${String(err)}` }, 502);
1232
+ return true;
1233
+ }
1234
+ sendJson(res, {
1235
+ ok: true,
1236
+ agentId,
1237
+ agentName: proxy.agentName,
1238
+ status: state.cloudManager.getStatus()
1239
+ });
1240
+ return true;
1241
+ }
1242
+ if (method === "POST" && pathname === "/api/cloud/disconnect") {
1243
+ if (state.cloudManager) {
1244
+ await state.cloudManager.disconnect();
1245
+ }
1246
+ const cloud = state.config.cloud ?? {};
1247
+ delete cloud.apiKey;
1248
+ state.config.cloud = cloud;
1249
+ applyCanonicalSetupConfig(state.config, {
1250
+ deploymentTarget: { runtime: "local" },
1251
+ linkedAccounts: {
1252
+ elizacloud: {
1253
+ status: "unlinked",
1254
+ source: "api-key"
1255
+ }
1256
+ },
1257
+ clearRoutes: ["llmText", "tts", "media", "embeddings", "rpc"]
1258
+ });
1259
+ migrateLegacyRuntimeConfig(state.config);
1260
+ try {
1261
+ if (state.saveConfig) {
1262
+ state.saveConfig(state.config);
1263
+ } else {
1264
+ logger.warn("[cloud-disconnect] saveConfig not available — config not persisted");
1265
+ }
1266
+ } catch (saveErr) {
1267
+ logger.error(`[cloud-disconnect] Failed to save config: ${String(saveErr)}`);
1268
+ sendJson(res, { ok: false, error: "Disconnected but failed to save config" }, 500);
1269
+ return true;
1270
+ }
1271
+ delete process.env.ELIZAOS_CLOUD_API_KEY;
1272
+ delete process.env.ELIZAOS_CLOUD_ENABLED;
1273
+ if (state.runtime) {
1274
+ const character = state.runtime.character ?? {};
1275
+ state.runtime.character = character;
1276
+ if (!character.secrets) {
1277
+ character.secrets = {};
1278
+ }
1279
+ const secrets = character.secrets;
1280
+ delete secrets.ELIZAOS_CLOUD_API_KEY;
1281
+ delete secrets.ELIZAOS_CLOUD_ENABLED;
1282
+ if (typeof state.runtime.updateAgent === "function") {
1283
+ await state.runtime.updateAgent(state.runtime.agentId, {
1284
+ secrets: { ...secrets }
1285
+ });
1286
+ } else {
1287
+ logger.warn("[cloud-disconnect] updateAgent not available — runtime secrets not persisted");
1288
+ }
1289
+ }
1290
+ sendJson(res, { ok: true, status: "disconnected" });
1291
+ return true;
1292
+ }
1293
+ return false;
1294
+ }
1295
+ var UUID_RE, CLOUD_LOGIN_CREATE_TIMEOUT_MS = 1e4, CLOUD_LOGIN_POLL_TIMEOUT_MS = 1e4, CONFIG_ENV_FILENAME2 = "config.env", CONFIG_ENV_BAK_SUFFIX = ".bak", CLOUD_WALLET_ROLLBACK_ENV_KEYS;
1296
+ var init_cloud_routes_autonomous = __esm(() => {
1297
+ init_base_url();
1298
+ init_cloud_wallet();
1299
+ init_validate_url();
1300
+ init_config_env();
1301
+ init_state_paths();
1302
+ UUID_RE = /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i;
1303
+ CLOUD_WALLET_ROLLBACK_ENV_KEYS = [
1304
+ ELIZA_CLOUD_CLIENT_ADDRESS_KEY_ENV,
1305
+ "ELIZA_CLOUD_EVM_ADDRESS",
1306
+ "ELIZA_CLOUD_SOLANA_ADDRESS",
1307
+ "WALLET_SOURCE_EVM",
1308
+ "WALLET_SOURCE_SOLANA"
1309
+ ];
1310
+ });
1311
+
1312
+ // src/lib/cloud-secrets.ts
1313
+ import {
1314
+ clearCloudSecrets,
1315
+ getCloudSecret,
1316
+ scrubCloudSecretsFromEnv,
1317
+ _resetCloudSecretsForTesting
1318
+ } from "@elizaos/shared";
1319
+ var init_cloud_secrets = () => {};
1320
+
1321
+ // src/lib/cloud-connection.ts
1322
+ import {
1323
+ isCloudInferenceSelectedInConfig as isCloudInferenceSelectedInConfig2,
1324
+ isElizaSettingsDebugEnabled,
1325
+ migrateLegacyRuntimeConfig as migrateLegacyRuntimeConfig2,
1326
+ settingsDebugCloudSummary
1327
+ } from "@elizaos/core";
1328
+ import { logger as logger2 } from "@elizaos/core";
1329
+ function cloudCreditsHttpErrorMessage(status, creditResponse) {
1330
+ const err = creditResponse.error;
1331
+ if (typeof err === "string" && err.trim()) {
1332
+ return err.trim();
1333
+ }
1334
+ if (err && typeof err === "object" && "message" in err) {
1335
+ const msg = err.message;
1336
+ if (typeof msg === "string" && msg.trim()) {
1337
+ return msg.trim();
1338
+ }
1339
+ }
1340
+ return `HTTP ${status}`;
1341
+ }
1342
+ function asRuntimeCloud(runtime) {
1343
+ return runtime;
1344
+ }
1345
+ function getCloudAuth2(runtime) {
1346
+ const runtimeWithServices = asRuntimeCloud(runtime);
1347
+ if (typeof runtimeWithServices?.getService !== "function") {
1348
+ return null;
1349
+ }
1350
+ const service = runtimeWithServices.getService("CLOUD_AUTH");
1351
+ return service && typeof service === "object" ? service : null;
1352
+ }
1353
+ function resolvePersistedCloudIdentity(runtime) {
1354
+ const runtimeWithCloud = asRuntimeCloud(runtime);
1355
+ return {
1356
+ organizationId: normalizeEnvValue(runtimeWithCloud?.getSetting?.("ELIZA_CLOUD_ORGANIZATION_ID")) ?? normalizeEnvValue(runtimeWithCloud?.character?.secrets?.ELIZA_CLOUD_ORGANIZATION_ID),
1357
+ userId: normalizeEnvValue(runtimeWithCloud?.getSetting?.("ELIZA_CLOUD_USER_ID")) ?? normalizeEnvValue(runtimeWithCloud?.character?.secrets?.ELIZA_CLOUD_USER_ID)
1358
+ };
1359
+ }
1360
+ function resolveCloudApiBaseUrl2(rawBaseUrl) {
1361
+ return resolveCloudApiBaseUrl(rawBaseUrl ?? DEFAULT_CLOUD_API_BASE_URL) ?? DEFAULT_CLOUD_API_BASE_URL;
1362
+ }
1363
+ function resolveCloudApiKey(config, runtime) {
1364
+ migrateLegacyRuntimeConfig2(config);
1365
+ const configApiKey = normalizeEnvValue(config.cloud?.apiKey);
1366
+ if (configApiKey)
1367
+ return configApiKey;
1368
+ if (!isCloudInferenceSelectedInConfig2(config)) {
1369
+ return;
1370
+ }
1371
+ const sealedKey = normalizeEnvValue(getCloudSecret("ELIZAOS_CLOUD_API_KEY"));
1372
+ if (sealedKey)
1373
+ return sealedKey;
1374
+ const envKey = normalizeEnvValue(process.env.ELIZAOS_CLOUD_API_KEY);
1375
+ if (envKey)
1376
+ return envKey;
1377
+ const runtimeSettingKey = normalizeEnvValue(runtime?.getSetting?.("ELIZAOS_CLOUD_API_KEY"));
1378
+ if (runtimeSettingKey)
1379
+ return runtimeSettingKey;
1380
+ const runtimeKey = normalizeEnvValue(runtime?.character?.secrets?.ELIZAOS_CLOUD_API_KEY);
1381
+ if (runtimeKey)
1382
+ return runtimeKey;
1383
+ return;
1384
+ }
1385
+ function resolveCloudConnectionSnapshot(config, runtime) {
1386
+ migrateLegacyRuntimeConfig2(config);
1387
+ const _cloudRecord = config.cloud && typeof config.cloud === "object" ? config.cloud : undefined;
1388
+ const enabled = isCloudInferenceSelectedInConfig2(config);
1389
+ const apiKey = resolveCloudApiKey(config, runtime);
1390
+ const cloudAuth = getCloudAuth2(runtime);
1391
+ const authConnected = Boolean(cloudAuth?.isAuthenticated?.());
1392
+ const hasApiKey = Boolean(apiKey);
1393
+ const persistedIdentity = resolvePersistedCloudIdentity(runtime);
1394
+ const shouldExposeIdentity = authConnected || hasApiKey;
1395
+ return {
1396
+ apiKey,
1397
+ authConnected,
1398
+ cloudAuth,
1399
+ connected: authConnected || hasApiKey,
1400
+ enabled,
1401
+ hasApiKey,
1402
+ organizationId: shouldExposeIdentity ? normalizeEnvValue(cloudAuth?.getOrganizationId?.()) ?? persistedIdentity.organizationId : undefined,
1403
+ userId: shouldExposeIdentity ? normalizeEnvValue(cloudAuth?.getUserId?.()) ?? persistedIdentity.userId : undefined
1404
+ };
1405
+ }
1406
+ function coerceCloudBalance(value) {
1407
+ if (typeof value === "number" && Number.isFinite(value)) {
1408
+ return value;
1409
+ }
1410
+ if (typeof value === "string") {
1411
+ const trimmed = value.trim();
1412
+ if (!trimmed)
1413
+ return null;
1414
+ const parsed = Number.parseFloat(trimmed);
1415
+ return Number.isFinite(parsed) ? parsed : null;
1416
+ }
1417
+ return null;
1418
+ }
1419
+ async function fetchCloudCreditsByApiKey(baseUrl, apiKey) {
1420
+ const response = await fetch(`${baseUrl}/credits/balance`, {
1421
+ headers: {
1422
+ Accept: "application/json",
1423
+ Authorization: `Bearer ${apiKey}`
1424
+ },
1425
+ redirect: "manual",
1426
+ signal: AbortSignal.timeout(1e4)
1427
+ });
1428
+ if (response.status >= 300 && response.status < 400) {
1429
+ throw new Error("Cloud credits request was redirected; redirects are not allowed");
1430
+ }
1431
+ const creditResponse = await response.json().catch((err) => {
1432
+ console.warn("[cloud-connection] Failed to parse credit balance response JSON:", err);
1433
+ return {};
1434
+ });
1435
+ if (response.status === 401) {
1436
+ throw new CloudCreditsAuthRejectedError(cloudCreditsHttpErrorMessage(401, creditResponse));
1437
+ }
1438
+ if (!response.ok) {
1439
+ throw new Error(cloudCreditsHttpErrorMessage(response.status, creditResponse));
1440
+ }
1441
+ const balance = coerceCloudBalance(creditResponse.balance) ?? coerceCloudBalance(creditResponse.data?.balance);
1442
+ return balance;
1443
+ }
1444
+ function withCreditFlags(balance) {
1445
+ return {
1446
+ connected: true,
1447
+ balance,
1448
+ low: balance < CREDIT_LOW_THRESHOLD,
1449
+ critical: balance < CREDIT_CRITICAL_THRESHOLD,
1450
+ topUpUrl: CLOUD_BILLING_URL
1451
+ };
1452
+ }
1453
+ async function fetchCloudCredits(config, runtime) {
1454
+ const snapshot = resolveCloudConnectionSnapshot(config, runtime);
1455
+ let authenticatedFailure = null;
1456
+ let authenticatedUnexpectedResponse = false;
1457
+ if (!snapshot.connected) {
1458
+ return { balance: null, connected: false };
1459
+ }
1460
+ const cloudClient = snapshot.cloudAuth?.getClient?.();
1461
+ if (snapshot.authConnected && typeof cloudClient?.get === "function") {
1462
+ try {
1463
+ const creditResponse = await cloudClient.get("/credits/balance");
1464
+ const rawBalance = coerceCloudBalance(creditResponse?.balance) ?? coerceCloudBalance(creditResponse?.data?.balance);
1465
+ if (typeof rawBalance === "number") {
1466
+ return withCreditFlags(rawBalance);
1467
+ }
1468
+ authenticatedUnexpectedResponse = true;
1469
+ logger2.debug(`[cloud/credits] Unexpected authenticated response shape: ${JSON.stringify(creditResponse)}`);
1470
+ } catch (err) {
1471
+ const msg = err instanceof Error ? err.message : "cloud API unreachable";
1472
+ authenticatedFailure = msg;
1473
+ logger2.debug(`[cloud/credits] Authenticated balance fetch failed: ${msg}`);
1474
+ }
1475
+ }
1476
+ if (!snapshot.apiKey) {
1477
+ return {
1478
+ balance: null,
1479
+ connected: snapshot.connected,
1480
+ error: authenticatedFailure ?? (authenticatedUnexpectedResponse ? "unexpected response" : "missing cloud api key")
1481
+ };
1482
+ }
1483
+ const resolvedBaseUrl = resolveCloudApiBaseUrl2(config.cloud?.baseUrl);
1484
+ const baseUrlRejection = await validateCloudBaseUrl(resolvedBaseUrl);
1485
+ if (baseUrlRejection) {
1486
+ return {
1487
+ balance: null,
1488
+ connected: true,
1489
+ error: baseUrlRejection
1490
+ };
1491
+ }
1492
+ try {
1493
+ const balance = await fetchCloudCreditsByApiKey(resolvedBaseUrl, snapshot.apiKey);
1494
+ if (typeof balance !== "number") {
1495
+ return {
1496
+ balance: null,
1497
+ connected: true,
1498
+ error: "unexpected response"
1499
+ };
1500
+ }
1501
+ return withCreditFlags(balance);
1502
+ } catch (err) {
1503
+ if (err instanceof CloudCreditsAuthRejectedError) {
1504
+ logger2.debug(`[cloud/credits] API key rejected: ${err.message}`);
1505
+ return {
1506
+ balance: null,
1507
+ connected: true,
1508
+ authRejected: true,
1509
+ error: err.message,
1510
+ topUpUrl: CLOUD_BILLING_URL
1511
+ };
1512
+ }
1513
+ const msg = err instanceof Error ? err.message : "cloud API unreachable";
1514
+ logger2.debug(`[cloud/credits] Failed to fetch balance via API key: ${msg}`);
1515
+ return {
1516
+ balance: null,
1517
+ connected: true,
1518
+ error: msg
1519
+ };
1520
+ }
1521
+ }
1522
+ async function clearCloudAuthService(cloudAuth) {
1523
+ if (!cloudAuth) {
1524
+ return;
1525
+ }
1526
+ const seen = new Set;
1527
+ for (const methodName of CLOUD_AUTH_CLEAR_METHODS) {
1528
+ const method = cloudAuth[methodName];
1529
+ if (typeof method !== "function" || seen.has(method)) {
1530
+ continue;
1531
+ }
1532
+ seen.add(method);
1533
+ try {
1534
+ await method.call(cloudAuth);
1535
+ break;
1536
+ } catch (err) {
1537
+ logger2.warn(`[cloud/disconnect] Failed to invoke CLOUD_AUTH.${methodName}: ${err instanceof Error ? err.message : String(err)}`);
1538
+ }
1539
+ }
1540
+ }
1541
+ function clearCloudEnv() {
1542
+ for (const key of CLOUD_ENV_KEYS) {
1543
+ delete process.env[key];
1544
+ }
1545
+ clearCloudSecrets();
1546
+ scrubCloudSecretsFromEnv();
1547
+ }
1548
+ async function clearRuntimeCloudState(runtime) {
1549
+ const runtimeWithCloud = asRuntimeCloud(runtime);
1550
+ if (!runtimeWithCloud) {
1551
+ return;
1552
+ }
1553
+ const existingSecrets = runtimeWithCloud.character.secrets ?? {};
1554
+ const nextSecrets = { ...existingSecrets };
1555
+ for (const key of CLOUD_RUNTIME_SECRET_KEYS) {
1556
+ delete nextSecrets[key];
1557
+ }
1558
+ runtimeWithCloud.character.secrets = nextSecrets;
1559
+ if (runtimeWithCloud.character.settings && typeof runtimeWithCloud.character.settings === "object") {
1560
+ for (const key of CLOUD_RUNTIME_SETTING_KEYS) {
1561
+ delete runtimeWithCloud.character.settings[key];
1562
+ }
1563
+ }
1564
+ if (typeof runtimeWithCloud.setSetting === "function") {
1565
+ for (const key of CLOUD_RUNTIME_SETTING_KEYS) {
1566
+ try {
1567
+ runtimeWithCloud.setSetting(key, null);
1568
+ } catch (err) {
1569
+ logger2.warn(`[cloud/disconnect] Failed to clear runtime setting ${key}: ${err instanceof Error ? err.message : String(err)}`);
1570
+ }
1571
+ }
1572
+ }
1573
+ if (typeof runtimeWithCloud.updateAgent === "function") {
1574
+ try {
1575
+ await runtimeWithCloud.updateAgent(runtimeWithCloud.agentId, {
1576
+ secrets: { ...nextSecrets }
1577
+ });
1578
+ } catch (err) {
1579
+ logger2.warn(`[cloud/disconnect] Failed to clear cloud secrets from agent DB: ${err instanceof Error ? err.message : String(err)}`);
1580
+ }
1581
+ }
1582
+ }
1583
+ async function disconnectCloudConnection(args) {
1584
+ const { cloudManager = null, config, runtime, saveConfig } = args;
1585
+ if (isElizaSettingsDebugEnabled()) {
1586
+ const c = config.cloud;
1587
+ logger2.debug(`[eliza][settings][cloud] disconnectCloudConnection start cloud=${JSON.stringify(settingsDebugCloudSummary(c))}`);
1588
+ }
1589
+ if (typeof cloudManager?.disconnect === "function") {
1590
+ try {
1591
+ await cloudManager.disconnect();
1592
+ } catch (err) {
1593
+ logger2.warn(`[cloud/disconnect] Failed to disconnect cloud manager: ${err instanceof Error ? err.message : String(err)}`);
1594
+ }
1595
+ }
1596
+ await clearCloudAuthService(getCloudAuth2(runtime));
1597
+ const nextCloud = { ...config.cloud ?? {} };
1598
+ delete nextCloud.apiKey;
1599
+ config.cloud = nextCloud;
1600
+ applyCanonicalSetupConfig(config, {
1601
+ deploymentTarget: { runtime: "local" },
1602
+ linkedAccounts: {
1603
+ elizacloud: {
1604
+ status: "unlinked",
1605
+ source: "api-key"
1606
+ }
1607
+ },
1608
+ clearRoutes: ["llmText", "tts", "media", "embeddings", "rpc"]
1609
+ });
1610
+ migrateLegacyRuntimeConfig2(config);
1611
+ try {
1612
+ saveConfig?.(config);
1613
+ if (isElizaSettingsDebugEnabled()) {
1614
+ const c = config.cloud;
1615
+ logger2.debug(`[eliza][settings][cloud] disconnectCloudConnection saveConfig OK cloud=${JSON.stringify(settingsDebugCloudSummary(c))}`);
1616
+ }
1617
+ } catch (err) {
1618
+ logger2.warn(`[cloud/disconnect] Failed to save cloud disconnect state: ${err instanceof Error ? err.message : String(err)}`);
1619
+ }
1620
+ clearCloudEnv();
1621
+ await clearRuntimeCloudState(runtime);
1622
+ if (isElizaSettingsDebugEnabled()) {
1623
+ logger2.debug("[eliza][settings][cloud] disconnectCloudConnection done (env cleared + runtime cloud state cleared)");
1624
+ }
1625
+ }
1626
+ function isCloudStatusReasonApiKeyOnly(reason) {
1627
+ return typeof reason === "string" && CLOUD_STATUS_API_KEY_ONLY_REASONS.has(reason);
1628
+ }
1629
+ var DEFAULT_CLOUD_API_BASE_URL = "https://www.elizacloud.ai/api/v1", CLOUD_BILLING_URL = "https://www.elizacloud.ai/dashboard/settings?tab=billing", CLOUD_ENV_KEYS, CLOUD_RUNTIME_SECRET_KEYS, CLOUD_RUNTIME_SETTING_KEYS, CLOUD_AUTH_CLEAR_METHODS, CloudCreditsAuthRejectedError, CREDIT_LOW_THRESHOLD, CREDIT_CRITICAL_THRESHOLD, CLOUD_STATUS_API_KEY_ONLY_REASONS;
1630
+ var init_cloud_connection = __esm(() => {
1631
+ init_base_url();
1632
+ init_validate_url();
1633
+ init_cloud_secrets();
1634
+ CLOUD_ENV_KEYS = [
1635
+ "ELIZAOS_CLOUD_API_KEY",
1636
+ "ELIZAOS_CLOUD_ENABLED",
1637
+ "ELIZAOS_CLOUD_BASE_URL",
1638
+ "ELIZAOS_CLOUD_NANO_MODEL",
1639
+ "ELIZAOS_CLOUD_MEDIUM_MODEL",
1640
+ "ELIZAOS_CLOUD_SMALL_MODEL",
1641
+ "ELIZAOS_CLOUD_LARGE_MODEL",
1642
+ "ELIZAOS_CLOUD_MEGA_MODEL",
1643
+ "ELIZAOS_CLOUD_RESPONSE_HANDLER_MODEL",
1644
+ "ELIZAOS_CLOUD_SHOULD_RESPOND_MODEL",
1645
+ "ELIZAOS_CLOUD_ACTION_PLANNER_MODEL",
1646
+ "ELIZAOS_CLOUD_PLANNER_MODEL",
1647
+ "ELIZAOS_CLOUD_USE_INFERENCE",
1648
+ "ELIZAOS_CLOUD_USE_TTS",
1649
+ "ELIZAOS_CLOUD_USE_MEDIA",
1650
+ "ELIZAOS_CLOUD_USE_EMBEDDINGS",
1651
+ "ELIZAOS_CLOUD_USE_RPC"
1652
+ ];
1653
+ CLOUD_RUNTIME_SECRET_KEYS = [
1654
+ "ELIZAOS_CLOUD_API_KEY",
1655
+ "ELIZAOS_CLOUD_ENABLED",
1656
+ "ELIZAOS_CLOUD_BASE_URL",
1657
+ "ELIZAOS_CLOUD_NANO_MODEL",
1658
+ "ELIZAOS_CLOUD_MEDIUM_MODEL",
1659
+ "ELIZAOS_CLOUD_SMALL_MODEL",
1660
+ "ELIZAOS_CLOUD_LARGE_MODEL",
1661
+ "ELIZAOS_CLOUD_MEGA_MODEL",
1662
+ "ELIZAOS_CLOUD_RESPONSE_HANDLER_MODEL",
1663
+ "ELIZAOS_CLOUD_SHOULD_RESPOND_MODEL",
1664
+ "ELIZAOS_CLOUD_ACTION_PLANNER_MODEL",
1665
+ "ELIZAOS_CLOUD_PLANNER_MODEL",
1666
+ "ELIZA_CLOUD_AUTH_TOKEN",
1667
+ "ELIZA_CLOUD_USER_ID",
1668
+ "ELIZA_CLOUD_ORGANIZATION_ID"
1669
+ ];
1670
+ CLOUD_RUNTIME_SETTING_KEYS = [
1671
+ "ELIZA_CLOUD_AUTH_TOKEN",
1672
+ "ELIZA_CLOUD_USER_ID",
1673
+ "ELIZA_CLOUD_ORGANIZATION_ID"
1674
+ ];
1675
+ CLOUD_AUTH_CLEAR_METHODS = [
1676
+ "disconnect",
1677
+ "logout",
1678
+ "signOut",
1679
+ "signout",
1680
+ "clearSession",
1681
+ "clearAuth",
1682
+ "resetAuth",
1683
+ "reset"
1684
+ ];
1685
+ CloudCreditsAuthRejectedError = class CloudCreditsAuthRejectedError extends Error {
1686
+ name = "CloudCreditsAuthRejectedError";
1687
+ constructor(message = "Eliza Cloud API key was rejected") {
1688
+ super(message);
1689
+ }
1690
+ };
1691
+ CREDIT_LOW_THRESHOLD = Number(process.env.ELIZA_CREDIT_LOW_THRESHOLD ?? "2.0");
1692
+ CREDIT_CRITICAL_THRESHOLD = Number(process.env.ELIZA_CREDIT_CRITICAL_THRESHOLD ?? "0.5");
1693
+ CLOUD_STATUS_API_KEY_ONLY_REASONS = new Set([
1694
+ "api_key_present_not_authenticated",
1695
+ "api_key_present_runtime_not_started"
1696
+ ]);
1697
+ });
1698
+
1699
+ // src/routes/cloud-coding-container-routes.ts
1700
+ import {
1701
+ PromoteVfsToCloudContainerRequestSchema,
1702
+ RequestCodingAgentContainerRequestSchema,
1703
+ SyncCloudCodingContainerRequestSchema
1704
+ } from "@elizaos/shared";
1705
+ async function handleCloudCodingContainerRoute(req, res, pathname, method, state) {
1706
+ if (method === "POST" && pathname === "/api/cloud/coding-containers/promotions") {
1707
+ const service = getCloudContainerService(state);
1708
+ if (!service) {
1709
+ sendJsonError(res, "Cloud container service is not available", 503);
1710
+ return true;
1711
+ }
1712
+ const body = await readJsonBody3(req, res);
1713
+ if (!body)
1714
+ return true;
1715
+ const parsed = PromoteVfsToCloudContainerRequestSchema.safeParse(body);
1716
+ if (!parsed.success) {
1717
+ sendJsonError(res, parsed.error.issues[0]?.message ?? "Invalid promotion request", 400);
1718
+ return true;
1719
+ }
1720
+ await sendServiceResponse(res, () => service.promoteVfsToCloudContainer(parsed.data));
1721
+ return true;
1722
+ }
1723
+ if (method === "POST" && pathname === "/api/cloud/coding-containers") {
1724
+ const service = getCloudContainerService(state);
1725
+ if (!service) {
1726
+ sendJsonError(res, "Cloud container service is not available", 503);
1727
+ return true;
1728
+ }
1729
+ const body = await readJsonBody3(req, res);
1730
+ if (!body)
1731
+ return true;
1732
+ const parsed = RequestCodingAgentContainerRequestSchema.safeParse(body);
1733
+ if (!parsed.success) {
1734
+ sendJsonError(res, parsed.error.issues[0]?.message ?? "Invalid coding container request", 400);
1735
+ return true;
1736
+ }
1737
+ await sendServiceResponse(res, () => service.requestCodingAgentContainer(parsed.data));
1738
+ return true;
1739
+ }
1740
+ const syncMatch = /^\/api\/cloud\/coding-containers\/([^/]+)\/sync$/.exec(pathname);
1741
+ if (method === "POST" && syncMatch) {
1742
+ const service = getCloudContainerService(state);
1743
+ if (!service) {
1744
+ sendJsonError(res, "Cloud container service is not available", 503);
1745
+ return true;
1746
+ }
1747
+ const containerId = decodeURIComponent(syncMatch[1]);
1748
+ const body = await readJsonBody3(req, res);
1749
+ if (!body)
1750
+ return true;
1751
+ const parsed = SyncCloudCodingContainerRequestSchema.safeParse(body);
1752
+ if (!parsed.success) {
1753
+ sendJsonError(res, parsed.error.issues[0]?.message ?? "Invalid sync request", 400);
1754
+ return true;
1755
+ }
1756
+ await sendServiceResponse(res, () => service.syncCodingContainerChanges(containerId, parsed.data));
1757
+ return true;
1758
+ }
1759
+ return false;
1760
+ }
1761
+ function getCloudContainerService(state) {
1762
+ const service = state.runtime?.getService?.("CLOUD_CONTAINER") ?? state.runtime?.getService?.("cloud-container") ?? state.runtime?.getService?.("cloudContainer");
1763
+ if (!service || typeof service !== "object")
1764
+ return null;
1765
+ const candidate = service;
1766
+ if (typeof candidate.promoteVfsToCloudContainer === "function" && typeof candidate.requestCodingAgentContainer === "function" && typeof candidate.syncCodingContainerChanges === "function") {
1767
+ return candidate;
1768
+ }
1769
+ return null;
1770
+ }
1771
+ async function readJsonBody3(req, res) {
1772
+ const preParsed = req.body;
1773
+ if (preParsed && typeof preParsed === "object" && !Array.isArray(preParsed)) {
1774
+ return preParsed;
1775
+ }
1776
+ const chunks = [];
1777
+ for await (const chunk of req) {
1778
+ chunks.push(typeof chunk === "string" ? Buffer.from(chunk) : chunk);
1779
+ }
1780
+ const raw = Buffer.concat(chunks).toString("utf8").trim();
1781
+ if (!raw)
1782
+ return {};
1783
+ let parsed;
1784
+ try {
1785
+ parsed = JSON.parse(raw);
1786
+ } catch {
1787
+ sendJsonError(res, "Invalid JSON body", 400);
1788
+ return null;
1789
+ }
1790
+ if (!parsed || typeof parsed !== "object" || Array.isArray(parsed)) {
1791
+ sendJsonError(res, "Invalid JSON body", 400);
1792
+ return null;
1793
+ }
1794
+ return parsed;
1795
+ }
1796
+ async function sendServiceResponse(res, fn) {
1797
+ try {
1798
+ sendJson(res, await fn());
1799
+ } catch (error) {
1800
+ const status = typeof error?.statusCode === "number" ? error.statusCode : 500;
1801
+ sendJsonError(res, error instanceof Error ? error.message : String(error), status);
1802
+ }
1803
+ }
1804
+ var init_cloud_coding_container_routes = () => {};
1805
+
1806
+ // src/routes/cloud-routes.ts
1807
+ import {
1808
+ isCloudInferenceSelectedInConfig as isCloudInferenceSelectedInConfig3,
1809
+ migrateLegacyRuntimeConfig as migrateLegacyRuntimeConfig3
1810
+ } from "@elizaos/core";
1811
+ import { logger as logger3 } from "@elizaos/core";
1812
+ async function readRouteJsonBody(req) {
1813
+ const preParsed = req.body;
1814
+ if (preParsed && typeof preParsed === "object" && !Array.isArray(preParsed)) {
1815
+ return preParsed;
1816
+ }
1817
+ const chunks = [];
1818
+ for await (const chunk of req) {
1819
+ chunks.push(typeof chunk === "string" ? Buffer.from(chunk) : chunk);
1820
+ }
1821
+ const rawBody = Buffer.concat(chunks).toString("utf8").trim();
1822
+ if (!rawBody) {
1823
+ return {};
1824
+ }
1825
+ const parsed = JSON.parse(rawBody);
1826
+ if (!parsed || typeof parsed !== "object" || Array.isArray(parsed)) {
1827
+ throw new Error("Invalid JSON body");
1828
+ }
1829
+ return parsed;
1830
+ }
1831
+ function isRedirectResponse2(response) {
1832
+ return response.status >= 300 && response.status < 400;
1833
+ }
1834
+ function createNoopTelemetrySpan2() {
1835
+ return {
1836
+ success: () => {},
1837
+ failure: () => {}
1838
+ };
1839
+ }
1840
+ function getTelemetrySpan2(meta) {
1841
+ return meta.services.createIntegrationTelemetrySpan(meta) ?? createNoopTelemetrySpan2();
1842
+ }
1843
+ async function fetchCloudLoginStatus(sessionId, baseUrl) {
1844
+ return fetch(`${baseUrl}/api/auth/cli-session/${encodeURIComponent(sessionId)}`, {
1845
+ redirect: "manual",
1846
+ signal: AbortSignal.timeout(CLOUD_LOGIN_POLL_TIMEOUT_MS2)
1847
+ });
1848
+ }
1849
+ async function persistCloudLoginStatus(args) {
1850
+ if (args.epochAtPollStart !== undefined && args.epochAtPollStart !== cloudDisconnectEpoch) {
1851
+ logger3.warn("[cloud-login] Skipping login persist: a disconnect occurred while the login poll was in-flight");
1852
+ return;
1853
+ }
1854
+ migrateLegacyRuntimeConfig3(args.state.config);
1855
+ const runtime = args.state.runtime;
1856
+ const cloudAuth = getCloudAuth2(runtime);
1857
+ await clearCloudAuthService(cloudAuth);
1858
+ const cloud = { ...args.state.config.cloud ?? {} };
1859
+ cloud.apiKey = args.apiKey;
1860
+ const cloudInferenceSelected = isCloudInferenceSelectedInConfig3(args.state.config);
1861
+ args.state.config.cloud = cloud;
1862
+ args.services.applyCanonicalSetupConfig(args.state.config, {
1863
+ linkedAccounts: {
1864
+ elizacloud: {
1865
+ status: "linked",
1866
+ source: "api-key"
1867
+ }
1868
+ }
1869
+ });
1870
+ migrateLegacyRuntimeConfig3(args.state.config);
1871
+ try {
1872
+ args.services.saveElizaConfig(args.state.config);
1873
+ logger3.info("[cloud-login] Saved cloud API key to config file");
1874
+ logger3.warn("[cloud-login] Cloud API key is stored in cleartext in ~/.eliza/eliza.json. " + "Ensure this file has restrictive permissions (chmod 600).");
1875
+ } catch (saveErr) {
1876
+ logger3.error(`[cloud-login] Failed to save cloud API key to config: ${saveErr instanceof Error ? saveErr.message : String(saveErr)}`);
1877
+ }
1878
+ clearCloudSecrets();
1879
+ process.env.ELIZAOS_CLOUD_API_KEY = args.apiKey;
1880
+ if (cloudInferenceSelected) {
1881
+ process.env.ELIZAOS_CLOUD_ENABLED = "true";
1882
+ } else {
1883
+ delete process.env.ELIZAOS_CLOUD_ENABLED;
1884
+ }
1885
+ scrubCloudSecretsFromEnv();
1886
+ const cloudManager = args.state.cloudManager;
1887
+ if (cloudManager && typeof cloudManager.replaceApiKey === "function") {
1888
+ await cloudManager.replaceApiKey(args.apiKey);
1889
+ } else if (cloudManager && !cloudManager.getClient() && typeof cloudManager.init === "function") {
1890
+ await cloudManager.init();
1891
+ }
1892
+ if (typeof cloudAuth?.authenticateWithApiKey === "function") {
1893
+ cloudAuth.authenticateWithApiKey({
1894
+ apiKey: args.apiKey,
1895
+ organizationId: args.organizationId,
1896
+ userId: args.userId
1897
+ });
1898
+ }
1899
+ const relayService = runtime?.getService("CLOUD_MANAGED_GATEWAY_RELAY") ?? runtime?.getService("cloud-managed-gateway-relay") ?? runtime?.getService("cloudManagedGatewayRelay");
1900
+ if (typeof relayService?.startRelayLoopIfReady === "function") {
1901
+ await relayService.startRelayLoopIfReady();
1902
+ }
1903
+ if (!runtime || typeof runtime.updateAgent !== "function") {
1904
+ return;
1905
+ }
1906
+ try {
1907
+ const nextSecrets = {
1908
+ ...runtime.character.secrets ?? {},
1909
+ ELIZAOS_CLOUD_API_KEY: args.apiKey
1910
+ };
1911
+ if (args.userId) {
1912
+ nextSecrets.ELIZA_CLOUD_USER_ID = args.userId;
1913
+ nextSecrets.ELIZAOS_CLOUD_USER_ID = args.userId;
1914
+ } else {
1915
+ delete nextSecrets.ELIZA_CLOUD_USER_ID;
1916
+ delete nextSecrets.ELIZAOS_CLOUD_USER_ID;
1917
+ }
1918
+ if (args.organizationId) {
1919
+ nextSecrets.ELIZA_CLOUD_ORGANIZATION_ID = args.organizationId;
1920
+ nextSecrets.ELIZAOS_CLOUD_ORG_ID = args.organizationId;
1921
+ } else {
1922
+ delete nextSecrets.ELIZA_CLOUD_ORGANIZATION_ID;
1923
+ delete nextSecrets.ELIZAOS_CLOUD_ORG_ID;
1924
+ }
1925
+ if (cloudInferenceSelected) {
1926
+ nextSecrets.ELIZAOS_CLOUD_ENABLED = "true";
1927
+ } else {
1928
+ delete nextSecrets.ELIZAOS_CLOUD_ENABLED;
1929
+ }
1930
+ runtime.character.secrets = nextSecrets;
1931
+ if (typeof runtime.setSetting === "function") {
1932
+ runtime.setSetting("ELIZA_CLOUD_USER_ID", args.userId ?? null);
1933
+ runtime.setSetting("ELIZAOS_CLOUD_USER_ID", args.userId ?? null);
1934
+ runtime.setSetting("ELIZA_CLOUD_ORGANIZATION_ID", args.organizationId ?? null);
1935
+ runtime.setSetting("ELIZAOS_CLOUD_ORG_ID", args.organizationId ?? null);
1936
+ }
1937
+ await runtime.updateAgent(runtime.agentId, {
1938
+ secrets: { ...nextSecrets }
1939
+ });
1940
+ } catch (err) {
1941
+ logger3.warn(`[cloud-routes] Failed to persist cloud secrets to agent DB: ${String(err)}`);
1942
+ }
1943
+ }
1944
+ function getCloudRouteServices(state) {
1945
+ return {
1946
+ ...DEFAULT_CLOUD_ROUTE_SERVICES,
1947
+ ...state.services
1948
+ };
1949
+ }
1950
+ function readRuntimeSetting(runtime, key) {
1951
+ const value = runtime?.getSetting(key);
1952
+ if (typeof value !== "string")
1953
+ return null;
1954
+ const trimmed = value.trim();
1955
+ return trimmed ? trimmed : null;
1956
+ }
1957
+ function toAutonomousState(state, services) {
1958
+ return {
1959
+ ...state,
1960
+ saveConfig: () => services.saveElizaConfig(state.config),
1961
+ createTelemetrySpan: services.createIntegrationTelemetrySpan
1962
+ };
1963
+ }
1964
+ async function handleCloudRoute2(req, res, pathname, method, state) {
1965
+ const services = getCloudRouteServices(state);
1966
+ const codingContainerHandled = await handleCloudCodingContainerRoute(req, res, pathname, method, { runtime: state.runtime });
1967
+ if (codingContainerHandled) {
1968
+ return true;
1969
+ }
1970
+ if (method === "GET" && pathname === "/api/cloud/relay-status") {
1971
+ const relayService = state.runtime?.getService("CLOUD_MANAGED_GATEWAY_RELAY") ?? state.runtime?.getService("cloud-managed-gateway-relay") ?? state.runtime?.getService("cloudManagedGatewayRelay");
1972
+ if (typeof relayService?.getSessionInfo !== "function") {
1973
+ sendJson(res, {
1974
+ available: false,
1975
+ status: "not_registered",
1976
+ reason: "Gateway relay service not active. Connect to Eliza Cloud in Settings to enable instance routing."
1977
+ });
1978
+ return true;
1979
+ }
1980
+ try {
1981
+ const info = relayService.getSessionInfo();
1982
+ sendJson(res, {
1983
+ available: true,
1984
+ ...info,
1985
+ accessUrl: buildHomeRemoteRunnerAccessUrl({
1986
+ cloudBaseUrl: services.normalizeCloudSiteUrl(state.config.cloud?.baseUrl),
1987
+ sessionId: info.sessionId
1988
+ }),
1989
+ ssh: buildHomeRemoteRunnerSshTunnel({
1990
+ remoteBaseUrl: readRuntimeSetting(state.runtime, "ELIZA_HOME_REMOTE_RUNNER_URL") ?? process.env.ELIZA_HOME_REMOTE_RUNNER_URL ?? readRuntimeSetting(state.runtime, "ELIZA_HOME_RUNNER_URL") ?? process.env.ELIZA_HOME_RUNNER_URL,
1991
+ sshTarget: readRuntimeSetting(state.runtime, "ELIZA_HOME_REMOTE_RUNNER_SSH_TARGET") ?? process.env.ELIZA_HOME_REMOTE_RUNNER_SSH_TARGET ?? readRuntimeSetting(state.runtime, "ELIZA_HOME_SSH_TARGET") ?? process.env.ELIZA_HOME_SSH_TARGET,
1992
+ sshIdentity: readRuntimeSetting(state.runtime, "ELIZA_HOME_REMOTE_RUNNER_SSH_IDENTITY") ?? process.env.ELIZA_HOME_REMOTE_RUNNER_SSH_IDENTITY ?? readRuntimeSetting(state.runtime, "ELIZA_HOME_SSH_IDENTITY") ?? process.env.ELIZA_HOME_SSH_IDENTITY,
1993
+ localPort: readRuntimeSetting(state.runtime, "ELIZA_HOME_REMOTE_RUNNER_SSH_LOCAL_PORT") ?? process.env.ELIZA_HOME_REMOTE_RUNNER_SSH_LOCAL_PORT
1994
+ })
1995
+ });
1996
+ } catch (error) {
1997
+ sendJson(res, {
1998
+ available: false,
1999
+ status: "error",
2000
+ reason: error instanceof Error ? error.message : String(error)
2001
+ });
2002
+ }
2003
+ return true;
2004
+ }
2005
+ if (method === "POST" && pathname === "/api/cloud/disconnect") {
2006
+ cloudDisconnectEpoch++;
2007
+ try {
2008
+ await disconnectCloudConnection({
2009
+ cloudManager: state.cloudManager,
2010
+ config: state.config,
2011
+ runtime: state.runtime,
2012
+ saveConfig: services.saveElizaConfig
2013
+ });
2014
+ } catch (err) {
2015
+ const message = err instanceof Error ? err.message : String(err);
2016
+ logger3.error(`[cloud/disconnect] failed: ${message}`);
2017
+ sendJson(res, { ok: false, error: message }, 500);
2018
+ return true;
2019
+ }
2020
+ sendJson(res, { ok: true, status: "disconnected" });
2021
+ return true;
2022
+ }
2023
+ if (method === "POST" && pathname === "/api/cloud/login/persist") {
2024
+ try {
2025
+ const body = await readRouteJsonBody(req);
2026
+ if (typeof body.apiKey !== "string" || !body.apiKey.trim()) {
2027
+ sendJson(res, { ok: false, error: "apiKey is required" }, 400);
2028
+ return true;
2029
+ }
2030
+ await persistCloudLoginStatus({
2031
+ apiKey: body.apiKey.trim(),
2032
+ organizationId: typeof body.organizationId === "string" ? body.organizationId.trim() : undefined,
2033
+ services,
2034
+ state,
2035
+ userId: typeof body.userId === "string" ? body.userId.trim() : undefined
2036
+ });
2037
+ sendJson(res, { ok: true });
2038
+ } catch (err) {
2039
+ const msg = err instanceof Error ? err.message : String(err);
2040
+ logger3.error(`[cloud/login/persist] Failed: ${msg}`);
2041
+ sendJson(res, { ok: false, error: msg }, 500);
2042
+ }
2043
+ return true;
2044
+ }
2045
+ if (method === "GET" && pathname.startsWith("/api/cloud/login/status")) {
2046
+ const url = new URL(req.url ?? "/", `http://${req.headers.host ?? "localhost"}`);
2047
+ const sessionId = url.searchParams.get("sessionId");
2048
+ if (!sessionId) {
2049
+ sendJsonError(res, "sessionId query parameter is required", 400);
2050
+ return true;
2051
+ }
2052
+ const baseUrl = services.normalizeCloudSiteUrl(state.config.cloud?.baseUrl);
2053
+ const urlError = await services.validateCloudBaseUrl(baseUrl);
2054
+ if (urlError) {
2055
+ sendJsonError(res, urlError, 400);
2056
+ return true;
2057
+ }
2058
+ const epochBeforePoll = cloudDisconnectEpoch;
2059
+ const loginPollSpan = getTelemetrySpan2({
2060
+ boundary: "cloud",
2061
+ operation: "login_poll_status",
2062
+ services,
2063
+ timeoutMs: CLOUD_LOGIN_POLL_TIMEOUT_MS2
2064
+ });
2065
+ let pollRes;
2066
+ try {
2067
+ pollRes = await fetchCloudLoginStatus(sessionId, baseUrl);
2068
+ } catch (fetchErr) {
2069
+ if (isTimeoutError(fetchErr)) {
2070
+ loginPollSpan.failure({ error: fetchErr, statusCode: 504 });
2071
+ sendJson(res, {
2072
+ status: "error",
2073
+ error: "Eliza Cloud status request timed out"
2074
+ }, 504);
2075
+ return true;
2076
+ }
2077
+ loginPollSpan.failure({ error: fetchErr, statusCode: 502 });
2078
+ sendJson(res, {
2079
+ status: "error",
2080
+ error: "Failed to reach Eliza Cloud"
2081
+ }, 502);
2082
+ return true;
2083
+ }
2084
+ if (isRedirectResponse2(pollRes)) {
2085
+ loginPollSpan.failure({
2086
+ statusCode: pollRes.status,
2087
+ errorKind: "redirect_response"
2088
+ });
2089
+ sendJson(res, {
2090
+ status: "error",
2091
+ error: "Eliza Cloud status request was redirected; redirects are not allowed"
2092
+ }, 502);
2093
+ return true;
2094
+ }
2095
+ if (!pollRes.ok) {
2096
+ loginPollSpan.failure({
2097
+ statusCode: pollRes.status,
2098
+ errorKind: "http_error"
2099
+ });
2100
+ sendJson(res, pollRes.status === 404 ? { status: "expired", error: "Session not found or expired" } : {
2101
+ status: "error",
2102
+ error: `Eliza Cloud returned HTTP ${pollRes.status}`
2103
+ });
2104
+ return true;
2105
+ }
2106
+ let data;
2107
+ try {
2108
+ data = await pollRes.json();
2109
+ } catch (parseErr) {
2110
+ loginPollSpan.failure({ error: parseErr, statusCode: pollRes.status });
2111
+ sendJson(res, {
2112
+ status: "error",
2113
+ error: "Eliza Cloud returned invalid JSON"
2114
+ }, 502);
2115
+ return true;
2116
+ }
2117
+ loginPollSpan.success({ statusCode: pollRes.status });
2118
+ if (data.status === "authenticated" && typeof data.apiKey === "string") {
2119
+ await persistCloudLoginStatus({
2120
+ apiKey: data.apiKey,
2121
+ organizationId: typeof data.organizationId === "string" ? data.organizationId : undefined,
2122
+ services,
2123
+ state,
2124
+ epochAtPollStart: epochBeforePoll,
2125
+ userId: typeof data.userId === "string" ? data.userId : undefined
2126
+ });
2127
+ sendJson(res, {
2128
+ status: "authenticated",
2129
+ keyPrefix: typeof data.keyPrefix === "string" ? data.keyPrefix : undefined,
2130
+ organizationId: typeof data.organizationId === "string" ? data.organizationId : undefined,
2131
+ token: data.apiKey,
2132
+ userId: typeof data.userId === "string" ? data.userId : undefined
2133
+ });
2134
+ return true;
2135
+ }
2136
+ sendJson(res, {
2137
+ status: typeof data.status === "string" ? data.status : "error"
2138
+ });
2139
+ return true;
2140
+ }
2141
+ const result = await services.handleAutonomousCloudRoute(req, res, pathname, method, toAutonomousState(state, services));
2142
+ scrubCloudSecretsFromEnv();
2143
+ return result;
2144
+ }
2145
+ var CLOUD_LOGIN_POLL_TIMEOUT_MS2 = 1e4, DEFAULT_CLOUD_ROUTE_SERVICES, cloudDisconnectEpoch = 0;
2146
+ var init_cloud_routes = __esm(() => {
2147
+ init_cloud_routes_autonomous();
2148
+ init_home_remote_runner_access_url();
2149
+ init_base_url();
2150
+ init_validate_url();
2151
+ init_cloud_coding_container_routes();
2152
+ init_cloud_connection();
2153
+ init_cloud_secrets();
2154
+ DEFAULT_CLOUD_ROUTE_SERVICES = {
2155
+ applyCanonicalSetupConfig,
2156
+ createIntegrationTelemetrySpan: () => {
2157
+ return;
2158
+ },
2159
+ handleAutonomousCloudRoute: handleCloudRoute,
2160
+ normalizeCloudSiteUrl,
2161
+ saveElizaConfig: () => {
2162
+ logger3.warn("[cloud-routes] saveConfig unavailable - config not persisted");
2163
+ },
2164
+ validateCloudBaseUrl
2165
+ };
2166
+ });
2167
+ init_cloud_routes();
2168
+
2169
+ export {
2170
+ handleCloudRoute2 as handleCloudRoute
2171
+ };
2172
+
2173
+ //# debugId=EBA7A1158F35379764756E2164756E21