@paxoslabs/amplify-sdk 0.0.1 → 0.1.0-alpha.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/CHANGELOG.md +22 -1
- package/README.md +5 -480
- package/dist/{amplify-sdk-api-DPrRhynk.d.mts → amplify-sdk-api-Biol0OIp.d.mts} +1 -1
- package/dist/{amplify-sdk-api-B5hBTGrB.d.ts → amplify-sdk-api-DGRgEybp.d.ts} +1 -1
- package/dist/{chunk-IBNTWZ4S.js → chunk-B2QCI6ET.js} +13 -35
- package/dist/chunk-B2QCI6ET.js.map +1 -0
- package/dist/{chunk-WFCHKDDG.mjs → chunk-CUGK4ZBJ.mjs} +13 -35
- package/dist/chunk-CUGK4ZBJ.mjs.map +1 -0
- package/dist/{chunk-BXUG3WDV.js → chunk-DTFLXAZJ.js} +27 -52
- package/dist/chunk-DTFLXAZJ.js.map +1 -0
- package/dist/{chunk-AIBI7ZQM.js → chunk-GS7TDQXA.js} +8 -8
- package/dist/{chunk-AIBI7ZQM.js.map → chunk-GS7TDQXA.js.map} +1 -1
- package/dist/{chunk-GBWBO6ZF.mjs → chunk-HI44AMLC.mjs} +8 -8
- package/dist/chunk-HI44AMLC.mjs.map +1 -0
- package/dist/{chunk-ZCVMGIMV.js → chunk-KYR6BFAE.js} +24 -24
- package/dist/chunk-KYR6BFAE.js.map +1 -0
- package/dist/{chunk-K4DL2AII.js → chunk-LSNRG5Z2.js} +4 -4
- package/dist/{chunk-K4DL2AII.js.map → chunk-LSNRG5Z2.js.map} +1 -1
- package/dist/{chunk-OPOYGPSS.mjs → chunk-REKEQLQA.mjs} +3 -3
- package/dist/{chunk-OPOYGPSS.mjs.map → chunk-REKEQLQA.mjs.map} +1 -1
- package/dist/{chunk-ZLS2AAMI.mjs → chunk-VIULRHK6.mjs} +3 -3
- package/dist/{chunk-ZLS2AAMI.mjs.map → chunk-VIULRHK6.mjs.map} +1 -1
- package/dist/{chunk-YP2TR5RP.mjs → chunk-ZILA73XN.mjs} +25 -50
- package/dist/chunk-ZILA73XN.mjs.map +1 -0
- package/dist/core.d.mts +6 -6
- package/dist/core.d.ts +6 -6
- package/dist/core.js +16 -16
- package/dist/core.js.map +1 -1
- package/dist/core.mjs +6 -6
- package/dist/core.mjs.map +1 -1
- package/dist/display.d.mts +3 -3
- package/dist/display.d.ts +3 -3
- package/dist/display.js +16 -16
- package/dist/display.js.map +1 -1
- package/dist/display.mjs +8 -8
- package/dist/display.mjs.map +1 -1
- package/dist/{exchange-rate-CRA_CMaX.d.mts → exchange-rate-BfPH_fQt.d.mts} +4 -4
- package/dist/{exchange-rate-D3_FVgqa.d.ts → exchange-rate-Cp1ddpw4.d.ts} +4 -4
- package/dist/index.d.mts +245 -15
- package/dist/index.d.ts +245 -15
- package/dist/index.js +341 -145
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +249 -53
- package/dist/index.mjs.map +1 -1
- package/dist/utils.d.mts +1 -1
- package/dist/utils.d.ts +1 -1
- package/dist/utils.js +5 -5
- package/dist/utils.mjs +2 -2
- package/package.json +7 -7
- package/dist/chunk-BXUG3WDV.js.map +0 -1
- package/dist/chunk-GBWBO6ZF.mjs.map +0 -1
- package/dist/chunk-IBNTWZ4S.js.map +0 -1
- package/dist/chunk-WFCHKDDG.mjs.map +0 -1
- package/dist/chunk-YP2TR5RP.mjs.map +0 -1
- package/dist/chunk-ZCVMGIMV.js.map +0 -1
package/dist/index.mjs
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
import { DEFAULT_SLIPPAGE_BPS } from './chunk-XXHRCCZS.mjs';
|
|
2
2
|
export { YieldType } from './chunk-XXHRCCZS.mjs';
|
|
3
|
-
export { getDepositExchangeRate, getWithdrawExchangeRate, isDepositSpendApproved, isWithdrawalSpendApproved } from './chunk-
|
|
4
|
-
import { getRateInQuoteWithAssetDecimals, TellerAbi, getClient, BoringVaultAbi, getRateInQuoteAndSharesAndWantAssetDecimals } from './chunk-
|
|
3
|
+
export { getDepositExchangeRate, getWithdrawExchangeRate, isDepositSpendApproved, isWithdrawalSpendApproved } from './chunk-HI44AMLC.mjs';
|
|
4
|
+
import { getRateInQuoteWithAssetDecimals, TellerAbi, getClient, BoringVaultAbi, getRateInQuoteAndSharesAndWantAssetDecimals } from './chunk-ZILA73XN.mjs';
|
|
5
5
|
import './chunk-R663BFAZ.mjs';
|
|
6
6
|
import { toChainId } from './chunk-J3662HYT.mjs';
|
|
7
|
-
import { calculateDeadline } from './chunk-
|
|
7
|
+
import { calculateDeadline } from './chunk-REKEQLQA.mjs';
|
|
8
8
|
import { WAD } from './chunk-7RWWVUHP.mjs';
|
|
9
|
-
import { findVaultByConfig, APIError, getAssetsFromCache, DEFAULT_APPROVAL_AMOUNT, fetchSupportedAssets, ATOMIC_QUEUE_CONTRACT_ADDRESS, DEFAULT_DEADLINE } from './chunk-
|
|
10
|
-
export { APIError, fetchSupportedAssets, fetchVaults, findVaultByConfig, getAssetsFromCache, getCache, getWithdrawSupportedAssets, initAmplifySDK, initializeCache, refreshVaultCache } from './chunk-
|
|
11
|
-
import { parseUnits, erc20Abi, hexToSignature } from 'viem';
|
|
9
|
+
import { findVaultByConfig, APIError, getAssetsFromCache, DEFAULT_APPROVAL_AMOUNT, fetchSupportedAssets, ATOMIC_QUEUE_CONTRACT_ADDRESS, DEFAULT_DEADLINE } from './chunk-CUGK4ZBJ.mjs';
|
|
10
|
+
export { APIError, fetchSupportedAssets, fetchVaults, findVaultByConfig, getAssetsFromCache, getCache, getWithdrawSupportedAssets, initAmplifySDK, initializeCache, refreshVaultCache } from './chunk-CUGK4ZBJ.mjs';
|
|
11
|
+
import { parseUnits, erc20Abi, toBytes, hexToSignature } from 'viem';
|
|
12
12
|
|
|
13
13
|
async function prepareApproveDepositTokenTxData({
|
|
14
14
|
yieldType,
|
|
@@ -65,6 +65,212 @@ async function prepareApproveDepositTokenTxData({
|
|
|
65
65
|
}
|
|
66
66
|
}
|
|
67
67
|
|
|
68
|
+
// src/abi/community-code-depositor-abi.ts
|
|
69
|
+
var CommunityCodeDepositorAbi = [
|
|
70
|
+
{
|
|
71
|
+
type: "constructor",
|
|
72
|
+
inputs: [
|
|
73
|
+
{ name: "_teller", type: "address", internalType: "address" },
|
|
74
|
+
{ name: "_owner", type: "address", internalType: "address" }
|
|
75
|
+
],
|
|
76
|
+
stateMutability: "nonpayable"
|
|
77
|
+
},
|
|
78
|
+
{
|
|
79
|
+
type: "function",
|
|
80
|
+
name: "authority",
|
|
81
|
+
inputs: [],
|
|
82
|
+
outputs: [
|
|
83
|
+
{ name: "", type: "address", internalType: "contract Authority" }
|
|
84
|
+
],
|
|
85
|
+
stateMutability: "view"
|
|
86
|
+
},
|
|
87
|
+
{
|
|
88
|
+
type: "function",
|
|
89
|
+
name: "boringVault",
|
|
90
|
+
inputs: [],
|
|
91
|
+
outputs: [{ name: "", type: "address", internalType: "address" }],
|
|
92
|
+
stateMutability: "view"
|
|
93
|
+
},
|
|
94
|
+
{
|
|
95
|
+
type: "function",
|
|
96
|
+
name: "deposit",
|
|
97
|
+
inputs: [
|
|
98
|
+
{
|
|
99
|
+
name: "depositAsset",
|
|
100
|
+
type: "address",
|
|
101
|
+
internalType: "contract ERC20"
|
|
102
|
+
},
|
|
103
|
+
{
|
|
104
|
+
name: "depositAmount",
|
|
105
|
+
type: "uint256",
|
|
106
|
+
internalType: "uint256"
|
|
107
|
+
},
|
|
108
|
+
{ name: "minimumMint", type: "uint256", internalType: "uint256" },
|
|
109
|
+
{ name: "to", type: "address", internalType: "address" },
|
|
110
|
+
{ name: "communityCode", type: "bytes", internalType: "bytes" }
|
|
111
|
+
],
|
|
112
|
+
outputs: [{ name: "shares", type: "uint256", internalType: "uint256" }],
|
|
113
|
+
stateMutability: "nonpayable"
|
|
114
|
+
},
|
|
115
|
+
{
|
|
116
|
+
type: "function",
|
|
117
|
+
name: "depositNative",
|
|
118
|
+
inputs: [
|
|
119
|
+
{
|
|
120
|
+
name: "depositAmount",
|
|
121
|
+
type: "uint256",
|
|
122
|
+
internalType: "uint256"
|
|
123
|
+
},
|
|
124
|
+
{ name: "minimumMint", type: "uint256", internalType: "uint256" },
|
|
125
|
+
{ name: "to", type: "address", internalType: "address" },
|
|
126
|
+
{ name: "communityCode", type: "bytes", internalType: "bytes" }
|
|
127
|
+
],
|
|
128
|
+
outputs: [{ name: "shares", type: "uint256", internalType: "uint256" }],
|
|
129
|
+
stateMutability: "payable"
|
|
130
|
+
},
|
|
131
|
+
{
|
|
132
|
+
type: "function",
|
|
133
|
+
name: "depositNonce",
|
|
134
|
+
inputs: [],
|
|
135
|
+
outputs: [{ name: "", type: "uint256", internalType: "uint256" }],
|
|
136
|
+
stateMutability: "view"
|
|
137
|
+
},
|
|
138
|
+
{
|
|
139
|
+
type: "function",
|
|
140
|
+
name: "owner",
|
|
141
|
+
inputs: [],
|
|
142
|
+
outputs: [{ name: "", type: "address", internalType: "address" }],
|
|
143
|
+
stateMutability: "view"
|
|
144
|
+
},
|
|
145
|
+
{
|
|
146
|
+
type: "function",
|
|
147
|
+
name: "setAuthority",
|
|
148
|
+
inputs: [
|
|
149
|
+
{
|
|
150
|
+
name: "newAuthority",
|
|
151
|
+
type: "address",
|
|
152
|
+
internalType: "contract Authority"
|
|
153
|
+
}
|
|
154
|
+
],
|
|
155
|
+
outputs: [],
|
|
156
|
+
stateMutability: "nonpayable"
|
|
157
|
+
},
|
|
158
|
+
{
|
|
159
|
+
type: "function",
|
|
160
|
+
name: "teller",
|
|
161
|
+
inputs: [],
|
|
162
|
+
outputs: [
|
|
163
|
+
{
|
|
164
|
+
name: "",
|
|
165
|
+
type: "address",
|
|
166
|
+
internalType: "contract TellerWithMultiAssetSupport"
|
|
167
|
+
}
|
|
168
|
+
],
|
|
169
|
+
stateMutability: "view"
|
|
170
|
+
},
|
|
171
|
+
{
|
|
172
|
+
type: "function",
|
|
173
|
+
name: "transferOwnership",
|
|
174
|
+
inputs: [{ name: "newOwner", type: "address", internalType: "address" }],
|
|
175
|
+
outputs: [],
|
|
176
|
+
stateMutability: "nonpayable"
|
|
177
|
+
},
|
|
178
|
+
{
|
|
179
|
+
type: "event",
|
|
180
|
+
name: "AuthorityUpdated",
|
|
181
|
+
inputs: [
|
|
182
|
+
{
|
|
183
|
+
name: "user",
|
|
184
|
+
type: "address",
|
|
185
|
+
indexed: true,
|
|
186
|
+
internalType: "address"
|
|
187
|
+
},
|
|
188
|
+
{
|
|
189
|
+
name: "newAuthority",
|
|
190
|
+
type: "address",
|
|
191
|
+
indexed: true,
|
|
192
|
+
internalType: "contract Authority"
|
|
193
|
+
}
|
|
194
|
+
],
|
|
195
|
+
anonymous: false
|
|
196
|
+
},
|
|
197
|
+
{
|
|
198
|
+
type: "event",
|
|
199
|
+
name: "DepositWithCommunityCode",
|
|
200
|
+
inputs: [
|
|
201
|
+
{
|
|
202
|
+
name: "depositor",
|
|
203
|
+
type: "address",
|
|
204
|
+
indexed: true,
|
|
205
|
+
internalType: "address"
|
|
206
|
+
},
|
|
207
|
+
{
|
|
208
|
+
name: "depositAsset",
|
|
209
|
+
type: "address",
|
|
210
|
+
indexed: true,
|
|
211
|
+
internalType: "contract ERC20"
|
|
212
|
+
},
|
|
213
|
+
{
|
|
214
|
+
name: "depositAmount",
|
|
215
|
+
type: "uint256",
|
|
216
|
+
indexed: false,
|
|
217
|
+
internalType: "uint256"
|
|
218
|
+
},
|
|
219
|
+
{
|
|
220
|
+
name: "minimumMint",
|
|
221
|
+
type: "uint256",
|
|
222
|
+
indexed: false,
|
|
223
|
+
internalType: "uint256"
|
|
224
|
+
},
|
|
225
|
+
{
|
|
226
|
+
name: "to",
|
|
227
|
+
type: "address",
|
|
228
|
+
indexed: true,
|
|
229
|
+
internalType: "address"
|
|
230
|
+
},
|
|
231
|
+
{
|
|
232
|
+
name: "depositHash",
|
|
233
|
+
type: "bytes32",
|
|
234
|
+
indexed: false,
|
|
235
|
+
internalType: "bytes32"
|
|
236
|
+
},
|
|
237
|
+
{
|
|
238
|
+
name: "communityCode",
|
|
239
|
+
type: "bytes",
|
|
240
|
+
indexed: false,
|
|
241
|
+
internalType: "bytes"
|
|
242
|
+
}
|
|
243
|
+
],
|
|
244
|
+
anonymous: false
|
|
245
|
+
},
|
|
246
|
+
{
|
|
247
|
+
type: "event",
|
|
248
|
+
name: "OwnershipTransferred",
|
|
249
|
+
inputs: [
|
|
250
|
+
{
|
|
251
|
+
name: "user",
|
|
252
|
+
type: "address",
|
|
253
|
+
indexed: true,
|
|
254
|
+
internalType: "address"
|
|
255
|
+
},
|
|
256
|
+
{
|
|
257
|
+
name: "newOwner",
|
|
258
|
+
type: "address",
|
|
259
|
+
indexed: true,
|
|
260
|
+
internalType: "address"
|
|
261
|
+
}
|
|
262
|
+
],
|
|
263
|
+
anonymous: false
|
|
264
|
+
},
|
|
265
|
+
{ type: "error", name: "IncorrectNativeDepositAmount", inputs: [] },
|
|
266
|
+
{
|
|
267
|
+
type: "error",
|
|
268
|
+
name: "NativeWrapperAccountantDecimalsMismatch",
|
|
269
|
+
inputs: []
|
|
270
|
+
},
|
|
271
|
+
{ type: "error", name: "ZeroAddress", inputs: [] }
|
|
272
|
+
];
|
|
273
|
+
|
|
68
274
|
// src/vaults/deposit/utils.ts
|
|
69
275
|
var calculateMinimumMint = (depositAmount, rate, vaultTokenDecimals, slippage) => {
|
|
70
276
|
const slippageValue = slippage ?? DEFAULT_SLIPPAGE_BPS;
|
|
@@ -84,7 +290,9 @@ async function prepareDepositTxData(params) {
|
|
|
84
290
|
depositToken,
|
|
85
291
|
depositAmount,
|
|
86
292
|
chainId,
|
|
87
|
-
slippage = DEFAULT_SLIPPAGE_BPS
|
|
293
|
+
slippage = DEFAULT_SLIPPAGE_BPS,
|
|
294
|
+
recipientAddress,
|
|
295
|
+
partnerCode
|
|
88
296
|
} = params;
|
|
89
297
|
try {
|
|
90
298
|
const normalizedChainId = toChainId(chainId);
|
|
@@ -126,6 +334,7 @@ async function prepareDepositTxData(params) {
|
|
|
126
334
|
);
|
|
127
335
|
}
|
|
128
336
|
const tellerAddress = vault.vault.tellerAddress;
|
|
337
|
+
const communityCodeDepositorAddress = vault.vault.communityCodeDepositorAddress;
|
|
129
338
|
const accountantAddress = vault.vault.accountantAddress;
|
|
130
339
|
const depositAssetAddress = asset.address;
|
|
131
340
|
const [depositAssetDecimalsResult, rateInQuoteResult] = await getRateInQuoteWithAssetDecimals({
|
|
@@ -170,6 +379,21 @@ async function prepareDepositTxData(params) {
|
|
|
170
379
|
depositAssetDecimalsResult.result,
|
|
171
380
|
slippage
|
|
172
381
|
);
|
|
382
|
+
if (communityCodeDepositorAddress && partnerCode) {
|
|
383
|
+
return {
|
|
384
|
+
abi: CommunityCodeDepositorAbi,
|
|
385
|
+
address: communityCodeDepositorAddress,
|
|
386
|
+
functionName: "deposit",
|
|
387
|
+
args: [
|
|
388
|
+
depositAssetAddress,
|
|
389
|
+
depositAmountAsBigInt,
|
|
390
|
+
minimumMint,
|
|
391
|
+
recipientAddress,
|
|
392
|
+
toBytes(partnerCode)
|
|
393
|
+
],
|
|
394
|
+
chainId: normalizedChainId
|
|
395
|
+
};
|
|
396
|
+
}
|
|
173
397
|
return {
|
|
174
398
|
abi: TellerAbi,
|
|
175
399
|
address: tellerAddress,
|
|
@@ -413,7 +637,7 @@ function parsePermitSignature(signature) {
|
|
|
413
637
|
);
|
|
414
638
|
}
|
|
415
639
|
}
|
|
416
|
-
async function
|
|
640
|
+
async function prepareDepositWithPermitTxData(params) {
|
|
417
641
|
const {
|
|
418
642
|
yieldType,
|
|
419
643
|
depositToken,
|
|
@@ -423,40 +647,29 @@ async function prepareDepositWithPermitTransactionData(params) {
|
|
|
423
647
|
deadline,
|
|
424
648
|
slippage = DEFAULT_SLIPPAGE_BPS
|
|
425
649
|
} = params;
|
|
426
|
-
console.log("[Amplify SDK] prepareDepositWithPermitTransactionData called", {
|
|
427
|
-
yieldType,
|
|
428
|
-
depositToken,
|
|
429
|
-
depositAmount,
|
|
430
|
-
chainId,
|
|
431
|
-
deadline: deadline.toString(),
|
|
432
|
-
slippage
|
|
433
|
-
});
|
|
434
650
|
try {
|
|
435
651
|
const { v, r, s } = parsePermitSignature(signature);
|
|
436
652
|
if (slippage < 0 || slippage > 1e4) {
|
|
437
653
|
throw new APIError(
|
|
438
654
|
`Invalid slippage value: ${slippage}. Slippage must be between 0 and 10000 basis points.`,
|
|
439
655
|
{
|
|
440
|
-
endpoint: "
|
|
656
|
+
endpoint: "prepareDepositWithPermitTxData"
|
|
441
657
|
}
|
|
442
658
|
);
|
|
443
659
|
}
|
|
444
660
|
const normalizedChainId = toChainId(chainId);
|
|
445
|
-
console.log("[Amplify SDK] Normalized chainId:", normalizedChainId);
|
|
446
661
|
let vault;
|
|
447
662
|
try {
|
|
448
|
-
console.log("[Amplify SDK] Resolving vault with findVaultByConfig...");
|
|
449
663
|
vault = await findVaultByConfig({
|
|
450
664
|
assetAddress: depositToken,
|
|
451
665
|
yieldType,
|
|
452
666
|
chainId: normalizedChainId
|
|
453
667
|
});
|
|
454
|
-
console.log("[Amplify SDK] Vault resolved:", vault ? "Found" : "Not found");
|
|
455
668
|
} catch (error) {
|
|
456
669
|
throw new APIError(
|
|
457
670
|
`Failed to resolve vault for token ${depositToken} with yield type ${yieldType} on chain ${normalizedChainId}: ${error instanceof Error ? error.message : "Unknown error"}`,
|
|
458
671
|
{
|
|
459
|
-
endpoint: "
|
|
672
|
+
endpoint: "prepareDepositWithPermitTxData",
|
|
460
673
|
cause: error
|
|
461
674
|
}
|
|
462
675
|
);
|
|
@@ -465,14 +678,12 @@ async function prepareDepositWithPermitTransactionData(params) {
|
|
|
465
678
|
throw new APIError(
|
|
466
679
|
`No vault found for token address ${depositToken} with yield type '${yieldType}' on chain ${normalizedChainId}. This combination may not be supported.`,
|
|
467
680
|
{
|
|
468
|
-
endpoint: "
|
|
681
|
+
endpoint: "prepareDepositWithPermitTxData"
|
|
469
682
|
}
|
|
470
683
|
);
|
|
471
684
|
}
|
|
472
|
-
console.log("[Amplify SDK] Fetching supported assets for depositToken:", depositToken);
|
|
473
685
|
let asset = null;
|
|
474
686
|
const assets = await fetchSupportedAssets({ address: depositToken });
|
|
475
|
-
console.log("[Amplify SDK] Supported assets found:", assets.length);
|
|
476
687
|
if (assets.length > 0) {
|
|
477
688
|
asset = assets.find((a) => a.chains.includes(normalizedChainId)) || assets[0] || null;
|
|
478
689
|
}
|
|
@@ -480,7 +691,7 @@ async function prepareDepositWithPermitTransactionData(params) {
|
|
|
480
691
|
throw new APIError(
|
|
481
692
|
`Asset metadata not found for token ${depositToken} on chain ${normalizedChainId}`,
|
|
482
693
|
{
|
|
483
|
-
endpoint: "
|
|
694
|
+
endpoint: "prepareDepositWithPermitTxData"
|
|
484
695
|
}
|
|
485
696
|
);
|
|
486
697
|
}
|
|
@@ -488,33 +699,23 @@ async function prepareDepositWithPermitTransactionData(params) {
|
|
|
488
699
|
throw new APIError(
|
|
489
700
|
`Token ${asset.symbol || depositToken} not supported on chain ${normalizedChainId}`,
|
|
490
701
|
{
|
|
491
|
-
endpoint: "
|
|
702
|
+
endpoint: "prepareDepositWithPermitTxData"
|
|
492
703
|
}
|
|
493
704
|
);
|
|
494
705
|
}
|
|
495
706
|
const tellerAddress = vault.vault.tellerAddress;
|
|
496
707
|
const accountantAddress = vault.vault.accountantAddress;
|
|
497
708
|
const depositAssetAddress = asset.address;
|
|
498
|
-
console.log("[Amplify SDK] Contract addresses:", {
|
|
499
|
-
tellerAddress,
|
|
500
|
-
accountantAddress,
|
|
501
|
-
depositAssetAddress
|
|
502
|
-
});
|
|
503
|
-
console.log("[Amplify SDK] Calling getRateInQuoteWithAssetDecimals...");
|
|
504
709
|
const [depositAssetDecimalsResult, rateInQuoteResult] = await getRateInQuoteWithAssetDecimals({
|
|
505
710
|
assetAddress: depositAssetAddress,
|
|
506
711
|
accountantAddress,
|
|
507
712
|
chainId: normalizedChainId
|
|
508
713
|
});
|
|
509
|
-
console.log("[Amplify SDK] getRateInQuoteWithAssetDecimals completed", {
|
|
510
|
-
decimalsStatus: depositAssetDecimalsResult.status,
|
|
511
|
-
rateStatus: rateInQuoteResult.status
|
|
512
|
-
});
|
|
513
714
|
if (depositAssetDecimalsResult.status === "failure") {
|
|
514
715
|
throw new APIError(
|
|
515
716
|
`Failed to get asset decimals: ${depositAssetDecimalsResult.error?.message || "Unknown error"}`,
|
|
516
717
|
{
|
|
517
|
-
endpoint: "
|
|
718
|
+
endpoint: "prepareDepositWithPermitTxData",
|
|
518
719
|
cause: depositAssetDecimalsResult.error
|
|
519
720
|
}
|
|
520
721
|
);
|
|
@@ -523,37 +724,27 @@ async function prepareDepositWithPermitTransactionData(params) {
|
|
|
523
724
|
throw new APIError(
|
|
524
725
|
`Failed to get exchange rate: ${rateInQuoteResult.error?.message || "Unknown error"}`,
|
|
525
726
|
{
|
|
526
|
-
endpoint: "
|
|
727
|
+
endpoint: "prepareDepositWithPermitTxData",
|
|
527
728
|
cause: rateInQuoteResult.error
|
|
528
729
|
}
|
|
529
730
|
);
|
|
530
731
|
}
|
|
531
732
|
const depositAmountAsBigInt = parseUnits(depositAmount, asset.decimals);
|
|
532
|
-
console.log("[Amplify SDK] Fetching vault shares asset:", vault.vault.boringVaultAddress);
|
|
533
733
|
const vaultSharesAssets = await fetchSupportedAssets({
|
|
534
734
|
address: vault.vault.boringVaultAddress
|
|
535
735
|
});
|
|
536
|
-
console.log("[Amplify SDK] Vault shares assets found:", vaultSharesAssets.length);
|
|
537
736
|
if (vaultSharesAssets.length === 0) {
|
|
538
737
|
throw new APIError(
|
|
539
738
|
`Vault shares token not found in supported assets: ${vault.vault.boringVaultAddress}`,
|
|
540
|
-
{ endpoint: "
|
|
739
|
+
{ endpoint: "prepareDepositWithPermitTxData" }
|
|
541
740
|
);
|
|
542
741
|
}
|
|
543
|
-
console.log("[Amplify SDK] Calculating minimumMint...", {
|
|
544
|
-
depositAmountAsBigInt: depositAmountAsBigInt.toString(),
|
|
545
|
-
rateInQuote: rateInQuoteResult.result.toString(),
|
|
546
|
-
vaultSharesDecimals: vaultSharesAssets[0].decimals,
|
|
547
|
-
slippage
|
|
548
|
-
});
|
|
549
742
|
const minimumMint = calculateMinimumMint(
|
|
550
743
|
depositAmountAsBigInt,
|
|
551
744
|
rateInQuoteResult.result,
|
|
552
745
|
vaultSharesAssets[0].decimals,
|
|
553
746
|
slippage
|
|
554
747
|
);
|
|
555
|
-
console.log("[Amplify SDK] minimumMint calculated:", minimumMint.toString());
|
|
556
|
-
console.log("[Amplify SDK] Returning transaction data successfully");
|
|
557
748
|
return {
|
|
558
749
|
data: {
|
|
559
750
|
abi: TellerAbi,
|
|
@@ -578,7 +769,7 @@ async function prepareDepositWithPermitTransactionData(params) {
|
|
|
578
769
|
throw new APIError(
|
|
579
770
|
`Failed to prepare deposit with permit transaction: ${error instanceof Error ? error.message : String(error)}`,
|
|
580
771
|
{
|
|
581
|
-
endpoint: "
|
|
772
|
+
endpoint: "prepareDepositWithPermitTxData",
|
|
582
773
|
cause: error
|
|
583
774
|
}
|
|
584
775
|
);
|
|
@@ -664,7 +855,7 @@ async function prepareBulkWithdrawTxData(params) {
|
|
|
664
855
|
shareAmount,
|
|
665
856
|
chainId,
|
|
666
857
|
slippage = DEFAULT_SLIPPAGE_BPS,
|
|
667
|
-
|
|
858
|
+
recipientAddress
|
|
668
859
|
} = params;
|
|
669
860
|
try {
|
|
670
861
|
const normalizedChainId = toChainId(chainId);
|
|
@@ -731,7 +922,12 @@ async function prepareBulkWithdrawTxData(params) {
|
|
|
731
922
|
abi: TellerAbi,
|
|
732
923
|
address: vault.vault.tellerAddress,
|
|
733
924
|
functionName: "bulkWithdraw",
|
|
734
|
-
args: [
|
|
925
|
+
args: [
|
|
926
|
+
wantAssetAddress,
|
|
927
|
+
offerAmountAsBigInt,
|
|
928
|
+
minimumAssets,
|
|
929
|
+
recipientAddress
|
|
930
|
+
],
|
|
735
931
|
chainId: normalizedChainId
|
|
736
932
|
};
|
|
737
933
|
} catch (error) {
|
|
@@ -1075,6 +1271,6 @@ var prepareWithdrawTxData = async ({
|
|
|
1075
1271
|
}
|
|
1076
1272
|
};
|
|
1077
1273
|
|
|
1078
|
-
export { PERMIT_TYPES, parsePermitSignature, prepareApproveDepositTokenTxData, prepareApproveWithdrawTxData, prepareBulkWithdrawTxData, prepareDepositPermitSignature, prepareDepositTxData,
|
|
1274
|
+
export { PERMIT_TYPES, parsePermitSignature, prepareApproveDepositTokenTxData, prepareApproveWithdrawTxData, prepareBulkWithdrawTxData, prepareDepositPermitSignature, prepareDepositTxData, prepareDepositWithPermitTxData, prepareWithdrawTxData };
|
|
1079
1275
|
//# sourceMappingURL=index.mjs.map
|
|
1080
1276
|
//# sourceMappingURL=index.mjs.map
|