@secretkeylabs/stacks-tools 0.2.0 → 0.3.0-05c5288

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.
Files changed (96) hide show
  1. package/dist/index.cjs +1090 -0
  2. package/dist/index.d.cts +661 -0
  3. package/dist/index.d.ts +661 -2
  4. package/dist/index.js +1052 -3
  5. package/package.json +13 -5
  6. package/dist/index.js.map +0 -1
  7. package/dist/pox4-api/burn-height-to-reward-cycle.d.ts +0 -7
  8. package/dist/pox4-api/burn-height-to-reward-cycle.js +0 -6
  9. package/dist/pox4-api/burn-height-to-reward-cycle.js.map +0 -1
  10. package/dist/pox4-api/current-pox-reward-cycle.d.ts +0 -1
  11. package/dist/pox4-api/current-pox-reward-cycle.js +0 -3
  12. package/dist/pox4-api/current-pox-reward-cycle.js.map +0 -1
  13. package/dist/pox4-api/get-stacker-info.d.ts +0 -1
  14. package/dist/pox4-api/get-stacker-info.js +0 -3
  15. package/dist/pox4-api/get-stacker-info.js.map +0 -1
  16. package/dist/pox4-api/reward-cycle-to-burn-height.d.ts +0 -1
  17. package/dist/pox4-api/reward-cycle-to-burn-height.js +0 -3
  18. package/dist/pox4-api/reward-cycle-to-burn-height.js.map +0 -1
  19. package/dist/queries/get-signer-total-locked.d.ts +0 -18
  20. package/dist/queries/get-signer-total-locked.js +0 -59
  21. package/dist/queries/get-signer-total-locked.js.map +0 -1
  22. package/dist/queries/index.d.ts +0 -4
  23. package/dist/queries/index.js +0 -5
  24. package/dist/queries/index.js.map +0 -1
  25. package/dist/stacks-api/accounts/balances.d.ts +0 -34
  26. package/dist/stacks-api/accounts/balances.js +0 -70
  27. package/dist/stacks-api/accounts/balances.js.map +0 -1
  28. package/dist/stacks-api/accounts/index.d.ts +0 -4
  29. package/dist/stacks-api/accounts/index.js +0 -5
  30. package/dist/stacks-api/accounts/index.js.map +0 -1
  31. package/dist/stacks-api/blocks/get-block.d.ts +0 -29
  32. package/dist/stacks-api/blocks/get-block.js +0 -62
  33. package/dist/stacks-api/blocks/get-block.js.map +0 -1
  34. package/dist/stacks-api/blocks/index.d.ts +0 -4
  35. package/dist/stacks-api/blocks/index.js +0 -5
  36. package/dist/stacks-api/blocks/index.js.map +0 -1
  37. package/dist/stacks-api/index.d.ts +0 -28
  38. package/dist/stacks-api/index.js +0 -17
  39. package/dist/stacks-api/index.js.map +0 -1
  40. package/dist/stacks-api/info/core-api.d.ts +0 -21
  41. package/dist/stacks-api/info/core-api.js +0 -55
  42. package/dist/stacks-api/info/core-api.js.map +0 -1
  43. package/dist/stacks-api/info/index.d.ts +0 -6
  44. package/dist/stacks-api/info/index.js +0 -7
  45. package/dist/stacks-api/info/index.js.map +0 -1
  46. package/dist/stacks-api/info/pox-details.d.ts +0 -59
  47. package/dist/stacks-api/info/pox-details.js +0 -92
  48. package/dist/stacks-api/info/pox-details.js.map +0 -1
  49. package/dist/stacks-api/proof-of-transfer/cycle.d.ts +0 -16
  50. package/dist/stacks-api/proof-of-transfer/cycle.js +0 -50
  51. package/dist/stacks-api/proof-of-transfer/cycle.js.map +0 -1
  52. package/dist/stacks-api/proof-of-transfer/cycles.d.ts +0 -37
  53. package/dist/stacks-api/proof-of-transfer/cycles.js +0 -61
  54. package/dist/stacks-api/proof-of-transfer/cycles.js.map +0 -1
  55. package/dist/stacks-api/proof-of-transfer/index.d.ts +0 -10
  56. package/dist/stacks-api/proof-of-transfer/index.js +0 -11
  57. package/dist/stacks-api/proof-of-transfer/index.js.map +0 -1
  58. package/dist/stacks-api/proof-of-transfer/signers-in-cycle.d.ts +0 -45
  59. package/dist/stacks-api/proof-of-transfer/signers-in-cycle.js +0 -66
  60. package/dist/stacks-api/proof-of-transfer/signers-in-cycle.js.map +0 -1
  61. package/dist/stacks-api/proof-of-transfer/stackers-for-signer-in-cycle.d.ts +0 -34
  62. package/dist/stacks-api/proof-of-transfer/stackers-for-signer-in-cycle.js +0 -59
  63. package/dist/stacks-api/proof-of-transfer/stackers-for-signer-in-cycle.js.map +0 -1
  64. package/dist/stacks-api/smart-contracts/index.d.ts +0 -4
  65. package/dist/stacks-api/smart-contracts/index.js +0 -5
  66. package/dist/stacks-api/smart-contracts/index.js.map +0 -1
  67. package/dist/stacks-api/smart-contracts/read-only.d.ts +0 -19
  68. package/dist/stacks-api/smart-contracts/read-only.js +0 -50
  69. package/dist/stacks-api/smart-contracts/read-only.js.map +0 -1
  70. package/dist/stacks-api/stacking-pool/index.d.ts +0 -4
  71. package/dist/stacks-api/stacking-pool/index.js +0 -5
  72. package/dist/stacks-api/stacking-pool/index.js.map +0 -1
  73. package/dist/stacks-api/stacking-pool/members.d.ts +0 -34
  74. package/dist/stacks-api/stacking-pool/members.js +0 -64
  75. package/dist/stacks-api/stacking-pool/members.js.map +0 -1
  76. package/dist/stacks-api/transactions/address-transactions.d.ts +0 -487
  77. package/dist/stacks-api/transactions/address-transactions.js +0 -75
  78. package/dist/stacks-api/transactions/address-transactions.js.map +0 -1
  79. package/dist/stacks-api/transactions/get-transaction.d.ts +0 -8
  80. package/dist/stacks-api/transactions/get-transaction.js +0 -42
  81. package/dist/stacks-api/transactions/get-transaction.js.map +0 -1
  82. package/dist/stacks-api/transactions/index.d.ts +0 -6
  83. package/dist/stacks-api/transactions/index.js +0 -7
  84. package/dist/stacks-api/transactions/index.js.map +0 -1
  85. package/dist/stacks-api/transactions/schemas.d.ts +0 -327
  86. package/dist/stacks-api/transactions/schemas.js +0 -85
  87. package/dist/stacks-api/transactions/schemas.js.map +0 -1
  88. package/dist/stacks-api/types.d.ts +0 -26
  89. package/dist/stacks-api/types.js +0 -8
  90. package/dist/stacks-api/types.js.map +0 -1
  91. package/dist/utils/call-rate-limited-api.d.ts +0 -8
  92. package/dist/utils/call-rate-limited-api.js +0 -28
  93. package/dist/utils/call-rate-limited-api.js.map +0 -1
  94. package/dist/utils/safe.d.ts +0 -10
  95. package/dist/utils/safe.js +0 -31
  96. package/dist/utils/safe.js.map +0 -1
package/dist/index.cjs ADDED
@@ -0,0 +1,1090 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+
30
+ // src/index.ts
31
+ var src_exports = {};
32
+ __export(src_exports, {
33
+ queries: () => queries,
34
+ stacksApi: () => stacksApi
35
+ });
36
+ module.exports = __toCommonJS(src_exports);
37
+
38
+ // src/utils/safe.ts
39
+ function success(data) {
40
+ return [null, data];
41
+ }
42
+ function error(error2) {
43
+ return [error2, null];
44
+ }
45
+ async function safePromise(promise) {
46
+ try {
47
+ return success(await promise);
48
+ } catch (e) {
49
+ return error({
50
+ name: "SafePromiseError",
51
+ message: "Safe promise rejected.",
52
+ data: e
53
+ });
54
+ }
55
+ }
56
+
57
+ // src/stacks-api/accounts/balances.ts
58
+ var v = __toESM(require("valibot"), 1);
59
+ var responseSchema = v.object({
60
+ stx: v.object({
61
+ balance: v.string(),
62
+ total_sent: v.string(),
63
+ total_received: v.string(),
64
+ total_fees_sent: v.string(),
65
+ total_miner_rewards_received: v.string(),
66
+ lock_tx_id: v.string(),
67
+ locked: v.string(),
68
+ lock_height: v.number(),
69
+ burnchain_lock_height: v.number(),
70
+ burnchain_unlock_height: v.number()
71
+ }),
72
+ fungible_tokens: v.record(
73
+ v.string(),
74
+ v.object({
75
+ balance: v.string(),
76
+ total_sent: v.string(),
77
+ total_received: v.string()
78
+ })
79
+ ),
80
+ non_fungible_tokens: v.record(
81
+ v.string(),
82
+ v.object({
83
+ count: v.string(),
84
+ total_sent: v.string(),
85
+ total_received: v.string()
86
+ })
87
+ )
88
+ });
89
+ async function balances(opts) {
90
+ const search = new URLSearchParams();
91
+ if (opts.unanchored) search.append("unanchored", "true");
92
+ if (opts.untilBlock) search.append("until_block", opts.untilBlock.toString());
93
+ const init = {};
94
+ if (opts.apiKeyConfig) {
95
+ init.headers = {
96
+ [opts.apiKeyConfig.header]: opts.apiKeyConfig.key
97
+ };
98
+ }
99
+ const endpoint = `${opts.baseUrl}/extended/v1/address/${opts.principal}/balances?${search}`;
100
+ const res = await fetch(endpoint, init);
101
+ if (!res.ok) {
102
+ return error({
103
+ name: "FetchBalancesError",
104
+ message: "Failed to fetch balances.",
105
+ data: {
106
+ status: res.status,
107
+ statusText: res.statusText,
108
+ bodyParseResult: await safePromise(res.json())
109
+ }
110
+ });
111
+ }
112
+ const [jsonError, data] = await safePromise(res.json());
113
+ if (jsonError) {
114
+ return error({
115
+ name: "ParseBodyError",
116
+ message: "Failed to parse response body as JSON.",
117
+ data: jsonError
118
+ });
119
+ }
120
+ const validationResult = v.safeParse(responseSchema, data);
121
+ if (!validationResult.success) {
122
+ return error({
123
+ name: "ValidateDataError",
124
+ message: "Failed to validate data.",
125
+ data: validationResult
126
+ });
127
+ }
128
+ return success(validationResult.output);
129
+ }
130
+
131
+ // src/stacks-api/accounts/index.ts
132
+ var accounts = {
133
+ balances
134
+ };
135
+
136
+ // src/stacks-api/types.ts
137
+ var v2 = __toESM(require("valibot"), 1);
138
+ var baseListResponseSchema = v2.object({
139
+ limit: v2.number(),
140
+ offset: v2.number(),
141
+ total: v2.number(),
142
+ results: v2.array(v2.unknown())
143
+ });
144
+
145
+ // src/stacks-api/blocks/get-block.ts
146
+ var v3 = __toESM(require("valibot"), 1);
147
+ var responseSchema2 = v3.object({
148
+ canonical: v3.boolean(),
149
+ height: v3.number(),
150
+ hash: v3.string(),
151
+ block_time: v3.number(),
152
+ block_time_iso: v3.string(),
153
+ index_block_hash: v3.string(),
154
+ parent_block_hash: v3.string(),
155
+ parent_index_block_hash: v3.string(),
156
+ burn_block_time: v3.number(),
157
+ burn_block_time_iso: v3.string(),
158
+ burn_block_hash: v3.string(),
159
+ burn_block_height: v3.number(),
160
+ miner_txid: v3.string(),
161
+ tx_count: v3.number(),
162
+ execution_cost_read_count: v3.number(),
163
+ execution_cost_read_length: v3.number(),
164
+ execution_cost_runtime: v3.number(),
165
+ execution_cost_write_count: v3.number(),
166
+ execution_cost_write_length: v3.number()
167
+ });
168
+ async function getBlock(opts) {
169
+ const init = {};
170
+ if (opts.apiKeyConfig) {
171
+ init.headers = {
172
+ [opts.apiKeyConfig.header]: opts.apiKeyConfig.key
173
+ };
174
+ }
175
+ const res = await fetch(
176
+ `${opts.baseUrl}/extended/v2/blocks/${opts.heightOrHash}`,
177
+ init
178
+ );
179
+ if (!res.ok) {
180
+ return error({
181
+ name: "FetchBlockError",
182
+ message: "Failed to fetch block.",
183
+ data: {
184
+ status: res.status,
185
+ statusText: res.statusText,
186
+ bodyParseResult: await safePromise(res.json())
187
+ }
188
+ });
189
+ }
190
+ const [jsonError, data] = await safePromise(res.json());
191
+ if (jsonError) {
192
+ return error({
193
+ name: "ParseBodyError",
194
+ message: "Failed to parse body.",
195
+ data: jsonError
196
+ });
197
+ }
198
+ const validationResult = v3.safeParse(responseSchema2, data);
199
+ if (!validationResult.success) {
200
+ return error({
201
+ name: "ValidateDataError",
202
+ message: "Failed to validate data.",
203
+ data: validationResult
204
+ });
205
+ }
206
+ return success(validationResult.output);
207
+ }
208
+
209
+ // src/stacks-api/blocks/index.ts
210
+ var blocks = {
211
+ getBlock
212
+ };
213
+
214
+ // src/stacks-api/info/core-api.ts
215
+ var v4 = __toESM(require("valibot"), 1);
216
+ var CoreApiResponseSchema = v4.object({
217
+ peer_version: v4.number(),
218
+ pox_consensus: v4.string(),
219
+ burn_block_height: v4.number(),
220
+ stable_pox_consensus: v4.string(),
221
+ stable_burn_block_height: v4.number(),
222
+ server_version: v4.string(),
223
+ network_id: v4.number(),
224
+ parent_network_id: v4.number(),
225
+ stacks_tip_height: v4.number(),
226
+ stacks_tip: v4.string(),
227
+ stacks_tip_consensus_hash: v4.string(),
228
+ unanchored_tip: v4.string(),
229
+ exit_at_block_height: v4.number()
230
+ });
231
+ async function coreApi(apiOpts) {
232
+ const init = {};
233
+ if (apiOpts.apiKeyConfig) {
234
+ init.headers = {
235
+ [apiOpts.apiKeyConfig.header]: apiOpts.apiKeyConfig.key
236
+ };
237
+ }
238
+ const res = await fetch(`${apiOpts.baseUrl}/v2/info`, init);
239
+ if (!res.ok) {
240
+ return error({
241
+ name: "FetchCoreApiError",
242
+ message: "Failed to fetch.",
243
+ data: {
244
+ status: res.status,
245
+ statusText: res.statusText,
246
+ bodyParseResult: await safePromise(res.json())
247
+ }
248
+ });
249
+ }
250
+ const [parseBodyError, data] = await safePromise(res.json());
251
+ if (parseBodyError) {
252
+ return error({
253
+ name: "ParseBodyError",
254
+ message: "Failed to parse response body as JSON.",
255
+ data: parseBodyError
256
+ });
257
+ }
258
+ const validationResult = v4.safeParse(CoreApiResponseSchema, data);
259
+ if (!validationResult.success) {
260
+ return error({
261
+ name: "ValidateDataError",
262
+ message: "Failed to validate data.",
263
+ data: validationResult
264
+ });
265
+ }
266
+ return success(validationResult.output);
267
+ }
268
+
269
+ // src/stacks-api/info/pox-details.ts
270
+ var v5 = __toESM(require("valibot"), 1);
271
+ var poxDetailsResponseSchema = v5.object({
272
+ contract_id: v5.string(),
273
+ pox_activation_threshold_ustx: v5.number(),
274
+ first_burnchain_block_height: v5.number(),
275
+ current_burnchain_block_height: v5.number(),
276
+ prepare_phase_block_length: v5.number(),
277
+ reward_phase_block_length: v5.number(),
278
+ reward_slots: v5.number(),
279
+ rejection_fraction: v5.null(),
280
+ total_liquid_supply_ustx: v5.number(),
281
+ current_cycle: v5.object({
282
+ id: v5.number(),
283
+ min_threshold_ustx: v5.number(),
284
+ stacked_ustx: v5.number(),
285
+ is_pox_active: v5.boolean()
286
+ }),
287
+ next_cycle: v5.object({
288
+ id: v5.number(),
289
+ min_threshold_ustx: v5.number(),
290
+ min_increment_ustx: v5.number(),
291
+ stacked_ustx: v5.number(),
292
+ prepare_phase_start_block_height: v5.number(),
293
+ blocks_until_prepare_phase: v5.number(),
294
+ reward_phase_start_block_height: v5.number(),
295
+ blocks_until_reward_phase: v5.number(),
296
+ ustx_until_pox_rejection: v5.null()
297
+ }),
298
+ epochs: v5.array(
299
+ v5.object({
300
+ epoch_id: v5.string(),
301
+ start_height: v5.number(),
302
+ end_height: v5.number(),
303
+ block_limit: v5.object({
304
+ write_length: v5.number(),
305
+ write_count: v5.number(),
306
+ read_length: v5.number(),
307
+ read_count: v5.number(),
308
+ runtime: v5.number()
309
+ }),
310
+ network_epoch: v5.number()
311
+ })
312
+ ),
313
+ min_amount_ustx: v5.number(),
314
+ prepare_cycle_length: v5.number(),
315
+ reward_cycle_id: v5.number(),
316
+ reward_cycle_length: v5.number(),
317
+ rejection_votes_left_required: v5.null(),
318
+ next_reward_cycle_in: v5.number(),
319
+ contract_versions: v5.array(
320
+ v5.object({
321
+ contract_id: v5.string(),
322
+ activation_burnchain_block_height: v5.number(),
323
+ first_reward_cycle_id: v5.number()
324
+ })
325
+ )
326
+ });
327
+ async function poxDetails(args) {
328
+ const init = {};
329
+ if (args.apiKeyConfig) {
330
+ init.headers = {
331
+ [args.apiKeyConfig.header]: args.apiKeyConfig.key
332
+ };
333
+ }
334
+ const res = await fetch(`${args.baseUrl}/v2/pox`, init);
335
+ if (!res.ok) {
336
+ return error({
337
+ name: "FetchPoxDetailsError",
338
+ message: "Failed to fetch pox details.",
339
+ data: {
340
+ status: res.status,
341
+ statusText: res.statusText,
342
+ bodyParseResult: await safePromise(res.json())
343
+ }
344
+ });
345
+ }
346
+ const [jsonParseError, data] = await safePromise(res.json());
347
+ if (jsonParseError) {
348
+ return error({
349
+ name: "ParseBodyError",
350
+ message: "Failed to parse pox details response.",
351
+ data: jsonParseError
352
+ });
353
+ }
354
+ const validationResult = v5.safeParse(poxDetailsResponseSchema, data);
355
+ if (!validationResult.success) {
356
+ return error({
357
+ name: "ValidateDataError",
358
+ message: "Failed to parse pox details response.",
359
+ data: validationResult
360
+ });
361
+ }
362
+ return success(validationResult.output);
363
+ }
364
+
365
+ // src/stacks-api/info/index.ts
366
+ var info = {
367
+ coreApi,
368
+ poxDetails
369
+ };
370
+
371
+ // src/stacks-api/proof-of-transfer/cycle.ts
372
+ var v6 = __toESM(require("valibot"), 1);
373
+ var responseSchema3 = v6.object({
374
+ block_height: v6.number(),
375
+ index_block_hash: v6.string(),
376
+ cycle_number: v6.number(),
377
+ total_weight: v6.number(),
378
+ total_stacked_amount: v6.string(),
379
+ total_signers: v6.number()
380
+ });
381
+ async function cycle(opts) {
382
+ const init = {};
383
+ if (opts.apiKeyConfig) {
384
+ init.headers = {
385
+ [opts.apiKeyConfig.header]: opts.apiKeyConfig.key
386
+ };
387
+ }
388
+ const endpoint = `${opts.baseUrl}/extended/v2/pox/cycles/${opts.cycleNumber}`;
389
+ const res = await fetch(endpoint, init);
390
+ if (!res.ok) {
391
+ return error({
392
+ name: "FetchCycleError",
393
+ message: "Failed to fetch cycle.",
394
+ data: {
395
+ endpoint,
396
+ status: res.status,
397
+ statusText: res.statusText,
398
+ bodyParseResult: await safePromise(res.json())
399
+ }
400
+ });
401
+ }
402
+ const [jsonError, data] = await safePromise(res.json());
403
+ if (jsonError) {
404
+ return error({
405
+ name: "ParseBodyError",
406
+ message: "Failed to parse response body as JSON.",
407
+ data: jsonError
408
+ });
409
+ }
410
+ const validationResult = v6.safeParse(responseSchema3, data);
411
+ if (!validationResult.success) {
412
+ return error({
413
+ name: "ValidateDataError",
414
+ message: "Failed to validate data.",
415
+ data: validationResult
416
+ });
417
+ }
418
+ return success(validationResult.output);
419
+ }
420
+
421
+ // src/stacks-api/proof-of-transfer/cycles.ts
422
+ var v7 = __toESM(require("valibot"), 1);
423
+ var cycleInfoSchema = v7.object({
424
+ block_height: v7.number(),
425
+ index_block_hash: v7.string(),
426
+ cycle_number: v7.number(),
427
+ total_weight: v7.number(),
428
+ total_stacked_amount: v7.string(),
429
+ total_signers: v7.number()
430
+ });
431
+ var resultsSchema = v7.array(cycleInfoSchema);
432
+ var cyclesResponseSchema = v7.object({
433
+ ...baseListResponseSchema.entries,
434
+ results: resultsSchema
435
+ });
436
+ async function cycles(args) {
437
+ const search = new URLSearchParams();
438
+ if (args.limit) search.append("limit", args.limit.toString());
439
+ if (args.offset) search.append("offset", args.offset.toString());
440
+ const init = {};
441
+ if (args.apiKeyConfig) {
442
+ init.headers = {
443
+ [args.apiKeyConfig.header]: args.apiKeyConfig.key
444
+ };
445
+ }
446
+ const endpoint = `${args.baseUrl}/extended/v2/pox/cycles`;
447
+ const res = await fetch(endpoint, init);
448
+ if (!res.ok) {
449
+ return error({
450
+ name: "FetchCyclesError",
451
+ message: "Failed to fetch cycles.",
452
+ data: {
453
+ endpoint,
454
+ status: res.status,
455
+ statusText: res.statusText,
456
+ bodyParseResult: await safePromise(res.json())
457
+ }
458
+ });
459
+ }
460
+ const [jsonError, data] = await safePromise(res.json());
461
+ if (jsonError) {
462
+ return error({
463
+ name: "ParseBodyError",
464
+ message: "Failed to parse response body as JSON.",
465
+ data: jsonError
466
+ });
467
+ }
468
+ const validationResult = v7.safeParse(cyclesResponseSchema, data);
469
+ if (!validationResult.success) {
470
+ return error({
471
+ name: "ValidateDataError",
472
+ message: "Failed to validate response data.",
473
+ data: validationResult
474
+ });
475
+ }
476
+ return success(validationResult.output);
477
+ }
478
+
479
+ // src/stacks-api/proof-of-transfer/signer-in-cycle.ts
480
+ var v8 = __toESM(require("valibot"), 1);
481
+ var signerInCycleResponseSchema = v8.object({
482
+ signing_key: v8.string(),
483
+ signer_address: v8.string(),
484
+ weight: v8.number(),
485
+ stacked_amount: v8.string(),
486
+ weight_percent: v8.number(),
487
+ stacked_amount_percent: v8.number(),
488
+ solo_stacker_count: v8.number(),
489
+ pooled_stacker_count: v8.number()
490
+ });
491
+ async function signerInCycle(args) {
492
+ const init = {};
493
+ if (args.apiKeyConfig) {
494
+ init.headers = {
495
+ [args.apiKeyConfig.header]: args.apiKeyConfig.key
496
+ };
497
+ }
498
+ const signerPublicKey = args.signerPublicKey.startsWith("0x") ? args.signerPublicKey : `0x${args.signerPublicKey}`;
499
+ const endpoint = `${args.baseUrl}/extended/v2/pox/cycles/${args.cycleId}/signers/${signerPublicKey}`;
500
+ const res = await fetch(endpoint, init);
501
+ if (!res.ok) {
502
+ return error({
503
+ name: "FetchSignerInCycleError",
504
+ message: "Failed to fetch signer in cycle.",
505
+ data: {
506
+ ...args,
507
+ endpoint,
508
+ status: res.status,
509
+ statusText: res.statusText
510
+ }
511
+ });
512
+ }
513
+ const [jsonError, data] = await safePromise(res.json());
514
+ if (jsonError) {
515
+ return error({
516
+ name: "ParseBodyError",
517
+ message: "Failed to parse response body.",
518
+ data: {
519
+ signerPublicKey: args.signerPublicKey,
520
+ cycleId: args.cycleId,
521
+ jsonError
522
+ }
523
+ });
524
+ }
525
+ const validationResult = v8.safeParse(signerInCycleResponseSchema, data);
526
+ if (!validationResult.success) {
527
+ return error({
528
+ name: "ValidateDataError",
529
+ message: "Failed to validate response data.",
530
+ data: validationResult.issues
531
+ });
532
+ }
533
+ return success(validationResult.output);
534
+ }
535
+
536
+ // src/stacks-api/proof-of-transfer/signers-in-cycle.ts
537
+ var v9 = __toESM(require("valibot"), 1);
538
+ var signerSchema = v9.object({
539
+ signing_key: v9.string(),
540
+ signer_address: v9.string(),
541
+ weight: v9.number(),
542
+ stacked_amount: v9.string(),
543
+ weight_percent: v9.number(),
544
+ stacked_amount_percent: v9.number(),
545
+ pooled_stacker_count: v9.number(),
546
+ solo_stacker_count: v9.number()
547
+ });
548
+ var resultsSchema2 = v9.array(signerSchema);
549
+ var signersResponseSchema = v9.object({
550
+ ...baseListResponseSchema.entries,
551
+ results: resultsSchema2
552
+ });
553
+ async function signersInCycle(args) {
554
+ const search = new URLSearchParams();
555
+ if (args.limit) search.append("limit", args.limit.toString());
556
+ if (args.offset) search.append("offset", args.offset.toString());
557
+ const init = {};
558
+ if (args.apiKeyConfig) {
559
+ init.headers = {
560
+ [args.apiKeyConfig.header]: args.apiKeyConfig.key
561
+ };
562
+ }
563
+ const endpoint = `${args.baseUrl}/extended/v2/pox/cycles/${args.cycleNumber}/signers`;
564
+ const res = await fetch(endpoint, init);
565
+ if (!res.ok) {
566
+ return error({
567
+ name: "FetchSignersError",
568
+ message: "Failed to fetch signers.",
569
+ data: {
570
+ endpoint,
571
+ status: res.status,
572
+ statusText: res.statusText,
573
+ bodyParseResult: await safePromise(res.json())
574
+ }
575
+ });
576
+ }
577
+ const [jsonError, data] = await safePromise(res.json());
578
+ if (jsonError) {
579
+ return error({
580
+ name: "ParseBodyError",
581
+ message: "Failed to parse response body as JSON.",
582
+ data: {
583
+ endpoint,
584
+ bodyParseResult: data
585
+ }
586
+ });
587
+ }
588
+ const validationResult = v9.safeParse(signersResponseSchema, data);
589
+ if (!validationResult.success) {
590
+ return error({
591
+ name: "ValidateDataError",
592
+ message: "Failed to validate response data.",
593
+ data: validationResult
594
+ });
595
+ }
596
+ return success(validationResult.output);
597
+ }
598
+
599
+ // src/stacks-api/proof-of-transfer/stackers-for-signer-in-cycle.ts
600
+ var v10 = __toESM(require("valibot"), 1);
601
+ var stackerInfoSchema = v10.object({
602
+ stacker_address: v10.string(),
603
+ stacked_amount: v10.string(),
604
+ pox_address: v10.string(),
605
+ stacker_type: v10.union([v10.literal("pooled"), v10.literal("solo")])
606
+ });
607
+ var resultsSchema3 = v10.array(stackerInfoSchema);
608
+ var stackersForSignerInCycleResponseSchema = v10.object({
609
+ ...baseListResponseSchema.entries,
610
+ results: resultsSchema3
611
+ });
612
+ async function stackersForSignerInCycle(opts) {
613
+ const search = new URLSearchParams();
614
+ if (opts.limit) search.append("limit", opts.limit.toString());
615
+ if (opts.offset) search.append("offset", opts.offset.toString());
616
+ const init = {};
617
+ if (opts.apiKeyConfig) {
618
+ init.headers = {
619
+ [opts.apiKeyConfig.header]: opts.apiKeyConfig.key
620
+ };
621
+ }
622
+ const endpoint = `${opts.baseUrl}/extended/v2/pox/cycles/${opts.cycleNumber}/signers/${opts.signerPublicKey}/stackers?${search}`;
623
+ const res = await fetch(endpoint, init);
624
+ if (!res.ok) {
625
+ return error({
626
+ name: "FetchStackersForSignerInCycleError",
627
+ message: "Failed to fetch stackers for signer in cycle.",
628
+ data: {
629
+ endpoint,
630
+ status: res.status,
631
+ statusText: res.statusText,
632
+ bodyParseResult: await safePromise(res.json())
633
+ }
634
+ });
635
+ }
636
+ const [jsonError, data] = await safePromise(res.json());
637
+ if (jsonError) {
638
+ return error({
639
+ name: "ParseBodyError",
640
+ message: "Failed to parse response body as JSON.",
641
+ data: jsonError
642
+ });
643
+ }
644
+ const validationResult = v10.safeParse(
645
+ stackersForSignerInCycleResponseSchema,
646
+ data
647
+ );
648
+ if (!validationResult.success) {
649
+ return error({
650
+ name: "ValidateDataError",
651
+ message: "Failed to validate response data.",
652
+ data: validationResult
653
+ });
654
+ }
655
+ return success(validationResult.output);
656
+ }
657
+
658
+ // src/stacks-api/proof-of-transfer/index.ts
659
+ var proofOfTransfer = {
660
+ cycle,
661
+ cycles,
662
+ signerInCycle,
663
+ signersInCycle,
664
+ stackersForSignerInCycle
665
+ };
666
+
667
+ // src/stacks-api/smart-contracts/read-only.ts
668
+ var v11 = __toESM(require("valibot"), 1);
669
+ var readOnlyResponseSchema = v11.variant("okay", [
670
+ v11.object({
671
+ okay: v11.literal(true),
672
+ result: v11.string()
673
+ }),
674
+ v11.object({
675
+ okay: v11.literal(false),
676
+ cause: v11.unknown()
677
+ })
678
+ ]);
679
+ async function readOnly(opts, apiOpts) {
680
+ const init = {};
681
+ if (apiOpts.apiKeyConfig) {
682
+ init.headers = {
683
+ [apiOpts.apiKeyConfig.header]: apiOpts.apiKeyConfig.key
684
+ };
685
+ }
686
+ const res = await fetch(
687
+ `${apiOpts.baseUrl}/v2/contracts/call-read/${opts.contractAddress}/${opts.contractName}/${opts.functionName}`,
688
+ init
689
+ );
690
+ if (!res.ok) {
691
+ return error({
692
+ name: "FetchReadOnlyError",
693
+ message: "Failed to fetch.",
694
+ data: {
695
+ status: res.status,
696
+ statusText: res.statusText,
697
+ bodyParseResult: await safePromise(res.json())
698
+ }
699
+ });
700
+ }
701
+ const [jsonError, data] = await safePromise(res.json());
702
+ if (jsonError) {
703
+ return error({
704
+ name: "ParseBodyError",
705
+ message: "Failed to parse response body as JSON.",
706
+ data: error
707
+ });
708
+ }
709
+ const validationResult = v11.safeParse(readOnlyResponseSchema, data);
710
+ if (!validationResult.success) {
711
+ return error({
712
+ name: "ValidateDataError",
713
+ message: "Failed to validate data.",
714
+ data: validationResult
715
+ });
716
+ }
717
+ return success(validationResult.output);
718
+ }
719
+
720
+ // src/stacks-api/smart-contracts/index.ts
721
+ var smartContracts = {
722
+ readOnly
723
+ };
724
+
725
+ // src/stacks-api/stacking-pool/members.ts
726
+ var v12 = __toESM(require("valibot"), 1);
727
+ var memberSchema = v12.object({
728
+ stacker: v12.string(),
729
+ pox_addr: v12.optional(v12.string()),
730
+ amount_ustx: v12.string(),
731
+ burn_block_unlock_height: v12.optional(v12.number()),
732
+ block_height: v12.number(),
733
+ tx_id: v12.string()
734
+ });
735
+ var membersResponseSchema = v12.object({
736
+ limit: v12.number(),
737
+ offset: v12.number(),
738
+ total: v12.number(),
739
+ results: v12.array(memberSchema)
740
+ });
741
+ async function members(opts, apiOpts) {
742
+ const search = new URLSearchParams();
743
+ if (opts.afterBlock) search.append("after_block", opts.afterBlock.toString());
744
+ if (opts.unanchored) search.append("unanchored", "true");
745
+ if (opts.limit) search.append("limit", opts.limit.toString());
746
+ if (opts.offset) search.append("offset", opts.offset.toString());
747
+ const init = {};
748
+ if (apiOpts.apiKeyConfig) {
749
+ init.headers = {
750
+ [apiOpts.apiKeyConfig.header]: apiOpts.apiKeyConfig.key
751
+ };
752
+ }
753
+ const res = await fetch(
754
+ `${apiOpts.baseUrl}/extended/beta/stacking/${opts.poolPrincipal}/delegations?${search}`,
755
+ init
756
+ );
757
+ if (!res.ok) {
758
+ return error({
759
+ name: "FetchMembersError",
760
+ message: "Failed to fetch members.",
761
+ data: {
762
+ status: res.status,
763
+ statusText: res.statusText,
764
+ bodyParseResult: await safePromise(res.json())
765
+ }
766
+ });
767
+ }
768
+ const [jsonParseError, data] = await safePromise(res.json());
769
+ if (jsonParseError) {
770
+ return error({
771
+ name: "ParseBodyError",
772
+ message: "Failed to parse response body as JSON.",
773
+ data: jsonParseError
774
+ });
775
+ }
776
+ const validationResult = v12.safeParse(membersResponseSchema, data);
777
+ if (!validationResult.success) {
778
+ return error({
779
+ name: "ValidateDataError",
780
+ message: "Failed to validate data.",
781
+ data: validationResult
782
+ });
783
+ }
784
+ return success(validationResult.output);
785
+ }
786
+
787
+ // src/stacks-api/stacking-pool/index.ts
788
+ var stackingPool = {
789
+ members
790
+ };
791
+
792
+ // src/stacks-api/transactions/schemas.ts
793
+ var v13 = __toESM(require("valibot"), 1);
794
+ var baseTransactionSchema = v13.object({
795
+ tx_id: v13.string(),
796
+ nonce: v13.number(),
797
+ fee_rate: v13.string(),
798
+ sender_address: v13.string(),
799
+ sponsored: v13.boolean(),
800
+ post_condition_mode: v13.string(),
801
+ post_conditions: v13.array(v13.unknown()),
802
+ anchor_mode: v13.string(),
803
+ is_unanchored: v13.boolean(),
804
+ block_hash: v13.string(),
805
+ parent_block_hash: v13.string(),
806
+ block_height: v13.number(),
807
+ block_time: v13.number(),
808
+ block_time_iso: v13.string(),
809
+ burn_block_height: v13.number(),
810
+ burn_block_time: v13.number(),
811
+ burn_block_time_iso: v13.string(),
812
+ parent_burn_block_time: v13.number(),
813
+ parent_burn_block_time_iso: v13.string(),
814
+ canonical: v13.boolean(),
815
+ tx_index: v13.number(),
816
+ tx_status: v13.string(),
817
+ tx_result: v13.object({
818
+ hex: v13.string(),
819
+ repr: v13.string()
820
+ }),
821
+ microblock_hash: v13.string(),
822
+ microblock_sequence: v13.number(),
823
+ microblock_canonical: v13.boolean(),
824
+ event_count: v13.number(),
825
+ events: v13.array(v13.unknown()),
826
+ execution_cost_read_count: v13.number(),
827
+ execution_cost_read_length: v13.number(),
828
+ execution_cost_runtime: v13.number(),
829
+ execution_cost_write_count: v13.number(),
830
+ execution_cost_write_length: v13.number()
831
+ });
832
+ var contractCallTransactionSchema = v13.object({
833
+ tx_type: v13.literal("contract_call"),
834
+ contract_call: v13.object({
835
+ contract_id: v13.string(),
836
+ function_name: v13.string(),
837
+ function_signature: v13.string(),
838
+ function_args: v13.array(
839
+ v13.object({
840
+ hex: v13.string(),
841
+ repr: v13.string(),
842
+ name: v13.string(),
843
+ type: v13.string()
844
+ })
845
+ )
846
+ }),
847
+ ...baseTransactionSchema.entries
848
+ });
849
+ var smartContractTransactionSchema = v13.object({
850
+ tx_type: v13.literal("smart_contract"),
851
+ smart_contract: v13.object({
852
+ /**
853
+ * NOTE: The types may be wrong, not sure what type of value is used when
854
+ * the version is not `null`.
855
+ */
856
+ clarity_version: v13.union([v13.null(), v13.number()]),
857
+ contract_id: v13.string(),
858
+ source_code: v13.string()
859
+ }),
860
+ ...baseTransactionSchema.entries
861
+ });
862
+ var tokenTransferSchema = v13.object({
863
+ tx_type: v13.literal("token_transfer"),
864
+ token_transfer: v13.object({
865
+ recipient_address: v13.string(),
866
+ amount: v13.string(),
867
+ memo: v13.string()
868
+ }),
869
+ ...baseTransactionSchema.entries
870
+ });
871
+ var transactionSchema = v13.variant("tx_type", [
872
+ contractCallTransactionSchema,
873
+ smartContractTransactionSchema,
874
+ tokenTransferSchema
875
+ ]);
876
+
877
+ // src/stacks-api/transactions/address-transactions.ts
878
+ var v14 = __toESM(require("valibot"), 1);
879
+ var resultSchema = v14.object({
880
+ tx: transactionSchema,
881
+ stx_sent: v14.string(),
882
+ stx_received: v14.string(),
883
+ events: v14.object({
884
+ stx: v14.object({
885
+ transfer: v14.number(),
886
+ mint: v14.number(),
887
+ burn: v14.number()
888
+ }),
889
+ ft: v14.object({
890
+ transfer: v14.number(),
891
+ mint: v14.number(),
892
+ burn: v14.number()
893
+ }),
894
+ nft: v14.object({
895
+ transfer: v14.number(),
896
+ mint: v14.number(),
897
+ burn: v14.number()
898
+ })
899
+ })
900
+ });
901
+ var resultsSchema4 = v14.array(resultSchema);
902
+ var addressTransactionsResponseSchema = v14.object({
903
+ ...baseListResponseSchema.entries,
904
+ results: resultsSchema4
905
+ });
906
+ async function addressTransactions(args) {
907
+ const search = new URLSearchParams();
908
+ if (args.limit) search.append("limit", args.limit.toString());
909
+ if (args.offset) search.append("offset", args.offset.toString());
910
+ const init = {};
911
+ if (args.apiKeyConfig) {
912
+ init.headers = {
913
+ [args.apiKeyConfig.header]: args.apiKeyConfig.key
914
+ };
915
+ }
916
+ const res = await fetch(
917
+ `${args.baseUrl}/extended/v2/addresses/${args.address}/transactions?${search}`,
918
+ init
919
+ );
920
+ if (!res.ok) {
921
+ return error({
922
+ name: "FetchAddressTransactionsError",
923
+ message: "Failed to fetch address transactions.",
924
+ data: {
925
+ status: res.status,
926
+ statusText: res.statusText,
927
+ bodyParseResult: await safePromise(res.json())
928
+ }
929
+ });
930
+ }
931
+ const [jsonParseError, data] = await safePromise(res.json());
932
+ if (jsonParseError) {
933
+ return error({
934
+ name: "ParseBodyError",
935
+ message: "Failed to parse response body as JSON.",
936
+ data: jsonParseError
937
+ });
938
+ }
939
+ const validationResult = v14.safeParse(addressTransactionsResponseSchema, data);
940
+ if (!validationResult.success) {
941
+ return error({
942
+ name: "ValidateDataError",
943
+ message: "Failed to validate data.",
944
+ data: validationResult
945
+ });
946
+ }
947
+ return success(validationResult.output);
948
+ }
949
+
950
+ // src/stacks-api/transactions/get-transaction.ts
951
+ var v15 = __toESM(require("valibot"), 1);
952
+ async function getTransaction(args) {
953
+ const init = {};
954
+ if (args.apiKeyConfig) {
955
+ init.headers = {
956
+ [args.apiKeyConfig.header]: args.apiKeyConfig.key
957
+ };
958
+ }
959
+ const endpoint = `${args.baseUrl}/extended/v1/tx/${args.transactionId}`;
960
+ const res = await fetch(endpoint, init);
961
+ if (!res.ok) {
962
+ return error({
963
+ name: "FetchTransactionError",
964
+ message: `Failed to fetch transaction ${args.transactionId}`,
965
+ response: {
966
+ status: res.status,
967
+ statusText: res.statusText,
968
+ body: await safePromise(res.json())
969
+ }
970
+ });
971
+ }
972
+ const [jsonParseError, data] = await safePromise(res.json());
973
+ if (jsonParseError) {
974
+ return error({
975
+ name: "ParseBodyError",
976
+ message: "Failed to parse response body as JSON.",
977
+ error: jsonParseError
978
+ });
979
+ }
980
+ const validationResult = v15.safeParse(transactionSchema, data);
981
+ if (!validationResult.success) {
982
+ return error({
983
+ name: "ValidateDataError",
984
+ message: "Failed to validate data.",
985
+ error: validationResult
986
+ });
987
+ }
988
+ return success(validationResult.output);
989
+ }
990
+
991
+ // src/stacks-api/transactions/index.ts
992
+ var transactions = {
993
+ addressTransactions,
994
+ getTransaction
995
+ };
996
+
997
+ // src/stacks-api/index.ts
998
+ var stacksApi = {
999
+ accounts,
1000
+ blocks,
1001
+ info,
1002
+ proofOfTransfer,
1003
+ smartContracts,
1004
+ stackingPool,
1005
+ transactions
1006
+ };
1007
+
1008
+ // src/utils/call-rate-limited-api.ts
1009
+ var import_exponential_backoff = require("exponential-backoff");
1010
+ async function safeCallRateLimitedApi(fn, options) {
1011
+ try {
1012
+ return await (0, import_exponential_backoff.backOff)(() => fn(), {
1013
+ startingDelay: options?.startingDelay ?? 15e3,
1014
+ numOfAttempts: options?.numOfAttempts ?? 5
1015
+ });
1016
+ } catch (error2) {
1017
+ return error({
1018
+ name: "MaxRetriesExceeded",
1019
+ message: "Failed to call rate limited API.",
1020
+ data: {
1021
+ error: error2
1022
+ }
1023
+ });
1024
+ }
1025
+ }
1026
+
1027
+ // src/queries/get-signer-stacked-amount.ts
1028
+ async function getSignerStackedAmount(args) {
1029
+ let totalLocked = 0n;
1030
+ const { identifier, ...rest } = args;
1031
+ let hasMore = true;
1032
+ let offset = 0;
1033
+ let found = false;
1034
+ const limit = 200;
1035
+ while (hasMore && !found) {
1036
+ const [error2, data] = await safeCallRateLimitedApi(
1037
+ () => signersInCycle({
1038
+ ...rest,
1039
+ limit
1040
+ })
1041
+ );
1042
+ if (error2) {
1043
+ return error({
1044
+ name: "GetSignerTotalLockedError",
1045
+ message: "Failed to get signer total locked.",
1046
+ data: {
1047
+ error: error2
1048
+ }
1049
+ });
1050
+ }
1051
+ for (const signer of data.results) {
1052
+ if (identifier.type === "address") {
1053
+ if (signer.signer_address === identifier.signerAddress) {
1054
+ totalLocked = BigInt(signer.stacked_amount);
1055
+ found = true;
1056
+ break;
1057
+ }
1058
+ } else {
1059
+ if (signer.signing_key === identifier.signerPublicKey) {
1060
+ totalLocked = BigInt(signer.stacked_amount);
1061
+ found = true;
1062
+ break;
1063
+ }
1064
+ }
1065
+ }
1066
+ offset += limit + data.results.length;
1067
+ hasMore = offset < data.total;
1068
+ }
1069
+ if (!found) {
1070
+ return error({
1071
+ name: "SignerNotFound",
1072
+ message: "Signer not found.",
1073
+ data: {
1074
+ identifier,
1075
+ cycle: args.cycleNumber
1076
+ }
1077
+ });
1078
+ }
1079
+ return success(totalLocked);
1080
+ }
1081
+
1082
+ // src/queries/index.ts
1083
+ var queries = {
1084
+ getSignerStackedAmount
1085
+ };
1086
+ // Annotate the CommonJS export names for ESM import in node:
1087
+ 0 && (module.exports = {
1088
+ queries,
1089
+ stacksApi
1090
+ });