@pufferfinance/puffer-sdk 1.4.2 → 1.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/api/puffer-client-helpers.cjs +2 -0
- package/dist/api/puffer-client-helpers.cjs.map +1 -0
- package/dist/api/puffer-client-helpers.d.ts +0 -1
- package/dist/api/puffer-client-helpers.js +142 -0
- package/dist/api/puffer-client-helpers.js.map +1 -0
- package/dist/api/puffer-client.cjs +2 -0
- package/dist/api/puffer-client.cjs.map +1 -0
- package/dist/api/puffer-client.d.ts +6 -1
- package/dist/api/puffer-client.js +97 -0
- package/dist/api/puffer-client.js.map +1 -0
- package/dist/{ccip-ZoYOXsGl.js → ccip-D4klNwCt.js} +28 -27
- package/dist/{ccip-ZoYOXsGl.js.map → ccip-D4klNwCt.js.map} +1 -1
- package/dist/ccip-DLDqFodf.cjs +2 -0
- package/dist/{ccip-Dv116NSL.cjs.map → ccip-DLDqFodf.cjs.map} +1 -1
- package/dist/chains/constants.cjs +2 -0
- package/dist/chains/constants.cjs.map +1 -0
- package/dist/chains/constants.d.ts +3 -2
- package/dist/chains/constants.js +6 -0
- package/dist/chains/constants.js.map +1 -0
- package/dist/constants-BvU-JhfL.cjs +9 -0
- package/dist/constants-BvU-JhfL.cjs.map +1 -0
- package/dist/constants-rWWWhxR_.js +2099 -0
- package/dist/constants-rWWWhxR_.js.map +1 -0
- package/dist/contracts/abis/holesky/PufferDepositor.cjs +2 -0
- package/dist/contracts/abis/holesky/PufferDepositor.cjs.map +1 -0
- package/dist/contracts/abis/holesky/PufferDepositor.js +377 -0
- package/dist/contracts/abis/holesky/PufferDepositor.js.map +1 -0
- package/dist/contracts/abis/holesky/PufferVaultV2.cjs +2 -0
- package/dist/contracts/abis/holesky/PufferVaultV2.cjs.map +1 -0
- package/dist/contracts/abis/holesky/PufferVaultV2.js +1787 -0
- package/dist/contracts/abis/holesky/PufferVaultV2.js.map +1 -0
- package/dist/contracts/abis/l1-reward-manager-abis.cjs +2 -0
- package/dist/contracts/abis/l1-reward-manager-abis.cjs.map +1 -0
- package/dist/contracts/abis/l1-reward-manager-abis.d.ts +527 -0
- package/dist/contracts/abis/l1-reward-manager-abis.js +9 -0
- package/dist/contracts/abis/l1-reward-manager-abis.js.map +1 -0
- package/dist/contracts/abis/l2-reward-manager-abis.cjs +2 -0
- package/dist/contracts/abis/l2-reward-manager-abis.cjs.map +1 -0
- package/dist/contracts/abis/l2-reward-manager-abis.d.ts +685 -0
- package/dist/contracts/abis/l2-reward-manager-abis.js +9 -0
- package/dist/contracts/abis/l2-reward-manager-abis.js.map +1 -0
- package/dist/contracts/abis/mainnet/ERC20Permit.cjs +2 -0
- package/dist/contracts/abis/mainnet/ERC20Permit.cjs.map +1 -0
- package/dist/contracts/abis/mainnet/ERC20Permit.js +524 -0
- package/dist/contracts/abis/mainnet/ERC20Permit.js.map +1 -0
- package/dist/contracts/abis/mainnet/L1RewardManager.cjs +2 -0
- package/dist/contracts/abis/mainnet/L1RewardManager.cjs.map +1 -0
- package/dist/contracts/abis/mainnet/L1RewardManager.d.ts +523 -0
- package/dist/contracts/abis/mainnet/L1RewardManager.js +447 -0
- package/dist/contracts/abis/mainnet/L1RewardManager.js.map +1 -0
- package/dist/contracts/abis/mainnet/L2RewardManager.cjs +2 -0
- package/dist/contracts/abis/mainnet/L2RewardManager.cjs.map +1 -0
- package/dist/contracts/abis/mainnet/L2RewardManager.d.ts +681 -0
- package/dist/contracts/abis/mainnet/L2RewardManager.js +538 -0
- package/dist/contracts/abis/mainnet/L2RewardManager.js.map +1 -0
- package/dist/contracts/abis/mainnet/PufLocker.cjs +2 -0
- package/dist/contracts/abis/mainnet/PufLocker.cjs.map +1 -0
- package/dist/contracts/abis/mainnet/PufLocker.js +362 -0
- package/dist/contracts/abis/mainnet/PufLocker.js.map +1 -0
- package/dist/contracts/abis/mainnet/PufToken.cjs +2 -0
- package/dist/contracts/abis/mainnet/PufToken.cjs.map +1 -0
- package/dist/contracts/abis/mainnet/PufToken.js +883 -0
- package/dist/contracts/abis/mainnet/PufToken.js.map +1 -0
- package/dist/contracts/abis/mainnet/PufferDepositor.cjs +2 -0
- package/dist/contracts/abis/mainnet/PufferDepositor.cjs.map +1 -0
- package/dist/contracts/abis/mainnet/PufferDepositor.js +377 -0
- package/dist/contracts/abis/mainnet/PufferDepositor.js.map +1 -0
- package/dist/contracts/abis/mainnet/PufferL2Depositor.cjs +2 -0
- package/dist/contracts/abis/mainnet/PufferL2Depositor.cjs.map +1 -0
- package/dist/contracts/abis/mainnet/PufferL2Depositor.js +300 -0
- package/dist/contracts/abis/mainnet/PufferL2Depositor.js.map +1 -0
- package/dist/contracts/abis/mainnet/PufferVaultV2.cjs +2 -0
- package/dist/contracts/abis/mainnet/PufferVaultV2.cjs.map +1 -0
- package/dist/contracts/abis/mainnet/PufferVaultV2.js +1864 -0
- package/dist/contracts/abis/mainnet/PufferVaultV2.js.map +1 -0
- package/dist/contracts/abis/puf-locker-abis.cjs +2 -0
- package/dist/contracts/abis/puf-locker-abis.cjs.map +1 -0
- package/dist/contracts/abis/puf-locker-abis.js +10 -0
- package/dist/contracts/abis/puf-locker-abis.js.map +1 -0
- package/dist/contracts/abis/puf-token-abis.cjs +2 -0
- package/dist/contracts/abis/puf-token-abis.cjs.map +1 -0
- package/dist/contracts/abis/puf-token-abis.js +10 -0
- package/dist/contracts/abis/puf-token-abis.js.map +1 -0
- package/dist/contracts/abis/puffer-depositor-abis.cjs +2 -0
- package/dist/contracts/abis/puffer-depositor-abis.cjs.map +1 -0
- package/dist/contracts/abis/puffer-depositor-abis.js +20 -0
- package/dist/contracts/abis/puffer-depositor-abis.js.map +1 -0
- package/dist/contracts/abis/puffer-vault-abis.cjs +2 -0
- package/dist/contracts/abis/puffer-vault-abis.cjs.map +1 -0
- package/dist/contracts/abis/puffer-vault-abis.js +15 -0
- package/dist/contracts/abis/puffer-vault-abis.js.map +1 -0
- package/dist/contracts/abis/tokens-abis.cjs +2 -0
- package/dist/contracts/abis/tokens-abis.cjs.map +1 -0
- package/dist/contracts/abis/tokens-abis.js +6 -0
- package/dist/contracts/abis/tokens-abis.js.map +1 -0
- package/dist/contracts/addresses.cjs +2 -0
- package/dist/contracts/addresses.cjs.map +1 -0
- package/dist/contracts/addresses.d.ts +23 -0
- package/dist/contracts/addresses.js +27 -0
- package/dist/contracts/addresses.js.map +1 -0
- package/dist/contracts/handlers/erc20-permit-handler.cjs +2 -0
- package/dist/contracts/handlers/erc20-permit-handler.cjs.map +1 -0
- package/dist/contracts/handlers/erc20-permit-handler.d.ts +579 -579
- package/dist/contracts/handlers/erc20-permit-handler.js +124 -0
- package/dist/contracts/handlers/erc20-permit-handler.js.map +1 -0
- package/dist/contracts/handlers/l1-reward-manager-handler.cjs +2 -0
- package/dist/contracts/handlers/l1-reward-manager-handler.cjs.map +1 -0
- package/dist/contracts/handlers/l1-reward-manager-handler.d.ts +6693 -0
- package/dist/contracts/handlers/l1-reward-manager-handler.js +68 -0
- package/dist/contracts/handlers/l1-reward-manager-handler.js.map +1 -0
- package/dist/contracts/handlers/l2-reward-manager-handler.cjs +2 -0
- package/dist/contracts/handlers/l2-reward-manager-handler.cjs.map +1 -0
- package/dist/contracts/handlers/l2-reward-manager-handler.d.ts +6912 -0
- package/dist/contracts/handlers/l2-reward-manager-handler.js +137 -0
- package/dist/contracts/handlers/l2-reward-manager-handler.js.map +1 -0
- package/dist/contracts/handlers/puf-locker-handler.cjs +2 -0
- package/dist/contracts/handlers/puf-locker-handler.cjs.map +1 -0
- package/dist/contracts/handlers/puf-locker-handler.d.ts +579 -579
- package/dist/contracts/handlers/puf-locker-handler.js +168 -0
- package/dist/contracts/handlers/puf-locker-handler.js.map +1 -0
- package/dist/contracts/handlers/puf-token-handler.cjs +2 -0
- package/dist/contracts/handlers/puf-token-handler.cjs.map +1 -0
- package/dist/contracts/handlers/puf-token-handler.d.ts +579 -579
- package/dist/contracts/handlers/puf-token-handler.js +174 -0
- package/dist/contracts/handlers/puf-token-handler.js.map +1 -0
- package/dist/contracts/handlers/puffer-depositor-handler.cjs +2 -0
- package/dist/contracts/handlers/puffer-depositor-handler.cjs.map +1 -0
- package/dist/contracts/handlers/puffer-depositor-handler.d.ts +579 -579
- package/dist/contracts/handlers/puffer-depositor-handler.js +113 -0
- package/dist/contracts/handlers/puffer-depositor-handler.js.map +1 -0
- package/dist/contracts/handlers/puffer-l2-depositor-handler.cjs +2 -0
- package/dist/contracts/handlers/puffer-l2-depositor-handler.cjs.map +1 -0
- package/dist/contracts/handlers/puffer-l2-depositor-handler.d.ts +579 -579
- package/dist/contracts/handlers/puffer-l2-depositor-handler.js +112 -0
- package/dist/contracts/handlers/puffer-l2-depositor-handler.js.map +1 -0
- package/dist/contracts/handlers/puffer-vault-handler.cjs +2 -0
- package/dist/contracts/handlers/puffer-vault-handler.cjs.map +1 -0
- package/dist/contracts/handlers/puffer-vault-handler.d.ts +579 -579
- package/dist/contracts/handlers/puffer-vault-handler.js +185 -0
- package/dist/contracts/handlers/puffer-vault-handler.js.map +1 -0
- package/dist/contracts/tokens.cjs +2 -0
- package/dist/contracts/tokens.cjs.map +1 -0
- package/dist/contracts/tokens.d.ts +0 -1
- package/dist/contracts/tokens.js +134 -0
- package/dist/contracts/tokens.js.map +1 -0
- package/dist/createWalletClient-Bmopj8MM.cjs +4 -0
- package/dist/createWalletClient-Bmopj8MM.cjs.map +1 -0
- package/dist/createWalletClient-DKcpswHR.js +2007 -0
- package/dist/createWalletClient-DKcpswHR.js.map +1 -0
- package/dist/errors/base-error.cjs +3 -0
- package/dist/errors/base-error.cjs.map +1 -0
- package/dist/errors/base-error.d.ts +0 -1
- package/dist/errors/base-error.js +23 -0
- package/dist/errors/base-error.js.map +1 -0
- package/dist/errors/types.cjs +2 -0
- package/dist/errors/types.cjs.map +1 -0
- package/dist/errors/types.js +2 -0
- package/dist/errors/types.js.map +1 -0
- package/dist/errors/validation-errors.cjs +2 -0
- package/dist/errors/validation-errors.cjs.map +1 -0
- package/dist/errors/validation-errors.d.ts +2 -1
- package/dist/errors/validation-errors.js +10 -0
- package/dist/errors/validation-errors.js.map +1 -0
- package/dist/getContract-B3Spz0SO.js +115 -0
- package/dist/getContract-B3Spz0SO.js.map +1 -0
- package/dist/getContract-MrPLx6gp.cjs +2 -0
- package/dist/getContract-MrPLx6gp.cjs.map +1 -0
- package/dist/main.cjs +1 -1
- package/dist/main.js +14 -10
- package/dist/main.js.map +1 -1
- package/dist/secp256k1-BLbXMlpX.js +1172 -0
- package/dist/secp256k1-BLbXMlpX.js.map +1 -0
- package/dist/secp256k1-CFnFaJ0H.cjs +2 -0
- package/dist/secp256k1-CFnFaJ0H.cjs.map +1 -0
- package/dist/utils/time.cjs +2 -0
- package/dist/utils/time.cjs.map +1 -0
- package/dist/utils/time.js +5 -0
- package/dist/utils/time.js.map +1 -0
- package/dist/utils/types.cjs +2 -0
- package/dist/utils/types.cjs.map +1 -0
- package/dist/utils/types.js +2 -0
- package/dist/utils/types.js.map +1 -0
- package/dist/utils/version.cjs +2 -0
- package/dist/utils/version.cjs.map +1 -0
- package/dist/utils/version.js +5 -0
- package/dist/utils/version.js.map +1 -0
- package/dist/writeContract-BBHpAss8.cjs +32 -0
- package/dist/writeContract-BBHpAss8.cjs.map +1 -0
- package/dist/writeContract-RluxM31W.js +3833 -0
- package/dist/writeContract-RluxM31W.js.map +1 -0
- package/package.json +22 -11
- package/dist/ccip-Dv116NSL.cjs +0 -2
- package/dist/contracts/handlers/erc20-permit-handler.test.d.ts +0 -1
- package/dist/contracts/handlers/puf-locker-handler.test.d.ts +0 -1
- package/dist/contracts/handlers/puf-token-handler.test.d.ts +0 -1
- package/dist/contracts/handlers/puffer-depositor-handler.test.d.ts +0 -1
- package/dist/contracts/handlers/puffer-l2-depositor-handler.test.d.ts +0 -1
- package/dist/contracts/handlers/puffer-vault-handler.test.d.ts +0 -1
- package/dist/main-69HiNG3t.js +0 -16001
- package/dist/main-69HiNG3t.js.map +0 -1
- package/dist/main-IyjWcdJ1.cjs +0 -41
- package/dist/main-IyjWcdJ1.cjs.map +0 -1
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
var n = Object.defineProperty;
|
|
2
|
+
var s = (r, t, e) => t in r ? n(r, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : r[t] = e;
|
|
3
|
+
var i = (r, t, e) => s(r, typeof t != "symbol" ? t + "" : t, e);
|
|
4
|
+
import { V as o } from "../../constants-rWWWhxR_.js";
|
|
5
|
+
import { CONTRACT_ADDRESSES as c } from "../addresses.js";
|
|
6
|
+
import { L2_REWARD_MANAGER_ABIS as l } from "../abis/l2-reward-manager-abis.js";
|
|
7
|
+
import { InvalidInputError as m } from "../../errors/validation-errors.js";
|
|
8
|
+
import { g as d } from "../../getContract-B3Spz0SO.js";
|
|
9
|
+
class f {
|
|
10
|
+
/**
|
|
11
|
+
* Create the handler for the `L2RewardManager` contract exposing
|
|
12
|
+
* methods to interact with the contract.
|
|
13
|
+
*
|
|
14
|
+
* @param chain Chain to use for the client.
|
|
15
|
+
* @param walletClient The wallet client to use for wallet
|
|
16
|
+
* interactions.
|
|
17
|
+
* @param publicClient The public client to use for public
|
|
18
|
+
* interactions.
|
|
19
|
+
*/
|
|
20
|
+
constructor(t, e, a) {
|
|
21
|
+
i(this, "viemChain");
|
|
22
|
+
this.chain = t, this.walletClient = e, this.publicClient = a, this.viemChain = o[t];
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Get the contract. This is a method because the typings are complex
|
|
26
|
+
* and lost when trying to make it a member.
|
|
27
|
+
*
|
|
28
|
+
* @returns The viem contract.
|
|
29
|
+
*/
|
|
30
|
+
getContract() {
|
|
31
|
+
const t = c[this.chain].L2RewardManager, e = l[this.chain].L2RewardManager, a = { public: this.publicClient, wallet: this.walletClient };
|
|
32
|
+
return d({ address: t, abi: e, client: a });
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Get the authority address.
|
|
36
|
+
*
|
|
37
|
+
* @returns The authority address.
|
|
38
|
+
*/
|
|
39
|
+
authority() {
|
|
40
|
+
return this.getContract().read.authority();
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Get the claiming delay.
|
|
44
|
+
*
|
|
45
|
+
* @returns The claiming delay.
|
|
46
|
+
*/
|
|
47
|
+
getClaimingDelay() {
|
|
48
|
+
return this.getContract().read.getClaimingDelay();
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Get the epoch record for a specific period.
|
|
52
|
+
*
|
|
53
|
+
* @param intervalId The interval ID for a given start and end epoch.
|
|
54
|
+
* See `getInternvalId`.
|
|
55
|
+
* @returns The epoch record of exchange rate and reward root.
|
|
56
|
+
*/
|
|
57
|
+
getEpochRecord(t) {
|
|
58
|
+
return this.getContract().read.getEpochRecord([t]);
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Returns the interval ID for a given start and end epoch.
|
|
62
|
+
*
|
|
63
|
+
* @param startEpoch Start epoch of the interval.
|
|
64
|
+
* @param endEpoch End epoch of the interval.
|
|
65
|
+
* @returns Interval ID for the given start and end epoch.
|
|
66
|
+
*/
|
|
67
|
+
getIntervalId(t, e) {
|
|
68
|
+
return this.getContract().read.getIntervalId([t, e]);
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Get the rewards claimer for a specific `account`.
|
|
72
|
+
*
|
|
73
|
+
* @param account Account for which to get the rewards claimer.
|
|
74
|
+
* @returns Rewards claimer address.
|
|
75
|
+
*/
|
|
76
|
+
getRewardsClaimer(t) {
|
|
77
|
+
return this.getContract().read.getRewardsClaimer([t]);
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Check if the reward has been claimed for an account and a specific
|
|
81
|
+
* interval.
|
|
82
|
+
*
|
|
83
|
+
* @param account The address of the account to check.
|
|
84
|
+
* @param intervalId The claiming interval ID. See `getIntervalId`.
|
|
85
|
+
* @returns Whether the reward has been claimed.
|
|
86
|
+
*/
|
|
87
|
+
isClaimed(t, e) {
|
|
88
|
+
return this.getContract().read.isClaimed([e, t]);
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Check whether the claiming is locked for the given interval.
|
|
92
|
+
*
|
|
93
|
+
* @param intervalId The interval to check the claiming lock for. See
|
|
94
|
+
* `getIntervalId`.
|
|
95
|
+
* @returns Whether the claiming is locked for the given interval.
|
|
96
|
+
*/
|
|
97
|
+
isClaimingLocked(t) {
|
|
98
|
+
return this.getContract().read.isClaimingLocked([t]);
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Claims the rewards for a specific epoch range based on the
|
|
102
|
+
* `ClaimOrder`.
|
|
103
|
+
*
|
|
104
|
+
* @param account The account using which to claim the rewards.
|
|
105
|
+
* @param claimOrders One or more claim orders.
|
|
106
|
+
* @param claimOrders[].account Account of the claim order.
|
|
107
|
+
* @param claimOrders[].amount Amount of the claim order.
|
|
108
|
+
* @param claimOrders[].intervalId Interval ID of the claim order. See
|
|
109
|
+
* `getIntervalId`.
|
|
110
|
+
* @param claimOrders[].merkleProof Merkle proof of the claim order.
|
|
111
|
+
* @returns `transact: () => Promise<Address>` - Used to make the
|
|
112
|
+
* transaction.
|
|
113
|
+
*
|
|
114
|
+
* `estimate: () => Promise<bigint>` - Gas estimate of the
|
|
115
|
+
* transaction.
|
|
116
|
+
* @throws {InvalidInputError} If `claimOrders` is empty.
|
|
117
|
+
*/
|
|
118
|
+
claimRewards(t, e) {
|
|
119
|
+
if (e.length === 0)
|
|
120
|
+
throw new m(
|
|
121
|
+
"`claimOrders` cannot be empty and must be specified",
|
|
122
|
+
{
|
|
123
|
+
fixMessage: "Specify at least one or more claim orders to claim rewards"
|
|
124
|
+
}
|
|
125
|
+
);
|
|
126
|
+
return { transact: () => this.getContract().write.claimRewards([e], {
|
|
127
|
+
chain: this.viemChain,
|
|
128
|
+
account: t
|
|
129
|
+
}), estimate: () => this.getContract().estimateGas.claimRewards([e], {
|
|
130
|
+
account: t
|
|
131
|
+
}) };
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
export {
|
|
135
|
+
f as L2RewardManagerHandler
|
|
136
|
+
};
|
|
137
|
+
//# sourceMappingURL=l2-reward-manager-handler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"l2-reward-manager-handler.js","sources":["../../../lib/contracts/handlers/l2-reward-manager-handler.ts"],"sourcesContent":["import {\n Address,\n WalletClient,\n PublicClient,\n getContract,\n GetContractReturnType,\n} from 'viem';\nimport { ViemChain, VIEM_CHAINS, Chain } from '../../chains/constants';\nimport { CONTRACT_ADDRESSES } from '../addresses';\nimport { L2_REWARD_MANAGER_ABIS } from '../abis/l2-reward-manager-abis';\nimport { InvalidInputError } from '../../errors/validation-errors';\n\nexport type ClaimOrder = {\n account: Address;\n amount: bigint;\n intervalId: Address;\n merkleProof: Address[];\n};\n\n/**\n * Handler for the `L2RewardManager` contract.\n */\nexport class L2RewardManagerHandler {\n private viemChain: ViemChain;\n\n /**\n * Create the handler for the `L2RewardManager` 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 }\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].L2RewardManager as Address;\n const abi = L2_REWARD_MANAGER_ABIS[this.chain].L2RewardManager;\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 the authority address.\n *\n * @returns The authority address.\n */\n public authority() {\n return this.getContract().read.authority();\n }\n\n /**\n * Get the claiming delay.\n *\n * @returns The claiming delay.\n */\n public getClaimingDelay() {\n return this.getContract().read.getClaimingDelay();\n }\n\n /**\n * Get the epoch record for a specific period.\n *\n * @param intervalId The interval ID for a given start and end epoch.\n * See `getInternvalId`.\n * @returns The epoch record of exchange rate and reward root.\n */\n public getEpochRecord(intervalId: Address) {\n return this.getContract().read.getEpochRecord([intervalId]);\n }\n\n /**\n * Returns the interval ID for a given start and end epoch.\n *\n * @param startEpoch Start epoch of the interval.\n * @param endEpoch End epoch of the interval.\n * @returns Interval ID for the given start and end epoch.\n */\n public getIntervalId(startEpoch: bigint, endEpoch: bigint) {\n return this.getContract().read.getIntervalId([startEpoch, endEpoch]);\n }\n\n /**\n * Get the rewards claimer for a specific `account`.\n *\n * @param account Account for which to get the rewards claimer.\n * @returns Rewards claimer address.\n */\n public getRewardsClaimer(account: Address) {\n return this.getContract().read.getRewardsClaimer([account]);\n }\n\n /**\n * Check if the reward has been claimed for an account and a specific\n * interval.\n *\n * @param account The address of the account to check.\n * @param intervalId The claiming interval ID. See `getIntervalId`.\n * @returns Whether the reward has been claimed.\n */\n public isClaimed(account: Address, intervalId: Address) {\n return this.getContract().read.isClaimed([intervalId, account]);\n }\n\n /**\n * Check whether the claiming is locked for the given interval.\n *\n * @param intervalId The interval to check the claiming lock for. See\n * `getIntervalId`.\n * @returns Whether the claiming is locked for the given interval.\n */\n public isClaimingLocked(intervalId: Address) {\n return this.getContract().read.isClaimingLocked([intervalId]);\n }\n\n /**\n * Claims the rewards for a specific epoch range based on the\n * `ClaimOrder`.\n *\n * @param account The account using which to claim the rewards.\n * @param claimOrders One or more claim orders.\n * @param claimOrders[].account Account of the claim order.\n * @param claimOrders[].amount Amount of the claim order.\n * @param claimOrders[].intervalId Interval ID of the claim order. See\n * `getIntervalId`.\n * @param claimOrders[].merkleProof Merkle proof of the claim order.\n * @returns `transact: () => Promise<Address>` - Used to make the\n * transaction.\n *\n * `estimate: () => Promise<bigint>` - Gas estimate of the\n * transaction.\n * @throws {InvalidInputError} If `claimOrders` is empty.\n */\n public claimRewards(account: Address, claimOrders: ClaimOrder[]) {\n if (claimOrders.length === 0) {\n throw new InvalidInputError(\n '`claimOrders` cannot be empty and must be specified',\n {\n fixMessage:\n 'Specify at least one or more claim orders to claim rewards',\n },\n );\n }\n\n const transact = () =>\n this.getContract().write.claimRewards([claimOrders], {\n chain: this.viemChain,\n account,\n });\n const estimate = () =>\n this.getContract().estimateGas.claimRewards([claimOrders], {\n account,\n });\n\n return { transact, estimate };\n }\n}\n"],"names":["L2RewardManagerHandler","chain","walletClient","publicClient","__publicField","VIEM_CHAINS","address","CONTRACT_ADDRESSES","abi","L2_REWARD_MANAGER_ABIS","client","getContract","intervalId","startEpoch","endEpoch","account","claimOrders","InvalidInputError"],"mappings":";;;;;;;;AAsBO,MAAMA,EAAuB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAalC,YACUC,GACAC,GACAC,GACR;AAhBM,IAAAC,EAAA;AAaE,SAAA,QAAAH,GACA,KAAA,eAAAC,GACA,KAAA,eAAAC,GAEH,KAAA,YAAYE,EAAYJ,CAAK;AAAA,EACpC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,cAAc;AACnB,UAAMK,IAAUC,EAAmB,KAAK,KAAK,EAAE,iBACzCC,IAAMC,EAAuB,KAAK,KAAK,EAAE,iBACzCC,IAAS,EAAE,QAAQ,KAAK,cAAc,QAAQ,KAAK;AAEzD,WAAOC,EAAY,EAAE,SAAAL,GAAS,KAAAE,GAAK,QAAAE,EAAQ,CAAA;AAAA,EAK7C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,YAAY;AACjB,WAAO,KAAK,YAAA,EAAc,KAAK,UAAU;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,mBAAmB;AACxB,WAAO,KAAK,YAAA,EAAc,KAAK,iBAAiB;AAAA,EAClD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASO,eAAeE,GAAqB;AACzC,WAAO,KAAK,cAAc,KAAK,eAAe,CAACA,CAAU,CAAC;AAAA,EAC5D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASO,cAAcC,GAAoBC,GAAkB;AAClD,WAAA,KAAK,cAAc,KAAK,cAAc,CAACD,GAAYC,CAAQ,CAAC;AAAA,EACrE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,kBAAkBC,GAAkB;AACzC,WAAO,KAAK,cAAc,KAAK,kBAAkB,CAACA,CAAO,CAAC;AAAA,EAC5D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUO,UAAUA,GAAkBH,GAAqB;AAC/C,WAAA,KAAK,cAAc,KAAK,UAAU,CAACA,GAAYG,CAAO,CAAC;AAAA,EAChE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASO,iBAAiBH,GAAqB;AAC3C,WAAO,KAAK,cAAc,KAAK,iBAAiB,CAACA,CAAU,CAAC;AAAA,EAC9D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAoBO,aAAaG,GAAkBC,GAA2B;AAC3D,QAAAA,EAAY,WAAW;AACzB,YAAM,IAAIC;AAAA,QACR;AAAA,QACA;AAAA,UACE,YACE;AAAA,QACJ;AAAA,MAAA;AAcG,WAAA,EAAE,UAVQ,MACf,KAAK,YAAA,EAAc,MAAM,aAAa,CAACD,CAAW,GAAG;AAAA,MACnD,OAAO,KAAK;AAAA,MACZ,SAAAD;AAAA,IAAA,CACD,GAMgB,UALF,MACf,KAAK,YAAA,EAAc,YAAY,aAAa,CAACC,CAAW,GAAG;AAAA,MACzD,SAAAD;AAAA,IAAA,CACD;EAGL;AACF;"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";var P=Object.defineProperty;var D=(r,t,e)=>t in r?P(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e;var c=(r,t,e)=>D(r,typeof t!="symbol"?t+"":t,e);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("../../constants-BvU-JhfL.cjs"),_=require("../abis/puf-locker-abis.cjs"),S=require("../addresses.cjs"),n=require("../tokens.cjs"),w=require("./erc20-permit-handler.cjs"),A=require("../../getContract-MrPLx6gp.cjs");class k{constructor(t,e,i){c(this,"viemChain");c(this,"erc20PermitHandler");this.chain=t,this.walletClient=e,this.publicClient=i,this.viemChain=o.VIEM_CHAINS[t],this.erc20PermitHandler=new w.ERC20PermitHandler(t,e,i)}getContract(){const t=S.CONTRACT_ADDRESSES[this.chain].PufLocker,e=_.PUF_LOCKER_ABIS[this.chain].PufLocker,i={public:this.publicClient,wallet:this.walletClient};return A.getContract({address:t,abi:e,client:i})}getAllDeposits(t,e){return this.getContract().read.getAllDeposits([n.TOKENS_ADDRESSES[t][this.chain],e])}getDeposits(t,e,i,a){return this.getContract().read.getDeposits([e,n.TOKENS_ADDRESSES[t][this.chain],i,a])}getLockPeriods(){return this.getContract().read.getLockPeriods()}async deposit(t){const{token:e,account:i,recipient:a,value:s,lockPeriod:h,isPreapproved:d=!1}=t;let u={r:o.padHex("0x",{size:32}),s:o.padHex("0x",{size:32}),v:0,deadline:0n,amount:s};if(!d){const{r:C,s:g,v:m,yParity:E,deadline:p}=await this.erc20PermitHandler.withToken(e).getPermitSignature(i,S.CONTRACT_ADDRESSES[this.chain].PufLocker,s);u={r:C,s:g,v:Number(m??E),deadline:p,amount:s}}const l=[n.TOKENS_ADDRESSES[e][this.chain],a,h,u];return{transact:()=>this.getContract().write.deposit(l,{account:i,chain:this.viemChain}),estimate:()=>this.getContract().estimateGas.deposit(l,{account:i})}}withdraw(t,e,i,a){const s=[n.TOKENS_ADDRESSES[t][this.chain],a,i];return{transact:()=>this.getContract().write.withdraw(s,{account:e,chain:this.viemChain}),estimate:()=>this.getContract().estimateGas.withdraw(s,{account:e})}}}exports.PufLockerHandler=k;
|
|
2
|
+
//# sourceMappingURL=puf-locker-handler.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"puf-locker-handler.cjs","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 { PUF_LOCKER_ABIS } from '../abis/puf-locker-abis';\nimport { CONTRACT_ADDRESSES } from '../addresses';\nimport { PufToken, TOKENS_ADDRESSES } from '../tokens';\nimport { ERC20PermitHandler } from './erc20-permit-handler';\n\nexport type LockerDepositParams = {\n token: PufToken;\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 = PUF_LOCKER_ABIS[this.chain].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: PufToken, 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: PufToken,\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 = {\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].PufLocker 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 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: PufToken,\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","__publicField","VIEM_CHAINS","ERC20PermitHandler","address","CONTRACT_ADDRESSES","abi","PUF_LOCKER_ABIS","client","getContract","pufToken","walletAddress","TOKENS_ADDRESSES","userAddress","start","limit","depositParams","token","account","recipient","value","lockPeriod","isPreapproved","permitData","padHex","r","s","v","yParity","deadline","depositArgs","depositIndexes","withdrawArgs"],"mappings":"0dA2BO,MAAMA,CAAiB,CAc5B,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,CAAA,CAEJ,CAQO,aAAc,CACnB,MAAMI,EAAUC,EAAA,mBAAmB,KAAK,KAAK,EAAE,UACzCC,EAAMC,EAAA,gBAAgB,KAAK,KAAK,EAAE,UAClCC,EAAS,CAAE,OAAQ,KAAK,aAAc,OAAQ,KAAK,cAEzD,OAAOC,EAAY,YAAA,CAAE,QAAAL,EAAS,IAAAE,EAAK,OAAAE,CAAQ,CAAA,CAK7C,CASO,eAAeE,EAAoBC,EAAwB,CAChE,OAAO,KAAK,cAAc,KAAK,eAAe,CAC5CC,EAAAA,iBAAiBF,CAAQ,EAAE,KAAK,KAAK,EACrCC,CAAA,CACD,CACH,CAWO,YACLD,EACAG,EACAC,EACAC,EACA,CACA,OAAO,KAAK,cAAc,KAAK,YAAY,CACzCF,EACAD,EAAAA,iBAAiBF,CAAQ,EAAE,KAAK,KAAK,EACrCI,EACAC,CAAA,CACD,CACH,CAQO,gBAAiB,CACtB,OAAO,KAAK,YAAA,EAAc,KAAK,eAAe,CAChD,CAqBA,MAAa,QAAQC,EAAoC,CACjD,KAAA,CACJ,MAAAC,EACA,QAAAC,EACA,UAAAC,EACA,MAAAC,EACA,WAAAC,EACA,cAAAC,EAAgB,EACd,EAAAN,EAIJ,IAAIO,EAAa,CACf,EAAGC,EAAAA,OAAO,KAAM,CAAE,KAAM,GAAI,EAC5B,EAAGA,EAAAA,OAAO,KAAM,CAAE,KAAM,GAAI,EAC5B,EAAG,EACH,SAAU,GACV,OAAQJ,CAAA,EAGV,GAAI,CAACE,EAAe,CAClB,KAAM,CAAE,EAAAG,EAAG,EAAAC,EAAG,EAAAC,EAAG,QAAAC,EAAS,SAAAC,GAAa,MAAM,KAAK,mBAC/C,UAAUZ,CAAK,EACf,mBACCC,EACAb,qBAAmB,KAAK,KAAK,EAAE,UAC/Be,CAAA,EAGSG,EAAA,CACX,EAAAE,EACA,EAAAC,EACA,EAAG,OAAOC,GAAKC,CAAO,EACtB,SAAAC,EACA,OAAQT,CAAA,CAEZ,CAEA,MAAMU,EAAqB,CACzBlB,EAAAA,iBAAiBK,CAAK,EAAE,KAAK,KAAK,EAClCE,EACAE,EACAE,CAAA,EAaK,MAAA,CAAE,SAVQ,IACf,KAAK,YAAc,EAAA,MAAM,QAAQO,EAAa,CAC5C,QAAAZ,EACA,MAAO,KAAK,SAAA,CACb,EAMgB,SALF,IACf,KAAK,YAAc,EAAA,YAAY,QAAQY,EAAa,CAClD,QAAAZ,CAAA,CACD,EAGL,CAYO,SACLR,EACAC,EACAQ,EACAY,EACA,CACA,MAAMC,EAAsB,CAC1BpB,EAAAA,iBAAiBF,CAAQ,EAAE,KAAK,KAAK,EACrCqB,EACAZ,CAAA,EAaK,MAAA,CAAE,SAVQ,IACf,KAAK,YAAc,EAAA,MAAM,SAASa,EAAc,CAC9C,QAASrB,EACT,MAAO,KAAK,SAAA,CACb,EAMgB,SALF,IACf,KAAK,YAAc,EAAA,YAAY,SAASqB,EAAc,CACpD,QAASrB,CAAA,CACV,EAGL,CACF"}
|