@agirails/sdk 2.2.0 → 2.2.2
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/ACTPClient.d.ts +200 -0
- package/dist/ACTPClient.d.ts.map +1 -1
- package/dist/ACTPClient.js +266 -2
- package/dist/ACTPClient.js.map +1 -1
- package/dist/abi/ACTPKernel.json +16 -0
- package/dist/adapters/AdapterRegistry.d.ts +140 -0
- package/dist/adapters/AdapterRegistry.d.ts.map +1 -0
- package/dist/adapters/AdapterRegistry.js +166 -0
- package/dist/adapters/AdapterRegistry.js.map +1 -0
- package/dist/adapters/AdapterRouter.d.ts +165 -0
- package/dist/adapters/AdapterRouter.d.ts.map +1 -0
- package/dist/adapters/AdapterRouter.js +350 -0
- package/dist/adapters/AdapterRouter.js.map +1 -0
- package/dist/adapters/BaseAdapter.d.ts +17 -0
- package/dist/adapters/BaseAdapter.d.ts.map +1 -1
- package/dist/adapters/BaseAdapter.js +21 -0
- package/dist/adapters/BaseAdapter.js.map +1 -1
- package/dist/adapters/BasicAdapter.d.ts +72 -3
- package/dist/adapters/BasicAdapter.d.ts.map +1 -1
- package/dist/adapters/BasicAdapter.js +170 -2
- package/dist/adapters/BasicAdapter.js.map +1 -1
- package/dist/adapters/IAdapter.d.ts +230 -0
- package/dist/adapters/IAdapter.d.ts.map +1 -0
- package/dist/adapters/IAdapter.js +44 -0
- package/dist/adapters/IAdapter.js.map +1 -0
- package/dist/adapters/StandardAdapter.d.ts +70 -1
- package/dist/adapters/StandardAdapter.d.ts.map +1 -1
- package/dist/adapters/StandardAdapter.js +184 -0
- package/dist/adapters/StandardAdapter.js.map +1 -1
- package/dist/adapters/X402Adapter.d.ts +208 -0
- package/dist/adapters/X402Adapter.d.ts.map +1 -0
- package/dist/adapters/X402Adapter.js +423 -0
- package/dist/adapters/X402Adapter.js.map +1 -0
- package/dist/adapters/index.d.ts +8 -0
- package/dist/adapters/index.d.ts.map +1 -1
- package/dist/adapters/index.js +19 -1
- package/dist/adapters/index.js.map +1 -1
- package/dist/cli/commands/init.d.ts +4 -0
- package/dist/cli/commands/init.d.ts.map +1 -1
- package/dist/cli/commands/init.js +184 -4
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/config/networks.js +3 -3
- package/dist/config/networks.js.map +1 -1
- package/dist/erc8004/ERC8004Bridge.d.ts +155 -0
- package/dist/erc8004/ERC8004Bridge.d.ts.map +1 -0
- package/dist/erc8004/ERC8004Bridge.js +325 -0
- package/dist/erc8004/ERC8004Bridge.js.map +1 -0
- package/dist/erc8004/ReputationReporter.d.ts +223 -0
- package/dist/erc8004/ReputationReporter.d.ts.map +1 -0
- package/dist/erc8004/ReputationReporter.js +266 -0
- package/dist/erc8004/ReputationReporter.js.map +1 -0
- package/dist/erc8004/index.d.ts +36 -0
- package/dist/erc8004/index.d.ts.map +1 -0
- package/dist/erc8004/index.js +46 -0
- package/dist/erc8004/index.js.map +1 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +21 -2
- package/dist/index.js.map +1 -1
- package/dist/protocol/ACTPKernel.d.ts +1 -1
- package/dist/protocol/ACTPKernel.d.ts.map +1 -1
- package/dist/protocol/ACTPKernel.js +16 -7
- package/dist/protocol/ACTPKernel.js.map +1 -1
- package/dist/runtime/BlockchainRuntime.d.ts.map +1 -1
- package/dist/runtime/BlockchainRuntime.js +2 -0
- package/dist/runtime/BlockchainRuntime.js.map +1 -1
- package/dist/runtime/IACTPRuntime.d.ts +6 -0
- package/dist/runtime/IACTPRuntime.d.ts.map +1 -1
- package/dist/runtime/MockRuntime.d.ts +12 -0
- package/dist/runtime/MockRuntime.d.ts.map +1 -1
- package/dist/runtime/MockRuntime.js +41 -0
- package/dist/runtime/MockRuntime.js.map +1 -1
- package/dist/runtime/types/MockState.d.ts +6 -0
- package/dist/runtime/types/MockState.d.ts.map +1 -1
- package/dist/runtime/types/MockState.js.map +1 -1
- package/dist/types/adapter.d.ts +359 -0
- package/dist/types/adapter.d.ts.map +1 -0
- package/dist/types/adapter.js +115 -0
- package/dist/types/adapter.js.map +1 -0
- package/dist/types/erc8004.d.ts +184 -0
- package/dist/types/erc8004.d.ts.map +1 -0
- package/dist/types/erc8004.js +132 -0
- package/dist/types/erc8004.js.map +1 -0
- package/dist/types/index.d.ts +3 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +3 -0
- package/dist/types/index.js.map +1 -1
- package/dist/types/transaction.d.ts +12 -0
- package/dist/types/transaction.d.ts.map +1 -1
- package/dist/types/x402.d.ts +162 -0
- package/dist/types/x402.d.ts.map +1 -0
- package/dist/types/x402.js +162 -0
- package/dist/types/x402.js.map +1 -0
- package/package.json +3 -2
- package/src/ACTPClient.ts +318 -2
- package/src/abi/ACTPKernel.json +16 -0
- package/src/adapters/AdapterRegistry.ts +173 -0
- package/src/adapters/AdapterRouter.ts +417 -0
- package/src/adapters/BaseAdapter.ts +25 -0
- package/src/adapters/BasicAdapter.ts +199 -3
- package/src/adapters/IAdapter.ts +292 -0
- package/src/adapters/StandardAdapter.ts +220 -1
- package/src/adapters/X402Adapter.ts +653 -0
- package/src/adapters/index.ts +27 -0
- package/src/cli/commands/init.ts +208 -3
- package/src/config/networks.ts +3 -3
- package/src/erc8004/ERC8004Bridge.ts +461 -0
- package/src/erc8004/ReputationReporter.ts +472 -0
- package/src/erc8004/index.ts +61 -0
- package/src/index.ts +43 -0
- package/src/protocol/ACTPKernel.ts +26 -7
- package/src/runtime/BlockchainRuntime.ts +2 -0
- package/src/runtime/IACTPRuntime.ts +6 -0
- package/src/runtime/MockRuntime.ts +42 -0
- package/src/runtime/types/MockState.ts +7 -0
- package/src/types/adapter.ts +296 -0
- package/src/types/erc8004.ts +293 -0
- package/src/types/index.ts +3 -0
- package/src/types/transaction.ts +12 -0
- package/src/types/x402.ts +219 -0
|
@@ -0,0 +1,325 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* ERC-8004 Identity Bridge
|
|
4
|
+
*
|
|
5
|
+
* READ-ONLY access to ERC-8004 Identity Registry.
|
|
6
|
+
* Resolves agent IDs to wallet addresses for ACTP payments.
|
|
7
|
+
*
|
|
8
|
+
* SECURITY NOTES:
|
|
9
|
+
* - All operations are view functions (no gas costs)
|
|
10
|
+
* - Safe to call without signer
|
|
11
|
+
* - Caches results to minimize RPC calls
|
|
12
|
+
* - Handles network errors gracefully
|
|
13
|
+
*
|
|
14
|
+
* @example
|
|
15
|
+
* ```typescript
|
|
16
|
+
* const bridge = new ERC8004Bridge({ network: 'base-sepolia' });
|
|
17
|
+
*
|
|
18
|
+
* // Check if agent exists
|
|
19
|
+
* const exists = await bridge.verifyAgent('12345');
|
|
20
|
+
*
|
|
21
|
+
* // Get wallet for payment
|
|
22
|
+
* const wallet = await bridge.getAgentWallet('12345');
|
|
23
|
+
*
|
|
24
|
+
* // Get full agent info
|
|
25
|
+
* const agent = await bridge.resolveAgent('12345');
|
|
26
|
+
* ```
|
|
27
|
+
*
|
|
28
|
+
* @module erc8004/ERC8004Bridge
|
|
29
|
+
*/
|
|
30
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
31
|
+
exports.ERC8004Bridge = void 0;
|
|
32
|
+
const ethers_1 = require("ethers");
|
|
33
|
+
const erc8004_1 = require("../types/erc8004");
|
|
34
|
+
// ============================================================================
|
|
35
|
+
// ERC8004Bridge
|
|
36
|
+
// ============================================================================
|
|
37
|
+
/**
|
|
38
|
+
* Bridge for reading from ERC-8004 Identity Registry.
|
|
39
|
+
*
|
|
40
|
+
* Provides methods to:
|
|
41
|
+
* - Verify agent existence
|
|
42
|
+
* - Get agent wallet address for payments
|
|
43
|
+
* - Resolve full agent info including metadata
|
|
44
|
+
* - List agents owned by an address
|
|
45
|
+
*/
|
|
46
|
+
class ERC8004Bridge {
|
|
47
|
+
constructor(config) {
|
|
48
|
+
this.network = config.network;
|
|
49
|
+
this.fetchFn = config.fetchFn ?? fetch;
|
|
50
|
+
this.cacheTimeMs = config.cacheTimeMs ?? 60000;
|
|
51
|
+
this.metadataTimeoutMs = config.metadataTimeoutMs ?? 10000;
|
|
52
|
+
this.cache = new Map();
|
|
53
|
+
// Use injected contract for testing
|
|
54
|
+
if (config._testContract) {
|
|
55
|
+
this.provider = null;
|
|
56
|
+
this.registry = config._testContract;
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
// Setup provider
|
|
60
|
+
const rpcUrl = config.rpcUrl ?? erc8004_1.ERC8004_DEFAULT_RPC[config.network];
|
|
61
|
+
this.provider = new ethers_1.ethers.JsonRpcProvider(rpcUrl);
|
|
62
|
+
// Setup registry contract
|
|
63
|
+
const registryAddress = config.registryAddress ?? erc8004_1.ERC8004_IDENTITY_REGISTRY[config.network];
|
|
64
|
+
if (registryAddress === ethers_1.ethers.ZeroAddress) {
|
|
65
|
+
console.warn(`[ERC8004] Registry not deployed on ${config.network}. Using zero address.`);
|
|
66
|
+
}
|
|
67
|
+
this.registry = new ethers_1.ethers.Contract(registryAddress, erc8004_1.ERC8004_IDENTITY_ABI, this.provider);
|
|
68
|
+
}
|
|
69
|
+
// ==========================================================================
|
|
70
|
+
// Public Methods
|
|
71
|
+
// ==========================================================================
|
|
72
|
+
/**
|
|
73
|
+
* Verify agent exists in ERC-8004 Identity Registry.
|
|
74
|
+
*
|
|
75
|
+
* Safe to call frequently - uses cache and is a view function.
|
|
76
|
+
*
|
|
77
|
+
* @param agentId - ERC-8004 agent ID (uint256 as string)
|
|
78
|
+
* @returns true if agent exists, false otherwise
|
|
79
|
+
*/
|
|
80
|
+
async verifyAgent(agentId) {
|
|
81
|
+
// Validate format first
|
|
82
|
+
if (!this.isValidAgentId(agentId)) {
|
|
83
|
+
return false;
|
|
84
|
+
}
|
|
85
|
+
// Check cache
|
|
86
|
+
const cached = this.cache.get(agentId);
|
|
87
|
+
if (cached && cached.expiresAt > Date.now()) {
|
|
88
|
+
return true;
|
|
89
|
+
}
|
|
90
|
+
try {
|
|
91
|
+
const owner = await this.registry.ownerOf(agentId);
|
|
92
|
+
return owner !== ethers_1.ethers.ZeroAddress;
|
|
93
|
+
}
|
|
94
|
+
catch {
|
|
95
|
+
// ownerOf reverts for non-existent tokens (ERC-721 standard)
|
|
96
|
+
return false;
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* Get wallet address for receiving payments.
|
|
101
|
+
*
|
|
102
|
+
* Wallet priority:
|
|
103
|
+
* 1. metadata.paymentAddress (explicit payment destination)
|
|
104
|
+
* 2. metadata.wallet (alternative field name)
|
|
105
|
+
* 3. owner address (fallback)
|
|
106
|
+
*
|
|
107
|
+
* @param agentId - ERC-8004 agent ID
|
|
108
|
+
* @returns Checksummed wallet address
|
|
109
|
+
* @throws ERC8004Error if agent not found
|
|
110
|
+
*/
|
|
111
|
+
async getAgentWallet(agentId) {
|
|
112
|
+
const agent = await this.resolveAgent(agentId);
|
|
113
|
+
return agent.wallet;
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* Resolve full agent info from ERC-8004.
|
|
117
|
+
*
|
|
118
|
+
* Fetches on-chain data (owner, agentURI) and off-chain metadata.
|
|
119
|
+
* Results are cached for cacheTimeMs.
|
|
120
|
+
*
|
|
121
|
+
* @param agentId - ERC-8004 agent ID
|
|
122
|
+
* @returns Full agent info including metadata
|
|
123
|
+
* @throws ERC8004Error if agent not found or invalid ID
|
|
124
|
+
*/
|
|
125
|
+
async resolveAgent(agentId) {
|
|
126
|
+
// Check cache first
|
|
127
|
+
const cached = this.cache.get(agentId);
|
|
128
|
+
if (cached && cached.expiresAt > Date.now()) {
|
|
129
|
+
return cached.agent;
|
|
130
|
+
}
|
|
131
|
+
// Validate format
|
|
132
|
+
if (!this.isValidAgentId(agentId)) {
|
|
133
|
+
throw new erc8004_1.ERC8004Error(`Invalid agent ID format: "${agentId}"`, erc8004_1.ERC8004ErrorCode.INVALID_AGENT_ID, agentId);
|
|
134
|
+
}
|
|
135
|
+
// Fetch on-chain data
|
|
136
|
+
let owner;
|
|
137
|
+
let agentURI;
|
|
138
|
+
try {
|
|
139
|
+
[owner, agentURI] = await Promise.all([
|
|
140
|
+
this.registry.ownerOf(agentId),
|
|
141
|
+
this.registry.getAgentURI(agentId),
|
|
142
|
+
]);
|
|
143
|
+
}
|
|
144
|
+
catch (error) {
|
|
145
|
+
// Check if it's a "nonexistent token" error
|
|
146
|
+
const isNotFound = error instanceof Error &&
|
|
147
|
+
(error.message.includes('nonexistent') ||
|
|
148
|
+
error.message.includes('ERC721') ||
|
|
149
|
+
error.message.includes('invalid token'));
|
|
150
|
+
if (isNotFound) {
|
|
151
|
+
throw new erc8004_1.ERC8004Error(`Agent ${agentId} not found in ERC-8004 registry`, erc8004_1.ERC8004ErrorCode.AGENT_NOT_FOUND, agentId);
|
|
152
|
+
}
|
|
153
|
+
throw new erc8004_1.ERC8004Error(`Failed to fetch agent ${agentId}: ${error instanceof Error ? error.message : 'Unknown error'}`, erc8004_1.ERC8004ErrorCode.NETWORK_ERROR, agentId, error instanceof Error ? error : undefined);
|
|
154
|
+
}
|
|
155
|
+
// Check owner is valid
|
|
156
|
+
if (owner === ethers_1.ethers.ZeroAddress) {
|
|
157
|
+
throw new erc8004_1.ERC8004Error(`Agent ${agentId} not found in ERC-8004 registry`, erc8004_1.ERC8004ErrorCode.AGENT_NOT_FOUND, agentId);
|
|
158
|
+
}
|
|
159
|
+
// Fetch metadata (may return undefined if fetch fails)
|
|
160
|
+
const metadata = await this.fetchMetadata(agentURI, agentId);
|
|
161
|
+
// Determine wallet address
|
|
162
|
+
// Priority: paymentAddress > wallet > owner
|
|
163
|
+
let walletAddress = owner;
|
|
164
|
+
if (metadata?.paymentAddress && this.isValidAddress(metadata.paymentAddress)) {
|
|
165
|
+
walletAddress = metadata.paymentAddress;
|
|
166
|
+
}
|
|
167
|
+
else if (metadata?.wallet && this.isValidAddress(metadata.wallet)) {
|
|
168
|
+
walletAddress = metadata.wallet;
|
|
169
|
+
}
|
|
170
|
+
// Build agent object
|
|
171
|
+
const agent = {
|
|
172
|
+
agentId,
|
|
173
|
+
owner: ethers_1.ethers.getAddress(owner), // Checksummed
|
|
174
|
+
wallet: ethers_1.ethers.getAddress(walletAddress), // Checksummed
|
|
175
|
+
agentURI,
|
|
176
|
+
metadata,
|
|
177
|
+
network: this.network,
|
|
178
|
+
};
|
|
179
|
+
// Cache result
|
|
180
|
+
this.cache.set(agentId, {
|
|
181
|
+
agent,
|
|
182
|
+
expiresAt: Date.now() + this.cacheTimeMs,
|
|
183
|
+
});
|
|
184
|
+
return agent;
|
|
185
|
+
}
|
|
186
|
+
/**
|
|
187
|
+
* Get all agent IDs owned by an address.
|
|
188
|
+
*
|
|
189
|
+
* @param owner - Owner address to query
|
|
190
|
+
* @returns Array of agent IDs (may be empty)
|
|
191
|
+
*/
|
|
192
|
+
async getAgentsByOwner(owner) {
|
|
193
|
+
if (!this.isValidAddress(owner)) {
|
|
194
|
+
return [];
|
|
195
|
+
}
|
|
196
|
+
try {
|
|
197
|
+
const balance = await this.registry.balanceOf(owner);
|
|
198
|
+
const balanceNum = Number(balance);
|
|
199
|
+
if (balanceNum === 0) {
|
|
200
|
+
return [];
|
|
201
|
+
}
|
|
202
|
+
const agentIds = [];
|
|
203
|
+
for (let i = 0; i < balanceNum; i++) {
|
|
204
|
+
const agentId = await this.registry.tokenOfOwnerByIndex(owner, i);
|
|
205
|
+
agentIds.push(agentId.toString());
|
|
206
|
+
}
|
|
207
|
+
return agentIds;
|
|
208
|
+
}
|
|
209
|
+
catch (error) {
|
|
210
|
+
console.warn(`[ERC8004] Failed to get agents for owner ${owner}:`, error);
|
|
211
|
+
return [];
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
/**
|
|
215
|
+
* Clear all cached entries.
|
|
216
|
+
* Useful for testing or forcing fresh data.
|
|
217
|
+
*/
|
|
218
|
+
clearCache() {
|
|
219
|
+
this.cache.clear();
|
|
220
|
+
}
|
|
221
|
+
/**
|
|
222
|
+
* Get cache statistics (for debugging).
|
|
223
|
+
*/
|
|
224
|
+
getCacheStats() {
|
|
225
|
+
return {
|
|
226
|
+
size: this.cache.size,
|
|
227
|
+
network: this.network,
|
|
228
|
+
};
|
|
229
|
+
}
|
|
230
|
+
// ==========================================================================
|
|
231
|
+
// Private Methods
|
|
232
|
+
// ==========================================================================
|
|
233
|
+
/**
|
|
234
|
+
* Validate agent ID format.
|
|
235
|
+
* Agent IDs are uint256 values (0 to 2^256-1).
|
|
236
|
+
*/
|
|
237
|
+
isValidAgentId(agentId) {
|
|
238
|
+
if (!agentId || typeof agentId !== 'string') {
|
|
239
|
+
return false;
|
|
240
|
+
}
|
|
241
|
+
// Must not look like an Ethereum address or URL
|
|
242
|
+
if (agentId.startsWith('0x') || agentId.includes('://')) {
|
|
243
|
+
return false;
|
|
244
|
+
}
|
|
245
|
+
try {
|
|
246
|
+
const bn = BigInt(agentId);
|
|
247
|
+
return bn >= 0n && bn < 2n ** 256n;
|
|
248
|
+
}
|
|
249
|
+
catch {
|
|
250
|
+
return false;
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
/**
|
|
254
|
+
* Validate Ethereum address format.
|
|
255
|
+
*/
|
|
256
|
+
isValidAddress(address) {
|
|
257
|
+
try {
|
|
258
|
+
ethers_1.ethers.getAddress(address);
|
|
259
|
+
return true;
|
|
260
|
+
}
|
|
261
|
+
catch {
|
|
262
|
+
return false;
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
/**
|
|
266
|
+
* Fetch and parse metadata from agentURI.
|
|
267
|
+
*
|
|
268
|
+
* Handles:
|
|
269
|
+
* - IPFS URIs (ipfs://...)
|
|
270
|
+
* - HTTPS URIs
|
|
271
|
+
* - Timeout protection
|
|
272
|
+
* - Parse errors
|
|
273
|
+
*
|
|
274
|
+
* Returns undefined on any failure (never throws).
|
|
275
|
+
*/
|
|
276
|
+
async fetchMetadata(agentURI, agentId) {
|
|
277
|
+
if (!agentURI) {
|
|
278
|
+
return undefined;
|
|
279
|
+
}
|
|
280
|
+
try {
|
|
281
|
+
// Convert IPFS URI to HTTP gateway
|
|
282
|
+
let url = agentURI;
|
|
283
|
+
if (url.startsWith('ipfs://')) {
|
|
284
|
+
const cid = url.slice(7);
|
|
285
|
+
url = `https://ipfs.io/ipfs/${cid}`;
|
|
286
|
+
}
|
|
287
|
+
// Validate URL
|
|
288
|
+
if (!url.startsWith('http://') && !url.startsWith('https://')) {
|
|
289
|
+
console.warn(`[ERC8004] Invalid agentURI scheme for ${agentId}: ${url}`);
|
|
290
|
+
return undefined;
|
|
291
|
+
}
|
|
292
|
+
// Fetch with timeout
|
|
293
|
+
const controller = new AbortController();
|
|
294
|
+
const timeoutId = setTimeout(() => controller.abort(), this.metadataTimeoutMs);
|
|
295
|
+
try {
|
|
296
|
+
const response = await this.fetchFn(url, {
|
|
297
|
+
headers: { Accept: 'application/json' },
|
|
298
|
+
signal: controller.signal,
|
|
299
|
+
});
|
|
300
|
+
clearTimeout(timeoutId);
|
|
301
|
+
if (!response.ok) {
|
|
302
|
+
console.warn(`[ERC8004] Metadata fetch failed for ${agentId}: HTTP ${response.status}`);
|
|
303
|
+
return undefined;
|
|
304
|
+
}
|
|
305
|
+
const data = await response.json();
|
|
306
|
+
return data;
|
|
307
|
+
}
|
|
308
|
+
finally {
|
|
309
|
+
clearTimeout(timeoutId);
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
catch (error) {
|
|
313
|
+
// Log but don't throw - metadata is optional
|
|
314
|
+
const errorMessage = error instanceof Error
|
|
315
|
+
? error.name === 'AbortError'
|
|
316
|
+
? 'timeout'
|
|
317
|
+
: error.message
|
|
318
|
+
: 'unknown error';
|
|
319
|
+
console.warn(`[ERC8004] Metadata fetch failed for ${agentId}: ${errorMessage}`);
|
|
320
|
+
return undefined;
|
|
321
|
+
}
|
|
322
|
+
}
|
|
323
|
+
}
|
|
324
|
+
exports.ERC8004Bridge = ERC8004Bridge;
|
|
325
|
+
//# sourceMappingURL=ERC8004Bridge.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ERC8004Bridge.js","sourceRoot":"","sources":["../../src/erc8004/ERC8004Bridge.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,223 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ERC-8004 Reputation Reporter
|
|
3
|
+
*
|
|
4
|
+
* WRITES to ERC-8004 Reputation Registry after ACTP settlements.
|
|
5
|
+
*
|
|
6
|
+
* CRITICAL SECURITY NOTES:
|
|
7
|
+
* 1. Requires signer (pays gas) - typically the requester
|
|
8
|
+
* 2. Caller MUST NOT be agent owner (ERC-8004 restriction)
|
|
9
|
+
* 3. Uses feedbackHash = keccak256(txId) for replay protection
|
|
10
|
+
* 4. Failures are logged but NEVER block ACTP settlement
|
|
11
|
+
* 5. Local dedup prevents double-reporting in same session
|
|
12
|
+
*
|
|
13
|
+
* WHEN TO CALL:
|
|
14
|
+
* - reportSettlement(): After successful release() (state = SETTLED)
|
|
15
|
+
* - reportDispute(): After dispute resolution
|
|
16
|
+
*
|
|
17
|
+
* FAILURE HANDLING:
|
|
18
|
+
* - All methods return null on failure (never throw)
|
|
19
|
+
* - Settlement/dispute already succeeded - reputation is bonus
|
|
20
|
+
* - Log warnings for debugging
|
|
21
|
+
*
|
|
22
|
+
* @example
|
|
23
|
+
* ```typescript
|
|
24
|
+
* const reporter = new ReputationReporter({
|
|
25
|
+
* network: 'base-sepolia',
|
|
26
|
+
* signer: requesterWallet,
|
|
27
|
+
* });
|
|
28
|
+
*
|
|
29
|
+
* // After successful release
|
|
30
|
+
* const txHash = await reporter.reportSettlement({
|
|
31
|
+
* agentId: '12345',
|
|
32
|
+
* txId: result.txId,
|
|
33
|
+
* capability: 'code_generation',
|
|
34
|
+
* });
|
|
35
|
+
*
|
|
36
|
+
* if (txHash) {
|
|
37
|
+
* console.log('Reputation reported:', txHash);
|
|
38
|
+
* } else {
|
|
39
|
+
* console.warn('Report failed (settlement still succeeded)');
|
|
40
|
+
* }
|
|
41
|
+
* ```
|
|
42
|
+
*
|
|
43
|
+
* @module erc8004/ReputationReporter
|
|
44
|
+
*/
|
|
45
|
+
import { Signer } from 'ethers';
|
|
46
|
+
import { ERC8004Network } from '../types/erc8004';
|
|
47
|
+
/**
|
|
48
|
+
* Transaction receipt interface for reputation reports.
|
|
49
|
+
*/
|
|
50
|
+
interface TransactionReceipt {
|
|
51
|
+
hash: string;
|
|
52
|
+
blockNumber: number;
|
|
53
|
+
gasUsed: bigint;
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Transaction response interface.
|
|
57
|
+
*/
|
|
58
|
+
interface TransactionResponse {
|
|
59
|
+
wait(): Promise<TransactionReceipt>;
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* Interface for ERC-8004 Reputation Registry contract.
|
|
63
|
+
* Used for testing with mock implementations.
|
|
64
|
+
*/
|
|
65
|
+
export interface IERC8004ReputationRegistry {
|
|
66
|
+
giveFeedback(agentId: string, value: number, valueDecimals: number, tag1: string, tag2: string, endpoint: string, feedbackURI: string, feedbackHash: string, txOptions?: {
|
|
67
|
+
gasLimit?: bigint;
|
|
68
|
+
}): Promise<TransactionResponse>;
|
|
69
|
+
getSummary(agentId: string, clientAddresses: string[], tag1: string, tag2: string): Promise<[bigint, bigint, number]>;
|
|
70
|
+
revokeLatest(agentId: string, feedbackIndex: bigint): Promise<TransactionResponse>;
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* Configuration for ReputationReporter.
|
|
74
|
+
*/
|
|
75
|
+
export interface ReputationReporterConfig {
|
|
76
|
+
/** Target network */
|
|
77
|
+
network: ERC8004Network;
|
|
78
|
+
/** Signer for transactions (pays gas) */
|
|
79
|
+
signer: Signer;
|
|
80
|
+
/** Override registry address (optional, for testing) */
|
|
81
|
+
registryAddress?: string;
|
|
82
|
+
/** Gas limit override (optional) */
|
|
83
|
+
gasLimit?: bigint;
|
|
84
|
+
/**
|
|
85
|
+
* Injected contract instance (optional, for testing).
|
|
86
|
+
* If provided, skips creating a real ethers Contract.
|
|
87
|
+
* @internal
|
|
88
|
+
*/
|
|
89
|
+
_testContract?: IERC8004ReputationRegistry;
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* Parameters for reporting a successful settlement.
|
|
93
|
+
*/
|
|
94
|
+
export interface ReportSettlementParams {
|
|
95
|
+
/** ERC-8004 agent ID */
|
|
96
|
+
agentId: string;
|
|
97
|
+
/** ACTP transaction ID (used for replay protection) */
|
|
98
|
+
txId: string;
|
|
99
|
+
/** Agent capability (e.g., 'code_generation', 'data_analysis') */
|
|
100
|
+
capability?: string;
|
|
101
|
+
/** Service endpoint (optional) */
|
|
102
|
+
endpoint?: string;
|
|
103
|
+
/** Link to transaction details (optional, IPFS or HTTPS) */
|
|
104
|
+
feedbackURI?: string;
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* Parameters for reporting a dispute resolution.
|
|
108
|
+
*/
|
|
109
|
+
export interface ReportDisputeParams {
|
|
110
|
+
/** ERC-8004 agent ID */
|
|
111
|
+
agentId: string;
|
|
112
|
+
/** ACTP transaction ID */
|
|
113
|
+
txId: string;
|
|
114
|
+
/** true if agent won the dispute, false if requester won */
|
|
115
|
+
agentWon: boolean;
|
|
116
|
+
/** Agent capability (optional) */
|
|
117
|
+
capability?: string;
|
|
118
|
+
/** Dispute reason/details (optional, stored as feedbackURI) */
|
|
119
|
+
reason?: string;
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* Result of a reputation report.
|
|
123
|
+
*/
|
|
124
|
+
export interface ReportResult {
|
|
125
|
+
/** Transaction hash */
|
|
126
|
+
txHash: string;
|
|
127
|
+
/** Block number */
|
|
128
|
+
blockNumber: number;
|
|
129
|
+
/** Gas used */
|
|
130
|
+
gasUsed: bigint;
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* Reporter for submitting ACTP settlement outcomes to ERC-8004 Reputation.
|
|
134
|
+
*
|
|
135
|
+
* Designed to never block or fail the main ACTP flow.
|
|
136
|
+
* All errors are caught and logged, returning null on failure.
|
|
137
|
+
*/
|
|
138
|
+
export declare class ReputationReporter {
|
|
139
|
+
private readonly registry;
|
|
140
|
+
private readonly signer;
|
|
141
|
+
private readonly network;
|
|
142
|
+
private readonly gasLimit?;
|
|
143
|
+
/**
|
|
144
|
+
* Track reported txIds to prevent double-reporting in same session.
|
|
145
|
+
* Note: This is in-memory only, so restarts allow re-reporting.
|
|
146
|
+
* On-chain, feedbackHash provides permanent dedup.
|
|
147
|
+
*/
|
|
148
|
+
private readonly reportedTxIds;
|
|
149
|
+
constructor(config: ReputationReporterConfig);
|
|
150
|
+
/**
|
|
151
|
+
* Report successful ACTP settlement to ERC-8004 Reputation.
|
|
152
|
+
*
|
|
153
|
+
* Call this AFTER release() succeeds. Failure here does NOT affect settlement.
|
|
154
|
+
*
|
|
155
|
+
* Reports:
|
|
156
|
+
* - value: 1 (positive feedback)
|
|
157
|
+
* - valueDecimals: 0 (binary)
|
|
158
|
+
* - tag1: 'actp_settled'
|
|
159
|
+
* - tag2: capability
|
|
160
|
+
* - feedbackHash: keccak256(txId)
|
|
161
|
+
*
|
|
162
|
+
* @param params - Settlement details
|
|
163
|
+
* @returns ReportResult if successful, null if failed
|
|
164
|
+
*/
|
|
165
|
+
reportSettlement(params: ReportSettlementParams): Promise<ReportResult | null>;
|
|
166
|
+
/**
|
|
167
|
+
* Report ACTP dispute resolution to ERC-8004 Reputation.
|
|
168
|
+
*
|
|
169
|
+
* Call this after dispute is resolved (either party won).
|
|
170
|
+
*
|
|
171
|
+
* Reports:
|
|
172
|
+
* - value: 1 if agent won, -1 if requester won
|
|
173
|
+
* - valueDecimals: 0 (binary)
|
|
174
|
+
* - tag1: 'actp_dispute_won' or 'actp_dispute_lost'
|
|
175
|
+
* - tag2: capability
|
|
176
|
+
* - feedbackHash: keccak256(txId)
|
|
177
|
+
*
|
|
178
|
+
* @param params - Dispute details
|
|
179
|
+
* @returns ReportResult if successful, null if failed
|
|
180
|
+
*/
|
|
181
|
+
reportDispute(params: ReportDisputeParams): Promise<ReportResult | null>;
|
|
182
|
+
/**
|
|
183
|
+
* Get reputation summary for an agent.
|
|
184
|
+
*
|
|
185
|
+
* This is a READ operation (no gas cost).
|
|
186
|
+
*
|
|
187
|
+
* @param agentId - ERC-8004 agent ID
|
|
188
|
+
* @param tag1 - Filter by tag1 (optional, e.g., 'actp_settled')
|
|
189
|
+
* @returns Summary if successful, null if failed
|
|
190
|
+
*/
|
|
191
|
+
getAgentReputation(agentId: string, tag1?: string): Promise<{
|
|
192
|
+
count: number;
|
|
193
|
+
score: number;
|
|
194
|
+
} | null>;
|
|
195
|
+
/**
|
|
196
|
+
* Check if a transaction was already reported in this session.
|
|
197
|
+
*
|
|
198
|
+
* Note: This is local-only. For on-chain check, you'd need to
|
|
199
|
+
* query the feedbackHash mapping (not exposed in standard interface).
|
|
200
|
+
*
|
|
201
|
+
* @param txId - ACTP transaction ID
|
|
202
|
+
*/
|
|
203
|
+
isReported(txId: string): boolean;
|
|
204
|
+
/**
|
|
205
|
+
* Clear local dedup cache.
|
|
206
|
+
* Use when starting new session or for testing.
|
|
207
|
+
*/
|
|
208
|
+
clearReportedCache(): void;
|
|
209
|
+
/**
|
|
210
|
+
* Get reporter statistics.
|
|
211
|
+
*/
|
|
212
|
+
getStats(): {
|
|
213
|
+
network: ERC8004Network;
|
|
214
|
+
reportedCount: number;
|
|
215
|
+
};
|
|
216
|
+
/**
|
|
217
|
+
* Log error in consistent format.
|
|
218
|
+
* NEVER throws - errors are informational only.
|
|
219
|
+
*/
|
|
220
|
+
private logError;
|
|
221
|
+
}
|
|
222
|
+
export {};
|
|
223
|
+
//# sourceMappingURL=ReputationReporter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ReputationReporter.d.ts","sourceRoot":"","sources":["../../src/erc8004/ReputationReporter.ts"],"names":[],"mappings":"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"}
|