@pufferfinance/puffer-sdk 1.30.2 → 1.31.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.
Files changed (155) hide show
  1. package/dist/api/puffer-client-helpers.cjs +1 -1
  2. package/dist/api/puffer-client-helpers.cjs.map +1 -1
  3. package/dist/api/puffer-client-helpers.js +42 -42
  4. package/dist/api/puffer-client-helpers.js.map +1 -1
  5. package/dist/api/puffer-client.cjs +1 -1
  6. package/dist/api/puffer-client.js +2 -2
  7. package/dist/ccip-DLz1DupU.cjs +2 -0
  8. package/dist/ccip-DLz1DupU.cjs.map +1 -0
  9. package/dist/ccip-oHxlHOaH.js +158 -0
  10. package/dist/ccip-oHxlHOaH.js.map +1 -0
  11. package/dist/chains/constants.cjs +1 -1
  12. package/dist/chains/constants.d.ts +2 -1
  13. package/dist/chains/constants.js +1 -1
  14. package/dist/constants-C-rrOSfg.js +3837 -0
  15. package/dist/constants-C-rrOSfg.js.map +1 -0
  16. package/dist/constants-PXB3A4Yl.cjs +38 -0
  17. package/dist/constants-PXB3A4Yl.cjs.map +1 -0
  18. package/dist/contracts/abis/mainnet/Teller.cjs +1 -1
  19. package/dist/contracts/abis/mainnet/Teller.cjs.map +1 -1
  20. package/dist/contracts/abis/mainnet/Teller.d.ts +234 -18
  21. package/dist/contracts/abis/mainnet/Teller.js +165 -13
  22. package/dist/contracts/abis/mainnet/Teller.js.map +1 -1
  23. package/dist/contracts/addresses.cjs +1 -1
  24. package/dist/contracts/addresses.js +1 -1
  25. package/dist/contracts/handlers/carrot-staking-handler.cjs +1 -1
  26. package/dist/contracts/handlers/carrot-staking-handler.d.ts +1549 -5281
  27. package/dist/contracts/handlers/carrot-staking-handler.js +2 -2
  28. package/dist/contracts/handlers/carrot-vesting-handler.cjs +1 -1
  29. package/dist/contracts/handlers/carrot-vesting-handler.d.ts +1549 -5281
  30. package/dist/contracts/handlers/carrot-vesting-handler.js +2 -2
  31. package/dist/contracts/handlers/concrete-vault-handler.cjs +1 -1
  32. package/dist/contracts/handlers/concrete-vault-handler.d.ts +1549 -5281
  33. package/dist/contracts/handlers/concrete-vault-handler.js +2 -2
  34. package/dist/contracts/handlers/distributor-handler.cjs +1 -1
  35. package/dist/contracts/handlers/distributor-handler.d.ts +1549 -5281
  36. package/dist/contracts/handlers/distributor-handler.js +2 -2
  37. package/dist/contracts/handlers/erc20-permit-handler.cjs +1 -1
  38. package/dist/contracts/handlers/erc20-permit-handler.cjs.map +1 -1
  39. package/dist/contracts/handlers/erc20-permit-handler.d.ts +1549 -5281
  40. package/dist/contracts/handlers/erc20-permit-handler.js +3 -3
  41. package/dist/contracts/handlers/erc20-permit-handler.js.map +1 -1
  42. package/dist/contracts/handlers/gauge-registry-handler.cjs +1 -1
  43. package/dist/contracts/handlers/gauge-registry-handler.d.ts +1549 -5281
  44. package/dist/contracts/handlers/gauge-registry-handler.js +2 -2
  45. package/dist/contracts/handlers/guardian-module-handler.cjs +1 -1
  46. package/dist/contracts/handlers/guardian-module-handler.d.ts +1549 -5281
  47. package/dist/contracts/handlers/guardian-module-handler.js +2 -2
  48. package/dist/contracts/handlers/institutional-access-manager-handler.cjs +1 -1
  49. package/dist/contracts/handlers/institutional-access-manager-handler.cjs.map +1 -1
  50. package/dist/contracts/handlers/institutional-access-manager-handler.d.ts +1549 -5281
  51. package/dist/contracts/handlers/institutional-access-manager-handler.js +48 -49
  52. package/dist/contracts/handlers/institutional-access-manager-handler.js.map +1 -1
  53. package/dist/contracts/handlers/institutional-vault-handler.cjs +1 -1
  54. package/dist/contracts/handlers/institutional-vault-handler.d.ts +1549 -5281
  55. package/dist/contracts/handlers/institutional-vault-handler.js +2 -2
  56. package/dist/contracts/handlers/l1-reward-manager-handler.cjs +1 -1
  57. package/dist/contracts/handlers/l1-reward-manager-handler.d.ts +1549 -5281
  58. package/dist/contracts/handlers/l1-reward-manager-handler.js +2 -2
  59. package/dist/contracts/handlers/l2-reward-manager-handler.cjs +1 -1
  60. package/dist/contracts/handlers/l2-reward-manager-handler.d.ts +1549 -5281
  61. package/dist/contracts/handlers/l2-reward-manager-handler.js +2 -2
  62. package/dist/contracts/handlers/lagoon-vault-handler.cjs +1 -1
  63. package/dist/contracts/handlers/lagoon-vault-handler.d.ts +1549 -5281
  64. package/dist/contracts/handlers/lagoon-vault-handler.js +2 -2
  65. package/dist/contracts/handlers/mtw-carrot-handler.cjs +1 -1
  66. package/dist/contracts/handlers/mtw-carrot-handler.d.ts +1549 -5281
  67. package/dist/contracts/handlers/mtw-carrot-handler.js +2 -2
  68. package/dist/contracts/handlers/non-restaking-withdrawal-credentials-handler.cjs +1 -1
  69. package/dist/contracts/handlers/non-restaking-withdrawal-credentials-handler.d.ts +1549 -5281
  70. package/dist/contracts/handlers/non-restaking-withdrawal-credentials-handler.js +2 -2
  71. package/dist/contracts/handlers/nucleus-accountant-handler.cjs +1 -1
  72. package/dist/contracts/handlers/nucleus-accountant-handler.d.ts +1549 -5281
  73. package/dist/contracts/handlers/nucleus-accountant-handler.js +1 -1
  74. package/dist/contracts/handlers/nucleus-atomic-queue-handler.cjs +1 -1
  75. package/dist/contracts/handlers/nucleus-atomic-queue-handler.d.ts +1549 -5281
  76. package/dist/contracts/handlers/nucleus-atomic-queue-handler.js +2 -2
  77. package/dist/contracts/handlers/nucleus-boring-vault-handler.cjs +1 -1
  78. package/dist/contracts/handlers/nucleus-boring-vault-handler.d.ts +1549 -5281
  79. package/dist/contracts/handlers/nucleus-boring-vault-handler.js +2 -2
  80. package/dist/contracts/handlers/nucleus-teller-handler.cjs +1 -1
  81. package/dist/contracts/handlers/nucleus-teller-handler.cjs.map +1 -1
  82. package/dist/contracts/handlers/nucleus-teller-handler.d.ts +1820 -5316
  83. package/dist/contracts/handlers/nucleus-teller-handler.js +63 -48
  84. package/dist/contracts/handlers/nucleus-teller-handler.js.map +1 -1
  85. package/dist/contracts/handlers/puf-locker-handler.cjs +1 -1
  86. package/dist/contracts/handlers/puf-locker-handler.d.ts +1549 -5281
  87. package/dist/contracts/handlers/puf-locker-handler.js +2 -2
  88. package/dist/contracts/handlers/puffer-depositor-handler.cjs +1 -1
  89. package/dist/contracts/handlers/puffer-depositor-handler.d.ts +1549 -5281
  90. package/dist/contracts/handlers/puffer-depositor-handler.js +2 -2
  91. package/dist/contracts/handlers/puffer-l2-depositor-handler.cjs +1 -1
  92. package/dist/contracts/handlers/puffer-l2-depositor-handler.d.ts +1549 -5281
  93. package/dist/contracts/handlers/puffer-l2-depositor-handler.js +2 -2
  94. package/dist/contracts/handlers/puffer-oracle-v2-handler.cjs +1 -1
  95. package/dist/contracts/handlers/puffer-oracle-v2-handler.d.ts +1549 -5281
  96. package/dist/contracts/handlers/puffer-oracle-v2-handler.js +2 -2
  97. package/dist/contracts/handlers/puffer-protocol-handler.cjs +1 -1
  98. package/dist/contracts/handlers/puffer-protocol-handler.d.ts +1549 -5281
  99. package/dist/contracts/handlers/puffer-protocol-handler.js +2 -2
  100. package/dist/contracts/handlers/puffer-vault-handler.cjs +1 -1
  101. package/dist/contracts/handlers/puffer-vault-handler.d.ts +1549 -5281
  102. package/dist/contracts/handlers/puffer-vault-handler.js +2 -2
  103. package/dist/contracts/handlers/puffer-withdrawal-manager-handler.cjs +1 -1
  104. package/dist/contracts/handlers/puffer-withdrawal-manager-handler.d.ts +1549 -5281
  105. package/dist/contracts/handlers/puffer-withdrawal-manager-handler.js +2 -2
  106. package/dist/contracts/handlers/validator-ticket-handler.cjs +1 -1
  107. package/dist/contracts/handlers/validator-ticket-handler.d.ts +1549 -5281
  108. package/dist/contracts/handlers/validator-ticket-handler.js +2 -2
  109. package/dist/contracts/handlers/vl-puffer-handler.cjs +1 -1
  110. package/dist/contracts/handlers/vl-puffer-handler.d.ts +1549 -5281
  111. package/dist/contracts/handlers/vl-puffer-handler.js +2 -2
  112. package/dist/contracts/tokens.cjs +1 -1
  113. package/dist/contracts/tokens.js +1 -1
  114. package/dist/contracts/vaults-addresses.cjs +1 -1
  115. package/dist/contracts/vaults-addresses.js +1 -1
  116. package/dist/{getContract-Cgkj3G1g.cjs → getContract-BL-M-dQc.cjs} +2 -2
  117. package/dist/{getContract-Cgkj3G1g.cjs.map → getContract-BL-M-dQc.cjs.map} +1 -1
  118. package/dist/{getContract-Dxh0At3n.js → getContract-BVdsHXdp.js} +11 -11
  119. package/dist/{getContract-Dxh0At3n.js.map → getContract-BVdsHXdp.js.map} +1 -1
  120. package/dist/http-BtVgpo6v.cjs +5 -0
  121. package/dist/http-BtVgpo6v.cjs.map +1 -0
  122. package/dist/{http-Clq2Hoy9.js → http-CJGQ2e7o.js} +1687 -1533
  123. package/dist/http-CJGQ2e7o.js.map +1 -0
  124. package/dist/{localBatchGatewayRequest-Dm7yXllz.js → localBatchGatewayRequest-BchhbxQ2.js} +18 -18
  125. package/dist/{localBatchGatewayRequest-Dm7yXllz.js.map → localBatchGatewayRequest-BchhbxQ2.js.map} +1 -1
  126. package/dist/{localBatchGatewayRequest-CuvkLo7E.cjs → localBatchGatewayRequest-Bz0YuhIJ.cjs} +2 -2
  127. package/dist/{localBatchGatewayRequest-CuvkLo7E.cjs.map → localBatchGatewayRequest-Bz0YuhIJ.cjs.map} +1 -1
  128. package/dist/main.cjs +1 -1
  129. package/dist/main.js +1 -1
  130. package/dist/{secp256k1-BbMQ_WWG.js → secp256k1-Bm3EstvG.js} +62 -62
  131. package/dist/{secp256k1-BbMQ_WWG.js.map → secp256k1-Bm3EstvG.js.map} +1 -1
  132. package/dist/{secp256k1-DrUar53F.cjs → secp256k1-cRXUqGNw.cjs} +2 -2
  133. package/dist/{secp256k1-DrUar53F.cjs.map → secp256k1-cRXUqGNw.cjs.map} +1 -1
  134. package/dist/utils/version.cjs +1 -1
  135. package/dist/utils/version.js +1 -1
  136. package/dist/writeContract-D9xqoPDa.js +3527 -0
  137. package/dist/writeContract-D9xqoPDa.js.map +1 -0
  138. package/dist/writeContract-Gli_t0c1.cjs +6 -0
  139. package/dist/writeContract-Gli_t0c1.cjs.map +1 -0
  140. package/package.json +13 -13
  141. package/dist/ccip-BTVr5-VZ.js +0 -150
  142. package/dist/ccip-BTVr5-VZ.js.map +0 -1
  143. package/dist/ccip-DNgt9tzv.cjs +0 -2
  144. package/dist/ccip-DNgt9tzv.cjs.map +0 -1
  145. package/dist/constants-CUYeD71n.js +0 -2491
  146. package/dist/constants-CUYeD71n.js.map +0 -1
  147. package/dist/constants-Dhpa19or.cjs +0 -8
  148. package/dist/constants-Dhpa19or.cjs.map +0 -1
  149. package/dist/http-C-TIpf-V.cjs +0 -5
  150. package/dist/http-C-TIpf-V.cjs.map +0 -1
  151. package/dist/http-Clq2Hoy9.js.map +0 -1
  152. package/dist/writeContract-Bq8HaVjW.js +0 -4618
  153. package/dist/writeContract-Bq8HaVjW.js.map +0 -1
  154. package/dist/writeContract-PoCaxmyT.cjs +0 -36
  155. package/dist/writeContract-PoCaxmyT.cjs.map +0 -1
@@ -1,7 +1,7 @@
1
- import { V as n } from "../../constants-CUYeD71n.js";
1
+ import { V as n } from "../../constants-C-rrOSfg.js";
2
2
  import { CONTRACT_ADDRESSES as o } from "../addresses.js";
3
3
  import { Distributor as s } from "../abis/mainnet/Distributor.js";
4
- import { g as c } from "../../getContract-Dxh0At3n.js";
4
+ import { g as c } from "../../getContract-BVdsHXdp.js";
5
5
  class g {
6
6
  /**
7
7
  * Create the handler for the Distributor contract exposing
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const a=require("../../constants-Dhpa19or.cjs"),s=require("../tokens.cjs"),g=require("../../utils/time.cjs"),p=require("../abis/mainnet/ERC20Permit.cjs"),d=require("../../getContract-Cgkj3G1g.cjs"),y=require("../../secp256k1-DrUar53F.cjs");function S(o){const{r:t,s:n}=y.secp256k1.Signature.fromCompact(o.slice(2,130)),e=+`0x${o.slice(130)}`,[i,r]=(()=>{if(e===0||e===1)return[void 0,e];if(e===27)return[BigInt(e),0];if(e===28)return[BigInt(e),1];throw new Error("Invalid yParityOrV value")})();return typeof i<"u"?{r:a.numberToHex(t,{size:32}),s:a.numberToHex(n,{size:32}),v:i,yParity:r}:{r:a.numberToHex(t,{size:32}),s:a.numberToHex(n,{size:32}),yParity:r}}class C{constructor(t,n,e){this.chain=t,this.walletClient=n,this.publicClient=e,this.viemChain=a.VIEM_CHAINS[t],this.token=s.Token.WETH}viemChain;token;withToken(t){return this.token=t,this}getContract(){const t=s.TOKENS_ADDRESSES[this.token][this.chain],n=p.ERC20Permit,e={public:this.publicClient,wallet:this.walletClient};return d.getContract({address:t,abi:n,client:e})}nonces(t){return this.getContract().read.nonces([t])}async getPermitSignature(t,n,e){const i=this.getContract(),r=await this.nonces(t),c={name:await i.read.name(),version:this.getPermitVersion(this.token),chainId:this.chain,verifyingContract:s.TOKENS_ADDRESSES[this.token][this.chain],salt:this.getPermitSalt(this.token)},u={Permit:[{name:"owner",type:"address"},{name:"spender",type:"address"},{name:"value",type:"uint256"},{name:"nonce",type:"uint256"},{name:"deadline",type:"uint256"}]},h=BigInt(g.getTimestampInSeconds()+3600*2),l=await this.walletClient.signTypedData({account:t,domain:c,types:u,primaryType:"Permit",message:{owner:t,spender:n,value:e,nonce:r,deadline:h}});return{...S(l),deadline:h}}async getPermitData(t,n,e){const{r:i,s:r,v:m,yParity:c,deadline:u}=await this.getPermitSignature(t,n,e);return{r:i,s:r,v:Number(m??c),deadline:u,amount:e}}approve(t,n,e){return this.getContract().write.approve([n,e],{account:t,chain:this.viemChain})}getPermitVersion(t){return s.TOKENS_PERMIT_VERSION[t]}getPermitSalt(t){return s.TOKENS_SALT?.[t]?.[this.chain]}}exports.ERC20PermitHandler=C;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const a=require("../../constants-PXB3A4Yl.cjs"),s=require("../tokens.cjs"),g=require("../../utils/time.cjs"),p=require("../abis/mainnet/ERC20Permit.cjs"),d=require("../../getContract-BL-M-dQc.cjs"),y=require("../../secp256k1-cRXUqGNw.cjs");function S(o){const{r:t,s:n}=y.secp256k1.Signature.fromCompact(o.slice(2,130)),e=+`0x${o.slice(130)}`,[i,r]=(()=>{if(e===0||e===1)return[void 0,e];if(e===27)return[BigInt(e),0];if(e===28)return[BigInt(e),1];throw new Error("Invalid yParityOrV value")})();return typeof i<"u"?{r:a.numberToHex(t,{size:32}),s:a.numberToHex(n,{size:32}),v:i,yParity:r}:{r:a.numberToHex(t,{size:32}),s:a.numberToHex(n,{size:32}),yParity:r}}class C{constructor(t,n,e){this.chain=t,this.walletClient=n,this.publicClient=e,this.viemChain=a.VIEM_CHAINS[t],this.token=s.Token.WETH}viemChain;token;withToken(t){return this.token=t,this}getContract(){const t=s.TOKENS_ADDRESSES[this.token][this.chain],n=p.ERC20Permit,e={public:this.publicClient,wallet:this.walletClient};return d.getContract({address:t,abi:n,client:e})}nonces(t){return this.getContract().read.nonces([t])}async getPermitSignature(t,n,e){const i=this.getContract(),r=await this.nonces(t),c={name:await i.read.name(),version:this.getPermitVersion(this.token),chainId:this.chain,verifyingContract:s.TOKENS_ADDRESSES[this.token][this.chain],salt:this.getPermitSalt(this.token)},u={Permit:[{name:"owner",type:"address"},{name:"spender",type:"address"},{name:"value",type:"uint256"},{name:"nonce",type:"uint256"},{name:"deadline",type:"uint256"}]},h=BigInt(g.getTimestampInSeconds()+3600*2),l=await this.walletClient.signTypedData({account:t,domain:c,types:u,primaryType:"Permit",message:{owner:t,spender:n,value:e,nonce:r,deadline:h}});return{...S(l),deadline:h}}async getPermitData(t,n,e){const{r:i,s:r,v:m,yParity:c,deadline:u}=await this.getPermitSignature(t,n,e);return{r:i,s:r,v:Number(m??c),deadline:u,amount:e}}approve(t,n,e){return this.getContract().write.approve([n,e],{account:t,chain:this.viemChain})}getPermitVersion(t){return s.TOKENS_PERMIT_VERSION[t]}getPermitSalt(t){return s.TOKENS_SALT?.[t]?.[this.chain]}}exports.ERC20PermitHandler=C;
2
2
  //# sourceMappingURL=erc20-permit-handler.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"erc20-permit-handler.cjs","sources":["../../../node_modules/.pnpm/viem@2.45.0_typescript@5.9.3_zod@4.1.12/node_modules/viem/_esm/utils/signature/parseSignature.js","../../../lib/contracts/handlers/erc20-permit-handler.ts"],"sourcesContent":["import { secp256k1 } from '@noble/curves/secp256k1';\nimport { numberToHex, } from '../../utils/encoding/toHex.js';\n/**\n * @description Parses a hex formatted signature into a structured signature.\n *\n * @param signatureHex Signature in hex format.\n * @returns The structured signature.\n *\n * @example\n * parseSignature('0x6e100a352ec6ad1b70802290e18aeed190704973570f3b8ed42cb9808e2ea6bf4a90a229a244495b41890987806fcbd2d5d23fc0dbe5f5256c2613c039d76db81c')\n * // { r: '0x...', s: '0x...', v: 28n }\n */\nexport function parseSignature(signatureHex) {\n const { r, s } = secp256k1.Signature.fromCompact(signatureHex.slice(2, 130));\n const yParityOrV = Number(`0x${signatureHex.slice(130)}`);\n const [v, yParity] = (() => {\n if (yParityOrV === 0 || yParityOrV === 1)\n return [undefined, yParityOrV];\n if (yParityOrV === 27)\n return [BigInt(yParityOrV), 0];\n if (yParityOrV === 28)\n return [BigInt(yParityOrV), 1];\n throw new Error('Invalid yParityOrV value');\n })();\n if (typeof v !== 'undefined')\n return {\n r: numberToHex(r, { size: 32 }),\n s: numberToHex(s, { size: 32 }),\n v,\n yParity,\n };\n return {\n r: numberToHex(r, { size: 32 }),\n s: numberToHex(s, { size: 32 }),\n yParity,\n };\n}\n//# sourceMappingURL=parseSignature.js.map","import {\n WalletClient,\n PublicClient,\n getContract,\n Address,\n parseSignature,\n GetContractReturnType,\n} from 'viem';\nimport { Chain, VIEM_CHAINS, ViemChain } from '../../chains/constants';\nimport {\n AnyToken,\n TOKENS_ADDRESSES,\n TOKENS_SALT,\n TOKENS_PERMIT_VERSION,\n Token,\n} from '../tokens';\nimport { getTimestampInSeconds } from '../../utils/time';\nimport { ERC20Permit } from '../abis/mainnet/ERC20Permit';\nimport { PermitData } from '../common/lib/types';\n\n/**\n * Handler for performing operations for and with ERC20Permit tokens.\n */\nexport class ERC20PermitHandler {\n private viemChain: ViemChain;\n private token: AnyToken;\n\n /**\n * Create the handler for processing tokens.\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.token = Token.WETH;\n }\n\n /**\n * Set the token to use for executing transactions on the contract.\n *\n * @param token Token to use for the handler.\n * @returns The handler.\n */\n public withToken(token: AnyToken) {\n this.token = token;\n return this;\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 = TOKENS_ADDRESSES[this.token][this.chain];\n const abi = ERC20Permit;\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 nonces for the given account.\n *\n * @param account Address of the account.\n * @returns The nonces.\n */\n public nonces(account: Address) {\n return this.getContract().read.nonces([account]);\n }\n\n /**\n * Process and get permit signature for the given token to perform\n * transactions without calling `approve()`.\n *\n * @param ownerAddress Address of the token owner.\n * @param spenderAddress Address of the spender who needs the permit.\n * @param value Value of the transaction.\n * @returns Permit signature in the form `{ r, s, v?, yParity }`.\n */\n public async getPermitSignature(\n ownerAddress: Address,\n spenderAddress: Address,\n value: bigint,\n ) {\n const contract = this.getContract();\n\n const permitNonces = await this.nonces(ownerAddress);\n const name = await contract.read.name();\n const domain = <const>{\n name,\n version: this.getPermitVersion(this.token),\n chainId: this.chain,\n verifyingContract: TOKENS_ADDRESSES[this.token][this.chain],\n salt: this.getPermitSalt(this.token),\n };\n const types = <const>{\n Permit: [\n { name: 'owner', type: 'address' },\n { name: 'spender', type: 'address' },\n { name: 'value', type: 'uint256' },\n { name: 'nonce', type: 'uint256' },\n { name: 'deadline', type: 'uint256' },\n ],\n };\n // Valid for 2 hours.\n const deadline = BigInt(getTimestampInSeconds() + 60 * 60 * 2);\n\n const signature = await this.walletClient.signTypedData({\n account: ownerAddress,\n domain,\n types,\n primaryType: 'Permit',\n message: {\n owner: ownerAddress,\n spender: spenderAddress,\n value,\n nonce: permitNonces,\n deadline,\n },\n });\n\n return { ...parseSignature(signature), deadline };\n }\n\n /**\n * Get the permit data for the given owner, spender and value.\n *\n * @param ownerAddress Address of the token owner.\n * @param spenderAddress Address of the spender who needs the permit.\n * @param value Value/amount to be permitted.\n * @returns Permit data in the form `{ r, s, v, deadline, amount }`.\n */\n public async getPermitData(\n ownerAddress: Address,\n spenderAddress: Address,\n value: bigint,\n ): Promise<PermitData> {\n const { r, s, v, yParity, deadline } = await this.getPermitSignature(\n ownerAddress,\n spenderAddress,\n value,\n );\n\n /* istanbul ignore next */\n return { r, s, v: Number(v ?? yParity), deadline, amount: value };\n }\n\n /**\n * Approve transaction for the spender to spend the owner's tokens.\n *\n * @param ownerAddress Address of the caller of the transaction.\n * @param spenderAddress Address of the spender.\n * @param value Value to approve for the spender.\n * @returns Hash of the transaction.\n */\n public approve(\n ownerAddress: Address,\n spenderAddress: Address,\n value: bigint,\n ) {\n return this.getContract().write.approve([spenderAddress, value], {\n account: ownerAddress,\n chain: this.viemChain,\n });\n }\n\n private getPermitVersion(token: AnyToken): string {\n return TOKENS_PERMIT_VERSION[token];\n }\n\n private getPermitSalt(token: AnyToken) {\n return TOKENS_SALT?.[token]?.[this.chain];\n }\n}\n"],"names":["parseSignature","signatureHex","r","s","secp256k1","yParityOrV","v","yParity","numberToHex","ERC20PermitHandler","chain","walletClient","publicClient","VIEM_CHAINS","Token","token","address","TOKENS_ADDRESSES","abi","ERC20Permit","client","getContract","account","ownerAddress","spenderAddress","value","contract","permitNonces","domain","types","deadline","getTimestampInSeconds","signature","TOKENS_PERMIT_VERSION","TOKENS_SALT"],"mappings":"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","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"erc20-permit-handler.cjs","sources":["../../../node_modules/.pnpm/viem@2.53.1_typescript@5.9.3_zod@4.1.12/node_modules/viem/_esm/utils/signature/parseSignature.js","../../../lib/contracts/handlers/erc20-permit-handler.ts"],"sourcesContent":["import { secp256k1 } from '@noble/curves/secp256k1';\nimport { numberToHex, } from '../../utils/encoding/toHex.js';\n/**\n * @description Parses a hex formatted signature into a structured signature.\n *\n * @param signatureHex Signature in hex format.\n * @returns The structured signature.\n *\n * @example\n * parseSignature('0x6e100a352ec6ad1b70802290e18aeed190704973570f3b8ed42cb9808e2ea6bf4a90a229a244495b41890987806fcbd2d5d23fc0dbe5f5256c2613c039d76db81c')\n * // { r: '0x...', s: '0x...', v: 28n }\n */\nexport function parseSignature(signatureHex) {\n const { r, s } = secp256k1.Signature.fromCompact(signatureHex.slice(2, 130));\n const yParityOrV = Number(`0x${signatureHex.slice(130)}`);\n const [v, yParity] = (() => {\n if (yParityOrV === 0 || yParityOrV === 1)\n return [undefined, yParityOrV];\n if (yParityOrV === 27)\n return [BigInt(yParityOrV), 0];\n if (yParityOrV === 28)\n return [BigInt(yParityOrV), 1];\n throw new Error('Invalid yParityOrV value');\n })();\n if (typeof v !== 'undefined')\n return {\n r: numberToHex(r, { size: 32 }),\n s: numberToHex(s, { size: 32 }),\n v,\n yParity,\n };\n return {\n r: numberToHex(r, { size: 32 }),\n s: numberToHex(s, { size: 32 }),\n yParity,\n };\n}\n//# sourceMappingURL=parseSignature.js.map","import {\n WalletClient,\n PublicClient,\n getContract,\n Address,\n parseSignature,\n GetContractReturnType,\n} from 'viem';\nimport { Chain, VIEM_CHAINS, ViemChain } from '../../chains/constants';\nimport {\n AnyToken,\n TOKENS_ADDRESSES,\n TOKENS_SALT,\n TOKENS_PERMIT_VERSION,\n Token,\n} from '../tokens';\nimport { getTimestampInSeconds } from '../../utils/time';\nimport { ERC20Permit } from '../abis/mainnet/ERC20Permit';\nimport { PermitData } from '../common/lib/types';\n\n/**\n * Handler for performing operations for and with ERC20Permit tokens.\n */\nexport class ERC20PermitHandler {\n private viemChain: ViemChain;\n private token: AnyToken;\n\n /**\n * Create the handler for processing tokens.\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.token = Token.WETH;\n }\n\n /**\n * Set the token to use for executing transactions on the contract.\n *\n * @param token Token to use for the handler.\n * @returns The handler.\n */\n public withToken(token: AnyToken) {\n this.token = token;\n return this;\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 = TOKENS_ADDRESSES[this.token][this.chain];\n const abi = ERC20Permit;\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 nonces for the given account.\n *\n * @param account Address of the account.\n * @returns The nonces.\n */\n public nonces(account: Address) {\n return this.getContract().read.nonces([account]);\n }\n\n /**\n * Process and get permit signature for the given token to perform\n * transactions without calling `approve()`.\n *\n * @param ownerAddress Address of the token owner.\n * @param spenderAddress Address of the spender who needs the permit.\n * @param value Value of the transaction.\n * @returns Permit signature in the form `{ r, s, v?, yParity }`.\n */\n public async getPermitSignature(\n ownerAddress: Address,\n spenderAddress: Address,\n value: bigint,\n ) {\n const contract = this.getContract();\n\n const permitNonces = await this.nonces(ownerAddress);\n const name = await contract.read.name();\n const domain = <const>{\n name,\n version: this.getPermitVersion(this.token),\n chainId: this.chain,\n verifyingContract: TOKENS_ADDRESSES[this.token][this.chain],\n salt: this.getPermitSalt(this.token),\n };\n const types = <const>{\n Permit: [\n { name: 'owner', type: 'address' },\n { name: 'spender', type: 'address' },\n { name: 'value', type: 'uint256' },\n { name: 'nonce', type: 'uint256' },\n { name: 'deadline', type: 'uint256' },\n ],\n };\n // Valid for 2 hours.\n const deadline = BigInt(getTimestampInSeconds() + 60 * 60 * 2);\n\n const signature = await this.walletClient.signTypedData({\n account: ownerAddress,\n domain,\n types,\n primaryType: 'Permit',\n message: {\n owner: ownerAddress,\n spender: spenderAddress,\n value,\n nonce: permitNonces,\n deadline,\n },\n });\n\n return { ...parseSignature(signature), deadline };\n }\n\n /**\n * Get the permit data for the given owner, spender and value.\n *\n * @param ownerAddress Address of the token owner.\n * @param spenderAddress Address of the spender who needs the permit.\n * @param value Value/amount to be permitted.\n * @returns Permit data in the form `{ r, s, v, deadline, amount }`.\n */\n public async getPermitData(\n ownerAddress: Address,\n spenderAddress: Address,\n value: bigint,\n ): Promise<PermitData> {\n const { r, s, v, yParity, deadline } = await this.getPermitSignature(\n ownerAddress,\n spenderAddress,\n value,\n );\n\n /* istanbul ignore next */\n return { r, s, v: Number(v ?? yParity), deadline, amount: value };\n }\n\n /**\n * Approve transaction for the spender to spend the owner's tokens.\n *\n * @param ownerAddress Address of the caller of the transaction.\n * @param spenderAddress Address of the spender.\n * @param value Value to approve for the spender.\n * @returns Hash of the transaction.\n */\n public approve(\n ownerAddress: Address,\n spenderAddress: Address,\n value: bigint,\n ) {\n return this.getContract().write.approve([spenderAddress, value], {\n account: ownerAddress,\n chain: this.viemChain,\n });\n }\n\n private getPermitVersion(token: AnyToken): string {\n return TOKENS_PERMIT_VERSION[token];\n }\n\n private getPermitSalt(token: AnyToken) {\n return TOKENS_SALT?.[token]?.[this.chain];\n }\n}\n"],"names":["parseSignature","signatureHex","r","s","secp256k1","yParityOrV","v","yParity","numberToHex","ERC20PermitHandler","chain","walletClient","publicClient","VIEM_CHAINS","Token","token","address","TOKENS_ADDRESSES","abi","ERC20Permit","client","getContract","account","ownerAddress","spenderAddress","value","contract","permitNonces","domain","types","deadline","getTimestampInSeconds","signature","TOKENS_PERMIT_VERSION","TOKENS_SALT"],"mappings":"gUAYO,SAASA,EAAeC,EAAc,CACzC,KAAM,CAAE,EAAAC,EAAG,EAAAC,CAAC,EAAKC,YAAU,UAAU,YAAYH,EAAa,MAAM,EAAG,GAAG,CAAC,EACrEI,EAAa,CAAO,KAAKJ,EAAa,MAAM,GAAG,CAAC,GAChD,CAACK,EAAGC,CAAO,GAAK,IAAM,CACxB,GAAIF,IAAe,GAAKA,IAAe,EACnC,MAAO,CAAC,OAAWA,CAAU,EACjC,GAAIA,IAAe,GACf,MAAO,CAAC,OAAOA,CAAU,EAAG,CAAC,EACjC,GAAIA,IAAe,GACf,MAAO,CAAC,OAAOA,CAAU,EAAG,CAAC,EACjC,MAAM,IAAI,MAAM,0BAA0B,CAC9C,GAAC,EACD,OAAI,OAAOC,EAAM,IACN,CACH,EAAGE,EAAAA,YAAYN,EAAG,CAAE,KAAM,EAAE,CAAE,EAC9B,EAAGM,EAAAA,YAAYL,EAAG,CAAE,KAAM,EAAE,CAAE,EAC9B,EAAAG,EACA,QAAAC,CACZ,EACW,CACH,EAAGC,EAAAA,YAAYN,EAAG,CAAE,KAAM,EAAE,CAAE,EAC9B,EAAGM,EAAAA,YAAYL,EAAG,CAAE,KAAM,EAAE,CAAE,EAC9B,QAAAI,CACR,CACA,CCbO,MAAME,CAAmB,CAa9B,YACUC,EACAC,EACAC,EACR,CAHQ,KAAA,MAAAF,EACA,KAAA,aAAAC,EACA,KAAA,aAAAC,EAER,KAAK,UAAYC,EAAAA,YAAYH,CAAK,EAClC,KAAK,MAAQI,EAAAA,MAAM,IACrB,CAnBQ,UACA,MA0BD,UAAUC,EAAiB,CAChC,YAAK,MAAQA,EACN,IACT,CAQO,aAAc,CACnB,MAAMC,EAAUC,EAAAA,iBAAiB,KAAK,KAAK,EAAE,KAAK,KAAK,EACjDC,EAAMC,EAAAA,YACNC,EAAS,CAAE,OAAQ,KAAK,aAAc,OAAQ,KAAK,YAAA,EAEzD,OAAOC,EAAAA,YAAY,CAAE,QAAAL,EAAS,IAAAE,EAAK,OAAAE,EAAQ,CAK7C,CAQO,OAAOE,EAAkB,CAC9B,OAAO,KAAK,YAAA,EAAc,KAAK,OAAO,CAACA,CAAO,CAAC,CACjD,CAWA,MAAa,mBACXC,EACAC,EACAC,EACA,CACA,MAAMC,EAAW,KAAK,YAAA,EAEhBC,EAAe,MAAM,KAAK,OAAOJ,CAAY,EAE7CK,EAAgB,CACpB,KAFW,MAAMF,EAAS,KAAK,KAAA,EAG/B,QAAS,KAAK,iBAAiB,KAAK,KAAK,EACzC,QAAS,KAAK,MACd,kBAAmBT,EAAAA,iBAAiB,KAAK,KAAK,EAAE,KAAK,KAAK,EAC1D,KAAM,KAAK,cAAc,KAAK,KAAK,CAAA,EAE/BY,EAAe,CACnB,OAAQ,CACN,CAAE,KAAM,QAAS,KAAM,SAAA,EACvB,CAAE,KAAM,UAAW,KAAM,SAAA,EACzB,CAAE,KAAM,QAAS,KAAM,SAAA,EACvB,CAAE,KAAM,QAAS,KAAM,SAAA,EACvB,CAAE,KAAM,WAAY,KAAM,SAAA,CAAU,CACtC,EAGIC,EAAW,OAAOC,EAAAA,sBAAA,EAA0B,KAAU,CAAC,EAEvDC,EAAY,MAAM,KAAK,aAAa,cAAc,CACtD,QAAST,EACT,OAAAK,EACA,MAAAC,EACA,YAAa,SACb,QAAS,CACP,MAAON,EACP,QAASC,EACT,MAAAC,EACA,MAAOE,EACP,SAAAG,CAAA,CACF,CACD,EAED,MAAO,CAAE,GAAG9B,EAAegC,CAAS,EAAG,SAAAF,CAAA,CACzC,CAUA,MAAa,cACXP,EACAC,EACAC,EACqB,CACrB,KAAM,CAAE,EAAAvB,EAAG,EAAAC,EAAG,EAAAG,EAAG,QAAAC,EAAS,SAAAuB,CAAA,EAAa,MAAM,KAAK,mBAChDP,EACAC,EACAC,CAAA,EAIF,MAAO,CAAE,EAAAvB,EAAG,EAAAC,EAAG,EAAG,OAAOG,GAAKC,CAAO,EAAG,SAAAuB,EAAU,OAAQL,CAAA,CAC5D,CAUO,QACLF,EACAC,EACAC,EACA,CACA,OAAO,KAAK,cAAc,MAAM,QAAQ,CAACD,EAAgBC,CAAK,EAAG,CAC/D,QAASF,EACT,MAAO,KAAK,SAAA,CACb,CACH,CAEQ,iBAAiBR,EAAyB,CAChD,OAAOkB,EAAAA,sBAAsBlB,CAAK,CACpC,CAEQ,cAAcA,EAAiB,CACrC,OAAOmB,gBAAcnB,CAAK,IAAI,KAAK,KAAK,CAC1C,CACF","x_google_ignoreList":[0]}