@pufferfinance/puffer-sdk 1.13.0 → 1.13.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 +70 -65
- 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-BO_b9tFc.cjs → ccip-C0xwQhXU.cjs} +2 -2
- package/dist/ccip-C0xwQhXU.cjs.map +1 -0
- package/dist/{ccip-DLDO0_x2.js → ccip-K-z2PL4P.js} +3 -3
- package/dist/ccip-K-z2PL4P.js.map +1 -0
- package/dist/chains/constants.cjs +1 -1
- package/dist/chains/constants.js +1 -1
- package/dist/constants-BcPRVxdH.cjs +9 -0
- package/dist/constants-BcPRVxdH.cjs.map +1 -0
- package/dist/{constants-BjRNQpT2.js → constants-CH7Tz5jz.js} +745 -694
- package/dist/constants-CH7Tz5jz.js.map +1 -0
- package/dist/contracts/abis/l1-reward-manager-abis.cjs +1 -1
- package/dist/contracts/abis/l1-reward-manager-abis.d.ts +527 -1
- package/dist/contracts/abis/l1-reward-manager-abis.js +1 -1
- package/dist/contracts/abis/l2-reward-manager-abis.cjs +1 -1
- package/dist/contracts/abis/l2-reward-manager-abis.d.ts +1416 -1
- package/dist/contracts/abis/l2-reward-manager-abis.js +1 -1
- package/dist/contracts/abis/nucleus-accountant-abis.cjs +1 -1
- package/dist/contracts/abis/nucleus-accountant-abis.d.ts +2 -1
- package/dist/contracts/abis/nucleus-accountant-abis.js +1 -1
- package/dist/contracts/abis/nucleus-atomic-queue-abis.cjs +1 -1
- package/dist/contracts/abis/nucleus-atomic-queue-abis.d.ts +2 -1
- package/dist/contracts/abis/nucleus-atomic-queue-abis.js +1 -1
- package/dist/contracts/abis/nucleus-boring-vault-abis.cjs +1 -1
- package/dist/contracts/abis/nucleus-boring-vault-abis.d.ts +2 -1
- package/dist/contracts/abis/nucleus-boring-vault-abis.js +1 -1
- package/dist/contracts/abis/nucleus-teller-abis.cjs +1 -1
- package/dist/contracts/abis/nucleus-teller-abis.d.ts +2 -1
- package/dist/contracts/abis/nucleus-teller-abis.js +1 -1
- package/dist/contracts/abis/puf-locker-abis.cjs +1 -1
- package/dist/contracts/abis/puf-locker-abis.d.ts +484 -1
- package/dist/contracts/abis/puf-locker-abis.js +1 -1
- package/dist/contracts/abis/puffer-depositor-abis.cjs +1 -1
- package/dist/contracts/abis/puffer-depositor-abis.d.ts +663 -2
- package/dist/contracts/abis/puffer-depositor-abis.js +1 -1
- package/dist/contracts/abis/puffer-vault-abis.cjs +1 -1
- package/dist/contracts/abis/puffer-vault-abis.d.ts +4 -2
- package/dist/contracts/abis/puffer-vault-abis.js +1 -1
- package/dist/contracts/abis/puffer-withdrawal-manager-abis.cjs +1 -1
- package/dist/contracts/abis/puffer-withdrawal-manager-abis.d.ts +514 -1
- package/dist/contracts/abis/puffer-withdrawal-manager-abis.js +1 -1
- package/dist/contracts/addresses.cjs +1 -1
- package/dist/contracts/addresses.d.ts +6 -15
- package/dist/contracts/addresses.js +1 -1
- package/dist/contracts/handlers/carrot-staking-handler.cjs +1 -1
- 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.js +2 -2
- 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 +17101 -14898
- package/dist/contracts/handlers/erc20-permit-handler.js +3 -3
- 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.js +2 -2
- package/dist/contracts/handlers/l2-reward-manager-handler.cjs +1 -1
- package/dist/contracts/handlers/l2-reward-manager-handler.js +2 -2
- package/dist/contracts/handlers/mtw-carrot-handler.cjs +1 -1
- 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.js +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 +7619 -14812
- package/dist/contracts/handlers/nucleus-atomic-queue-handler.js +2 -2
- 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.js +2 -2
- package/dist/contracts/handlers/nucleus-teller-handler.cjs +1 -1
- package/dist/contracts/handlers/nucleus-teller-handler.js +2 -2
- 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.js +2 -2
- 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.d.ts +11215 -14794
- package/dist/contracts/handlers/puffer-depositor-handler.js +2 -2
- package/dist/contracts/handlers/puffer-l2-depositor-handler.cjs +1 -1
- package/dist/contracts/handlers/puffer-l2-depositor-handler.js +2 -2
- package/dist/contracts/handlers/puffer-vault-handler.cjs +1 -1
- package/dist/contracts/handlers/puffer-vault-handler.js +2 -2
- package/dist/contracts/handlers/puffer-withdrawal-manager-handler.cjs +1 -1
- package/dist/contracts/handlers/puffer-withdrawal-manager-handler.js +2 -2
- package/dist/contracts/tokens.cjs +1 -1
- package/dist/contracts/tokens.js +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 +3289 -0
- package/dist/createWalletClient-DNLhBkOd.js.map +1 -0
- package/dist/createWalletClient-Di5of07E.cjs +6 -0
- package/dist/createWalletClient-Di5of07E.cjs.map +1 -0
- package/dist/{getContract-CezEyDf-.js → getContract-6ajhFbP2.js} +2 -2
- package/dist/getContract-6ajhFbP2.js.map +1 -0
- package/dist/{getContract-3QbyfZBF.cjs → getContract-ChPFzc5y.cjs} +2 -2
- package/dist/{getContract-CezEyDf-.js.map → getContract-ChPFzc5y.cjs.map} +1 -1
- package/dist/main.cjs +1 -1
- package/dist/main.js +1 -1
- package/dist/secp256k1-B8plqpXf.cjs +2 -0
- package/dist/secp256k1-B8plqpXf.cjs.map +1 -0
- package/dist/secp256k1-Ev0s9Yr6.js +1340 -0
- package/dist/secp256k1-Ev0s9Yr6.js.map +1 -0
- package/dist/utils/version.cjs +1 -1
- package/dist/utils/version.js +1 -1
- package/dist/writeContract-BatuNuTe.cjs +32 -0
- package/dist/writeContract-BatuNuTe.cjs.map +1 -0
- package/dist/{writeContract-ChuHpJLC.js → writeContract-CjcOEtWX.js} +822 -763
- package/dist/writeContract-CjcOEtWX.js.map +1 -0
- package/package.json +15 -15
- package/dist/ccip-BO_b9tFc.cjs.map +0 -1
- package/dist/ccip-DLDO0_x2.js.map +0 -1
- package/dist/constants-BjRNQpT2.js.map +0 -1
- package/dist/constants-DA2xUb9r.cjs +0 -9
- package/dist/constants-DA2xUb9r.cjs.map +0 -1
- package/dist/contracts/handlers/carrot-staking-handler.d.ts +0 -15063
- package/dist/contracts/handlers/distributor-handler.d.ts +0 -15369
- package/dist/contracts/handlers/l1-reward-manager-handler.d.ts +0 -15107
- package/dist/contracts/handlers/l2-reward-manager-handler.d.ts +0 -15353
- package/dist/contracts/handlers/mtw-carrot-handler.d.ts +0 -15293
- package/dist/contracts/handlers/nucleus-accountant-handler.d.ts +0 -15126
- package/dist/contracts/handlers/nucleus-boring-vault-handler.d.ts +0 -15284
- package/dist/contracts/handlers/nucleus-teller-handler.d.ts +0 -15201
- package/dist/contracts/handlers/puf-locker-handler.d.ts +0 -15116
- package/dist/contracts/handlers/puffer-l2-depositor-handler.d.ts +0 -14969
- package/dist/contracts/handlers/puffer-vault-handler.d.ts +0 -17452
- package/dist/contracts/handlers/puffer-withdrawal-manager-handler.d.ts +0 -15111
- package/dist/createWalletClient-BuLYysrp.cjs +0 -4
- package/dist/createWalletClient-BuLYysrp.cjs.map +0 -1
- package/dist/createWalletClient-DNcW-ENe.js +0 -2028
- package/dist/createWalletClient-DNcW-ENe.js.map +0 -1
- package/dist/getContract-3QbyfZBF.cjs.map +0 -1
- package/dist/secp256k1-3OC5y4qp.js +0 -1579
- package/dist/secp256k1-3OC5y4qp.js.map +0 -1
- package/dist/secp256k1-bcahnPX9.cjs +0 -2
- package/dist/secp256k1-bcahnPX9.cjs.map +0 -1
- package/dist/writeContract-ChuHpJLC.js.map +0 -1
- package/dist/writeContract-D97dSJQe.cjs +0 -32
- package/dist/writeContract-D97dSJQe.cjs.map +0 -1
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
var a = Object.defineProperty;
|
|
2
2
|
var n = (s, t, e) => t in s ? a(s, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : s[t] = e;
|
|
3
3
|
var c = (s, t, e) => n(s, typeof t != "symbol" ? t + "" : t, e);
|
|
4
|
-
import { V as u } from "../../constants-
|
|
4
|
+
import { V as u } from "../../constants-CH7Tz5jz.js";
|
|
5
5
|
import { CONTRACT_ADDRESSES as l } from "../addresses.js";
|
|
6
6
|
import { NUCLEUS_ATOMIC_QUEUE_ABIS as h } from "../abis/nucleus-atomic-queue-abis.js";
|
|
7
|
-
import { g as m } from "../../getContract-
|
|
7
|
+
import { g as m } from "../../getContract-6ajhFbP2.js";
|
|
8
8
|
class R {
|
|
9
9
|
constructor(t, e, i) {
|
|
10
10
|
c(this, "viemChain");
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"nucleus-atomic-queue-handler.js","sources":["../../../lib/contracts/handlers/nucleus-atomic-queue-handler.ts"],"sourcesContent":["import {\n WalletClient,\n PublicClient,\n getContract,\n Address,\n GetContractReturnType,\n Account,\n
|
|
1
|
+
{"version":3,"file":"nucleus-atomic-queue-handler.js","sources":["../../../lib/contracts/handlers/nucleus-atomic-queue-handler.ts"],"sourcesContent":["import {\n WalletClient,\n PublicClient,\n getContract,\n Address,\n GetContractReturnType,\n Account,\n Chain,\n} from 'viem';\nimport { Chain as LocalChain, VIEM_CHAINS } from '../../chains/constants';\nimport { CONTRACT_ADDRESSES } from '../addresses';\nimport { NUCLEUS_ATOMIC_QUEUE_ABIS } from '../abis/nucleus-atomic-queue-abis';\n\nexport type AtomicRequest = {\n deadline: bigint;\n atomicPrice: bigint;\n offerAmount: bigint;\n inSolve: boolean;\n};\n\nexport type SolveMetaData = {\n user: Address;\n flags: number;\n assetsToOffer: bigint;\n assetsForWant: bigint;\n};\n\n/**\n * Handler for the `AtomicQueue` contract.\n */\nexport class NucleusAtomicQueueHandler {\n private viemChain: Chain;\n\n constructor(\n private chain: LocalChain,\n private walletClient: WalletClient,\n private publicClient: PublicClient,\n ) {\n this.viemChain = VIEM_CHAINS[chain];\n }\n\n public getContract() {\n const address = CONTRACT_ADDRESSES[this.chain]\n .NucleusAtomicQueue as Address;\n const abi = NUCLEUS_ATOMIC_QUEUE_ABIS[this.chain].AtomicQueue;\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 atomic request details for a specific user (wallet address).\n * @param user User address\n * @param offerToken Token being offered\n * @param wantToken Token being requested\n */\n public getUserAtomicRequest(\n user: Address,\n offerToken: Address,\n wantToken: Address,\n ) {\n return this.getContract().read.getUserAtomicRequest([\n user,\n offerToken,\n wantToken,\n ]);\n }\n\n /**\n * Check if an atomic request is valid.\n * @param offerToken Token being offered\n * @param user User address\n * @param request Atomic request details\n */\n public isAtomicRequestValid(\n offerToken: Address,\n user: Address,\n request: AtomicRequest,\n ) {\n return this.getContract().read.isAtomicRequestValid([\n offerToken,\n user,\n request,\n ]);\n }\n\n /**\n * Solve atomic requests for multiple users.\n * @param offerToken Token being offered\n * @param wantToken Token being requested\n * @param users Array of user addresses\n * @param runData Execution data for the solve\n * @param solver Address of the solver\n */\n public solve(\n offerToken: Address,\n wantToken: Address,\n users: Address[],\n runData: `0x${string}`,\n solver: Address,\n ) {\n return this.getContract().write.solve(\n [offerToken, wantToken, users, runData, solver],\n {\n account: this.walletClient.account as Account,\n chain: this.viemChain,\n },\n );\n }\n\n /**\n * Update an atomic request.\n * @param offerToken Token being offered\n * @param wantToken Token being requested\n * @param request New atomic request details\n */\n public updateAtomicRequest(\n offerToken: Address,\n wantToken: Address,\n request: AtomicRequest,\n ownerAddress: Address,\n ) {\n return this.getContract().write.updateAtomicRequest(\n [offerToken, wantToken, request],\n { account: ownerAddress, chain: this.viemChain },\n );\n }\n\n /**\n * Get user's atomic request details directly from storage.\n * @param user User address\n * @param offerToken Token being offered\n * @param wantToken Token being requested\n */\n public userAtomicRequest(\n user: Address,\n offerToken: Address,\n wantToken: Address,\n ) {\n return this.getContract().read.userAtomicRequest([\n user,\n offerToken,\n wantToken,\n ]);\n }\n}\n"],"names":["NucleusAtomicQueueHandler","chain","walletClient","publicClient","__publicField","VIEM_CHAINS","address","CONTRACT_ADDRESSES","abi","NUCLEUS_ATOMIC_QUEUE_ABIS","client","getContract","user","offerToken","wantToken","request","users","runData","solver","ownerAddress"],"mappings":";;;;;;;AA8BO,MAAMA,EAA0B;AAAA,EAGrC,YACUC,GACAC,GACAC,GACR;AANM,IAAAC,EAAA;AAGE,SAAA,QAAAH,GACA,KAAA,eAAAC,GACA,KAAA,eAAAC,GAEH,KAAA,YAAYE,EAAYJ,CAAK;AAAA,EAAA;AAAA,EAG7B,cAAc;AACnB,UAAMK,IAAUC,EAAmB,KAAK,KAAK,EAC1C,oBACGC,IAAMC,EAA0B,KAAK,KAAK,EAAE,aAC5CC,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,EAatC,qBACLE,GACAC,GACAC,GACA;AACA,WAAO,KAAK,cAAc,KAAK,qBAAqB;AAAA,MAClDF;AAAA,MACAC;AAAA,MACAC;AAAA,IAAA,CACD;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASI,qBACLD,GACAD,GACAG,GACA;AACA,WAAO,KAAK,cAAc,KAAK,qBAAqB;AAAA,MAClDF;AAAA,MACAD;AAAA,MACAG;AAAA,IAAA,CACD;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAWI,MACLF,GACAC,GACAE,GACAC,GACAC,GACA;AACO,WAAA,KAAK,cAAc,MAAM;AAAA,MAC9B,CAACL,GAAYC,GAAWE,GAAOC,GAASC,CAAM;AAAA,MAC9C;AAAA,QACE,SAAS,KAAK,aAAa;AAAA,QAC3B,OAAO,KAAK;AAAA,MAAA;AAAA,IAEhB;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASK,oBACLL,GACAC,GACAC,GACAI,GACA;AACO,WAAA,KAAK,cAAc,MAAM;AAAA,MAC9B,CAACN,GAAYC,GAAWC,CAAO;AAAA,MAC/B,EAAE,SAASI,GAAc,OAAO,KAAK,UAAU;AAAA,IACjD;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASK,kBACLP,GACAC,GACAC,GACA;AACA,WAAO,KAAK,cAAc,KAAK,kBAAkB;AAAA,MAC/CF;AAAA,MACAC;AAAA,MACAC;AAAA,IAAA,CACD;AAAA,EAAA;AAEL;"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var l=Object.defineProperty;var C=(a,t,e)=>t in a?l(a,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):a[t]=e;var c=(a,t,e)=>C(a,typeof t!="symbol"?t+"":t,e);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const g=require("../../constants-
|
|
1
|
+
"use strict";var l=Object.defineProperty;var C=(a,t,e)=>t in a?l(a,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):a[t]=e;var c=(a,t,e)=>C(a,typeof t!="symbol"?t+"":t,e);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const g=require("../../constants-BcPRVxdH.cjs"),m=require("../abis/nucleus-boring-vault-abis.cjs"),p=require("../vaults-addresses.cjs"),S=require("../tokens.cjs"),b=require("../../getContract-ChPFzc5y.cjs");class f{constructor(t,e,n){c(this,"viemChain");c(this,"token");this.chain=t,this.walletClient=e,this.publicClient=n,this.viemChain=g.VIEM_CHAINS[t],this.token=S.UnifiToken.unifiETH}withToken(t){return this.token=t,this}getContract(){const t=p.VAULTS_ADDRESSES[this.token][this.chain].NucleusBoringVault,e=m.NUCLEUS_BORING_VAULT_ABIS[this.chain].BoringVault,n={public:this.publicClient,wallet:this.walletClient};return b.getContract({address:t,abi:e,client:n})}getAllowance(t,e){return this.getContract().read.allowance([t,e])}balanceOf(t){return this.getContract().read.balanceOf([t])}totalSupply(){return this.getContract().read.totalSupply()}approve(t,e,n){return this.getContract().write.approve([e,n],{account:t,chain:this.viemChain})}transfer(t,e,n){return{transact:()=>this.getContract().write.transfer([e,n],{account:t,chain:this.viemChain}),estimate:()=>this.getContract().estimateGas.transfer([e,n],{account:t})}}transferFrom(t,e,n,i){return{transact:()=>this.getContract().write.transferFrom([e,n,i],{account:t,chain:this.viemChain}),estimate:()=>this.getContract().estimateGas.transferFrom([e,n,i],{account:t})}}permit(t){const{account:e,owner:n,spender:i,value:r,deadline:s,v:o,r:u,s:h}=t;return{transact:()=>this.getContract().write.permit([n,i,r,s,o,u,h],{account:e,chain:this.viemChain}),estimate:()=>this.getContract().estimateGas.permit([n,i,r,s,o,u,h],{account:e})}}}exports.NucleusBoringVaultHandler=f;
|
|
2
2
|
//# sourceMappingURL=nucleus-boring-vault-handler.cjs.map
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
var u = Object.defineProperty;
|
|
2
2
|
var l = (e, t, n) => t in e ? u(e, t, { enumerable: !0, configurable: !0, writable: !0, value: n }) : e[t] = n;
|
|
3
3
|
var c = (e, t, n) => l(e, typeof t != "symbol" ? t + "" : t, n);
|
|
4
|
-
import { V as C } from "../../constants-
|
|
4
|
+
import { V as C } from "../../constants-CH7Tz5jz.js";
|
|
5
5
|
import { NUCLEUS_BORING_VAULT_ABIS as p } from "../abis/nucleus-boring-vault-abis.js";
|
|
6
6
|
import { VAULTS_ADDRESSES as g } from "../vaults-addresses.js";
|
|
7
7
|
import { UnifiToken as f } from "../tokens.js";
|
|
8
|
-
import { g as w } from "../../getContract-
|
|
8
|
+
import { g as w } from "../../getContract-6ajhFbP2.js";
|
|
9
9
|
class T {
|
|
10
10
|
/**
|
|
11
11
|
* Create the handler for processing UniFi tokens.
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var S=Object.defineProperty;var P=(r,t,e)=>t in r?S(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e;var u=(r,t,e)=>P(r,typeof t!="symbol"?t+"":t,e);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const T=require("../../constants-
|
|
1
|
+
"use strict";var S=Object.defineProperty;var P=(r,t,e)=>t in r?S(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e;var u=(r,t,e)=>P(r,typeof t!="symbol"?t+"":t,e);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const T=require("../../constants-BcPRVxdH.cjs"),p=require("../vaults-addresses.cjs"),k=require("../abis/nucleus-teller-abis.cjs"),l=require("../tokens.cjs"),E=require("./erc20-permit-handler.cjs"),_=require("../../getContract-ChPFzc5y.cjs");class v{constructor(t,e,i){u(this,"viemChain");u(this,"erc20PermitHandler");u(this,"token");this.chain=t,this.walletClient=e,this.publicClient=i,this.viemChain=T.VIEM_CHAINS[t],this.erc20PermitHandler=new E.ERC20PermitHandler(t,e,i),this.token=l.UnifiToken.unifiETH}withToken(t){return this.token=t,this}getContract(){const t=p.VAULTS_ADDRESSES[this.token][this.chain].NucleusTeller,e=k.NUCLEUS_TELLER_ABIS[this.chain].Teller,i={public:this.publicClient,wallet:this.walletClient};return _.getContract({address:t,abi:e,client:i})}accountant(){return this.getContract().read.accountant()}vault(){return this.getContract().read.vault()}shareLockPeriod(){return this.getContract().read.shareLockPeriod()}shareUnlockTime(t){return this.getContract().read.shareUnlockTime([t])}isPaused(){return this.getContract().read.isPaused()}async deposit(t){const{token:e,unifiToken:i,account:s,amount:n,minimumMint:a,isPreapproved:o=!1}=t,c=l.TOKENS_ADDRESSES[e][this.chain];if(o)return{transact:()=>this.getContract().write.deposit([c,n,a],{account:s,chain:this.viemChain}),estimate:()=>this.getContract().estimateGas.deposit([c,n,a],{account:s})};const{r:h,s:d,v:m,deadline:g}=await this.erc20PermitHandler.withToken(e).getPermitSignature(s,l.TOKENS_ADDRESSES[i][this.chain],n),C=[c,n,a,g,Number(m),h,d];return{transact:()=>this.getContract().write.depositWithPermit(C,{account:s,chain:this.viemChain}),estimate:()=>this.getContract().estimateGas.depositWithPermit(C,{account:s})}}depositWithPermit(t){const{account:e,depositAsset:i,depositAmount:s,minimumMint:n,deadline:a,v:o,r:c,s:h}=t;return{transact:()=>this.getContract().write.depositWithPermit([i,s,n,a,o,c,h],{account:e,chain:this.viemChain}),estimate:()=>this.getContract().estimateGas.depositWithPermit([i,s,n,a,o,c,h],{account:e})}}}exports.NucleusTellerHandler=v;
|
|
2
2
|
//# sourceMappingURL=nucleus-teller-handler.cjs.map
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
var g = Object.defineProperty;
|
|
2
2
|
var P = (n, t, e) => t in n ? g(n, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : n[t] = e;
|
|
3
3
|
var m = (n, t, e) => P(n, typeof t != "symbol" ? t + "" : t, e);
|
|
4
|
-
import { V as k } from "../../constants-
|
|
4
|
+
import { V as k } from "../../constants-CH7Tz5jz.js";
|
|
5
5
|
import { VAULTS_ADDRESSES as T } from "../vaults-addresses.js";
|
|
6
6
|
import { NUCLEUS_TELLER_ABIS as S } from "../abis/nucleus-teller-abis.js";
|
|
7
7
|
import { UnifiToken as f, TOKENS_ADDRESSES as C } from "../tokens.js";
|
|
8
8
|
import { ERC20PermitHandler as E } from "./erc20-permit-handler.js";
|
|
9
|
-
import { g as v } from "../../getContract-
|
|
9
|
+
import { g as v } from "../../getContract-6ajhFbP2.js";
|
|
10
10
|
class D {
|
|
11
11
|
/**
|
|
12
12
|
* Create the handler for processing tokens.
|
|
@@ -1,2 +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-
|
|
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-BcPRVxdH.cjs"),_=require("../abis/puf-locker-abis.cjs"),S=require("../addresses.cjs"),n=require("../tokens.cjs"),w=require("./erc20-permit-handler.cjs"),A=require("../../getContract-ChPFzc5y.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
2
|
//# sourceMappingURL=puf-locker-handler.cjs.map
|
|
@@ -1 +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 {
|
|
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 { AnyToken, TOKENS_ADDRESSES } from '../tokens';\nimport { ERC20PermitHandler } from './erc20-permit-handler';\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 = 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: 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 = {\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: 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","__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,CACF,CAAA,CASK,aAAc,CACnB,MAAMI,EAAUC,EAAA,mBAAmB,KAAK,KAAK,EAAE,UACzCC,EAAMC,EAAA,gBAAgB,KAAK,KAAK,EAAE,UAClCC,EAAS,CAAE,OAAQ,KAAK,aAAc,OAAQ,KAAK,YAAa,EAEtE,OAAOC,EAAY,YAAA,CAAE,QAAAL,EAAS,IAAAE,EAAK,OAAAE,EAAQ,CAAA,CActC,eAAeE,EAAoBC,EAAwB,CAChE,OAAO,KAAK,cAAc,KAAK,eAAe,CAC5CC,EAAAA,iBAAiBF,CAAQ,EAAE,KAAK,KAAK,EACrCC,CAAA,CACD,CAAA,CAYI,YACLD,EACAG,EACAC,EACAC,EACA,CACA,OAAO,KAAK,cAAc,KAAK,YAAY,CACzCF,EACAD,EAAAA,iBAAiBF,CAAQ,EAAE,KAAK,KAAK,EACrCI,EACAC,CAAA,CACD,CAAA,CASI,gBAAiB,CACtB,OAAO,KAAK,cAAc,KAAK,eAAe,CAAA,CAsBhD,MAAa,QAAQC,EAAoC,CACjD,KAAA,CACJ,MAAAC,EACA,QAAAC,EACA,UAAAC,EACA,MAAAC,EACA,WAAAC,EACA,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,OAAQJ,CACV,EAEA,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,CACF,EAEWG,EAAA,CACX,EAAAE,EACA,EAAAC,EACA,EAAG,OAAOC,GAAKC,CAAO,EACtB,SAAAC,EACA,OAAQT,CACV,CAAA,CAGF,MAAMU,EAAqB,CACzBlB,EAAAA,iBAAiBK,CAAK,EAAE,KAAK,KAAK,EAClCE,EACAE,EACAE,CACF,EAYO,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,CAEyB,CAAA,CAavB,SACLR,EACAC,EACAQ,EACAY,EACA,CACA,MAAMC,EAAsB,CAC1BpB,EAAAA,iBAAiBF,CAAQ,EAAE,KAAK,KAAK,EACrCqB,EACAZ,CACF,EAYO,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,CAEyB,CAAA,CAEhC"}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
var f = Object.defineProperty;
|
|
2
2
|
var S = (r, t, e) => t in r ? f(r, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : r[t] = e;
|
|
3
3
|
var o = (r, t, e) => S(r, typeof t != "symbol" ? t + "" : t, e);
|
|
4
|
-
import { V as k, p as l } from "../../constants-
|
|
4
|
+
import { V as k, p as l } from "../../constants-CH7Tz5jz.js";
|
|
5
5
|
import { PUF_LOCKER_ABIS as v } from "../abis/puf-locker-abis.js";
|
|
6
6
|
import { CONTRACT_ADDRESSES as p } from "../addresses.js";
|
|
7
7
|
import { TOKENS_ADDRESSES as n } from "../tokens.js";
|
|
8
8
|
import { ERC20PermitHandler as D } from "./erc20-permit-handler.js";
|
|
9
|
-
import { g as A } from "../../getContract-
|
|
9
|
+
import { g as A } from "../../getContract-6ajhFbP2.js";
|
|
10
10
|
class y {
|
|
11
11
|
/**
|
|
12
12
|
* Create the handler for the `PufLocker` contract exposing methods to
|
|
@@ -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 { PUF_LOCKER_ABIS } from '../abis/puf-locker-abis';\nimport { CONTRACT_ADDRESSES } from '../addresses';\nimport {
|
|
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 { PUF_LOCKER_ABIS } from '../abis/puf-locker-abis';\nimport { CONTRACT_ADDRESSES } from '../addresses';\nimport { AnyToken, TOKENS_ADDRESSES } from '../tokens';\nimport { ERC20PermitHandler } from './erc20-permit-handler';\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 = 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: 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 = {\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: 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","__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":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var p=Object.defineProperty;var P=(n,t,e)=>t in n?p(n,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):n[t]=e;var h=(n,t,e)=>P(n,typeof t!="symbol"?t+"":t,e);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const S=require("../../constants-
|
|
1
|
+
"use strict";var p=Object.defineProperty;var P=(n,t,e)=>t in n?p(n,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):n[t]=e;var h=(n,t,e)=>P(n,typeof t!="symbol"?t+"":t,e);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const S=require("../../constants-BcPRVxdH.cjs"),E=require("../abis/puffer-depositor-abis.cjs"),u=require("../addresses.cjs"),H=require("./erc20-permit-handler.cjs"),m=require("../tokens.cjs"),D=require("../../getContract-ChPFzc5y.cjs");class f{constructor(t,e,i){h(this,"viemChain");h(this,"erc20PermitHandler");this.chain=t,this.walletClient=e,this.publicClient=i,this.viemChain=S.VIEM_CHAINS[t],this.erc20PermitHandler=new H.ERC20PermitHandler(t,e,i)}getContract(){const t=u.CONTRACT_ADDRESSES[this.chain].PufferDepositor,e=E.PUFFER_DEPOSITOR_ABIS[this.chain].PufferDepositor,i={public:this.publicClient,wallet:this.walletClient};return D.getContract({address:t,abi:e,client:i})}async depositStETH(t,e){const{r:i,s:a,v:s,yParity:c,deadline:o}=await this.erc20PermitHandler.withToken(m.Token.stETH).getPermitSignature(t,u.CONTRACT_ADDRESSES[this.chain].PufferDepositor,e),r={r:i,s:a,v:Number(s??c),deadline:o,amount:e};return{transact:async()=>await this.getContract().write.depositStETH([r,t],{account:t,chain:this.viemChain}),estimate:async()=>await this.getContract().estimateGas.depositStETH([r,t],{account:t})}}async depositWstETH(t,e){const{r:i,s:a,v:s,yParity:c,deadline:o}=await this.erc20PermitHandler.withToken(m.Token.wstETH).getPermitSignature(t,u.CONTRACT_ADDRESSES[this.chain].PufferDepositor,e),r={r:i,s:a,v:Number(s??c),deadline:o,amount:e};return{transact:async()=>await this.getContract().write.depositWstETH([r,t],{account:t,chain:this.viemChain}),estimate:async()=>await this.getContract().estimateGas.depositWstETH([r,t],{account:t})}}}exports.PufferDepositorHandler=f;
|
|
2
2
|
//# sourceMappingURL=puffer-depositor-handler.cjs.map
|