@elizaos/plugin-elizacloud 2.0.0-alpha.7 → 2.0.0-beta.1
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.
- package/LICENSE +21 -0
- package/README.md +220 -0
- package/auto-enable.ts +17 -0
- package/dist/browser/index.browser.js +2 -21
- package/dist/browser/index.browser.js.map +5 -37
- package/dist/cjs/index.d.ts +2 -2
- package/dist/cjs/index.node.cjs +12173 -2271
- package/dist/cjs/index.node.js.map +135 -27
- package/dist/cloud/auth.d.ts +19 -0
- package/dist/cloud/auth.d.ts.map +1 -0
- package/dist/cloud/auth.js +330 -0
- package/dist/cloud/auth.js.map +12 -0
- package/dist/cloud/backup.d.ts +18 -0
- package/dist/cloud/backup.d.ts.map +1 -0
- package/dist/cloud/backup.js +63 -0
- package/dist/cloud/backup.js.map +10 -0
- package/dist/cloud/base-url.d.ts +3 -0
- package/dist/cloud/base-url.d.ts.map +1 -0
- package/dist/cloud/base-url.js +77 -0
- package/dist/cloud/base-url.js.map +10 -0
- package/dist/cloud/bridge-client.d.ts +126 -0
- package/dist/cloud/bridge-client.d.ts.map +1 -0
- package/dist/cloud/bridge-client.js +432 -0
- package/dist/cloud/bridge-client.js.map +11 -0
- package/dist/cloud/cloud-api-key.d.ts +26 -0
- package/dist/cloud/cloud-api-key.d.ts.map +1 -0
- package/dist/cloud/cloud-api-key.js +60 -0
- package/dist/cloud/cloud-api-key.js.map +10 -0
- package/dist/cloud/cloud-manager.d.ts +33 -0
- package/dist/cloud/cloud-manager.d.ts.map +1 -0
- package/dist/cloud/cloud-manager.js +853 -0
- package/dist/cloud/cloud-manager.js.map +16 -0
- package/dist/cloud/cloud-proxy.d.ts +20 -0
- package/dist/cloud/cloud-proxy.d.ts.map +1 -0
- package/dist/cloud/cloud-proxy.js +54 -0
- package/dist/cloud/cloud-proxy.js.map +10 -0
- package/dist/cloud/cloud-wallet.d.ts +94 -0
- package/dist/cloud/cloud-wallet.d.ts.map +1 -0
- package/dist/cloud/cloud-wallet.js +5195 -0
- package/dist/cloud/cloud-wallet.js.map +92 -0
- package/dist/cloud/index.d.ts +9 -0
- package/dist/cloud/index.d.ts.map +1 -0
- package/dist/cloud/index.js +30 -0
- package/dist/cloud/index.js.map +9 -0
- package/dist/cloud/reconnect.d.ts +26 -0
- package/dist/cloud/reconnect.d.ts.map +1 -0
- package/dist/cloud/reconnect.js +104 -0
- package/dist/cloud/reconnect.js.map +10 -0
- package/dist/cloud/validate-url.d.ts +2 -0
- package/dist/cloud/validate-url.d.ts.map +1 -0
- package/dist/cloud/validate-url.js +174 -0
- package/dist/cloud/validate-url.js.map +10 -0
- package/dist/cloud-providers/cloud-status.d.ts.map +1 -1
- package/dist/cloud-providers/cloud-status.js +78 -0
- package/dist/cloud-providers/cloud-status.js.map +10 -0
- package/dist/cloud-providers/container-health.d.ts.map +1 -1
- package/dist/cloud-providers/container-health.js +74 -0
- package/dist/cloud-providers/container-health.js.map +10 -0
- package/dist/cloud-providers/credit-balance.d.ts.map +1 -1
- package/dist/cloud-providers/credit-balance.js +85 -0
- package/dist/cloud-providers/credit-balance.js.map +10 -0
- package/dist/cloud-providers/index.d.ts.map +1 -1
- package/dist/cloud-providers/index.js +24 -0
- package/dist/cloud-providers/index.js.map +9 -0
- package/dist/cloud-providers/model-registry.d.ts.map +1 -1
- package/dist/cloud-providers/model-registry.js +71 -0
- package/dist/cloud-providers/model-registry.js.map +10 -0
- package/dist/index.browser.d.ts +4 -2
- package/dist/index.browser.d.ts.map +1 -1
- package/dist/index.d.ts +18 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +12851 -0
- package/dist/index.js.map +145 -0
- package/dist/index.node.d.ts +15 -2
- package/dist/index.node.d.ts.map +1 -1
- package/dist/init.d.ts.map +1 -1
- package/dist/init.js +169 -0
- package/dist/init.js.map +12 -0
- package/dist/lib/cloud-connection.d.ts +78 -0
- package/dist/lib/cloud-connection.d.ts.map +1 -0
- package/dist/lib/cloud-connection.js +731 -0
- package/dist/lib/cloud-connection.js.map +14 -0
- package/dist/lib/cloud-secrets.d.ts +23 -0
- package/dist/lib/cloud-secrets.d.ts.map +1 -0
- package/dist/lib/cloud-secrets.js +64 -0
- package/dist/lib/cloud-secrets.js.map +10 -0
- package/dist/lib/config-env.d.ts +5 -0
- package/dist/lib/config-env.d.ts.map +1 -0
- package/dist/lib/config-env.js +191 -0
- package/dist/lib/config-env.js.map +11 -0
- package/dist/lib/config-like.d.ts +40 -0
- package/dist/lib/config-like.d.ts.map +1 -0
- package/dist/lib/config-like.js +103 -0
- package/dist/lib/config-like.js.map +10 -0
- package/dist/lib/credential-type-map.d.ts +53 -0
- package/dist/lib/credential-type-map.d.ts.map +1 -0
- package/dist/lib/credential-type-map.js +88 -0
- package/dist/lib/credential-type-map.js.map +10 -0
- package/dist/lib/feature-flags.d.ts +2 -0
- package/dist/lib/feature-flags.d.ts.map +1 -0
- package/dist/lib/feature-flags.js +40 -0
- package/dist/lib/feature-flags.js.map +10 -0
- package/dist/lib/http.d.ts +22 -0
- package/dist/lib/http.d.ts.map +1 -0
- package/dist/lib/http.js +107 -0
- package/dist/lib/http.js.map +10 -0
- package/dist/lib/server-cloud-tts.d.ts +34 -0
- package/dist/lib/server-cloud-tts.d.ts.map +1 -0
- package/dist/lib/server-cloud-tts.js +549 -0
- package/dist/lib/server-cloud-tts.js.map +13 -0
- package/dist/lib/state-paths.d.ts +4 -0
- package/dist/lib/state-paths.d.ts.map +1 -0
- package/dist/lib/state-paths.js +52 -0
- package/dist/lib/state-paths.js.map +10 -0
- package/dist/lib/tts-debug.d.ts +4 -0
- package/dist/lib/tts-debug.d.ts.map +1 -0
- package/dist/lib/tts-debug.js +57 -0
- package/dist/lib/tts-debug.js.map +10 -0
- package/dist/models/embeddings.d.ts.map +1 -1
- package/dist/models/embeddings.js +319 -0
- package/dist/models/embeddings.js.map +13 -0
- package/dist/models/image.d.ts.map +1 -1
- package/dist/models/image.js +374 -0
- package/dist/models/image.js.map +14 -0
- package/dist/models/index.d.ts +1 -2
- package/dist/models/index.d.ts.map +1 -1
- package/dist/models/index.js +1386 -0
- package/dist/models/index.js.map +20 -0
- package/dist/models/research.d.ts.map +1 -1
- package/dist/models/research.js +324 -0
- package/dist/models/research.js.map +13 -0
- package/dist/models/speech.d.ts.map +1 -1
- package/dist/models/speech.js +273 -0
- package/dist/models/speech.js.map +13 -0
- package/dist/models/text.d.ts +5 -2
- package/dist/models/text.d.ts.map +1 -1
- package/dist/models/text.js +803 -0
- package/dist/models/text.js.map +15 -0
- package/dist/models/tokenization.d.ts.map +1 -1
- package/dist/models/tokenization.js +65 -0
- package/dist/models/tokenization.js.map +10 -0
- package/dist/models/transcription.d.ts.map +1 -1
- package/dist/models/transcription.js +283 -0
- package/dist/models/transcription.js.map +13 -0
- package/dist/node/index.d.ts +2 -2
- package/dist/node/index.node.js +12171 -2266
- package/dist/node/index.node.js.map +135 -27
- package/dist/onboarding.d.ts +35 -0
- package/dist/onboarding.d.ts.map +1 -0
- package/dist/onboarding.js +883 -0
- package/dist/onboarding.js.map +14 -0
- package/dist/plugin.d.ts +20 -0
- package/dist/plugin.d.ts.map +1 -0
- package/dist/plugin.js +7611 -0
- package/dist/plugin.js.map +104 -0
- package/dist/providers/openai.d.ts.map +1 -1
- package/dist/providers/openai.js +127 -0
- package/dist/providers/openai.js.map +11 -0
- package/dist/register-routes.d.ts +2 -0
- package/dist/register-routes.d.ts.map +1 -0
- package/dist/register-routes.js +7612 -0
- package/dist/register-routes.js.map +105 -0
- package/dist/routes/cloud-billing-routes.d.ts +9 -0
- package/dist/routes/cloud-billing-routes.d.ts.map +1 -0
- package/dist/routes/cloud-billing-routes.js +807 -0
- package/dist/routes/cloud-billing-routes.js.map +14 -0
- package/dist/routes/cloud-compat-routes.d.ts +10 -0
- package/dist/routes/cloud-compat-routes.d.ts.map +1 -0
- package/dist/routes/cloud-compat-routes.js +538 -0
- package/dist/routes/cloud-compat-routes.js.map +14 -0
- package/dist/routes/cloud-features-routes.d.ts +9 -0
- package/dist/routes/cloud-features-routes.d.ts.map +1 -0
- package/dist/routes/cloud-features-routes.js +124 -0
- package/dist/routes/cloud-features-routes.js.map +11 -0
- package/dist/routes/cloud-provisioning.d.ts +14 -0
- package/dist/routes/cloud-provisioning.d.ts.map +1 -0
- package/dist/routes/cloud-provisioning.js +37 -0
- package/dist/routes/cloud-provisioning.js.map +10 -0
- package/dist/routes/cloud-relay-routes.d.ts +22 -0
- package/dist/routes/cloud-relay-routes.d.ts.map +1 -0
- package/dist/routes/cloud-relay-routes.js +60 -0
- package/dist/routes/cloud-relay-routes.js.map +10 -0
- package/dist/routes/cloud-routes-autonomous.d.ts +83 -0
- package/dist/routes/cloud-routes-autonomous.d.ts.map +1 -0
- package/dist/routes/cloud-routes-autonomous.js +6134 -0
- package/dist/routes/cloud-routes-autonomous.js.map +97 -0
- package/dist/routes/cloud-routes.d.ts +35 -0
- package/dist/routes/cloud-routes.d.ts.map +1 -0
- package/dist/routes/cloud-routes.js +6888 -0
- package/dist/routes/cloud-routes.js.map +100 -0
- package/dist/routes/cloud-status-routes-autonomous.d.ts +15 -0
- package/dist/routes/cloud-status-routes-autonomous.d.ts.map +1 -0
- package/dist/routes/cloud-status-routes-autonomous.js +396 -0
- package/dist/routes/cloud-status-routes-autonomous.js.map +13 -0
- package/dist/routes/cloud-status-routes.d.ts +4 -0
- package/dist/routes/cloud-status-routes.d.ts.map +1 -0
- package/dist/routes/cloud-status-routes.js +771 -0
- package/dist/routes/cloud-status-routes.js.map +15 -0
- package/dist/services/cloud-auth.d.ts +140 -5
- package/dist/services/cloud-auth.d.ts.map +1 -1
- package/dist/services/cloud-auth.js +363 -0
- package/dist/services/cloud-auth.js.map +12 -0
- package/dist/services/cloud-backup.d.ts.map +1 -1
- package/dist/services/cloud-backup.js +176 -0
- package/dist/services/cloud-backup.js.map +11 -0
- package/dist/services/cloud-bootstrap.d.ts +38 -0
- package/dist/services/cloud-bootstrap.d.ts.map +1 -0
- package/dist/services/cloud-bootstrap.js +84 -0
- package/dist/services/cloud-bootstrap.js.map +10 -0
- package/dist/services/cloud-bridge.d.ts +1 -1
- package/dist/services/cloud-bridge.d.ts.map +1 -1
- package/dist/services/cloud-bridge.js +308 -0
- package/dist/services/cloud-bridge.js.map +11 -0
- package/dist/services/cloud-container.d.ts.map +1 -1
- package/dist/services/cloud-container.js +241 -0
- package/dist/services/cloud-container.js.map +11 -0
- package/dist/services/cloud-credential-provider.d.ts +55 -0
- package/dist/services/cloud-credential-provider.d.ts.map +1 -0
- package/dist/services/cloud-credential-provider.js +190 -0
- package/dist/services/cloud-credential-provider.js.map +11 -0
- package/dist/services/cloud-managed-gateway-relay.d.ts +38 -0
- package/dist/services/cloud-managed-gateway-relay.d.ts.map +1 -0
- package/dist/services/cloud-managed-gateway-relay.js +479 -0
- package/dist/services/cloud-managed-gateway-relay.js.map +10 -0
- package/dist/services/cloud-model-registry.d.ts.map +1 -1
- package/dist/services/cloud-model-registry.js +175 -0
- package/dist/services/cloud-model-registry.js.map +10 -0
- package/dist/services/index.d.ts +3 -1
- package/dist/services/index.d.ts.map +1 -1
- package/dist/services/index.js +29 -0
- package/dist/services/index.js.map +9 -0
- package/dist/types/cloud.d.ts +41 -19
- package/dist/types/cloud.d.ts.map +1 -1
- package/dist/types/cloud.js +52 -0
- package/dist/types/cloud.js.map +10 -0
- package/dist/types/index.d.ts +1 -1
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +24 -0
- package/dist/types/index.js.map +9 -0
- package/dist/utils/cloud-api.d.ts +2 -27
- package/dist/utils/cloud-api.d.ts.map +1 -1
- package/dist/utils/cloud-api.js +33 -0
- package/dist/utils/cloud-api.js.map +10 -0
- package/dist/utils/cloud-sdk/client.d.ts +133 -0
- package/dist/utils/cloud-sdk/client.d.ts.map +1 -0
- package/dist/utils/cloud-sdk/client.js +3561 -0
- package/dist/utils/cloud-sdk/client.js.map +13 -0
- package/dist/utils/cloud-sdk/http.d.ts +37 -0
- package/dist/utils/cloud-sdk/http.d.ts.map +1 -0
- package/dist/utils/cloud-sdk/http.js +237 -0
- package/dist/utils/cloud-sdk/http.js.map +11 -0
- package/dist/utils/cloud-sdk/index.d.ts +6 -0
- package/dist/utils/cloud-sdk/index.d.ts.map +1 -0
- package/dist/utils/cloud-sdk/index.js +29 -0
- package/dist/utils/cloud-sdk/index.js.map +9 -0
- package/dist/utils/cloud-sdk/public-routes.d.ts +5377 -0
- package/dist/utils/cloud-sdk/public-routes.d.ts.map +1 -0
- package/dist/utils/cloud-sdk/public-routes.js +2950 -0
- package/dist/utils/cloud-sdk/public-routes.js.map +10 -0
- package/dist/utils/cloud-sdk/types.cloud-api.d.ts +101 -0
- package/dist/utils/cloud-sdk/types.cloud-api.d.ts.map +1 -0
- package/dist/utils/cloud-sdk/types.cloud-api.js +2 -0
- package/dist/utils/cloud-sdk/types.cloud-api.js.map +9 -0
- package/dist/utils/cloud-sdk/types.d.ts +655 -0
- package/dist/utils/cloud-sdk/types.d.ts.map +1 -0
- package/dist/utils/cloud-sdk/types.js +29 -0
- package/dist/utils/cloud-sdk/types.js.map +10 -0
- package/dist/utils/config.d.ts +7 -3
- package/dist/utils/config.d.ts.map +1 -1
- package/dist/utils/config.js +137 -0
- package/dist/utils/config.js.map +10 -0
- package/dist/utils/events.d.ts.map +1 -1
- package/dist/utils/events.js +43 -0
- package/dist/utils/events.js.map +10 -0
- package/dist/utils/helpers.d.ts.map +1 -1
- package/dist/utils/helpers.js +103 -0
- package/dist/utils/helpers.js.map +10 -0
- package/dist/utils/responses-output.d.ts +13 -0
- package/dist/utils/responses-output.d.ts.map +1 -0
- package/dist/utils/responses-output.js +102 -0
- package/dist/utils/responses-output.js.map +10 -0
- package/dist/utils/sdk-client.d.ts +5 -0
- package/dist/utils/sdk-client.d.ts.map +1 -0
- package/dist/utils/sdk-client.js +144 -0
- package/dist/utils/sdk-client.js.map +11 -0
- package/package.json +108 -19
- package/src/cloud/auth.ts +175 -0
- package/src/cloud/backup.ts +46 -0
- package/src/cloud/base-url.ts +62 -0
- package/src/cloud/bridge-client.ts +602 -0
- package/src/cloud/cloud-api-key.ts +80 -0
- package/src/cloud/cloud-manager.ts +163 -0
- package/src/cloud/cloud-proxy.ts +52 -0
- package/src/cloud/cloud-wallet.ts +341 -0
- package/src/cloud/index.ts +28 -0
- package/src/cloud/reconnect.ts +111 -0
- package/src/cloud/validate-url.ts +181 -0
- package/src/cloud-providers/cloud-status.ts +75 -0
- package/src/cloud-providers/container-health.ts +68 -0
- package/src/cloud-providers/credit-balance.ts +70 -0
- package/src/cloud-providers/index.ts +3 -0
- package/src/cloud-providers/model-registry.ts +74 -0
- package/src/index.browser.ts +10 -0
- package/src/index.node.ts +39 -0
- package/src/index.ts +347 -0
- package/src/init.ts +39 -0
- package/src/lib/cloud-connection.ts +663 -0
- package/src/lib/cloud-secrets.ts +58 -0
- package/src/lib/config-env.ts +168 -0
- package/src/lib/config-like.ts +149 -0
- package/src/lib/credential-type-map.ts +130 -0
- package/src/lib/feature-flags.ts +26 -0
- package/src/lib/http.ts +139 -0
- package/src/lib/server-cloud-tts.ts +609 -0
- package/src/lib/state-paths.ts +28 -0
- package/src/lib/tts-debug.ts +34 -0
- package/src/models/embeddings.ts +234 -0
- package/src/models/image.ts +219 -0
- package/src/models/index.ts +16 -0
- package/src/models/research.ts +265 -0
- package/src/models/speech.ts +78 -0
- package/src/models/text.ts +899 -0
- package/src/models/tokenization.ts +67 -0
- package/src/models/transcription.ts +97 -0
- package/src/onboarding.ts +396 -0
- package/src/plugin.ts +243 -0
- package/src/providers/openai.ts +16 -0
- package/src/register-routes.ts +6 -0
- package/src/routes/cloud-billing-routes.ts +754 -0
- package/src/routes/cloud-compat-routes.ts +314 -0
- package/src/routes/cloud-features-routes.ts +57 -0
- package/src/routes/cloud-provisioning.ts +37 -0
- package/src/routes/cloud-relay-routes.ts +89 -0
- package/src/routes/cloud-routes-autonomous.ts +996 -0
- package/src/routes/cloud-routes.ts +576 -0
- package/src/routes/cloud-status-routes-autonomous.ts +234 -0
- package/src/routes/cloud-status-routes.ts +73 -0
- package/src/services/cloud-auth.ts +567 -0
- package/src/services/cloud-backup.ts +208 -0
- package/src/services/cloud-bootstrap.ts +108 -0
- package/src/services/cloud-bridge.ts +386 -0
- package/src/services/cloud-container.ts +297 -0
- package/src/services/cloud-credential-provider.ts +210 -0
- package/src/services/cloud-managed-gateway-relay.ts +663 -0
- package/src/services/cloud-model-registry.ts +202 -0
- package/src/services/index.ts +17 -0
- package/{types → src/types}/cloud.ts +52 -29
- package/{types → src/types}/index.ts +6 -0
- package/src/utils/cloud-api.ts +10 -0
- package/src/utils/cloud-sdk/client.ts +735 -0
- package/src/utils/cloud-sdk/http.ts +291 -0
- package/src/utils/cloud-sdk/index.ts +23 -0
- package/src/utils/cloud-sdk/public-routes.ts +5070 -0
- package/src/utils/cloud-sdk/types.cloud-api.ts +120 -0
- package/src/utils/cloud-sdk/types.ts +762 -0
- package/src/utils/config.ts +174 -0
- package/src/utils/events.ts +37 -0
- package/src/utils/helpers.ts +107 -0
- package/src/utils/responses-output.ts +115 -0
- package/src/utils/sdk-client.ts +37 -0
- package/dist/actions/check-credits.d.ts +0 -6
- package/dist/actions/check-credits.d.ts.map +0 -1
- package/dist/actions/freeze-agent.d.ts +0 -9
- package/dist/actions/freeze-agent.d.ts.map +0 -1
- package/dist/actions/index.d.ts +0 -5
- package/dist/actions/index.d.ts.map +0 -1
- package/dist/actions/provision-agent.d.ts +0 -8
- package/dist/actions/provision-agent.d.ts.map +0 -1
- package/dist/actions/resume-agent.d.ts +0 -9
- package/dist/actions/resume-agent.d.ts.map +0 -1
- package/dist/build.d.ts +0 -3
- package/dist/build.d.ts.map +0 -1
- package/dist/generated/specs/specs.d.ts +0 -55
- package/dist/generated/specs/specs.d.ts.map +0 -1
- package/dist/models/object.d.ts +0 -4
- package/dist/models/object.d.ts.map +0 -1
- package/dist/utils/forwarded-settings.d.ts +0 -8
- package/dist/utils/forwarded-settings.d.ts.map +0 -1
|
@@ -0,0 +1,883 @@
|
|
|
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
|
+
function isLoopbackHost(hostname) {
|
|
21
|
+
const normalized = hostname.toLowerCase();
|
|
22
|
+
return normalized === "localhost" || normalized === "::1" || normalized === "0:0:0:0:0:0:0:1" || normalized.startsWith("127.");
|
|
23
|
+
}
|
|
24
|
+
function trimApiPath(pathname) {
|
|
25
|
+
const normalized = pathname.trim().replace(/\/+$/, "");
|
|
26
|
+
if (!normalized)
|
|
27
|
+
return "";
|
|
28
|
+
if (normalized === "/api/v1")
|
|
29
|
+
return "";
|
|
30
|
+
if (normalized.endsWith("/api/v1")) {
|
|
31
|
+
return normalized.slice(0, -"/api/v1".length);
|
|
32
|
+
}
|
|
33
|
+
return normalized;
|
|
34
|
+
}
|
|
35
|
+
function normalizeCloudSiteUrl(rawUrl) {
|
|
36
|
+
const envOverride = process.env.ELIZAOS_CLOUD_BASE_URL?.trim();
|
|
37
|
+
const candidate = envOverride || rawUrl?.trim() || DEFAULT_CLOUD_SITE_URL;
|
|
38
|
+
try {
|
|
39
|
+
const parsed = new URL(candidate);
|
|
40
|
+
const pathname = trimApiPath(parsed.pathname);
|
|
41
|
+
const host = parsed.hostname.toLowerCase();
|
|
42
|
+
const preserveLocalOrigin = isLoopbackHost(host);
|
|
43
|
+
parsed.hash = "";
|
|
44
|
+
parsed.search = "";
|
|
45
|
+
if (!preserveLocalOrigin) {
|
|
46
|
+
parsed.protocol = "https:";
|
|
47
|
+
parsed.port = "";
|
|
48
|
+
}
|
|
49
|
+
parsed.pathname = pathname;
|
|
50
|
+
if (LEGACY_CLOUD_HOST_ALIASES.has(host)) {
|
|
51
|
+
parsed.hostname = "www.elizacloud.ai";
|
|
52
|
+
parsed.pathname = "";
|
|
53
|
+
}
|
|
54
|
+
return parsed.toString().replace(/\/{1,1024}$/, "");
|
|
55
|
+
} catch {
|
|
56
|
+
const safeCandidate = candidate.length > 8192 ? candidate.slice(0, 8192) : candidate;
|
|
57
|
+
return safeCandidate.replace(/\/{1,1024}$/, "");
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
function resolveCloudApiBaseUrl(rawUrl) {
|
|
61
|
+
return `${normalizeCloudSiteUrl(rawUrl)}/api/v1`;
|
|
62
|
+
}
|
|
63
|
+
var DEFAULT_CLOUD_SITE_URL = "https://www.elizacloud.ai", LEGACY_CLOUD_HOST_ALIASES;
|
|
64
|
+
var init_base_url = __esm(() => {
|
|
65
|
+
LEGACY_CLOUD_HOST_ALIASES = new Set([
|
|
66
|
+
"elizacloud.ai",
|
|
67
|
+
"www.elizacloud.ai"
|
|
68
|
+
]);
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
// src/cloud/validate-url.ts
|
|
72
|
+
import dns from "node:dns";
|
|
73
|
+
import net from "node:net";
|
|
74
|
+
import { promisify } from "node:util";
|
|
75
|
+
function normalizeHostLike(value) {
|
|
76
|
+
return value.trim().toLowerCase().replace(/^\[|\]$/g, "");
|
|
77
|
+
}
|
|
78
|
+
function decodeIpv6MappedHex(mapped) {
|
|
79
|
+
const parts = mapped.split(":");
|
|
80
|
+
if (parts.length < 1 || parts.length > 2)
|
|
81
|
+
return null;
|
|
82
|
+
const parsed = parts.map((part) => {
|
|
83
|
+
if (!/^[0-9a-f]{1,4}$/i.test(part))
|
|
84
|
+
return Number.NaN;
|
|
85
|
+
return Number.parseInt(part, 16);
|
|
86
|
+
});
|
|
87
|
+
if (parsed.some((value) => !Number.isFinite(value)))
|
|
88
|
+
return null;
|
|
89
|
+
const [hi, lo] = parsed.length === 1 ? [0, parsed[0]] : parsed;
|
|
90
|
+
const octets = [hi >> 8, hi & 255, lo >> 8, lo & 255];
|
|
91
|
+
return octets.join(".");
|
|
92
|
+
}
|
|
93
|
+
function canonicalizeIpv6(ip) {
|
|
94
|
+
try {
|
|
95
|
+
return new URL(`http://[${ip}]/`).hostname.replace(/^\[|\]$/g, "");
|
|
96
|
+
} catch {
|
|
97
|
+
return null;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
function normalizeIpForPolicy(ip) {
|
|
101
|
+
const base = normalizeHostLike(ip).split("%")[0];
|
|
102
|
+
if (!base)
|
|
103
|
+
return base;
|
|
104
|
+
let normalized = base;
|
|
105
|
+
if (net.isIP(normalized) === 6) {
|
|
106
|
+
normalized = canonicalizeIpv6(normalized) ?? normalized;
|
|
107
|
+
}
|
|
108
|
+
let mapped = null;
|
|
109
|
+
if (normalized.startsWith("::ffff:")) {
|
|
110
|
+
mapped = normalized.slice("::ffff:".length);
|
|
111
|
+
} else if (normalized.startsWith("0:0:0:0:0:ffff:")) {
|
|
112
|
+
mapped = normalized.slice("0:0:0:0:0:ffff:".length);
|
|
113
|
+
}
|
|
114
|
+
if (!mapped)
|
|
115
|
+
return normalized;
|
|
116
|
+
if (net.isIP(mapped) === 4)
|
|
117
|
+
return mapped;
|
|
118
|
+
return decodeIpv6MappedHex(mapped) ?? normalized;
|
|
119
|
+
}
|
|
120
|
+
function cidrV4(base, prefix) {
|
|
121
|
+
const parsed = parseIpv4ToInt(base);
|
|
122
|
+
if (parsed === null) {
|
|
123
|
+
throw new Error(`Invalid CIDR base IPv4 address: ${base}`);
|
|
124
|
+
}
|
|
125
|
+
const shift = 32 - prefix;
|
|
126
|
+
const mask = shift === 32 ? 0 : 4294967295 << shift >>> 0;
|
|
127
|
+
return { base: parsed & mask, mask };
|
|
128
|
+
}
|
|
129
|
+
function parseIpv4ToInt(ip) {
|
|
130
|
+
const parts = ip.split(".");
|
|
131
|
+
if (parts.length !== 4)
|
|
132
|
+
return null;
|
|
133
|
+
let value = 0;
|
|
134
|
+
for (const part of parts) {
|
|
135
|
+
if (!/^\d{1,3}$/.test(part))
|
|
136
|
+
return null;
|
|
137
|
+
const octet = Number.parseInt(part, 10);
|
|
138
|
+
if (!Number.isInteger(octet) || octet < 0 || octet > 255)
|
|
139
|
+
return null;
|
|
140
|
+
value = value << 8 | octet;
|
|
141
|
+
}
|
|
142
|
+
return value >>> 0;
|
|
143
|
+
}
|
|
144
|
+
function isBlockedIpv4(ip) {
|
|
145
|
+
const asInt = parseIpv4ToInt(ip);
|
|
146
|
+
if (asInt === null)
|
|
147
|
+
return true;
|
|
148
|
+
return BLOCKED_IPV4_CIDRS.some((cidr) => (asInt & cidr.mask) === cidr.base);
|
|
149
|
+
}
|
|
150
|
+
function isBlockedIpv6(ip) {
|
|
151
|
+
const normalized = ip.toLowerCase();
|
|
152
|
+
return normalized === "::" || normalized === "::1" || /^fe[89ab][0-9a-f]:/.test(normalized) || /^f[cd][0-9a-f]{2}:/i.test(normalized) || normalized.startsWith("ff");
|
|
153
|
+
}
|
|
154
|
+
function isBlockedIp(ip) {
|
|
155
|
+
const normalized = normalizeIpForPolicy(ip);
|
|
156
|
+
const family = net.isIP(normalized);
|
|
157
|
+
if (family === 4)
|
|
158
|
+
return isBlockedIpv4(normalized);
|
|
159
|
+
if (family === 6)
|
|
160
|
+
return isBlockedIpv6(normalized);
|
|
161
|
+
return false;
|
|
162
|
+
}
|
|
163
|
+
async function validateCloudBaseUrl(rawUrl) {
|
|
164
|
+
let parsed;
|
|
165
|
+
try {
|
|
166
|
+
parsed = new URL(rawUrl);
|
|
167
|
+
} catch {
|
|
168
|
+
return `Invalid cloud base URL: "${rawUrl}"`;
|
|
169
|
+
}
|
|
170
|
+
if (parsed.protocol !== "https:") {
|
|
171
|
+
return `Cloud base URL must use HTTPS, got "${parsed.protocol}" in "${rawUrl}"`;
|
|
172
|
+
}
|
|
173
|
+
const hostname = normalizeHostLike(parsed.hostname);
|
|
174
|
+
if (!hostname) {
|
|
175
|
+
return `Invalid cloud base URL: "${rawUrl}"`;
|
|
176
|
+
}
|
|
177
|
+
if (hostname === "localhost" || hostname.endsWith(".localhost") || hostname.endsWith(".local")) {
|
|
178
|
+
return `Cloud base URL "${rawUrl}" points to a blocked local hostname.`;
|
|
179
|
+
}
|
|
180
|
+
if (true) {
|
|
181
|
+
return null;
|
|
182
|
+
}
|
|
183
|
+
if (isBlockedIp(hostname)) {
|
|
184
|
+
return `Cloud base URL "${rawUrl}" points to a blocked address.`;
|
|
185
|
+
}
|
|
186
|
+
try {
|
|
187
|
+
const results = await dnsLookupAll(hostname, { all: true });
|
|
188
|
+
const addresses = Array.isArray(results) ? results : [results];
|
|
189
|
+
for (const entry of addresses) {
|
|
190
|
+
const ip = typeof entry === "string" ? entry : entry.address;
|
|
191
|
+
if (isBlockedIp(ip)) {
|
|
192
|
+
return `Cloud base URL "${rawUrl}" resolves to ${ip}, ` + "which is a blocked internal/metadata address.";
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
} catch {
|
|
196
|
+
return `Cloud base URL "${rawUrl}" could not be resolved via DNS.`;
|
|
197
|
+
}
|
|
198
|
+
return null;
|
|
199
|
+
}
|
|
200
|
+
var dnsLookupAll, BLOCKED_IPV4_CIDRS;
|
|
201
|
+
var init_validate_url = __esm(() => {
|
|
202
|
+
dnsLookupAll = promisify(dns.lookup);
|
|
203
|
+
BLOCKED_IPV4_CIDRS = [
|
|
204
|
+
cidrV4("0.0.0.0", 8),
|
|
205
|
+
cidrV4("10.0.0.0", 8),
|
|
206
|
+
cidrV4("172.16.0.0", 12),
|
|
207
|
+
cidrV4("192.168.0.0", 16),
|
|
208
|
+
cidrV4("100.64.0.0", 10),
|
|
209
|
+
cidrV4("127.0.0.0", 8),
|
|
210
|
+
cidrV4("169.254.0.0", 16),
|
|
211
|
+
cidrV4("192.0.0.0", 24),
|
|
212
|
+
cidrV4("198.18.0.0", 15),
|
|
213
|
+
cidrV4("192.0.2.0", 24),
|
|
214
|
+
cidrV4("198.51.100.0", 24),
|
|
215
|
+
cidrV4("203.0.113.0", 24),
|
|
216
|
+
cidrV4("224.0.0.0", 4),
|
|
217
|
+
cidrV4("240.0.0.0", 4)
|
|
218
|
+
];
|
|
219
|
+
});
|
|
220
|
+
|
|
221
|
+
// src/cloud/auth.ts
|
|
222
|
+
init_base_url();
|
|
223
|
+
init_validate_url();
|
|
224
|
+
import crypto2 from "node:crypto";
|
|
225
|
+
import { logger } from "@elizaos/core";
|
|
226
|
+
var DEFAULT_CLOUD_REQUEST_TIMEOUT_MS = 1e4;
|
|
227
|
+
function isRedirectResponse(response) {
|
|
228
|
+
return response.status >= 300 && response.status < 400;
|
|
229
|
+
}
|
|
230
|
+
function isTimeoutError(err) {
|
|
231
|
+
if (!(err instanceof Error))
|
|
232
|
+
return false;
|
|
233
|
+
if (err.name === "TimeoutError" || err.name === "AbortError")
|
|
234
|
+
return true;
|
|
235
|
+
const msg = err.message.toLowerCase();
|
|
236
|
+
return msg.includes("timed out") || msg.includes("timeout");
|
|
237
|
+
}
|
|
238
|
+
async function fetchWithTimeout(input, init, timeoutMs) {
|
|
239
|
+
return fetch(input, {
|
|
240
|
+
...init,
|
|
241
|
+
redirect: "manual",
|
|
242
|
+
signal: AbortSignal.timeout(timeoutMs)
|
|
243
|
+
});
|
|
244
|
+
}
|
|
245
|
+
async function cloudLogin(options = {}) {
|
|
246
|
+
const baseUrl = normalizeCloudSiteUrl(options.baseUrl);
|
|
247
|
+
const urlError = await validateCloudBaseUrl(baseUrl);
|
|
248
|
+
if (urlError) {
|
|
249
|
+
throw new Error(urlError);
|
|
250
|
+
}
|
|
251
|
+
const timeoutMs = options.timeoutMs ?? 300000;
|
|
252
|
+
const requestTimeoutMs = options.requestTimeoutMs ?? DEFAULT_CLOUD_REQUEST_TIMEOUT_MS;
|
|
253
|
+
const pollIntervalMs = options.pollIntervalMs ?? 2000;
|
|
254
|
+
const sessionId = crypto2.randomUUID();
|
|
255
|
+
logger.info("[cloud-auth] Creating auth session...");
|
|
256
|
+
let createResponse;
|
|
257
|
+
try {
|
|
258
|
+
createResponse = await fetchWithTimeout(`${baseUrl}/api/auth/cli-session`, {
|
|
259
|
+
method: "POST",
|
|
260
|
+
headers: { "Content-Type": "application/json" },
|
|
261
|
+
body: JSON.stringify({ sessionId })
|
|
262
|
+
}, requestTimeoutMs);
|
|
263
|
+
} catch (err) {
|
|
264
|
+
if (isTimeoutError(err)) {
|
|
265
|
+
throw new Error(`Cloud login request timed out while creating session (>${requestTimeoutMs}ms).`);
|
|
266
|
+
}
|
|
267
|
+
throw new Error(`Failed to create auth session: ${String(err)}`);
|
|
268
|
+
}
|
|
269
|
+
if (!createResponse.ok) {
|
|
270
|
+
if (isRedirectResponse(createResponse)) {
|
|
271
|
+
throw new Error("Cloud login request was redirected; redirects are not allowed.");
|
|
272
|
+
}
|
|
273
|
+
const errorText = await createResponse.text();
|
|
274
|
+
throw new Error(`Failed to create auth session (HTTP ${createResponse.status}): ${errorText}`);
|
|
275
|
+
}
|
|
276
|
+
const browserUrl = `${baseUrl}/auth/cli-login?session=${encodeURIComponent(sessionId)}`;
|
|
277
|
+
logger.info(`[cloud-auth] Browser URL: ${browserUrl}`);
|
|
278
|
+
options.onBrowserUrl?.(browserUrl);
|
|
279
|
+
const deadline = Date.now() + timeoutMs;
|
|
280
|
+
while (Date.now() < deadline) {
|
|
281
|
+
const remainingBeforeSleep = deadline - Date.now();
|
|
282
|
+
if (remainingBeforeSleep <= 0)
|
|
283
|
+
break;
|
|
284
|
+
await new Promise((resolve) => setTimeout(resolve, Math.min(pollIntervalMs, remainingBeforeSleep)));
|
|
285
|
+
const remaining = deadline - Date.now();
|
|
286
|
+
if (remaining <= 0)
|
|
287
|
+
break;
|
|
288
|
+
let pollResponse;
|
|
289
|
+
try {
|
|
290
|
+
pollResponse = await fetchWithTimeout(`${baseUrl}/api/auth/cli-session/${encodeURIComponent(sessionId)}`, {}, Math.min(requestTimeoutMs, remaining));
|
|
291
|
+
} catch (err) {
|
|
292
|
+
if (isTimeoutError(err)) {
|
|
293
|
+
if (remaining <= requestTimeoutMs) {
|
|
294
|
+
break;
|
|
295
|
+
}
|
|
296
|
+
throw new Error(`Cloud login polling request timed out (>${Math.min(requestTimeoutMs, remaining)}ms).`);
|
|
297
|
+
}
|
|
298
|
+
throw new Error(`Cloud login polling failed: ${String(err)}`);
|
|
299
|
+
}
|
|
300
|
+
if (!pollResponse.ok) {
|
|
301
|
+
if (isRedirectResponse(pollResponse)) {
|
|
302
|
+
throw new Error("Cloud login polling request was redirected; redirects are not allowed.");
|
|
303
|
+
}
|
|
304
|
+
if (pollResponse.status === 404) {
|
|
305
|
+
throw new Error("Auth session expired or not found. Please try again.");
|
|
306
|
+
}
|
|
307
|
+
options.onPollStatus?.("error");
|
|
308
|
+
continue;
|
|
309
|
+
}
|
|
310
|
+
const data = await pollResponse.json();
|
|
311
|
+
options.onPollStatus?.(data.status);
|
|
312
|
+
if (data.status === "authenticated" && data.apiKey) {
|
|
313
|
+
logger.info("[cloud-auth] Authentication complete");
|
|
314
|
+
return {
|
|
315
|
+
apiKey: data.apiKey,
|
|
316
|
+
keyPrefix: data.keyPrefix ?? "",
|
|
317
|
+
expiresAt: data.expiresAt ?? null
|
|
318
|
+
};
|
|
319
|
+
}
|
|
320
|
+
if (data.status === "authenticated" && !data.apiKey) {
|
|
321
|
+
throw new Error("Auth session was completed but the API key was already retrieved. Please try logging in again.");
|
|
322
|
+
}
|
|
323
|
+
}
|
|
324
|
+
throw new Error(`Cloud login timed out. The browser login was not completed within ${Math.round(timeoutMs / 1000)} seconds.`);
|
|
325
|
+
}
|
|
326
|
+
|
|
327
|
+
// src/cloud/bridge-client.ts
|
|
328
|
+
init_base_url();
|
|
329
|
+
|
|
330
|
+
class CloudBridgeError extends Error {
|
|
331
|
+
status;
|
|
332
|
+
body;
|
|
333
|
+
constructor(message, status, body) {
|
|
334
|
+
super(message);
|
|
335
|
+
this.status = status;
|
|
336
|
+
this.body = body;
|
|
337
|
+
this.name = "CloudBridgeError";
|
|
338
|
+
}
|
|
339
|
+
}
|
|
340
|
+
|
|
341
|
+
class SignatureInvalidError extends CloudBridgeError {
|
|
342
|
+
constructor(message, body) {
|
|
343
|
+
super(message, 401, body);
|
|
344
|
+
this.name = "SignatureInvalidError";
|
|
345
|
+
}
|
|
346
|
+
}
|
|
347
|
+
|
|
348
|
+
class NonceReplayError extends CloudBridgeError {
|
|
349
|
+
constructor(message, body) {
|
|
350
|
+
super(message, 409, body);
|
|
351
|
+
this.name = "NonceReplayError";
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
|
|
355
|
+
class SessionExpiredError extends CloudBridgeError {
|
|
356
|
+
constructor(message, body) {
|
|
357
|
+
super(message, 410, body);
|
|
358
|
+
this.name = "SessionExpiredError";
|
|
359
|
+
}
|
|
360
|
+
}
|
|
361
|
+
|
|
362
|
+
class CloudUnavailableError extends CloudBridgeError {
|
|
363
|
+
constructor(message, status, body) {
|
|
364
|
+
super(message, status, body);
|
|
365
|
+
this.name = "CloudUnavailableError";
|
|
366
|
+
}
|
|
367
|
+
}
|
|
368
|
+
function formatApiErrorBody(text) {
|
|
369
|
+
if (!text)
|
|
370
|
+
return null;
|
|
371
|
+
try {
|
|
372
|
+
const parsed = JSON.parse(text);
|
|
373
|
+
const baseError = typeof parsed.error === "string" && parsed.error.trim().length > 0 ? parsed.error.trim() : null;
|
|
374
|
+
const details = Array.isArray(parsed.details) ? parsed.details.map((detail) => typeof detail?.message === "string" ? detail.message.trim() : "").filter((message) => message.length > 0) : [];
|
|
375
|
+
if (baseError && details.length > 0) {
|
|
376
|
+
return `${baseError}: ${details.join("; ")}`;
|
|
377
|
+
}
|
|
378
|
+
if (baseError)
|
|
379
|
+
return baseError;
|
|
380
|
+
} catch {}
|
|
381
|
+
return text.slice(0, 200) || null;
|
|
382
|
+
}
|
|
383
|
+
function isRedirectResponse2(response) {
|
|
384
|
+
return response.status >= 300 && response.status < 400;
|
|
385
|
+
}
|
|
386
|
+
function normalizeChainAddress(addresses, chain) {
|
|
387
|
+
const value = addresses?.[chain];
|
|
388
|
+
if (typeof value !== "string")
|
|
389
|
+
return null;
|
|
390
|
+
const trimmed = value.trim();
|
|
391
|
+
return trimmed.length > 0 ? trimmed : null;
|
|
392
|
+
}
|
|
393
|
+
function looksLikeChainAddress(address, chain) {
|
|
394
|
+
if (chain === "evm") {
|
|
395
|
+
return /^0x[a-fA-F0-9]{40}$/.test(address);
|
|
396
|
+
}
|
|
397
|
+
return /^[1-9A-HJ-NP-Za-km-z]{32,44}$/.test(address);
|
|
398
|
+
}
|
|
399
|
+
function resolveRequestedWalletAddress(data, chain) {
|
|
400
|
+
const explicit = normalizeChainAddress(data.walletAddresses, chain);
|
|
401
|
+
if (explicit)
|
|
402
|
+
return explicit;
|
|
403
|
+
if (typeof data.walletAddress !== "string")
|
|
404
|
+
return null;
|
|
405
|
+
const trimmed = data.walletAddress.trim();
|
|
406
|
+
if (!trimmed)
|
|
407
|
+
return null;
|
|
408
|
+
return looksLikeChainAddress(trimmed, chain) ? trimmed : null;
|
|
409
|
+
}
|
|
410
|
+
|
|
411
|
+
class ElizaCloudClient {
|
|
412
|
+
baseUrl;
|
|
413
|
+
apiKey;
|
|
414
|
+
constructor(baseUrl, apiKey) {
|
|
415
|
+
this.baseUrl = normalizeCloudSiteUrl(baseUrl);
|
|
416
|
+
this.apiKey = apiKey;
|
|
417
|
+
}
|
|
418
|
+
async listAgents() {
|
|
419
|
+
const res = await this.request("GET", "/api/v1/eliza/agents");
|
|
420
|
+
return res.data ?? [];
|
|
421
|
+
}
|
|
422
|
+
async createAgent(params) {
|
|
423
|
+
const res = await this.request("POST", "/api/v1/eliza/agents", params);
|
|
424
|
+
if (!res.success || !res.data)
|
|
425
|
+
throw new Error(res.error ?? "Failed to create cloud agent");
|
|
426
|
+
return res.data;
|
|
427
|
+
}
|
|
428
|
+
async getAgent(agentId) {
|
|
429
|
+
const res = await this.request("GET", `/api/v1/eliza/agents/${agentId}`);
|
|
430
|
+
if (!res.success || !res.data)
|
|
431
|
+
throw new Error(res.error ?? "Agent not found");
|
|
432
|
+
return res.data;
|
|
433
|
+
}
|
|
434
|
+
async deleteAgent(agentId) {
|
|
435
|
+
const res = await this.request("DELETE", `/api/v1/eliza/agents/${agentId}`);
|
|
436
|
+
if (!res.success)
|
|
437
|
+
throw new Error(res.error ?? "Failed to delete agent");
|
|
438
|
+
}
|
|
439
|
+
async provision(agentId) {
|
|
440
|
+
const res = await this.request("POST", `/api/v1/eliza/agents/${agentId}/provision`);
|
|
441
|
+
if (!res.success || !res.data)
|
|
442
|
+
throw new Error(res.error ?? "Failed to provision sandbox");
|
|
443
|
+
return res.data;
|
|
444
|
+
}
|
|
445
|
+
async sendMessage(agentId, text, roomId = "web-chat", channelType = "DM") {
|
|
446
|
+
const url = `${this.baseUrl}/api/v1/eliza/agents/${agentId}/bridge`;
|
|
447
|
+
const response = await fetch(url, {
|
|
448
|
+
method: "POST",
|
|
449
|
+
headers: { "Content-Type": "application/json", "X-Api-Key": this.apiKey },
|
|
450
|
+
body: JSON.stringify({
|
|
451
|
+
jsonrpc: "2.0",
|
|
452
|
+
id: crypto.randomUUID(),
|
|
453
|
+
method: "message.send",
|
|
454
|
+
params: { text, roomId, channelType }
|
|
455
|
+
}),
|
|
456
|
+
redirect: "manual",
|
|
457
|
+
signal: AbortSignal.timeout(60000)
|
|
458
|
+
});
|
|
459
|
+
if (isRedirectResponse2(response)) {
|
|
460
|
+
throw new Error("Bridge request was redirected; redirects are not allowed");
|
|
461
|
+
}
|
|
462
|
+
if (!response.ok) {
|
|
463
|
+
const errorText = await response.text().catch(() => "");
|
|
464
|
+
throw new Error(`Bridge request failed: HTTP ${response.status} ${errorText.slice(0, 200)}`);
|
|
465
|
+
}
|
|
466
|
+
const rpc = await response.json();
|
|
467
|
+
if (rpc.error)
|
|
468
|
+
throw new Error(rpc.error.message);
|
|
469
|
+
return rpc.result?.text ?? "(no response)";
|
|
470
|
+
}
|
|
471
|
+
async* sendMessageStream(agentId, text, roomId = "web-chat", channelType = "DM") {
|
|
472
|
+
const url = `${this.baseUrl}/api/v1/eliza/agents/${agentId}/stream`;
|
|
473
|
+
const response = await fetch(url, {
|
|
474
|
+
method: "POST",
|
|
475
|
+
headers: { "Content-Type": "application/json", "X-Api-Key": this.apiKey },
|
|
476
|
+
body: JSON.stringify({
|
|
477
|
+
jsonrpc: "2.0",
|
|
478
|
+
id: crypto.randomUUID(),
|
|
479
|
+
method: "message.send",
|
|
480
|
+
params: { text, roomId, channelType }
|
|
481
|
+
}),
|
|
482
|
+
redirect: "manual"
|
|
483
|
+
});
|
|
484
|
+
if (isRedirectResponse2(response)) {
|
|
485
|
+
throw new Error("Stream request was redirected; redirects are not allowed");
|
|
486
|
+
}
|
|
487
|
+
if (!response.ok || !response.body) {
|
|
488
|
+
throw new Error(`Stream request failed: HTTP ${response.status}`);
|
|
489
|
+
}
|
|
490
|
+
const reader = response.body.getReader();
|
|
491
|
+
const decoder = new TextDecoder;
|
|
492
|
+
let buffer = "";
|
|
493
|
+
for (;; ) {
|
|
494
|
+
const { done, value } = await reader.read();
|
|
495
|
+
if (done)
|
|
496
|
+
break;
|
|
497
|
+
buffer += decoder.decode(value, { stream: true });
|
|
498
|
+
const parts = buffer.split(`
|
|
499
|
+
|
|
500
|
+
`);
|
|
501
|
+
buffer = parts.pop() ?? "";
|
|
502
|
+
for (const part of parts) {
|
|
503
|
+
if (!part.trim())
|
|
504
|
+
continue;
|
|
505
|
+
let eventType = "message";
|
|
506
|
+
let eventData = "";
|
|
507
|
+
for (const line of part.split(`
|
|
508
|
+
`)) {
|
|
509
|
+
if (line.startsWith("event: "))
|
|
510
|
+
eventType = line.slice(7).trim();
|
|
511
|
+
else if (line.startsWith("data: "))
|
|
512
|
+
eventData += (eventData ? `
|
|
513
|
+
` : "") + line.slice(6);
|
|
514
|
+
}
|
|
515
|
+
if (eventData) {
|
|
516
|
+
let data;
|
|
517
|
+
try {
|
|
518
|
+
data = JSON.parse(eventData);
|
|
519
|
+
} catch {
|
|
520
|
+
continue;
|
|
521
|
+
}
|
|
522
|
+
yield { type: eventType, data };
|
|
523
|
+
}
|
|
524
|
+
}
|
|
525
|
+
}
|
|
526
|
+
}
|
|
527
|
+
async snapshot(agentId) {
|
|
528
|
+
const res = await this.request("POST", `/api/v1/eliza/agents/${agentId}/snapshot`);
|
|
529
|
+
if (!res.success || !res.data)
|
|
530
|
+
throw new Error(res.error ?? "Snapshot failed");
|
|
531
|
+
return res.data;
|
|
532
|
+
}
|
|
533
|
+
async listBackups(agentId) {
|
|
534
|
+
const res = await this.request("GET", `/api/v1/eliza/agents/${agentId}/backups`);
|
|
535
|
+
return res.data ?? [];
|
|
536
|
+
}
|
|
537
|
+
async restore(agentId, backupId) {
|
|
538
|
+
const res = await this.request("POST", `/api/v1/eliza/agents/${agentId}/restore`, backupId ? { backupId } : {});
|
|
539
|
+
if (!res.success)
|
|
540
|
+
throw new Error(res.error ?? "Restore failed");
|
|
541
|
+
}
|
|
542
|
+
async heartbeat(agentId) {
|
|
543
|
+
const url = `${this.baseUrl}/api/v1/eliza/agents/${agentId}/bridge`;
|
|
544
|
+
try {
|
|
545
|
+
const response = await fetch(url, {
|
|
546
|
+
method: "POST",
|
|
547
|
+
headers: {
|
|
548
|
+
"Content-Type": "application/json",
|
|
549
|
+
"X-Api-Key": this.apiKey
|
|
550
|
+
},
|
|
551
|
+
body: JSON.stringify({ jsonrpc: "2.0", method: "heartbeat" }),
|
|
552
|
+
redirect: "manual",
|
|
553
|
+
signal: AbortSignal.timeout(1e4)
|
|
554
|
+
});
|
|
555
|
+
if (isRedirectResponse2(response))
|
|
556
|
+
return false;
|
|
557
|
+
return response.ok;
|
|
558
|
+
} catch {
|
|
559
|
+
return false;
|
|
560
|
+
}
|
|
561
|
+
}
|
|
562
|
+
async getAgentWallet(agentId, chain) {
|
|
563
|
+
const res = await this.request("GET", `/api/v1/eliza/agents/${encodeURIComponent(agentId)}/wallet?chain=${encodeURIComponent(chain)}`);
|
|
564
|
+
if (!res.success || !res.data) {
|
|
565
|
+
throw new CloudBridgeError(res.error ?? "Failed to fetch agent wallet");
|
|
566
|
+
}
|
|
567
|
+
const data = res.data;
|
|
568
|
+
const walletAddress = resolveRequestedWalletAddress(data, chain);
|
|
569
|
+
if (!walletAddress || !data.walletProvider) {
|
|
570
|
+
throw new CloudBridgeError(`Agent has no cloud ${chain} wallet provisioned`);
|
|
571
|
+
}
|
|
572
|
+
return {
|
|
573
|
+
agentWalletId: data.agentId ?? agentId,
|
|
574
|
+
walletAddress,
|
|
575
|
+
walletProvider: data.walletProvider,
|
|
576
|
+
chainType: chain,
|
|
577
|
+
balance: data.balance ?? undefined
|
|
578
|
+
};
|
|
579
|
+
}
|
|
580
|
+
async provisionWallet(input) {
|
|
581
|
+
const res = await this.request("POST", "/api/v1/user/wallets/provision", input);
|
|
582
|
+
if (!res.success || !res.data) {
|
|
583
|
+
throw new CloudBridgeError(res.error ?? "Failed to provision wallet");
|
|
584
|
+
}
|
|
585
|
+
return {
|
|
586
|
+
walletId: res.data.id,
|
|
587
|
+
address: res.data.address,
|
|
588
|
+
chainType: res.data.chainType,
|
|
589
|
+
provider: res.data.provider ?? "privy"
|
|
590
|
+
};
|
|
591
|
+
}
|
|
592
|
+
async executeRpc(envelope) {
|
|
593
|
+
const { correlationId, ...body } = envelope;
|
|
594
|
+
const headers = {
|
|
595
|
+
"Content-Type": "application/json"
|
|
596
|
+
};
|
|
597
|
+
if (correlationId) {
|
|
598
|
+
headers["X-Correlation-Id"] = correlationId;
|
|
599
|
+
}
|
|
600
|
+
let response;
|
|
601
|
+
try {
|
|
602
|
+
response = await fetch(`${this.baseUrl}/api/v1/user/wallets/rpc`, {
|
|
603
|
+
method: "POST",
|
|
604
|
+
headers,
|
|
605
|
+
body: JSON.stringify(body),
|
|
606
|
+
redirect: "manual",
|
|
607
|
+
signal: AbortSignal.timeout(60000)
|
|
608
|
+
});
|
|
609
|
+
} catch (err) {
|
|
610
|
+
throw new CloudUnavailableError(`Cloud RPC network error: ${err.message}`, 0);
|
|
611
|
+
}
|
|
612
|
+
if (isRedirectResponse2(response)) {
|
|
613
|
+
throw new CloudBridgeError("Cloud RPC request was redirected; redirects are not allowed", response.status);
|
|
614
|
+
}
|
|
615
|
+
const text = await response.text().catch(() => "");
|
|
616
|
+
if (response.ok) {
|
|
617
|
+
try {
|
|
618
|
+
const parsed = JSON.parse(text);
|
|
619
|
+
if (!parsed.success || parsed.data === undefined) {
|
|
620
|
+
throw new CloudBridgeError(parsed.error ?? "Cloud RPC returned no data", response.status, text);
|
|
621
|
+
}
|
|
622
|
+
return parsed.data;
|
|
623
|
+
} catch (err) {
|
|
624
|
+
if (err instanceof CloudBridgeError)
|
|
625
|
+
throw err;
|
|
626
|
+
throw new CloudBridgeError(`Cloud RPC returned malformed JSON: ${err.message}`, response.status, text);
|
|
627
|
+
}
|
|
628
|
+
}
|
|
629
|
+
let errMessage = `HTTP ${response.status}`;
|
|
630
|
+
try {
|
|
631
|
+
const parsed = JSON.parse(text);
|
|
632
|
+
if (parsed.error)
|
|
633
|
+
errMessage = parsed.error;
|
|
634
|
+
} catch {
|
|
635
|
+
if (text)
|
|
636
|
+
errMessage = text.slice(0, 200);
|
|
637
|
+
}
|
|
638
|
+
if (response.status === 401) {
|
|
639
|
+
throw new SignatureInvalidError(errMessage, text);
|
|
640
|
+
}
|
|
641
|
+
if (response.status === 409) {
|
|
642
|
+
throw new NonceReplayError(errMessage, text);
|
|
643
|
+
}
|
|
644
|
+
if (response.status === 410) {
|
|
645
|
+
throw new SessionExpiredError(errMessage, text);
|
|
646
|
+
}
|
|
647
|
+
if (response.status >= 500) {
|
|
648
|
+
throw new CloudUnavailableError(errMessage, response.status, text);
|
|
649
|
+
}
|
|
650
|
+
throw new CloudBridgeError(errMessage, response.status, text);
|
|
651
|
+
}
|
|
652
|
+
async request(method, path, body) {
|
|
653
|
+
const headers = { "X-Api-Key": this.apiKey };
|
|
654
|
+
if (body !== undefined)
|
|
655
|
+
headers["Content-Type"] = "application/json";
|
|
656
|
+
const response = await fetch(`${this.baseUrl}${path}`, {
|
|
657
|
+
method,
|
|
658
|
+
headers,
|
|
659
|
+
body: body !== undefined ? JSON.stringify(body) : undefined,
|
|
660
|
+
redirect: "manual",
|
|
661
|
+
signal: AbortSignal.timeout(30000)
|
|
662
|
+
});
|
|
663
|
+
if (isRedirectResponse2(response)) {
|
|
664
|
+
return {
|
|
665
|
+
success: false,
|
|
666
|
+
error: "Cloud API request was redirected; redirects are not allowed"
|
|
667
|
+
};
|
|
668
|
+
}
|
|
669
|
+
if (!response.ok) {
|
|
670
|
+
const text = await response.text().catch(() => "");
|
|
671
|
+
return {
|
|
672
|
+
success: false,
|
|
673
|
+
error: formatApiErrorBody(text) ?? `HTTP ${response.status}`
|
|
674
|
+
};
|
|
675
|
+
}
|
|
676
|
+
return await response.json();
|
|
677
|
+
}
|
|
678
|
+
}
|
|
679
|
+
|
|
680
|
+
// src/onboarding.ts
|
|
681
|
+
import { logger as logger2 } from "@elizaos/core";
|
|
682
|
+
init_base_url();
|
|
683
|
+
var DEFAULT_CLOUD_BASE_URL = "https://www.elizacloud.ai";
|
|
684
|
+
var PROVISION_TIMEOUT_MS = 120000;
|
|
685
|
+
var PROVISION_POLL_INTERVAL_MS = 3000;
|
|
686
|
+
async function checkCloudAvailability(baseUrl) {
|
|
687
|
+
try {
|
|
688
|
+
const url = `${normalizeCloudSiteUrl(baseUrl)}/api/compat/availability`;
|
|
689
|
+
const res = await fetch(url, {
|
|
690
|
+
method: "GET",
|
|
691
|
+
headers: { Accept: "application/json" },
|
|
692
|
+
signal: AbortSignal.timeout(1e4)
|
|
693
|
+
});
|
|
694
|
+
if (!res.ok) {
|
|
695
|
+
return `Cloud returned HTTP ${res.status}. It may be temporarily unavailable.`;
|
|
696
|
+
}
|
|
697
|
+
const body = await res.json();
|
|
698
|
+
if (!body.success || !body.data?.acceptingNewAgents) {
|
|
699
|
+
return "Eliza Cloud is currently at capacity. Try again later or run locally.";
|
|
700
|
+
}
|
|
701
|
+
return null;
|
|
702
|
+
} catch (err) {
|
|
703
|
+
const msg = String(err);
|
|
704
|
+
if (msg.includes("timed out") || msg.includes("timeout")) {
|
|
705
|
+
return "Could not reach Eliza Cloud (request timed out). Check your internet connection.";
|
|
706
|
+
}
|
|
707
|
+
return `Could not reach Eliza Cloud: ${msg}`;
|
|
708
|
+
}
|
|
709
|
+
}
|
|
710
|
+
async function runCloudAuth(clack, baseUrl) {
|
|
711
|
+
const spinner = clack.spinner();
|
|
712
|
+
spinner.start("Connecting to Eliza Cloud...");
|
|
713
|
+
try {
|
|
714
|
+
const result = await cloudLogin({
|
|
715
|
+
baseUrl,
|
|
716
|
+
timeoutMs: 300000,
|
|
717
|
+
onBrowserUrl: (url) => {
|
|
718
|
+
spinner.stop("Opening your browser to log in...");
|
|
719
|
+
clack.log.info(`If the browser didn't open, visit:
|
|
720
|
+
${url}`);
|
|
721
|
+
openBrowser(url).catch(() => {});
|
|
722
|
+
spinner.start("Waiting for login in browser...");
|
|
723
|
+
},
|
|
724
|
+
onPollStatus: (status) => {
|
|
725
|
+
if (status === "pending") {
|
|
726
|
+
spinner.message("Waiting for login in browser...");
|
|
727
|
+
}
|
|
728
|
+
}
|
|
729
|
+
});
|
|
730
|
+
spinner.stop("✓ Logged in to Eliza Cloud!");
|
|
731
|
+
return result;
|
|
732
|
+
} catch (err) {
|
|
733
|
+
const msg = String(err);
|
|
734
|
+
spinner.stop(`Login failed: ${msg}`);
|
|
735
|
+
return null;
|
|
736
|
+
}
|
|
737
|
+
}
|
|
738
|
+
async function provisionCloudAgent(clack, client, agentName, preset) {
|
|
739
|
+
const spinner = clack.spinner();
|
|
740
|
+
spinner.start("Creating your cloud agent...");
|
|
741
|
+
try {
|
|
742
|
+
const agentConfig = {};
|
|
743
|
+
if (preset) {
|
|
744
|
+
agentConfig.bio = preset.bio;
|
|
745
|
+
agentConfig.system = preset.system;
|
|
746
|
+
agentConfig.style = preset.style;
|
|
747
|
+
agentConfig.adjectives = preset.adjectives;
|
|
748
|
+
agentConfig.topics = preset.topics;
|
|
749
|
+
agentConfig.postExamples = preset.postExamples;
|
|
750
|
+
agentConfig.messageExamples = preset.messageExamples;
|
|
751
|
+
}
|
|
752
|
+
const params = {
|
|
753
|
+
agentName,
|
|
754
|
+
agentConfig
|
|
755
|
+
};
|
|
756
|
+
const agent = await client.createAgent(params);
|
|
757
|
+
const agentId = agent.id;
|
|
758
|
+
spinner.message("Agent created! Provisioning cloud environment...");
|
|
759
|
+
const deadline = Date.now() + PROVISION_TIMEOUT_MS;
|
|
760
|
+
let lastStatus = agent.status;
|
|
761
|
+
while (Date.now() < deadline) {
|
|
762
|
+
await sleep(PROVISION_POLL_INTERVAL_MS);
|
|
763
|
+
try {
|
|
764
|
+
const current = await client.getAgent(agentId);
|
|
765
|
+
lastStatus = current.status;
|
|
766
|
+
switch (lastStatus) {
|
|
767
|
+
case "running":
|
|
768
|
+
case "completed":
|
|
769
|
+
spinner.stop(`☁️ Cloud agent "${agentName}" is running!`);
|
|
770
|
+
return { agentId, bridgeUrl: current.bridgeUrl };
|
|
771
|
+
case "failed":
|
|
772
|
+
case "error":
|
|
773
|
+
spinner.stop(`Provisioning failed: ${current.errorMessage ?? "unknown error"}`);
|
|
774
|
+
return null;
|
|
775
|
+
case "queued":
|
|
776
|
+
spinner.message("Queued — waiting for available slot...");
|
|
777
|
+
break;
|
|
778
|
+
case "provisioning":
|
|
779
|
+
spinner.message("Provisioning cloud environment...");
|
|
780
|
+
break;
|
|
781
|
+
default:
|
|
782
|
+
spinner.message(`Status: ${lastStatus}...`);
|
|
783
|
+
}
|
|
784
|
+
} catch (pollErr) {
|
|
785
|
+
logger2.debug(`[cloud-onboarding] Poll error: ${String(pollErr)}`);
|
|
786
|
+
}
|
|
787
|
+
}
|
|
788
|
+
spinner.stop(`Provisioning timed out (last status: ${lastStatus}). The agent may still be starting up.`);
|
|
789
|
+
return { agentId };
|
|
790
|
+
} catch (err) {
|
|
791
|
+
const msg = String(err);
|
|
792
|
+
spinner.stop(`Failed to create cloud agent: ${msg}`);
|
|
793
|
+
return null;
|
|
794
|
+
}
|
|
795
|
+
}
|
|
796
|
+
async function runCloudOnboarding(clack, agentName, preset, baseUrl) {
|
|
797
|
+
const resolvedBaseUrl = normalizeCloudSiteUrl(baseUrl ?? DEFAULT_CLOUD_BASE_URL);
|
|
798
|
+
const unavailableReason = await checkCloudAvailability(resolvedBaseUrl);
|
|
799
|
+
if (unavailableReason) {
|
|
800
|
+
clack.log.warn(unavailableReason);
|
|
801
|
+
const fallback = await clack.confirm({
|
|
802
|
+
message: "Run locally instead?",
|
|
803
|
+
initialValue: true
|
|
804
|
+
});
|
|
805
|
+
if (clack.isCancel(fallback) || fallback) {
|
|
806
|
+
return null;
|
|
807
|
+
}
|
|
808
|
+
}
|
|
809
|
+
const authResult = await runCloudAuth(clack, resolvedBaseUrl);
|
|
810
|
+
if (!authResult) {
|
|
811
|
+
clack.log.warn("Cloud login was not completed.");
|
|
812
|
+
const retry = await clack.confirm({
|
|
813
|
+
message: "Try again, or run locally?",
|
|
814
|
+
active: "Try again",
|
|
815
|
+
inactive: "Run locally",
|
|
816
|
+
initialValue: false
|
|
817
|
+
});
|
|
818
|
+
if (clack.isCancel(retry) || !retry) {
|
|
819
|
+
return null;
|
|
820
|
+
}
|
|
821
|
+
const retryResult = await runCloudAuth(clack, resolvedBaseUrl);
|
|
822
|
+
if (!retryResult) {
|
|
823
|
+
clack.log.warn("Login was not completed. Falling back to local mode.");
|
|
824
|
+
return null;
|
|
825
|
+
}
|
|
826
|
+
return await finishProvisioning(clack, resolvedBaseUrl, retryResult, agentName, preset);
|
|
827
|
+
}
|
|
828
|
+
return await finishProvisioning(clack, resolvedBaseUrl, authResult, agentName, preset);
|
|
829
|
+
}
|
|
830
|
+
async function finishProvisioning(clack, baseUrl, authResult, agentName, preset) {
|
|
831
|
+
const client = new ElizaCloudClient(baseUrl, authResult.apiKey);
|
|
832
|
+
const provisionResult = await provisionCloudAgent(clack, client, agentName, preset);
|
|
833
|
+
if (!provisionResult) {
|
|
834
|
+
clack.log.warn("Cloud provisioning did not complete. You can try `eliza cloud connect` later.");
|
|
835
|
+
const runLocal = await clack.confirm({
|
|
836
|
+
message: "Continue with local setup instead?",
|
|
837
|
+
initialValue: true
|
|
838
|
+
});
|
|
839
|
+
if (clack.isCancel(runLocal) || runLocal) {
|
|
840
|
+
return null;
|
|
841
|
+
}
|
|
842
|
+
return {
|
|
843
|
+
apiKey: authResult.apiKey,
|
|
844
|
+
agentId: undefined,
|
|
845
|
+
baseUrl
|
|
846
|
+
};
|
|
847
|
+
}
|
|
848
|
+
return {
|
|
849
|
+
apiKey: authResult.apiKey,
|
|
850
|
+
agentId: provisionResult.agentId,
|
|
851
|
+
baseUrl,
|
|
852
|
+
bridgeUrl: provisionResult.bridgeUrl
|
|
853
|
+
};
|
|
854
|
+
}
|
|
855
|
+
function sleep(ms) {
|
|
856
|
+
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
857
|
+
}
|
|
858
|
+
async function openBrowser(url) {
|
|
859
|
+
const { execFile } = await import("node:child_process");
|
|
860
|
+
const { platform } = await import("node:os");
|
|
861
|
+
const p = platform();
|
|
862
|
+
return new Promise((resolve) => {
|
|
863
|
+
const onError = (err) => {
|
|
864
|
+
if (err) {
|
|
865
|
+
logger2.debug(`[cloud-onboarding] Failed to open browser: ${err.message}`);
|
|
866
|
+
}
|
|
867
|
+
resolve();
|
|
868
|
+
};
|
|
869
|
+
if (p === "darwin") {
|
|
870
|
+
execFile("open", [url], onError);
|
|
871
|
+
} else if (p === "win32") {
|
|
872
|
+
execFile("cmd.exe", ["/c", "start", "", url], onError);
|
|
873
|
+
} else {
|
|
874
|
+
execFile("xdg-open", [url], onError);
|
|
875
|
+
}
|
|
876
|
+
});
|
|
877
|
+
}
|
|
878
|
+
export {
|
|
879
|
+
runCloudOnboarding,
|
|
880
|
+
checkCloudAvailability
|
|
881
|
+
};
|
|
882
|
+
|
|
883
|
+
//# debugId=298D6EFBB02E82E964756E2164756E21
|