@gardenfi/orderbook 2.1.8-beta.1 → 2.1.8

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/index5.js CHANGED
@@ -1,190 +1,350 @@
1
- var p = (e, t, a) => {
2
- if (!t.has(e))
3
- throw TypeError("Cannot " + a);
4
- }, h = (e, t, a) => (p(e, t, "read from private field"), a ? a.call(e) : t.get(e)), u = (e, t, a) => {
5
- if (t.has(e))
6
- throw TypeError("Cannot add the same private member more than once");
7
- t instanceof WeakSet ? t.add(e) : t.set(e, a);
8
- }, w = (e, t, a, r) => (p(e, t, "write to private field"), t.set(e, a), a);
9
- const d = (e) => new Promise((t) => setTimeout(t, e));
10
- class g {
11
- /**
12
- * @param {number} maxRetries - The maximum number of retries, if less < 0 then it is set to 0
13
- * @param {number} delay - The delay between retries
14
- */
15
- constructor(t, a) {
16
- this.maxRetries = Math.max(t, 0), this.delay = a;
1
+ import { Chains as e } from "./index3.js";
2
+ const c = {
3
+ id: 1001,
4
+ name: "Starknet Localnet",
5
+ nativeCurrency: {
6
+ name: "Stark Token",
7
+ symbol: "STRK",
8
+ decimals: 18
9
+ },
10
+ rpcUrls: {
11
+ default: {
12
+ http: ["http://127.0.0.1:8547/"]
13
+ }
14
+ },
15
+ testnet: !0
16
+ }, d = {
17
+ id: 31338,
18
+ name: "Arbitrum Localnet",
19
+ nativeCurrency: {
20
+ name: "Ethereum",
21
+ symbol: "ETH",
22
+ decimals: 18
23
+ },
24
+ rpcUrls: {
25
+ default: {
26
+ http: ["http://localhost:8546/"]
27
+ }
28
+ },
29
+ testnet: !0
30
+ }, o = {
31
+ id: 31337,
32
+ name: "Ethereum Localnet",
33
+ nativeCurrency: {
34
+ name: "Ethereum",
35
+ symbol: "ETH",
36
+ decimals: 18
37
+ },
38
+ rpcUrls: {
39
+ default: {
40
+ http: ["http://localhost:8545/"]
41
+ }
42
+ },
43
+ testnet: !0
44
+ }, m = {
45
+ name: "Bitcoin Regtest",
46
+ decimals: 8,
47
+ symbol: "BTC",
48
+ chain: e.bitcoin_regtest,
49
+ atomicSwapAddress: "primary",
50
+ tokenAddress: "primary"
51
+ }, a = {
52
+ name: "WBTC Arbitrum Localnet",
53
+ decimals: 8,
54
+ symbol: "WBTC",
55
+ chain: e.arbitrum_localnet,
56
+ atomicSwapAddress: "0xDc64a140Aa3E981100a9becA4E685f962f0cF6C9",
57
+ tokenAddress: "0xe7f1725E7734CE288F8367e1Bb143E90bb3F0512"
58
+ }, t = {
59
+ name: "WBTC Ethereum Localnet",
60
+ decimals: 8,
61
+ symbol: "WBTC",
62
+ chain: e.ethereum_localnet,
63
+ atomicSwapAddress: "0xe7f1725E7734CE288F8367e1Bb143E90bb3F0512",
64
+ tokenAddress: "0x5FbDB2315678afecb367f032d93F642f64180aa3"
65
+ }, s = {
66
+ name: "STRK Starknet Localnet",
67
+ decimals: 18,
68
+ symbol: "STRK",
69
+ chain: e.starknet_devnet,
70
+ atomicSwapAddress: "0x15cf8b127aa850c97ed10de6f8b300cabc4f09232a57e63667af02fdef8a55a",
71
+ tokenAddress: "0x51aa025f1c9948790113e4ebea826dee24542bc50902076c05892774210e8d2"
72
+ }, n = {
73
+ name: "ETH Starknet Localnet",
74
+ decimals: 18,
75
+ symbol: "ETH",
76
+ chain: e.starknet_devnet,
77
+ atomicSwapAddress: "0x1890470168440bbb9df50988748924a74ea22de10d22a081e458737b9574e75",
78
+ tokenAddress: "0x51aa025f1c9948790113e4ebea826dee24542bc50902076c05892774210e8d2"
79
+ }, r = {
80
+ localnet: {
81
+ arbitrum_localnet_WBTC: a,
82
+ ethereum_localnet_WBTC: t,
83
+ starknet_localnet_STRK: s,
84
+ starknet_localnet_ETH: n
85
+ },
86
+ testnet: {
87
+ bitcoin_testnet_BTC: {
88
+ name: "BTC",
89
+ decimals: 8,
90
+ symbol: "BTC",
91
+ chain: e.bitcoin_testnet,
92
+ tokenAddress: "primary",
93
+ atomicSwapAddress: "primary"
94
+ },
95
+ ethereum_sepolia_WBTC: {
96
+ name: "Wrapped Bitcoin",
97
+ decimals: 8,
98
+ symbol: "WBTC",
99
+ chain: e.ethereum_sepolia,
100
+ logo: "https://garden-finance.imgix.net/token-images/wbtc.svg",
101
+ tokenAddress: "0x4D68da063577F98C55166c7AF6955cF58a97b20A",
102
+ atomicSwapAddress: "0x3C6a17b8cD92976D1D91E491c93c98cd81998265"
103
+ },
104
+ arbitrum_sepolia_WBTC: {
105
+ name: "Wrapped Bitcoin",
106
+ decimals: 8,
107
+ symbol: "WBTC",
108
+ logo: "https://garden-finance.imgix.net/token-images/wbtc.svg",
109
+ chain: e.arbitrum_sepolia,
110
+ tokenAddress: "0x00ab86f54F436CfE15253845F139955ae0C00bAf",
111
+ atomicSwapAddress: "0x1cd0bBd55fD66B4C5F7dfE434eFD009C09e628d1"
112
+ },
113
+ arbitrum_sepolia_SEED: {
114
+ name: "Seed",
115
+ decimals: 18,
116
+ symbol: "SEED",
117
+ chain: e.arbitrum_sepolia,
118
+ logo: "https://garden-finance.imgix.net/token-images/seed.svg",
119
+ tokenAddress: "0x13DCec0762EcC5E666c207ab44Dc768e5e33070F",
120
+ atomicSwapAddress: "0xD5FeDb4ceCB0F1D32788a190d9EB47D94D23eE4e"
121
+ },
122
+ arbitrum_sepolia_iBTC: {
123
+ name: "iBTC",
124
+ decimals: 8,
125
+ symbol: "iBTC",
126
+ chain: e.arbitrum_sepolia,
127
+ logo: "https://garden-finance.imgix.net/token-images/dlcBTCIcon.svg",
128
+ tokenAddress: "0x8219B871534F29ff7434519287131a875e0D8eCa",
129
+ atomicSwapAddress: "0xdfe6d9363ee96152d39391009a6723819d9e25eb"
130
+ },
131
+ base_sepolia_WBTC: {
132
+ name: "Wrapped Bitcoin",
133
+ decimals: 8,
134
+ symbol: "WBTC",
135
+ chain: e.base_sepolia,
136
+ logo: "https://garden-finance.imgix.net/token-images/wbtc.svg",
137
+ tokenAddress: "0x13DCec0762EcC5E666c207ab44Dc768e5e33070F",
138
+ atomicSwapAddress: "0x00ab86f54F436CfE15253845F139955ae0C00bAf"
139
+ },
140
+ base_sepolia_USDT: {
141
+ name: "Tether USD",
142
+ decimals: 6,
143
+ symbol: "USDT",
144
+ chain: e.base_sepolia,
145
+ logo: "https://garden-finance.imgix.net/token-images/usdt.svg",
146
+ tokenAddress: "0xD72Fc3e7D52301b3e5f7d4E3366F88d5C8747520",
147
+ atomicSwapAddress: "0xB391CA6D0A76CD2A927bC314856E8a374a225CFc"
148
+ },
149
+ base_sepolia_iBTC: {
150
+ name: "iBTC",
151
+ decimals: 8,
152
+ symbol: "iBTC",
153
+ chain: e.base_sepolia,
154
+ logo: "https://garden-finance.imgix.net/token-images/dlcBTCIcon.svg",
155
+ tokenAddress: "0xbaFb499B60F9E30fd82A54342cb7695C92F5B527",
156
+ atomicSwapAddress: "0xbcdad29ac77e5bb27fd528ab0045af630259fe4f"
157
+ },
158
+ citrea_testnet_WCBTC: {
159
+ name: "Wrapped Citrea Bitcoin",
160
+ decimals: 18,
161
+ symbol: "WCBTC",
162
+ chain: e.citrea_testnet,
163
+ logo: "https://garden-finance.imgix.net/token-images/wbtc.svg",
164
+ tokenAddress: "0x8d0c9d1c17aE5e40ffF9bE350f57840E9E66Cd93",
165
+ atomicSwapAddress: "0xaD9d14CA82d9BF97fFf745fFC7d48172A1c0969E"
166
+ },
167
+ citrea_testnet_cBTC: {
168
+ name: "Citrea Bitcoin",
169
+ decimals: 18,
170
+ symbol: "cBTC",
171
+ chain: e.citrea_testnet,
172
+ logo: "https://garden-finance.imgix.net/token-images/bitcoin.svg",
173
+ tokenAddress: "0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE",
174
+ atomicSwapAddress: "0x6218FA00f47a61aCD8B46D6f1b15c4D730F803F2"
175
+ },
176
+ starknet_testnet_WBTC: {
177
+ name: "Wrapped Bitcoin",
178
+ decimals: 8,
179
+ symbol: "WBTC",
180
+ chain: e.starknet_sepolia,
181
+ logo: "https://garden-finance.imgix.net/token-images/wbtc.svg",
182
+ tokenAddress: "0x496bef3ed20371382fbe0ca6a5a64252c5c848f9f1f0cccf8110fc4def912d5",
183
+ atomicSwapAddress: "0x06579d255314109429a4477d89629bc2b94f529ae01979c2f8014f9246482603"
184
+ },
185
+ monad_testnet_cbBTC: {
186
+ name: "Coinbase Bitcoin",
187
+ decimals: 8,
188
+ symbol: "cbBTC",
189
+ chain: e.monad_testnet,
190
+ logo: "https://garden-finance.imgix.net/token-images/cbBTC.svg",
191
+ tokenAddress: "0xaD9d14CA82d9BF97fFf745fFC7d48172A1c0969E",
192
+ atomicSwapAddress: "0x1dC94FdcAd8Aee13cfd34Db8a26d26E31572805c"
193
+ },
194
+ monad_testnet_USDC: {
195
+ name: "USD Coin",
196
+ decimals: 6,
197
+ symbol: "USDC",
198
+ chain: e.monad_testnet,
199
+ logo: "https://garden-finance.imgix.net/token-images/usdc.svg",
200
+ tokenAddress: "0x00ab86f54F436CfE15253845F139955ae0C00bAf",
201
+ atomicSwapAddress: "0xE99D8A21d4F2ad2f90c279c869311503f9e25867"
202
+ }
203
+ },
204
+ mainnet: {
205
+ bitcoin_BTC: {
206
+ name: "BTC",
207
+ decimals: 8,
208
+ symbol: "BTC",
209
+ chain: e.bitcoin,
210
+ tokenAddress: "primary",
211
+ atomicSwapAddress: "primary"
212
+ },
213
+ base_cbBTC: {
214
+ name: "Coinbase Bitcoin",
215
+ decimals: 8,
216
+ symbol: "cbBTC",
217
+ chain: e.base,
218
+ logo: "https://garden-finance.imgix.net/token-images/cbBTC.svg",
219
+ tokenAddress: "0xcbB7C0000aB88B473b1f5aFd9ef808440eed33Bf",
220
+ atomicSwapAddress: "0xeae7721d779276eb0f5837e2fe260118724a2ba4"
221
+ },
222
+ base_USDC: {
223
+ name: "USD Coin",
224
+ decimals: 6,
225
+ symbol: "USDC",
226
+ chain: e.base,
227
+ logo: "https://garden-finance.imgix.net/token-images/usdc.svg",
228
+ tokenAddress: "0x833589fCD6eDb6E08f4c7C32D4f71b54bdA02913",
229
+ atomicSwapAddress: "0xd8a6e3fca403d79b6ad6216b60527f51cc967d39"
230
+ },
231
+ ethereum_WBTC: {
232
+ name: "Wrapped Bitcoin",
233
+ decimals: 8,
234
+ symbol: "WBTC",
235
+ chain: e.ethereum,
236
+ logo: "https://garden-finance.imgix.net/token-images/wbtc.svg",
237
+ tokenAddress: "0x2260FAC5E5542a773Aa44fBCfeDf7C193bc2C599",
238
+ atomicSwapAddress: "0x795dcb58d1cd4789169d5f938ea05e17eceb68ca"
239
+ },
240
+ ethereum_USDC: {
241
+ name: "USD Coin",
242
+ decimals: 6,
243
+ symbol: "USDC",
244
+ chain: e.ethereum,
245
+ logo: "https://garden-finance.imgix.net/token-images/usdc.svg",
246
+ tokenAddress: "0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48",
247
+ atomicSwapAddress: "0xd8a6e3fca403d79b6ad6216b60527f51cc967d39"
248
+ },
249
+ ethereum_cbBTC: {
250
+ name: "Coinbase Bitcoin",
251
+ decimals: 8,
252
+ symbol: "cbBTC",
253
+ chain: e.ethereum,
254
+ logo: "https://garden-finance.imgix.net/token-images/cbBTC.svg",
255
+ tokenAddress: "0xcbB7C0000aB88B473b1f5aFd9ef808440eed33Bf",
256
+ atomicSwapAddress: "0xeae7721d779276eb0f5837e2fe260118724a2ba4"
257
+ },
258
+ arbitrum_WBTC: {
259
+ name: "Wrapped Bitcoin",
260
+ decimals: 8,
261
+ symbol: "WBTC",
262
+ chain: e.arbitrum,
263
+ logo: "https://garden-finance.imgix.net/token-images/wbtc.svg",
264
+ tokenAddress: "0x2f2a2543B76A4166549F7aaB2e75Bef0aefC5B0f",
265
+ atomicSwapAddress: "0x6b6303fab8ec7232b4f2a7b9fa58e5216f608fcb"
266
+ },
267
+ arbitrum_USDC: {
268
+ name: "USD Coin",
269
+ decimals: 6,
270
+ symbol: "USDC",
271
+ chain: e.arbitrum,
272
+ logo: "https://garden-finance.imgix.net/token-images/usdc.svg",
273
+ tokenAddress: "0xaf88d065e77c8cC2239327C5EDb3A432268e5831",
274
+ atomicSwapAddress: "0xeae7721d779276eb0f5837e2fe260118724a2ba4"
275
+ },
276
+ arbitrum_iBTC: {
277
+ name: "iBTC",
278
+ decimals: 8,
279
+ symbol: "iBTC",
280
+ chain: e.arbitrum,
281
+ logo: "https://garden-finance.imgix.net/token-images/iBTC.svg",
282
+ tokenAddress: "0x050C24dBf1eEc17babE5fc585F06116A259CC77A",
283
+ atomicSwapAddress: "0xdc74a45e86dedf1ff7c6dac77e0c2f082f9e4f72"
284
+ },
285
+ bera_LBTC: {
286
+ name: "Lombard Bitcoin",
287
+ decimals: 8,
288
+ symbol: "LBTC",
289
+ chain: e.bera,
290
+ logo: "https://garden-finance.imgix.net/token-images/LBTC.svg",
291
+ tokenAddress: "0xecAc9C5F704e954931349Da37F60E39f515c11c1",
292
+ atomicSwapAddress: "0x39f3294352208905fc6ebf033954E6c6455CdB4C"
293
+ },
294
+ hyperliquid_uBTC: {
295
+ name: "Unit Bitcoin",
296
+ decimals: 8,
297
+ symbol: "uBTC",
298
+ chain: e.hyperliquid,
299
+ tokenAddress: "0x9FDBdA0A5e284c32744D2f17Ee5c74B284993463",
300
+ atomicSwapAddress: "0x39f3294352208905fc6ebf033954E6c6455CdB4C"
301
+ },
302
+ starknet_WBTC: {
303
+ name: "Wrapped Bitcoin",
304
+ decimals: 8,
305
+ symbol: "WBTC",
306
+ chain: e.starknet,
307
+ logo: "https://garden-finance.imgix.net/token-images/wbtc.svg",
308
+ tokenAddress: "0x3fe2b97c1fd336e750087d68b9b867997fd64a2661ff3ca5a7c771641e8e7ac",
309
+ atomicSwapAddress: "0x7defd8eb3b770005ab1ca5f89ad31f98fb5bc3c52deaeafd130be3b49f967b4"
310
+ },
311
+ unichain_USDC: {
312
+ name: "USD Coin",
313
+ decimals: 6,
314
+ symbol: "USDC",
315
+ chain: e.unichain,
316
+ logo: "https://garden-finance.imgix.net/token-images/usdc.svg",
317
+ tokenAddress: "0x078D782b760474a361dDA0AF3839290b0EF57AD6",
318
+ atomicSwapAddress: "0x795Dcb58d1cd4789169D5F938Ea05E17ecEB68cA"
319
+ },
320
+ corn_BTCN: {
321
+ name: "Bitcorn",
322
+ decimals: 18,
323
+ symbol: "BTCN",
324
+ chain: e.corn,
325
+ logo: "https://garden-finance.imgix.net/token-images/bitcorn.jpg",
326
+ tokenAddress: "0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE",
327
+ atomicSwapAddress: "0xeaE7721d779276eb0f5837e2fE260118724a2Ba4"
328
+ },
329
+ botanix_BOTX: {
330
+ name: "Botanix",
331
+ decimals: 18,
332
+ symbol: "BTC",
333
+ chain: e.botanix,
334
+ logo: "https://garden-finance.imgix.net/chain_images/BotanixLogo.svg",
335
+ tokenAddress: "0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE",
336
+ atomicSwapAddress: "0x39f3294352208905fc6ebf033954E6c6455CdB4C"
337
+ }
17
338
  }
18
- /**
19
- * Retries a function until it succeeds or the max number of retries is reached
20
- *
21
- * @param {() => Promise<T>} fn - The function to retry
22
- * @return {Promise<T>} a Promise that resolves to the result of the function
23
- */
24
- async retry(t) {
25
- let a = 0, r;
26
- for (; a < this.maxRetries + 1; )
27
- try {
28
- return await t();
29
- } catch (i) {
30
- a++, r = i, await d(this.delay * a);
31
- }
32
- throw r;
33
- }
34
- }
35
- const v = (e) => {
36
- try {
37
- return JSON.parse(e);
38
- } catch {
39
- return e;
40
- }
41
- };
42
- class m {
43
- static async _postWithFallback(t, a) {
44
- let r = "";
45
- for (const i of t)
46
- try {
47
- const s = await fetch(i, {
48
- method: "POST",
49
- ...a
50
- });
51
- if (s.status >= 500) {
52
- r = await (s.text() || s.json());
53
- continue;
54
- }
55
- return await this.parse(s);
56
- } catch (s) {
57
- r = y(s);
58
- continue;
59
- }
60
- throw new Error(r || "All APIs failed");
61
- }
62
- /**
63
- * Asynchronously sends a POST request to multiple URLs with fallback logic.
64
- *
65
- * @param {string[]} input - array of URLs to send the POST request to
66
- * @param {RequestInit} [init] - optional request initialization options
67
- * @return {Promise<T>} a Promise that resolves to the parsed response data
68
- */
69
- static async postWithFallback(t, a) {
70
- return await n(a).retry(
71
- () => this._postWithFallback(t, a)
72
- );
73
- }
74
- static async _getWithFallback(t, a) {
75
- let r = "";
76
- for (const i of t)
77
- try {
78
- const s = await fetch(i, a);
79
- if (s.status >= 500) {
80
- r = await (s.text() || s.json());
81
- continue;
82
- }
83
- return await this.parse(s);
84
- } catch (s) {
85
- r = y(s);
86
- continue;
87
- }
88
- throw new Error(r || "All APIs failed");
89
- }
90
- /**
91
- * Asynchronously sends a POST request to multiple URLs with fallback mechanism.
92
- *
93
- * @param {string[]} input - An array of URLs to retrieve data from.
94
- * @param {RequestInit} [init] - Optional request options.
95
- * @return {Promise<T>} A promise that resolves to the retrieved data.
96
- */
97
- static async getWithFallback(t, a) {
98
- return await n(a).retry(
99
- () => this._getWithFallback(t, a)
100
- );
101
- }
102
- static async _get(t, a) {
103
- return await this.parse(await fetch(t, a));
104
- }
105
- /**
106
- * Asynchronously retrieves data of type T from the specified URL or RequestInfo, with optional initialization options.
107
- *
108
- * @param {RequestInfo | URL} input - The URL or RequestInfo to fetch data from
109
- * @param {RequestInit} init - Optional initialization options for the fetch request
110
- * @return {Promise<T>} The retrieved data of type T
111
- */
112
- static async get(t, a) {
113
- return await n(a).retry(() => this._get(t, a));
114
- }
115
- static async _post(t, a) {
116
- return await this.parse(
117
- await fetch(t, {
118
- method: "POST",
119
- ...a
120
- })
121
- );
122
- }
123
- /**
124
- * Asynchronously sends a POST request to the specified URL or RequestInfo, with optional initialization options.
125
- */
126
- static async post(t, a) {
127
- return await n(a).retry(() => this._post(t, a));
128
- }
129
- /**
130
- * Parses the response and returns the result as the specified type.
131
- *
132
- * @param {Response} res - the response object to be parsed
133
- * @return {Promise<T>} the parsed result of type T
134
- */
135
- static async parse(t) {
136
- const a = await t.text();
137
- if (t.status >= 200 && t.status < 300)
138
- return v(a);
139
- throw new Error(a);
140
- }
141
- }
142
- function y(e) {
143
- return (e == null ? void 0 : e.message) || (e == null ? void 0 : e.toString()) || "unknown error";
144
- }
145
- const n = (e) => new g((e == null ? void 0 : e.retryCount) ?? 2, (e == null ? void 0 : e.retryDelay) ?? 1e3);
146
- var o, c, l;
147
- class f {
148
- constructor(t, a, r = void 0) {
149
- u(this, o, void 0), u(this, c, void 0), u(this, l, void 0), w(this, o, t), w(this, l, r), w(this, c, a);
150
- }
151
- get ok() {
152
- return h(this, o);
153
- }
154
- get error() {
155
- return h(this, l);
156
- }
157
- get val() {
158
- return h(this, c);
159
- }
160
- }
161
- o = /* @__PURE__ */ new WeakMap(), c = /* @__PURE__ */ new WeakMap(), l = /* @__PURE__ */ new WeakMap();
162
- const k = (e) => new f(!0, e), W = (e, ...t) => {
163
- if (typeof e == "string" && t && t.length > 0) {
164
- let a = [e, ...t].map((r) => {
165
- if (r) {
166
- if (r instanceof Error)
167
- return r.message;
168
- if (typeof r == "string")
169
- return r;
170
- if (r != null && r.toString)
171
- return r.toString();
172
- }
173
- });
174
- return new f(
175
- !1,
176
- null,
177
- a.filter((r) => r !== void 0).join(" ")
178
- );
179
- }
180
- return new f(!1, null, e);
181
339
  };
182
340
  export {
183
- W as Err,
184
- m as Fetcher,
185
- k as Ok,
186
- f as Result,
187
- g as Retry,
188
- v as safeParseJson,
189
- d as sleep
341
+ d as ArbitrumLocalnet,
342
+ n as ETHStarknetLocalnetAsset,
343
+ o as EthereumLocalnet,
344
+ s as STRKStarknetLocalnetAsset,
345
+ c as StarknetLocalnet,
346
+ r as SupportedAssets,
347
+ a as WBTCArbitrumLocalnetAsset,
348
+ t as WBTCEthereumLocalnetAsset,
349
+ m as bitcoinRegtestAsset
190
350
  };
package/dist/index6.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const i=(n,o,t)=>{const r=n.endpoint(o);return t&&Object.entries(t).forEach(([c,e])=>{e!==void 0&&r.searchParams.append(c,e.toString())}),r};exports.ConstructUrl=i;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});var p=(a,t,e)=>{if(!t.has(a))throw TypeError("Cannot "+e)},u=(a,t,e)=>(p(a,t,"read from private field"),e?e.call(a):t.get(a)),w=(a,t,e)=>{if(t.has(a))throw TypeError("Cannot add the same private member more than once");t instanceof WeakSet?t.add(a):t.set(a,e)},f=(a,t,e,r)=>(p(a,t,"write to private field"),t.set(a,e),e);const d=a=>new Promise(t=>setTimeout(t,a));class g{constructor(t,e){this.maxRetries=Math.max(t,0),this.delay=e}async retry(t){let e=0,r;for(;e<this.maxRetries+1;)try{return await t()}catch(i){e++,r=i,await d(this.delay*e)}throw r}}const v=a=>{try{return JSON.parse(a)}catch{return a}};class m{static async _postWithFallback(t,e){let r="";for(const i of t)try{const s=await fetch(i,{method:"POST",...e});if(s.status>=500){r=await(s.text()||s.json());continue}return await this.parse(s)}catch(s){r=y(s);continue}throw new Error(r||"All APIs failed")}static async postWithFallback(t,e){return await n(e).retry(()=>this._postWithFallback(t,e))}static async _getWithFallback(t,e){let r="";for(const i of t)try{const s=await fetch(i,e);if(s.status>=500){r=await(s.text()||s.json());continue}return await this.parse(s)}catch(s){r=y(s);continue}throw new Error(r||"All APIs failed")}static async getWithFallback(t,e){return await n(e).retry(()=>this._getWithFallback(t,e))}static async _get(t,e){return await this.parse(await fetch(t,e))}static async get(t,e){return await n(e).retry(()=>this._get(t,e))}static async _post(t,e){return await this.parse(await fetch(t,{method:"POST",...e}))}static async post(t,e){return await n(e).retry(()=>this._post(t,e))}static async parse(t){const e=await t.text();if(t.status>=200&&t.status<300)return v(e);throw new Error(e)}}function y(a){return(a==null?void 0:a.message)||(a==null?void 0:a.toString())||"unknown error"}const n=a=>new g((a==null?void 0:a.retryCount)??2,(a==null?void 0:a.retryDelay)??1e3);var o,c,l;class h{constructor(t,e,r=void 0){w(this,o,void 0),w(this,c,void 0),w(this,l,void 0),f(this,o,t),f(this,l,r),f(this,c,e)}get ok(){return u(this,o)}get error(){return u(this,l)}get val(){return u(this,c)}}o=new WeakMap,c=new WeakMap,l=new WeakMap;const k=a=>new h(!0,a),W=(a,...t)=>{if(typeof a=="string"&&t&&t.length>0){let e=[a,...t].map(r=>{if(r){if(r instanceof Error)return r.message;if(typeof r=="string")return r;if(r!=null&&r.toString)return r.toString()}});return new h(!1,null,e.filter(r=>r!==void 0).join(" "))}return new h(!1,null,a)};exports.Err=W;exports.Fetcher=m;exports.Ok=k;exports.Result=h;exports.Retry=g;exports.safeParseJson=v;exports.sleep=d;