@wireio/stake 0.3.0 → 0.3.69
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/README.md +185 -243
- package/lib/stake.browser.js +58399 -13167
- package/lib/stake.browser.js.map +1 -1
- package/lib/stake.d.ts +16784 -3247
- package/lib/stake.js +59134 -13803
- package/lib/stake.js.map +1 -1
- package/lib/stake.m.js +58399 -13167
- package/lib/stake.m.js.map +1 -1
- package/package.json +6 -3
- package/src/assets/ethereum/hoodi/common/Base58.sol/Base58.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/common/Base58.sol/Base58.json +164 -0
- package/src/assets/ethereum/hoodi/common/OpenZepArtifacts.sol/__Dummy_OZ_UUPS__.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/common/OpenZepArtifacts.sol/__Dummy_OZ_UUPS__.json +76 -0
- package/src/assets/ethereum/hoodi/common/RestrictedCallers.sol/RestrictedCallers.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/common/RestrictedCallers.sol/RestrictedCallers.json +10 -0
- package/src/assets/ethereum/hoodi/common/iodata.sol/iodata.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/common/iodata.sol/iodata.json +618 -0
- package/src/assets/ethereum/hoodi/common/iodata_util.sol/iodata_util.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/common/iodata_util.sol/iodata_util.json +40 -0
- package/src/assets/ethereum/hoodi/common/sysio_data.sol/sysio_data.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/common/sysio_data.sol/sysio_data.json +10 -0
- package/src/assets/ethereum/hoodi/common/sysio_errors.sol/sysio_errors.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/common/sysio_errors.sol/sysio_errors.json +10 -0
- package/src/assets/ethereum/hoodi/common/sysio_merkle.sol/sysio_merkle.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/common/sysio_merkle.sol/sysio_merkle.json +233 -0
- package/src/assets/ethereum/hoodi/common/sysio_name.sol/sysio_name.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/common/sysio_name.sol/sysio_name.json +49 -0
- package/src/assets/ethereum/hoodi/common/sysio_pubkey.sol/sysio_pubkey.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/common/sysio_pubkey.sol/sysio_pubkey.json +64 -0
- package/src/assets/ethereum/hoodi/common/sysio_read.sol/sysio_read.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/common/sysio_read.sol/sysio_read.json +1458 -0
- package/src/assets/ethereum/hoodi/common/sysio_tester.sol/SysioTester.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/common/sysio_tester.sol/SysioTester.json +1532 -0
- package/src/assets/ethereum/hoodi/common/sysio_verify.sol/sysio_verify.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/common/sysio_verify.sol/sysio_verify.json +1525 -0
- package/src/assets/ethereum/hoodi/common/sysio_write.sol/sysio_write.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/common/sysio_write.sol/sysio_write.json +1076 -0
- package/src/assets/ethereum/hoodi/liqEth/BeaconState.sol/BeaconState.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/DepositManager.sol/DepositManagerV2.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/DepositManager.sol/DepositManagerV2.json +985 -0
- package/src/assets/ethereum/hoodi/liqEth/LiqEthAuthority.sol/LiqEthAuthority.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/LiqEthCommon.sol/IAccounting.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/LiqEthCommon.sol/IAccounting.json +182 -0
- package/src/assets/ethereum/hoodi/liqEth/LiqEthCommon.sol/IDepositContract.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/LiqEthCommon.sol/IDepositManager.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/LiqEthCommon.sol/ILiqEthUpgradeable.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/LiqEthCommon.sol/IRewardsERC20.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/LiqEthCommon.sol/IRewardsERC20.json +319 -0
- package/src/assets/ethereum/hoodi/liqEth/LiqEthCommon.sol/IRewardsERC20Pausable.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/LiqEthCommon.sol/IRewardsERC20Pausable.json +333 -0
- package/src/assets/ethereum/hoodi/liqEth/LiqEthCommon.sol/IStakingModule.dbg.json +4 -0
- package/src/assets/ethereum/{ABI → hoodi}/liqEth/LiqEthCommon.sol/IStakingModule.json +1 -1
- package/src/assets/ethereum/hoodi/liqEth/LiqEthCommon.sol/IValidatorBalanceVerifier.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/LiqEthCommon.sol/IWithdrawalRecord.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/LiqEthCommon.sol/LiqEthCommon.dbg.json +4 -0
- package/src/assets/ethereum/{ABI → hoodi}/liqEth/LiqEthCommon.sol/LiqEthCommon.json +2 -2
- package/src/assets/ethereum/hoodi/liqEth/LiqEthDeepFreeze.sol/LiqEthDeepFreeze.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/LiqEthDeepFreeze.sol/LiqEthDeepFreeze.json +236 -0
- package/src/assets/ethereum/hoodi/liqEth/LiqEthManaged.sol/LiqEthManaged.dbg.json +4 -0
- package/src/assets/ethereum/{ABI → hoodi}/liqEth/LiqEthManaged.sol/LiqEthManaged.json +2 -2
- package/src/assets/ethereum/hoodi/liqEth/RewardsERC20.sol/RewardsERC20UpgradeableV2.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/RewardsERC20.sol/RewardsERC20UpgradeableV2.json +957 -0
- package/src/assets/ethereum/hoodi/liqEth/RewardsERC20Pausable.sol/RewardsERC20PausableUpgradeableV2.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/RewardsERC20Pausable.sol/RewardsERC20PausableUpgradeableV2.json +1020 -0
- package/src/assets/ethereum/hoodi/liqEth/Yield.sol/YieldOracle.dbg.json +4 -0
- package/src/assets/ethereum/{ABI → hoodi}/liqEth/Yield.sol/YieldOracle.json +2 -2
- package/src/assets/ethereum/hoodi/liqEth/accounting.sol/AccountingV2.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/accounting.sol/AccountingV2.json +629 -0
- package/src/assets/ethereum/hoodi/liqEth/liqEth.sol/LiqEthTokenV2.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/liqEth.sol/LiqEthTokenV2.json +1323 -0
- package/src/assets/ethereum/hoodi/liqEth/stakingModule.sol/StakingModuleV2.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/stakingModule.sol/StakingModuleV2.json +1779 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/DepositManager.sol/DepositManager.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/DepositManager.sol/DepositManager.json +978 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/LiqEthCommon.sol/IAccounting.dbg.json +4 -0
- package/src/assets/ethereum/{ABI/liqEth → hoodi/liqEth/v1}/LiqEthCommon.sol/IAccounting.json +1 -1
- package/src/assets/ethereum/hoodi/liqEth/v1/LiqEthCommon.sol/IDepositContract.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/LiqEthCommon.sol/IDepositContract.json +39 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/LiqEthCommon.sol/IDepositManager.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/LiqEthCommon.sol/IDepositManager.json +64 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/LiqEthCommon.sol/ILiqEthUpgradeable.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/LiqEthCommon.sol/ILiqEthUpgradeable.json +29 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/LiqEthCommon.sol/IRewardsERC20.dbg.json +4 -0
- package/src/assets/ethereum/{ABI/liqEth → hoodi/liqEth/v1}/LiqEthCommon.sol/IRewardsERC20.json +1 -1
- package/src/assets/ethereum/hoodi/liqEth/v1/LiqEthCommon.sol/IRewardsERC20Pausable.dbg.json +4 -0
- package/src/assets/ethereum/{ABI/liqEth → hoodi/liqEth/v1}/LiqEthCommon.sol/IRewardsERC20Pausable.json +1 -1
- package/src/assets/ethereum/hoodi/liqEth/v1/LiqEthCommon.sol/IStakingModule.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/LiqEthCommon.sol/IStakingModule.json +344 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/LiqEthCommon.sol/IValidatorBalanceVerifier.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/LiqEthCommon.sol/IValidatorBalanceVerifier.json +129 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/LiqEthCommon.sol/IWithdrawalRecord.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/LiqEthCommon.sol/IWithdrawalRecord.json +66 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/LiqEthCommon.sol/LiqEthCommon.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/LiqEthCommon.sol/LiqEthCommon.json +10 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/RewardsERC20.sol/RewardsERC20Upgradeable.dbg.json +4 -0
- package/src/assets/ethereum/{ABI/liqEth → hoodi/liqEth/v1}/RewardsERC20.sol/RewardsERC20Upgradeable.json +1 -1
- package/src/assets/ethereum/hoodi/liqEth/v1/RewardsERC20Pausable.sol/RewardsERC20PausableUpgradeable.dbg.json +4 -0
- package/src/assets/ethereum/{ABI/liqEth → hoodi/liqEth/v1}/RewardsERC20Pausable.sol/RewardsERC20PausableUpgradeable.json +1 -1
- package/src/assets/ethereum/hoodi/liqEth/v1/accounting.sol/Accounting.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/accounting.sol/Accounting.json +548 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/liqEth.sol/LiqEthToken.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/liqEth.sol/LiqEthToken.json +1233 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/stakingModule.sol/StakingModule.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/v1/stakingModule.sol/StakingModule.json +1772 -0
- package/src/assets/ethereum/hoodi/liqEth/withdrawalQueue.sol/WithdrawalQueue.dbg.json +4 -0
- package/src/assets/ethereum/{ABI → hoodi}/liqEth/withdrawalQueue.sol/WithdrawalQueue.json +2 -2
- package/src/assets/ethereum/hoodi/liqEth/withdrawalVault.sol/Uint64BE.dbg.json +4 -0
- package/src/assets/ethereum/{ABI → hoodi}/liqEth/withdrawalVault.sol/Uint64BE.json +2 -2
- package/src/assets/ethereum/hoodi/liqEth/withdrawalVault.sol/WithdrawalVault.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/liqEth/withdrawalVault.sol/WithdrawalVault.json +441 -0
- package/src/assets/ethereum/hoodi/outpost/BAR.sol/BAR.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/BAR.sol/BAR.json +1111 -0
- package/src/assets/ethereum/hoodi/outpost/Depositor.sol/Depositor.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/Depositor.sol/Depositor.json +1696 -0
- package/src/assets/ethereum/hoodi/outpost/EthUsdPriceConsumer.sol/AggregatorV3Interface.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/EthUsdPriceConsumer.sol/EthUsdPriceConsumer.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/EthUsdPriceConsumer.sol/EthUsdPriceConsumer.json +274 -0
- package/src/assets/ethereum/hoodi/outpost/InstaswapBridgeAttestations.sol/BridgeDepositCodec.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/InstaswapBridgeAttestations.sol/BridgeDepositCodec.json +10 -0
- package/src/assets/ethereum/hoodi/outpost/InstaswapBridgeAttestations.sol/BridgeWithdrawCodec.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/InstaswapBridgeAttestations.sol/BridgeWithdrawCodec.json +10 -0
- package/src/assets/ethereum/hoodi/outpost/InstaswapBridgeAttestations.sol/BridgeWithdrawConfirmCodec.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/InstaswapBridgeAttestations.sol/BridgeWithdrawConfirmCodec.json +10 -0
- package/src/assets/ethereum/hoodi/outpost/InstaswapBridgeAttestations.sol/InstaswapBridgeAttestationTypeLib.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/InstaswapBridgeAttestations.sol/InstaswapBridgeAttestationTypeLib.json +10 -0
- package/src/assets/ethereum/hoodi/outpost/LiqEthBridge.sol/LiqEthBridge.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/LiqEthBridge.sol/LiqEthBridge.json +1044 -0
- package/src/assets/ethereum/hoodi/outpost/OPP.sol/OPP.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OPP.sol/OPP.json +1055 -0
- package/src/assets/ethereum/hoodi/outpost/OPPCommon.sol/IOPP.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OPPCommon.sol/IOPP.json +81 -0
- package/src/assets/ethereum/hoodi/outpost/OPPCommon.sol/IOPPEndpoint.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OPPCommon.sol/IOPPInbound.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OPPCommon.sol/IOPPInbound.json +330 -0
- package/src/assets/ethereum/hoodi/outpost/OPPCommon.sol/IOPPReceiver.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OPPCommon.sol/IOPPReceiver.json +29 -0
- package/src/assets/ethereum/hoodi/outpost/OPPCommon.sol/IOPPSender.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OPPCommon.sol/IOPPSender.json +41 -0
- package/src/assets/ethereum/hoodi/outpost/OPPCommon.sol/OPPCommon.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OPPCommon.sol/OPPCommon.json +287 -0
- package/src/assets/ethereum/hoodi/outpost/OPPEndpoint.sol/OPPEndpoint.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OPPEndpoint.sol/OPPEndpoint.json +294 -0
- package/src/assets/ethereum/hoodi/outpost/OPPEndpointManaged.sol/OPPEndpointManaged.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OPPEndpointManaged.sol/OPPEndpointManaged.json +415 -0
- package/src/assets/ethereum/hoodi/outpost/OPPEndpointOwnable.sol/OPPEndpointOwnable.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OPPEndpointOwnable.sol/OPPEndpointOwnable.json +399 -0
- package/src/assets/ethereum/hoodi/outpost/OPPErrors.sol/OPPErrors.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OPPErrors.sol/OPPErrors.json +245 -0
- package/src/assets/ethereum/hoodi/outpost/OPPInbound.sol/OPPInbound.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OPPInbound.sol/OPPInbound.json +1204 -0
- package/src/assets/ethereum/hoodi/outpost/OPPReceiver.sol/OPPReceiver.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OPPReceiver.sol/OPPReceiver.json +312 -0
- package/src/assets/ethereum/hoodi/outpost/OPPSender.sol/OPPSender.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OPPSender.sol/OPPSender.json +324 -0
- package/src/assets/ethereum/hoodi/outpost/OperatorRegistry.sol/OperatorRegistry.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OperatorRegistry.sol/OperatorRegistry.json +1068 -0
- package/src/assets/ethereum/hoodi/outpost/OutpostErrors.sol/OutpostErrors.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OutpostErrors.sol/OutpostErrors.json +211 -0
- package/src/assets/ethereum/hoodi/outpost/OutpostManaged.sol/OutpostManaged.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OutpostManaged.sol/OutpostManaged.json +229 -0
- package/src/assets/ethereum/hoodi/outpost/OutpostManager.sol/OutpostManager.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OutpostManager.sol/OutpostManager.json +751 -0
- package/src/assets/ethereum/hoodi/outpost/OutpostManagerAuthority.sol/OutpostManagerAuthority.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OutpostManagerAuthority.sol/OutpostManagerAuthority.json +1432 -0
- package/src/assets/ethereum/hoodi/outpost/OutpostManagerCommon.sol/IOutpostManager.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OutpostManagerCommon.sol/IOutpostManager.json +130 -0
- package/src/assets/ethereum/hoodi/outpost/OutpostManagerCommon.sol/IOutpostUpgradeable.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OutpostManagerCommon.sol/OutpostManagerCommon.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OutpostManagerCommon.sol/OutpostManagerCommon.json +141 -0
- package/src/assets/ethereum/hoodi/outpost/OutpostOwnable.sol/OutpostOwnable.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OutpostOwnable.sol/OutpostOwnable.json +213 -0
- package/src/assets/ethereum/hoodi/outpost/OutpostReserve.sol/OutpostReserve.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/OutpostReserve.sol/OutpostReserve.json +888 -0
- package/src/assets/ethereum/hoodi/outpost/Pool.sol/Pool.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/Pool.sol/Pool.json +659 -0
- package/src/assets/ethereum/hoodi/outpost/Pretoken.sol/Pretoken.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/Pretoken.sol/Pretoken.json +1393 -0
- package/src/assets/ethereum/hoodi/outpost/ReceiptNFT.sol/ReceiptNFT.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/ReceiptNFT.sol/ReceiptNFT.json +1738 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/InstaswapConfirmCodec.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/InstaswapConfirmCodec.json +10 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/InstaswapFailedCodec.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/InstaswapFailedCodec.json +10 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/InstaswapRequestCodec.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/InstaswapRequestCodec.json +10 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/InstaswapSettlementCodec.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/InstaswapSettlementCodec.json +10 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/PrincipalExitConfirmCodec.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/PrincipalExitConfirmCodec.json +10 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/PrincipalExitFailedCodec.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/PrincipalExitFailedCodec.json +10 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/PrincipalExitRequestCodec.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/PrincipalExitRequestCodec.json +10 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/PrincipalStakeDeltaCodec.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/PrincipalStakeDeltaCodec.json +10 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/WireYieldHubAssetCodec.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/WireYieldHubAssetCodec.json +10 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/WireYieldHubAttestationTypeLib.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/WireYieldHubAttestationTypeLib.json +10 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/WireYieldHubAttestations.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/WireYieldHubAttestations.json +1437 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/YieldDepositCodec.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/WireYieldHubAttestations.sol/YieldDepositCodec.json +10 -0
- package/src/assets/ethereum/hoodi/outpost/interfaces/IPretoken.sol/IPretoken.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/interfaces/IWarrant.sol/IWarrant.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/token/ERC721EthEquivalentVotesUpgradeable.sol/ERC721EthEquivalentVotesUpgradeable.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/outpost/token/IERC721EthEquivalent.sol/IERC721EthEquivalent.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/token/ERC1155Token.sol/ERC1155Token.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/token/ERC1155Token.sol/ERC1155Token.json +472 -0
- package/src/assets/ethereum/hoodi/token/ERC20Token.sol/ERC20Token.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/token/ERC20Token.sol/ERC20Token.json +330 -0
- package/src/assets/ethereum/hoodi/token/ERC721Token.sol/ERC721Token.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/token/ERC721Token.sol/ERC721Token.json +449 -0
- package/src/assets/ethereum/hoodi/token/Eman1155.sol/Eman1155.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/token/Eman1155.sol/Eman1155.json +560 -0
- package/src/assets/ethereum/hoodi/token/Eman20.sol/Eman20.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/token/Eman20.sol/Eman20.json +460 -0
- package/src/assets/ethereum/hoodi/token/Eman721.sol/Eman721.dbg.json +4 -0
- package/src/assets/ethereum/hoodi/token/Eman721.sol/Eman721.json +624 -0
- package/src/assets/ethereum/mainnet/common/Base58.sol/Base58.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/common/Base58.sol/Base58.json +164 -0
- package/src/assets/ethereum/mainnet/common/OpenZepArtifacts.sol/__Dummy_OZ_UUPS__.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/common/OpenZepArtifacts.sol/__Dummy_OZ_UUPS__.json +76 -0
- package/src/assets/ethereum/mainnet/common/RestrictedCallers.sol/RestrictedCallers.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/common/RestrictedCallers.sol/RestrictedCallers.json +10 -0
- package/src/assets/ethereum/mainnet/common/iodata.sol/iodata.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/common/iodata.sol/iodata.json +618 -0
- package/src/assets/ethereum/mainnet/common/iodata_util.sol/iodata_util.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/common/iodata_util.sol/iodata_util.json +40 -0
- package/src/assets/ethereum/mainnet/common/sysio_data.sol/sysio_data.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/common/sysio_data.sol/sysio_data.json +10 -0
- package/src/assets/ethereum/mainnet/common/sysio_errors.sol/sysio_errors.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/common/sysio_errors.sol/sysio_errors.json +10 -0
- package/src/assets/ethereum/mainnet/common/sysio_merkle.sol/sysio_merkle.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/common/sysio_merkle.sol/sysio_merkle.json +233 -0
- package/src/assets/ethereum/mainnet/common/sysio_name.sol/sysio_name.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/common/sysio_name.sol/sysio_name.json +49 -0
- package/src/assets/ethereum/mainnet/common/sysio_pubkey.sol/sysio_pubkey.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/common/sysio_pubkey.sol/sysio_pubkey.json +64 -0
- package/src/assets/ethereum/mainnet/common/sysio_read.sol/sysio_read.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/common/sysio_read.sol/sysio_read.json +1458 -0
- package/src/assets/ethereum/mainnet/common/sysio_tester.sol/SysioTester.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/common/sysio_tester.sol/SysioTester.json +1532 -0
- package/src/assets/ethereum/mainnet/common/sysio_verify.sol/sysio_verify.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/common/sysio_verify.sol/sysio_verify.json +1525 -0
- package/src/assets/ethereum/mainnet/common/sysio_write.sol/sysio_write.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/common/sysio_write.sol/sysio_write.json +1076 -0
- package/src/assets/ethereum/mainnet/liqEth/BeaconState.sol/BeaconState.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/BeaconState.sol/BeaconState.json +807 -0
- package/src/assets/ethereum/mainnet/liqEth/DepositManager.sol/DepositManagerV2.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/DepositManager.sol/DepositManagerV2.json +1004 -0
- package/src/assets/ethereum/mainnet/liqEth/DepositManager.sol/IStakingModuleBondLocker.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/DepositManager.sol/IStakingModuleBondLocker.json +29 -0
- package/src/assets/ethereum/mainnet/liqEth/KeyBondManager.sol/KeyBondManager.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/KeyBondManager.sol/KeyBondManager.json +897 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthAuthority.sol/LiqEthAuthority.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthAuthority.sol/LiqEthAuthority.json +1289 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthCommon.sol/IDepositContract.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthCommon.sol/IDepositContract.json +39 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthCommon.sol/IDepositManager.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthCommon.sol/IDepositManager.json +64 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthCommon.sol/IKeyBondManager.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthCommon.sol/IKeyBondManager.json +189 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthCommon.sol/ILiqEthUpgradeable.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthCommon.sol/ILiqEthUpgradeable.json +29 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthCommon.sol/IRewardsERC20.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthCommon.sol/IRewardsERC20.json +319 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthCommon.sol/IRewardsERC20Pausable.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthCommon.sol/IRewardsERC20Pausable.json +333 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthCommon.sol/IStakingModule.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthCommon.sol/IStakingModule.json +279 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthCommon.sol/IValidatorBalanceVerifier.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthCommon.sol/IValidatorBalanceVerifier.json +129 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthCommon.sol/IWithdrawalRecord.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthCommon.sol/IWithdrawalRecord.json +66 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthCommon.sol/LiqEthCommon.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthCommon.sol/LiqEthCommon.json +10 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthDeepFreeze.sol/LiqEthDeepFreeze.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthDeepFreeze.sol/LiqEthDeepFreeze.json +236 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthManaged.sol/LiqEthManaged.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/LiqEthManaged.sol/LiqEthManaged.json +229 -0
- package/src/assets/ethereum/mainnet/liqEth/RewardsERC20.sol/RewardsERC20UpgradeableV2.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/RewardsERC20.sol/RewardsERC20UpgradeableV2.json +957 -0
- package/src/assets/ethereum/mainnet/liqEth/RewardsERC20Pausable.sol/RewardsERC20PausableUpgradeableV2.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/RewardsERC20Pausable.sol/RewardsERC20PausableUpgradeableV2.json +1020 -0
- package/src/assets/ethereum/mainnet/liqEth/StakingLib.sol/StakingLib.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/StakingLib.sol/StakingLib.json +89 -0
- package/src/assets/ethereum/mainnet/liqEth/Yield.sol/YieldOracle.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/Yield.sol/YieldOracle.json +1376 -0
- package/src/assets/ethereum/mainnet/liqEth/liqEth.sol/LiqEthTokenV2.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/liqEth.sol/LiqEthTokenV2.json +1323 -0
- package/src/assets/ethereum/mainnet/liqEth/stakingModule.sol/StakingModuleV2.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/stakingModule.sol/StakingModuleV2.json +1896 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/DepositManager.sol/DepositManager.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/DepositManager.sol/DepositManager.json +978 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/LiqEthCommon.sol/IAccounting.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/LiqEthCommon.sol/IAccounting.json +176 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/LiqEthCommon.sol/IDepositContract.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/LiqEthCommon.sol/IDepositContract.json +39 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/LiqEthCommon.sol/IDepositManager.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/LiqEthCommon.sol/IDepositManager.json +64 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/LiqEthCommon.sol/ILiqEthUpgradeable.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/LiqEthCommon.sol/ILiqEthUpgradeable.json +29 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/LiqEthCommon.sol/IRewardsERC20.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/LiqEthCommon.sol/IRewardsERC20.json +249 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/LiqEthCommon.sol/IRewardsERC20Pausable.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/LiqEthCommon.sol/IRewardsERC20Pausable.json +263 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/LiqEthCommon.sol/IStakingModule.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/LiqEthCommon.sol/IStakingModule.json +344 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/LiqEthCommon.sol/IValidatorBalanceVerifier.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/LiqEthCommon.sol/IValidatorBalanceVerifier.json +129 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/LiqEthCommon.sol/IWithdrawalRecord.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/LiqEthCommon.sol/IWithdrawalRecord.json +66 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/LiqEthCommon.sol/LiqEthCommon.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/LiqEthCommon.sol/LiqEthCommon.json +10 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/RewardsERC20.sol/RewardsERC20Upgradeable.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/RewardsERC20.sol/RewardsERC20Upgradeable.json +874 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/RewardsERC20Pausable.sol/RewardsERC20PausableUpgradeable.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/RewardsERC20Pausable.sol/RewardsERC20PausableUpgradeable.json +937 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/accounting.sol/Accounting.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/accounting.sol/Accounting.json +542 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/liqEth.sol/LiqEthToken.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/liqEth.sol/LiqEthToken.json +1233 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/stakingModule.sol/StakingModule.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/v1/stakingModule.sol/StakingModule.json +1772 -0
- package/src/assets/ethereum/mainnet/liqEth/withdrawalQueue.sol/WithdrawalQueue.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/withdrawalQueue.sol/WithdrawalQueue.json +973 -0
- package/src/assets/ethereum/mainnet/liqEth/withdrawalVault.sol/Uint64BE.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/withdrawalVault.sol/Uint64BE.json +10 -0
- package/src/assets/ethereum/mainnet/liqEth/withdrawalVault.sol/WithdrawalVault.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/liqEth/withdrawalVault.sol/WithdrawalVault.json +441 -0
- package/src/assets/ethereum/mainnet/outpost/BAR.sol/BARV2.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/BAR.sol/BARV2.json +1915 -0
- package/src/assets/ethereum/mainnet/outpost/Depositor.sol/DepositorV2.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/Depositor.sol/DepositorV2.json +1845 -0
- package/src/assets/ethereum/mainnet/outpost/EthUsdPriceConsumer.sol/AggregatorV3Interface.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/EthUsdPriceConsumer.sol/AggregatorV3Interface.json +122 -0
- package/src/assets/ethereum/mainnet/outpost/EthUsdPriceConsumer.sol/EthUsdPriceConsumer.dbg.json +4 -0
- package/src/assets/ethereum/{ABI → mainnet}/outpost/EthUsdPriceConsumer.sol/EthUsdPriceConsumer.json +31 -29
- package/src/assets/ethereum/mainnet/outpost/OPP.sol/OPP.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/OPPCommon.sol/IOPP.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/OPPCommon.sol/IOPPEndpoint.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/OPPCommon.sol/IOPPEndpoint.json +29 -0
- package/src/assets/ethereum/mainnet/outpost/OPPCommon.sol/IOPPInbound.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/OPPCommon.sol/IOPPReceiver.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/OPPCommon.sol/IOPPSender.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/OPPCommon.sol/OPPCommon.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/OPPEndpoint.sol/OPPEndpoint.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/OPPEndpointManaged.sol/OPPEndpointManaged.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/OPPEndpointOwnable.sol/OPPEndpointOwnable.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/OPPErrors.sol/OPPErrors.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/OPPInbound.sol/OPPInbound.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/OPPReceiver.sol/OPPReceiver.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/OPPSender.sol/OPPSender.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/OutpostErrors.sol/OutpostErrors.dbg.json +4 -0
- package/src/assets/ethereum/{ABI → mainnet}/outpost/OutpostErrors.sol/OutpostErrors.json +33 -18
- package/src/assets/ethereum/mainnet/outpost/OutpostManaged.sol/OutpostManaged.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/OutpostManager.sol/OutpostManagerV2.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/OutpostManager.sol/OutpostManagerV2.json +737 -0
- package/src/assets/ethereum/mainnet/outpost/OutpostManagerAuthority.sol/OutpostManagerAuthority.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/OutpostManagerCommon.sol/IOutpostManager.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/OutpostManagerCommon.sol/IOutpostUpgradeable.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/OutpostManagerCommon.sol/IOutpostUpgradeable.json +29 -0
- package/src/assets/ethereum/mainnet/outpost/OutpostManagerCommon.sol/OutpostManagerCommon.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/OutpostOwnable.sol/OutpostOwnable.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/Pool.sol/PoolV2.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/Pool.sol/PoolV2.json +943 -0
- package/src/assets/ethereum/mainnet/outpost/Pretoken.sol/PretokenV2.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/Pretoken.sol/PretokenV2.json +1703 -0
- package/src/assets/ethereum/mainnet/outpost/ReceiptNFT.sol/ReceiptNFT.dbg.json +4 -0
- package/src/assets/ethereum/{ABI → mainnet}/outpost/ReceiptNFT.sol/ReceiptNFT.json +33 -18
- package/src/assets/ethereum/mainnet/outpost/interfaces/IPretoken.sol/IPretoken.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/interfaces/IPretoken.sol/IPretoken.json +29 -0
- package/src/assets/ethereum/mainnet/outpost/interfaces/IWarrant.sol/IWarrant.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/interfaces/IWarrant.sol/IWarrant.json +29 -0
- package/src/assets/ethereum/mainnet/outpost/token/ERC721EthEquivalentVotesUpgradeable.sol/ERC721EthEquivalentVotesUpgradeable.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/token/ERC721EthEquivalentVotesUpgradeable.sol/ERC721EthEquivalentVotesUpgradeable.json +858 -0
- package/src/assets/ethereum/mainnet/outpost/token/IERC721EthEquivalent.sol/IERC721EthEquivalent.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/token/IERC721EthEquivalent.sol/IERC721EthEquivalent.json +30 -0
- package/src/assets/ethereum/mainnet/outpost/v1/BAR.sol/BAR.dbg.json +4 -0
- package/src/assets/ethereum/{ABI/outpost → mainnet/outpost/v1}/BAR.sol/BAR.json +34 -19
- package/src/assets/ethereum/mainnet/outpost/v1/Depositor.sol/Depositor.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/v1/Depositor.sol/Depositor.json +1653 -0
- package/src/assets/ethereum/mainnet/outpost/v1/OutpostManager.sol/OutpostManager.dbg.json +4 -0
- package/src/assets/ethereum/{ABI/outpost → mainnet/outpost/v1}/OutpostManager.sol/OutpostManager.json +3 -3
- package/src/assets/ethereum/mainnet/outpost/v1/Pool.sol/Pool.dbg.json +4 -0
- package/src/assets/ethereum/{ABI/outpost → mainnet/outpost/v1}/Pool.sol/Pool.json +34 -19
- package/src/assets/ethereum/mainnet/outpost/v1/Pretoken.sol/Pretoken.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/outpost/v1/Pretoken.sol/Pretoken.json +1665 -0
- package/src/assets/ethereum/mainnet/token/ERC1155Token.sol/ERC1155Token.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/token/ERC1155Token.sol/ERC1155Token.json +472 -0
- package/src/assets/ethereum/mainnet/token/ERC20Token.sol/ERC20Token.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/token/ERC20Token.sol/ERC20Token.json +330 -0
- package/src/assets/ethereum/mainnet/token/ERC721Token.sol/ERC721Token.dbg.json +4 -0
- package/src/assets/ethereum/mainnet/token/ERC721Token.sol/ERC721Token.json +449 -0
- package/src/assets/solana/devnet/idl/liqsol_core.json +8566 -0
- package/src/assets/solana/{idl → devnet/idl}/liqsol_token.json +35 -1
- package/src/assets/solana/devnet/idl/transfer_hook.json +490 -0
- package/src/assets/solana/devnet/idl/validator_leaderboard.json +735 -0
- package/src/assets/solana/devnet/types/liqsol_core.ts +8572 -0
- package/src/assets/solana/{types → devnet/types}/liqsol_token.ts +35 -1
- package/src/assets/solana/devnet/types/transfer_hook.ts +496 -0
- package/src/assets/solana/devnet/types/validator_leaderboard.ts +741 -0
- package/src/assets/solana/{idl → mainnet/idl}/liqsol_core.json +3816 -1567
- package/src/assets/solana/mainnet/idl/liqsol_token.json +217 -0
- package/src/assets/solana/mainnet/idl/transfer_hook.json +479 -0
- package/src/assets/solana/{idl → mainnet/idl}/validator_leaderboard.json +4 -4
- package/src/assets/solana/{types → mainnet/types}/liqsol_core.ts +3816 -1567
- package/src/assets/solana/mainnet/types/liqsol_token.ts +223 -0
- package/src/assets/solana/mainnet/types/transfer_hook.ts +485 -0
- package/src/assets/solana/{types → mainnet/types}/validator_leaderboard.ts +4 -4
- package/src/assets/solana/realdevnet/idl/liqsol_core.json +7112 -0
- package/src/assets/solana/realdevnet/idl/liqsol_token.json +217 -0
- package/src/assets/solana/realdevnet/idl/transfer_hook.json +479 -0
- package/src/assets/solana/realdevnet/idl/validator_leaderboard.json +735 -0
- package/src/assets/solana/realdevnet/types/liqsol_core.ts +7118 -0
- package/src/assets/solana/realdevnet/types/liqsol_token.ts +223 -0
- package/src/assets/solana/realdevnet/types/transfer_hook.ts +485 -0
- package/src/assets/solana/realdevnet/types/validator_leaderboard.ts +741 -0
- package/src/index.ts +2 -2
- package/src/networks/ethereum/clients/{deposit.client.ts → convert.client.ts} +66 -5
- package/src/networks/ethereum/clients/opp.client.ts +389 -0
- package/src/networks/ethereum/clients/pretoken.client.ts +87 -49
- package/src/networks/ethereum/clients/receipt.client.ts +199 -0
- package/src/networks/ethereum/clients/stake.client.ts +86 -161
- package/src/networks/ethereum/clients/validator.client.ts +61 -0
- package/src/networks/ethereum/contract.ts +424 -151
- package/src/networks/ethereum/ethereum.ts +454 -244
- package/src/networks/ethereum/types.ts +65 -27
- package/src/networks/ethereum/utils.ts +104 -72
- package/src/networks/solana/clients/convert.client.ts +341 -0
- package/src/networks/solana/clients/distribution.client.ts +269 -263
- package/src/networks/solana/clients/leaderboard.client.ts +68 -26
- package/src/networks/solana/clients/outpost.client.ts +224 -357
- package/src/networks/solana/clients/token.client.ts +96 -106
- package/src/networks/solana/constants.ts +88 -216
- package/src/networks/solana/program.ts +432 -28
- package/src/networks/solana/solana.ts +1066 -293
- package/src/networks/solana/types.ts +687 -78
- package/src/networks/solana/utils.ts +159 -356
- package/src/staker.ts +25 -4
- package/src/types.ts +267 -31
- package/src/assets/ethereum/ABI/liqEth/BeaconState.sol/BeaconState.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/DepositManager.sol/DepositManager.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/DepositManager.sol/DepositManager.json +0 -952
- package/src/assets/ethereum/ABI/liqEth/LiqEthAuthority.sol/LiqEthAuthority.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/LiqEthCommon.sol/IAccounting.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/LiqEthCommon.sol/IDepositContract.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/LiqEthCommon.sol/IDepositManager.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/LiqEthCommon.sol/ILiqEthUpgradeable.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/LiqEthCommon.sol/IRewardsERC20.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/LiqEthCommon.sol/IRewardsERC20Pausable.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/LiqEthCommon.sol/IStakingModule.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/LiqEthCommon.sol/IValidatorBalanceVerifier.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/LiqEthCommon.sol/IWithdrawalRecord.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/LiqEthCommon.sol/LiqEthCommon.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/LiqEthManaged.sol/LiqEthManaged.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/RewardsERC20.sol/RewardsERC20Upgradeable.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/RewardsERC20Pausable.sol/RewardsERC20PausableUpgradeable.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/ValidatorBalanceVerifier.sol/BeaconRoots.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/ValidatorBalanceVerifier.sol/BeaconRoots.json +0 -10
- package/src/assets/ethereum/ABI/liqEth/ValidatorBalanceVerifier.sol/SSZ.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/ValidatorBalanceVerifier.sol/SSZ.json +0 -10
- package/src/assets/ethereum/ABI/liqEth/ValidatorBalanceVerifier.sol/SSZExtras.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/ValidatorBalanceVerifier.sol/SSZExtras.json +0 -10
- package/src/assets/ethereum/ABI/liqEth/ValidatorBalanceVerifier.sol/SSZVec48.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/ValidatorBalanceVerifier.sol/SSZVec48.json +0 -10
- package/src/assets/ethereum/ABI/liqEth/ValidatorBalanceVerifier.sol/ValidatorBalanceVerifier.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/ValidatorBalanceVerifier.sol/ValidatorBalanceVerifier.json +0 -291
- package/src/assets/ethereum/ABI/liqEth/Yield.sol/YieldOracle.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/accounting.sol/Accounting.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/accounting.sol/Accounting.json +0 -555
- package/src/assets/ethereum/ABI/liqEth/liqEth.sol/LiqEthToken.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/liqEth.sol/LiqEthToken.json +0 -1202
- package/src/assets/ethereum/ABI/liqEth/stakingModule.sol/StakingModule.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/stakingModule.sol/StakingModule.json +0 -1791
- package/src/assets/ethereum/ABI/liqEth/withdrawalQueue.sol/WithdrawalQueue.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/withdrawalVault.sol/Uint64BE.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/withdrawalVault.sol/WithdrawalVault.dbg.json +0 -4
- package/src/assets/ethereum/ABI/liqEth/withdrawalVault.sol/WithdrawalVault.json +0 -460
- package/src/assets/ethereum/ABI/outpost/Aggregator.sol/Aggregator.json +0 -82
- package/src/assets/ethereum/ABI/outpost/BAR.sol/BAR.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/Depositor.sol/Depositor.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/Depositor.sol/Depositor.json +0 -1638
- package/src/assets/ethereum/ABI/outpost/EthUsdPriceConsumer.sol/AggregatorV3Interface.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/EthUsdPriceConsumer.sol/EthUsdPriceConsumer.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OPP.sol/OPP.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OPPCommon.sol/IOPP.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OPPCommon.sol/IOPPEndpoint.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OPPCommon.sol/IOPPInbound.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OPPCommon.sol/IOPPReceiver.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OPPCommon.sol/IOPPSender.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OPPCommon.sol/OPPCommon.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OPPEndpoint.sol/OPPEndpoint.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OPPEndpointManaged.sol/OPPEndpointManaged.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OPPEndpointOwnable.sol/OPPEndpointOwnable.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OPPErrors.sol/OPPErrors.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OPPInbound.sol/OPPInbound.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OPPReceiver.sol/OPPReceiver.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OPPSender.sol/OPPSender.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OutpostErrors.sol/OutpostErrors.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OutpostManaged.sol/OutpostManaged.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OutpostManager.sol/OutpostManager.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OutpostManagerAuthority.sol/OutpostManagerAuthority.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OutpostManagerCommon.sol/IOutpostManager.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OutpostManagerCommon.sol/IOutpostUpgradeable.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OutpostManagerCommon.sol/OutpostManagerCommon.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/OutpostOwnable.sol/OutpostOwnable.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/Pool.sol/Pool.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/Pretoken.sol/Pretoken.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/Pretoken.sol/Pretoken.json +0 -1650
- package/src/assets/ethereum/ABI/outpost/ReceiptNFT.sol/ReceiptNFT.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/interfaces/IPretoken.sol/IPretoken.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/interfaces/IWarrant.sol/IWarrant.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/token/ERC721EthEquivalentVotesUpgradeable.sol/ERC721EthEquivalentVotesUpgradeable.dbg.json +0 -4
- package/src/assets/ethereum/ABI/outpost/token/IERC721EthEquivalent.sol/IERC721EthEquivalent.dbg.json +0 -4
- package/src/assets/ethereum/ABI/token/ERC1155Token.sol/ERC1155Token.dbg.json +0 -4
- package/src/assets/ethereum/ABI/token/ERC1155Token.sol/ERC1155Token.json +0 -472
- package/src/assets/ethereum/ABI/token/ERC20Token.sol/ERC20Token.dbg.json +0 -4
- package/src/assets/ethereum/ABI/token/ERC20Token.sol/ERC20Token.json +0 -330
- package/src/assets/ethereum/ABI/token/ERC721Token.sol/ERC721Token.dbg.json +0 -4
- package/src/assets/ethereum/ABI/token/ERC721Token.sol/ERC721Token.json +0 -449
- package/src/networks/ethereum/clients/liq.client.ts +0 -47
- package/src/networks/solana/clients/deposit.client.ts +0 -127
- package/src/staker/types.ts +0 -62
- /package/src/assets/ethereum/{ABI → hoodi}/liqEth/BeaconState.sol/BeaconState.json +0 -0
- /package/src/assets/ethereum/{ABI → hoodi}/liqEth/LiqEthAuthority.sol/LiqEthAuthority.json +0 -0
- /package/src/assets/ethereum/{ABI → hoodi}/liqEth/LiqEthCommon.sol/IDepositContract.json +0 -0
- /package/src/assets/ethereum/{ABI → hoodi}/liqEth/LiqEthCommon.sol/IDepositManager.json +0 -0
- /package/src/assets/ethereum/{ABI → hoodi}/liqEth/LiqEthCommon.sol/ILiqEthUpgradeable.json +0 -0
- /package/src/assets/ethereum/{ABI → hoodi}/liqEth/LiqEthCommon.sol/IValidatorBalanceVerifier.json +0 -0
- /package/src/assets/ethereum/{ABI → hoodi}/liqEth/LiqEthCommon.sol/IWithdrawalRecord.json +0 -0
- /package/src/assets/ethereum/{ABI → hoodi}/outpost/EthUsdPriceConsumer.sol/AggregatorV3Interface.json +0 -0
- /package/src/assets/ethereum/{ABI → hoodi}/outpost/OPPCommon.sol/IOPPEndpoint.json +0 -0
- /package/src/assets/ethereum/{ABI → hoodi}/outpost/OutpostManagerCommon.sol/IOutpostUpgradeable.json +0 -0
- /package/src/assets/ethereum/{ABI → hoodi}/outpost/interfaces/IPretoken.sol/IPretoken.json +0 -0
- /package/src/assets/ethereum/{ABI → hoodi}/outpost/interfaces/IWarrant.sol/IWarrant.json +0 -0
- /package/src/assets/ethereum/{ABI → hoodi}/outpost/token/ERC721EthEquivalentVotesUpgradeable.sol/ERC721EthEquivalentVotesUpgradeable.json +0 -0
- /package/src/assets/ethereum/{ABI → hoodi}/outpost/token/IERC721EthEquivalent.sol/IERC721EthEquivalent.json +0 -0
- /package/src/assets/ethereum/{ABI → mainnet}/outpost/OPP.sol/OPP.json +0 -0
- /package/src/assets/ethereum/{ABI → mainnet}/outpost/OPPCommon.sol/IOPP.json +0 -0
- /package/src/assets/ethereum/{ABI → mainnet}/outpost/OPPCommon.sol/IOPPInbound.json +0 -0
- /package/src/assets/ethereum/{ABI → mainnet}/outpost/OPPCommon.sol/IOPPReceiver.json +0 -0
- /package/src/assets/ethereum/{ABI → mainnet}/outpost/OPPCommon.sol/IOPPSender.json +0 -0
- /package/src/assets/ethereum/{ABI → mainnet}/outpost/OPPCommon.sol/OPPCommon.json +0 -0
- /package/src/assets/ethereum/{ABI → mainnet}/outpost/OPPEndpoint.sol/OPPEndpoint.json +0 -0
- /package/src/assets/ethereum/{ABI → mainnet}/outpost/OPPEndpointManaged.sol/OPPEndpointManaged.json +0 -0
- /package/src/assets/ethereum/{ABI → mainnet}/outpost/OPPEndpointOwnable.sol/OPPEndpointOwnable.json +0 -0
- /package/src/assets/ethereum/{ABI → mainnet}/outpost/OPPErrors.sol/OPPErrors.json +0 -0
- /package/src/assets/ethereum/{ABI → mainnet}/outpost/OPPInbound.sol/OPPInbound.json +0 -0
- /package/src/assets/ethereum/{ABI → mainnet}/outpost/OPPReceiver.sol/OPPReceiver.json +0 -0
- /package/src/assets/ethereum/{ABI → mainnet}/outpost/OPPSender.sol/OPPSender.json +0 -0
- /package/src/assets/ethereum/{ABI → mainnet}/outpost/OutpostManaged.sol/OutpostManaged.json +0 -0
- /package/src/assets/ethereum/{ABI → mainnet}/outpost/OutpostManagerAuthority.sol/OutpostManagerAuthority.json +0 -0
- /package/src/assets/ethereum/{ABI → mainnet}/outpost/OutpostManagerCommon.sol/IOutpostManager.json +0 -0
- /package/src/assets/ethereum/{ABI → mainnet}/outpost/OutpostManagerCommon.sol/OutpostManagerCommon.json +0 -0
- /package/src/assets/ethereum/{ABI → mainnet}/outpost/OutpostOwnable.sol/OutpostOwnable.json +0 -0
|
@@ -1,56 +1,71 @@
|
|
|
1
1
|
import { BigNumber, ethers } from 'ethers';
|
|
2
|
-
import { IStakingClient, Portfolio, StakerConfig, TrancheSnapshot } from '../../types';
|
|
3
2
|
import { ChainID, EvmChainID, PublicKey as WirePubKey } from '@wireio/core';
|
|
3
|
+
import {
|
|
4
|
+
IStakingClient,
|
|
5
|
+
OPPAssertion,
|
|
6
|
+
Portfolio,
|
|
7
|
+
StakerConfig,
|
|
8
|
+
TrancheSnapshot
|
|
9
|
+
} from '../../types';
|
|
4
10
|
import { EthereumContractService } from './contract';
|
|
5
|
-
import { preLaunchReceipt } from './types';
|
|
6
|
-
import {
|
|
11
|
+
import { preLaunchReceipt, WithdrawReceipt } from './types';
|
|
12
|
+
import { buildEthereumTrancheSnapshot } from './utils';
|
|
13
|
+
import { ConvertClient } from './clients/convert.client';
|
|
7
14
|
import { StakeClient } from './clients/stake.client';
|
|
8
15
|
import { PretokenClient } from './clients/pretoken.client';
|
|
9
|
-
import {
|
|
10
|
-
import {
|
|
11
|
-
|
|
12
|
-
|
|
16
|
+
import { OPPClient } from './clients/opp.client';
|
|
17
|
+
import { ReceiptClient } from './clients/receipt.client';
|
|
18
|
+
import { ValidatorClient } from './clients/validator.client';
|
|
13
19
|
|
|
20
|
+
export const INITIAL_TRANCHE_SUPPLY = 35000;
|
|
14
21
|
|
|
15
22
|
export class EthereumStakingClient implements IStakingClient {
|
|
23
|
+
private readonly provider: ethers.providers.Web3Provider | ethers.providers.JsonRpcProvider;
|
|
16
24
|
public readonly pubKey?: WirePubKey;
|
|
17
|
-
private readonly
|
|
18
|
-
private readonly signer: ethers.Signer;
|
|
25
|
+
private readonly signer?: ethers.Signer;
|
|
19
26
|
private readonly contractService: EthereumContractService;
|
|
20
27
|
|
|
21
|
-
private
|
|
22
|
-
private liqClient: LiqClient;
|
|
28
|
+
private convertClient: ConvertClient;
|
|
23
29
|
private pretokenClient: PretokenClient;
|
|
24
30
|
private stakeClient: StakeClient;
|
|
25
|
-
|
|
31
|
+
private oppClient: OPPClient;
|
|
32
|
+
private receiptClient: ReceiptClient;
|
|
33
|
+
private validatorClient: ValidatorClient;
|
|
26
34
|
|
|
27
35
|
get contract() { return this.contractService.contract; }
|
|
28
36
|
get network() { return this.config.network; }
|
|
37
|
+
get address() { return this.signer?.getAddress(); }
|
|
29
38
|
|
|
30
39
|
constructor(private config: StakerConfig) {
|
|
31
40
|
try {
|
|
32
|
-
|
|
33
|
-
|
|
41
|
+
if (config.provider) {
|
|
42
|
+
this.provider = config.provider as ethers.providers.Web3Provider;
|
|
43
|
+
this.signer = this.provider.getSigner();
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
this.provider = new ethers.providers.JsonRpcProvider(config.network.rpcUrls[0]);
|
|
47
|
+
}
|
|
34
48
|
this.pubKey = config.pubKey;
|
|
35
|
-
|
|
49
|
+
|
|
36
50
|
this.contractService = new EthereumContractService({
|
|
37
51
|
provider: this.provider,
|
|
38
52
|
signer: this.signer,
|
|
53
|
+
chainId: config.network.chainId as EvmChainID,
|
|
39
54
|
});
|
|
40
|
-
|
|
41
|
-
this.
|
|
42
|
-
this.liqClient = new LiqClient(this.contractService);
|
|
55
|
+
|
|
56
|
+
this.convertClient = new ConvertClient(this.contractService);
|
|
43
57
|
this.pretokenClient = new PretokenClient(this.contractService);
|
|
44
58
|
this.stakeClient = new StakeClient(this.contractService);
|
|
45
|
-
|
|
59
|
+
this.oppClient = new OPPClient(this.contractService);
|
|
60
|
+
this.receiptClient = new ReceiptClient(this.contractService);
|
|
61
|
+
this.validatorClient = new ValidatorClient(this.contractService)
|
|
62
|
+
}
|
|
46
63
|
catch (error) {
|
|
47
64
|
// console.error('Error initializing EthereumStakingClient:', error);
|
|
48
65
|
throw error;
|
|
49
|
-
}
|
|
66
|
+
}
|
|
50
67
|
}
|
|
51
68
|
|
|
52
|
-
|
|
53
|
-
|
|
54
69
|
// ---------------------------------------------------------------------
|
|
55
70
|
// Public IStakingClient Interface Methods
|
|
56
71
|
// ---------------------------------------------------------------------
|
|
@@ -62,40 +77,66 @@ export class EthereumStakingClient implements IStakingClient {
|
|
|
62
77
|
* @returns transaction hash
|
|
63
78
|
*/
|
|
64
79
|
async deposit(amount: number | string | bigint | BigNumber): Promise<string> {
|
|
80
|
+
this.ensureUser();
|
|
81
|
+
|
|
65
82
|
const amountWei = BigNumber.isBigNumber(amount)
|
|
66
83
|
? amount
|
|
67
84
|
: BigNumber.from(amount);
|
|
68
85
|
|
|
69
|
-
const result = await this.
|
|
86
|
+
const result = await this.convertClient.performDeposit(amountWei);
|
|
70
87
|
return result.txHash;
|
|
71
88
|
}
|
|
72
89
|
|
|
73
|
-
|
|
74
|
-
|
|
75
90
|
/**
|
|
76
91
|
* Withdraw native ETH from the liqETH protocol via the liqeth safeBurn function, which burns the LiqETH and adds the user to the withdrawal queue.
|
|
77
92
|
* @param amount Amount in wei (or something convertible to BigNumber).
|
|
78
93
|
* @returns transaction hash
|
|
79
94
|
*/
|
|
80
95
|
async withdraw(amount: bigint): Promise<string> {
|
|
81
|
-
|
|
96
|
+
this.ensureUser();
|
|
97
|
+
|
|
98
|
+
const address = await this.address!;
|
|
82
99
|
const amountWei = BigNumber.from(amount);
|
|
83
|
-
// const chainId = this.network?.chainId ?? (await this.provider.getNetwork()).chainId;
|
|
84
|
-
// const result = await this.depositClient.requestWithdraw(amountWei, this.signer, chainId);
|
|
85
100
|
|
|
86
|
-
const result = await this.
|
|
101
|
+
const result = await this.convertClient.performWithdraw(address, amountWei)
|
|
102
|
+
return result.txHash;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
/**
|
|
106
|
+
* List withdrawal queue receipts for a wallet (pending / in-progress exits after safeBurn).
|
|
107
|
+
* @param address Owner to query; defaults to the connected wallet.
|
|
108
|
+
* @returns Withdrawal receipt NFT entries from the protocol view
|
|
109
|
+
*/
|
|
110
|
+
async getPendingWithdraws(address?: string): Promise<WithdrawReceipt[]> {
|
|
111
|
+
this.ensureUser();
|
|
112
|
+
const owner = address ?? await this.address!;
|
|
113
|
+
return await this.receiptClient.fetchWithdrawReceipts(owner);
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
/**
|
|
117
|
+
* Claim native ETH for a matured withdrawal using the WithdrawalQueue NFT token id
|
|
118
|
+
* (via DepositManager.claim after the delay has passed).
|
|
119
|
+
* @param tokenId Withdrawal request / queue NFT token id
|
|
120
|
+
* @returns transaction hash
|
|
121
|
+
*/
|
|
122
|
+
async claimWithdraw(tokenId: bigint): Promise<string> {
|
|
123
|
+
this.ensureUser();
|
|
124
|
+
|
|
125
|
+
const tokenIdBigNum = BigNumber.from(tokenId)
|
|
126
|
+
const result = await this.convertClient.claimWithdraw(tokenIdBigNum)
|
|
87
127
|
return result.txHash;
|
|
88
128
|
}
|
|
89
129
|
|
|
90
130
|
|
|
91
131
|
/**
|
|
92
132
|
* Stake liqETH via DepositManager.
|
|
93
|
-
* @param amount Amount in wei
|
|
94
|
-
* Keep this as a bigint / string in the caller; avoid JS floats.
|
|
133
|
+
* @param amount Amount in wei - Keep this as a bigint / string in the caller; avoid JS floats.
|
|
95
134
|
* @returns transaction hash
|
|
96
135
|
*/
|
|
97
136
|
async stake(amount: bigint): Promise<string> {
|
|
98
|
-
|
|
137
|
+
this.ensureUser();
|
|
138
|
+
|
|
139
|
+
const walletAddress = await this.address!;
|
|
99
140
|
const amountWei = BigNumber.from(amount);
|
|
100
141
|
|
|
101
142
|
const result = await this.stakeClient.performStake(amountWei, walletAddress);
|
|
@@ -108,6 +149,46 @@ export class EthereumStakingClient implements IStakingClient {
|
|
|
108
149
|
throw new Error("Method not yet implemented.");
|
|
109
150
|
}
|
|
110
151
|
|
|
152
|
+
/**
|
|
153
|
+
* Deposit ETH to liqETH, then stake liqETH in a single transaction.
|
|
154
|
+
* @param amountWei Amount in wei.
|
|
155
|
+
* @returns transaction hash
|
|
156
|
+
*/
|
|
157
|
+
async depositAndStake(amountWei: bigint): Promise<string> {
|
|
158
|
+
this.ensureUser();
|
|
159
|
+
if (!amountWei || amountWei <= BigInt(0))
|
|
160
|
+
throw new Error('Amount must be greater than zero.');
|
|
161
|
+
|
|
162
|
+
const result = await this.stakeClient.performDepositAndStake(BigNumber.from(amountWei));
|
|
163
|
+
return result.txHash;
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
/**
|
|
167
|
+
* Deposit ETH to liqETH, then purchase pretokens in a single transaction.
|
|
168
|
+
* @param amountWei Amount in wei.
|
|
169
|
+
* @returns transaction hash
|
|
170
|
+
*/
|
|
171
|
+
async depositAndBuy(amountWei: bigint): Promise<string> {
|
|
172
|
+
this.ensureUser();
|
|
173
|
+
if (!amountWei || amountWei <= BigInt(0))
|
|
174
|
+
throw new Error('Amount must be greater than zero.');
|
|
175
|
+
|
|
176
|
+
const result = await this.stakeClient.performDepositAndPurchase(BigNumber.from(amountWei));
|
|
177
|
+
return result.txHash;
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
/**
|
|
181
|
+
* Unstake liqETH, then request a withdrawal in a single transaction.
|
|
182
|
+
* @param tokenId The ReceiptNFT token ID for the stake position
|
|
183
|
+
* @returns transaction hash
|
|
184
|
+
*/
|
|
185
|
+
async unstakeAndWithdraw(tokenId: bigint): Promise<string> {
|
|
186
|
+
this.ensureUser();
|
|
187
|
+
|
|
188
|
+
const result = await this.stakeClient.performUnstakeAndRequestWithdraw(BigNumber.from(tokenId));
|
|
189
|
+
return result.txHash;
|
|
190
|
+
}
|
|
191
|
+
|
|
111
192
|
|
|
112
193
|
/**
|
|
113
194
|
* ETH Prelaunch function to unstake liqEth
|
|
@@ -116,86 +197,219 @@ export class EthereumStakingClient implements IStakingClient {
|
|
|
116
197
|
* @returns the transaction hash
|
|
117
198
|
*/
|
|
118
199
|
async unstakePrelaunch(tokenId: bigint, recipient: string): Promise<string> {
|
|
200
|
+
this.ensureUser();
|
|
201
|
+
|
|
119
202
|
const tokenIdBigNum = BigNumber.from(tokenId)
|
|
120
203
|
const result = await this.stakeClient.performWithdrawStake(tokenIdBigNum, recipient);
|
|
121
204
|
return result.txHash;
|
|
122
205
|
}
|
|
123
206
|
|
|
124
207
|
|
|
125
|
-
|
|
126
208
|
async buy(amount: bigint): Promise<string> {
|
|
127
|
-
|
|
128
|
-
|
|
209
|
+
this.ensureUser();
|
|
210
|
+
|
|
211
|
+
const buyer = await this.address!;
|
|
129
212
|
|
|
130
213
|
// ! Hoodi only - check if the mock aggregator price is stale, and if so, update it before submitting the buy request
|
|
131
|
-
await this.
|
|
132
|
-
|
|
214
|
+
// const network = await this.provider.getNetwork();
|
|
215
|
+
// const chainId = network.chainId;
|
|
216
|
+
// const allowedTestChains = new Set([560048]);
|
|
217
|
+
// if (allowedTestChains.has(chainId)) await this.updateMockAggregatorPrice();
|
|
133
218
|
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
throw new Error("Error - Depositor is in a paused state");
|
|
138
|
-
}
|
|
219
|
+
let result = await this.pretokenClient.purchasePretokensWithLiqETH(amount, buyer);
|
|
220
|
+
return result && result.txHash ? result.txHash : "Error - no resulting txHash";
|
|
221
|
+
}
|
|
139
222
|
|
|
140
|
-
// if current liq balance is less than the requested buy amount, throw an error
|
|
141
|
-
if (bal.lt(amount)) {
|
|
142
|
-
throw new Error(`Balance insufficient for pre-token purchase`);
|
|
143
|
-
}
|
|
144
223
|
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
224
|
+
/**
|
|
225
|
+
* Validator functions
|
|
226
|
+
*/
|
|
227
|
+
async validatorDeposit(): Promise<string> {
|
|
228
|
+
this.ensureUser();
|
|
148
229
|
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
230
|
+
let result = await this.validatorClient.validatorDepositAndLockBond();
|
|
231
|
+
return result && result.txHash ? result.txHash : "Error - no resulting txHash";
|
|
232
|
+
}
|
|
233
|
+
|
|
152
234
|
|
|
153
|
-
// currently requested unlimited amount - potentially change to only request up to the current amount?
|
|
154
|
-
const approveAmount = ethers.constants.MaxUint256;
|
|
155
235
|
|
|
156
|
-
console.warn(`allowance insufficient (${allowance.toString()} < ${amount.toString()}); sending approve(${depositorAddr}, ${approveAmount.toString()})`);
|
|
157
236
|
|
|
158
|
-
const approveTx = await liqWrite.approve(depositorAddr, approveAmount);
|
|
159
|
-
await approveTx.wait(1);
|
|
160
237
|
|
|
161
|
-
// re-read allowance to ensure approval succeeded
|
|
162
|
-
const newAllowance = await this.contract.LiqEth.allowance(buyer, depositorAddr);
|
|
163
|
-
if (newAllowance.lt(amount)) {
|
|
164
|
-
throw new Error('Approval failed or allowance still insufficient after approve');
|
|
165
|
-
}
|
|
166
|
-
}
|
|
167
238
|
|
|
239
|
+
/**
|
|
240
|
+
* Resolve the user's ETH + liqETH balances.
|
|
241
|
+
*
|
|
242
|
+
* native = ETH in wallet
|
|
243
|
+
* actual = liqETH token balance (ERC-20)
|
|
244
|
+
* tracked = liqETH tracked balance (protocol/accounting view)
|
|
245
|
+
*/
|
|
246
|
+
async getPortfolio(address?: string): Promise<Portfolio | null> {
|
|
168
247
|
|
|
169
|
-
|
|
248
|
+
try {
|
|
249
|
+
if (!this.signer) return Promise.resolve(null);
|
|
170
250
|
|
|
171
|
-
|
|
172
|
-
}
|
|
251
|
+
const walletAddress = address ?? await this.address!;
|
|
173
252
|
|
|
253
|
+
// 1) Native ETH balance
|
|
254
|
+
const nativeBalance = await this.provider.getBalance(walletAddress);
|
|
255
|
+
const nativeDecimals = this.network?.nativeCurrency?.decimals ?? 18;
|
|
256
|
+
const nativeSymbol = this.network?.nativeCurrency?.symbol ?? 'ETH';
|
|
174
257
|
|
|
175
|
-
|
|
258
|
+
// 2) liqETH ERC-20 balance (actual)
|
|
259
|
+
const liqBalance: ethers.BigNumber = await this.contract.LiqEthToken.balanceOf(walletAddress);
|
|
260
|
+
const liqSymbol = 'Liq' + (this.network?.nativeCurrency?.symbol ?? 'ETH');
|
|
176
261
|
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
}
|
|
262
|
+
// 3) staked liqEth ERC-20 balance (calculate from receipts)
|
|
263
|
+
let stakeReceipts = await this.receiptClient.stakeReceipts(walletAddress);
|
|
180
264
|
|
|
265
|
+
let stakeBalanceBN = BigNumber.from(0);
|
|
266
|
+
for (let r of stakeReceipts) {
|
|
267
|
+
stakeBalanceBN = stakeBalanceBN.add(BigNumber.from(r.receipt.principal.amount));
|
|
268
|
+
}
|
|
269
|
+
let stakeSharesBN = BigNumber.from(0);
|
|
270
|
+
for (let r of stakeReceipts) {
|
|
271
|
+
stakeSharesBN = stakeSharesBN.add(BigNumber.from(r.receipt.shares.amount));
|
|
272
|
+
}
|
|
273
|
+
|
|
274
|
+
// 4) WIRE pretoken balance
|
|
275
|
+
const wireBalance: ethers.BigNumber = await this.contract.Pretoken.balanceOf(walletAddress);
|
|
276
|
+
|
|
277
|
+
// 5) Calculate staking yield
|
|
278
|
+
let currentIndex = BigInt(0);
|
|
279
|
+
let totalShares = BigInt(0);
|
|
280
|
+
let userShares = BigInt(0);
|
|
281
|
+
const indexScale = BigInt(1e27);
|
|
282
|
+
try {
|
|
283
|
+
// These may throw if not implemented on contract
|
|
284
|
+
const [indexBn, totalSharesBn] = await Promise.all([
|
|
285
|
+
this.contract.Depositor.index().catch(() => BigNumber.from(0)),
|
|
286
|
+
this.contract.Depositor.totalShares().catch(() => BigNumber.from(0)),
|
|
287
|
+
]);
|
|
288
|
+
|
|
289
|
+
const userSharesBn = stakeSharesBN;
|
|
290
|
+
currentIndex = BigInt(indexBn.toString());
|
|
291
|
+
totalShares = BigInt(totalSharesBn.toString());
|
|
292
|
+
userShares = BigInt(userSharesBn.toString());
|
|
293
|
+
} catch (error) {
|
|
294
|
+
console.log('Error fetching staking index/shares:', error);
|
|
295
|
+
}
|
|
296
|
+
|
|
297
|
+
// sharesToTokens(userShares, currentIndex) = userShares * currentIndex / indexScale
|
|
298
|
+
let estimatedClaim = BigInt(0);
|
|
299
|
+
let estimatedYield = BigInt(0);
|
|
300
|
+
|
|
301
|
+
if (userShares > BigInt(0) && currentIndex > BigInt(0)) {
|
|
302
|
+
estimatedClaim = (userShares * currentIndex) / indexScale;
|
|
303
|
+
if (estimatedClaim > stakeBalanceBN.toBigInt()) {
|
|
304
|
+
estimatedYield = estimatedClaim - stakeBalanceBN.toBigInt();
|
|
305
|
+
}
|
|
306
|
+
}
|
|
307
|
+
|
|
308
|
+
|
|
309
|
+
const portfolio: Portfolio = {
|
|
310
|
+
native: {
|
|
311
|
+
amount: nativeBalance.toBigInt(),
|
|
312
|
+
decimals: nativeDecimals,
|
|
313
|
+
symbol: nativeSymbol,
|
|
314
|
+
},
|
|
315
|
+
liq: {
|
|
316
|
+
amount: liqBalance.toBigInt(),
|
|
317
|
+
decimals: nativeDecimals,
|
|
318
|
+
symbol: liqSymbol,
|
|
319
|
+
},
|
|
320
|
+
staked: {
|
|
321
|
+
amount: stakeBalanceBN.toBigInt(),
|
|
322
|
+
decimals: nativeDecimals,
|
|
323
|
+
symbol: liqSymbol,
|
|
324
|
+
},
|
|
325
|
+
wire: {
|
|
326
|
+
amount: wireBalance.toBigInt(),
|
|
327
|
+
decimals: 18,
|
|
328
|
+
symbol: '$WIRE',
|
|
329
|
+
},
|
|
330
|
+
|
|
331
|
+
yield: {
|
|
332
|
+
currentIndex,
|
|
333
|
+
indexScale,
|
|
334
|
+
totalShares,
|
|
335
|
+
userShares,
|
|
336
|
+
estimatedClaim,
|
|
337
|
+
estimatedYield,
|
|
338
|
+
},
|
|
339
|
+
chainID: this.network.chainId
|
|
340
|
+
}
|
|
341
|
+
return portfolio;
|
|
342
|
+
}
|
|
343
|
+
catch (error) {
|
|
344
|
+
// console.log('Error fetching Ethereum portfolio:', error);
|
|
345
|
+
throw error;
|
|
346
|
+
}
|
|
347
|
+
}
|
|
181
348
|
|
|
182
|
-
|
|
183
349
|
/**
|
|
184
|
-
* ETH Prelaunch function to list the ReceiptNFTs owned by a specific user
|
|
350
|
+
* ETH Prelaunch function to list the Stake ReceiptNFTs owned by a specific user
|
|
185
351
|
* @param address address to query the receipts for
|
|
186
352
|
* @returns array of receipts
|
|
187
353
|
*/
|
|
188
354
|
async fetchPrelaunchReceipts(address?: string): Promise<preLaunchReceipt[]> {
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
355
|
+
this.ensureUser();
|
|
356
|
+
|
|
357
|
+
if (address === undefined) address = await this.address!;
|
|
358
|
+
|
|
359
|
+
//default to stake receipts
|
|
360
|
+
return await this.receiptClient.stakeReceipts(address);
|
|
361
|
+
}
|
|
362
|
+
|
|
363
|
+
async getOPPMessages(address?: string): Promise<OPPAssertion[]> {
|
|
364
|
+
this.ensureUser();
|
|
365
|
+
|
|
366
|
+
if (!address) address = await this.address!;
|
|
367
|
+
|
|
368
|
+
return await this.oppClient.getMessages(address);
|
|
369
|
+
}
|
|
370
|
+
|
|
371
|
+
|
|
372
|
+
|
|
373
|
+
// Ensure that signer wallet is available for write operations
|
|
374
|
+
private ensureUser() {
|
|
375
|
+
if (!this.signer) {
|
|
376
|
+
throw new Error(
|
|
377
|
+
'EthereumStakingClient: write operation requires a wallet-connected Web3 provider',
|
|
378
|
+
);
|
|
379
|
+
}
|
|
380
|
+
}
|
|
381
|
+
|
|
382
|
+
|
|
383
|
+
// ---------------------------------------------------------------------
|
|
384
|
+
// READ-ONLY Public Methods
|
|
385
|
+
// ---------------------------------------------------------------------
|
|
386
|
+
|
|
387
|
+
// Protocol-wide ETH staking APY in percent, e.g. 3.0 => "3.00%"
|
|
388
|
+
async getSystemAPY(): Promise<number> {
|
|
389
|
+
// NOTE: despite the name, this value is effectively *annual* BPS on-chain.
|
|
390
|
+
// e.g. 300 => 3% APY
|
|
391
|
+
const annualBpsBn = await this.contract.DepositManager.dailyRateBPS();
|
|
392
|
+
const annualBps = annualBpsBn.toNumber(); // e.g. 300 for 3%
|
|
393
|
+
|
|
394
|
+
// Convert basis points (1/100 of 1%) to percent:
|
|
395
|
+
// 10,000 bps = 100% ⇒ 100 bps = 1% ⇒ divide by 100.
|
|
396
|
+
const apyPercent = annualBps / 100;
|
|
397
|
+
|
|
398
|
+
return apyPercent; // 3 => "3.00%"
|
|
399
|
+
}
|
|
400
|
+
|
|
401
|
+
// Protocol fee charged for deposit from Native to LIQ
|
|
402
|
+
async getDepositFee(amountWei: bigint): Promise<bigint> {
|
|
403
|
+
const feeBn: BigNumber = await this.contract.DepositManager.procFee(amountWei);
|
|
404
|
+
return BigInt(feeBn.toString());
|
|
405
|
+
}
|
|
406
|
+
|
|
407
|
+
async getOPPStatus(): Promise<any> {
|
|
408
|
+
return await this.oppClient.getStatus();
|
|
193
409
|
}
|
|
194
410
|
|
|
195
|
-
|
|
196
|
-
|
|
197
411
|
async getEthStats(): Promise<any> {
|
|
198
|
-
let withdrawDelay = await this.contract.
|
|
412
|
+
let withdrawDelay = await this.contract.WithdrawalQueue.withdrawDelay();
|
|
199
413
|
let minDeposit = await this.contract.DepositManager.minDeposit();
|
|
200
414
|
let rewardCooldown = await this.contract.DepositManager.rewardCooldown();
|
|
201
415
|
|
|
@@ -207,188 +421,184 @@ export class EthereumStakingClient implements IStakingClient {
|
|
|
207
421
|
}
|
|
208
422
|
|
|
209
423
|
/**
|
|
210
|
-
*
|
|
211
|
-
*
|
|
212
|
-
*
|
|
213
|
-
* actual = liqETH token balance (ERC-20)
|
|
214
|
-
* tracked = liqETH tracked balance (protocol/accounting view)
|
|
424
|
+
* Program-level prelaunch WIRE / tranche snapshot for Ethereum
|
|
425
|
+
*
|
|
426
|
+
* SUPPORTS READ-ONLY ACcESS
|
|
215
427
|
*/
|
|
216
|
-
async
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
428
|
+
async getTrancheSnapshot(chainID: ChainID): Promise<TrancheSnapshot> {
|
|
429
|
+
try {
|
|
430
|
+
const blockNumber = await this.provider.getBlockNumber();
|
|
431
|
+
const blockTag = { blockTag: blockNumber };
|
|
432
|
+
|
|
433
|
+
// Fetch all required contract data
|
|
434
|
+
const [totalSharesBn, indexBn, trancheNumberBn, trancheSupplyBn, tranchePriceUsdBn, totalSupplyBn, supplyGrowthBps, priceGrowthCents, minPriceUsd, maxPriceUsd] = await Promise.all([
|
|
435
|
+
this.contract.Depositor.totalShares(blockTag),
|
|
436
|
+
this.contract.Depositor.index(blockTag),
|
|
437
|
+
this.contract.Pretoken.trancheNumber(blockTag),
|
|
438
|
+
this.contract.Pretoken.trancheSupply(blockTag),
|
|
439
|
+
this.contract.Pretoken.tranchePriceUsd(blockTag),
|
|
440
|
+
this.contract.Pretoken.totalSupply(blockTag),
|
|
441
|
+
this.contract.Pretoken.supplyGrowthBps(blockTag),
|
|
442
|
+
this.contract.Pretoken.priceIncrementUsd(blockTag),
|
|
443
|
+
this.contract.EthUsdPriceConsumer.MIN_PRICE(),
|
|
444
|
+
this.contract.EthUsdPriceConsumer.MAX_PRICE(),
|
|
445
|
+
]);
|
|
446
|
+
|
|
447
|
+
const totalTrancheSupply = BigInt(totalSupplyBn.toString()) / BigInt(1e10);
|
|
448
|
+
const currentTrancheSupply = BigInt(trancheSupplyBn.toString()) / BigInt(1e10);
|
|
449
|
+
|
|
450
|
+
// fetch price and timestamp from aggregator
|
|
451
|
+
// const [roundId, answer, startedAt, updatedAt, answeredInRound] = await this.contract.MockAggregator.latestRoundData();
|
|
452
|
+
//originally fetched ethPrice from aggregator - pulling from EthUsdPriceConsumer instead - this is where the actual price gets pulled from when purchasing pretokens.
|
|
453
|
+
// let ethPriceUsd: bigint = BigInt(answer.toString());)
|
|
454
|
+
|
|
455
|
+
let ethPriceUsdBn = await this.contract.EthUsdPriceConsumer.getPrice18Decimals();
|
|
456
|
+
let ethPriceUsd: bigint = BigInt(ethPriceUsdBn.toString()) / BigInt(1e10);
|
|
457
|
+
|
|
458
|
+
// let nativePriceTimestamp: number = Number(updatedAt);
|
|
459
|
+
|
|
460
|
+
const initialTrancheSupply = BigInt(INITIAL_TRANCHE_SUPPLY) * BigInt(1e8);
|
|
461
|
+
|
|
462
|
+
return buildEthereumTrancheSnapshot({
|
|
463
|
+
chainID,
|
|
464
|
+
totalSharesBn,
|
|
465
|
+
indexBn,
|
|
466
|
+
trancheNumberBn,
|
|
467
|
+
currentTrancheSupply,
|
|
468
|
+
tranchePriceUsdBn,
|
|
469
|
+
totalTrancheSupply,
|
|
470
|
+
initialTrancheSupply,
|
|
471
|
+
supplyGrowthBps,
|
|
472
|
+
priceGrowthCents,
|
|
473
|
+
minPriceUsd,
|
|
474
|
+
maxPriceUsd,
|
|
475
|
+
ethPriceUsd,
|
|
476
|
+
});
|
|
477
|
+
}
|
|
478
|
+
catch (err: any) {
|
|
479
|
+
throw new Error(`Error fetching Ethereum tranche snapshot: ${err?.message || err}`);
|
|
261
480
|
}
|
|
262
|
-
return portfolio;
|
|
263
481
|
}
|
|
264
482
|
|
|
265
|
-
|
|
266
483
|
/**
|
|
267
|
-
*
|
|
484
|
+
* Estimate a conservative native ETH buffer (in wei) to leave in the wallet
|
|
485
|
+
* so the user can pay gas for the current deposit and at least one more tx.
|
|
486
|
+
*
|
|
487
|
+
* Typical usage in UI:
|
|
488
|
+
* const buffer = await client.estimateGasBuffer();
|
|
489
|
+
* const maxSpendable = balanceWei > buffer ? balanceWei - buffer : 0n;
|
|
490
|
+
*
|
|
491
|
+
* @param options.txCount How many transactions to cover (default 2: deposit + 1 more)
|
|
492
|
+
* @param options.safetyMultiplier Additional safety multiplier on top of txCount (default 1.5x)
|
|
493
|
+
* @param options.minBufferWei Optional override minimum buffer (defaults ~0.002 ETH)
|
|
268
494
|
*/
|
|
269
|
-
async
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
const
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
const [totalSharesBn, indexBn, trancheNumberBn, trancheSupplyBn, tranchePriceWadBn, totalSupplyBn, supplyGrowthBps, priceGrowthBps, minPriceUsd, maxPriceUsd] = await Promise.all([
|
|
286
|
-
this.contract.Depositor.totalShares(blockTag),
|
|
287
|
-
this.contract.Depositor.index(blockTag),
|
|
288
|
-
this.contract.Pretoken.trancheNumber(blockTag),
|
|
289
|
-
this.contract.Pretoken.trancheSupply(blockTag),
|
|
290
|
-
this.contract.Pretoken.tranchePriceUsd(blockTag),
|
|
291
|
-
this.contract.Pretoken.totalSupply(blockTag),
|
|
292
|
-
this.contract.Pretoken.supplyGrowthBps(blockTag),
|
|
293
|
-
this.contract.Pretoken.priceGrowthBps(blockTag),
|
|
294
|
-
this.contract.EthUsdPriceConsumer.MIN_PRICE(),
|
|
295
|
-
this.contract.EthUsdPriceConsumer.MAX_PRICE(),
|
|
296
|
-
]);
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
const totalTrancheSupply = BigInt(totalSupplyBn.toString()) / BigInt(1e10);
|
|
300
|
-
const currentTrancheSupply = BigInt(trancheSupplyBn.toString()) / BigInt(1e10);
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
// fetch price and timestamp from aggregator
|
|
304
|
-
const [ roundId, answer, startedAt, updatedAt, answeredInRound ] = await this.contract.Aggregator.latestRoundData();
|
|
305
|
-
let ethPriceUsd: bigint = BigInt(answer.toString());
|
|
306
|
-
let nativePriceTimestamp: number = Number(updatedAt);
|
|
307
|
-
|
|
308
|
-
// ! Placeholder from hoodi deployment - don't think this can be fetched dynamically
|
|
309
|
-
const initialTrancheSupply = BigInt(60000) * BigInt(1e8);
|
|
310
|
-
|
|
311
|
-
return buildEthereumTrancheSnapshot({
|
|
312
|
-
chainID,
|
|
313
|
-
totalSharesBn,
|
|
314
|
-
indexBn,
|
|
315
|
-
trancheNumberBn,
|
|
316
|
-
currentTrancheSupply,
|
|
317
|
-
tranchePriceWadBn,
|
|
318
|
-
totalTrancheSupply,
|
|
319
|
-
initialTrancheSupply,
|
|
320
|
-
supplyGrowthBps,
|
|
321
|
-
priceGrowthBps,
|
|
322
|
-
minPriceUsd,
|
|
323
|
-
maxPriceUsd,
|
|
324
|
-
|
|
325
|
-
ethPriceUsd,
|
|
326
|
-
nativePriceTimestamp,
|
|
327
|
-
ladderWindowBefore: windowBefore,
|
|
328
|
-
ladderWindowAfter: windowAfter,
|
|
495
|
+
async getDepositBuffer(options?: {
|
|
496
|
+
txCount?: number;
|
|
497
|
+
safetyMultiplier?: number;
|
|
498
|
+
minBufferWei?: bigint;
|
|
499
|
+
balanceOverrideLamports?: bigint;
|
|
500
|
+
}): Promise<bigint> {
|
|
501
|
+
this.ensureUser();
|
|
502
|
+
|
|
503
|
+
const walletAddress = await this.address!;
|
|
504
|
+
|
|
505
|
+
// 1) Estimate a baseline gas usage using a simple self-transfer.
|
|
506
|
+
// This is cheap and doesn't depend on your contract ABI at all.
|
|
507
|
+
const baseGas = await this.provider.estimateGas({
|
|
508
|
+
from: walletAddress,
|
|
509
|
+
to: walletAddress,
|
|
510
|
+
value: ethers.constants.Zero,
|
|
329
511
|
});
|
|
330
|
-
}
|
|
331
|
-
|
|
332
512
|
|
|
513
|
+
// 2) Fetch current gas price / max fee per gas.
|
|
514
|
+
const feeData = await this.provider.getFeeData();
|
|
515
|
+
let gasPrice =
|
|
516
|
+
feeData.maxFeePerGas ??
|
|
517
|
+
feeData.gasPrice ??
|
|
518
|
+
ethers.utils.parseUnits('20', 'gwei'); // conservative fallback
|
|
333
519
|
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
// ---------------------------------------------------------------------
|
|
520
|
+
// 3) How many txs do we want to cover?
|
|
521
|
+
// Default: 2 (deposit + one extra action such as stake or small follow-up).
|
|
522
|
+
const txCount = options?.txCount ?? 2;
|
|
338
523
|
|
|
524
|
+
// We also assume that contract interactions are more expensive than a simple transfer.
|
|
525
|
+
// Use a multiplier (e.g., 5x) on baseGas to approximate a more complex tx.
|
|
526
|
+
const COMPLEX_TX_MULTIPLIER = 5; // tuning knob
|
|
527
|
+
const totalGasUnits = baseGas
|
|
528
|
+
.mul(COMPLEX_TX_MULTIPLIER)
|
|
529
|
+
.mul(txCount);
|
|
339
530
|
|
|
340
|
-
|
|
531
|
+
const baseCost = totalGasUnits.mul(gasPrice);
|
|
341
532
|
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
const
|
|
345
|
-
|
|
346
|
-
// read latest round & compute age
|
|
347
|
-
const [roundId, answer, startedAt, updatedAt, answeredInRound] = await aggregator.latestRoundData();
|
|
348
|
-
const now = (await this.provider.getBlock("latest")).timestamp;
|
|
349
|
-
const ageSec = Number(now) - Number(updatedAt);
|
|
350
|
-
|
|
351
|
-
const ONE_HOUR = 1 * 3600;
|
|
352
|
-
// const ONE_HOUR = 10;
|
|
353
|
-
if (ageSec > ONE_HOUR) {
|
|
354
|
-
// safety check - only run in non-production contexts
|
|
355
|
-
const network = await this.provider.getNetwork();
|
|
356
|
-
const chainId = network.chainId;
|
|
357
|
-
const allowedTestChains = new Set([560048]);
|
|
358
|
-
if (!allowedTestChains.has(chainId)) {
|
|
359
|
-
console.warn(`MockAggregator is stale (${ageSec}s) but chainId ${chainId} is not a test/local network — skipping update.`);
|
|
360
|
-
return;
|
|
361
|
-
}
|
|
533
|
+
// 4) Safety multiplier on top of that (e.g. 1.5x).
|
|
534
|
+
const safetyMultiplier = options?.safetyMultiplier ?? 1.5;
|
|
535
|
+
const safetyScaled = Math.round(safetyMultiplier * 100); // e.g. 150
|
|
362
536
|
|
|
537
|
+
const bufferedCost = baseCost
|
|
538
|
+
.mul(safetyScaled)
|
|
539
|
+
.div(100); // apply safety factor
|
|
363
540
|
|
|
364
|
-
|
|
365
|
-
const res = await fetch('https://api.coingecko.com/api/v3/simple/price?ids=ethereum&vs_currencies=usd');
|
|
366
|
-
const data = await res.json();
|
|
367
|
-
const ethUsd = data.ethereum.usd;
|
|
541
|
+
let bufferWei = bufferedCost.toBigInt();
|
|
368
542
|
|
|
369
|
-
|
|
543
|
+
// 5) Enforce a minimum floor (e.g. ~0.002 ETH).
|
|
544
|
+
const defaultMinBufferWei = BigInt(2_000_000_000_000_000); // 0.002 ETH
|
|
545
|
+
const minBufferWei = options?.minBufferWei ?? defaultMinBufferWei;
|
|
370
546
|
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
// const alttx = await aggregator.updateStale(currentEthPrice, now - 7200);
|
|
374
|
-
// const altreceipt = await alttx.wait(1);
|
|
375
|
-
// console.log('stale update receipt', altreceipt)
|
|
376
|
-
|
|
377
|
-
//update answer with current timestamp
|
|
378
|
-
const tx = await aggregator.updateAnswer(currentEthPrice);
|
|
379
|
-
const txreceipt = await tx.wait(1);
|
|
380
|
-
// console.log('MockAggregator answer updated - receipt:', txreceipt)
|
|
381
|
-
} catch (err: any) {
|
|
382
|
-
console.error('MockAggregator updateAnswer failed', err?.message || err);
|
|
383
|
-
}
|
|
384
|
-
} else {
|
|
385
|
-
console.log(`MockAggregator updated ${ageSec}s ago — no update needed`);
|
|
547
|
+
if (bufferWei < minBufferWei) {
|
|
548
|
+
bufferWei = minBufferWei;
|
|
386
549
|
}
|
|
387
|
-
}
|
|
388
|
-
|
|
389
|
-
|
|
390
550
|
|
|
551
|
+
return bufferWei;
|
|
552
|
+
}
|
|
391
553
|
|
|
554
|
+
// ---------------------------------------------------------------------
|
|
555
|
+
// Internal ETH Staking client helper functions
|
|
556
|
+
// ---------------------------------------------------------------------
|
|
392
557
|
|
|
393
|
-
//
|
|
394
|
-
|
|
558
|
+
// ! This is a temporary measure for Hoodi testnet because there is no aggregator deployed
|
|
559
|
+
// private async updateMockAggregatorPrice() {
|
|
560
|
+
// const aggregator = this.contract.MockAggregator;
|
|
561
|
+
|
|
562
|
+
// // read latest round & compute age
|
|
563
|
+
// const [roundId, answer, startedAt, updatedAt, answeredInRound] = await aggregator.latestRoundData();
|
|
564
|
+
// const now = (await this.provider.getBlock("latest")).timestamp;
|
|
565
|
+
// const ageSec = Number(now) - Number(updatedAt);
|
|
566
|
+
|
|
567
|
+
// const ONE_HOUR = 1 * 3600;
|
|
568
|
+
// // const ONE_HOUR = 10;
|
|
569
|
+
// if (ageSec > ONE_HOUR) {
|
|
570
|
+
// // safety check - only run in non-production contexts
|
|
571
|
+
// const network = await this.provider.getNetwork();
|
|
572
|
+
// const chainId = network.chainId;
|
|
573
|
+
// const allowedTestChains = new Set([560048]);
|
|
574
|
+
// if (!allowedTestChains.has(chainId)) {
|
|
575
|
+
// console.warn(`MockAggregator is stale (${ageSec}s) but chainId ${chainId} is not a test/local network — skipping update.`);
|
|
576
|
+
// return;
|
|
577
|
+
// }
|
|
578
|
+
|
|
579
|
+
|
|
580
|
+
// //fetch the current ETH / USD price
|
|
581
|
+
// const res = await fetch('https://api.coingecko.com/api/v3/simple/price?ids=ethereum&vs_currencies=usd');
|
|
582
|
+
// const data = await res.json();
|
|
583
|
+
// const ethUsd = data.ethereum.usd;
|
|
584
|
+
|
|
585
|
+
// const currentEthPrice = ethers.utils.parseUnits(ethUsd.toString(), 8);
|
|
586
|
+
|
|
587
|
+
// try {
|
|
588
|
+
// //update to be intentionally stale
|
|
589
|
+
// // const alttx = await aggregator.updateStale(currentEthPrice, now - 7200);
|
|
590
|
+
// // const altreceipt = await alttx.wait(1);
|
|
591
|
+
// // console.log('stale update receipt', altreceipt)
|
|
592
|
+
|
|
593
|
+
// //update answer with current timestamp
|
|
594
|
+
// const tx = await aggregator.updateAnswer(currentEthPrice);
|
|
595
|
+
// const txreceipt = await tx.wait(1);
|
|
596
|
+
// // console.log('MockAggregator answer updated - receipt:', txreceipt)
|
|
597
|
+
// } catch (err: any) {
|
|
598
|
+
// console.error('MockAggregator updateAnswer failed', err?.message || err);
|
|
599
|
+
// }
|
|
600
|
+
// } else {
|
|
601
|
+
// console.log(`MockAggregator updated ${ageSec}s ago — no update needed`);
|
|
602
|
+
// }
|
|
603
|
+
// }
|
|
604
|
+
}
|