@pufferfinance/puffer-sdk 1.13.2 → 1.14.1
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/api/puffer-client-helpers.cjs +1 -1
- package/dist/api/puffer-client-helpers.cjs.map +1 -1
- package/dist/api/puffer-client-helpers.js +3 -3
- package/dist/api/puffer-client-helpers.js.map +1 -1
- package/dist/api/puffer-client.cjs +1 -1
- package/dist/api/puffer-client.js +2 -2
- package/dist/{ccip-C0xwQhXU.cjs → ccip-BYEwaDSr.cjs} +2 -2
- package/dist/{ccip-C0xwQhXU.cjs.map → ccip-BYEwaDSr.cjs.map} +1 -1
- package/dist/{ccip-K-z2PL4P.js → ccip-DA_MOIPz.js} +3 -3
- package/dist/{ccip-K-z2PL4P.js.map → ccip-DA_MOIPz.js.map} +1 -1
- package/dist/chains/constants.cjs +1 -1
- package/dist/chains/constants.d.ts +4 -1
- package/dist/chains/constants.js +1 -1
- package/dist/constants-5WxIZnbu.cjs +9 -0
- package/dist/constants-5WxIZnbu.cjs.map +1 -0
- package/dist/{constants-CH7Tz5jz.js → constants-BDqMRitM.js} +924 -798
- package/dist/constants-BDqMRitM.js.map +1 -0
- package/dist/contracts/abis/mainnet/Accountant.cjs +1 -1
- package/dist/contracts/abis/mainnet/Accountant.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/Accountant.d.ts +13 -457
- package/dist/contracts/abis/mainnet/Accountant.js +12 -441
- package/dist/contracts/abis/mainnet/Accountant.js.map +1 -1
- package/dist/contracts/abis/mainnet/BoringVault.cjs +1 -1
- package/dist/contracts/abis/mainnet/BoringVault.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/BoringVault.d.ts +18 -505
- package/dist/contracts/abis/mainnet/BoringVault.js +15 -346
- package/dist/contracts/abis/mainnet/BoringVault.js.map +1 -1
- package/dist/contracts/abis/mainnet/CarrotStaker.cjs +1 -1
- package/dist/contracts/abis/mainnet/CarrotStaker.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/CarrotStaker.d.ts +2 -371
- package/dist/contracts/abis/mainnet/CarrotStaker.js +4 -295
- package/dist/contracts/abis/mainnet/CarrotStaker.js.map +1 -1
- package/dist/contracts/abis/mainnet/Distributor.cjs +1 -1
- package/dist/contracts/abis/mainnet/Distributor.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/Distributor.d.ts +0 -413
- package/dist/contracts/abis/mainnet/Distributor.js +2 -355
- package/dist/contracts/abis/mainnet/Distributor.js.map +1 -1
- package/dist/contracts/abis/mainnet/L1RewardManager.cjs +1 -1
- package/dist/contracts/abis/mainnet/L1RewardManager.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/L1RewardManager.d.ts +0 -489
- package/dist/contracts/abis/mainnet/L1RewardManager.js +0 -411
- package/dist/contracts/abis/mainnet/L1RewardManager.js.map +1 -1
- package/dist/contracts/abis/mainnet/L2RewardManager.cjs +1 -1
- package/dist/contracts/abis/mainnet/L2RewardManager.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/L2RewardManager.d.ts +23 -569
- package/dist/contracts/abis/mainnet/L2RewardManager.js +16 -484
- package/dist/contracts/abis/mainnet/L2RewardManager.js.map +1 -1
- package/dist/contracts/abis/mainnet/PufLocker.cjs +1 -1
- package/dist/contracts/abis/mainnet/PufLocker.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/PufLocker.d.ts +29 -371
- package/dist/contracts/abis/mainnet/PufLocker.js +15 -285
- package/dist/contracts/abis/mainnet/PufLocker.js.map +1 -1
- package/dist/contracts/abis/mainnet/PufferL2Depositor.cjs +1 -1
- package/dist/contracts/abis/mainnet/PufferL2Depositor.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/PufferL2Depositor.d.ts +0 -325
- package/dist/contracts/abis/mainnet/PufferL2Depositor.js +0 -270
- package/dist/contracts/abis/mainnet/PufferL2Depositor.js.map +1 -1
- package/dist/contracts/abis/mainnet/PufferVaultV2.cjs +1 -1
- package/dist/contracts/abis/mainnet/PufferVaultV2.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/PufferVaultV2.d.ts +35 -1289
- package/dist/contracts/abis/mainnet/PufferVaultV2.js +45 -1681
- package/dist/contracts/abis/mainnet/PufferVaultV2.js.map +1 -1
- package/dist/contracts/abis/mainnet/PufferWithdrawalManager.cjs +1 -1
- package/dist/contracts/abis/mainnet/PufferWithdrawalManager.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/PufferWithdrawalManager.d.ts +3 -426
- package/dist/contracts/abis/mainnet/PufferWithdrawalManager.js +5 -552
- package/dist/contracts/abis/mainnet/PufferWithdrawalManager.js.map +1 -1
- package/dist/contracts/abis/mainnet/Teller.cjs +1 -1
- package/dist/contracts/abis/mainnet/Teller.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/Teller.d.ts +18 -444
- package/dist/contracts/abis/mainnet/Teller.js +15 -390
- package/dist/contracts/abis/mainnet/Teller.js.map +1 -1
- package/dist/contracts/abis/mainnet/mtwCARROT.cjs +1 -1
- package/dist/contracts/abis/mainnet/mtwCARROT.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/mtwCARROT.d.ts +69 -399
- package/dist/contracts/abis/mainnet/mtwCARROT.js +43 -346
- package/dist/contracts/abis/mainnet/mtwCARROT.js.map +1 -1
- package/dist/contracts/addresses.cjs +1 -1
- package/dist/contracts/addresses.cjs.map +1 -1
- package/dist/contracts/addresses.js +4 -1
- package/dist/contracts/addresses.js.map +1 -1
- package/dist/contracts/handlers/carrot-staking-handler.cjs +1 -1
- package/dist/contracts/handlers/carrot-staking-handler.d.ts +1652 -0
- package/dist/contracts/handlers/carrot-staking-handler.js +2 -2
- package/dist/contracts/handlers/distributor-handler.cjs +1 -1
- package/dist/contracts/handlers/distributor-handler.cjs.map +1 -1
- package/dist/contracts/handlers/distributor-handler.d.ts +8762 -0
- package/dist/contracts/handlers/distributor-handler.js +13 -127
- package/dist/contracts/handlers/distributor-handler.js.map +1 -1
- package/dist/contracts/handlers/erc20-permit-handler.cjs +1 -1
- package/dist/contracts/handlers/erc20-permit-handler.cjs.map +1 -1
- package/dist/contracts/handlers/erc20-permit-handler.d.ts +4 -4
- package/dist/contracts/handlers/erc20-permit-handler.js +14 -14
- package/dist/contracts/handlers/erc20-permit-handler.js.map +1 -1
- package/dist/contracts/handlers/l1-reward-manager-handler.cjs +1 -1
- package/dist/contracts/handlers/l1-reward-manager-handler.cjs.map +1 -1
- package/dist/contracts/handlers/l1-reward-manager-handler.d.ts +339 -0
- package/dist/contracts/handlers/l1-reward-manager-handler.js +14 -14
- package/dist/contracts/handlers/l1-reward-manager-handler.js.map +1 -1
- package/dist/contracts/handlers/l2-reward-manager-handler.cjs +1 -1
- package/dist/contracts/handlers/l2-reward-manager-handler.cjs.map +1 -1
- package/dist/contracts/handlers/l2-reward-manager-handler.d.ts +2423 -0
- package/dist/contracts/handlers/l2-reward-manager-handler.js +6 -6
- package/dist/contracts/handlers/l2-reward-manager-handler.js.map +1 -1
- package/dist/contracts/handlers/mtw-carrot-handler.cjs +1 -1
- package/dist/contracts/handlers/mtw-carrot-handler.d.ts +14333 -0
- package/dist/contracts/handlers/mtw-carrot-handler.js +2 -2
- package/dist/contracts/handlers/nucleus-accountant-handler.cjs +1 -1
- package/dist/contracts/handlers/nucleus-accountant-handler.cjs.map +1 -1
- package/dist/contracts/handlers/nucleus-accountant-handler.d.ts +620 -0
- package/dist/contracts/handlers/nucleus-accountant-handler.js +8 -8
- package/dist/contracts/handlers/nucleus-accountant-handler.js.map +1 -1
- package/dist/contracts/handlers/nucleus-atomic-queue-handler.cjs +1 -1
- package/dist/contracts/handlers/nucleus-atomic-queue-handler.cjs.map +1 -1
- package/dist/contracts/handlers/nucleus-atomic-queue-handler.js +9 -9
- package/dist/contracts/handlers/nucleus-atomic-queue-handler.js.map +1 -1
- package/dist/contracts/handlers/nucleus-boring-vault-handler.cjs +1 -1
- package/dist/contracts/handlers/nucleus-boring-vault-handler.cjs.map +1 -1
- package/dist/contracts/handlers/nucleus-boring-vault-handler.d.ts +3917 -0
- package/dist/contracts/handlers/nucleus-boring-vault-handler.js +24 -24
- package/dist/contracts/handlers/nucleus-boring-vault-handler.js.map +1 -1
- package/dist/contracts/handlers/nucleus-teller-handler.cjs +1 -1
- package/dist/contracts/handlers/nucleus-teller-handler.cjs.map +1 -1
- package/dist/contracts/handlers/nucleus-teller-handler.d.ts +2209 -0
- package/dist/contracts/handlers/nucleus-teller-handler.js +14 -14
- package/dist/contracts/handlers/nucleus-teller-handler.js.map +1 -1
- package/dist/contracts/handlers/puf-locker-handler.cjs +1 -1
- package/dist/contracts/handlers/puf-locker-handler.cjs.map +1 -1
- package/dist/contracts/handlers/puf-locker-handler.d.ts +2389 -0
- package/dist/contracts/handlers/puf-locker-handler.js +12 -12
- package/dist/contracts/handlers/puf-locker-handler.js.map +1 -1
- package/dist/contracts/handlers/puffer-depositor-handler.cjs +1 -1
- package/dist/contracts/handlers/puffer-depositor-handler.cjs.map +1 -1
- package/dist/contracts/handlers/puffer-depositor-handler.d.ts +100 -100
- package/dist/contracts/handlers/puffer-depositor-handler.js +19 -19
- package/dist/contracts/handlers/puffer-depositor-handler.js.map +1 -1
- package/dist/contracts/handlers/puffer-l2-depositor-handler.cjs +1 -1
- package/dist/contracts/handlers/puffer-l2-depositor-handler.cjs.map +1 -1
- package/dist/contracts/handlers/puffer-l2-depositor-handler.d.ts +471 -0
- package/dist/contracts/handlers/puffer-l2-depositor-handler.js +17 -17
- package/dist/contracts/handlers/puffer-l2-depositor-handler.js.map +1 -1
- package/dist/contracts/handlers/puffer-vault-handler.cjs +1 -1
- package/dist/contracts/handlers/puffer-vault-handler.cjs.map +1 -1
- package/dist/contracts/handlers/puffer-vault-handler.d.ts +4657 -0
- package/dist/contracts/handlers/puffer-vault-handler.js +4 -4
- package/dist/contracts/handlers/puffer-vault-handler.js.map +1 -1
- package/dist/contracts/handlers/puffer-withdrawal-manager-handler.cjs +1 -1
- package/dist/contracts/handlers/puffer-withdrawal-manager-handler.cjs.map +1 -1
- package/dist/contracts/handlers/puffer-withdrawal-manager-handler.d.ts +1882 -0
- package/dist/contracts/handlers/puffer-withdrawal-manager-handler.js +10 -10
- package/dist/contracts/handlers/puffer-withdrawal-manager-handler.js.map +1 -1
- package/dist/contracts/tokens.cjs +1 -1
- package/dist/contracts/tokens.cjs.map +1 -1
- package/dist/contracts/tokens.d.ts +3 -1
- package/dist/contracts/tokens.js +71 -60
- package/dist/contracts/tokens.js.map +1 -1
- package/dist/contracts/vaults-addresses.cjs +1 -1
- package/dist/contracts/vaults-addresses.d.ts +5 -4
- package/dist/contracts/vaults-addresses.js +1 -1
- package/dist/{createWalletClient-DNLhBkOd.js → createWalletClient-DMXR-Bug.js} +4 -4
- package/dist/{createWalletClient-DNLhBkOd.js.map → createWalletClient-DMXR-Bug.js.map} +1 -1
- package/dist/{createWalletClient-Di5of07E.cjs → createWalletClient-L7tR5Gda.cjs} +2 -2
- package/dist/{createWalletClient-Di5of07E.cjs.map → createWalletClient-L7tR5Gda.cjs.map} +1 -1
- package/dist/{getContract-ChPFzc5y.cjs → getContract-Bt9GsQBq.cjs} +2 -2
- package/dist/{getContract-ChPFzc5y.cjs.map → getContract-Bt9GsQBq.cjs.map} +1 -1
- package/dist/{getContract-6ajhFbP2.js → getContract-DXPZJOBy.js} +2 -2
- package/dist/{getContract-6ajhFbP2.js.map → getContract-DXPZJOBy.js.map} +1 -1
- package/dist/main.cjs +1 -1
- package/dist/main.js +1 -1
- package/dist/{secp256k1-Ev0s9Yr6.js → secp256k1-D02y6Pc-.js} +2 -2
- package/dist/{secp256k1-Ev0s9Yr6.js.map → secp256k1-D02y6Pc-.js.map} +1 -1
- package/dist/{secp256k1-B8plqpXf.cjs → secp256k1-q_akf6f-.cjs} +2 -2
- package/dist/{secp256k1-B8plqpXf.cjs.map → secp256k1-q_akf6f-.cjs.map} +1 -1
- package/dist/utils/version.cjs +1 -1
- package/dist/utils/version.js +1 -1
- package/dist/{writeContract-CjcOEtWX.js → writeContract-BsrMQkg5.js} +4 -4
- package/dist/{writeContract-CjcOEtWX.js.map → writeContract-BsrMQkg5.js.map} +1 -1
- package/dist/{writeContract-BatuNuTe.cjs → writeContract-Cbrw62uO.cjs} +3 -3
- package/dist/{writeContract-BatuNuTe.cjs.map → writeContract-Cbrw62uO.cjs.map} +1 -1
- package/package.json +2 -2
- package/dist/constants-BcPRVxdH.cjs +0 -9
- package/dist/constants-BcPRVxdH.cjs.map +0 -1
- package/dist/constants-CH7Tz5jz.js.map +0 -1
- package/dist/contracts/abis/holesky/PufferDepositor.cjs +0 -2
- package/dist/contracts/abis/holesky/PufferDepositor.cjs.map +0 -1
- package/dist/contracts/abis/holesky/PufferDepositor.d.ts +0 -283
- package/dist/contracts/abis/holesky/PufferDepositor.js +0 -377
- package/dist/contracts/abis/holesky/PufferDepositor.js.map +0 -1
- package/dist/contracts/abis/holesky/PufferVaultV2.cjs +0 -2
- package/dist/contracts/abis/holesky/PufferVaultV2.cjs.map +0 -1
- package/dist/contracts/abis/holesky/PufferVaultV2.d.ts +0 -1361
- package/dist/contracts/abis/holesky/PufferVaultV2.js +0 -1787
- package/dist/contracts/abis/holesky/PufferVaultV2.js.map +0 -1
- package/dist/contracts/abis/l1-reward-manager-abis.cjs +0 -2
- package/dist/contracts/abis/l1-reward-manager-abis.cjs.map +0 -1
- package/dist/contracts/abis/l1-reward-manager-abis.d.ts +0 -527
- package/dist/contracts/abis/l1-reward-manager-abis.js +0 -10
- package/dist/contracts/abis/l1-reward-manager-abis.js.map +0 -1
- package/dist/contracts/abis/l2-reward-manager-abis.cjs +0 -2
- package/dist/contracts/abis/l2-reward-manager-abis.cjs.map +0 -1
- package/dist/contracts/abis/l2-reward-manager-abis.d.ts +0 -709
- package/dist/contracts/abis/l2-reward-manager-abis.js +0 -11
- package/dist/contracts/abis/l2-reward-manager-abis.js.map +0 -1
- package/dist/contracts/abis/nucleus-accountant-abis.cjs +0 -2
- package/dist/contracts/abis/nucleus-accountant-abis.cjs.map +0 -1
- package/dist/contracts/abis/nucleus-accountant-abis.d.ts +0 -525
- package/dist/contracts/abis/nucleus-accountant-abis.js +0 -9
- package/dist/contracts/abis/nucleus-accountant-abis.js.map +0 -1
- package/dist/contracts/abis/nucleus-atomic-queue-abis.cjs +0 -2
- package/dist/contracts/abis/nucleus-atomic-queue-abis.cjs.map +0 -1
- package/dist/contracts/abis/nucleus-atomic-queue-abis.d.ts +0 -332
- package/dist/contracts/abis/nucleus-atomic-queue-abis.js +0 -9
- package/dist/contracts/abis/nucleus-atomic-queue-abis.js.map +0 -1
- package/dist/contracts/abis/nucleus-boring-vault-abis.cjs +0 -2
- package/dist/contracts/abis/nucleus-boring-vault-abis.cjs.map +0 -1
- package/dist/contracts/abis/nucleus-boring-vault-abis.d.ts +0 -626
- package/dist/contracts/abis/nucleus-boring-vault-abis.js +0 -9
- package/dist/contracts/abis/nucleus-boring-vault-abis.js.map +0 -1
- package/dist/contracts/abis/nucleus-teller-abis.cjs +0 -2
- package/dist/contracts/abis/nucleus-teller-abis.cjs.map +0 -1
- package/dist/contracts/abis/nucleus-teller-abis.d.ts +0 -545
- package/dist/contracts/abis/nucleus-teller-abis.js +0 -9
- package/dist/contracts/abis/nucleus-teller-abis.js.map +0 -1
- package/dist/contracts/abis/puf-locker-abis.cjs +0 -2
- package/dist/contracts/abis/puf-locker-abis.cjs.map +0 -1
- package/dist/contracts/abis/puf-locker-abis.d.ts +0 -484
- package/dist/contracts/abis/puf-locker-abis.js +0 -10
- package/dist/contracts/abis/puf-locker-abis.js.map +0 -1
- package/dist/contracts/abis/puffer-depositor-abis.cjs +0 -2
- package/dist/contracts/abis/puffer-depositor-abis.cjs.map +0 -1
- package/dist/contracts/abis/puffer-depositor-abis.d.ts +0 -664
- package/dist/contracts/abis/puffer-depositor-abis.js +0 -20
- package/dist/contracts/abis/puffer-depositor-abis.js.map +0 -1
- package/dist/contracts/abis/puffer-vault-abis.cjs +0 -2
- package/dist/contracts/abis/puffer-vault-abis.cjs.map +0 -1
- package/dist/contracts/abis/puffer-vault-abis.d.ts +0 -2787
- package/dist/contracts/abis/puffer-vault-abis.js +0 -15
- package/dist/contracts/abis/puffer-vault-abis.js.map +0 -1
- package/dist/contracts/abis/puffer-withdrawal-manager-abis.cjs +0 -2
- package/dist/contracts/abis/puffer-withdrawal-manager-abis.cjs.map +0 -1
- package/dist/contracts/abis/puffer-withdrawal-manager-abis.d.ts +0 -514
- package/dist/contracts/abis/puffer-withdrawal-manager-abis.js +0 -10
- package/dist/contracts/abis/puffer-withdrawal-manager-abis.js.map +0 -1
- package/dist/contracts/abis/tokens-abis.cjs +0 -2
- package/dist/contracts/abis/tokens-abis.cjs.map +0 -1
- package/dist/contracts/abis/tokens-abis.d.ts +0 -396
- package/dist/contracts/abis/tokens-abis.js +0 -6
- package/dist/contracts/abis/tokens-abis.js.map +0 -1
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
var C = Object.defineProperty;
|
|
2
|
-
var
|
|
3
|
-
var m = (e, t, i) =>
|
|
4
|
-
import { V as
|
|
5
|
-
import { PUFFER_DEPOSITOR_ABIS as E } from "../abis/puffer-depositor-abis.js";
|
|
2
|
+
var H = (e, t, i) => t in e ? C(e, t, { enumerable: !0, configurable: !0, writable: !0, value: i }) : e[t] = i;
|
|
3
|
+
var m = (e, t, i) => H(e, typeof t != "symbol" ? t + "" : t, i);
|
|
4
|
+
import { V as P } from "../../constants-BDqMRitM.js";
|
|
6
5
|
import { CONTRACT_ADDRESSES as h } from "../addresses.js";
|
|
7
6
|
import { ERC20PermitHandler as T } from "./erc20-permit-handler.js";
|
|
8
7
|
import { Token as p } from "../tokens.js";
|
|
9
|
-
import {
|
|
10
|
-
|
|
8
|
+
import { PufferDepositor as E } from "../abis/mainnet/PufferDepositor.js";
|
|
9
|
+
import { g } from "../../getContract-DXPZJOBy.js";
|
|
10
|
+
class k {
|
|
11
11
|
/**
|
|
12
12
|
* Create the handler for the `PufferDepositor` contract exposing
|
|
13
13
|
* methods to interact with the contract.
|
|
@@ -21,7 +21,7 @@ class I {
|
|
|
21
21
|
constructor(t, i, a) {
|
|
22
22
|
m(this, "viemChain");
|
|
23
23
|
m(this, "erc20PermitHandler");
|
|
24
|
-
this.chain = t, this.walletClient = i, this.publicClient = a, this.viemChain =
|
|
24
|
+
this.chain = t, this.walletClient = i, this.publicClient = a, this.viemChain = P[t], this.erc20PermitHandler = new T(
|
|
25
25
|
t,
|
|
26
26
|
i,
|
|
27
27
|
a
|
|
@@ -34,7 +34,7 @@ class I {
|
|
|
34
34
|
* @returns The viem contract.
|
|
35
35
|
*/
|
|
36
36
|
getContract() {
|
|
37
|
-
const t = h[this.chain].PufferDepositor, i = E
|
|
37
|
+
const t = h[this.chain].PufferDepositor, i = E, a = { public: this.publicClient, wallet: this.walletClient };
|
|
38
38
|
return g({ address: t, abi: i, client: a });
|
|
39
39
|
}
|
|
40
40
|
/**
|
|
@@ -51,22 +51,22 @@ class I {
|
|
|
51
51
|
* transaction.
|
|
52
52
|
*/
|
|
53
53
|
async depositStETH(t, i) {
|
|
54
|
-
const { r: a, s:
|
|
54
|
+
const { r: a, s: n, v: o, yParity: s, deadline: c } = await this.erc20PermitHandler.withToken(p.stETH).getPermitSignature(
|
|
55
55
|
t,
|
|
56
56
|
h[this.chain].PufferDepositor,
|
|
57
57
|
i
|
|
58
|
-
),
|
|
58
|
+
), r = {
|
|
59
59
|
r: a,
|
|
60
|
-
s:
|
|
60
|
+
s: n,
|
|
61
61
|
v: Number(o ?? s),
|
|
62
62
|
deadline: c,
|
|
63
63
|
amount: i
|
|
64
64
|
};
|
|
65
|
-
return { transact: async () => await this.getContract().write.depositStETH([
|
|
65
|
+
return { transact: async () => await this.getContract().write.depositStETH([r, t], {
|
|
66
66
|
account: t,
|
|
67
67
|
chain: this.viemChain
|
|
68
68
|
}), estimate: async () => await this.getContract().estimateGas.depositStETH(
|
|
69
|
-
[
|
|
69
|
+
[r, t],
|
|
70
70
|
{ account: t }
|
|
71
71
|
) };
|
|
72
72
|
}
|
|
@@ -84,30 +84,30 @@ class I {
|
|
|
84
84
|
* transaction.
|
|
85
85
|
*/
|
|
86
86
|
async depositWstETH(t, i) {
|
|
87
|
-
const { r: a, s:
|
|
87
|
+
const { r: a, s: n, v: o, yParity: s, deadline: c } = await this.erc20PermitHandler.withToken(p.wstETH).getPermitSignature(
|
|
88
88
|
t,
|
|
89
89
|
h[this.chain].PufferDepositor,
|
|
90
90
|
i
|
|
91
|
-
),
|
|
91
|
+
), r = {
|
|
92
92
|
r: a,
|
|
93
|
-
s:
|
|
93
|
+
s: n,
|
|
94
94
|
v: Number(o ?? s),
|
|
95
95
|
deadline: c,
|
|
96
96
|
amount: i
|
|
97
97
|
};
|
|
98
98
|
return { transact: async () => await this.getContract().write.depositWstETH(
|
|
99
|
-
[
|
|
99
|
+
[r, t],
|
|
100
100
|
{
|
|
101
101
|
account: t,
|
|
102
102
|
chain: this.viemChain
|
|
103
103
|
}
|
|
104
104
|
), estimate: async () => await this.getContract().estimateGas.depositWstETH(
|
|
105
|
-
[
|
|
105
|
+
[r, t],
|
|
106
106
|
{ account: t }
|
|
107
107
|
) };
|
|
108
108
|
}
|
|
109
109
|
}
|
|
110
110
|
export {
|
|
111
|
-
|
|
111
|
+
k as PufferDepositorHandler
|
|
112
112
|
};
|
|
113
113
|
//# sourceMappingURL=puffer-depositor-handler.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"puffer-depositor-handler.js","sources":["../../../lib/contracts/handlers/puffer-depositor-handler.ts"],"sourcesContent":["import {\n Address,\n GetContractReturnType,\n PublicClient,\n WalletClient,\n getContract,\n} from 'viem';\nimport { Chain, VIEM_CHAINS, ViemChain } from '../../chains/constants';\nimport {
|
|
1
|
+
{"version":3,"file":"puffer-depositor-handler.js","sources":["../../../lib/contracts/handlers/puffer-depositor-handler.ts"],"sourcesContent":["import {\n Address,\n GetContractReturnType,\n PublicClient,\n WalletClient,\n getContract,\n} from 'viem';\nimport { Chain, VIEM_CHAINS, ViemChain } from '../../chains/constants';\nimport { CONTRACT_ADDRESSES } from '../addresses';\nimport { ERC20PermitHandler } from './erc20-permit-handler';\nimport { Token } from '../tokens';\nimport { PufferDepositor } from '../abis/mainnet/PufferDepositor';\n\n/**\n * Handler for the `PufferDepositor` contract exposing methods to\n * interact with the contract.\n */\nexport class PufferDepositorHandler {\n private viemChain: ViemChain;\n private erc20PermitHandler: ERC20PermitHandler;\n\n /**\n * Create the handler for the `PufferDepositor` contract exposing\n * methods to interact with the contract.\n *\n * @param chain Chain to use for the client.\n * @param walletClient The wallet client to use for wallet\n * interactions.\n * @param publicClient The public client to use for public\n * interactions.\n */\n constructor(\n private chain: Chain,\n private walletClient: WalletClient,\n private publicClient: PublicClient,\n ) {\n this.viemChain = VIEM_CHAINS[chain];\n this.erc20PermitHandler = new ERC20PermitHandler(\n chain,\n walletClient,\n publicClient,\n );\n }\n\n /**\n * Get the contract. This is a method because the typings are complex\n * and lost when trying to make it a member.\n *\n * @returns The viem contract.\n */\n public getContract() {\n const address = CONTRACT_ADDRESSES[this.chain].PufferDepositor as Address;\n const abi = PufferDepositor;\n const client = { public: this.publicClient, wallet: this.walletClient };\n\n return getContract({ address, abi, client }) as GetContractReturnType<\n typeof abi,\n typeof client,\n Address\n >;\n }\n\n /**\n * Deposit stETH in exchange for pufETH. This doesn't make the\n * transaction but returns two methods namely `transact` and\n * `estimate`.\n *\n * @param walletAddress Wallet address to get the stETH from.\n * @param value Value in wei of the stETH to deposit.\n * @returns `transact: () => Promise<Address>` - Used to make the\n * transaction.\n *\n * `estimate: () => Promise<bigint>` - Gas estimate of the\n * transaction.\n */\n public async depositStETH(walletAddress: Address, value: bigint) {\n const { r, s, v, yParity, deadline } = await this.erc20PermitHandler\n .withToken(Token.stETH)\n .getPermitSignature(\n walletAddress,\n CONTRACT_ADDRESSES[this.chain].PufferDepositor as Address,\n value,\n );\n /* istanbul ignore next */\n const permitData = {\n r,\n s,\n v: Number(v ?? yParity),\n deadline,\n amount: value,\n };\n\n const transact = async () =>\n await this.getContract().write.depositStETH([permitData, walletAddress], {\n account: walletAddress,\n chain: this.viemChain,\n });\n const estimate = async () =>\n await this.getContract().estimateGas.depositStETH(\n [permitData, walletAddress],\n { account: walletAddress },\n );\n\n return { transact, estimate };\n }\n\n /**\n * Deposit wstETH in exchange for pufETH. This doesn't make the\n * transaction but returns two methods namely `transact` and\n * `estimate`.\n *\n * @param walletAddress Wallet address to get the stETH from.\n * @param value Value in wei of the wstETH to deposit.\n * @returns `transact: () => Promise<Address>` - Used to make the\n * transaction.\n *\n * `estimate: () => Promise<bigint>` - Gas estimate of the\n * transaction.\n */\n public async depositWstETH(walletAddress: Address, value: bigint) {\n const { r, s, v, yParity, deadline } = await this.erc20PermitHandler\n .withToken(Token.wstETH)\n .getPermitSignature(\n walletAddress,\n CONTRACT_ADDRESSES[this.chain].PufferDepositor as Address,\n value,\n );\n /* istanbul ignore next */\n const permitData = {\n r,\n s,\n v: Number(v ?? yParity),\n deadline,\n amount: value,\n };\n\n const transact = async () =>\n await this.getContract().write.depositWstETH(\n [permitData, walletAddress],\n {\n account: walletAddress,\n chain: this.viemChain,\n },\n );\n const estimate = async () =>\n await this.getContract().estimateGas.depositWstETH(\n [permitData, walletAddress],\n { account: walletAddress },\n );\n\n return { transact, estimate };\n }\n}\n"],"names":["PufferDepositorHandler","chain","walletClient","publicClient","__publicField","VIEM_CHAINS","ERC20PermitHandler","address","CONTRACT_ADDRESSES","abi","PufferDepositor","client","getContract","walletAddress","value","r","s","v","yParity","deadline","Token","permitData"],"mappings":";;;;;;;;;AAiBO,MAAMA,EAAuB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAclC,YACUC,GACAC,GACAC,GACR;AAjBM,IAAAC,EAAA;AACA,IAAAA,EAAA;AAaE,SAAA,QAAAH,GACA,KAAA,eAAAC,GACA,KAAA,eAAAC,GAEH,KAAA,YAAYE,EAAYJ,CAAK,GAClC,KAAK,qBAAqB,IAAIK;AAAA,MAC5BL;AAAA,MACAC;AAAA,MACAC;AAAA,IACF;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASK,cAAc;AACnB,UAAMI,IAAUC,EAAmB,KAAK,KAAK,EAAE,iBACzCC,IAAMC,GACNC,IAAS,EAAE,QAAQ,KAAK,cAAc,QAAQ,KAAK,aAAa;AAEtE,WAAOC,EAAY,EAAE,SAAAL,GAAS,KAAAE,GAAK,QAAAE,GAAQ;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAoB7C,MAAa,aAAaE,GAAwBC,GAAe;AAC/D,UAAM,EAAE,GAAAC,GAAG,GAAAC,GAAG,GAAAC,GAAG,SAAAC,GAAS,UAAAC,EAAA,IAAa,MAAM,KAAK,mBAC/C,UAAUC,EAAM,KAAK,EACrB;AAAA,MACCP;AAAA,MACAL,EAAmB,KAAK,KAAK,EAAE;AAAA,MAC/BM;AAAA,IACF,GAEIO,IAAa;AAAA,MACjB,GAAAN;AAAA,MACA,GAAAC;AAAA,MACA,GAAG,OAAOC,KAAKC,CAAO;AAAA,MACtB,UAAAC;AAAA,MACA,QAAQL;AAAA,IACV;AAaO,WAAA,EAAE,UAXQ,YACf,MAAM,KAAK,YAAA,EAAc,MAAM,aAAa,CAACO,GAAYR,CAAa,GAAG;AAAA,MACvE,SAASA;AAAA,MACT,OAAO,KAAK;AAAA,IAAA,CACb,GAOgB,UANF,YACf,MAAM,KAAK,cAAc,YAAY;AAAA,MACnC,CAACQ,GAAYR,CAAa;AAAA,MAC1B,EAAE,SAASA,EAAc;AAAA,IAC3B,EAE0B;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAgB9B,MAAa,cAAcA,GAAwBC,GAAe;AAChE,UAAM,EAAE,GAAAC,GAAG,GAAAC,GAAG,GAAAC,GAAG,SAAAC,GAAS,UAAAC,EAAA,IAAa,MAAM,KAAK,mBAC/C,UAAUC,EAAM,MAAM,EACtB;AAAA,MACCP;AAAA,MACAL,EAAmB,KAAK,KAAK,EAAE;AAAA,MAC/BM;AAAA,IACF,GAEIO,IAAa;AAAA,MACjB,GAAAN;AAAA,MACA,GAAAC;AAAA,MACA,GAAG,OAAOC,KAAKC,CAAO;AAAA,MACtB,UAAAC;AAAA,MACA,QAAQL;AAAA,IACV;AAgBO,WAAA,EAAE,UAdQ,YACf,MAAM,KAAK,cAAc,MAAM;AAAA,MAC7B,CAACO,GAAYR,CAAa;AAAA,MAC1B;AAAA,QACE,SAASA;AAAA,QACT,OAAO,KAAK;AAAA,MAAA;AAAA,IAEhB,GAOiB,UANF,YACf,MAAM,KAAK,cAAc,YAAY;AAAA,MACnC,CAACQ,GAAYR,CAAa;AAAA,MAC1B,EAAE,SAASA,EAAc;AAAA,IAC3B,EAE0B;AAAA,EAAA;AAEhC;"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var S=Object.defineProperty;var D=(i,t,e)=>t in i?S(i,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):i[t]=e;var n=(i,t,e)=>D(i,typeof t!="symbol"?t+"":t,e);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const a=require("../../constants-
|
|
1
|
+
"use strict";var S=Object.defineProperty;var D=(i,t,e)=>t in i?S(i,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):i[t]=e;var n=(i,t,e)=>D(i,typeof t!="symbol"?t+"":t,e);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const a=require("../../constants-5WxIZnbu.cjs"),l=require("../addresses.cjs"),_=require("../tokens.cjs"),g=require("./erc20-permit-handler.cjs"),H=require("../abis/mainnet/PufferL2Depositor.cjs"),v=require("../../getContract-Bt9GsQBq.cjs");class E{constructor(t,e,r){n(this,"viemChain");n(this,"erc20PermitHandler");this.chain=t,this.walletClient=e,this.publicClient=r,this.viemChain=a.VIEM_CHAINS[t],this.erc20PermitHandler=new g.ERC20PermitHandler(t,e,r)}getContract(){const t=l.CONTRACT_ADDRESSES[this.chain].PufferL2Depositor,e=H.PufferL2Depositor,r={public:this.publicClient,wallet:this.walletClient};return v.getContract({address:t,abi:e,client:r})}async deposit(t){const{token:e,account:r,value:s,referralCode:d=0n,lockPeriod:u=0n,isPreapproved:h=!1}=t;let o={r:a.padHex("0x",{size:32}),s:a.padHex("0x",{size:32}),v:0,deadline:0n,amount:s};if(!h){const{r:m,s:p,v:C,yParity:f,deadline:P}=await this.erc20PermitHandler.withToken(e).getPermitSignature(r,l.CONTRACT_ADDRESSES[this.chain].PufferL2Depositor,s);o={r:m,s:p,v:Number(C??f),deadline:P,amount:s}}const c=[_.TOKENS_ADDRESSES[e][this.chain],r,o,d,u];return{transact:()=>this.getContract().write.deposit(c,{account:r,chain:this.viemChain}),estimate:()=>this.getContract().estimateGas.deposit(c,{account:r})}}}exports.PufferL2DepositorHandler=E;
|
|
2
2
|
//# sourceMappingURL=puffer-l2-depositor-handler.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"puffer-l2-depositor-handler.cjs","sources":["../../../lib/contracts/handlers/puffer-l2-depositor-handler.ts"],"sourcesContent":["import {\n WalletClient,\n PublicClient,\n getContract,\n Address,\n padHex,\n GetContractReturnType,\n} from 'viem';\nimport { Chain, VIEM_CHAINS, ViemChain } from '../../chains/constants';\nimport {
|
|
1
|
+
{"version":3,"file":"puffer-l2-depositor-handler.cjs","sources":["../../../lib/contracts/handlers/puffer-l2-depositor-handler.ts"],"sourcesContent":["import {\n WalletClient,\n PublicClient,\n getContract,\n Address,\n padHex,\n GetContractReturnType,\n} from 'viem';\nimport { Chain, VIEM_CHAINS, ViemChain } from '../../chains/constants';\nimport { CONTRACT_ADDRESSES } from '../addresses';\nimport { TOKENS_ADDRESSES, Token } from '../tokens';\nimport { ERC20PermitHandler } from './erc20-permit-handler';\nimport { PufferL2Depositor } from '../abis/mainnet/PufferL2Depositor';\n\nexport type L2DepositParams = {\n token: Token;\n account: Address;\n value: bigint;\n referralCode?: bigint;\n lockPeriod?: bigint;\n isPreapproved?: boolean;\n};\n\n/**\n * Handler for the `PufferL2Depositor` contract exposing methods to\n * interact with the contract.\n */\nexport class PufferL2DepositorHandler {\n private viemChain: ViemChain;\n private erc20PermitHandler: ERC20PermitHandler;\n\n /**\n * Create the handler for the `PufferL2Depositor` contract exposing\n * methods to interact with the contract.\n *\n * @param chain Chain to use for the client.\n * @param walletClient The wallet client to use for wallet\n * interactions.\n * @param publicClient The public client to use for public\n * interactions.\n */\n constructor(\n private chain: Chain,\n private walletClient: WalletClient,\n private publicClient: PublicClient,\n ) {\n this.viemChain = VIEM_CHAINS[chain];\n this.erc20PermitHandler = new ERC20PermitHandler(\n chain,\n walletClient,\n publicClient,\n );\n }\n\n /**\n * Get the contract. This is a method because the typings are complex\n * and lost when trying to make it a member.\n *\n * @returns The viem contract.\n */\n public getContract() {\n const address = CONTRACT_ADDRESSES[this.chain].PufferL2Depositor as Address;\n const abi = PufferL2Depositor;\n const client = { public: this.publicClient, wallet: this.walletClient };\n\n return getContract({ address, abi, client }) as GetContractReturnType<\n typeof abi,\n typeof client,\n Address\n >;\n }\n\n /**\n * Deposit the given token in exchange for the wrapped PufToken. This\n * doesn't make the transaction but returns two methods namely\n * `transact` and `estimate`.\n *\n * Note that not all token contracts support permit signatures (e.g.\n * USDC). If a token's contract doesn't support permit signatures, use\n * `Token.approve()` and be sure to set the option `isPreapproved` to\n * `true`.\n *\n * @param depositParams.token Token to deposit.\n * @param depositParams.account Wallet address to take the token from.\n * @param depositParams.value Value in wei of the token to deposit.\n * @param depositParams.referralCode Referral code for the deposit.\n * @param depositParams.lockPeriod The period for the deposit in\n * seconds.\n * @param depositParams.isPreapproved Whether the token is\n * pre-approved or needs a permit.\n * @returns `transact: () => Promise<Address>` - Used to make the\n * transaction.\n *\n * `estimate: () => Promise<bigint>` - Gas estimate of the\n * transaction.\n */\n public async deposit(depositParams: L2DepositParams) {\n const {\n token,\n account,\n value,\n referralCode = 0n,\n lockPeriod = 0n,\n isPreapproved = false,\n } = depositParams;\n\n // Only `amount` is needed if `Token.approve()` is already called.\n // So using mock values for other properties.\n let permitData = {\n r: padHex('0x', { size: 32 }),\n s: padHex('0x', { size: 32 }),\n v: 0,\n deadline: 0n,\n amount: value,\n };\n\n if (!isPreapproved) {\n const { r, s, v, yParity, deadline } = await this.erc20PermitHandler\n .withToken(token)\n .getPermitSignature(\n account,\n CONTRACT_ADDRESSES[this.chain].PufferL2Depositor as Address,\n value,\n );\n /* istanbul ignore next */\n permitData = {\n r,\n s,\n v: Number(v ?? yParity),\n deadline,\n amount: value,\n };\n }\n\n const depositArgs = <const>[\n TOKENS_ADDRESSES[token][this.chain],\n account,\n permitData,\n referralCode,\n lockPeriod,\n ];\n\n const transact = () =>\n this.getContract().write.deposit(depositArgs, {\n account,\n chain: this.viemChain,\n });\n const estimate = () =>\n this.getContract().estimateGas.deposit(depositArgs, {\n account,\n });\n\n return { transact, estimate };\n }\n}\n"],"names":["PufferL2DepositorHandler","chain","walletClient","publicClient","__publicField","VIEM_CHAINS","ERC20PermitHandler","address","CONTRACT_ADDRESSES","abi","PufferL2Depositor","client","getContract","depositParams","token","account","value","referralCode","lockPeriod","isPreapproved","permitData","padHex","r","s","v","yParity","deadline","depositArgs","TOKENS_ADDRESSES"],"mappings":"oeA2BO,MAAMA,CAAyB,CAcpC,YACUC,EACAC,EACAC,EACR,CAjBMC,EAAA,kBACAA,EAAA,2BAaE,KAAA,MAAAH,EACA,KAAA,aAAAC,EACA,KAAA,aAAAC,EAEH,KAAA,UAAYE,cAAYJ,CAAK,EAClC,KAAK,mBAAqB,IAAIK,EAAA,mBAC5BL,EACAC,EACAC,CACF,CAAA,CASK,aAAc,CACnB,MAAMI,EAAUC,EAAA,mBAAmB,KAAK,KAAK,EAAE,kBACzCC,EAAMC,EAAA,kBACNC,EAAS,CAAE,OAAQ,KAAK,aAAc,OAAQ,KAAK,YAAa,EAEtE,OAAOC,EAAY,YAAA,CAAE,QAAAL,EAAS,IAAAE,EAAK,OAAAE,EAAQ,CAAA,CA+B7C,MAAa,QAAQE,EAAgC,CAC7C,KAAA,CACJ,MAAAC,EACA,QAAAC,EACA,MAAAC,EACA,aAAAC,EAAe,GACf,WAAAC,EAAa,GACb,cAAAC,EAAgB,EAAA,EACdN,EAIJ,IAAIO,EAAa,CACf,EAAGC,EAAAA,OAAO,KAAM,CAAE,KAAM,GAAI,EAC5B,EAAGA,EAAAA,OAAO,KAAM,CAAE,KAAM,GAAI,EAC5B,EAAG,EACH,SAAU,GACV,OAAQL,CACV,EAEA,GAAI,CAACG,EAAe,CAClB,KAAM,CAAE,EAAAG,EAAG,EAAAC,EAAG,EAAAC,EAAG,QAAAC,EAAS,SAAAC,GAAa,MAAM,KAAK,mBAC/C,UAAUZ,CAAK,EACf,mBACCC,EACAP,qBAAmB,KAAK,KAAK,EAAE,kBAC/BQ,CACF,EAEWI,EAAA,CACX,EAAAE,EACA,EAAAC,EACA,EAAG,OAAOC,GAAKC,CAAO,EACtB,SAAAC,EACA,OAAQV,CACV,CAAA,CAGF,MAAMW,EAAqB,CACzBC,EAAAA,iBAAiBd,CAAK,EAAE,KAAK,KAAK,EAClCC,EACAK,EACAH,EACAC,CACF,EAYO,MAAA,CAAE,SAVQ,IACf,KAAK,YAAc,EAAA,MAAM,QAAQS,EAAa,CAC5C,QAAAZ,EACA,MAAO,KAAK,SAAA,CACb,EAMgB,SALF,IACf,KAAK,YAAc,EAAA,YAAY,QAAQY,EAAa,CAClD,QAAAZ,CAAA,CACD,CAEyB,CAAA,CAEhC"}
|
|
@@ -0,0 +1,471 @@
|
|
|
1
|
+
import { WalletClient, PublicClient, Address } from 'viem';
|
|
2
|
+
import { Chain, ViemChain } from '../../chains/constants';
|
|
3
|
+
import { Token } from '../tokens';
|
|
4
|
+
export type L2DepositParams = {
|
|
5
|
+
token: Token;
|
|
6
|
+
account: Address;
|
|
7
|
+
value: bigint;
|
|
8
|
+
referralCode?: bigint;
|
|
9
|
+
lockPeriod?: bigint;
|
|
10
|
+
isPreapproved?: boolean;
|
|
11
|
+
};
|
|
12
|
+
/**
|
|
13
|
+
* Handler for the `PufferL2Depositor` contract exposing methods to
|
|
14
|
+
* interact with the contract.
|
|
15
|
+
*/
|
|
16
|
+
export declare class PufferL2DepositorHandler {
|
|
17
|
+
private chain;
|
|
18
|
+
private walletClient;
|
|
19
|
+
private publicClient;
|
|
20
|
+
private viemChain;
|
|
21
|
+
private erc20PermitHandler;
|
|
22
|
+
/**
|
|
23
|
+
* Create the handler for the `PufferL2Depositor` contract exposing
|
|
24
|
+
* methods to interact with the contract.
|
|
25
|
+
*
|
|
26
|
+
* @param chain Chain to use for the client.
|
|
27
|
+
* @param walletClient The wallet client to use for wallet
|
|
28
|
+
* interactions.
|
|
29
|
+
* @param publicClient The public client to use for public
|
|
30
|
+
* interactions.
|
|
31
|
+
*/
|
|
32
|
+
constructor(chain: Chain, walletClient: WalletClient, publicClient: PublicClient);
|
|
33
|
+
/**
|
|
34
|
+
* Get the contract. This is a method because the typings are complex
|
|
35
|
+
* and lost when trying to make it a member.
|
|
36
|
+
*
|
|
37
|
+
* @returns The viem contract.
|
|
38
|
+
*/
|
|
39
|
+
getContract(): {
|
|
40
|
+
estimateGas: {
|
|
41
|
+
deposit: (args: readonly [`0x${string}`, `0x${string}`, {
|
|
42
|
+
deadline: bigint;
|
|
43
|
+
amount: bigint;
|
|
44
|
+
v: number;
|
|
45
|
+
r: `0x${string}`;
|
|
46
|
+
s: `0x${string}`;
|
|
47
|
+
}, bigint, bigint], options: import('viem').Prettify<import('viem').UnionOmit<import('viem').EstimateContractGasParameters<readonly [{
|
|
48
|
+
readonly inputs: readonly [{
|
|
49
|
+
readonly internalType: "address";
|
|
50
|
+
readonly name: "token";
|
|
51
|
+
readonly type: "address";
|
|
52
|
+
}, {
|
|
53
|
+
readonly internalType: "address";
|
|
54
|
+
readonly name: "account";
|
|
55
|
+
readonly type: "address";
|
|
56
|
+
}, {
|
|
57
|
+
readonly components: readonly [{
|
|
58
|
+
readonly internalType: "uint256";
|
|
59
|
+
readonly name: "deadline";
|
|
60
|
+
readonly type: "uint256";
|
|
61
|
+
}, {
|
|
62
|
+
readonly internalType: "uint256";
|
|
63
|
+
readonly name: "amount";
|
|
64
|
+
readonly type: "uint256";
|
|
65
|
+
}, {
|
|
66
|
+
readonly internalType: "uint8";
|
|
67
|
+
readonly name: "v";
|
|
68
|
+
readonly type: "uint8";
|
|
69
|
+
}, {
|
|
70
|
+
readonly internalType: "bytes32";
|
|
71
|
+
readonly name: "r";
|
|
72
|
+
readonly type: "bytes32";
|
|
73
|
+
}, {
|
|
74
|
+
readonly internalType: "bytes32";
|
|
75
|
+
readonly name: "s";
|
|
76
|
+
readonly type: "bytes32";
|
|
77
|
+
}];
|
|
78
|
+
readonly internalType: "struct Permit";
|
|
79
|
+
readonly name: "permitData";
|
|
80
|
+
readonly type: "tuple";
|
|
81
|
+
}, {
|
|
82
|
+
readonly internalType: "uint256";
|
|
83
|
+
readonly name: "referralCode";
|
|
84
|
+
readonly type: "uint256";
|
|
85
|
+
}, {
|
|
86
|
+
readonly internalType: "uint128";
|
|
87
|
+
readonly name: "lockPeriod";
|
|
88
|
+
readonly type: "uint128";
|
|
89
|
+
}];
|
|
90
|
+
readonly name: "deposit";
|
|
91
|
+
readonly outputs: readonly [];
|
|
92
|
+
readonly stateMutability: "nonpayable";
|
|
93
|
+
readonly type: "function";
|
|
94
|
+
}], "deposit", readonly [`0x${string}`, `0x${string}`, {
|
|
95
|
+
deadline: bigint;
|
|
96
|
+
amount: bigint;
|
|
97
|
+
v: number;
|
|
98
|
+
r: `0x${string}`;
|
|
99
|
+
s: `0x${string}`;
|
|
100
|
+
}, bigint, bigint], ViemChain | undefined>, "address" | "abi" | "args" | "functionName">>) => Promise<import('viem').EstimateContractGasReturnType>;
|
|
101
|
+
} & {
|
|
102
|
+
deposit: (args: readonly [`0x${string}`, `0x${string}`, {
|
|
103
|
+
deadline: bigint;
|
|
104
|
+
amount: bigint;
|
|
105
|
+
v: number;
|
|
106
|
+
r: `0x${string}`;
|
|
107
|
+
s: `0x${string}`;
|
|
108
|
+
}, bigint, bigint], options: import('viem').Prettify<import('viem').UnionOmit<import('viem').EstimateContractGasParameters<readonly [{
|
|
109
|
+
readonly inputs: readonly [{
|
|
110
|
+
readonly internalType: "address";
|
|
111
|
+
readonly name: "token";
|
|
112
|
+
readonly type: "address";
|
|
113
|
+
}, {
|
|
114
|
+
readonly internalType: "address";
|
|
115
|
+
readonly name: "account";
|
|
116
|
+
readonly type: "address";
|
|
117
|
+
}, {
|
|
118
|
+
readonly components: readonly [{
|
|
119
|
+
readonly internalType: "uint256";
|
|
120
|
+
readonly name: "deadline";
|
|
121
|
+
readonly type: "uint256";
|
|
122
|
+
}, {
|
|
123
|
+
readonly internalType: "uint256";
|
|
124
|
+
readonly name: "amount";
|
|
125
|
+
readonly type: "uint256";
|
|
126
|
+
}, {
|
|
127
|
+
readonly internalType: "uint8";
|
|
128
|
+
readonly name: "v";
|
|
129
|
+
readonly type: "uint8";
|
|
130
|
+
}, {
|
|
131
|
+
readonly internalType: "bytes32";
|
|
132
|
+
readonly name: "r";
|
|
133
|
+
readonly type: "bytes32";
|
|
134
|
+
}, {
|
|
135
|
+
readonly internalType: "bytes32";
|
|
136
|
+
readonly name: "s";
|
|
137
|
+
readonly type: "bytes32";
|
|
138
|
+
}];
|
|
139
|
+
readonly internalType: "struct Permit";
|
|
140
|
+
readonly name: "permitData";
|
|
141
|
+
readonly type: "tuple";
|
|
142
|
+
}, {
|
|
143
|
+
readonly internalType: "uint256";
|
|
144
|
+
readonly name: "referralCode";
|
|
145
|
+
readonly type: "uint256";
|
|
146
|
+
}, {
|
|
147
|
+
readonly internalType: "uint128";
|
|
148
|
+
readonly name: "lockPeriod";
|
|
149
|
+
readonly type: "uint128";
|
|
150
|
+
}];
|
|
151
|
+
readonly name: "deposit";
|
|
152
|
+
readonly outputs: readonly [];
|
|
153
|
+
readonly stateMutability: "nonpayable";
|
|
154
|
+
readonly type: "function";
|
|
155
|
+
}], "deposit", readonly [`0x${string}`, `0x${string}`, {
|
|
156
|
+
deadline: bigint;
|
|
157
|
+
amount: bigint;
|
|
158
|
+
v: number;
|
|
159
|
+
r: `0x${string}`;
|
|
160
|
+
s: `0x${string}`;
|
|
161
|
+
}, bigint, bigint], ViemChain | undefined>, "address" | "abi" | "args" | "functionName">>) => Promise<import('viem').EstimateContractGasReturnType>;
|
|
162
|
+
};
|
|
163
|
+
simulate: {
|
|
164
|
+
deposit: <chainOverride extends ViemChain | undefined = undefined, accountOverride extends import('viem').Account | Address | undefined = undefined>(args: readonly [`0x${string}`, `0x${string}`, {
|
|
165
|
+
deadline: bigint;
|
|
166
|
+
amount: bigint;
|
|
167
|
+
v: number;
|
|
168
|
+
r: `0x${string}`;
|
|
169
|
+
s: `0x${string}`;
|
|
170
|
+
}, bigint, bigint], options?: Omit<import('viem').SimulateContractParameters<readonly [{
|
|
171
|
+
readonly inputs: readonly [{
|
|
172
|
+
readonly internalType: "address";
|
|
173
|
+
readonly name: "token";
|
|
174
|
+
readonly type: "address";
|
|
175
|
+
}, {
|
|
176
|
+
readonly internalType: "address";
|
|
177
|
+
readonly name: "account";
|
|
178
|
+
readonly type: "address";
|
|
179
|
+
}, {
|
|
180
|
+
readonly components: readonly [{
|
|
181
|
+
readonly internalType: "uint256";
|
|
182
|
+
readonly name: "deadline";
|
|
183
|
+
readonly type: "uint256";
|
|
184
|
+
}, {
|
|
185
|
+
readonly internalType: "uint256";
|
|
186
|
+
readonly name: "amount";
|
|
187
|
+
readonly type: "uint256";
|
|
188
|
+
}, {
|
|
189
|
+
readonly internalType: "uint8";
|
|
190
|
+
readonly name: "v";
|
|
191
|
+
readonly type: "uint8";
|
|
192
|
+
}, {
|
|
193
|
+
readonly internalType: "bytes32";
|
|
194
|
+
readonly name: "r";
|
|
195
|
+
readonly type: "bytes32";
|
|
196
|
+
}, {
|
|
197
|
+
readonly internalType: "bytes32";
|
|
198
|
+
readonly name: "s";
|
|
199
|
+
readonly type: "bytes32";
|
|
200
|
+
}];
|
|
201
|
+
readonly internalType: "struct Permit";
|
|
202
|
+
readonly name: "permitData";
|
|
203
|
+
readonly type: "tuple";
|
|
204
|
+
}, {
|
|
205
|
+
readonly internalType: "uint256";
|
|
206
|
+
readonly name: "referralCode";
|
|
207
|
+
readonly type: "uint256";
|
|
208
|
+
}, {
|
|
209
|
+
readonly internalType: "uint128";
|
|
210
|
+
readonly name: "lockPeriod";
|
|
211
|
+
readonly type: "uint128";
|
|
212
|
+
}];
|
|
213
|
+
readonly name: "deposit";
|
|
214
|
+
readonly outputs: readonly [];
|
|
215
|
+
readonly stateMutability: "nonpayable";
|
|
216
|
+
readonly type: "function";
|
|
217
|
+
}], "deposit", readonly [`0x${string}`, `0x${string}`, {
|
|
218
|
+
deadline: bigint;
|
|
219
|
+
amount: bigint;
|
|
220
|
+
v: number;
|
|
221
|
+
r: `0x${string}`;
|
|
222
|
+
s: `0x${string}`;
|
|
223
|
+
}, bigint, bigint], ViemChain | undefined, chainOverride, accountOverride>, "address" | "abi" | "args" | "functionName"> | undefined) => Promise<import('viem').SimulateContractReturnType<readonly [{
|
|
224
|
+
readonly inputs: readonly [{
|
|
225
|
+
readonly internalType: "address";
|
|
226
|
+
readonly name: "token";
|
|
227
|
+
readonly type: "address";
|
|
228
|
+
}, {
|
|
229
|
+
readonly internalType: "address";
|
|
230
|
+
readonly name: "account";
|
|
231
|
+
readonly type: "address";
|
|
232
|
+
}, {
|
|
233
|
+
readonly components: readonly [{
|
|
234
|
+
readonly internalType: "uint256";
|
|
235
|
+
readonly name: "deadline";
|
|
236
|
+
readonly type: "uint256";
|
|
237
|
+
}, {
|
|
238
|
+
readonly internalType: "uint256";
|
|
239
|
+
readonly name: "amount";
|
|
240
|
+
readonly type: "uint256";
|
|
241
|
+
}, {
|
|
242
|
+
readonly internalType: "uint8";
|
|
243
|
+
readonly name: "v";
|
|
244
|
+
readonly type: "uint8";
|
|
245
|
+
}, {
|
|
246
|
+
readonly internalType: "bytes32";
|
|
247
|
+
readonly name: "r";
|
|
248
|
+
readonly type: "bytes32";
|
|
249
|
+
}, {
|
|
250
|
+
readonly internalType: "bytes32";
|
|
251
|
+
readonly name: "s";
|
|
252
|
+
readonly type: "bytes32";
|
|
253
|
+
}];
|
|
254
|
+
readonly internalType: "struct Permit";
|
|
255
|
+
readonly name: "permitData";
|
|
256
|
+
readonly type: "tuple";
|
|
257
|
+
}, {
|
|
258
|
+
readonly internalType: "uint256";
|
|
259
|
+
readonly name: "referralCode";
|
|
260
|
+
readonly type: "uint256";
|
|
261
|
+
}, {
|
|
262
|
+
readonly internalType: "uint128";
|
|
263
|
+
readonly name: "lockPeriod";
|
|
264
|
+
readonly type: "uint128";
|
|
265
|
+
}];
|
|
266
|
+
readonly name: "deposit";
|
|
267
|
+
readonly outputs: readonly [];
|
|
268
|
+
readonly stateMutability: "nonpayable";
|
|
269
|
+
readonly type: "function";
|
|
270
|
+
}], "deposit", readonly [`0x${string}`, `0x${string}`, {
|
|
271
|
+
deadline: bigint;
|
|
272
|
+
amount: bigint;
|
|
273
|
+
v: number;
|
|
274
|
+
r: `0x${string}`;
|
|
275
|
+
s: `0x${string}`;
|
|
276
|
+
}, bigint, bigint], ViemChain | undefined, import('viem').Account | undefined, chainOverride, accountOverride>>;
|
|
277
|
+
};
|
|
278
|
+
write: {
|
|
279
|
+
deposit: <chainOverride extends ViemChain | undefined, options extends import('viem').UnionOmit<import('viem').WriteContractParameters<readonly [{
|
|
280
|
+
readonly inputs: readonly [{
|
|
281
|
+
readonly internalType: "address";
|
|
282
|
+
readonly name: "token";
|
|
283
|
+
readonly type: "address";
|
|
284
|
+
}, {
|
|
285
|
+
readonly internalType: "address";
|
|
286
|
+
readonly name: "account";
|
|
287
|
+
readonly type: "address";
|
|
288
|
+
}, {
|
|
289
|
+
readonly components: readonly [{
|
|
290
|
+
readonly internalType: "uint256";
|
|
291
|
+
readonly name: "deadline";
|
|
292
|
+
readonly type: "uint256";
|
|
293
|
+
}, {
|
|
294
|
+
readonly internalType: "uint256";
|
|
295
|
+
readonly name: "amount";
|
|
296
|
+
readonly type: "uint256";
|
|
297
|
+
}, {
|
|
298
|
+
readonly internalType: "uint8";
|
|
299
|
+
readonly name: "v";
|
|
300
|
+
readonly type: "uint8";
|
|
301
|
+
}, {
|
|
302
|
+
readonly internalType: "bytes32";
|
|
303
|
+
readonly name: "r";
|
|
304
|
+
readonly type: "bytes32";
|
|
305
|
+
}, {
|
|
306
|
+
readonly internalType: "bytes32";
|
|
307
|
+
readonly name: "s";
|
|
308
|
+
readonly type: "bytes32";
|
|
309
|
+
}];
|
|
310
|
+
readonly internalType: "struct Permit";
|
|
311
|
+
readonly name: "permitData";
|
|
312
|
+
readonly type: "tuple";
|
|
313
|
+
}, {
|
|
314
|
+
readonly internalType: "uint256";
|
|
315
|
+
readonly name: "referralCode";
|
|
316
|
+
readonly type: "uint256";
|
|
317
|
+
}, {
|
|
318
|
+
readonly internalType: "uint128";
|
|
319
|
+
readonly name: "lockPeriod";
|
|
320
|
+
readonly type: "uint128";
|
|
321
|
+
}];
|
|
322
|
+
readonly name: "deposit";
|
|
323
|
+
readonly outputs: readonly [];
|
|
324
|
+
readonly stateMutability: "nonpayable";
|
|
325
|
+
readonly type: "function";
|
|
326
|
+
}], "deposit", readonly [`0x${string}`, `0x${string}`, {
|
|
327
|
+
deadline: bigint;
|
|
328
|
+
amount: bigint;
|
|
329
|
+
v: number;
|
|
330
|
+
r: `0x${string}`;
|
|
331
|
+
s: `0x${string}`;
|
|
332
|
+
}, bigint, bigint], ViemChain | undefined, import('viem').Account | undefined, chainOverride>, "address" | "abi" | "args" | "functionName"> extends infer T ? { [K in keyof T]: import('viem').UnionOmit<import('viem').WriteContractParameters<readonly [{
|
|
333
|
+
readonly inputs: readonly [{
|
|
334
|
+
readonly internalType: "address";
|
|
335
|
+
readonly name: "token";
|
|
336
|
+
readonly type: "address";
|
|
337
|
+
}, {
|
|
338
|
+
readonly internalType: "address";
|
|
339
|
+
readonly name: "account";
|
|
340
|
+
readonly type: "address";
|
|
341
|
+
}, {
|
|
342
|
+
readonly components: readonly [{
|
|
343
|
+
readonly internalType: "uint256";
|
|
344
|
+
readonly name: "deadline";
|
|
345
|
+
readonly type: "uint256";
|
|
346
|
+
}, {
|
|
347
|
+
readonly internalType: "uint256";
|
|
348
|
+
readonly name: "amount";
|
|
349
|
+
readonly type: "uint256";
|
|
350
|
+
}, {
|
|
351
|
+
readonly internalType: "uint8";
|
|
352
|
+
readonly name: "v";
|
|
353
|
+
readonly type: "uint8";
|
|
354
|
+
}, {
|
|
355
|
+
readonly internalType: "bytes32";
|
|
356
|
+
readonly name: "r";
|
|
357
|
+
readonly type: "bytes32";
|
|
358
|
+
}, {
|
|
359
|
+
readonly internalType: "bytes32";
|
|
360
|
+
readonly name: "s";
|
|
361
|
+
readonly type: "bytes32";
|
|
362
|
+
}];
|
|
363
|
+
readonly internalType: "struct Permit";
|
|
364
|
+
readonly name: "permitData";
|
|
365
|
+
readonly type: "tuple";
|
|
366
|
+
}, {
|
|
367
|
+
readonly internalType: "uint256";
|
|
368
|
+
readonly name: "referralCode";
|
|
369
|
+
readonly type: "uint256";
|
|
370
|
+
}, {
|
|
371
|
+
readonly internalType: "uint128";
|
|
372
|
+
readonly name: "lockPeriod";
|
|
373
|
+
readonly type: "uint128";
|
|
374
|
+
}];
|
|
375
|
+
readonly name: "deposit";
|
|
376
|
+
readonly outputs: readonly [];
|
|
377
|
+
readonly stateMutability: "nonpayable";
|
|
378
|
+
readonly type: "function";
|
|
379
|
+
}], "deposit", readonly [`0x${string}`, `0x${string}`, {
|
|
380
|
+
deadline: bigint;
|
|
381
|
+
amount: bigint;
|
|
382
|
+
v: number;
|
|
383
|
+
r: `0x${string}`;
|
|
384
|
+
s: `0x${string}`;
|
|
385
|
+
}, bigint, bigint], ViemChain | undefined, import('viem').Account | undefined, chainOverride>, "address" | "abi" | "args" | "functionName">[K]; } : never>(args: readonly [`0x${string}`, `0x${string}`, {
|
|
386
|
+
deadline: bigint;
|
|
387
|
+
amount: bigint;
|
|
388
|
+
v: number;
|
|
389
|
+
r: `0x${string}`;
|
|
390
|
+
s: `0x${string}`;
|
|
391
|
+
}, bigint, bigint], options: options) => Promise<import('viem').WriteContractReturnType>;
|
|
392
|
+
};
|
|
393
|
+
address: `0x${string}`;
|
|
394
|
+
abi: readonly [{
|
|
395
|
+
readonly inputs: readonly [{
|
|
396
|
+
readonly internalType: "address";
|
|
397
|
+
readonly name: "token";
|
|
398
|
+
readonly type: "address";
|
|
399
|
+
}, {
|
|
400
|
+
readonly internalType: "address";
|
|
401
|
+
readonly name: "account";
|
|
402
|
+
readonly type: "address";
|
|
403
|
+
}, {
|
|
404
|
+
readonly components: readonly [{
|
|
405
|
+
readonly internalType: "uint256";
|
|
406
|
+
readonly name: "deadline";
|
|
407
|
+
readonly type: "uint256";
|
|
408
|
+
}, {
|
|
409
|
+
readonly internalType: "uint256";
|
|
410
|
+
readonly name: "amount";
|
|
411
|
+
readonly type: "uint256";
|
|
412
|
+
}, {
|
|
413
|
+
readonly internalType: "uint8";
|
|
414
|
+
readonly name: "v";
|
|
415
|
+
readonly type: "uint8";
|
|
416
|
+
}, {
|
|
417
|
+
readonly internalType: "bytes32";
|
|
418
|
+
readonly name: "r";
|
|
419
|
+
readonly type: "bytes32";
|
|
420
|
+
}, {
|
|
421
|
+
readonly internalType: "bytes32";
|
|
422
|
+
readonly name: "s";
|
|
423
|
+
readonly type: "bytes32";
|
|
424
|
+
}];
|
|
425
|
+
readonly internalType: "struct Permit";
|
|
426
|
+
readonly name: "permitData";
|
|
427
|
+
readonly type: "tuple";
|
|
428
|
+
}, {
|
|
429
|
+
readonly internalType: "uint256";
|
|
430
|
+
readonly name: "referralCode";
|
|
431
|
+
readonly type: "uint256";
|
|
432
|
+
}, {
|
|
433
|
+
readonly internalType: "uint128";
|
|
434
|
+
readonly name: "lockPeriod";
|
|
435
|
+
readonly type: "uint128";
|
|
436
|
+
}];
|
|
437
|
+
readonly name: "deposit";
|
|
438
|
+
readonly outputs: readonly [];
|
|
439
|
+
readonly stateMutability: "nonpayable";
|
|
440
|
+
readonly type: "function";
|
|
441
|
+
}];
|
|
442
|
+
};
|
|
443
|
+
/**
|
|
444
|
+
* Deposit the given token in exchange for the wrapped PufToken. This
|
|
445
|
+
* doesn't make the transaction but returns two methods namely
|
|
446
|
+
* `transact` and `estimate`.
|
|
447
|
+
*
|
|
448
|
+
* Note that not all token contracts support permit signatures (e.g.
|
|
449
|
+
* USDC). If a token's contract doesn't support permit signatures, use
|
|
450
|
+
* `Token.approve()` and be sure to set the option `isPreapproved` to
|
|
451
|
+
* `true`.
|
|
452
|
+
*
|
|
453
|
+
* @param depositParams.token Token to deposit.
|
|
454
|
+
* @param depositParams.account Wallet address to take the token from.
|
|
455
|
+
* @param depositParams.value Value in wei of the token to deposit.
|
|
456
|
+
* @param depositParams.referralCode Referral code for the deposit.
|
|
457
|
+
* @param depositParams.lockPeriod The period for the deposit in
|
|
458
|
+
* seconds.
|
|
459
|
+
* @param depositParams.isPreapproved Whether the token is
|
|
460
|
+
* pre-approved or needs a permit.
|
|
461
|
+
* @returns `transact: () => Promise<Address>` - Used to make the
|
|
462
|
+
* transaction.
|
|
463
|
+
*
|
|
464
|
+
* `estimate: () => Promise<bigint>` - Gas estimate of the
|
|
465
|
+
* transaction.
|
|
466
|
+
*/
|
|
467
|
+
deposit(depositParams: L2DepositParams): Promise<{
|
|
468
|
+
transact: () => Promise<`0x${string}`>;
|
|
469
|
+
estimate: () => Promise<bigint>;
|
|
470
|
+
}>;
|
|
471
|
+
}
|