@xpr-agents/sdk 0.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 +165 -0
- package/dist/AgentRegistry.d.ts +182 -0
- package/dist/AgentRegistry.js +892 -0
- package/dist/EscrowRegistry.d.ts +253 -0
- package/dist/EscrowRegistry.js +731 -0
- package/dist/FeedbackRegistry.d.ts +83 -0
- package/dist/FeedbackRegistry.js +424 -0
- package/dist/ValidationRegistry.d.ts +115 -0
- package/dist/ValidationRegistry.js +638 -0
- package/dist/index.d.ts +25 -0
- package/dist/index.js +59 -0
- package/dist/types.d.ts +345 -0
- package/dist/types.js +4 -0
- package/dist/utils.d.ts +79 -0
- package/dist/utils.js +235 -0
- package/package.json +65 -0
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { Feedback, FeedbackConfig, AgentScore, Dispute, FeedbackListOptions, SubmitFeedbackData, TransactionResult, JsonRpc, ProtonSession } from './types';
|
|
2
|
+
export declare class FeedbackRegistry {
|
|
3
|
+
private rpc;
|
|
4
|
+
private session;
|
|
5
|
+
private contract;
|
|
6
|
+
constructor(rpc: JsonRpc, session?: ProtonSession, contract?: string);
|
|
7
|
+
/**
|
|
8
|
+
* Get feedback by ID
|
|
9
|
+
*/
|
|
10
|
+
getFeedback(id: number): Promise<Feedback | null>;
|
|
11
|
+
/**
|
|
12
|
+
* List feedback for an agent
|
|
13
|
+
*/
|
|
14
|
+
listFeedbackForAgent(agent: string, options?: FeedbackListOptions): Promise<Feedback[]>;
|
|
15
|
+
/**
|
|
16
|
+
* List feedback submitted by a reviewer
|
|
17
|
+
*/
|
|
18
|
+
listFeedbackByReviewer(reviewer: string, options?: FeedbackListOptions): Promise<Feedback[]>;
|
|
19
|
+
/**
|
|
20
|
+
* Get aggregated score for an agent
|
|
21
|
+
*/
|
|
22
|
+
getAgentScore(agent: string): Promise<AgentScore | null>;
|
|
23
|
+
/**
|
|
24
|
+
* Get dispute by ID
|
|
25
|
+
*/
|
|
26
|
+
getDispute(id: number): Promise<Dispute | null>;
|
|
27
|
+
/**
|
|
28
|
+
* Get disputes for a feedback
|
|
29
|
+
*/
|
|
30
|
+
getDisputesForFeedback(feedbackId: number): Promise<Dispute[]>;
|
|
31
|
+
/**
|
|
32
|
+
* Submit feedback for an agent
|
|
33
|
+
*/
|
|
34
|
+
submit(data: SubmitFeedbackData): Promise<TransactionResult>;
|
|
35
|
+
/**
|
|
36
|
+
* Dispute feedback
|
|
37
|
+
*/
|
|
38
|
+
dispute(feedbackId: number, reason: string, evidenceUri?: string): Promise<TransactionResult>;
|
|
39
|
+
/**
|
|
40
|
+
* Recalculate agent score (paginated).
|
|
41
|
+
*
|
|
42
|
+
* Recalculation is done in batches to avoid CPU exhaustion.
|
|
43
|
+
* - First call: offset=0, processes first `limit` feedbacks
|
|
44
|
+
* - Subsequent calls: use the next_offset from RecalcState
|
|
45
|
+
* - Recalculation expires after 1 hour if not completed
|
|
46
|
+
*
|
|
47
|
+
* @param agent - Agent account to recalculate
|
|
48
|
+
* @param offset - Must be 0 to start, or match next_offset to continue
|
|
49
|
+
* @param limit - Feedbacks to process per call (max 100)
|
|
50
|
+
*/
|
|
51
|
+
recalculate(agent: string, offset?: number, limit?: number): Promise<TransactionResult>;
|
|
52
|
+
/**
|
|
53
|
+
* Resolve a feedback dispute (owner only)
|
|
54
|
+
*/
|
|
55
|
+
resolve(disputeId: number, upheld: boolean, resolutionNotes: string): Promise<TransactionResult>;
|
|
56
|
+
/**
|
|
57
|
+
* Cancel an in-progress recalculation
|
|
58
|
+
*/
|
|
59
|
+
cancelRecalculation(agent: string): Promise<TransactionResult>;
|
|
60
|
+
/**
|
|
61
|
+
* Submit feedback with fee in one transaction.
|
|
62
|
+
*
|
|
63
|
+
* @param data - Feedback data
|
|
64
|
+
* @param amount - The feedback fee (e.g., "1.0000 XPR")
|
|
65
|
+
*/
|
|
66
|
+
submitWithFee(data: SubmitFeedbackData, amount: string): Promise<TransactionResult>;
|
|
67
|
+
/**
|
|
68
|
+
* Clean up old feedback entries (permissionless)
|
|
69
|
+
*/
|
|
70
|
+
cleanFeedback(agent: string, maxAge: number, maxDelete: number): Promise<TransactionResult>;
|
|
71
|
+
/**
|
|
72
|
+
* Clean up resolved disputes (permissionless)
|
|
73
|
+
*/
|
|
74
|
+
cleanDisputes(maxAge: number, maxDelete: number): Promise<TransactionResult>;
|
|
75
|
+
/**
|
|
76
|
+
* Get feedback contract configuration
|
|
77
|
+
*/
|
|
78
|
+
getConfig(): Promise<FeedbackConfig>;
|
|
79
|
+
private requireSession;
|
|
80
|
+
private parseFeedback;
|
|
81
|
+
private parseAgentScore;
|
|
82
|
+
private parseDispute;
|
|
83
|
+
}
|
|
@@ -0,0 +1,424 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.FeedbackRegistry = void 0;
|
|
4
|
+
const utils_1 = require("./utils");
|
|
5
|
+
const DEFAULT_CONTRACT = 'agentfeed';
|
|
6
|
+
class FeedbackRegistry {
|
|
7
|
+
constructor(rpc, session, contract) {
|
|
8
|
+
this.rpc = rpc;
|
|
9
|
+
this.session = session || null;
|
|
10
|
+
this.contract = contract || DEFAULT_CONTRACT;
|
|
11
|
+
}
|
|
12
|
+
// ============== READ OPERATIONS ==============
|
|
13
|
+
/**
|
|
14
|
+
* Get feedback by ID
|
|
15
|
+
*/
|
|
16
|
+
async getFeedback(id) {
|
|
17
|
+
const result = await this.rpc.get_table_rows({
|
|
18
|
+
json: true,
|
|
19
|
+
code: this.contract,
|
|
20
|
+
scope: this.contract,
|
|
21
|
+
table: 'feedback',
|
|
22
|
+
lower_bound: String(id),
|
|
23
|
+
upper_bound: String(id),
|
|
24
|
+
limit: 1,
|
|
25
|
+
});
|
|
26
|
+
if (result.rows.length === 0)
|
|
27
|
+
return null;
|
|
28
|
+
return this.parseFeedback(result.rows[0]);
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* List feedback for an agent
|
|
32
|
+
*/
|
|
33
|
+
async listFeedbackForAgent(agent, options = {}) {
|
|
34
|
+
const { limit = 100 } = options;
|
|
35
|
+
const result = await this.rpc.get_table_rows({
|
|
36
|
+
json: true,
|
|
37
|
+
code: this.contract,
|
|
38
|
+
scope: this.contract,
|
|
39
|
+
table: 'feedback',
|
|
40
|
+
index_position: 2,
|
|
41
|
+
key_type: 'i64',
|
|
42
|
+
limit,
|
|
43
|
+
});
|
|
44
|
+
let feedbacks = result.rows
|
|
45
|
+
.filter((row) => row.agent === agent)
|
|
46
|
+
.map((row) => this.parseFeedback(row));
|
|
47
|
+
if (options.min_score !== undefined) {
|
|
48
|
+
feedbacks = feedbacks.filter((f) => f.score >= options.min_score);
|
|
49
|
+
}
|
|
50
|
+
if (options.max_score !== undefined) {
|
|
51
|
+
feedbacks = feedbacks.filter((f) => f.score <= options.max_score);
|
|
52
|
+
}
|
|
53
|
+
return feedbacks;
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* List feedback submitted by a reviewer
|
|
57
|
+
*/
|
|
58
|
+
async listFeedbackByReviewer(reviewer, options = {}) {
|
|
59
|
+
const { limit = 100 } = options;
|
|
60
|
+
const result = await this.rpc.get_table_rows({
|
|
61
|
+
json: true,
|
|
62
|
+
code: this.contract,
|
|
63
|
+
scope: this.contract,
|
|
64
|
+
table: 'feedback',
|
|
65
|
+
index_position: 3,
|
|
66
|
+
key_type: 'i64',
|
|
67
|
+
limit,
|
|
68
|
+
});
|
|
69
|
+
return result.rows
|
|
70
|
+
.filter((row) => row.reviewer === reviewer)
|
|
71
|
+
.map((row) => this.parseFeedback(row));
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Get aggregated score for an agent
|
|
75
|
+
*/
|
|
76
|
+
async getAgentScore(agent) {
|
|
77
|
+
const result = await this.rpc.get_table_rows({
|
|
78
|
+
json: true,
|
|
79
|
+
code: this.contract,
|
|
80
|
+
scope: this.contract,
|
|
81
|
+
table: 'agentscores',
|
|
82
|
+
lower_bound: agent,
|
|
83
|
+
upper_bound: agent,
|
|
84
|
+
limit: 1,
|
|
85
|
+
});
|
|
86
|
+
if (result.rows.length === 0)
|
|
87
|
+
return null;
|
|
88
|
+
return this.parseAgentScore(result.rows[0]);
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Get dispute by ID
|
|
92
|
+
*/
|
|
93
|
+
async getDispute(id) {
|
|
94
|
+
const result = await this.rpc.get_table_rows({
|
|
95
|
+
json: true,
|
|
96
|
+
code: this.contract,
|
|
97
|
+
scope: this.contract,
|
|
98
|
+
table: 'disputes',
|
|
99
|
+
lower_bound: String(id),
|
|
100
|
+
upper_bound: String(id),
|
|
101
|
+
limit: 1,
|
|
102
|
+
});
|
|
103
|
+
if (result.rows.length === 0)
|
|
104
|
+
return null;
|
|
105
|
+
return this.parseDispute(result.rows[0]);
|
|
106
|
+
}
|
|
107
|
+
/**
|
|
108
|
+
* Get disputes for a feedback
|
|
109
|
+
*/
|
|
110
|
+
async getDisputesForFeedback(feedbackId) {
|
|
111
|
+
const result = await this.rpc.get_table_rows({
|
|
112
|
+
json: true,
|
|
113
|
+
code: this.contract,
|
|
114
|
+
scope: this.contract,
|
|
115
|
+
table: 'disputes',
|
|
116
|
+
index_position: 2,
|
|
117
|
+
key_type: 'i64',
|
|
118
|
+
limit: 100,
|
|
119
|
+
});
|
|
120
|
+
return result.rows
|
|
121
|
+
.filter((row) => row.feedback_id === String(feedbackId))
|
|
122
|
+
.map((row) => this.parseDispute(row));
|
|
123
|
+
}
|
|
124
|
+
// ============== WRITE OPERATIONS ==============
|
|
125
|
+
/**
|
|
126
|
+
* Submit feedback for an agent
|
|
127
|
+
*/
|
|
128
|
+
async submit(data) {
|
|
129
|
+
this.requireSession();
|
|
130
|
+
return this.session.link.transact({
|
|
131
|
+
actions: [
|
|
132
|
+
{
|
|
133
|
+
account: this.contract,
|
|
134
|
+
name: 'submit',
|
|
135
|
+
authorization: [
|
|
136
|
+
{
|
|
137
|
+
actor: this.session.auth.actor,
|
|
138
|
+
permission: this.session.auth.permission,
|
|
139
|
+
},
|
|
140
|
+
],
|
|
141
|
+
data: {
|
|
142
|
+
reviewer: this.session.auth.actor,
|
|
143
|
+
agent: data.agent,
|
|
144
|
+
score: data.score,
|
|
145
|
+
tags: (data.tags || []).join(','),
|
|
146
|
+
job_hash: data.job_hash || '',
|
|
147
|
+
evidence_uri: data.evidence_uri || '',
|
|
148
|
+
amount_paid: data.amount_paid || 0,
|
|
149
|
+
},
|
|
150
|
+
},
|
|
151
|
+
],
|
|
152
|
+
});
|
|
153
|
+
}
|
|
154
|
+
/**
|
|
155
|
+
* Dispute feedback
|
|
156
|
+
*/
|
|
157
|
+
async dispute(feedbackId, reason, evidenceUri) {
|
|
158
|
+
this.requireSession();
|
|
159
|
+
return this.session.link.transact({
|
|
160
|
+
actions: [
|
|
161
|
+
{
|
|
162
|
+
account: this.contract,
|
|
163
|
+
name: 'dispute',
|
|
164
|
+
authorization: [
|
|
165
|
+
{
|
|
166
|
+
actor: this.session.auth.actor,
|
|
167
|
+
permission: this.session.auth.permission,
|
|
168
|
+
},
|
|
169
|
+
],
|
|
170
|
+
data: {
|
|
171
|
+
disputer: this.session.auth.actor,
|
|
172
|
+
feedback_id: feedbackId,
|
|
173
|
+
reason,
|
|
174
|
+
evidence_uri: evidenceUri || '',
|
|
175
|
+
},
|
|
176
|
+
},
|
|
177
|
+
],
|
|
178
|
+
});
|
|
179
|
+
}
|
|
180
|
+
/**
|
|
181
|
+
* Recalculate agent score (paginated).
|
|
182
|
+
*
|
|
183
|
+
* Recalculation is done in batches to avoid CPU exhaustion.
|
|
184
|
+
* - First call: offset=0, processes first `limit` feedbacks
|
|
185
|
+
* - Subsequent calls: use the next_offset from RecalcState
|
|
186
|
+
* - Recalculation expires after 1 hour if not completed
|
|
187
|
+
*
|
|
188
|
+
* @param agent - Agent account to recalculate
|
|
189
|
+
* @param offset - Must be 0 to start, or match next_offset to continue
|
|
190
|
+
* @param limit - Feedbacks to process per call (max 100)
|
|
191
|
+
*/
|
|
192
|
+
async recalculate(agent, offset = 0, limit = 100) {
|
|
193
|
+
this.requireSession();
|
|
194
|
+
return this.session.link.transact({
|
|
195
|
+
actions: [
|
|
196
|
+
{
|
|
197
|
+
account: this.contract,
|
|
198
|
+
name: 'recalc',
|
|
199
|
+
authorization: [
|
|
200
|
+
{
|
|
201
|
+
actor: this.session.auth.actor,
|
|
202
|
+
permission: this.session.auth.permission,
|
|
203
|
+
},
|
|
204
|
+
],
|
|
205
|
+
data: {
|
|
206
|
+
agent,
|
|
207
|
+
offset,
|
|
208
|
+
limit,
|
|
209
|
+
},
|
|
210
|
+
},
|
|
211
|
+
],
|
|
212
|
+
});
|
|
213
|
+
}
|
|
214
|
+
/**
|
|
215
|
+
* Resolve a feedback dispute (owner only)
|
|
216
|
+
*/
|
|
217
|
+
async resolve(disputeId, upheld, resolutionNotes) {
|
|
218
|
+
this.requireSession();
|
|
219
|
+
return this.session.link.transact({
|
|
220
|
+
actions: [
|
|
221
|
+
{
|
|
222
|
+
account: this.contract,
|
|
223
|
+
name: 'resolve',
|
|
224
|
+
authorization: [
|
|
225
|
+
{
|
|
226
|
+
actor: this.session.auth.actor,
|
|
227
|
+
permission: this.session.auth.permission,
|
|
228
|
+
},
|
|
229
|
+
],
|
|
230
|
+
data: {
|
|
231
|
+
resolver: this.session.auth.actor,
|
|
232
|
+
dispute_id: disputeId,
|
|
233
|
+
upheld,
|
|
234
|
+
resolution_notes: resolutionNotes,
|
|
235
|
+
},
|
|
236
|
+
},
|
|
237
|
+
],
|
|
238
|
+
});
|
|
239
|
+
}
|
|
240
|
+
/**
|
|
241
|
+
* Cancel an in-progress recalculation
|
|
242
|
+
*/
|
|
243
|
+
async cancelRecalculation(agent) {
|
|
244
|
+
this.requireSession();
|
|
245
|
+
return this.session.link.transact({
|
|
246
|
+
actions: [
|
|
247
|
+
{
|
|
248
|
+
account: this.contract,
|
|
249
|
+
name: 'cancelrecalc',
|
|
250
|
+
authorization: [
|
|
251
|
+
{
|
|
252
|
+
actor: this.session.auth.actor,
|
|
253
|
+
permission: this.session.auth.permission,
|
|
254
|
+
},
|
|
255
|
+
],
|
|
256
|
+
data: {
|
|
257
|
+
agent,
|
|
258
|
+
},
|
|
259
|
+
},
|
|
260
|
+
],
|
|
261
|
+
});
|
|
262
|
+
}
|
|
263
|
+
/**
|
|
264
|
+
* Submit feedback with fee in one transaction.
|
|
265
|
+
*
|
|
266
|
+
* @param data - Feedback data
|
|
267
|
+
* @param amount - The feedback fee (e.g., "1.0000 XPR")
|
|
268
|
+
*/
|
|
269
|
+
async submitWithFee(data, amount) {
|
|
270
|
+
this.requireSession();
|
|
271
|
+
const actor = this.session.auth.actor;
|
|
272
|
+
return this.session.link.transact({
|
|
273
|
+
actions: [
|
|
274
|
+
{
|
|
275
|
+
account: 'eosio.token',
|
|
276
|
+
name: 'transfer',
|
|
277
|
+
authorization: [{
|
|
278
|
+
actor,
|
|
279
|
+
permission: this.session.auth.permission,
|
|
280
|
+
}],
|
|
281
|
+
data: {
|
|
282
|
+
from: actor,
|
|
283
|
+
to: this.contract,
|
|
284
|
+
quantity: amount,
|
|
285
|
+
memo: `feedfee:${actor}`,
|
|
286
|
+
},
|
|
287
|
+
},
|
|
288
|
+
{
|
|
289
|
+
account: this.contract,
|
|
290
|
+
name: 'submit',
|
|
291
|
+
authorization: [{
|
|
292
|
+
actor,
|
|
293
|
+
permission: this.session.auth.permission,
|
|
294
|
+
}],
|
|
295
|
+
data: {
|
|
296
|
+
reviewer: actor,
|
|
297
|
+
agent: data.agent,
|
|
298
|
+
score: data.score,
|
|
299
|
+
tags: (data.tags || []).join(','),
|
|
300
|
+
job_hash: data.job_hash || '',
|
|
301
|
+
evidence_uri: data.evidence_uri || '',
|
|
302
|
+
amount_paid: data.amount_paid || 0,
|
|
303
|
+
},
|
|
304
|
+
},
|
|
305
|
+
],
|
|
306
|
+
});
|
|
307
|
+
}
|
|
308
|
+
/**
|
|
309
|
+
* Clean up old feedback entries (permissionless)
|
|
310
|
+
*/
|
|
311
|
+
async cleanFeedback(agent, maxAge, maxDelete) {
|
|
312
|
+
this.requireSession();
|
|
313
|
+
return this.session.link.transact({
|
|
314
|
+
actions: [{
|
|
315
|
+
account: this.contract,
|
|
316
|
+
name: 'cleanfback',
|
|
317
|
+
authorization: [{
|
|
318
|
+
actor: this.session.auth.actor,
|
|
319
|
+
permission: this.session.auth.permission,
|
|
320
|
+
}],
|
|
321
|
+
data: {
|
|
322
|
+
agent,
|
|
323
|
+
max_age: maxAge,
|
|
324
|
+
max_delete: maxDelete,
|
|
325
|
+
},
|
|
326
|
+
}],
|
|
327
|
+
});
|
|
328
|
+
}
|
|
329
|
+
/**
|
|
330
|
+
* Clean up resolved disputes (permissionless)
|
|
331
|
+
*/
|
|
332
|
+
async cleanDisputes(maxAge, maxDelete) {
|
|
333
|
+
this.requireSession();
|
|
334
|
+
return this.session.link.transact({
|
|
335
|
+
actions: [{
|
|
336
|
+
account: this.contract,
|
|
337
|
+
name: 'cleandisps',
|
|
338
|
+
authorization: [{
|
|
339
|
+
actor: this.session.auth.actor,
|
|
340
|
+
permission: this.session.auth.permission,
|
|
341
|
+
}],
|
|
342
|
+
data: {
|
|
343
|
+
max_age: maxAge,
|
|
344
|
+
max_delete: maxDelete,
|
|
345
|
+
},
|
|
346
|
+
}],
|
|
347
|
+
});
|
|
348
|
+
}
|
|
349
|
+
/**
|
|
350
|
+
* Get feedback contract configuration
|
|
351
|
+
*/
|
|
352
|
+
async getConfig() {
|
|
353
|
+
const result = await this.rpc.get_table_rows({
|
|
354
|
+
json: true,
|
|
355
|
+
code: this.contract,
|
|
356
|
+
scope: this.contract,
|
|
357
|
+
table: 'config',
|
|
358
|
+
limit: 1,
|
|
359
|
+
});
|
|
360
|
+
if (result.rows.length === 0) {
|
|
361
|
+
throw new Error('Contract not initialized');
|
|
362
|
+
}
|
|
363
|
+
const row = result.rows[0];
|
|
364
|
+
return {
|
|
365
|
+
owner: row.owner,
|
|
366
|
+
core_contract: row.core_contract,
|
|
367
|
+
min_score: row.min_score,
|
|
368
|
+
max_score: row.max_score,
|
|
369
|
+
dispute_window: (0, utils_1.safeParseInt)(row.dispute_window),
|
|
370
|
+
decay_period: (0, utils_1.safeParseInt)(row.decay_period),
|
|
371
|
+
decay_floor: (0, utils_1.safeParseInt)(row.decay_floor),
|
|
372
|
+
paused: row.paused === 1,
|
|
373
|
+
feedback_fee: (0, utils_1.safeParseInt)(row.feedback_fee),
|
|
374
|
+
};
|
|
375
|
+
}
|
|
376
|
+
// ============== HELPERS ==============
|
|
377
|
+
requireSession() {
|
|
378
|
+
if (!this.session) {
|
|
379
|
+
throw new Error('Session required for write operations');
|
|
380
|
+
}
|
|
381
|
+
}
|
|
382
|
+
parseFeedback(raw) {
|
|
383
|
+
return {
|
|
384
|
+
id: (0, utils_1.safeParseInt)(raw.id),
|
|
385
|
+
agent: raw.agent,
|
|
386
|
+
reviewer: raw.reviewer,
|
|
387
|
+
reviewer_kyc_level: raw.reviewer_kyc_level,
|
|
388
|
+
score: raw.score,
|
|
389
|
+
tags: (0, utils_1.parseTags)(raw.tags),
|
|
390
|
+
job_hash: raw.job_hash,
|
|
391
|
+
evidence_uri: raw.evidence_uri,
|
|
392
|
+
amount_paid: (0, utils_1.safeParseInt)(raw.amount_paid),
|
|
393
|
+
timestamp: (0, utils_1.safeParseInt)(raw.timestamp),
|
|
394
|
+
disputed: raw.disputed === 1,
|
|
395
|
+
resolved: raw.resolved === 1,
|
|
396
|
+
};
|
|
397
|
+
}
|
|
398
|
+
parseAgentScore(raw) {
|
|
399
|
+
return {
|
|
400
|
+
agent: raw.agent,
|
|
401
|
+
total_score: (0, utils_1.safeParseInt)(raw.total_score),
|
|
402
|
+
total_weight: (0, utils_1.safeParseInt)(raw.total_weight),
|
|
403
|
+
feedback_count: (0, utils_1.safeParseInt)(raw.feedback_count),
|
|
404
|
+
avg_score: (0, utils_1.safeParseInt)(raw.avg_score),
|
|
405
|
+
last_updated: (0, utils_1.safeParseInt)(raw.last_updated),
|
|
406
|
+
};
|
|
407
|
+
}
|
|
408
|
+
parseDispute(raw) {
|
|
409
|
+
return {
|
|
410
|
+
id: (0, utils_1.safeParseInt)(raw.id),
|
|
411
|
+
feedback_id: (0, utils_1.safeParseInt)(raw.feedback_id),
|
|
412
|
+
disputer: raw.disputer,
|
|
413
|
+
reason: raw.reason,
|
|
414
|
+
evidence_uri: raw.evidence_uri,
|
|
415
|
+
status: (0, utils_1.disputeStatusFromNumber)(raw.status),
|
|
416
|
+
resolver: raw.resolver,
|
|
417
|
+
resolution_notes: raw.resolution_notes,
|
|
418
|
+
created_at: (0, utils_1.safeParseInt)(raw.created_at),
|
|
419
|
+
resolved_at: (0, utils_1.safeParseInt)(raw.resolved_at),
|
|
420
|
+
};
|
|
421
|
+
}
|
|
422
|
+
}
|
|
423
|
+
exports.FeedbackRegistry = FeedbackRegistry;
|
|
424
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"FeedbackRegistry.js","sourceRoot":"","sources":["../src/FeedbackRegistry.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Feedback,\n  FeedbackRaw,\n  FeedbackConfig,\n  AgentScore,\n  AgentScoreRaw,\n  Dispute,\n  FeedbackListOptions,\n  SubmitFeedbackData,\n  TransactionResult,\n  JsonRpc,\n  ProtonSession,\n} from './types';\nimport { parseTags, disputeStatusFromNumber, safeParseInt } from './utils';\n\nconst DEFAULT_CONTRACT = 'agentfeed';\n\nexport class FeedbackRegistry {\n  private rpc: JsonRpc;\n  private session: ProtonSession | null;\n  private contract: string;\n\n  constructor(rpc: JsonRpc, session?: ProtonSession, contract?: string) {\n    this.rpc = rpc;\n    this.session = session || null;\n    this.contract = contract || DEFAULT_CONTRACT;\n  }\n\n  // ============== READ OPERATIONS ==============\n\n  /**\n   * Get feedback by ID\n   */\n  async getFeedback(id: number): Promise<Feedback | null> {\n    const result = await this.rpc.get_table_rows<FeedbackRaw>({\n      json: true,\n      code: this.contract,\n      scope: this.contract,\n      table: 'feedback',\n      lower_bound: String(id),\n      upper_bound: String(id),\n      limit: 1,\n    });\n\n    if (result.rows.length === 0) return null;\n    return this.parseFeedback(result.rows[0]);\n  }\n\n  /**\n   * List feedback for an agent\n   */\n  async listFeedbackForAgent(\n    agent: string,\n    options: FeedbackListOptions = {}\n  ): Promise<Feedback[]> {\n    const { limit = 100 } = options;\n\n    const result = await this.rpc.get_table_rows<FeedbackRaw>({\n      json: true,\n      code: this.contract,\n      scope: this.contract,\n      table: 'feedback',\n      index_position: 2,\n      key_type: 'i64',\n      limit,\n    });\n\n    let feedbacks = result.rows\n      .filter((row) => row.agent === agent)\n      .map((row) => this.parseFeedback(row));\n\n    if (options.min_score !== undefined) {\n      feedbacks = feedbacks.filter((f) => f.score >= options.min_score!);\n    }\n\n    if (options.max_score !== undefined) {\n      feedbacks = feedbacks.filter((f) => f.score <= options.max_score!);\n    }\n\n    return feedbacks;\n  }\n\n  /**\n   * List feedback submitted by a reviewer\n   */\n  async listFeedbackByReviewer(\n    reviewer: string,\n    options: FeedbackListOptions = {}\n  ): Promise<Feedback[]> {\n    const { limit = 100 } = options;\n\n    const result = await this.rpc.get_table_rows<FeedbackRaw>({\n      json: true,\n      code: this.contract,\n      scope: this.contract,\n      table: 'feedback',\n      index_position: 3,\n      key_type: 'i64',\n      limit,\n    });\n\n    return result.rows\n      .filter((row) => row.reviewer === reviewer)\n      .map((row) => this.parseFeedback(row));\n  }\n\n  /**\n   * Get aggregated score for an agent\n   */\n  async getAgentScore(agent: string): Promise<AgentScore | null> {\n    const result = await this.rpc.get_table_rows<AgentScoreRaw>({\n      json: true,\n      code: this.contract,\n      scope: this.contract,\n      table: 'agentscores',\n      lower_bound: agent,\n      upper_bound: agent,\n      limit: 1,\n    });\n\n    if (result.rows.length === 0) return null;\n    return this.parseAgentScore(result.rows[0]);\n  }\n\n  /**\n   * Get dispute by ID\n   */\n  async getDispute(id: number): Promise<Dispute | null> {\n    const result = await this.rpc.get_table_rows<{\n      id: string;\n      feedback_id: string;\n      disputer: string;\n      reason: string;\n      evidence_uri: string;\n      status: number;\n      resolver: string;\n      resolution_notes: string;\n      created_at: string;\n      resolved_at: string;\n    }>({\n      json: true,\n      code: this.contract,\n      scope: this.contract,\n      table: 'disputes',\n      lower_bound: String(id),\n      upper_bound: String(id),\n      limit: 1,\n    });\n\n    if (result.rows.length === 0) return null;\n    return this.parseDispute(result.rows[0]);\n  }\n\n  /**\n   * Get disputes for a feedback\n   */\n  async getDisputesForFeedback(feedbackId: number): Promise<Dispute[]> {\n    const result = await this.rpc.get_table_rows<{\n      id: string;\n      feedback_id: string;\n      disputer: string;\n      reason: string;\n      evidence_uri: string;\n      status: number;\n      resolver: string;\n      resolution_notes: string;\n      created_at: string;\n      resolved_at: string;\n    }>({\n      json: true,\n      code: this.contract,\n      scope: this.contract,\n      table: 'disputes',\n      index_position: 2,\n      key_type: 'i64',\n      limit: 100,\n    });\n\n    return result.rows\n      .filter((row) => row.feedback_id === String(feedbackId))\n      .map((row) => this.parseDispute(row));\n  }\n\n  // ============== WRITE OPERATIONS ==============\n\n  /**\n   * Submit feedback for an agent\n   */\n  async submit(data: SubmitFeedbackData): Promise<TransactionResult> {\n    this.requireSession();\n\n    return this.session!.link.transact({\n      actions: [\n        {\n          account: this.contract,\n          name: 'submit',\n          authorization: [\n            {\n              actor: this.session!.auth.actor,\n              permission: this.session!.auth.permission,\n            },\n          ],\n          data: {\n            reviewer: this.session!.auth.actor,\n            agent: data.agent,\n            score: data.score,\n            tags: (data.tags || []).join(','),\n            job_hash: data.job_hash || '',\n            evidence_uri: data.evidence_uri || '',\n            amount_paid: data.amount_paid || 0,\n          },\n        },\n      ],\n    });\n  }\n\n  /**\n   * Dispute feedback\n   */\n  async dispute(\n    feedbackId: number,\n    reason: string,\n    evidenceUri?: string\n  ): Promise<TransactionResult> {\n    this.requireSession();\n\n    return this.session!.link.transact({\n      actions: [\n        {\n          account: this.contract,\n          name: 'dispute',\n          authorization: [\n            {\n              actor: this.session!.auth.actor,\n              permission: this.session!.auth.permission,\n            },\n          ],\n          data: {\n            disputer: this.session!.auth.actor,\n            feedback_id: feedbackId,\n            reason,\n            evidence_uri: evidenceUri || '',\n          },\n        },\n      ],\n    });\n  }\n\n  /**\n   * Recalculate agent score (paginated).\n   *\n   * Recalculation is done in batches to avoid CPU exhaustion.\n   * - First call: offset=0, processes first `limit` feedbacks\n   * - Subsequent calls: use the next_offset from RecalcState\n   * - Recalculation expires after 1 hour if not completed\n   *\n   * @param agent - Agent account to recalculate\n   * @param offset - Must be 0 to start, or match next_offset to continue\n   * @param limit - Feedbacks to process per call (max 100)\n   */\n  async recalculate(agent: string, offset: number = 0, limit: number = 100): Promise<TransactionResult> {\n    this.requireSession();\n\n    return this.session!.link.transact({\n      actions: [\n        {\n          account: this.contract,\n          name: 'recalc',\n          authorization: [\n            {\n              actor: this.session!.auth.actor,\n              permission: this.session!.auth.permission,\n            },\n          ],\n          data: {\n            agent,\n            offset,\n            limit,\n          },\n        },\n      ],\n    });\n  }\n\n  /**\n   * Resolve a feedback dispute (owner only)\n   */\n  async resolve(\n    disputeId: number,\n    upheld: boolean,\n    resolutionNotes: string\n  ): Promise<TransactionResult> {\n    this.requireSession();\n\n    return this.session!.link.transact({\n      actions: [\n        {\n          account: this.contract,\n          name: 'resolve',\n          authorization: [\n            {\n              actor: this.session!.auth.actor,\n              permission: this.session!.auth.permission,\n            },\n          ],\n          data: {\n            resolver: this.session!.auth.actor,\n            dispute_id: disputeId,\n            upheld,\n            resolution_notes: resolutionNotes,\n          },\n        },\n      ],\n    });\n  }\n\n  /**\n   * Cancel an in-progress recalculation\n   */\n  async cancelRecalculation(agent: string): Promise<TransactionResult> {\n    this.requireSession();\n\n    return this.session!.link.transact({\n      actions: [\n        {\n          account: this.contract,\n          name: 'cancelrecalc',\n          authorization: [\n            {\n              actor: this.session!.auth.actor,\n              permission: this.session!.auth.permission,\n            },\n          ],\n          data: {\n            agent,\n          },\n        },\n      ],\n    });\n  }\n\n  /**\n   * Submit feedback with fee in one transaction.\n   *\n   * @param data - Feedback data\n   * @param amount - The feedback fee (e.g., \"1.0000 XPR\")\n   */\n  async submitWithFee(data: SubmitFeedbackData, amount: string): Promise<TransactionResult> {\n    this.requireSession();\n\n    const actor = this.session!.auth.actor;\n\n    return this.session!.link.transact({\n      actions: [\n        {\n          account: 'eosio.token',\n          name: 'transfer',\n          authorization: [{\n            actor,\n            permission: this.session!.auth.permission,\n          }],\n          data: {\n            from: actor,\n            to: this.contract,\n            quantity: amount,\n            memo: `feedfee:${actor}`,\n          },\n        },\n        {\n          account: this.contract,\n          name: 'submit',\n          authorization: [{\n            actor,\n            permission: this.session!.auth.permission,\n          }],\n          data: {\n            reviewer: actor,\n            agent: data.agent,\n            score: data.score,\n            tags: (data.tags || []).join(','),\n            job_hash: data.job_hash || '',\n            evidence_uri: data.evidence_uri || '',\n            amount_paid: data.amount_paid || 0,\n          },\n        },\n      ],\n    });\n  }\n\n  /**\n   * Clean up old feedback entries (permissionless)\n   */\n  async cleanFeedback(agent: string, maxAge: number, maxDelete: number): Promise<TransactionResult> {\n    this.requireSession();\n\n    return this.session!.link.transact({\n      actions: [{\n        account: this.contract,\n        name: 'cleanfback',\n        authorization: [{\n          actor: this.session!.auth.actor,\n          permission: this.session!.auth.permission,\n        }],\n        data: {\n          agent,\n          max_age: maxAge,\n          max_delete: maxDelete,\n        },\n      }],\n    });\n  }\n\n  /**\n   * Clean up resolved disputes (permissionless)\n   */\n  async cleanDisputes(maxAge: number, maxDelete: number): Promise<TransactionResult> {\n    this.requireSession();\n\n    return this.session!.link.transact({\n      actions: [{\n        account: this.contract,\n        name: 'cleandisps',\n        authorization: [{\n          actor: this.session!.auth.actor,\n          permission: this.session!.auth.permission,\n        }],\n        data: {\n          max_age: maxAge,\n          max_delete: maxDelete,\n        },\n      }],\n    });\n  }\n\n  /**\n   * Get feedback contract configuration\n   */\n  async getConfig(): Promise<FeedbackConfig> {\n    const result = await this.rpc.get_table_rows<{\n      owner: string;\n      core_contract: string;\n      min_score: number;\n      max_score: number;\n      dispute_window: string;\n      decay_period: string;\n      decay_floor: string;\n      paused: number;\n      feedback_fee: string;\n    }>({\n      json: true,\n      code: this.contract,\n      scope: this.contract,\n      table: 'config',\n      limit: 1,\n    });\n\n    if (result.rows.length === 0) {\n      throw new Error('Contract not initialized');\n    }\n\n    const row = result.rows[0];\n    return {\n      owner: row.owner,\n      core_contract: row.core_contract,\n      min_score: row.min_score,\n      max_score: row.max_score,\n      dispute_window: safeParseInt(row.dispute_window),\n      decay_period: safeParseInt(row.decay_period),\n      decay_floor: safeParseInt(row.decay_floor),\n      paused: row.paused === 1,\n      feedback_fee: safeParseInt(row.feedback_fee),\n    };\n  }\n\n  // ============== HELPERS ==============\n\n  private requireSession(): void {\n    if (!this.session) {\n      throw new Error('Session required for write operations');\n    }\n  }\n\n  private parseFeedback(raw: FeedbackRaw): Feedback {\n    return {\n      id: safeParseInt(raw.id),\n      agent: raw.agent,\n      reviewer: raw.reviewer,\n      reviewer_kyc_level: raw.reviewer_kyc_level,\n      score: raw.score,\n      tags: parseTags(raw.tags),\n      job_hash: raw.job_hash,\n      evidence_uri: raw.evidence_uri,\n      amount_paid: safeParseInt(raw.amount_paid),\n      timestamp: safeParseInt(raw.timestamp),\n      disputed: raw.disputed === 1,\n      resolved: raw.resolved === 1,\n    };\n  }\n\n  private parseAgentScore(raw: AgentScoreRaw): AgentScore {\n    return {\n      agent: raw.agent,\n      total_score: safeParseInt(raw.total_score),\n      total_weight: safeParseInt(raw.total_weight),\n      feedback_count: safeParseInt(raw.feedback_count),\n      avg_score: safeParseInt(raw.avg_score),\n      last_updated: safeParseInt(raw.last_updated),\n    };\n  }\n\n  private parseDispute(raw: {\n    id: string;\n    feedback_id: string;\n    disputer: string;\n    reason: string;\n    evidence_uri: string;\n    status: number;\n    resolver: string;\n    resolution_notes: string;\n    created_at: string;\n    resolved_at: string;\n  }): Dispute {\n    return {\n      id: safeParseInt(raw.id),\n      feedback_id: safeParseInt(raw.feedback_id),\n      disputer: raw.disputer,\n      reason: raw.reason,\n      evidence_uri: raw.evidence_uri,\n      status: disputeStatusFromNumber(raw.status),\n      resolver: raw.resolver,\n      resolution_notes: raw.resolution_notes,\n      created_at: safeParseInt(raw.created_at),\n      resolved_at: safeParseInt(raw.resolved_at),\n    };\n  }\n}\n"]}
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import { Validator, Validation, ValidationConfig, Challenge, ValidatorListOptions, SubmitValidationData, TransactionResult, JsonRpc, ProtonSession } from './types';
|
|
2
|
+
export declare class ValidationRegistry {
|
|
3
|
+
private rpc;
|
|
4
|
+
private session;
|
|
5
|
+
private contract;
|
|
6
|
+
constructor(rpc: JsonRpc, session?: ProtonSession, contract?: string);
|
|
7
|
+
/**
|
|
8
|
+
* Get a validator by account
|
|
9
|
+
*/
|
|
10
|
+
getValidator(account: string): Promise<Validator | null>;
|
|
11
|
+
/**
|
|
12
|
+
* List all validators
|
|
13
|
+
*/
|
|
14
|
+
listValidators(options?: ValidatorListOptions): Promise<Validator[]>;
|
|
15
|
+
/**
|
|
16
|
+
* Get validation by ID
|
|
17
|
+
*/
|
|
18
|
+
getValidation(id: number): Promise<Validation | null>;
|
|
19
|
+
/**
|
|
20
|
+
* List validations for an agent
|
|
21
|
+
*/
|
|
22
|
+
listValidationsForAgent(agent: string, limit?: number): Promise<Validation[]>;
|
|
23
|
+
/**
|
|
24
|
+
* List validations by a validator
|
|
25
|
+
*/
|
|
26
|
+
listValidationsByValidator(validator: string, limit?: number): Promise<Validation[]>;
|
|
27
|
+
/**
|
|
28
|
+
* Get challenge by ID
|
|
29
|
+
*/
|
|
30
|
+
getChallenge(id: number): Promise<Challenge | null>;
|
|
31
|
+
/**
|
|
32
|
+
* Get challenges for a validation
|
|
33
|
+
*/
|
|
34
|
+
getChallengesForValidation(validationId: number): Promise<Challenge[]>;
|
|
35
|
+
/**
|
|
36
|
+
* Register as a validator
|
|
37
|
+
*/
|
|
38
|
+
registerValidator(method: string, specializations: string[]): Promise<TransactionResult>;
|
|
39
|
+
/**
|
|
40
|
+
* Update validator info
|
|
41
|
+
*/
|
|
42
|
+
updateValidator(method: string, specializations: string[]): Promise<TransactionResult>;
|
|
43
|
+
/**
|
|
44
|
+
* Stake XPR as validator
|
|
45
|
+
*/
|
|
46
|
+
stake(amount: string): Promise<TransactionResult>;
|
|
47
|
+
/**
|
|
48
|
+
* Submit validation
|
|
49
|
+
*/
|
|
50
|
+
validate(data: SubmitValidationData): Promise<TransactionResult>;
|
|
51
|
+
/**
|
|
52
|
+
* Challenge a validation
|
|
53
|
+
*/
|
|
54
|
+
challenge(validationId: number, reason: string, evidenceUri?: string): Promise<TransactionResult>;
|
|
55
|
+
/**
|
|
56
|
+
* Stake for a challenge
|
|
57
|
+
*/
|
|
58
|
+
stakeChallengeDeposit(challengeId: number, amount: string): Promise<TransactionResult>;
|
|
59
|
+
/**
|
|
60
|
+
* Set validator active status
|
|
61
|
+
*/
|
|
62
|
+
setValidatorStatus(active: boolean): Promise<TransactionResult>;
|
|
63
|
+
/**
|
|
64
|
+
* Request to unstake validator funds (time-delayed).
|
|
65
|
+
* Must be deactivated and have no pending challenges first.
|
|
66
|
+
*
|
|
67
|
+
* @param amount - Amount to unstake in smallest units
|
|
68
|
+
*/
|
|
69
|
+
unstake(amount: number): Promise<TransactionResult>;
|
|
70
|
+
/**
|
|
71
|
+
* Withdraw unstaked validator funds (after delay period)
|
|
72
|
+
*
|
|
73
|
+
* @param unstakeId - The ID of the unstake request to withdraw
|
|
74
|
+
*/
|
|
75
|
+
withdraw(unstakeId: number): Promise<TransactionResult>;
|
|
76
|
+
/**
|
|
77
|
+
* Cancel an unfunded challenge (within grace period or after deadline)
|
|
78
|
+
*/
|
|
79
|
+
cancelChallenge(challengeId: number): Promise<TransactionResult>;
|
|
80
|
+
/**
|
|
81
|
+
* Resolve a validation challenge (owner only)
|
|
82
|
+
*/
|
|
83
|
+
resolve(challengeId: number, upheld: boolean, resolutionNotes: string): Promise<TransactionResult>;
|
|
84
|
+
/**
|
|
85
|
+
* Expire an unfunded challenge (permissionless cleanup)
|
|
86
|
+
*/
|
|
87
|
+
expireUnfundedChallenge(challengeId: number): Promise<TransactionResult>;
|
|
88
|
+
/**
|
|
89
|
+
* Expire a funded challenge that was not resolved within timeout (permissionless cleanup)
|
|
90
|
+
*/
|
|
91
|
+
expireFundedChallenge(challengeId: number): Promise<TransactionResult>;
|
|
92
|
+
/**
|
|
93
|
+
* Submit validation with fee in one transaction.
|
|
94
|
+
*
|
|
95
|
+
* @param data - Validation data
|
|
96
|
+
* @param amount - The validation fee (e.g., "1.0000 XPR")
|
|
97
|
+
*/
|
|
98
|
+
validateWithFee(data: SubmitValidationData, amount: string): Promise<TransactionResult>;
|
|
99
|
+
/**
|
|
100
|
+
* Clean up old validations (permissionless)
|
|
101
|
+
*/
|
|
102
|
+
cleanValidations(agent: string, maxAge: number, maxDelete: number): Promise<TransactionResult>;
|
|
103
|
+
/**
|
|
104
|
+
* Clean up resolved challenges (permissionless)
|
|
105
|
+
*/
|
|
106
|
+
cleanChallenges(maxAge: number, maxDelete: number): Promise<TransactionResult>;
|
|
107
|
+
/**
|
|
108
|
+
* Get validation contract configuration
|
|
109
|
+
*/
|
|
110
|
+
getConfig(): Promise<ValidationConfig>;
|
|
111
|
+
private requireSession;
|
|
112
|
+
private parseValidator;
|
|
113
|
+
private parseValidation;
|
|
114
|
+
private parseChallenge;
|
|
115
|
+
}
|