@pufferfinance/puffer-sdk 1.28.1 → 1.28.3
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 +7 -7
- package/dist/api/puffer-client-helpers.js.map +1 -1
- package/dist/api/puffer-client.cjs +1 -1
- package/dist/api/puffer-client.cjs.map +1 -1
- package/dist/api/puffer-client.js +119 -122
- package/dist/api/puffer-client.js.map +1 -1
- package/dist/ccip-78YM988s.js +150 -0
- package/dist/{ccip-C76-YhQK.js.map → ccip-78YM988s.js.map} +1 -1
- package/dist/ccip-LIGR3N1A.cjs +2 -0
- package/dist/{ccip-CEodLZ4s.cjs.map → ccip-LIGR3N1A.cjs.map} +1 -1
- package/dist/chains/constants.cjs +1 -1
- package/dist/chains/constants.js +1 -1
- package/dist/constants-6kuRTsbU.cjs +9 -0
- package/dist/{constants-CxSgz27h.cjs.map → constants-6kuRTsbU.cjs.map} +1 -1
- package/dist/{constants-C9YZ6Ewc.js → constants-CuIEh_ZS.js} +605 -656
- package/dist/{constants-C9YZ6Ewc.js.map → constants-CuIEh_ZS.js.map} +1 -1
- package/dist/contracts/abis/mainnet/Accountant.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/Accountant.js.map +1 -1
- package/dist/contracts/abis/mainnet/AtomicQueue.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/AtomicQueue.js.map +1 -1
- package/dist/contracts/abis/mainnet/BoringVault.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/BoringVault.js.map +1 -1
- package/dist/contracts/abis/mainnet/CarrotStaker.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/CarrotStaker.js.map +1 -1
- package/dist/contracts/abis/mainnet/CarrotVesting.cjs +1 -1
- package/dist/contracts/abis/mainnet/CarrotVesting.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/CarrotVesting.d.ts +84 -92
- package/dist/contracts/abis/mainnet/CarrotVesting.js +56 -62
- package/dist/contracts/abis/mainnet/CarrotVesting.js.map +1 -1
- package/dist/contracts/abis/mainnet/ConcreteMultiStrategyVault.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/ConcreteMultiStrategyVault.js.map +1 -1
- package/dist/contracts/abis/mainnet/Distributor.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/Distributor.js.map +1 -1
- package/dist/contracts/abis/mainnet/ERC20Permit.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/ERC20Permit.js.map +1 -1
- package/dist/contracts/abis/mainnet/GaugeRegistry.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/GaugeRegistry.js.map +1 -1
- package/dist/contracts/abis/mainnet/GuardianModule.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/GuardianModule.js.map +1 -1
- package/dist/contracts/abis/mainnet/InstitutionalAccessManager.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/InstitutionalAccessManager.js.map +1 -1
- package/dist/contracts/abis/mainnet/InstitutionalVault.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/InstitutionalVault.js.map +1 -1
- package/dist/contracts/abis/mainnet/L1RewardManager.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/L1RewardManager.js.map +1 -1
- package/dist/contracts/abis/mainnet/L2RewardManager.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/L2RewardManager.js.map +1 -1
- package/dist/contracts/abis/mainnet/LagoonVault.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/LagoonVault.js.map +1 -1
- package/dist/contracts/abis/mainnet/PufLocker.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/PufLocker.js.map +1 -1
- package/dist/contracts/abis/mainnet/PufferDepositor.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/PufferDepositor.js.map +1 -1
- package/dist/contracts/abis/mainnet/PufferL2Depositor.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/PufferL2Depositor.js.map +1 -1
- package/dist/contracts/abis/mainnet/PufferOracleV2.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/PufferOracleV2.js.map +1 -1
- package/dist/contracts/abis/mainnet/PufferProtocol.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/PufferProtocol.js.map +1 -1
- package/dist/contracts/abis/mainnet/PufferVaultV5.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/PufferVaultV5.js.map +1 -1
- package/dist/contracts/abis/mainnet/PufferWithdrawalManager.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/PufferWithdrawalManager.js.map +1 -1
- package/dist/contracts/abis/mainnet/Teller.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/Teller.js.map +1 -1
- package/dist/contracts/abis/mainnet/ValidatorTicket.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/ValidatorTicket.js.map +1 -1
- package/dist/contracts/abis/mainnet/mtwCARROT.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/mtwCARROT.js.map +1 -1
- package/dist/contracts/abis/mainnet/vlPUFFER.cjs.map +1 -1
- package/dist/contracts/abis/mainnet/vlPUFFER.js.map +1 -1
- package/dist/contracts/addresses.cjs +1 -1
- package/dist/contracts/addresses.cjs.map +1 -1
- package/dist/contracts/addresses.js +5 -5
- 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.cjs.map +1 -1
- package/dist/contracts/handlers/carrot-staking-handler.d.ts +96 -6599
- package/dist/contracts/handlers/carrot-staking-handler.js +13 -16
- package/dist/contracts/handlers/carrot-staking-handler.js.map +1 -1
- package/dist/contracts/handlers/carrot-vesting-handler.cjs +1 -1
- package/dist/contracts/handlers/carrot-vesting-handler.cjs.map +1 -1
- package/dist/contracts/handlers/carrot-vesting-handler.d.ts +102 -6605
- package/dist/contracts/handlers/carrot-vesting-handler.js +25 -39
- package/dist/contracts/handlers/carrot-vesting-handler.js.map +1 -1
- package/dist/contracts/handlers/concrete-vault-handler.cjs +1 -1
- package/dist/contracts/handlers/concrete-vault-handler.cjs.map +1 -1
- package/dist/contracts/handlers/concrete-vault-handler.d.ts +96 -6599
- package/dist/contracts/handlers/concrete-vault-handler.js +15 -18
- package/dist/contracts/handlers/concrete-vault-handler.js.map +1 -1
- 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 +96 -6599
- package/dist/contracts/handlers/distributor-handler.js +15 -18
- 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 +96 -6599
- package/dist/contracts/handlers/erc20-permit-handler.js +34 -38
- package/dist/contracts/handlers/erc20-permit-handler.js.map +1 -1
- package/dist/contracts/handlers/gauge-registry-handler.cjs +1 -1
- package/dist/contracts/handlers/gauge-registry-handler.cjs.map +1 -1
- package/dist/contracts/handlers/gauge-registry-handler.d.ts +96 -6599
- package/dist/contracts/handlers/gauge-registry-handler.js +11 -14
- package/dist/contracts/handlers/gauge-registry-handler.js.map +1 -1
- package/dist/contracts/handlers/guardian-module-handler.cjs +1 -1
- package/dist/contracts/handlers/guardian-module-handler.cjs.map +1 -1
- package/dist/contracts/handlers/guardian-module-handler.d.ts +96 -6599
- package/dist/contracts/handlers/guardian-module-handler.js +11 -14
- package/dist/contracts/handlers/guardian-module-handler.js.map +1 -1
- package/dist/contracts/handlers/institutional-access-manager-handler.cjs +1 -1
- package/dist/contracts/handlers/institutional-access-manager-handler.cjs.map +1 -1
- package/dist/contracts/handlers/institutional-access-manager-handler.d.ts +96 -6599
- package/dist/contracts/handlers/institutional-access-manager-handler.js +45 -50
- package/dist/contracts/handlers/institutional-access-manager-handler.js.map +1 -1
- package/dist/contracts/handlers/institutional-vault-handler.cjs +1 -1
- package/dist/contracts/handlers/institutional-vault-handler.cjs.map +1 -1
- package/dist/contracts/handlers/institutional-vault-handler.d.ts +96 -6599
- package/dist/contracts/handlers/institutional-vault-handler.js +16 -19
- package/dist/contracts/handlers/institutional-vault-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 +96 -6599
- package/dist/contracts/handlers/l1-reward-manager-handler.js +14 -17
- 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 +96 -6599
- package/dist/contracts/handlers/l2-reward-manager-handler.js +13 -16
- package/dist/contracts/handlers/l2-reward-manager-handler.js.map +1 -1
- package/dist/contracts/handlers/lagoon-vault-handler.cjs +1 -1
- package/dist/contracts/handlers/lagoon-vault-handler.cjs.map +1 -1
- package/dist/contracts/handlers/lagoon-vault-handler.d.ts +96 -6599
- package/dist/contracts/handlers/lagoon-vault-handler.js +11 -14
- package/dist/contracts/handlers/lagoon-vault-handler.js.map +1 -1
- package/dist/contracts/handlers/mtw-carrot-handler.cjs +1 -1
- package/dist/contracts/handlers/mtw-carrot-handler.cjs.map +1 -1
- package/dist/contracts/handlers/mtw-carrot-handler.d.ts +96 -6599
- package/dist/contracts/handlers/mtw-carrot-handler.js +12 -15
- package/dist/contracts/handlers/mtw-carrot-handler.js.map +1 -1
- 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 +96 -6599
- package/dist/contracts/handlers/nucleus-accountant-handler.js +13 -16
- 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.d.ts +96 -6599
- package/dist/contracts/handlers/nucleus-atomic-queue-handler.js +14 -17
- 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 +96 -6599
- package/dist/contracts/handlers/nucleus-boring-vault-handler.js +18 -21
- 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 +96 -6599
- package/dist/contracts/handlers/nucleus-teller-handler.js +35 -38
- 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 +96 -6599
- package/dist/contracts/handlers/puf-locker-handler.js +51 -54
- 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 +96 -6599
- package/dist/contracts/handlers/puffer-depositor-handler.js +28 -31
- 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 +96 -6599
- package/dist/contracts/handlers/puffer-l2-depositor-handler.js +42 -45
- package/dist/contracts/handlers/puffer-l2-depositor-handler.js.map +1 -1
- package/dist/contracts/handlers/puffer-oracle-v2-handler.cjs +1 -1
- package/dist/contracts/handlers/puffer-oracle-v2-handler.cjs.map +1 -1
- package/dist/contracts/handlers/puffer-oracle-v2-handler.d.ts +96 -6599
- package/dist/contracts/handlers/puffer-oracle-v2-handler.js +13 -16
- package/dist/contracts/handlers/puffer-oracle-v2-handler.js.map +1 -1
- package/dist/contracts/handlers/puffer-protocol-handler.cjs +1 -1
- package/dist/contracts/handlers/puffer-protocol-handler.cjs.map +1 -1
- package/dist/contracts/handlers/puffer-protocol-handler.d.ts +96 -6599
- package/dist/contracts/handlers/puffer-protocol-handler.js +12 -15
- package/dist/contracts/handlers/puffer-protocol-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 +96 -6599
- package/dist/contracts/handlers/puffer-vault-handler.js +12 -15
- 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 +96 -6599
- package/dist/contracts/handlers/puffer-withdrawal-manager-handler.js +15 -18
- package/dist/contracts/handlers/puffer-withdrawal-manager-handler.js.map +1 -1
- package/dist/contracts/handlers/validator-ticket-handler.cjs +1 -1
- package/dist/contracts/handlers/validator-ticket-handler.cjs.map +1 -1
- package/dist/contracts/handlers/validator-ticket-handler.d.ts +96 -6599
- package/dist/contracts/handlers/validator-ticket-handler.js +12 -15
- package/dist/contracts/handlers/validator-ticket-handler.js.map +1 -1
- package/dist/contracts/handlers/vl-puffer-handler.cjs +1 -1
- package/dist/contracts/handlers/vl-puffer-handler.cjs.map +1 -1
- package/dist/contracts/handlers/vl-puffer-handler.d.ts +96 -6599
- package/dist/contracts/handlers/vl-puffer-handler.js +19 -22
- package/dist/contracts/handlers/vl-puffer-handler.js.map +1 -1
- package/dist/contracts/tokens.cjs +1 -1
- package/dist/contracts/tokens.cjs.map +1 -1
- package/dist/contracts/tokens.js +1 -1
- package/dist/contracts/tokens.js.map +1 -1
- package/dist/contracts/vaults-addresses.cjs +1 -1
- package/dist/contracts/vaults-addresses.cjs.map +1 -1
- package/dist/contracts/vaults-addresses.js +1 -1
- package/dist/contracts/vaults-addresses.js.map +1 -1
- package/dist/errors/base-error.cjs.map +1 -1
- package/dist/errors/base-error.js.map +1 -1
- package/dist/{getContract-DUA3M2pm.cjs → getContract-D4_SEfqa.cjs} +2 -2
- package/dist/{getContract-DUA3M2pm.cjs.map → getContract-D4_SEfqa.cjs.map} +1 -1
- package/dist/{getContract-DEPNMZxg.js → getContract-DQN7VDBo.js} +2 -2
- package/dist/{getContract-DEPNMZxg.js.map → getContract-DQN7VDBo.js.map} +1 -1
- package/dist/http-CajzXkt4.js +4005 -0
- package/dist/http-CajzXkt4.js.map +1 -0
- package/dist/http-qhIDc8Dn.cjs +5 -0
- package/dist/http-qhIDc8Dn.cjs.map +1 -0
- package/dist/{localBatchGatewayRequest-CKLnLqib.cjs → localBatchGatewayRequest-C7zYTS2c.cjs} +2 -2
- package/dist/{localBatchGatewayRequest-CKLnLqib.cjs.map → localBatchGatewayRequest-C7zYTS2c.cjs.map} +1 -1
- package/dist/{localBatchGatewayRequest-C0QtijkB.js → localBatchGatewayRequest-DtOvBmA9.js} +3 -3
- package/dist/{localBatchGatewayRequest-C0QtijkB.js.map → localBatchGatewayRequest-DtOvBmA9.js.map} +1 -1
- package/dist/main.cjs +1 -1
- package/dist/main.js +1 -1
- package/dist/secp256k1-CMP_u7qb.cjs +2 -0
- package/dist/secp256k1-CMP_u7qb.cjs.map +1 -0
- package/dist/secp256k1-DCMgMsfV.js +1297 -0
- package/dist/secp256k1-DCMgMsfV.js.map +1 -0
- package/dist/utils/time.cjs.map +1 -1
- package/dist/utils/time.js.map +1 -1
- package/dist/utils/version.cjs +1 -1
- package/dist/utils/version.js +1 -1
- package/dist/writeContract-BnmmOPwy.cjs +36 -0
- package/dist/writeContract-BnmmOPwy.cjs.map +1 -0
- package/dist/{writeContract-DkC9wV5p.js → writeContract-DYAfDrRz.js} +1788 -1712
- package/dist/writeContract-DYAfDrRz.js.map +1 -0
- package/package.json +8 -8
- package/dist/ccip-C76-YhQK.js +0 -152
- package/dist/ccip-CEodLZ4s.cjs +0 -2
- package/dist/constants-CxSgz27h.cjs +0 -9
- package/dist/createWalletClient-Cct6ojqI.cjs +0 -5
- package/dist/createWalletClient-Cct6ojqI.cjs.map +0 -1
- package/dist/createWalletClient-DAuQCrLq.js +0 -3262
- package/dist/createWalletClient-DAuQCrLq.js.map +0 -1
- package/dist/secp256k1-ClOw2ksU.js +0 -1291
- package/dist/secp256k1-ClOw2ksU.js.map +0 -1
- package/dist/secp256k1-YUzyTLhP.cjs +0 -2
- package/dist/secp256k1-YUzyTLhP.cjs.map +0 -1
- package/dist/writeContract-BfAYISeL.cjs +0 -36
- package/dist/writeContract-BfAYISeL.cjs.map +0 -1
- package/dist/writeContract-DkC9wV5p.js.map +0 -1
|
@@ -1,13 +1,10 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
7
|
-
|
|
8
|
-
import { PufLocker as P } from "../abis/mainnet/PufLocker.js";
|
|
9
|
-
import { g as f } from "../../getContract-DEPNMZxg.js";
|
|
10
|
-
class R {
|
|
1
|
+
import { V as p, p as m } from "../../constants-CuIEh_ZS.js";
|
|
2
|
+
import { CONTRACT_ADDRESSES as d } from "../addresses.js";
|
|
3
|
+
import { TOKENS_ADDRESSES as a } from "../tokens.js";
|
|
4
|
+
import { ERC20PermitHandler as l } from "./erc20-permit-handler.js";
|
|
5
|
+
import { PufLocker as g } from "../abis/mainnet/PufLocker.js";
|
|
6
|
+
import { g as C } from "../../getContract-DQN7VDBo.js";
|
|
7
|
+
class E {
|
|
11
8
|
/**
|
|
12
9
|
* Create the handler for the `PufLocker` contract exposing methods to
|
|
13
10
|
* interact with the contract.
|
|
@@ -18,15 +15,15 @@ class R {
|
|
|
18
15
|
* @param publicClient The public client to use for public
|
|
19
16
|
* interactions.
|
|
20
17
|
*/
|
|
21
|
-
constructor(
|
|
22
|
-
|
|
23
|
-
o(this, "erc20PermitHandler");
|
|
24
|
-
this.chain = t, this.walletClient = e, this.publicClient = i, this.viemChain = u[t], this.erc20PermitHandler = new w(
|
|
25
|
-
t,
|
|
18
|
+
constructor(e, t, i) {
|
|
19
|
+
this.chain = e, this.walletClient = t, this.publicClient = i, this.viemChain = p[e], this.erc20PermitHandler = new l(
|
|
26
20
|
e,
|
|
21
|
+
t,
|
|
27
22
|
i
|
|
28
23
|
);
|
|
29
24
|
}
|
|
25
|
+
viemChain;
|
|
26
|
+
erc20PermitHandler;
|
|
30
27
|
/**
|
|
31
28
|
* Get the contract. This is a method because the typings are complex
|
|
32
29
|
* and lost when trying to make it a member.
|
|
@@ -34,8 +31,8 @@ class R {
|
|
|
34
31
|
* @returns The viem contract.
|
|
35
32
|
*/
|
|
36
33
|
getContract() {
|
|
37
|
-
const
|
|
38
|
-
return
|
|
34
|
+
const e = d[this.chain].PufLocker, t = g, i = { public: this.publicClient, wallet: this.walletClient };
|
|
35
|
+
return C({ address: e, abi: t, client: i });
|
|
39
36
|
}
|
|
40
37
|
/**
|
|
41
38
|
* Get all deposits of the given account address.
|
|
@@ -44,10 +41,10 @@ class R {
|
|
|
44
41
|
* @param walletAddress The wallet address to get the deposits for.
|
|
45
42
|
* @returns The amount and deposits of the given account address.
|
|
46
43
|
*/
|
|
47
|
-
getAllDeposits(
|
|
44
|
+
getAllDeposits(e, t) {
|
|
48
45
|
return this.getContract().read.getAllDeposits([
|
|
49
|
-
|
|
50
|
-
|
|
46
|
+
a[e][this.chain],
|
|
47
|
+
t
|
|
51
48
|
]);
|
|
52
49
|
}
|
|
53
50
|
/**
|
|
@@ -59,12 +56,12 @@ class R {
|
|
|
59
56
|
* @param limit The maximum number of deposits to retrieve.
|
|
60
57
|
* @returns The amount and release time of the deposits.
|
|
61
58
|
*/
|
|
62
|
-
getDeposits(
|
|
59
|
+
getDeposits(e, t, i, r) {
|
|
63
60
|
return this.getContract().read.getDeposits([
|
|
64
|
-
|
|
65
|
-
|
|
61
|
+
t,
|
|
62
|
+
a[e][this.chain],
|
|
66
63
|
i,
|
|
67
|
-
|
|
64
|
+
r
|
|
68
65
|
]);
|
|
69
66
|
}
|
|
70
67
|
/**
|
|
@@ -95,37 +92,37 @@ class R {
|
|
|
95
92
|
* `estimate: () => Promise<bigint>` - Gas estimate of the
|
|
96
93
|
* transaction.
|
|
97
94
|
*/
|
|
98
|
-
async deposit(
|
|
95
|
+
async deposit(e) {
|
|
99
96
|
const {
|
|
100
|
-
token:
|
|
97
|
+
token: t,
|
|
101
98
|
account: i,
|
|
102
|
-
recipient:
|
|
103
|
-
value:
|
|
104
|
-
lockPeriod:
|
|
105
|
-
isPreapproved:
|
|
106
|
-
} =
|
|
107
|
-
let
|
|
108
|
-
r:
|
|
109
|
-
s:
|
|
99
|
+
recipient: r,
|
|
100
|
+
value: s,
|
|
101
|
+
lockPeriod: n,
|
|
102
|
+
isPreapproved: o = !1
|
|
103
|
+
} = e;
|
|
104
|
+
let c = {
|
|
105
|
+
r: m("0x", { size: 32 }),
|
|
106
|
+
s: m("0x", { size: 32 }),
|
|
110
107
|
v: 0,
|
|
111
108
|
deadline: 0n,
|
|
112
|
-
amount:
|
|
109
|
+
amount: s
|
|
113
110
|
};
|
|
114
|
-
|
|
111
|
+
o || (c = await this.erc20PermitHandler.withToken(t).getPermitData(
|
|
115
112
|
i,
|
|
116
|
-
|
|
117
|
-
|
|
113
|
+
d[this.chain].PufLocker,
|
|
114
|
+
s
|
|
118
115
|
));
|
|
119
|
-
const
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
116
|
+
const h = [
|
|
117
|
+
a[t][this.chain],
|
|
118
|
+
r,
|
|
119
|
+
n,
|
|
120
|
+
c
|
|
124
121
|
];
|
|
125
|
-
return { transact: () => this.getContract().write.deposit(
|
|
122
|
+
return { transact: () => this.getContract().write.deposit(h, {
|
|
126
123
|
account: i,
|
|
127
124
|
chain: this.viemChain
|
|
128
|
-
}), estimate: () => this.getContract().estimateGas.deposit(
|
|
125
|
+
}), estimate: () => this.getContract().estimateGas.deposit(h, {
|
|
129
126
|
account: i
|
|
130
127
|
}) };
|
|
131
128
|
}
|
|
@@ -139,21 +136,21 @@ class R {
|
|
|
139
136
|
* @param depositIndexes Deposit indexes to withdraw.
|
|
140
137
|
* @returns Hash of the withdrawal transaction.
|
|
141
138
|
*/
|
|
142
|
-
withdraw(
|
|
143
|
-
const
|
|
144
|
-
|
|
145
|
-
|
|
139
|
+
withdraw(e, t, i, r) {
|
|
140
|
+
const s = [
|
|
141
|
+
a[e][this.chain],
|
|
142
|
+
r,
|
|
146
143
|
i
|
|
147
144
|
];
|
|
148
|
-
return { transact: () => this.getContract().write.withdraw(
|
|
149
|
-
account:
|
|
145
|
+
return { transact: () => this.getContract().write.withdraw(s, {
|
|
146
|
+
account: t,
|
|
150
147
|
chain: this.viemChain
|
|
151
|
-
}), estimate: () => this.getContract().estimateGas.withdraw(
|
|
152
|
-
account:
|
|
148
|
+
}), estimate: () => this.getContract().estimateGas.withdraw(s, {
|
|
149
|
+
account: t
|
|
153
150
|
}) };
|
|
154
151
|
}
|
|
155
152
|
}
|
|
156
153
|
export {
|
|
157
|
-
|
|
154
|
+
E as PufLockerHandler
|
|
158
155
|
};
|
|
159
156
|
//# sourceMappingURL=puf-locker-handler.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"puf-locker-handler.js","sources":["../../../lib/contracts/handlers/puf-locker-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 { AnyToken, TOKENS_ADDRESSES } from '../tokens';\nimport { ERC20PermitHandler } from './erc20-permit-handler';\nimport { PufLocker } from '../abis/mainnet/PufLocker';\nimport { PermitData } from '../common/lib/types';\n\nexport type LockerDepositParams = {\n token: AnyToken;\n account: Address;\n recipient: Address;\n value: bigint;\n lockPeriod: bigint;\n isPreapproved?: boolean;\n};\n\n/**\n * Handler for the `PufLocker` contract exposing methods to interact\n * with the contract.\n */\nexport class PufLockerHandler {\n private viemChain: ViemChain;\n private erc20PermitHandler: ERC20PermitHandler;\n\n /**\n * Create the handler for the `PufLocker` contract exposing methods to\n * 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].PufLocker as Address;\n const abi = PufLocker;\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 * Get all deposits of the given account address.\n *\n * @param pufToken The PufToken to get the deposits for.\n * @param walletAddress The wallet address to get the deposits for.\n * @returns The amount and deposits of the given account address.\n */\n public getAllDeposits(pufToken: AnyToken, walletAddress: Address) {\n return this.getContract().read.getAllDeposits([\n TOKENS_ADDRESSES[pufToken][this.chain],\n walletAddress,\n ]);\n }\n\n /**\n * Get the user's deposits for the given token and deposit index.\n *\n * @param pufToken PufToken to get the deposits of.\n * @param userAddress User address to get the deposits for.\n * @param start The starting index of the deposits.\n * @param limit The maximum number of deposits to retrieve.\n * @returns The amount and release time of the deposits.\n */\n public getDeposits(\n pufToken: AnyToken,\n userAddress: Address,\n start: bigint,\n limit: bigint,\n ) {\n return this.getContract().read.getDeposits([\n userAddress,\n TOKENS_ADDRESSES[pufToken][this.chain],\n start,\n limit,\n ]);\n }\n\n /**\n * Get the minimum and maximum lock periods allowed for deposits.\n *\n * @returns The minimum and maximum lock period in seconds.\n * (`[minLock, maxLock]`)\n */\n public getLockPeriods() {\n return this.getContract().read.getLockPeriods();\n }\n\n /**\n * Deposit the given PufToken into the locker. This doesn't make the\n * transaction but returns two methods namely `transact` and\n * `estimate`.\n *\n * @param depositParams.pufToken PufToken to deposit.\n * @param depositParams.account Wallet address of the depositor.\n * @param depositParams.recipient Recipient of the deposit.\n * @param depositParams.value Amount of 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: LockerDepositParams) {\n const {\n token,\n account,\n recipient,\n value,\n lockPeriod,\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: 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 permitData = await this.erc20PermitHandler\n .withToken(token)\n .getPermitData(\n account,\n CONTRACT_ADDRESSES[this.chain].PufLocker as Address,\n value,\n );\n }\n\n const depositArgs = <const>[\n TOKENS_ADDRESSES[token][this.chain],\n recipient,\n lockPeriod,\n permitData,\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 /**\n * Withdraw the deposits identified by the deposit indexes from the\n * locker.\n *\n * @param pufToken PufToken to withdraw.\n * @param walletAddress Address of the account making the transaction.\n * @param recipient Recipient of the withdrawal.\n * @param depositIndexes Deposit indexes to withdraw.\n * @returns Hash of the withdrawal transaction.\n */\n public withdraw(\n pufToken: AnyToken,\n walletAddress: Address,\n recipient: Address,\n depositIndexes: bigint[],\n ) {\n const withdrawArgs = <const>[\n TOKENS_ADDRESSES[pufToken][this.chain],\n depositIndexes,\n recipient,\n ];\n\n const transact = () =>\n this.getContract().write.withdraw(withdrawArgs, {\n account: walletAddress,\n chain: this.viemChain,\n });\n const estimate = () =>\n this.getContract().estimateGas.withdraw(withdrawArgs, {\n account: walletAddress,\n });\n\n return { transact, estimate };\n }\n}\n"],"names":["PufLockerHandler","chain","walletClient","publicClient","
|
|
1
|
+
{"version":3,"file":"puf-locker-handler.js","sources":["../../../lib/contracts/handlers/puf-locker-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 { AnyToken, TOKENS_ADDRESSES } from '../tokens';\nimport { ERC20PermitHandler } from './erc20-permit-handler';\nimport { PufLocker } from '../abis/mainnet/PufLocker';\nimport { PermitData } from '../common/lib/types';\n\nexport type LockerDepositParams = {\n token: AnyToken;\n account: Address;\n recipient: Address;\n value: bigint;\n lockPeriod: bigint;\n isPreapproved?: boolean;\n};\n\n/**\n * Handler for the `PufLocker` contract exposing methods to interact\n * with the contract.\n */\nexport class PufLockerHandler {\n private viemChain: ViemChain;\n private erc20PermitHandler: ERC20PermitHandler;\n\n /**\n * Create the handler for the `PufLocker` contract exposing methods to\n * 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].PufLocker as Address;\n const abi = PufLocker;\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 * Get all deposits of the given account address.\n *\n * @param pufToken The PufToken to get the deposits for.\n * @param walletAddress The wallet address to get the deposits for.\n * @returns The amount and deposits of the given account address.\n */\n public getAllDeposits(pufToken: AnyToken, walletAddress: Address) {\n return this.getContract().read.getAllDeposits([\n TOKENS_ADDRESSES[pufToken][this.chain],\n walletAddress,\n ]);\n }\n\n /**\n * Get the user's deposits for the given token and deposit index.\n *\n * @param pufToken PufToken to get the deposits of.\n * @param userAddress User address to get the deposits for.\n * @param start The starting index of the deposits.\n * @param limit The maximum number of deposits to retrieve.\n * @returns The amount and release time of the deposits.\n */\n public getDeposits(\n pufToken: AnyToken,\n userAddress: Address,\n start: bigint,\n limit: bigint,\n ) {\n return this.getContract().read.getDeposits([\n userAddress,\n TOKENS_ADDRESSES[pufToken][this.chain],\n start,\n limit,\n ]);\n }\n\n /**\n * Get the minimum and maximum lock periods allowed for deposits.\n *\n * @returns The minimum and maximum lock period in seconds.\n * (`[minLock, maxLock]`)\n */\n public getLockPeriods() {\n return this.getContract().read.getLockPeriods();\n }\n\n /**\n * Deposit the given PufToken into the locker. This doesn't make the\n * transaction but returns two methods namely `transact` and\n * `estimate`.\n *\n * @param depositParams.pufToken PufToken to deposit.\n * @param depositParams.account Wallet address of the depositor.\n * @param depositParams.recipient Recipient of the deposit.\n * @param depositParams.value Amount of 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: LockerDepositParams) {\n const {\n token,\n account,\n recipient,\n value,\n lockPeriod,\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: 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 permitData = await this.erc20PermitHandler\n .withToken(token)\n .getPermitData(\n account,\n CONTRACT_ADDRESSES[this.chain].PufLocker as Address,\n value,\n );\n }\n\n const depositArgs = <const>[\n TOKENS_ADDRESSES[token][this.chain],\n recipient,\n lockPeriod,\n permitData,\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 /**\n * Withdraw the deposits identified by the deposit indexes from the\n * locker.\n *\n * @param pufToken PufToken to withdraw.\n * @param walletAddress Address of the account making the transaction.\n * @param recipient Recipient of the withdrawal.\n * @param depositIndexes Deposit indexes to withdraw.\n * @returns Hash of the withdrawal transaction.\n */\n public withdraw(\n pufToken: AnyToken,\n walletAddress: Address,\n recipient: Address,\n depositIndexes: bigint[],\n ) {\n const withdrawArgs = <const>[\n TOKENS_ADDRESSES[pufToken][this.chain],\n depositIndexes,\n recipient,\n ];\n\n const transact = () =>\n this.getContract().write.withdraw(withdrawArgs, {\n account: walletAddress,\n chain: this.viemChain,\n });\n const estimate = () =>\n this.getContract().estimateGas.withdraw(withdrawArgs, {\n account: walletAddress,\n });\n\n return { transact, estimate };\n }\n}\n"],"names":["PufLockerHandler","chain","walletClient","publicClient","VIEM_CHAINS","ERC20PermitHandler","address","CONTRACT_ADDRESSES","abi","PufLocker","client","getContract","pufToken","walletAddress","TOKENS_ADDRESSES","userAddress","start","limit","depositParams","token","account","recipient","value","lockPeriod","isPreapproved","permitData","padHex","depositArgs","depositIndexes","withdrawArgs"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const c=require("../../constants-6kuRTsbU.cjs"),a=require("../addresses.cjs"),o=require("./erc20-permit-handler.cjs"),n=require("../tokens.cjs"),h=require("../abis/mainnet/PufferDepositor.cjs"),u=require("../../getContract-D4_SEfqa.cjs");class m{constructor(t,i,e){this.chain=t,this.walletClient=i,this.publicClient=e,this.viemChain=c.VIEM_CHAINS[t],this.erc20PermitHandler=new o.ERC20PermitHandler(t,i,e)}viemChain;erc20PermitHandler;getContract(){const t=a.CONTRACT_ADDRESSES[this.chain].PufferDepositor,i=h.PufferDepositor,e={public:this.publicClient,wallet:this.walletClient};return u.getContract({address:t,abi:i,client:e})}async depositStETH(t,i){const e=await this.erc20PermitHandler.withToken(n.Token.stETH).getPermitData(t,a.CONTRACT_ADDRESSES[this.chain].PufferDepositor,i);return{transact:async()=>await this.getContract().write.depositStETH([e,t],{account:t,chain:this.viemChain}),estimate:async()=>await this.getContract().estimateGas.depositStETH([e,t],{account:t})}}async depositWstETH(t,i){const e=await this.erc20PermitHandler.withToken(n.Token.wstETH).getPermitData(t,a.CONTRACT_ADDRESSES[this.chain].PufferDepositor,i);return{transact:async()=>await this.getContract().write.depositWstETH([e,t],{account:t,chain:this.viemChain}),estimate:async()=>await this.getContract().estimateGas.depositWstETH([e,t],{account:t})}}}exports.PufferDepositorHandler=m;
|
|
2
2
|
//# sourceMappingURL=puffer-depositor-handler.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"puffer-depositor-handler.cjs","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 permitData = await this.erc20PermitHandler\n .withToken(Token.stETH)\n .getPermitData(\n walletAddress,\n CONTRACT_ADDRESSES[this.chain].PufferDepositor as Address,\n 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 permitData = await this.erc20PermitHandler\n .withToken(Token.wstETH)\n .getPermitData(\n walletAddress,\n CONTRACT_ADDRESSES[this.chain].PufferDepositor as Address,\n 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","
|
|
1
|
+
{"version":3,"file":"puffer-depositor-handler.cjs","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 permitData = await this.erc20PermitHandler\n .withToken(Token.stETH)\n .getPermitData(\n walletAddress,\n CONTRACT_ADDRESSES[this.chain].PufferDepositor as Address,\n 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 permitData = await this.erc20PermitHandler\n .withToken(Token.wstETH)\n .getPermitData(\n walletAddress,\n CONTRACT_ADDRESSES[this.chain].PufferDepositor as Address,\n 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","VIEM_CHAINS","ERC20PermitHandler","address","CONTRACT_ADDRESSES","abi","PufferDepositor","client","getContract","walletAddress","value","permitData","Token"],"mappings":"8TAiBO,MAAMA,CAAuB,CAclC,YACUC,EACAC,EACAC,EACR,CAHQ,KAAA,MAAAF,EACA,KAAA,aAAAC,EACA,KAAA,aAAAC,EAER,KAAK,UAAYC,EAAAA,YAAYH,CAAK,EAClC,KAAK,mBAAqB,IAAII,EAAAA,mBAC5BJ,EACAC,EACAC,CAAA,CAEJ,CAxBQ,UACA,mBA+BD,aAAc,CACnB,MAAMG,EAAUC,EAAAA,mBAAmB,KAAK,KAAK,EAAE,gBACzCC,EAAMC,EAAAA,gBACNC,EAAS,CAAE,OAAQ,KAAK,aAAc,OAAQ,KAAK,YAAA,EAEzD,OAAOC,EAAAA,YAAY,CAAE,QAAAL,EAAS,IAAAE,EAAK,OAAAE,EAAQ,CAK7C,CAeA,MAAa,aAAaE,EAAwBC,EAAe,CAC/D,MAAMC,EAAa,MAAM,KAAK,mBAC3B,UAAUC,EAAAA,MAAM,KAAK,EACrB,cACCH,EACAL,qBAAmB,KAAK,KAAK,EAAE,gBAC/BM,CAAA,EAcJ,MAAO,CAAE,SAXQ,SACf,MAAM,KAAK,YAAA,EAAc,MAAM,aAAa,CAACC,EAAYF,CAAa,EAAG,CACvE,QAASA,EACT,MAAO,KAAK,SAAA,CACb,EAOgB,SANF,SACf,MAAM,KAAK,YAAA,EAAc,YAAY,aACnC,CAACE,EAAYF,CAAa,EAC1B,CAAE,QAASA,CAAA,CAAc,CAGV,CACrB,CAeA,MAAa,cAAcA,EAAwBC,EAAe,CAChE,MAAMC,EAAa,MAAM,KAAK,mBAC3B,UAAUC,EAAAA,MAAM,MAAM,EACtB,cACCH,EACAL,qBAAmB,KAAK,KAAK,EAAE,gBAC/BM,CAAA,EAiBJ,MAAO,CAAE,SAdQ,SACf,MAAM,KAAK,YAAA,EAAc,MAAM,cAC7B,CAACC,EAAYF,CAAa,EAC1B,CACE,QAASA,EACT,MAAO,KAAK,SAAA,CACd,EAQe,SANF,SACf,MAAM,KAAK,YAAA,EAAc,YAAY,cACnC,CAACE,EAAYF,CAAa,EAC1B,CAAE,QAASA,CAAA,CAAc,CAGV,CACrB,CACF"}
|