agentwallet-sdk 6.0.5 → 6.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -373,6 +373,44 @@ const rep = await reputation.getAgentReputation(agentId!);
373
373
  console.log(`Score: ${rep.totalScore} from ${rep.count} reviews`);
374
374
  ```
375
375
 
376
+ ## Cross-Chain Identity (UAID)
377
+
378
+ ERC-8004 identities live on EVM chains. For agents on Solana, Hedera, or off-chain frameworks, the UAID (Universal Agent Identifier) resolver bridges identities across all chains via the [HOL Registry](https://hol.org).
379
+
380
+ ```typescript
381
+ import { UAIDResolver, ERC8004Client } from 'agentwallet-sdk';
382
+
383
+ const resolver = new UAIDResolver();
384
+
385
+ // Resolve any agent by UAID — works across all chains
386
+ const result = await resolver.resolve(
387
+ 'uaid:aid:eip155:8453:0x8004...;uid=42;proto=erc8004'
388
+ );
389
+ if (result.resolved) {
390
+ console.log(result.identity?.paymentAddress); // Payment address, any chain
391
+ console.log(result.trustScore); // Trust score (0-100)
392
+ }
393
+
394
+ // Convert your ERC-8004 identity to universal format
395
+ const erc8004 = new ERC8004Client({ chain: 'base' });
396
+ const identity = await erc8004.lookupAgentIdentity(42n);
397
+ const universal = resolver.erc8004ToUniversal(identity, 'base');
398
+ console.log(universal.uaid); // Cross-chain discoverable ID
399
+
400
+ // Verify any agent before transacting (chain-agnostic)
401
+ const check = await resolver.verify('uaid:aid:hedera:0.0.5678;uid=x;proto=openconvai');
402
+ if (check.verified) { /* safe to transact */ }
403
+
404
+ // Register for cross-chain discovery (requires HOL API key)
405
+ const registrar = new UAIDResolver({ apiKey: process.env.HOL_API_KEY });
406
+ const uaid = await registrar.registerERC8004Agent({
407
+ agentId: 42n, chain: 'base',
408
+ name: 'My Agent', description: 'Trading agent with x402 support',
409
+ });
410
+ ```
411
+
412
+ See [`examples/cross-chain-identity.ts`](./examples/cross-chain-identity.ts) for the full walkthrough.
413
+
376
414
  ## Decimal Helpers
377
415
 
378
416
  ```typescript
@@ -419,11 +457,66 @@ Stateless design — wallet state lives on-chain, not in application memory. Mul
419
457
  - SpendingPolicy changes are on-chain events — tamper-proof
420
458
  - NFT transfer = instant revocation of all agent permissions — no "forgot to deprovision" risk
421
459
 
460
+ ## Supported Payment Rails — Three-Rail Architecture
461
+
462
+ AgentWallet SDK routes payments across three independent rails, selecting the optimal one based on amount, session context, autonomy level, and ecosystem preference:
463
+
464
+ | Rail | Status | Use Case | Overhead |
465
+ |------|--------|----------|----------|
466
+ | ✅ **x402** (Base, EVM) | **Live** | Autonomous micropayments, API access, agent-to-agent commerce | 0 bps (no protocol fee) |
467
+ | ✅ **Stripe MPP** | **Live** | High-frequency session payments, fiat-connected merchants, dispute resolution | ~290 bps |
468
+ | 🔜 **Google AP2** | **Roadmap** | Google-managed identity + payment bundle, enterprise SSO integration | ~100 bps (est.) |
469
+ | 🔜 **Solana x402** | **Roadmap Q2** | Solana-native agent payments via Solana Foundation gateway | 0 bps |
470
+
471
+ ### How the Router Decides
472
+
473
+ The `PaymentRouter` evaluates each transaction and selects the rail automatically:
474
+
475
+ - **Micropayments (< $1) + autonomous agent** → x402 (zero overhead, on-chain audit)
476
+ - **High-frequency session (5+ txns)** → MPP (batching efficiency)
477
+ - **Larger amounts or supervised agent** → MPP (fiat rails, dispute resolution)
478
+ - **Google ecosystem preference** → Google AP2 (when live — managed identity + payment)
479
+ - **Solana preference** → x402-solana (when live)
480
+
481
+ AgentWallet SDK is the **multi-rail abstraction layer** — your agent code doesn't change when you add a new payment rail. Write once, pay on any chain or protocol.
482
+
483
+ ```typescript
484
+ import { createX402Client } from 'agentwallet-sdk';
485
+
486
+ // Same API regardless of underlying rail
487
+ const client = createX402Client(wallet, {
488
+ supportedNetworks: ['base:8453'], // Solana coming soon
489
+ globalDailyLimit: 50_000_000n,
490
+ });
491
+ ```
492
+
493
+ ## Open Wallet Standard (OWS) Compatibility
494
+
495
+ AgentWallet SDK is designed to work **on top of** [MoonPay's Open Wallet Standard](https://github.com/moonpay/open-wallet-standard) — not compete with it. OWS handles wallet key management (multi-chain signing, hardware-backed vaults, encrypted local storage). AgentWallet SDK handles everything above that: MCP integration, framework abstraction, spend-policy enforcement, payment routing, and human-in-the-loop approval.
496
+
497
+ **The complete stack:**
498
+
499
+ | Layer | Component | Responsibility |
500
+ |-------|-----------|---------------|
501
+ | Wallet & Key Management | **Open Wallet Standard (OWS)** | Multi-chain signing, hardware-backed keys (Ledger), encrypted vault, policy engine |
502
+ | Framework & Integration | **AgentWallet SDK** | On-chain spend limits, payment routing (x402/MPP/AP2), human approval, framework adapters |
503
+ | MCP Server | **[agentpay-mcp](https://github.com/up2itnow0822/agentpay-mcp)** | MCP-native payment tools for any MCP-compatible agent |
504
+
505
+ If your agent framework or wallet provider already implements OWS, AgentWallet SDK plugs in as the payment execution and policy layer. Your agent gets supervised spending, multi-rail routing, and auditable on-chain payments without replacing your existing key management.
506
+
507
+ ## Market Context
508
+
509
+ The agentic AI SDK market is projected to grow from **$2.4B (2025) to $16B by 2030** (Mordor Intelligence). AI agents are forecast to drive **$262B in bank sales** via embedded payments and lending by 2026. x402 alone has processed **140M+ agent payment transactions** ($43M) in 9 months, with 98.6% USDC settlement.
510
+
511
+ AgentWallet SDK is [production-validated with NVIDIA NeMo](https://github.com/NVIDIA/NeMo-Agent-Toolkit-Examples/pull/17) — demonstrating enterprise-grade agent payment integration at scale. NVIDIA reports 88% revenue impact and 87% cost reduction from AI agent deployments.
512
+
422
513
  ## Links
423
514
 
424
515
  - [GitHub](https://github.com/up2itnow0822/agent-wallet-sdk)
425
516
  - [npm](https://www.npmjs.com/package/agentwallet-sdk)
426
517
  - [ERC-8004 Spec](https://eips.ethereum.org/EIPS/eip-8004)
518
+ - [Open Wallet Standard](https://github.com/moonpay/open-wallet-standard) — wallet key management layer
519
+ - [HOL Registry](https://hol.org) — Cross-chain agent identity registry (UAID resolution)
427
520
  - [agentpay-mcp](https://github.com/up2itnow0822/agentpay-mcp) — MCP server wrapping this SDK
428
521
 
429
522
  ## Patent Notice
@@ -4,4 +4,6 @@ export { ReputationClient, ReputationRegistryAbi } from './reputation.js';
4
4
  export type { ReputationClientConfig, GiveFeedbackParams, FeedbackEntry, AgentReputationSummary, FeedbackFilters, RespondToFeedbackParams, } from './reputation.js';
5
5
  export { ValidationClient, ValidationRegistryAbi } from './validation.js';
6
6
  export type { ValidationClientConfig, RequestValidationParams, RespondToValidationParams, ValidationStatus, ValidationSummary, } from './validation.js';
7
+ export { UAIDResolver } from './uaid.js';
8
+ export type { UAIDProtocol, ParsedUAID, UAIDResolution, UniversalAgentIdentity, UAIDResolverConfig, RegisterUAIDParams, } from './uaid.js';
7
9
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/identity/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,aAAa,EAAE,0BAA0B,EAAE,aAAa,EACxD,sBAAsB,EAAE,wBAAwB,EAChD,YAAY,EAAE,YAAY,EAAE,eAAe,EAAE,wBAAwB,EAAE,mBAAmB,GAC3F,MAAM,cAAc,CAAC;AACtB,YAAY,EACV,oBAAoB,EAAE,uBAAuB,EAAE,oBAAoB,EACnE,qBAAqB,EAAE,kBAAkB,EAAE,aAAa,EACxD,aAAa,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,cAAc,GACvE,MAAM,cAAc,CAAC;AAEtB,OAAO,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,MAAM,iBAAiB,CAAC;AAC1E,YAAY,EACV,sBAAsB,EAAE,kBAAkB,EAAE,aAAa,EACzD,sBAAsB,EAAE,eAAe,EAAE,uBAAuB,GACjE,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,MAAM,iBAAiB,CAAC;AAC1E,YAAY,EACV,sBAAsB,EAAE,uBAAuB,EAAE,yBAAyB,EAC1E,gBAAgB,EAAE,iBAAiB,GACpC,MAAM,iBAAiB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/identity/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,aAAa,EAAE,0BAA0B,EAAE,aAAa,EACxD,sBAAsB,EAAE,wBAAwB,EAChD,YAAY,EAAE,YAAY,EAAE,eAAe,EAAE,wBAAwB,EAAE,mBAAmB,GAC3F,MAAM,cAAc,CAAC;AACtB,YAAY,EACV,oBAAoB,EAAE,uBAAuB,EAAE,oBAAoB,EACnE,qBAAqB,EAAE,kBAAkB,EAAE,aAAa,EACxD,aAAa,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,cAAc,GACvE,MAAM,cAAc,CAAC;AAEtB,OAAO,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,MAAM,iBAAiB,CAAC;AAC1E,YAAY,EACV,sBAAsB,EAAE,kBAAkB,EAAE,aAAa,EACzD,sBAAsB,EAAE,eAAe,EAAE,uBAAuB,GACjE,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,MAAM,iBAAiB,CAAC;AAC1E,YAAY,EACV,sBAAsB,EAAE,uBAAuB,EAAE,yBAAyB,EAC1E,gBAAgB,EAAE,iBAAiB,GACpC,MAAM,iBAAiB,CAAC;AAGzB,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,YAAY,EACV,YAAY,EAAE,UAAU,EAAE,cAAc,EAAE,sBAAsB,EAChE,kBAAkB,EAAE,kBAAkB,GACvC,MAAM,WAAW,CAAC"}
@@ -1,4 +1,6 @@
1
1
  export { ERC8004Client, ERC8004IdentityRegistryAbi, METADATA_KEYS, REGISTRATION_FILE_TYPE, KNOWN_REGISTRY_ADDRESSES, buildDataURI, parseDataURI, resolveAgentURI, validateRegistrationFile, formatAgentRegistry, } from './erc8004.js';
2
2
  export { ReputationClient, ReputationRegistryAbi } from './reputation.js';
3
3
  export { ValidationClient, ValidationRegistryAbi } from './validation.js';
4
+ // ─── UAID: Cross-Chain Identity Resolution ─────────────────────────────────
5
+ export { UAIDResolver } from './uaid.js';
4
6
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/identity/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,aAAa,EAAE,0BAA0B,EAAE,aAAa,EACxD,sBAAsB,EAAE,wBAAwB,EAChD,YAAY,EAAE,YAAY,EAAE,eAAe,EAAE,wBAAwB,EAAE,mBAAmB,GAC3F,MAAM,cAAc,CAAC;AAOtB,OAAO,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,MAAM,iBAAiB,CAAC;AAM1E,OAAO,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,MAAM,iBAAiB,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/identity/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,aAAa,EAAE,0BAA0B,EAAE,aAAa,EACxD,sBAAsB,EAAE,wBAAwB,EAChD,YAAY,EAAE,YAAY,EAAE,eAAe,EAAE,wBAAwB,EAAE,mBAAmB,GAC3F,MAAM,cAAc,CAAC;AAOtB,OAAO,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,MAAM,iBAAiB,CAAC;AAM1E,OAAO,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,MAAM,iBAAiB,CAAC;AAM1E,8EAA8E;AAC9E,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC"}
@@ -0,0 +1,193 @@
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
+ import type { AgentIdentity, AgentRegistrationFile, SupportedChain } from './erc8004.js';
17
+ import type { Address } from 'viem';
18
+ /** Supported protocol types in the UAID ecosystem */
19
+ export type UAIDProtocol = 'erc8004' | 'a2a' | 'openconvai' | 'virtuals' | 'x402' | 'hedera' | 'solana' | string;
20
+ /** A parsed UAID with its component parts */
21
+ export interface ParsedUAID {
22
+ /** Raw UAID string */
23
+ raw: string;
24
+ /** Agent identifier portion */
25
+ aid: string;
26
+ /** Unique identifier portion */
27
+ uid: string;
28
+ /** Protocol used for resolution */
29
+ protocol: UAIDProtocol;
30
+ /** Native identifier on the protocol's own chain/system */
31
+ nativeId?: string;
32
+ }
33
+ /** Result of resolving a UAID to a known identity */
34
+ export interface UAIDResolution {
35
+ /** Whether resolution succeeded */
36
+ resolved: boolean;
37
+ /** The UAID that was resolved */
38
+ uaid: string;
39
+ /** Resolved agent identity (if ERC-8004 backed) */
40
+ identity: UniversalAgentIdentity | null;
41
+ /** Protocol the agent was resolved through */
42
+ protocol: UAIDProtocol;
43
+ /** Chain the identity lives on (if applicable) */
44
+ chain?: string;
45
+ /** Trust score from the registry (0-100) */
46
+ trustScore?: number;
47
+ /** Whether the agent is verified in the HOL registry */
48
+ registryVerified: boolean;
49
+ /** Error message if resolution failed */
50
+ error?: string;
51
+ }
52
+ /**
53
+ * Universal agent identity — superset of ERC-8004 AgentIdentity that works
54
+ * across chains. For EVM agents, this mirrors AgentIdentity. For non-EVM
55
+ * agents, it provides equivalent fields using native identifiers.
56
+ */
57
+ export interface UniversalAgentIdentity {
58
+ /** Identifier — ERC-8004 tokenId for EVM, native ID for others */
59
+ agentId: string;
60
+ /** Owner — EVM address, Hedera account, Solana pubkey, etc. */
61
+ owner: string;
62
+ /** Agent URI / metadata endpoint */
63
+ agentURI: string;
64
+ /** Payment address (chain-native format) */
65
+ paymentAddress: string;
66
+ /** Registration metadata (if available) */
67
+ registrationFile: AgentRegistrationFile | null;
68
+ /** Source protocol */
69
+ protocol: UAIDProtocol;
70
+ /** Source chain */
71
+ chain: string;
72
+ /** UAID for cross-chain reference */
73
+ uaid: string;
74
+ }
75
+ /** Configuration for the UAID resolver */
76
+ export interface UAIDResolverConfig {
77
+ /** HOL Registry Broker API key (optional for read-only resolution) */
78
+ apiKey?: string;
79
+ /** Custom broker base URL (defaults to production) */
80
+ brokerUrl?: string;
81
+ /** Request timeout in ms (default: 10000) */
82
+ timeoutMs?: number;
83
+ /** Cache resolved identities for this many ms (default: 300000 = 5 min) */
84
+ cacheTtlMs?: number;
85
+ }
86
+ /** Parameters for registering an ERC-8004 identity as a UAID */
87
+ export interface RegisterUAIDParams {
88
+ /** ERC-8004 agent ID (tokenId) */
89
+ agentId: bigint;
90
+ /** Chain the identity is registered on */
91
+ chain: SupportedChain;
92
+ /** Registry contract address (uses known defaults if omitted) */
93
+ registryAddress?: Address;
94
+ /** Agent name for the registry */
95
+ name: string;
96
+ /** Agent description */
97
+ description: string;
98
+ /** Optional: additional capabilities to advertise */
99
+ capabilities?: string[];
100
+ }
101
+ export declare class UAIDResolver {
102
+ private readonly brokerUrl;
103
+ private readonly apiKey?;
104
+ private readonly timeoutMs;
105
+ private readonly cacheTtlMs;
106
+ private readonly cache;
107
+ constructor(config?: UAIDResolverConfig);
108
+ /**
109
+ * Resolve a UAID to an agent identity.
110
+ *
111
+ * Works across chains — the resolver contacts the HOL Registry Broker to
112
+ * find the agent's identity regardless of whether it lives on EVM, Hedera,
113
+ * Solana, or off-chain.
114
+ *
115
+ * @param uaid - Universal Agent Identifier string
116
+ * @returns Resolution result with identity details
117
+ *
118
+ * @example
119
+ * ```ts
120
+ * const resolver = new UAIDResolver();
121
+ * const result = await resolver.resolve('uaid:aid:0x8004...;uid=42;proto=erc8004');
122
+ * if (result.resolved) {
123
+ * console.log(result.identity?.paymentAddress);
124
+ * }
125
+ * ```
126
+ */
127
+ resolve(uaid: string): Promise<UAIDResolution>;
128
+ /**
129
+ * Search the HOL registry for agents matching criteria.
130
+ *
131
+ * @param query - Search terms (name, capability, protocol)
132
+ * @param options - Optional filters
133
+ * @returns Array of matching UAIDResolution results
134
+ */
135
+ search(query: string, options?: {
136
+ protocol?: UAIDProtocol;
137
+ limit?: number;
138
+ minTrustScore?: number;
139
+ }): Promise<UAIDResolution[]>;
140
+ /**
141
+ * Convert an ERC-8004 AgentIdentity to a UniversalAgentIdentity.
142
+ *
143
+ * Useful when you already have an on-chain identity and want to work
144
+ * with the universal format (e.g., for cross-chain discovery).
145
+ */
146
+ erc8004ToUniversal(identity: AgentIdentity, chain: SupportedChain): UniversalAgentIdentity;
147
+ /**
148
+ * Build a UAID string for an ERC-8004 agent.
149
+ *
150
+ * This creates the identifier — it does NOT register with the HOL registry.
151
+ * Use registerERC8004Agent() to make the agent discoverable cross-chain.
152
+ */
153
+ buildERC8004UAID(agentId: bigint, chain: SupportedChain, ownerAddress: Address): string;
154
+ /**
155
+ * Register an ERC-8004 agent in the HOL registry for cross-chain discovery.
156
+ *
157
+ * After registration, agents on Solana, Hedera, or any protocol can
158
+ * discover and verify this agent's identity via its UAID.
159
+ *
160
+ * Requires an API key with write permissions.
161
+ *
162
+ * @param params - Registration parameters
163
+ * @returns The assigned UAID
164
+ */
165
+ registerERC8004Agent(params: RegisterUAIDParams): Promise<string>;
166
+ /**
167
+ * Verify an agent's identity via UAID — works across any chain.
168
+ *
169
+ * This is the cross-chain equivalent of ERC8004Client.lookupAgentIdentity().
170
+ * For EVM agents, it verifies the UAID maps to a valid on-chain ERC-8004 token.
171
+ * For non-EVM agents, it verifies through the registry's native trust mechanism.
172
+ *
173
+ * @param uaid - Universal Agent Identifier to verify
174
+ * @returns Verification result
175
+ */
176
+ verify(uaid: string): Promise<{
177
+ verified: boolean;
178
+ identity: UniversalAgentIdentity | null;
179
+ trustScore: number;
180
+ protocol: UAIDProtocol;
181
+ error?: string;
182
+ }>;
183
+ /**
184
+ * Parse a UAID string into its components.
185
+ *
186
+ * Format: `uaid:aid:<identifier>;uid=<unique-id>;proto=<protocol>[;nativeId=<id>]`
187
+ */
188
+ static parseUAID(uaid: string): ParsedUAID | null;
189
+ /** Clear the resolution cache */
190
+ clearCache(): void;
191
+ private brokerRequest;
192
+ }
193
+ //# sourceMappingURL=uaid.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"uaid.d.ts","sourceRoot":"","sources":["../../src/identity/uaid.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,296 @@
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
+ // ─── Constants ───────────────────────────────────────────────────────────────
17
+ const DEFAULT_BROKER_URL = 'https://hol.org/registry/api/v1';
18
+ const DEFAULT_TIMEOUT_MS = 10000;
19
+ const DEFAULT_CACHE_TTL_MS = 300000; // 5 minutes
20
+ /** EVM chain IDs for UAID protocol mapping */
21
+ const EVM_CHAIN_IDS = {
22
+ 'ethereum': 1,
23
+ 'base': 8453,
24
+ 'base-sepolia': 84532,
25
+ 'arbitrum': 42161,
26
+ 'arbitrum-sepolia': 421614,
27
+ 'polygon': 137,
28
+ };
29
+ // ─── Client ──────────────────────────────────────────────────────────────────
30
+ export class UAIDResolver {
31
+ constructor(config = {}) {
32
+ this.cache = new Map();
33
+ this.brokerUrl = (config.brokerUrl ?? DEFAULT_BROKER_URL).replace(/\/+$/, '');
34
+ this.apiKey = config.apiKey;
35
+ this.timeoutMs = config.timeoutMs ?? DEFAULT_TIMEOUT_MS;
36
+ this.cacheTtlMs = config.cacheTtlMs ?? DEFAULT_CACHE_TTL_MS;
37
+ }
38
+ // ── Core resolution ──────────────────────────────────────────────────────
39
+ /**
40
+ * Resolve a UAID to an agent identity.
41
+ *
42
+ * Works across chains — the resolver contacts the HOL Registry Broker to
43
+ * find the agent's identity regardless of whether it lives on EVM, Hedera,
44
+ * Solana, or off-chain.
45
+ *
46
+ * @param uaid - Universal Agent Identifier string
47
+ * @returns Resolution result with identity details
48
+ *
49
+ * @example
50
+ * ```ts
51
+ * const resolver = new UAIDResolver();
52
+ * const result = await resolver.resolve('uaid:aid:0x8004...;uid=42;proto=erc8004');
53
+ * if (result.resolved) {
54
+ * console.log(result.identity?.paymentAddress);
55
+ * }
56
+ * ```
57
+ */
58
+ async resolve(uaid) {
59
+ // Check cache
60
+ const cached = this.cache.get(uaid);
61
+ if (cached && cached.expiresAt > Date.now()) {
62
+ return cached.result;
63
+ }
64
+ try {
65
+ const response = await this.brokerRequest('GET', `/agents/resolve?uaid=${encodeURIComponent(uaid)}`);
66
+ if (!response.ok) {
67
+ const result = {
68
+ resolved: false, uaid, identity: null, protocol: 'unknown',
69
+ registryVerified: false, error: `Registry returned ${response.status}`,
70
+ };
71
+ return result;
72
+ }
73
+ const data = await response.json();
74
+ const identity = {
75
+ agentId: String(data.agentId ?? data.nativeId ?? ''),
76
+ owner: data.owner ?? data.controller ?? '',
77
+ agentURI: data.agentURI ?? data.metadataUri ?? '',
78
+ paymentAddress: data.paymentAddress ?? data.agentWallet ?? '',
79
+ registrationFile: data.registrationFile ?? null,
80
+ protocol: data.protocol ?? 'unknown',
81
+ chain: data.chain ?? '',
82
+ uaid,
83
+ };
84
+ const result = {
85
+ resolved: true, uaid, identity,
86
+ protocol: data.protocol ?? 'unknown',
87
+ chain: data.chain,
88
+ trustScore: data.trustScore,
89
+ registryVerified: data.verified ?? false,
90
+ };
91
+ // Cache the result
92
+ this.cache.set(uaid, { result, expiresAt: Date.now() + this.cacheTtlMs });
93
+ return result;
94
+ }
95
+ catch (error) {
96
+ const message = error instanceof Error ? error.message : String(error);
97
+ return {
98
+ resolved: false, uaid, identity: null, protocol: 'unknown',
99
+ registryVerified: false, error: `Resolution failed: ${message}`,
100
+ };
101
+ }
102
+ }
103
+ /**
104
+ * Search the HOL registry for agents matching criteria.
105
+ *
106
+ * @param query - Search terms (name, capability, protocol)
107
+ * @param options - Optional filters
108
+ * @returns Array of matching UAIDResolution results
109
+ */
110
+ async search(query, options) {
111
+ try {
112
+ const params = new URLSearchParams({ q: query });
113
+ if (options?.protocol)
114
+ params.set('protocol', options.protocol);
115
+ if (options?.limit)
116
+ params.set('limit', String(options.limit));
117
+ if (options?.minTrustScore)
118
+ params.set('minTrust', String(options.minTrustScore));
119
+ const response = await this.brokerRequest('GET', `/agents/search?${params}`);
120
+ if (!response.ok)
121
+ return [];
122
+ const data = await response.json();
123
+ const results = (data.agents ?? []).map((agent) => ({
124
+ resolved: true,
125
+ uaid: agent.uaid,
126
+ identity: {
127
+ agentId: String(agent.agentId ?? agent.nativeId ?? ''),
128
+ owner: (agent.owner ?? agent.controller ?? ''),
129
+ agentURI: (agent.agentURI ?? agent.metadataUri ?? ''),
130
+ paymentAddress: (agent.paymentAddress ?? agent.agentWallet ?? ''),
131
+ registrationFile: (agent.registrationFile ?? null),
132
+ protocol: (agent.protocol ?? 'unknown'),
133
+ chain: (agent.chain ?? ''),
134
+ uaid: agent.uaid,
135
+ },
136
+ protocol: (agent.protocol ?? 'unknown'),
137
+ chain: agent.chain,
138
+ trustScore: agent.trustScore,
139
+ registryVerified: (agent.verified ?? false),
140
+ }));
141
+ return results;
142
+ }
143
+ catch {
144
+ return [];
145
+ }
146
+ }
147
+ // ── ERC-8004 ↔ UAID bridge ────────────────────────────────────────────────
148
+ /**
149
+ * Convert an ERC-8004 AgentIdentity to a UniversalAgentIdentity.
150
+ *
151
+ * Useful when you already have an on-chain identity and want to work
152
+ * with the universal format (e.g., for cross-chain discovery).
153
+ */
154
+ erc8004ToUniversal(identity, chain) {
155
+ const chainId = EVM_CHAIN_IDS[chain];
156
+ return {
157
+ agentId: identity.agentId.toString(),
158
+ owner: identity.owner,
159
+ agentURI: identity.agentURI,
160
+ paymentAddress: identity.agentWallet,
161
+ registrationFile: identity.registrationFile,
162
+ protocol: 'erc8004',
163
+ chain: `eip155:${chainId}`,
164
+ uaid: `uaid:aid:eip155:${chainId}:${identity.owner};uid=${identity.agentId};proto=erc8004`,
165
+ };
166
+ }
167
+ /**
168
+ * Build a UAID string for an ERC-8004 agent.
169
+ *
170
+ * This creates the identifier — it does NOT register with the HOL registry.
171
+ * Use registerERC8004Agent() to make the agent discoverable cross-chain.
172
+ */
173
+ buildERC8004UAID(agentId, chain, ownerAddress) {
174
+ const chainId = EVM_CHAIN_IDS[chain];
175
+ return `uaid:aid:eip155:${chainId}:${ownerAddress};uid=${agentId};proto=erc8004`;
176
+ }
177
+ /**
178
+ * Register an ERC-8004 agent in the HOL registry for cross-chain discovery.
179
+ *
180
+ * After registration, agents on Solana, Hedera, or any protocol can
181
+ * discover and verify this agent's identity via its UAID.
182
+ *
183
+ * Requires an API key with write permissions.
184
+ *
185
+ * @param params - Registration parameters
186
+ * @returns The assigned UAID
187
+ */
188
+ async registerERC8004Agent(params) {
189
+ if (!this.apiKey) {
190
+ throw new Error('UAIDResolver: API key required for registration. Get one at https://hol.org');
191
+ }
192
+ const chainId = EVM_CHAIN_IDS[params.chain];
193
+ const uaid = `uaid:aid:eip155:${chainId}:${params.registryAddress ?? '0x8004A169FB4a3325136EB29fA0ceB6D2e539a432'};uid=${params.agentId};proto=erc8004`;
194
+ const response = await this.brokerRequest('POST', '/agents/register', {
195
+ uaid,
196
+ protocol: 'erc8004',
197
+ chain: `eip155:${chainId}`,
198
+ agentId: params.agentId.toString(),
199
+ name: params.name,
200
+ description: params.description,
201
+ capabilities: params.capabilities ?? [],
202
+ registryAddress: params.registryAddress ?? '0x8004A169FB4a3325136EB29fA0ceB6D2e539a432',
203
+ });
204
+ if (!response.ok) {
205
+ const errorBody = await response.text().catch(() => '');
206
+ throw new Error(`UAIDResolver: Registration failed (${response.status}): ${errorBody}`);
207
+ }
208
+ const data = await response.json();
209
+ return data.uaid ?? uaid;
210
+ }
211
+ // ── Verification ──────────────────────────────────────────────────────────
212
+ /**
213
+ * Verify an agent's identity via UAID — works across any chain.
214
+ *
215
+ * This is the cross-chain equivalent of ERC8004Client.lookupAgentIdentity().
216
+ * For EVM agents, it verifies the UAID maps to a valid on-chain ERC-8004 token.
217
+ * For non-EVM agents, it verifies through the registry's native trust mechanism.
218
+ *
219
+ * @param uaid - Universal Agent Identifier to verify
220
+ * @returns Verification result
221
+ */
222
+ async verify(uaid) {
223
+ const resolution = await this.resolve(uaid);
224
+ if (!resolution.resolved || !resolution.identity) {
225
+ return {
226
+ verified: false,
227
+ identity: null,
228
+ trustScore: 0,
229
+ protocol: resolution.protocol,
230
+ error: resolution.error ?? 'Agent not found in registry',
231
+ };
232
+ }
233
+ return {
234
+ verified: resolution.registryVerified,
235
+ identity: resolution.identity,
236
+ trustScore: resolution.trustScore ?? 0,
237
+ protocol: resolution.protocol,
238
+ };
239
+ }
240
+ // ── Utility ───────────────────────────────────────────────────────────────
241
+ /**
242
+ * Parse a UAID string into its components.
243
+ *
244
+ * Format: `uaid:aid:<identifier>;uid=<unique-id>;proto=<protocol>[;nativeId=<id>]`
245
+ */
246
+ static parseUAID(uaid) {
247
+ if (!uaid.startsWith('uaid:'))
248
+ return null;
249
+ const parts = uaid.split(';');
250
+ const aidPart = parts.find(p => p.startsWith('uaid:aid:'));
251
+ const uidPart = parts.find(p => p.startsWith('uid='));
252
+ const protoPart = parts.find(p => p.startsWith('proto='));
253
+ const nativeIdPart = parts.find(p => p.startsWith('nativeId='));
254
+ if (!aidPart || !uidPart || !protoPart)
255
+ return null;
256
+ return {
257
+ raw: uaid,
258
+ aid: aidPart.replace('uaid:aid:', ''),
259
+ uid: uidPart.replace('uid=', ''),
260
+ protocol: protoPart.replace('proto=', ''),
261
+ nativeId: nativeIdPart?.replace('nativeId=', ''),
262
+ };
263
+ }
264
+ /** Clear the resolution cache */
265
+ clearCache() {
266
+ this.cache.clear();
267
+ }
268
+ // ── Private ───────────────────────────────────────────────────────────────
269
+ async brokerRequest(method, path, body) {
270
+ const url = `${this.brokerUrl}${path}`;
271
+ const headers = {
272
+ 'Accept': 'application/json',
273
+ 'User-Agent': 'agentwallet-sdk/uaid-resolver',
274
+ };
275
+ if (this.apiKey) {
276
+ headers['Authorization'] = `Bearer ${this.apiKey}`;
277
+ }
278
+ if (body) {
279
+ headers['Content-Type'] = 'application/json';
280
+ }
281
+ const controller = new AbortController();
282
+ const timeout = setTimeout(() => controller.abort(), this.timeoutMs);
283
+ try {
284
+ return await fetch(url, {
285
+ method,
286
+ headers,
287
+ body: body ? JSON.stringify(body) : undefined,
288
+ signal: controller.signal,
289
+ });
290
+ }
291
+ finally {
292
+ clearTimeout(timeout);
293
+ }
294
+ }
295
+ }
296
+ //# sourceMappingURL=uaid.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"uaid.js","sourceRoot":"","sources":["../../src/identity/uaid.ts"],"names":[],"mappings":"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"}