@zenland/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/dist/index.cjs ADDED
@@ -0,0 +1,502 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/index.ts
21
+ var src_exports = {};
22
+ __export(src_exports, {
23
+ STATE_GROUPS: () => STATE_GROUPS,
24
+ ZenlandGraphQLError: () => ZenlandGraphQLError,
25
+ ZenlandRequestError: () => ZenlandRequestError,
26
+ computeAgentMavUsd: () => computeAgentMavUsd,
27
+ createAgentsDomain: () => createAgentsDomain,
28
+ createEscrowsDomain: () => createEscrowsDomain,
29
+ createProtocolStatsDomain: () => createProtocolStatsDomain,
30
+ createTransactionLogsDomain: () => createTransactionLogsDomain,
31
+ createZenlandClient: () => createZenlandClient,
32
+ isAgentEligibleForEscrow: () => isAgentEligibleForEscrow,
33
+ zenland: () => zenland
34
+ });
35
+ module.exports = __toCommonJS(src_exports);
36
+
37
+ // src/request.ts
38
+ var ZenlandGraphQLError = class extends Error {
39
+ errors;
40
+ constructor(message, errors) {
41
+ super(message);
42
+ this.name = "ZenlandGraphQLError";
43
+ this.errors = errors;
44
+ }
45
+ };
46
+ var ZenlandRequestError = class extends Error {
47
+ status;
48
+ statusText;
49
+ constructor(message, status, statusText) {
50
+ super(message);
51
+ this.name = "ZenlandRequestError";
52
+ this.status = status;
53
+ this.statusText = statusText;
54
+ }
55
+ };
56
+ async function graphqlRequest(baseUrl, document, variables, options) {
57
+ const endpoint = `${baseUrl}/graphql`;
58
+ const res = await fetch(endpoint, {
59
+ method: "POST",
60
+ headers: {
61
+ "content-type": "application/json"
62
+ },
63
+ body: JSON.stringify({ query: document, variables }),
64
+ signal: options?.signal,
65
+ cache: "no-store"
66
+ });
67
+ if (!res.ok) {
68
+ const text = await res.text().catch(() => "");
69
+ throw new ZenlandRequestError(
70
+ `Zenland request failed (${res.status} ${res.statusText})${text ? `: ${text}` : ""}`,
71
+ res.status,
72
+ res.statusText
73
+ );
74
+ }
75
+ const json = await res.json();
76
+ if (json.errors?.length) {
77
+ throw new ZenlandGraphQLError(
78
+ json.errors.map((e) => e.message ?? "GraphQL error").join("; "),
79
+ json.errors
80
+ );
81
+ }
82
+ if (!json.data) {
83
+ throw new Error("Zenland response missing data.");
84
+ }
85
+ return json.data;
86
+ }
87
+
88
+ // src/queries.ts
89
+ var AGENT_QUERY = `
90
+ query Agent($id: String!) {
91
+ agent(id: $id) {
92
+ id
93
+ isActive
94
+ isAvailable
95
+ stablecoinDecimals
96
+ stablecoinToken
97
+ stablecoinStake
98
+ daoTokenStake
99
+ disputeFeeBps
100
+ assignmentFeeBps
101
+ description
102
+ contact
103
+ totalResolved
104
+ activeCases
105
+ registrationTime
106
+ lastEngagementTimestamp
107
+ totalEarnings
108
+ totalSlashed
109
+ cases(limit: 5, orderBy: "invitedAt", orderDirection: "desc") {
110
+ items {
111
+ id
112
+ escrow
113
+ invitedAt
114
+ resolvedAt
115
+ timedOut
116
+ escrowRef {
117
+ id
118
+ amount
119
+ token
120
+ state
121
+ }
122
+ }
123
+ totalCount
124
+ }
125
+ }
126
+ }
127
+ `;
128
+ var AGENTS_QUERY = `
129
+ query Agents($where: agentFilter, $orderBy: String, $orderDirection: String, $limit: Int, $offset: Int) {
130
+ agents(where: $where, orderBy: $orderBy, orderDirection: $orderDirection, limit: $limit, offset: $offset) {
131
+ totalCount
132
+ items {
133
+ id
134
+ isActive
135
+ isAvailable
136
+ stablecoinDecimals
137
+ stablecoinStake
138
+ daoTokenStake
139
+ disputeFeeBps
140
+ assignmentFeeBps
141
+ description
142
+ contact
143
+ totalResolved
144
+ activeCases
145
+ registrationTime
146
+ lastEngagementTimestamp
147
+ totalEarnings
148
+ totalSlashed
149
+ }
150
+ pageInfo {
151
+ hasNextPage
152
+ hasPreviousPage
153
+ }
154
+ }
155
+ }
156
+ `;
157
+ var ESCROW_QUERY = `
158
+ query escrow($id: String!) {
159
+ escrow(id: $id) {
160
+ id
161
+ buyer
162
+ seller
163
+ agent
164
+ amount
165
+ token
166
+ state
167
+ createdAt
168
+ sellerAcceptDeadline
169
+ buyerProtectionTime
170
+ termsHash
171
+ version
172
+ fundedAt
173
+ fulfilledAt
174
+ resolvedAt
175
+ agentInvitedAt
176
+ splitProposer
177
+ proposedBuyerBps
178
+ proposedSellerBps
179
+ buyerApprovedSplit
180
+ sellerApprovedSplit
181
+ agentFeeReceived
182
+ buyerReceived
183
+ sellerReceived
184
+ creationFee
185
+ }
186
+ }
187
+ `;
188
+ var ESCROWS_QUERY = `
189
+ query escrows(
190
+ $limit: Int = 30
191
+ $offset: Int = 0
192
+ $orderBy: String = "createdAt"
193
+ $orderDirection: String = "desc"
194
+ $where: escrowFilter
195
+ ) {
196
+ escrows(
197
+ limit: $limit
198
+ offset: $offset
199
+ orderBy: $orderBy
200
+ orderDirection: $orderDirection
201
+ where: $where
202
+ ) {
203
+ items {
204
+ id
205
+ buyer
206
+ seller
207
+ agent
208
+ amount
209
+ token
210
+ state
211
+ createdAt
212
+ fundedAt
213
+ fulfilledAt
214
+ sellerAcceptDeadline
215
+ agentInvitedAt
216
+ buyerProtectionTime
217
+ splitProposer
218
+ buyerApprovedSplit
219
+ sellerApprovedSplit
220
+ proposedBuyerBps
221
+ proposedSellerBps
222
+ }
223
+ pageInfo {
224
+ hasNextPage
225
+ hasPreviousPage
226
+ }
227
+ totalCount
228
+ }
229
+ }
230
+ `;
231
+ var PROTOCOL_STATS_QUERY = `
232
+ query protocolStats($id: String! = "global") {
233
+ protocolStats(id: $id) {
234
+ id
235
+ totalEscrowsCreated
236
+ totalVolumeEscrowed
237
+ totalFeesCollected
238
+ currentTVL
239
+ activeEscrowCount
240
+ totalAgentsRegistered
241
+ activeAgentsCount
242
+ }
243
+ }
244
+ `;
245
+ var TRANSACTION_LOGS_QUERY = `
246
+ query transactionLogs(
247
+ $escrowAddress: String
248
+ $limit: Int
249
+ $offset: Int
250
+ $orderBy: String
251
+ $orderDirection: String
252
+ ) {
253
+ transactionLogs(
254
+ where: { escrowAddress: $escrowAddress }
255
+ limit: $limit
256
+ offset: $offset
257
+ orderBy: $orderBy
258
+ orderDirection: $orderDirection
259
+ ) {
260
+ items {
261
+ id
262
+ txHash
263
+ blockNumber
264
+ timestamp
265
+ eventName
266
+ contractAddress
267
+ contractType
268
+ escrowAddress
269
+ agentAddress
270
+ userAddress
271
+ eventData
272
+ }
273
+ }
274
+ }
275
+ `;
276
+
277
+ // src/domains/escrows.ts
278
+ var STATE_GROUPS = {
279
+ ACTIVE: ["PENDING", "ACTIVE", "FULFILLED"],
280
+ IN_DISPUTE: ["DISPUTED", "AGENT_INVITED"],
281
+ COMPLETED: ["RELEASED", "AGENT_RESOLVED", "REFUNDED", "SPLIT"]
282
+ };
283
+ function createEscrowsDomain(baseUrl) {
284
+ async function list(args) {
285
+ const where = {};
286
+ if (args?.buyer) where.buyer = args.buyer.toLowerCase();
287
+ if (args?.seller) where.seller = args.seller.toLowerCase();
288
+ if (args?.agent) where.agent = args.agent.toLowerCase();
289
+ if (args?.states && args.states.length > 0) {
290
+ where.state_in = args.states;
291
+ } else if (args?.state) {
292
+ where.state = args.state;
293
+ }
294
+ if (args?.user) {
295
+ const userLower = args.user.toLowerCase();
296
+ where.OR = [{ buyer: userLower }, { seller: userLower }, { agent: userLower }];
297
+ }
298
+ const variables = {
299
+ limit: args?.limit ?? 30,
300
+ offset: args?.offset ?? 0,
301
+ orderBy: args?.orderBy ?? "createdAt",
302
+ orderDirection: args?.orderDirection ?? "desc",
303
+ where: Object.keys(where).length > 0 ? where : void 0
304
+ };
305
+ const response = await graphqlRequest(
306
+ baseUrl,
307
+ ESCROWS_QUERY,
308
+ variables
309
+ );
310
+ return response.escrows;
311
+ }
312
+ async function getById(id) {
313
+ const variables = { id: id.toLowerCase() };
314
+ const response = await graphqlRequest(
315
+ baseUrl,
316
+ ESCROW_QUERY,
317
+ variables
318
+ );
319
+ return response.escrow;
320
+ }
321
+ async function getByUser(userAddress, args) {
322
+ return list({ ...args, user: userAddress });
323
+ }
324
+ async function getByStateGroup(stateGroup, args) {
325
+ return list({ ...args, states: [...STATE_GROUPS[stateGroup]] });
326
+ }
327
+ return {
328
+ list,
329
+ getById,
330
+ getByUser,
331
+ getByStateGroup
332
+ };
333
+ }
334
+
335
+ // src/domains/agents.ts
336
+ function createAgentsDomain(baseUrl) {
337
+ async function list(args) {
338
+ const where = {};
339
+ if (args?.onlyActive) where.isActive = true;
340
+ if (args?.onlyAvailable) where.isAvailable = true;
341
+ const variables = {
342
+ limit: args?.limit ?? 30,
343
+ offset: args?.offset ?? 0,
344
+ orderBy: args?.orderBy ?? "totalResolved",
345
+ orderDirection: args?.orderDirection ?? "desc",
346
+ where: Object.keys(where).length > 0 ? where : void 0
347
+ };
348
+ const response = await graphqlRequest(
349
+ baseUrl,
350
+ AGENTS_QUERY,
351
+ variables
352
+ );
353
+ return response.agents;
354
+ }
355
+ async function getById(id) {
356
+ const variables = { id: id.toLowerCase() };
357
+ const response = await graphqlRequest(
358
+ baseUrl,
359
+ AGENT_QUERY,
360
+ variables
361
+ );
362
+ return response.agent;
363
+ }
364
+ async function getAvailable(args) {
365
+ return list({ ...args, onlyActive: true, onlyAvailable: true });
366
+ }
367
+ return {
368
+ list,
369
+ getById,
370
+ getAvailable
371
+ };
372
+ }
373
+
374
+ // src/domains/protocol-stats.ts
375
+ function normalizeProtocolStats(raw) {
376
+ return {
377
+ id: raw.id,
378
+ totalEscrowsCreated: raw.totalEscrowsCreated,
379
+ totalVolumeEscrowed: BigInt(raw.totalVolumeEscrowed),
380
+ totalFeesCollected: BigInt(raw.totalFeesCollected),
381
+ currentTVL: BigInt(raw.currentTVL),
382
+ activeEscrowCount: raw.activeEscrowCount,
383
+ totalAgentsRegistered: raw.totalAgentsRegistered,
384
+ activeAgentsCount: raw.activeAgentsCount
385
+ };
386
+ }
387
+ function createProtocolStatsDomain(baseUrl) {
388
+ async function get() {
389
+ const variables = { id: "global" };
390
+ const response = await graphqlRequest(
391
+ baseUrl,
392
+ PROTOCOL_STATS_QUERY,
393
+ variables
394
+ );
395
+ if (!response.protocolStats) {
396
+ return null;
397
+ }
398
+ return normalizeProtocolStats(response.protocolStats);
399
+ }
400
+ async function getRaw() {
401
+ const variables = { id: "global" };
402
+ const response = await graphqlRequest(
403
+ baseUrl,
404
+ PROTOCOL_STATS_QUERY,
405
+ variables
406
+ );
407
+ return response.protocolStats;
408
+ }
409
+ return {
410
+ get,
411
+ getRaw
412
+ };
413
+ }
414
+
415
+ // src/domains/transaction-logs.ts
416
+ function createTransactionLogsDomain(baseUrl) {
417
+ async function list(args) {
418
+ const variables = {
419
+ escrowAddress: args?.escrowAddress?.toLowerCase(),
420
+ limit: args?.limit ?? 100,
421
+ offset: args?.offset ?? 0,
422
+ orderBy: args?.orderBy ?? "timestamp",
423
+ orderDirection: args?.orderDirection ?? "asc"
424
+ };
425
+ const response = await graphqlRequest(
426
+ baseUrl,
427
+ TRANSACTION_LOGS_QUERY,
428
+ variables
429
+ );
430
+ return response.transactionLogs.items;
431
+ }
432
+ async function getByEscrow(escrowAddress, args) {
433
+ return list({ ...args, escrowAddress });
434
+ }
435
+ function parseEventData(eventData) {
436
+ try {
437
+ return JSON.parse(eventData);
438
+ } catch {
439
+ return {};
440
+ }
441
+ }
442
+ return {
443
+ list,
444
+ getByEscrow,
445
+ parseEventData
446
+ };
447
+ }
448
+
449
+ // src/client.ts
450
+ var DEFAULT_BASE_URL = "https://api.zen.land";
451
+ function createZenlandClient(config) {
452
+ const baseUrl = normalizeBaseUrl(config?.baseUrl ?? DEFAULT_BASE_URL);
453
+ return {
454
+ baseUrl,
455
+ escrows: createEscrowsDomain(baseUrl),
456
+ agents: createAgentsDomain(baseUrl),
457
+ protocolStats: createProtocolStatsDomain(baseUrl),
458
+ transactionLogs: createTransactionLogsDomain(baseUrl)
459
+ };
460
+ }
461
+ function normalizeBaseUrl(url) {
462
+ return url.endsWith("/") ? url.slice(0, -1) : url;
463
+ }
464
+ var zenland = createZenlandClient();
465
+
466
+ // src/agents/eligibility.ts
467
+ var MAV_MULTIPLIER = 20n;
468
+ function computeAgentMavUsd(agent) {
469
+ return BigInt(agent.stablecoinStake) * MAV_MULTIPLIER;
470
+ }
471
+ function isAgentEligibleForEscrow(args) {
472
+ const requiredUsd = args.escrowAmount;
473
+ if (!args.agent) {
474
+ return { ok: false, reason: "NOT_REGISTERED", requiredUsd };
475
+ }
476
+ if (!args.agent.isActive) {
477
+ return { ok: false, reason: "NOT_ACTIVE", requiredUsd };
478
+ }
479
+ if (!args.agent.isAvailable) {
480
+ return { ok: false, reason: "NOT_AVAILABLE", requiredUsd };
481
+ }
482
+ const agentMavUsd = computeAgentMavUsd(args.agent);
483
+ if (agentMavUsd < requiredUsd) {
484
+ return { ok: false, reason: "INSUFFICIENT_MAV", agentMavUsd, requiredUsd };
485
+ }
486
+ return { ok: true, agentMavUsd, requiredUsd };
487
+ }
488
+ // Annotate the CommonJS export names for ESM import in node:
489
+ 0 && (module.exports = {
490
+ STATE_GROUPS,
491
+ ZenlandGraphQLError,
492
+ ZenlandRequestError,
493
+ computeAgentMavUsd,
494
+ createAgentsDomain,
495
+ createEscrowsDomain,
496
+ createProtocolStatsDomain,
497
+ createTransactionLogsDomain,
498
+ createZenlandClient,
499
+ isAgentEligibleForEscrow,
500
+ zenland
501
+ });
502
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/index.ts","../src/request.ts","../src/queries.ts","../src/domains/escrows.ts","../src/domains/agents.ts","../src/domains/protocol-stats.ts","../src/domains/transaction-logs.ts","../src/client.ts","../src/agents/eligibility.ts"],"sourcesContent":["/**\n * @zenland/sdk\n *\n * Official SDK for interacting with the Zenland escrow protocol indexer.\n *\n * @example\n * ```typescript\n * import { createZenlandClient, zenland } from '@zenland/sdk';\n *\n * // Use the default client (production API)\n * const escrows = await zenland.escrows.list();\n *\n * // Or create a custom client\n * const client = createZenlandClient({ baseUrl: 'http://localhost:42069' });\n * const agents = await client.agents.list({ onlyActive: true });\n * ```\n */\n\n// Main client\nexport { createZenlandClient, zenland } from \"./client\";\nexport type { ZenlandClient, ZenlandClientConfig } from \"./client\";\n\n// Domain modules (for advanced usage)\nexport {\n createEscrowsDomain,\n createAgentsDomain,\n createProtocolStatsDomain,\n createTransactionLogsDomain,\n STATE_GROUPS,\n} from \"./domains\";\nexport type {\n EscrowsDomain,\n AgentsDomain,\n ProtocolStatsDomain,\n TransactionLogsDomain,\n ListEscrowsArgs,\n ListAgentsArgs,\n ListTransactionLogsArgs,\n StateGroup,\n ProtocolStats,\n} from \"./domains\";\n\n// Types\nexport type {\n // GraphQL types\n GqlAgent,\n GqlAgentCase,\n GqlAgentCasePage,\n GqlAgentPage,\n GqlAgentFilter,\n GqlEscrow,\n GqlEscrowPage,\n GqlEscrowFilter,\n GqlProtocolStats,\n GqlTransactionLog,\n GqlTransactionLogPage,\n GqlTransactionLogFilter,\n GqlPageInfo,\n BigIntScalar,\n Maybe,\n InputMaybe,\n} from \"./generated/types\";\n\n// Protocol / business-logic utilities\nexport {\n computeAgentMavUsd,\n isAgentEligibleForEscrow,\n} from \"./agents/eligibility\";\nexport type {\n IndexerAgent,\n AgentEligibilityFailureReason,\n AgentEligibilityResult,\n} from \"./agents/eligibility\";\n\n// Errors\nexport { ZenlandGraphQLError, ZenlandRequestError } from \"./request\";\n","/**\n * GraphQL request utilities for the Zenland SDK\n */\n\ntype GraphQLErrorLike = {\n message?: string;\n [key: string]: unknown;\n};\n\ntype GraphQLResponse<TData> = {\n data?: TData;\n errors?: GraphQLErrorLike[];\n};\n\n/**\n * Error thrown when the indexer returns GraphQL errors\n */\nexport class ZenlandGraphQLError extends Error {\n public readonly errors: GraphQLErrorLike[];\n\n constructor(message: string, errors: GraphQLErrorLike[]) {\n super(message);\n this.name = \"ZenlandGraphQLError\";\n this.errors = errors;\n }\n}\n\n/**\n * Error thrown when the indexer request fails at the network/HTTP level\n */\nexport class ZenlandRequestError extends Error {\n public readonly status: number;\n public readonly statusText: string;\n\n constructor(message: string, status: number, statusText: string) {\n super(message);\n this.name = \"ZenlandRequestError\";\n this.status = status;\n this.statusText = statusText;\n }\n}\n\nexport interface GraphQLRequestOptions {\n signal?: AbortSignal;\n}\n\n/**\n * Execute a GraphQL request against the Zenland indexer\n */\nexport async function graphqlRequest<TData, TVariables extends object | undefined>(\n baseUrl: string,\n document: string,\n variables?: TVariables,\n options?: GraphQLRequestOptions,\n): Promise<TData> {\n const endpoint = `${baseUrl}/graphql`;\n\n const res = await fetch(endpoint, {\n method: \"POST\",\n headers: {\n \"content-type\": \"application/json\",\n },\n body: JSON.stringify({ query: document, variables }),\n signal: options?.signal,\n cache: \"no-store\",\n });\n\n if (!res.ok) {\n const text = await res.text().catch(() => \"\");\n throw new ZenlandRequestError(\n `Zenland request failed (${res.status} ${res.statusText})${text ? `: ${text}` : \"\"}`,\n res.status,\n res.statusText,\n );\n }\n\n const json = (await res.json()) as GraphQLResponse<TData>;\n\n if (json.errors?.length) {\n throw new ZenlandGraphQLError(\n json.errors.map((e) => e.message ?? \"GraphQL error\").join(\"; \"),\n json.errors,\n );\n }\n\n if (!json.data) {\n throw new Error(\"Zenland response missing data.\");\n }\n\n return json.data;\n}\n","/**\n * GraphQL query strings for the Zenland indexer.\n * These are compiled into the SDK to avoid runtime parsing.\n */\n\nexport const AGENT_QUERY = `\nquery Agent($id: String!) {\n agent(id: $id) {\n id\n isActive\n isAvailable\n stablecoinDecimals\n stablecoinToken\n stablecoinStake\n daoTokenStake\n disputeFeeBps\n assignmentFeeBps\n description\n contact\n totalResolved\n activeCases\n registrationTime\n lastEngagementTimestamp\n totalEarnings\n totalSlashed\n cases(limit: 5, orderBy: \"invitedAt\", orderDirection: \"desc\") {\n items {\n id\n escrow\n invitedAt\n resolvedAt\n timedOut\n escrowRef {\n id\n amount\n token\n state\n }\n }\n totalCount\n }\n }\n}\n`;\n\nexport const AGENTS_QUERY = `\nquery Agents($where: agentFilter, $orderBy: String, $orderDirection: String, $limit: Int, $offset: Int) {\n agents(where: $where, orderBy: $orderBy, orderDirection: $orderDirection, limit: $limit, offset: $offset) {\n totalCount\n items {\n id\n isActive\n isAvailable\n stablecoinDecimals\n stablecoinStake\n daoTokenStake\n disputeFeeBps\n assignmentFeeBps\n description\n contact\n totalResolved\n activeCases\n registrationTime\n lastEngagementTimestamp\n totalEarnings\n totalSlashed\n }\n pageInfo {\n hasNextPage\n hasPreviousPage\n }\n }\n}\n`;\n\nexport const ESCROW_QUERY = `\nquery escrow($id: String!) {\n escrow(id: $id) {\n id\n buyer\n seller\n agent\n amount\n token\n state\n createdAt\n sellerAcceptDeadline\n buyerProtectionTime\n termsHash\n version\n fundedAt\n fulfilledAt\n resolvedAt\n agentInvitedAt\n splitProposer\n proposedBuyerBps\n proposedSellerBps\n buyerApprovedSplit\n sellerApprovedSplit\n agentFeeReceived\n buyerReceived\n sellerReceived\n creationFee\n }\n}\n`;\n\nexport const ESCROWS_QUERY = `\nquery escrows(\n $limit: Int = 30\n $offset: Int = 0\n $orderBy: String = \"createdAt\"\n $orderDirection: String = \"desc\"\n $where: escrowFilter\n) {\n escrows(\n limit: $limit\n offset: $offset\n orderBy: $orderBy\n orderDirection: $orderDirection\n where: $where\n ) {\n items {\n id\n buyer\n seller\n agent\n amount\n token\n state\n createdAt\n fundedAt\n fulfilledAt\n sellerAcceptDeadline\n agentInvitedAt\n buyerProtectionTime\n splitProposer\n buyerApprovedSplit\n sellerApprovedSplit\n proposedBuyerBps\n proposedSellerBps\n }\n pageInfo {\n hasNextPage\n hasPreviousPage\n }\n totalCount\n }\n}\n`;\n\nexport const PROTOCOL_STATS_QUERY = `\nquery protocolStats($id: String! = \"global\") {\n protocolStats(id: $id) {\n id\n totalEscrowsCreated\n totalVolumeEscrowed\n totalFeesCollected\n currentTVL\n activeEscrowCount\n totalAgentsRegistered\n activeAgentsCount\n }\n}\n`;\n\nexport const RECENT_ESCROWS_QUERY = `\nquery recentEscrows($limit: Int = 5) {\n escrows(\n limit: $limit\n orderBy: \"createdAt\"\n orderDirection: \"desc\"\n ) {\n items {\n id\n amount\n token\n state\n createdAt\n }\n }\n}\n`;\n\nexport const TRANSACTION_LOGS_QUERY = `\nquery transactionLogs(\n $escrowAddress: String\n $limit: Int\n $offset: Int\n $orderBy: String\n $orderDirection: String\n) {\n transactionLogs(\n where: { escrowAddress: $escrowAddress }\n limit: $limit\n offset: $offset\n orderBy: $orderBy\n orderDirection: $orderDirection\n ) {\n items {\n id\n txHash\n blockNumber\n timestamp\n eventName\n contractAddress\n contractType\n escrowAddress\n agentAddress\n userAddress\n eventData\n }\n }\n}\n`;\n","/**\n * Escrow domain module for the Zenland SDK\n */\n\nimport { graphqlRequest } from \"../request\";\nimport { ESCROW_QUERY, ESCROWS_QUERY } from \"../queries\";\nimport type {\n GqlEscrow,\n GqlEscrowPage,\n GqlEscrowFilter,\n EscrowQueryResponse,\n EscrowsQueryResponse,\n} from \"../generated/types\";\n\n/** State groups for filtering escrows */\nexport const STATE_GROUPS = {\n ACTIVE: [\"PENDING\", \"ACTIVE\", \"FULFILLED\"] as const,\n IN_DISPUTE: [\"DISPUTED\", \"AGENT_INVITED\"] as const,\n COMPLETED: [\"RELEASED\", \"AGENT_RESOLVED\", \"REFUNDED\", \"SPLIT\"] as const,\n} as const;\n\nexport type StateGroup = keyof typeof STATE_GROUPS;\n\nexport interface ListEscrowsArgs {\n limit?: number;\n offset?: number;\n buyer?: string;\n seller?: string;\n agent?: string;\n /** Search across buyer, seller, or agent roles */\n user?: string;\n state?: string;\n /** Multiple states for group filtering */\n states?: string[];\n orderBy?: string;\n orderDirection?: \"asc\" | \"desc\";\n}\n\n/**\n * Creates escrow domain functions bound to a base URL\n */\nexport function createEscrowsDomain(baseUrl: string) {\n /**\n * List escrows with filtering and pagination\n */\n async function list(args?: ListEscrowsArgs): Promise<GqlEscrowPage> {\n const where: GqlEscrowFilter = {};\n\n // Role-specific filters\n if (args?.buyer) where.buyer = args.buyer.toLowerCase();\n if (args?.seller) where.seller = args.seller.toLowerCase();\n if (args?.agent) where.agent = args.agent.toLowerCase();\n\n // State filters - single or multiple\n if (args?.states && args.states.length > 0) {\n where.state_in = args.states;\n } else if (args?.state) {\n where.state = args.state;\n }\n\n // User filter: search across buyer, seller, or agent roles\n if (args?.user) {\n const userLower = args.user.toLowerCase();\n where.OR = [{ buyer: userLower }, { seller: userLower }, { agent: userLower }];\n }\n\n const variables = {\n limit: args?.limit ?? 30,\n offset: args?.offset ?? 0,\n orderBy: args?.orderBy ?? \"createdAt\",\n orderDirection: args?.orderDirection ?? \"desc\",\n where: Object.keys(where).length > 0 ? where : undefined,\n };\n\n const response = await graphqlRequest<EscrowsQueryResponse, typeof variables>(\n baseUrl,\n ESCROWS_QUERY,\n variables,\n );\n\n return response.escrows;\n }\n\n /**\n * Get a single escrow by ID (address)\n */\n async function getById(id: string): Promise<GqlEscrow | null> {\n const variables = { id: id.toLowerCase() };\n\n const response = await graphqlRequest<EscrowQueryResponse, typeof variables>(\n baseUrl,\n ESCROW_QUERY,\n variables,\n );\n\n return response.escrow;\n }\n\n /**\n * Get escrows for a specific user across all roles\n */\n async function getByUser(\n userAddress: string,\n args?: Omit<ListEscrowsArgs, \"user\" | \"buyer\" | \"seller\" | \"agent\">,\n ): Promise<GqlEscrowPage> {\n return list({ ...args, user: userAddress });\n }\n\n /**\n * Get escrows by state group\n */\n async function getByStateGroup(\n stateGroup: StateGroup,\n args?: Omit<ListEscrowsArgs, \"state\" | \"states\">,\n ): Promise<GqlEscrowPage> {\n return list({ ...args, states: [...STATE_GROUPS[stateGroup]] });\n }\n\n return {\n list,\n getById,\n getByUser,\n getByStateGroup,\n };\n}\n\nexport type EscrowsDomain = ReturnType<typeof createEscrowsDomain>;\n","/**\n * Agent domain module for the Zenland SDK\n */\n\nimport { graphqlRequest } from \"../request\";\nimport { AGENT_QUERY, AGENTS_QUERY } from \"../queries\";\nimport type {\n GqlAgent,\n GqlAgentPage,\n GqlAgentFilter,\n AgentQueryResponse,\n AgentsQueryResponse,\n} from \"../generated/types\";\n\nexport interface ListAgentsArgs {\n limit?: number;\n offset?: number;\n onlyActive?: boolean;\n onlyAvailable?: boolean;\n orderBy?: string;\n orderDirection?: \"asc\" | \"desc\";\n}\n\n/**\n * Creates agent domain functions bound to a base URL\n */\nexport function createAgentsDomain(baseUrl: string) {\n /**\n * List agents with filtering and pagination\n */\n async function list(args?: ListAgentsArgs): Promise<GqlAgentPage> {\n const where: GqlAgentFilter = {};\n\n if (args?.onlyActive) where.isActive = true;\n if (args?.onlyAvailable) where.isAvailable = true;\n\n const variables = {\n limit: args?.limit ?? 30,\n offset: args?.offset ?? 0,\n orderBy: args?.orderBy ?? \"totalResolved\",\n orderDirection: args?.orderDirection ?? \"desc\",\n where: Object.keys(where).length > 0 ? where : undefined,\n };\n\n const response = await graphqlRequest<AgentsQueryResponse, typeof variables>(\n baseUrl,\n AGENTS_QUERY,\n variables,\n );\n\n return response.agents;\n }\n\n /**\n * Get a single agent by ID (address)\n */\n async function getById(id: string): Promise<GqlAgent | null> {\n const variables = { id: id.toLowerCase() };\n\n const response = await graphqlRequest<AgentQueryResponse, typeof variables>(\n baseUrl,\n AGENT_QUERY,\n variables,\n );\n\n return response.agent;\n }\n\n /**\n * Get all active and available agents\n */\n async function getAvailable(args?: Omit<ListAgentsArgs, \"onlyActive\" | \"onlyAvailable\">): Promise<GqlAgentPage> {\n return list({ ...args, onlyActive: true, onlyAvailable: true });\n }\n\n return {\n list,\n getById,\n getAvailable,\n };\n}\n\nexport type AgentsDomain = ReturnType<typeof createAgentsDomain>;\n","/**\n * Protocol Stats domain module for the Zenland SDK\n */\n\nimport { graphqlRequest } from \"../request\";\nimport { PROTOCOL_STATS_QUERY } from \"../queries\";\nimport type { GqlProtocolStats, ProtocolStatsQueryResponse } from \"../generated/types\";\n\n/** Normalized protocol stats with BigInt values */\nexport interface ProtocolStats {\n id: string;\n totalEscrowsCreated: number;\n totalVolumeEscrowed: bigint;\n totalFeesCollected: bigint;\n currentTVL: bigint;\n activeEscrowCount: number;\n totalAgentsRegistered: number;\n activeAgentsCount: number;\n}\n\n/**\n * Convert raw GraphQL response to normalized ProtocolStats\n */\nfunction normalizeProtocolStats(raw: GqlProtocolStats): ProtocolStats {\n return {\n id: raw.id,\n totalEscrowsCreated: raw.totalEscrowsCreated,\n totalVolumeEscrowed: BigInt(raw.totalVolumeEscrowed),\n totalFeesCollected: BigInt(raw.totalFeesCollected),\n currentTVL: BigInt(raw.currentTVL),\n activeEscrowCount: raw.activeEscrowCount,\n totalAgentsRegistered: raw.totalAgentsRegistered,\n activeAgentsCount: raw.activeAgentsCount,\n };\n}\n\n/**\n * Creates protocol stats domain functions bound to a base URL\n */\nexport function createProtocolStatsDomain(baseUrl: string) {\n /**\n * Fetch global protocol statistics\n */\n async function get(): Promise<ProtocolStats | null> {\n const variables = { id: \"global\" };\n\n const response = await graphqlRequest<ProtocolStatsQueryResponse, typeof variables>(\n baseUrl,\n PROTOCOL_STATS_QUERY,\n variables,\n );\n\n if (!response.protocolStats) {\n return null;\n }\n\n return normalizeProtocolStats(response.protocolStats);\n }\n\n /**\n * Fetch raw protocol statistics (without BigInt conversion)\n */\n async function getRaw(): Promise<GqlProtocolStats | null> {\n const variables = { id: \"global\" };\n\n const response = await graphqlRequest<ProtocolStatsQueryResponse, typeof variables>(\n baseUrl,\n PROTOCOL_STATS_QUERY,\n variables,\n );\n\n return response.protocolStats;\n }\n\n return {\n get,\n getRaw,\n };\n}\n\nexport type ProtocolStatsDomain = ReturnType<typeof createProtocolStatsDomain>;\n","/**\n * Transaction Logs domain module for the Zenland SDK\n */\n\nimport { graphqlRequest } from \"../request\";\nimport { TRANSACTION_LOGS_QUERY } from \"../queries\";\nimport type { GqlTransactionLog, TransactionLogsQueryResponse } from \"../generated/types\";\n\nexport interface ListTransactionLogsArgs {\n escrowAddress?: string;\n limit?: number;\n offset?: number;\n orderBy?: string;\n orderDirection?: \"asc\" | \"desc\";\n}\n\n/**\n * Creates transaction logs domain functions bound to a base URL\n */\nexport function createTransactionLogsDomain(baseUrl: string) {\n /**\n * List transaction logs with filtering and pagination\n */\n async function list(args?: ListTransactionLogsArgs): Promise<GqlTransactionLog[]> {\n const variables = {\n escrowAddress: args?.escrowAddress?.toLowerCase(),\n limit: args?.limit ?? 100,\n offset: args?.offset ?? 0,\n orderBy: args?.orderBy ?? \"timestamp\",\n orderDirection: args?.orderDirection ?? \"asc\",\n };\n\n const response = await graphqlRequest<TransactionLogsQueryResponse, typeof variables>(\n baseUrl,\n TRANSACTION_LOGS_QUERY,\n variables,\n );\n\n return response.transactionLogs.items;\n }\n\n /**\n * Get transaction logs for a specific escrow\n */\n async function getByEscrow(\n escrowAddress: string,\n args?: Omit<ListTransactionLogsArgs, \"escrowAddress\">,\n ): Promise<GqlTransactionLog[]> {\n return list({ ...args, escrowAddress });\n }\n\n /**\n * Parse eventData JSON string from a transaction log\n */\n function parseEventData(eventData: string): Record<string, unknown> {\n try {\n return JSON.parse(eventData);\n } catch {\n return {};\n }\n }\n\n return {\n list,\n getByEscrow,\n parseEventData,\n };\n}\n\nexport type TransactionLogsDomain = ReturnType<typeof createTransactionLogsDomain>;\n","/**\n * Zenland SDK Client\n *\n * The main entry point for interacting with the Zenland indexer.\n */\n\nimport { createEscrowsDomain, type EscrowsDomain } from \"./domains/escrows\";\nimport { createAgentsDomain, type AgentsDomain } from \"./domains/agents\";\nimport { createProtocolStatsDomain, type ProtocolStatsDomain } from \"./domains/protocol-stats\";\nimport { createTransactionLogsDomain, type TransactionLogsDomain } from \"./domains/transaction-logs\";\n\n/** Default production indexer URL */\nconst DEFAULT_BASE_URL = \"https://api.zen.land\";\n\nexport interface ZenlandClientConfig {\n /** Base URL for the indexer API. Defaults to https://api.zen.land */\n baseUrl?: string;\n}\n\nexport interface ZenlandClient {\n /** The base URL being used by this client */\n readonly baseUrl: string;\n\n /** Escrow-related operations */\n readonly escrows: EscrowsDomain;\n\n /** Agent-related operations */\n readonly agents: AgentsDomain;\n\n /** Protocol statistics */\n readonly protocolStats: ProtocolStatsDomain;\n\n /** Transaction logs */\n readonly transactionLogs: TransactionLogsDomain;\n}\n\n/**\n * Create a new Zenland SDK client.\n *\n * @example\n * ```typescript\n * // Use production API (default)\n * const client = createZenlandClient();\n *\n * // Use custom endpoint (e.g., local development)\n * const client = createZenlandClient({ baseUrl: 'http://localhost:42069' });\n *\n * // Fetch escrows\n * const { items, totalCount } = await client.escrows.list({ limit: 10 });\n *\n * // Fetch a specific escrow\n * const escrow = await client.escrows.getById('0x...');\n *\n * // Fetch agents\n * const agents = await client.agents.list({ onlyActive: true });\n *\n * // Fetch protocol stats\n * const stats = await client.protocolStats.get();\n * ```\n */\nexport function createZenlandClient(config?: ZenlandClientConfig): ZenlandClient {\n const baseUrl = normalizeBaseUrl(config?.baseUrl ?? DEFAULT_BASE_URL);\n\n return {\n baseUrl,\n escrows: createEscrowsDomain(baseUrl),\n agents: createAgentsDomain(baseUrl),\n protocolStats: createProtocolStatsDomain(baseUrl),\n transactionLogs: createTransactionLogsDomain(baseUrl),\n };\n}\n\n/**\n * Normalize base URL by removing trailing slash\n */\nfunction normalizeBaseUrl(url: string): string {\n return url.endsWith(\"/\") ? url.slice(0, -1) : url;\n}\n\n/**\n * Default client instance using production API.\n * Use this for quick access without creating a new client.\n *\n * @example\n * ```typescript\n * import { zenland } from '@zenland/sdk';\n *\n * const escrows = await zenland.escrows.list();\n * ```\n */\nexport const zenland = createZenlandClient();\n","/**\n * Agent eligibility utilities.\n *\n * This is protocol/business logic (React-agnostic) and is safe to consume\n * from any app (interface, backend, bots, etc.).\n */\n\n/**\n * Minimal view of an Agent returned by the indexer.\n */\nexport type IndexerAgent = {\n id: string;\n isActive: boolean;\n isAvailable: boolean;\n stablecoinStake: bigint;\n stablecoinDecimals: number;\n registrationTime: bigint;\n activeCases: number;\n totalResolved: number;\n};\n\nexport type AgentEligibilityFailureReason =\n | \"NOT_REGISTERED\"\n | \"NOT_ACTIVE\"\n | \"NOT_AVAILABLE\"\n | \"INSUFFICIENT_MAV\";\n\nexport type AgentEligibilityResult =\n | {\n ok: true;\n agentMavUsd: bigint;\n requiredUsd: bigint;\n }\n | {\n ok: false;\n reason: AgentEligibilityFailureReason;\n agentMavUsd?: bigint;\n requiredUsd: bigint;\n };\n\n/**\n * MAV multiplier - how much MAV you get per dollar staked.\n * $1 stake * 20 = $20 MAV\n */\nconst MAV_MULTIPLIER = 20n;\n\n/**\n * Compute agent MAV from its stablecoin stake.\n *\n * Bigint-safe:\n * - stablecoinStake is in smallest units (stablecoinDecimals)\n * - return MAV in the same smallest units (stablecoinDecimals)\n */\nexport function computeAgentMavUsd(\n agent: Pick<IndexerAgent, \"stablecoinStake\" | \"stablecoinDecimals\">,\n): bigint {\n // decimals are not used in arithmetic; they’re carried for formatting.\n // MAV is a simple multiplier in the same units.\n return BigInt(agent.stablecoinStake) * MAV_MULTIPLIER;\n}\n\n/**\n * Evaluate whether an agent is eligible for a given escrow amount.\n *\n * NOTE: escrowAmount must be the escrow principal ONLY (fees excluded).\n */\nexport function isAgentEligibleForEscrow(args: {\n agent: IndexerAgent | null | undefined;\n escrowAmount: bigint;\n}): AgentEligibilityResult {\n const requiredUsd = args.escrowAmount;\n\n if (!args.agent) {\n return { ok: false, reason: \"NOT_REGISTERED\", requiredUsd };\n }\n\n if (!args.agent.isActive) {\n return { ok: false, reason: \"NOT_ACTIVE\", requiredUsd };\n }\n\n if (!args.agent.isAvailable) {\n return { ok: false, reason: \"NOT_AVAILABLE\", requiredUsd };\n }\n\n const agentMavUsd = computeAgentMavUsd(args.agent);\n\n if (agentMavUsd < requiredUsd) {\n return { ok: false, reason: \"INSUFFICIENT_MAV\", agentMavUsd, requiredUsd };\n }\n\n return { ok: true, agentMavUsd, requiredUsd };\n}\n"],"mappings":"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","names":[]}