@elizaos/plugin-steward-app 2.0.3-beta.6 → 2.0.3-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.
- package/dist/ApprovalQueue.d.ts +18 -0
- package/dist/ApprovalQueue.d.ts.map +1 -0
- package/dist/ApprovalQueue.js +420 -0
- package/dist/ApprovalQueue.js.map +1 -0
- package/dist/StewardLogo.d.ts +11 -0
- package/dist/StewardLogo.d.ts.map +1 -0
- package/dist/StewardLogo.js +36 -0
- package/dist/StewardLogo.js.map +1 -0
- package/dist/StewardView.d.ts +13 -0
- package/dist/StewardView.d.ts.map +1 -0
- package/dist/StewardView.helpers.d.ts +15 -0
- package/dist/StewardView.helpers.d.ts.map +1 -0
- package/dist/StewardView.helpers.js +45 -0
- package/dist/StewardView.helpers.js.map +1 -0
- package/dist/StewardView.interact.d.ts +2 -0
- package/dist/StewardView.interact.d.ts.map +1 -0
- package/dist/StewardView.interact.js +54 -0
- package/dist/StewardView.interact.js.map +1 -0
- package/dist/StewardView.js +249 -0
- package/dist/StewardView.js.map +1 -0
- package/dist/TransactionHistory.d.ts +22 -0
- package/dist/TransactionHistory.d.ts.map +1 -0
- package/dist/TransactionHistory.js +361 -0
- package/dist/TransactionHistory.js.map +1 -0
- package/dist/__fixtures__/steward-sdk-fixtures.d.ts +10 -0
- package/dist/__fixtures__/steward-sdk-fixtures.d.ts.map +1 -0
- package/dist/__fixtures__/steward-sdk-fixtures.js +60 -0
- package/dist/__fixtures__/steward-sdk-fixtures.js.map +1 -0
- package/dist/actions/wallet-action-shared.d.ts +15 -0
- package/dist/actions/wallet-action-shared.d.ts.map +1 -0
- package/dist/actions/wallet-action-shared.js +16 -0
- package/dist/actions/wallet-action-shared.js.map +1 -0
- package/dist/api/binance-skill-helpers.d.ts +21 -0
- package/dist/api/binance-skill-helpers.d.ts.map +1 -0
- package/dist/api/binance-skill-helpers.js +790 -0
- package/dist/api/binance-skill-helpers.js.map +1 -0
- package/dist/api/bsc-trade.d.ts +36 -0
- package/dist/api/bsc-trade.d.ts.map +1 -0
- package/dist/api/bsc-trade.js +796 -0
- package/dist/api/bsc-trade.js.map +1 -0
- package/dist/api/trade-safety.d.ts +35 -0
- package/dist/api/trade-safety.d.ts.map +1 -0
- package/dist/api/trade-safety.js +56 -0
- package/dist/api/trade-safety.js.map +1 -0
- package/dist/api/tx-service.d.ts +53 -0
- package/dist/api/tx-service.d.ts.map +1 -0
- package/dist/api/tx-service.js +206 -0
- package/dist/api/tx-service.js.map +1 -0
- package/dist/api/wallet-bsc-routes.d.ts +63 -0
- package/dist/api/wallet-bsc-routes.d.ts.map +1 -0
- package/dist/api/wallet-bsc-routes.js +337 -0
- package/dist/api/wallet-bsc-routes.js.map +1 -0
- package/dist/api/wallet-capability.d.ts +2 -0
- package/dist/api/wallet-capability.d.ts.map +1 -0
- package/dist/api/wallet-capability.js +15 -0
- package/dist/api/wallet-capability.js.map +1 -0
- package/dist/api/wallet-dex-prices.d.ts +43 -0
- package/dist/api/wallet-dex-prices.d.ts.map +1 -0
- package/dist/api/wallet-dex-prices.js +132 -0
- package/dist/api/wallet-dex-prices.js.map +1 -0
- package/dist/api/wallet-evm-balance.d.ts +72 -0
- package/dist/api/wallet-evm-balance.d.ts.map +1 -0
- package/dist/api/wallet-evm-balance.js +697 -0
- package/dist/api/wallet-evm-balance.js.map +1 -0
- package/dist/api/wallet-routes.d.ts +27 -0
- package/dist/api/wallet-routes.d.ts.map +1 -0
- package/dist/api/wallet-routes.js +556 -0
- package/dist/api/wallet-routes.js.map +1 -0
- package/dist/api/wallet-rpc.d.ts +73 -0
- package/dist/api/wallet-rpc.d.ts.map +1 -0
- package/dist/api/wallet-rpc.js +460 -0
- package/dist/api/wallet-rpc.js.map +1 -0
- package/dist/api/wallet-trade-routes.d.ts +104 -0
- package/dist/api/wallet-trade-routes.d.ts.map +1 -0
- package/dist/api/wallet-trade-routes.js +353 -0
- package/dist/api/wallet-trade-routes.js.map +1 -0
- package/dist/api/wallet-trading-profile.d.ts +31 -0
- package/dist/api/wallet-trading-profile.d.ts.map +1 -0
- package/dist/api/wallet-trading-profile.js +500 -0
- package/dist/api/wallet-trading-profile.js.map +1 -0
- package/dist/api/wallet.d.ts +60 -0
- package/dist/api/wallet.d.ts.map +1 -0
- package/dist/api/wallet.js +617 -0
- package/dist/api/wallet.js.map +1 -0
- package/dist/chain-utils.d.ts +10 -0
- package/dist/chain-utils.d.ts.map +1 -0
- package/dist/chain-utils.js +81 -0
- package/dist/chain-utils.js.map +1 -0
- package/dist/components/StewardSpatialView.d.ts +74 -0
- package/dist/components/StewardSpatialView.d.ts.map +1 -0
- package/dist/components/StewardSpatialView.js +309 -0
- package/dist/components/StewardSpatialView.js.map +1 -0
- package/dist/index.d.ts +20 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +77 -0
- package/dist/index.js.map +1 -0
- package/dist/plugin.d.ts +21 -0
- package/dist/plugin.d.ts.map +1 -0
- package/dist/plugin.js +319 -0
- package/dist/plugin.js.map +1 -0
- package/dist/providers/steward-balance.d.ts +12 -0
- package/dist/providers/steward-balance.d.ts.map +1 -0
- package/dist/providers/steward-balance.js +85 -0
- package/dist/providers/steward-balance.js.map +1 -0
- package/dist/providers/steward-receive-address.d.ts +12 -0
- package/dist/providers/steward-receive-address.d.ts.map +1 -0
- package/dist/providers/steward-receive-address.js +47 -0
- package/dist/providers/steward-receive-address.js.map +1 -0
- package/dist/register-routes.d.ts +2 -0
- package/dist/register-routes.d.ts.map +1 -0
- package/dist/register-routes.js +6 -0
- package/dist/register-routes.js.map +1 -0
- package/dist/register-terminal-view.d.ts +15 -0
- package/dist/register-terminal-view.d.ts.map +1 -0
- package/dist/register-terminal-view.js +34 -0
- package/dist/register-terminal-view.js.map +1 -0
- package/dist/routes/steward-bridge.d.ts +202 -0
- package/dist/routes/steward-bridge.d.ts.map +1 -0
- package/dist/routes/steward-bridge.js +776 -0
- package/dist/routes/steward-bridge.js.map +1 -0
- package/dist/routes/steward-compat-routes.d.ts +21 -0
- package/dist/routes/steward-compat-routes.d.ts.map +1 -0
- package/dist/routes/steward-compat-routes.js +350 -0
- package/dist/routes/steward-compat-routes.js.map +1 -0
- package/dist/routes/wallet-browser-compat-routes.d.ts +6 -0
- package/dist/routes/wallet-browser-compat-routes.d.ts.map +1 -0
- package/dist/routes/wallet-browser-compat-routes.js +402 -0
- package/dist/routes/wallet-browser-compat-routes.js.map +1 -0
- package/dist/routes/wallet-bsc-core-routes.d.ts +15 -0
- package/dist/routes/wallet-bsc-core-routes.d.ts.map +1 -0
- package/dist/routes/wallet-bsc-core-routes.js +59 -0
- package/dist/routes/wallet-bsc-core-routes.js.map +1 -0
- package/dist/routes/wallet-compat-routes.d.ts +13 -0
- package/dist/routes/wallet-compat-routes.d.ts.map +1 -0
- package/dist/routes/wallet-compat-routes.js +206 -0
- package/dist/routes/wallet-compat-routes.js.map +1 -0
- package/dist/routes/wallet-core-routes.d.ts +16 -0
- package/dist/routes/wallet-core-routes.d.ts.map +1 -0
- package/dist/routes/wallet-core-routes.js +48 -0
- package/dist/routes/wallet-core-routes.js.map +1 -0
- package/dist/routes/wallet-trade-compat-routes.d.ts +11 -0
- package/dist/routes/wallet-trade-compat-routes.d.ts.map +1 -0
- package/dist/routes/wallet-trade-compat-routes.js +570 -0
- package/dist/routes/wallet-trade-compat-routes.js.map +1 -0
- package/dist/security/hydrate-wallet-keys-from-platform-store.d.ts +7 -0
- package/dist/security/hydrate-wallet-keys-from-platform-store.d.ts.map +1 -0
- package/dist/security/hydrate-wallet-keys-from-platform-store.js +43 -0
- package/dist/security/hydrate-wallet-keys-from-platform-store.js.map +1 -0
- package/dist/security/wallet-os-store-actions.d.ts +14 -0
- package/dist/security/wallet-os-store-actions.d.ts.map +1 -0
- package/dist/security/wallet-os-store-actions.js +63 -0
- package/dist/security/wallet-os-store-actions.js.map +1 -0
- package/dist/services/steward-credentials.d.ts +2 -0
- package/dist/services/steward-credentials.d.ts.map +1 -0
- package/dist/services/steward-credentials.js +2 -0
- package/dist/services/steward-credentials.js.map +1 -0
- package/dist/services/steward-evm-account.d.ts +75 -0
- package/dist/services/steward-evm-account.d.ts.map +1 -0
- package/dist/services/steward-evm-account.js +279 -0
- package/dist/services/steward-evm-account.js.map +1 -0
- package/dist/services/steward-evm-bridge.d.ts +36 -0
- package/dist/services/steward-evm-bridge.d.ts.map +1 -0
- package/dist/services/steward-evm-bridge.js +78 -0
- package/dist/services/steward-evm-bridge.js.map +1 -0
- package/dist/services/steward-sidecar/health-check.d.ts +2 -0
- package/dist/services/steward-sidecar/health-check.d.ts.map +1 -0
- package/dist/services/steward-sidecar/health-check.js +2 -0
- package/dist/services/steward-sidecar/health-check.js.map +1 -0
- package/dist/services/steward-sidecar/helpers.d.ts +2 -0
- package/dist/services/steward-sidecar/helpers.d.ts.map +1 -0
- package/dist/services/steward-sidecar/helpers.js +2 -0
- package/dist/services/steward-sidecar/helpers.js.map +1 -0
- package/dist/services/steward-sidecar/process-management.d.ts +2 -0
- package/dist/services/steward-sidecar/process-management.d.ts.map +1 -0
- package/dist/services/steward-sidecar/process-management.js +2 -0
- package/dist/services/steward-sidecar/process-management.js.map +1 -0
- package/dist/services/steward-sidecar/types.d.ts +2 -0
- package/dist/services/steward-sidecar/types.d.ts.map +1 -0
- package/dist/services/steward-sidecar/types.js +2 -0
- package/dist/services/steward-sidecar/types.js.map +1 -0
- package/dist/services/steward-sidecar/wallet-setup.d.ts +2 -0
- package/dist/services/steward-sidecar/wallet-setup.d.ts.map +1 -0
- package/dist/services/steward-sidecar/wallet-setup.js +2 -0
- package/dist/services/steward-sidecar/wallet-setup.js.map +1 -0
- package/dist/services/steward-sidecar.d.ts +2 -0
- package/dist/services/steward-sidecar.d.ts.map +1 -0
- package/dist/services/steward-sidecar.js +2 -0
- package/dist/services/steward-sidecar.js.map +1 -0
- package/dist/services/steward-wallet.d.ts +25 -0
- package/dist/services/steward-wallet.d.ts.map +1 -0
- package/dist/services/steward-wallet.js +333 -0
- package/dist/services/steward-wallet.js.map +1 -0
- package/dist/steward-ui-state.d.ts +14 -0
- package/dist/steward-ui-state.d.ts.map +1 -0
- package/dist/steward-ui-state.js +46 -0
- package/dist/steward-ui-state.js.map +1 -0
- package/dist/steward-view-bundle.d.ts +3 -0
- package/dist/steward-view-bundle.d.ts.map +1 -0
- package/dist/steward-view-bundle.js +7 -0
- package/dist/steward-view-bundle.js.map +1 -0
- package/dist/types/bsc-trade.d.ts +180 -0
- package/dist/types/bsc-trade.d.ts.map +1 -0
- package/dist/types/bsc-trade.js +1 -0
- package/dist/types/bsc-trade.js.map +1 -0
- package/dist/types/index.d.ts +3 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +3 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/steward.d.ts +83 -0
- package/dist/types/steward.d.ts.map +1 -0
- package/dist/types/steward.js +1 -0
- package/dist/types/steward.js.map +1 -0
- package/dist/ui.d.ts +7 -0
- package/dist/ui.d.ts.map +1 -0
- package/dist/ui.js +7 -0
- package/dist/ui.js.map +1 -0
- package/dist/views/bundle.js +601 -0
- package/dist/views/bundle.js.map +1 -0
- package/package.json +8 -8
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import {
|
|
2
|
+
buildAuthHeaders,
|
|
3
|
+
getWalletActionApiPort
|
|
4
|
+
} from "../actions/wallet-action-shared.js";
|
|
5
|
+
const ADDRESSES_TIMEOUT_MS = 1e4;
|
|
6
|
+
const stewardReceiveAddressProvider = {
|
|
7
|
+
name: "stewardReceiveAddress",
|
|
8
|
+
description: "Wallet receive addresses by chain (EVM, Solana). Read-only snapshot for the planner so it can surface a deposit address without invoking a mutating action.",
|
|
9
|
+
descriptionCompressed: "Wallet receive addresses by chain.",
|
|
10
|
+
dynamic: true,
|
|
11
|
+
contexts: ["finance", "wallet", "crypto"],
|
|
12
|
+
contextGate: { anyOf: ["finance", "wallet", "crypto"] },
|
|
13
|
+
cacheStable: false,
|
|
14
|
+
cacheScope: "turn",
|
|
15
|
+
get: async (_runtime, _message, _state) => {
|
|
16
|
+
try {
|
|
17
|
+
const response = await fetch(
|
|
18
|
+
`http://127.0.0.1:${getWalletActionApiPort()}/api/wallet/addresses`,
|
|
19
|
+
{
|
|
20
|
+
headers: { ...buildAuthHeaders() },
|
|
21
|
+
signal: AbortSignal.timeout(ADDRESSES_TIMEOUT_MS)
|
|
22
|
+
}
|
|
23
|
+
);
|
|
24
|
+
if (!response.ok) {
|
|
25
|
+
return { text: "" };
|
|
26
|
+
}
|
|
27
|
+
const addresses = await response.json();
|
|
28
|
+
const snapshot = {
|
|
29
|
+
evm: addresses.evmAddress,
|
|
30
|
+
solana: addresses.solanaAddress
|
|
31
|
+
};
|
|
32
|
+
if (!snapshot.evm && !snapshot.solana) {
|
|
33
|
+
return { text: "" };
|
|
34
|
+
}
|
|
35
|
+
return {
|
|
36
|
+
text: JSON.stringify({ steward_receive_address: snapshot }),
|
|
37
|
+
data: { snapshot }
|
|
38
|
+
};
|
|
39
|
+
} catch {
|
|
40
|
+
return { text: "", data: { snapshot: null } };
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
export {
|
|
45
|
+
stewardReceiveAddressProvider
|
|
46
|
+
};
|
|
47
|
+
//# sourceMappingURL=steward-receive-address.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/providers/steward-receive-address.ts"],"sourcesContent":["/**\n * stewardReceiveAddress provider — wallet receive addresses for the planner.\n *\n * Replaces the legacy GET_RECEIVE_ADDRESS action. Fetches\n * `/api/wallet/addresses` and renders a JSON-encoded summary so the LLM can\n * surface the user's deposit address without invoking a mutating action.\n *\n * @module providers/steward-receive-address\n */\n\nimport type {\n IAgentRuntime,\n Memory,\n Provider,\n ProviderResult,\n State,\n WalletAddresses,\n} from \"@elizaos/core\";\nimport {\n buildAuthHeaders,\n getWalletActionApiPort,\n} from \"../actions/wallet-action-shared.js\";\n\n/** Timeout for the addresses API call. */\nconst ADDRESSES_TIMEOUT_MS = 10_000;\n\ninterface ReceiveAddressSnapshot {\n evm: string | null;\n solana: string | null;\n}\n\nexport const stewardReceiveAddressProvider: Provider = {\n name: \"stewardReceiveAddress\",\n\n description:\n \"Wallet receive addresses by chain (EVM, Solana). Read-only snapshot for \" +\n \"the planner so it can surface a deposit address without invoking a \" +\n \"mutating action.\",\n descriptionCompressed: \"Wallet receive addresses by chain.\",\n\n dynamic: true,\n contexts: [\"finance\", \"wallet\", \"crypto\"],\n contextGate: { anyOf: [\"finance\", \"wallet\", \"crypto\"] },\n cacheStable: false,\n cacheScope: \"turn\",\n\n get: async (\n _runtime: IAgentRuntime,\n _message: Memory,\n _state: State,\n ): Promise<ProviderResult> => {\n try {\n const response = await fetch(\n `http://127.0.0.1:${getWalletActionApiPort()}/api/wallet/addresses`,\n {\n headers: { ...buildAuthHeaders() },\n signal: AbortSignal.timeout(ADDRESSES_TIMEOUT_MS),\n },\n );\n\n if (!response.ok) {\n return { text: \"\" };\n }\n\n const addresses = (await response.json()) as WalletAddresses;\n const snapshot: ReceiveAddressSnapshot = {\n evm: addresses.evmAddress,\n solana: addresses.solanaAddress,\n };\n\n if (!snapshot.evm && !snapshot.solana) {\n return { text: \"\" };\n }\n\n return {\n text: JSON.stringify({ steward_receive_address: snapshot }),\n data: { snapshot },\n };\n } catch {\n return { text: \"\", data: { snapshot: null } };\n }\n },\n};\n"],"mappings":"AAkBA;AAAA,EACE;AAAA,EACA;AAAA,OACK;AAGP,MAAM,uBAAuB;AAOtB,MAAM,gCAA0C;AAAA,EACrD,MAAM;AAAA,EAEN,aACE;AAAA,EAGF,uBAAuB;AAAA,EAEvB,SAAS;AAAA,EACT,UAAU,CAAC,WAAW,UAAU,QAAQ;AAAA,EACxC,aAAa,EAAE,OAAO,CAAC,WAAW,UAAU,QAAQ,EAAE;AAAA,EACtD,aAAa;AAAA,EACb,YAAY;AAAA,EAEZ,KAAK,OACH,UACA,UACA,WAC4B;AAC5B,QAAI;AACF,YAAM,WAAW,MAAM;AAAA,QACrB,oBAAoB,uBAAuB,CAAC;AAAA,QAC5C;AAAA,UACE,SAAS,EAAE,GAAG,iBAAiB,EAAE;AAAA,UACjC,QAAQ,YAAY,QAAQ,oBAAoB;AAAA,QAClD;AAAA,MACF;AAEA,UAAI,CAAC,SAAS,IAAI;AAChB,eAAO,EAAE,MAAM,GAAG;AAAA,MACpB;AAEA,YAAM,YAAa,MAAM,SAAS,KAAK;AACvC,YAAM,WAAmC;AAAA,QACvC,KAAK,UAAU;AAAA,QACf,QAAQ,UAAU;AAAA,MACpB;AAEA,UAAI,CAAC,SAAS,OAAO,CAAC,SAAS,QAAQ;AACrC,eAAO,EAAE,MAAM,GAAG;AAAA,MACpB;AAEA,aAAO;AAAA,QACL,MAAM,KAAK,UAAU,EAAE,yBAAyB,SAAS,CAAC;AAAA,QAC1D,MAAM,EAAE,SAAS;AAAA,MACnB;AAAA,IACF,QAAQ;AACN,aAAO,EAAE,MAAM,IAAI,MAAM,EAAE,UAAU,KAAK,EAAE;AAAA,IAC9C;AAAA,EACF;AACF;","names":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"register-routes.d.ts","sourceRoot":"","sources":["../src/register-routes.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { registerAppRoutePluginLoader } from "@elizaos/core";
|
|
2
|
+
registerAppRoutePluginLoader("@elizaos/plugin-steward-app", async () => {
|
|
3
|
+
const { stewardPlugin } = await import("./plugin.js");
|
|
4
|
+
return stewardPlugin;
|
|
5
|
+
});
|
|
6
|
+
//# sourceMappingURL=register-routes.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/register-routes.ts"],"sourcesContent":["import { registerAppRoutePluginLoader } from \"@elizaos/core\";\n\nregisterAppRoutePluginLoader(\"@elizaos/plugin-steward-app\", async () => {\n const { stewardPlugin } = await import(\"./plugin.js\");\n return stewardPlugin;\n});\n"],"mappings":"AAAA,SAAS,oCAAoC;AAE7C,6BAA6B,+BAA+B,YAAY;AACtE,QAAM,EAAE,cAAc,IAAI,MAAM,OAAO,aAAa;AACpD,SAAO;AACT,CAAC;","names":[]}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Register the Steward view for terminal rendering.
|
|
3
|
+
*
|
|
4
|
+
* The agent terminal mounts plugin views by id from the `@elizaos/tui` terminal
|
|
5
|
+
* registry. This makes Steward's `viewType: "tui"` declaration render for real
|
|
6
|
+
* in the terminal (the unified {@link StewardSpatialView}) rather than only
|
|
7
|
+
* navigating a GUI shell. A module-level snapshot lets a host push live vault
|
|
8
|
+
* data; with no Steward bridge configured it defaults to a disconnected panel.
|
|
9
|
+
*/
|
|
10
|
+
import { type StewardSnapshot } from "./components/StewardSpatialView.js";
|
|
11
|
+
/** Update the snapshot the registered terminal view renders from. */
|
|
12
|
+
export declare function setStewardTerminalSnapshot(next: StewardSnapshot): void;
|
|
13
|
+
/** Register the Steward terminal view; returns an unregister function. */
|
|
14
|
+
export declare function registerStewardTerminalView(): () => void;
|
|
15
|
+
//# sourceMappingURL=register-terminal-view.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"register-terminal-view.d.ts","sourceRoot":"","sources":["../src/register-terminal-view.tsx"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAIH,OAAO,EACL,KAAK,eAAe,EAErB,MAAM,qCAAqC,CAAC;AAmB7C,qEAAqE;AACrE,wBAAgB,0BAA0B,CAAC,IAAI,EAAE,eAAe,GAAG,IAAI,CAEtE;AAED,0EAA0E;AAC1E,wBAAgB,2BAA2B,IAAI,MAAM,IAAI,CAIxD"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { registerSpatialTerminalView } from "@elizaos/ui/spatial/tui";
|
|
2
|
+
import { createElement } from "react";
|
|
3
|
+
import {
|
|
4
|
+
StewardSpatialView
|
|
5
|
+
} from "./components/StewardSpatialView.js";
|
|
6
|
+
const EMPTY = {
|
|
7
|
+
tab: "approvals",
|
|
8
|
+
connected: false,
|
|
9
|
+
configured: false,
|
|
10
|
+
available: false,
|
|
11
|
+
evmAddress: null,
|
|
12
|
+
pendingApprovals: [],
|
|
13
|
+
history: [],
|
|
14
|
+
historyTotal: 0,
|
|
15
|
+
statusFilter: null,
|
|
16
|
+
chainFilter: null,
|
|
17
|
+
page: 0,
|
|
18
|
+
pageSize: 25
|
|
19
|
+
};
|
|
20
|
+
let current = EMPTY;
|
|
21
|
+
function setStewardTerminalSnapshot(next) {
|
|
22
|
+
current = next;
|
|
23
|
+
}
|
|
24
|
+
function registerStewardTerminalView() {
|
|
25
|
+
return registerSpatialTerminalView(
|
|
26
|
+
"steward",
|
|
27
|
+
() => createElement(StewardSpatialView, { snapshot: current })
|
|
28
|
+
);
|
|
29
|
+
}
|
|
30
|
+
export {
|
|
31
|
+
registerStewardTerminalView,
|
|
32
|
+
setStewardTerminalSnapshot
|
|
33
|
+
};
|
|
34
|
+
//# sourceMappingURL=register-terminal-view.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/register-terminal-view.tsx"],"sourcesContent":["/**\n * Register the Steward view for terminal rendering.\n *\n * The agent terminal mounts plugin views by id from the `@elizaos/tui` terminal\n * registry. This makes Steward's `viewType: \"tui\"` declaration render for real\n * in the terminal (the unified {@link StewardSpatialView}) rather than only\n * navigating a GUI shell. A module-level snapshot lets a host push live vault\n * data; with no Steward bridge configured it defaults to a disconnected panel.\n */\n\nimport { registerSpatialTerminalView } from \"@elizaos/ui/spatial/tui\";\nimport { createElement } from \"react\";\nimport {\n type StewardSnapshot,\n StewardSpatialView,\n} from \"./components/StewardSpatialView.js\";\n\nconst EMPTY: StewardSnapshot = {\n tab: \"approvals\",\n connected: false,\n configured: false,\n available: false,\n evmAddress: null,\n pendingApprovals: [],\n history: [],\n historyTotal: 0,\n statusFilter: null,\n chainFilter: null,\n page: 0,\n pageSize: 25,\n};\n\nlet current: StewardSnapshot = EMPTY;\n\n/** Update the snapshot the registered terminal view renders from. */\nexport function setStewardTerminalSnapshot(next: StewardSnapshot): void {\n current = next;\n}\n\n/** Register the Steward terminal view; returns an unregister function. */\nexport function registerStewardTerminalView(): () => void {\n return registerSpatialTerminalView(\"steward\", () =>\n createElement(StewardSpatialView, { snapshot: current }),\n );\n}\n"],"mappings":"AAUA,SAAS,mCAAmC;AAC5C,SAAS,qBAAqB;AAC9B;AAAA,EAEE;AAAA,OACK;AAEP,MAAM,QAAyB;AAAA,EAC7B,KAAK;AAAA,EACL,WAAW;AAAA,EACX,YAAY;AAAA,EACZ,WAAW;AAAA,EACX,YAAY;AAAA,EACZ,kBAAkB,CAAC;AAAA,EACnB,SAAS,CAAC;AAAA,EACV,cAAc;AAAA,EACd,cAAc;AAAA,EACd,aAAa;AAAA,EACb,MAAM;AAAA,EACN,UAAU;AACZ;AAEA,IAAI,UAA2B;AAGxB,SAAS,2BAA2B,MAA6B;AACtE,YAAU;AACZ;AAGO,SAAS,8BAA0C;AACxD,SAAO;AAAA,IAA4B;AAAA,IAAW,MAC5C,cAAc,oBAAoB,EAAE,UAAU,QAAQ,CAAC;AAAA,EACzD;AACF;","names":[]}
|
|
@@ -0,0 +1,202 @@
|
|
|
1
|
+
import { type PolicyResult, type PolicyRule, type SignTransactionInput, StewardClient, type TxRecord } from "@stwd/sdk";
|
|
2
|
+
import type { StewardSignRequest, StewardSignResponse } from "../types/steward.js";
|
|
3
|
+
export interface StewardBridgeOptions {
|
|
4
|
+
env?: NodeJS.ProcessEnv;
|
|
5
|
+
evmAddress?: string | null;
|
|
6
|
+
agentId?: string | null;
|
|
7
|
+
client?: StewardClient | null;
|
|
8
|
+
}
|
|
9
|
+
export interface StewardBridgeStatus {
|
|
10
|
+
configured: boolean;
|
|
11
|
+
available: boolean;
|
|
12
|
+
connected: boolean;
|
|
13
|
+
baseUrl: string | null;
|
|
14
|
+
agentId: string | null;
|
|
15
|
+
evmAddress: string | null;
|
|
16
|
+
error: string | null;
|
|
17
|
+
walletAddresses?: {
|
|
18
|
+
evm: string | null;
|
|
19
|
+
solana: string | null;
|
|
20
|
+
};
|
|
21
|
+
agentName?: string;
|
|
22
|
+
vaultHealth?: "ok" | "degraded" | "error";
|
|
23
|
+
}
|
|
24
|
+
export interface StewardPendingApprovalResult {
|
|
25
|
+
mode: "steward";
|
|
26
|
+
pendingApproval: true;
|
|
27
|
+
policyResults: PolicyResult[];
|
|
28
|
+
}
|
|
29
|
+
export interface StewardSignedTransactionResult {
|
|
30
|
+
mode: "steward";
|
|
31
|
+
pendingApproval: false;
|
|
32
|
+
txHash: string;
|
|
33
|
+
}
|
|
34
|
+
export type StewardExecutionResult = StewardPendingApprovalResult | StewardSignedTransactionResult;
|
|
35
|
+
export declare function resolveStewardAgentId(env?: NodeJS.ProcessEnv, evmAddress?: string | null): string | null;
|
|
36
|
+
export declare function createStewardClient(options?: StewardBridgeOptions): StewardClient | null;
|
|
37
|
+
export declare function getStewardBridgeStatus(options?: StewardBridgeOptions): Promise<StewardBridgeStatus>;
|
|
38
|
+
/** Check if Steward env vars are configured (synchronous, no network). */
|
|
39
|
+
export declare function isStewardConfigured(env?: NodeJS.ProcessEnv): boolean;
|
|
40
|
+
export declare function formatStewardError(error: unknown): string;
|
|
41
|
+
export declare function signTransactionWithOptionalSteward(params: {
|
|
42
|
+
tx: SignTransactionInput;
|
|
43
|
+
env?: NodeJS.ProcessEnv;
|
|
44
|
+
evmAddress?: string | null;
|
|
45
|
+
agentId?: string | null;
|
|
46
|
+
client?: StewardClient | null;
|
|
47
|
+
}): Promise<StewardExecutionResult>;
|
|
48
|
+
export interface StewardWalletAddresses {
|
|
49
|
+
evmAddress: string | null;
|
|
50
|
+
solanaAddress: string | null;
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Fetch steward-managed wallet addresses for the configured agent.
|
|
54
|
+
* Calls `GET /agents/:agentId` and extracts `walletAddresses.evm` / `walletAddresses.solana`.
|
|
55
|
+
* Falls back to the flat `walletAddress` field if the extended shape is missing.
|
|
56
|
+
*/
|
|
57
|
+
export declare function getStewardWalletAddresses(options?: StewardBridgeOptions): Promise<StewardWalletAddresses>;
|
|
58
|
+
export interface StewardBalanceResult {
|
|
59
|
+
balance: string;
|
|
60
|
+
formatted: string;
|
|
61
|
+
symbol: string;
|
|
62
|
+
chainId: number;
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Fetch the native balance for a steward-managed agent wallet.
|
|
66
|
+
* Uses the SDK's `getBalance()` when available.
|
|
67
|
+
*/
|
|
68
|
+
export declare function getStewardBalance(agentId: string, chainId?: number, options?: StewardBridgeOptions): Promise<StewardBalanceResult>;
|
|
69
|
+
export interface StewardTokenBalancesResult {
|
|
70
|
+
native: {
|
|
71
|
+
balance: string;
|
|
72
|
+
formatted: string;
|
|
73
|
+
symbol: string;
|
|
74
|
+
chainId: number;
|
|
75
|
+
};
|
|
76
|
+
tokens: Array<{
|
|
77
|
+
address: string;
|
|
78
|
+
symbol: string;
|
|
79
|
+
name: string;
|
|
80
|
+
balance: string;
|
|
81
|
+
formatted: string;
|
|
82
|
+
decimals: number;
|
|
83
|
+
valueUsd?: string;
|
|
84
|
+
logoUrl?: string;
|
|
85
|
+
}>;
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Fetch token balances for a steward-managed agent wallet.
|
|
89
|
+
* The SDK doesn't expose a token-list endpoint, so this uses a direct
|
|
90
|
+
* fetch to `GET /agents/:agentId/tokens?chainId=X`.
|
|
91
|
+
*/
|
|
92
|
+
export declare function getStewardTokenBalances(agentId: string, chainId?: number, options?: StewardBridgeOptions): Promise<StewardTokenBalancesResult>;
|
|
93
|
+
/**
|
|
94
|
+
* Build auth headers for direct steward API calls.
|
|
95
|
+
* Used by direct REST adapters for pending, approve, and deny endpoints.
|
|
96
|
+
*/
|
|
97
|
+
export declare function buildStewardHeaders(env?: NodeJS.ProcessEnv): Headers;
|
|
98
|
+
export interface StewardPendingEntry {
|
|
99
|
+
queueId: string;
|
|
100
|
+
status: string;
|
|
101
|
+
requestedAt: string;
|
|
102
|
+
transaction: TxRecord;
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* Fetch pending approval queue from steward.
|
|
106
|
+
* Returns empty array if the endpoint is not available (404).
|
|
107
|
+
*/
|
|
108
|
+
export declare function getStewardPendingApprovals(agentId: string, env?: NodeJS.ProcessEnv): Promise<StewardPendingEntry[]>;
|
|
109
|
+
/**
|
|
110
|
+
* Approve a pending transaction on steward.
|
|
111
|
+
*/
|
|
112
|
+
export declare function approveStewardTransaction(agentId: string, txId: string, env?: NodeJS.ProcessEnv): Promise<{
|
|
113
|
+
txId: string;
|
|
114
|
+
txHash?: string;
|
|
115
|
+
}>;
|
|
116
|
+
/**
|
|
117
|
+
* Deny/reject a pending transaction on steward.
|
|
118
|
+
* Uses POST /vault/:agentId/reject/:txId
|
|
119
|
+
*/
|
|
120
|
+
export declare function denyStewardTransaction(agentId: string, txId: string, reason?: string, env?: NodeJS.ProcessEnv): Promise<{
|
|
121
|
+
txId: string;
|
|
122
|
+
}>;
|
|
123
|
+
/**
|
|
124
|
+
* Fetch transaction history from steward.
|
|
125
|
+
* Uses GET /vault/:agentId/history for full transaction records.
|
|
126
|
+
*/
|
|
127
|
+
export declare function getStewardHistory(agentId: string, opts?: {
|
|
128
|
+
limit?: number;
|
|
129
|
+
offset?: number;
|
|
130
|
+
}, env?: NodeJS.ProcessEnv): Promise<TxRecord[]>;
|
|
131
|
+
/**
|
|
132
|
+
* Provision a steward wallet for a new agent.
|
|
133
|
+
* Creates the agent identity + wallet on steward, optionally with default policies.
|
|
134
|
+
*/
|
|
135
|
+
export declare function provisionStewardWallet(params: {
|
|
136
|
+
agentId: string;
|
|
137
|
+
agentName: string;
|
|
138
|
+
platformId?: string;
|
|
139
|
+
defaultPolicies?: PolicyRule[];
|
|
140
|
+
env?: NodeJS.ProcessEnv;
|
|
141
|
+
}): Promise<{
|
|
142
|
+
walletAddress: string;
|
|
143
|
+
}>;
|
|
144
|
+
/**
|
|
145
|
+
* Sign (and optionally broadcast) a transaction through the Steward vault.
|
|
146
|
+
*
|
|
147
|
+
* This calls `POST /vault/:agentId/sign` directly. The three possible outcomes
|
|
148
|
+
* are mapped to a combined {@link StewardSignResponse}:
|
|
149
|
+
*
|
|
150
|
+
* - **Approved** (HTTP 200): `{ approved: true, txHash }`.
|
|
151
|
+
* - **Pending approval** (HTTP 202): `{ approved: false, pending: true, txId }`.
|
|
152
|
+
* - **Denied** (HTTP 403): `{ approved: false, denied: true, violations }`.
|
|
153
|
+
*/
|
|
154
|
+
export declare function signViaSteward(request: StewardSignRequest, env?: NodeJS.ProcessEnv): Promise<StewardSignResponse>;
|
|
155
|
+
export type StewardWebhookEventType = "tx.pending" | "tx.approved" | "tx.denied" | "tx.confirmed";
|
|
156
|
+
export interface StewardWebhookEvent {
|
|
157
|
+
event: StewardWebhookEventType;
|
|
158
|
+
data: Record<string, unknown>;
|
|
159
|
+
timestamp?: string;
|
|
160
|
+
}
|
|
161
|
+
/** Push a webhook event into the in-memory buffer. */
|
|
162
|
+
export declare function pushWebhookEvent(event: StewardWebhookEvent): void;
|
|
163
|
+
/** Read recent webhook events, optionally filtered by event type. */
|
|
164
|
+
export declare function getRecentWebhookEvents(eventType?: StewardWebhookEventType, sinceIndex?: number): {
|
|
165
|
+
events: StewardWebhookEvent[];
|
|
166
|
+
nextIndex: number;
|
|
167
|
+
};
|
|
168
|
+
/**
|
|
169
|
+
* Register a webhook URL with steward so it pushes tx events to the app.
|
|
170
|
+
* Calls PUT /tenants/:tenantId with { webhookUrl }.
|
|
171
|
+
*/
|
|
172
|
+
export declare function registerStewardWebhook(webhookUrl: string, env?: NodeJS.ProcessEnv): Promise<void>;
|
|
173
|
+
/**
|
|
174
|
+
* Attempt to register the local webhook endpoint with steward.
|
|
175
|
+
* Logs but does not throw on failure (best-effort).
|
|
176
|
+
*/
|
|
177
|
+
export declare function tryRegisterStewardWebhook(port?: number, env?: NodeJS.ProcessEnv): Promise<void>;
|
|
178
|
+
export interface EnsureStewardAgentResult {
|
|
179
|
+
agentId: string;
|
|
180
|
+
agentName: string;
|
|
181
|
+
walletAddresses: {
|
|
182
|
+
evm: string | null;
|
|
183
|
+
solana: string | null;
|
|
184
|
+
};
|
|
185
|
+
created: boolean;
|
|
186
|
+
}
|
|
187
|
+
/**
|
|
188
|
+
* Ensure the configured steward agent exists. If it doesn't, create it.
|
|
189
|
+
*
|
|
190
|
+
* This is a lazy-init function — call it on first request to steward-status,
|
|
191
|
+
* not on server startup. It's idempotent and will only run once per process.
|
|
192
|
+
*
|
|
193
|
+
* If steward setup fails, logs a warning and returns null (does not throw).
|
|
194
|
+
*/
|
|
195
|
+
export declare function ensureStewardAgent(options?: {
|
|
196
|
+
agentId?: string;
|
|
197
|
+
agentName?: string;
|
|
198
|
+
env?: NodeJS.ProcessEnv;
|
|
199
|
+
}): Promise<EnsureStewardAgentResult | null>;
|
|
200
|
+
/** Reset the ensured flag (for testing). */
|
|
201
|
+
export declare function __resetStewardAgentEnsured(): void;
|
|
202
|
+
//# sourceMappingURL=steward-bridge.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"steward-bridge.d.ts","sourceRoot":"","sources":["../../src/routes/steward-bridge.ts"],"names":[],"mappings":"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"}
|