@elizaos/plugin-wallet 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 +64 -0
- package/auto-enable.ts +76 -0
- package/dist/LpManagementService-BWrQ5-cO.mjs +353 -0
- package/dist/MockLpService-D_Apn4Fd.mjs +99 -0
- package/dist/aerodrome-CfnESC32.mjs +890 -0
- package/dist/chunk-hT5z_Zn9.mjs +35 -0
- package/dist/index.d.mts +34727 -0
- package/dist/index.mjs +21590 -0
- package/dist/lib/server-wallet-trade.d.mts +34 -0
- package/dist/lib/server-wallet-trade.mjs +306 -0
- package/dist/meteora-BPX39hZo.mjs +22640 -0
- package/dist/orca-Bybp1HXO.mjs +249 -0
- package/dist/pancakeswp-CkEXlXti.mjs +604 -0
- package/dist/plugin-ZO_MTyd0.mjs +529 -0
- package/dist/raydium-rfaM9yEf.mjs +539 -0
- package/dist/sdk/index.d.mts +32492 -0
- package/dist/sdk/index.mjs +6415 -0
- package/dist/types-D5252NZk.mjs +487 -0
- package/dist/uniswap-CReXgXVN.mjs +573 -0
- package/dist/wallet-action.d.mts +6 -0
- package/dist/wallet-action.mjs +820 -0
- package/package.json +152 -0
- package/src/actions/failure-codes.ts +79 -0
- package/src/actions/index.ts +1 -0
- package/src/analytics/birdeye/actions/wallet-search-address.ts +9 -0
- package/src/analytics/birdeye/birdeye-task.ts +175 -0
- package/src/analytics/birdeye/birdeye.ts +813 -0
- package/src/analytics/birdeye/constants.ts +74 -0
- package/src/analytics/birdeye/providers/agent-portfolio-provider.ts +18 -0
- package/src/analytics/birdeye/providers/market.ts +227 -0
- package/src/analytics/birdeye/providers/portfolio-factory.test.ts +138 -0
- package/src/analytics/birdeye/providers/portfolio-factory.ts +252 -0
- package/src/analytics/birdeye/providers/trending.ts +365 -0
- package/src/analytics/birdeye/providers/wallet.ts +14 -0
- package/src/analytics/birdeye/search-category.test.ts +207 -0
- package/src/analytics/birdeye/search-category.ts +506 -0
- package/src/analytics/birdeye/service.ts +992 -0
- package/src/analytics/birdeye/tasks/birdeye.ts +232 -0
- package/src/analytics/birdeye/types/api/common.ts +305 -0
- package/src/analytics/birdeye/types/api/defi.ts +220 -0
- package/src/analytics/birdeye/types/api/pair.ts +200 -0
- package/src/analytics/birdeye/types/api/search.ts +86 -0
- package/src/analytics/birdeye/types/api/token.ts +635 -0
- package/src/analytics/birdeye/types/api/trader.ts +76 -0
- package/src/analytics/birdeye/types/api/wallet.ts +181 -0
- package/src/analytics/birdeye/types/shared.ts +106 -0
- package/src/analytics/birdeye/utils.ts +700 -0
- package/src/analytics/dexscreener/errors.ts +28 -0
- package/src/analytics/dexscreener/index.ts +3 -0
- package/src/analytics/dexscreener/search-category.test.ts +49 -0
- package/src/analytics/dexscreener/search-category.ts +42 -0
- package/src/analytics/dexscreener/service.ts +595 -0
- package/src/analytics/dexscreener/types.ts +128 -0
- package/src/analytics/lpinfo/index.d.ts +7 -0
- package/src/analytics/lpinfo/index.ts +52 -0
- package/src/analytics/lpinfo/kamino/README.md +102 -0
- package/src/analytics/lpinfo/kamino/index.ts +24 -0
- package/src/analytics/lpinfo/kamino/providers/kaminoLiquidityProvider.ts +422 -0
- package/src/analytics/lpinfo/kamino/providers/kaminoPoolProvider.ts +365 -0
- package/src/analytics/lpinfo/kamino/providers/kaminoProvider.ts +496 -0
- package/src/analytics/lpinfo/kamino/services/kaminoLiquidityService.ts +1123 -0
- package/src/analytics/lpinfo/kamino/services/kaminoService.ts +758 -0
- package/src/analytics/lpinfo/steer/README.md +169 -0
- package/src/analytics/lpinfo/steer/index.ts +23 -0
- package/src/analytics/lpinfo/steer/providers/steerLiquidityProvider.ts +544 -0
- package/src/analytics/lpinfo/steer/services/steerLiquidityService.ts +1690 -0
- package/src/analytics/lpinfo/steer/steer-display-types.ts +99 -0
- package/src/analytics/news/index.ts +52 -0
- package/src/analytics/news/interfaces/types.ts +222 -0
- package/src/analytics/news/providers/defiNewsProvider.ts +734 -0
- package/src/analytics/news/services/newsDataService.ts +332 -0
- package/src/analytics/news/utils/formatters.ts +151 -0
- package/src/analytics/token-info/action.ts +240 -0
- package/src/analytics/token-info/index.ts +3 -0
- package/src/analytics/token-info/params.ts +215 -0
- package/src/analytics/token-info/providers.ts +681 -0
- package/src/analytics/token-info/service.ts +168 -0
- package/src/analytics/token-info/types.ts +74 -0
- package/src/audit/audit-log.ts +45 -0
- package/src/browser-shim/build-shim.ts +123 -0
- package/src/browser-shim/index.ts +5 -0
- package/src/browser-shim/shim.template.js +563 -0
- package/src/chains/evm/.github/workflows/npm-deploy.yml +112 -0
- package/src/chains/evm/LICENSE +21 -0
- package/src/chains/evm/README.md +106 -0
- package/src/chains/evm/actions/helpers.ts +147 -0
- package/src/chains/evm/actions/swap.ts +839 -0
- package/src/chains/evm/actions/transfer.ts +254 -0
- package/src/chains/evm/biome.json +61 -0
- package/src/chains/evm/bridge-router.ts +660 -0
- package/src/chains/evm/build.ts +89 -0
- package/src/chains/evm/chain-handler.ts +416 -0
- package/src/chains/evm/constants.ts +23 -0
- package/src/chains/evm/contracts/artifacts/OZGovernor.json +1707 -0
- package/src/chains/evm/contracts/artifacts/TimelockController.json +1007 -0
- package/src/chains/evm/contracts/artifacts/VoteToken.json +895 -0
- package/src/chains/evm/dex/aerodrome/index.ts +34 -0
- package/src/chains/evm/dex/aerodrome/services/AerodromeLpService.ts +558 -0
- package/src/chains/evm/dex/aerodrome/types.ts +318 -0
- package/src/chains/evm/dex/pancakeswp/index.ts +35 -0
- package/src/chains/evm/dex/pancakeswp/services/PancakeSwapV3LpService.ts +743 -0
- package/src/chains/evm/dex/pancakeswp/types.ts +65 -0
- package/src/chains/evm/dex/uniswap/index.ts +35 -0
- package/src/chains/evm/dex/uniswap/services/UniswapV3LpService.ts +759 -0
- package/src/chains/evm/dex/uniswap/types.ts +390 -0
- package/src/chains/evm/generated/specs/spec-helpers.ts +73 -0
- package/src/chains/evm/generated/specs/specs.ts +151 -0
- package/src/chains/evm/gov-router.ts +250 -0
- package/src/chains/evm/index.browser.ts +16 -0
- package/src/chains/evm/index.ts +31 -0
- package/src/chains/evm/prompts.ts +193 -0
- package/src/chains/evm/providers/get-balance.ts +123 -0
- package/src/chains/evm/providers/wallet.ts +715 -0
- package/src/chains/evm/routes/sign.ts +333 -0
- package/src/chains/evm/rpc-providers.ts +410 -0
- package/src/chains/evm/service.ts +140 -0
- package/src/chains/evm/templates/index.ts +10 -0
- package/src/chains/evm/types/index.ts +432 -0
- package/src/chains/evm/vitest.config.ts +18 -0
- package/src/chains/registry.ts +668 -0
- package/src/chains/solana/README.md +367 -0
- package/src/chains/wallet-action.ts +533 -0
- package/src/chains/wallet-router.test.ts +296 -0
- package/src/contracts.ts +65 -0
- package/src/core-augmentation.ts +10 -0
- package/src/index.ts +71 -0
- package/src/lib/server-wallet-trade.ts +192 -0
- package/src/lib/wallet-export-guard.ts +330 -0
- package/src/lp/actions/liquidity.ts +827 -0
- package/src/lp/e2e/real-token-tests.ts +428 -0
- package/src/lp/e2e/scenarios.ts +470 -0
- package/src/lp/e2e/test-utils.ts +145 -0
- package/src/lp/lp-manager-entry.ts +303 -0
- package/src/lp/services/ConcentratedLiquidityService.ts +120 -0
- package/src/lp/services/DexInteractionService.ts +226 -0
- package/src/lp/services/LpManagementService.test.ts +148 -0
- package/src/lp/services/LpManagementService.ts +632 -0
- package/src/lp/services/UserLpProfileService.ts +163 -0
- package/src/lp/services/VaultService.ts +153 -0
- package/src/lp/services/YieldOptimizationService.ts +344 -0
- package/src/lp/services/__tests__/MockLpService.ts +146 -0
- package/src/lp/tasks/LpAutoRebalanceTask.ts +117 -0
- package/src/lp/tasks/__tests__/LpAutoRebalanceTask.test.ts +370 -0
- package/src/lp/types.ts +582 -0
- package/src/lp/utils/solanaClient.ts +143 -0
- package/src/plugin.ts +125 -0
- package/src/policy/policy.ts +19 -0
- package/src/providers/canonical-provider.ts +27 -0
- package/src/providers/unified-wallet-provider.ts +79 -0
- package/src/register-routes.ts +11 -0
- package/src/routes/plugin.ts +47 -0
- package/src/routes/wallet-market-overview-route.ts +869 -0
- package/src/sdk/abi.ts +258 -0
- package/src/sdk/bridge/abis.ts +126 -0
- package/src/sdk/bridge/client.ts +518 -0
- package/src/sdk/bridge/index.ts +56 -0
- package/src/sdk/bridge/solana.ts +604 -0
- package/src/sdk/bridge/types.ts +202 -0
- package/src/sdk/convenience.ts +347 -0
- package/src/sdk/escrow/MutualStakeEscrow.ts +480 -0
- package/src/sdk/escrow/types.ts +64 -0
- package/src/sdk/escrow/verifiers.ts +73 -0
- package/src/sdk/identity/erc8004.ts +692 -0
- package/src/sdk/identity/reputation.ts +449 -0
- package/src/sdk/identity/uaid.ts +497 -0
- package/src/sdk/identity/validation.ts +372 -0
- package/src/sdk/index.ts +763 -0
- package/src/sdk/policy/SpendingPolicy.ts +260 -0
- package/src/sdk/policy/UptoBillingPolicy.ts +320 -0
- package/src/sdk/router/PaymentRouter.ts +215 -0
- package/src/sdk/router/index.ts +8 -0
- package/src/sdk/swap/SwapModule.ts +310 -0
- package/src/sdk/swap/abi.ts +117 -0
- package/src/sdk/swap/index.ts +34 -0
- package/src/sdk/swap/types.ts +135 -0
- package/src/sdk/tokens/decimals.ts +140 -0
- package/src/sdk/tokens/registry.ts +911 -0
- package/src/sdk/tokens/solana.ts +419 -0
- package/src/sdk/tokens/transfers.ts +327 -0
- package/src/sdk/types.ts +158 -0
- package/src/sdk/wallet-core.ts +115 -0
- package/src/sdk/x402/budget.ts +168 -0
- package/src/sdk/x402/chains/abstract/index.ts +280 -0
- package/src/sdk/x402/client.ts +320 -0
- package/src/sdk/x402/index.ts +46 -0
- package/src/sdk/x402/middleware.ts +92 -0
- package/src/sdk/x402/multi-asset.ts +144 -0
- package/src/sdk/x402/types.ts +156 -0
- package/src/services/wallet-backend-service.ts +328 -0
- package/src/types/wallet-router.ts +227 -0
- package/src/utils/intent-trajectory.ts +106 -0
- package/src/wallet/backend.ts +62 -0
- package/src/wallet/errors.ts +49 -0
- package/src/wallet/index.ts +27 -0
- package/src/wallet/local-eoa-backend.ts +201 -0
- package/src/wallet/pending.ts +60 -0
- package/src/wallet/select-backend.ts +47 -0
- package/src/wallet/steward-backend.ts +161 -0
- package/src/wallet-action.ts +1 -0
|
@@ -0,0 +1,497 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* uaid.ts — Universal Agent Identifier (UAID) Resolution Layer
|
|
3
|
+
*
|
|
4
|
+
* Provides cross-chain agent identity resolution via the HOL Registry Broker.
|
|
5
|
+
* UAIDs are chain-agnostic identifiers that bridge ERC-8004 tokens on EVM chains
|
|
6
|
+
* to agents on Solana, Hedera, off-chain frameworks, and any other protocol.
|
|
7
|
+
*
|
|
8
|
+
* This module is an optional extension — agents that only operate on EVM chains
|
|
9
|
+
* can continue using ERC8004Client directly.
|
|
10
|
+
*
|
|
11
|
+
* Registry: https://hol.org
|
|
12
|
+
* SDK: @hol-org/rb-client (peer dependency — install only if needed)
|
|
13
|
+
*
|
|
14
|
+
* @module identity/uaid
|
|
15
|
+
*/
|
|
16
|
+
|
|
17
|
+
import type { Address } from "viem";
|
|
18
|
+
import type {
|
|
19
|
+
AgentIdentity,
|
|
20
|
+
AgentRegistrationFile,
|
|
21
|
+
SupportedChain,
|
|
22
|
+
} from "./erc8004.js";
|
|
23
|
+
|
|
24
|
+
// ─── Types ───────────────────────────────────────────────────────────────────
|
|
25
|
+
|
|
26
|
+
/** Supported protocol types in the UAID ecosystem */
|
|
27
|
+
export type UAIDProtocol =
|
|
28
|
+
| "erc8004"
|
|
29
|
+
| "a2a"
|
|
30
|
+
| "openconvai"
|
|
31
|
+
| "virtuals"
|
|
32
|
+
| "x402"
|
|
33
|
+
| "hedera"
|
|
34
|
+
| "solana"
|
|
35
|
+
| string;
|
|
36
|
+
|
|
37
|
+
/** A parsed UAID with its component parts */
|
|
38
|
+
export interface ParsedUAID {
|
|
39
|
+
/** Raw UAID string */
|
|
40
|
+
raw: string;
|
|
41
|
+
/** Agent identifier portion */
|
|
42
|
+
aid: string;
|
|
43
|
+
/** Unique identifier portion */
|
|
44
|
+
uid: string;
|
|
45
|
+
/** Protocol used for resolution */
|
|
46
|
+
protocol: UAIDProtocol;
|
|
47
|
+
/** Native identifier on the protocol's own chain/system */
|
|
48
|
+
nativeId?: string;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
/** Result of resolving a UAID to a known identity */
|
|
52
|
+
export interface UAIDResolution {
|
|
53
|
+
/** Whether resolution succeeded */
|
|
54
|
+
resolved: boolean;
|
|
55
|
+
/** The UAID that was resolved */
|
|
56
|
+
uaid: string;
|
|
57
|
+
/** Resolved agent identity (if ERC-8004 backed) */
|
|
58
|
+
identity: UniversalAgentIdentity | null;
|
|
59
|
+
/** Protocol the agent was resolved through */
|
|
60
|
+
protocol: UAIDProtocol;
|
|
61
|
+
/** Chain the identity lives on (if applicable) */
|
|
62
|
+
chain?: string;
|
|
63
|
+
/** Trust score from the registry (0-100) */
|
|
64
|
+
trustScore?: number;
|
|
65
|
+
/** Whether the agent is verified in the HOL registry */
|
|
66
|
+
registryVerified: boolean;
|
|
67
|
+
/** Error message if resolution failed */
|
|
68
|
+
error?: string;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
/**
|
|
72
|
+
* Universal agent identity — superset of ERC-8004 AgentIdentity that works
|
|
73
|
+
* across chains. For EVM agents, this mirrors AgentIdentity. For non-EVM
|
|
74
|
+
* agents, it provides equivalent fields using native identifiers.
|
|
75
|
+
*/
|
|
76
|
+
export interface UniversalAgentIdentity {
|
|
77
|
+
/** Identifier — ERC-8004 tokenId for EVM, native ID for others */
|
|
78
|
+
agentId: string;
|
|
79
|
+
/** Owner — EVM address, Hedera account, Solana pubkey, etc. */
|
|
80
|
+
owner: string;
|
|
81
|
+
/** Agent URI / metadata endpoint */
|
|
82
|
+
agentURI: string;
|
|
83
|
+
/** Payment address (chain-native format) */
|
|
84
|
+
paymentAddress: string;
|
|
85
|
+
/** Registration metadata (if available) */
|
|
86
|
+
registrationFile: AgentRegistrationFile | null;
|
|
87
|
+
/** Source protocol */
|
|
88
|
+
protocol: UAIDProtocol;
|
|
89
|
+
/** Source chain */
|
|
90
|
+
chain: string;
|
|
91
|
+
/** UAID for cross-chain reference */
|
|
92
|
+
uaid: string;
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
/** Configuration for the UAID resolver */
|
|
96
|
+
export interface UAIDResolverConfig {
|
|
97
|
+
/** HOL Registry Broker API key (optional for read-only resolution) */
|
|
98
|
+
apiKey?: string;
|
|
99
|
+
/** Custom broker base URL (defaults to production) */
|
|
100
|
+
brokerUrl?: string;
|
|
101
|
+
/** Request timeout in ms (default: 10000) */
|
|
102
|
+
timeoutMs?: number;
|
|
103
|
+
/** Cache resolved identities for this many ms (default: 300000 = 5 min) */
|
|
104
|
+
cacheTtlMs?: number;
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
/** Parameters for registering an ERC-8004 identity as a UAID */
|
|
108
|
+
export interface RegisterUAIDParams {
|
|
109
|
+
/** ERC-8004 agent ID (tokenId) */
|
|
110
|
+
agentId: bigint;
|
|
111
|
+
/** Chain the identity is registered on */
|
|
112
|
+
chain: SupportedChain;
|
|
113
|
+
/** Registry contract address (uses known defaults if omitted) */
|
|
114
|
+
registryAddress?: Address;
|
|
115
|
+
/** Agent name for the registry */
|
|
116
|
+
name: string;
|
|
117
|
+
/** Agent description */
|
|
118
|
+
description: string;
|
|
119
|
+
/** Optional: additional capabilities to advertise */
|
|
120
|
+
capabilities?: string[];
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
// ─── Constants ───────────────────────────────────────────────────────────────
|
|
124
|
+
|
|
125
|
+
const DEFAULT_BROKER_URL = "https://hol.org/registry/api/v1";
|
|
126
|
+
const DEFAULT_TIMEOUT_MS = 10_000;
|
|
127
|
+
const DEFAULT_CACHE_TTL_MS = 300_000; // 5 minutes
|
|
128
|
+
|
|
129
|
+
/** EVM chain IDs for UAID protocol mapping */
|
|
130
|
+
const EVM_CHAIN_IDS: Record<SupportedChain, number> = {
|
|
131
|
+
ethereum: 1,
|
|
132
|
+
base: 8453,
|
|
133
|
+
"base-sepolia": 84532,
|
|
134
|
+
arbitrum: 42161,
|
|
135
|
+
"arbitrum-sepolia": 421614,
|
|
136
|
+
polygon: 137,
|
|
137
|
+
};
|
|
138
|
+
|
|
139
|
+
// ─── Cache ───────────────────────────────────────────────────────────────────
|
|
140
|
+
|
|
141
|
+
interface CacheEntry {
|
|
142
|
+
result: UAIDResolution;
|
|
143
|
+
expiresAt: number;
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
// ─── Client ──────────────────────────────────────────────────────────────────
|
|
147
|
+
|
|
148
|
+
export class UAIDResolver {
|
|
149
|
+
private readonly brokerUrl: string;
|
|
150
|
+
private readonly apiKey?: string;
|
|
151
|
+
private readonly timeoutMs: number;
|
|
152
|
+
private readonly cacheTtlMs: number;
|
|
153
|
+
private readonly cache = new Map<string, CacheEntry>();
|
|
154
|
+
|
|
155
|
+
constructor(config: UAIDResolverConfig = {}) {
|
|
156
|
+
this.brokerUrl = (config.brokerUrl ?? DEFAULT_BROKER_URL).replace(
|
|
157
|
+
/\/+$/,
|
|
158
|
+
"",
|
|
159
|
+
);
|
|
160
|
+
this.apiKey = config.apiKey;
|
|
161
|
+
this.timeoutMs = config.timeoutMs ?? DEFAULT_TIMEOUT_MS;
|
|
162
|
+
this.cacheTtlMs = config.cacheTtlMs ?? DEFAULT_CACHE_TTL_MS;
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
// ── Core resolution ──────────────────────────────────────────────────────
|
|
166
|
+
|
|
167
|
+
/**
|
|
168
|
+
* Resolve a UAID to an agent identity.
|
|
169
|
+
*
|
|
170
|
+
* Works across chains — the resolver contacts the HOL Registry Broker to
|
|
171
|
+
* find the agent's identity regardless of whether it lives on EVM, Hedera,
|
|
172
|
+
* Solana, or off-chain.
|
|
173
|
+
*
|
|
174
|
+
* @param uaid - Universal Agent Identifier string
|
|
175
|
+
* @returns Resolution result with identity details
|
|
176
|
+
*
|
|
177
|
+
* @example
|
|
178
|
+
* ```ts
|
|
179
|
+
* const resolver = new UAIDResolver();
|
|
180
|
+
* const result = await resolver.resolve('uaid:aid:0x8004...;uid=42;proto=erc8004');
|
|
181
|
+
* if (result.resolved) {
|
|
182
|
+
* console.log(result.identity?.paymentAddress);
|
|
183
|
+
* }
|
|
184
|
+
* ```
|
|
185
|
+
*/
|
|
186
|
+
async resolve(uaid: string): Promise<UAIDResolution> {
|
|
187
|
+
// Check cache
|
|
188
|
+
const cached = this.cache.get(uaid);
|
|
189
|
+
if (cached && cached.expiresAt > Date.now()) {
|
|
190
|
+
return cached.result;
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
try {
|
|
194
|
+
const response = await this.brokerRequest(
|
|
195
|
+
"GET",
|
|
196
|
+
`/agents/resolve?uaid=${encodeURIComponent(uaid)}`,
|
|
197
|
+
);
|
|
198
|
+
|
|
199
|
+
if (!response.ok) {
|
|
200
|
+
const result: UAIDResolution = {
|
|
201
|
+
resolved: false,
|
|
202
|
+
uaid,
|
|
203
|
+
identity: null,
|
|
204
|
+
protocol: "unknown",
|
|
205
|
+
registryVerified: false,
|
|
206
|
+
error: `Registry returned ${response.status}`,
|
|
207
|
+
};
|
|
208
|
+
return result;
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
const data = await response.json();
|
|
212
|
+
|
|
213
|
+
const identity: UniversalAgentIdentity = {
|
|
214
|
+
agentId: String(data.agentId ?? data.nativeId ?? ""),
|
|
215
|
+
owner: data.owner ?? data.controller ?? "",
|
|
216
|
+
agentURI: data.agentURI ?? data.metadataUri ?? "",
|
|
217
|
+
paymentAddress: data.paymentAddress ?? data.agentWallet ?? "",
|
|
218
|
+
registrationFile: data.registrationFile ?? null,
|
|
219
|
+
protocol: data.protocol ?? "unknown",
|
|
220
|
+
chain: data.chain ?? "",
|
|
221
|
+
uaid,
|
|
222
|
+
};
|
|
223
|
+
|
|
224
|
+
const result: UAIDResolution = {
|
|
225
|
+
resolved: true,
|
|
226
|
+
uaid,
|
|
227
|
+
identity,
|
|
228
|
+
protocol: data.protocol ?? "unknown",
|
|
229
|
+
chain: data.chain,
|
|
230
|
+
trustScore: data.trustScore,
|
|
231
|
+
registryVerified: data.verified ?? false,
|
|
232
|
+
};
|
|
233
|
+
|
|
234
|
+
// Cache the result
|
|
235
|
+
this.cache.set(uaid, { result, expiresAt: Date.now() + this.cacheTtlMs });
|
|
236
|
+
return result;
|
|
237
|
+
} catch (error: unknown) {
|
|
238
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
239
|
+
return {
|
|
240
|
+
resolved: false,
|
|
241
|
+
uaid,
|
|
242
|
+
identity: null,
|
|
243
|
+
protocol: "unknown",
|
|
244
|
+
registryVerified: false,
|
|
245
|
+
error: `Resolution failed: ${message}`,
|
|
246
|
+
};
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
|
|
250
|
+
/**
|
|
251
|
+
* Search the HOL registry for agents matching criteria.
|
|
252
|
+
*
|
|
253
|
+
* @param query - Search terms (name, capability, protocol)
|
|
254
|
+
* @param options - Optional filters
|
|
255
|
+
* @returns Array of matching UAIDResolution results
|
|
256
|
+
*/
|
|
257
|
+
async search(
|
|
258
|
+
query: string,
|
|
259
|
+
options?: {
|
|
260
|
+
protocol?: UAIDProtocol;
|
|
261
|
+
limit?: number;
|
|
262
|
+
minTrustScore?: number;
|
|
263
|
+
},
|
|
264
|
+
): Promise<UAIDResolution[]> {
|
|
265
|
+
try {
|
|
266
|
+
const params = new URLSearchParams({ q: query });
|
|
267
|
+
if (options?.protocol) params.set("protocol", options.protocol);
|
|
268
|
+
if (options?.limit) params.set("limit", String(options.limit));
|
|
269
|
+
if (options?.minTrustScore)
|
|
270
|
+
params.set("minTrust", String(options.minTrustScore));
|
|
271
|
+
|
|
272
|
+
const response = await this.brokerRequest(
|
|
273
|
+
"GET",
|
|
274
|
+
`/agents/search?${params}`,
|
|
275
|
+
);
|
|
276
|
+
if (!response.ok) return [];
|
|
277
|
+
|
|
278
|
+
const data = await response.json();
|
|
279
|
+
const results: UAIDResolution[] = (data.agents ?? []).map(
|
|
280
|
+
(agent: Record<string, unknown>) => ({
|
|
281
|
+
resolved: true,
|
|
282
|
+
uaid: agent.uaid as string,
|
|
283
|
+
identity: {
|
|
284
|
+
agentId: String(agent.agentId ?? agent.nativeId ?? ""),
|
|
285
|
+
owner: (agent.owner ?? agent.controller ?? "") as string,
|
|
286
|
+
agentURI: (agent.agentURI ?? agent.metadataUri ?? "") as string,
|
|
287
|
+
paymentAddress: (agent.paymentAddress ??
|
|
288
|
+
agent.agentWallet ??
|
|
289
|
+
"") as string,
|
|
290
|
+
registrationFile: (agent.registrationFile ??
|
|
291
|
+
null) as AgentRegistrationFile | null,
|
|
292
|
+
protocol: (agent.protocol ?? "unknown") as UAIDProtocol,
|
|
293
|
+
chain: (agent.chain ?? "") as string,
|
|
294
|
+
uaid: agent.uaid as string,
|
|
295
|
+
},
|
|
296
|
+
protocol: (agent.protocol ?? "unknown") as UAIDProtocol,
|
|
297
|
+
chain: agent.chain as string | undefined,
|
|
298
|
+
trustScore: agent.trustScore as number | undefined,
|
|
299
|
+
registryVerified: (agent.verified ?? false) as boolean,
|
|
300
|
+
}),
|
|
301
|
+
);
|
|
302
|
+
|
|
303
|
+
return results;
|
|
304
|
+
} catch {
|
|
305
|
+
return [];
|
|
306
|
+
}
|
|
307
|
+
}
|
|
308
|
+
|
|
309
|
+
// ── ERC-8004 ↔ UAID bridge ────────────────────────────────────────────────
|
|
310
|
+
|
|
311
|
+
/**
|
|
312
|
+
* Convert an ERC-8004 AgentIdentity to a UniversalAgentIdentity.
|
|
313
|
+
*
|
|
314
|
+
* Useful when you already have an on-chain identity and want to work
|
|
315
|
+
* with the universal format (e.g., for cross-chain discovery).
|
|
316
|
+
*/
|
|
317
|
+
erc8004ToUniversal(
|
|
318
|
+
identity: AgentIdentity,
|
|
319
|
+
chain: SupportedChain,
|
|
320
|
+
): UniversalAgentIdentity {
|
|
321
|
+
const chainId = EVM_CHAIN_IDS[chain];
|
|
322
|
+
return {
|
|
323
|
+
agentId: identity.agentId.toString(),
|
|
324
|
+
owner: identity.owner,
|
|
325
|
+
agentURI: identity.agentURI,
|
|
326
|
+
paymentAddress: identity.agentWallet,
|
|
327
|
+
registrationFile: identity.registrationFile,
|
|
328
|
+
protocol: "erc8004",
|
|
329
|
+
chain: `eip155:${chainId}`,
|
|
330
|
+
uaid: `uaid:aid:eip155:${chainId}:${identity.owner};uid=${identity.agentId};proto=erc8004`,
|
|
331
|
+
};
|
|
332
|
+
}
|
|
333
|
+
|
|
334
|
+
/**
|
|
335
|
+
* Build a UAID string for an ERC-8004 agent.
|
|
336
|
+
*
|
|
337
|
+
* This creates the identifier — it does NOT register with the HOL registry.
|
|
338
|
+
* Use registerERC8004Agent() to make the agent discoverable cross-chain.
|
|
339
|
+
*/
|
|
340
|
+
buildERC8004UAID(
|
|
341
|
+
agentId: bigint,
|
|
342
|
+
chain: SupportedChain,
|
|
343
|
+
ownerAddress: Address,
|
|
344
|
+
): string {
|
|
345
|
+
const chainId = EVM_CHAIN_IDS[chain];
|
|
346
|
+
return `uaid:aid:eip155:${chainId}:${ownerAddress};uid=${agentId};proto=erc8004`;
|
|
347
|
+
}
|
|
348
|
+
|
|
349
|
+
/**
|
|
350
|
+
* Register an ERC-8004 agent in the HOL registry for cross-chain discovery.
|
|
351
|
+
*
|
|
352
|
+
* After registration, agents on Solana, Hedera, or any protocol can
|
|
353
|
+
* discover and verify this agent's identity via its UAID.
|
|
354
|
+
*
|
|
355
|
+
* Requires an API key with write permissions.
|
|
356
|
+
*
|
|
357
|
+
* @param params - Registration parameters
|
|
358
|
+
* @returns The assigned UAID
|
|
359
|
+
*/
|
|
360
|
+
async registerERC8004Agent(params: RegisterUAIDParams): Promise<string> {
|
|
361
|
+
if (!this.apiKey) {
|
|
362
|
+
throw new Error(
|
|
363
|
+
"UAIDResolver: API key required for registration. Get one at https://hol.org",
|
|
364
|
+
);
|
|
365
|
+
}
|
|
366
|
+
|
|
367
|
+
const chainId = EVM_CHAIN_IDS[params.chain];
|
|
368
|
+
const uaid = `uaid:aid:eip155:${chainId}:${params.registryAddress ?? "0x8004A169FB4a3325136EB29fA0ceB6D2e539a432"};uid=${params.agentId};proto=erc8004`;
|
|
369
|
+
|
|
370
|
+
const response = await this.brokerRequest("POST", "/agents/register", {
|
|
371
|
+
uaid,
|
|
372
|
+
protocol: "erc8004",
|
|
373
|
+
chain: `eip155:${chainId}`,
|
|
374
|
+
agentId: params.agentId.toString(),
|
|
375
|
+
name: params.name,
|
|
376
|
+
description: params.description,
|
|
377
|
+
capabilities: params.capabilities ?? [],
|
|
378
|
+
registryAddress:
|
|
379
|
+
params.registryAddress ?? "0x8004A169FB4a3325136EB29fA0ceB6D2e539a432",
|
|
380
|
+
});
|
|
381
|
+
|
|
382
|
+
if (!response.ok) {
|
|
383
|
+
const errorBody = await response.text().catch(() => "");
|
|
384
|
+
throw new Error(
|
|
385
|
+
`UAIDResolver: Registration failed (${response.status}): ${errorBody}`,
|
|
386
|
+
);
|
|
387
|
+
}
|
|
388
|
+
|
|
389
|
+
const data = await response.json();
|
|
390
|
+
return data.uaid ?? uaid;
|
|
391
|
+
}
|
|
392
|
+
|
|
393
|
+
// ── Verification ──────────────────────────────────────────────────────────
|
|
394
|
+
|
|
395
|
+
/**
|
|
396
|
+
* Verify an agent's identity via UAID — works across any chain.
|
|
397
|
+
*
|
|
398
|
+
* This is the cross-chain equivalent of ERC8004Client.lookupAgentIdentity().
|
|
399
|
+
* For EVM agents, it verifies the UAID maps to a valid on-chain ERC-8004 token.
|
|
400
|
+
* For non-EVM agents, it verifies through the registry's native trust mechanism.
|
|
401
|
+
*
|
|
402
|
+
* @param uaid - Universal Agent Identifier to verify
|
|
403
|
+
* @returns Verification result
|
|
404
|
+
*/
|
|
405
|
+
async verify(uaid: string): Promise<{
|
|
406
|
+
verified: boolean;
|
|
407
|
+
identity: UniversalAgentIdentity | null;
|
|
408
|
+
trustScore: number;
|
|
409
|
+
protocol: UAIDProtocol;
|
|
410
|
+
error?: string;
|
|
411
|
+
}> {
|
|
412
|
+
const resolution = await this.resolve(uaid);
|
|
413
|
+
|
|
414
|
+
if (!resolution.resolved || !resolution.identity) {
|
|
415
|
+
return {
|
|
416
|
+
verified: false,
|
|
417
|
+
identity: null,
|
|
418
|
+
trustScore: 0,
|
|
419
|
+
protocol: resolution.protocol,
|
|
420
|
+
error: resolution.error ?? "Agent not found in registry",
|
|
421
|
+
};
|
|
422
|
+
}
|
|
423
|
+
|
|
424
|
+
return {
|
|
425
|
+
verified: resolution.registryVerified,
|
|
426
|
+
identity: resolution.identity,
|
|
427
|
+
trustScore: resolution.trustScore ?? 0,
|
|
428
|
+
protocol: resolution.protocol,
|
|
429
|
+
};
|
|
430
|
+
}
|
|
431
|
+
|
|
432
|
+
// ── Utility ───────────────────────────────────────────────────────────────
|
|
433
|
+
|
|
434
|
+
/**
|
|
435
|
+
* Parse a UAID string into its components.
|
|
436
|
+
*
|
|
437
|
+
* Format: `uaid:aid:<identifier>;uid=<unique-id>;proto=<protocol>[;nativeId=<id>]`
|
|
438
|
+
*/
|
|
439
|
+
static parseUAID(uaid: string): ParsedUAID | null {
|
|
440
|
+
if (!uaid.startsWith("uaid:")) return null;
|
|
441
|
+
|
|
442
|
+
const parts = uaid.split(";");
|
|
443
|
+
const aidPart = parts.find((p) => p.startsWith("uaid:aid:"));
|
|
444
|
+
const uidPart = parts.find((p) => p.startsWith("uid="));
|
|
445
|
+
const protoPart = parts.find((p) => p.startsWith("proto="));
|
|
446
|
+
const nativeIdPart = parts.find((p) => p.startsWith("nativeId="));
|
|
447
|
+
|
|
448
|
+
if (!aidPart || !uidPart || !protoPart) return null;
|
|
449
|
+
|
|
450
|
+
return {
|
|
451
|
+
raw: uaid,
|
|
452
|
+
aid: aidPart.replace("uaid:aid:", ""),
|
|
453
|
+
uid: uidPart.replace("uid=", ""),
|
|
454
|
+
protocol: protoPart.replace("proto=", "") as UAIDProtocol,
|
|
455
|
+
nativeId: nativeIdPart?.replace("nativeId=", ""),
|
|
456
|
+
};
|
|
457
|
+
}
|
|
458
|
+
|
|
459
|
+
/** Clear the resolution cache */
|
|
460
|
+
clearCache(): void {
|
|
461
|
+
this.cache.clear();
|
|
462
|
+
}
|
|
463
|
+
|
|
464
|
+
// ── Private ───────────────────────────────────────────────────────────────
|
|
465
|
+
|
|
466
|
+
private async brokerRequest(
|
|
467
|
+
method: string,
|
|
468
|
+
path: string,
|
|
469
|
+
body?: unknown,
|
|
470
|
+
): Promise<Response> {
|
|
471
|
+
const url = `${this.brokerUrl}${path}`;
|
|
472
|
+
const headers: Record<string, string> = {
|
|
473
|
+
Accept: "application/json",
|
|
474
|
+
"User-Agent": "agentwallet-sdk/uaid-resolver",
|
|
475
|
+
};
|
|
476
|
+
if (this.apiKey) {
|
|
477
|
+
headers.Authorization = `Bearer ${this.apiKey}`;
|
|
478
|
+
}
|
|
479
|
+
if (body) {
|
|
480
|
+
headers["Content-Type"] = "application/json";
|
|
481
|
+
}
|
|
482
|
+
|
|
483
|
+
const controller = new AbortController();
|
|
484
|
+
const timeout = setTimeout(() => controller.abort(), this.timeoutMs);
|
|
485
|
+
|
|
486
|
+
try {
|
|
487
|
+
return await fetch(url, {
|
|
488
|
+
method,
|
|
489
|
+
headers,
|
|
490
|
+
body: body ? JSON.stringify(body) : undefined,
|
|
491
|
+
signal: controller.signal,
|
|
492
|
+
});
|
|
493
|
+
} finally {
|
|
494
|
+
clearTimeout(timeout);
|
|
495
|
+
}
|
|
496
|
+
}
|
|
497
|
+
}
|