@lidofinance/lsv-cli 1.4.0 → 1.5.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/abi/Dashboard.d.ts +24 -0
- package/dist/abi/PredepositGuarantee.d.ts +48 -0
- package/dist/abi/PredepositGuarantee.js +32 -0
- package/dist/abi/PredepositGuarantee.js.map +1 -1
- package/dist/abi/StEth.d.ts +1175 -59
- package/dist/abi/StEth.js +885 -320
- package/dist/abi/StEth.js.map +1 -1
- package/dist/abi/defi-wrapper/Factory.d.ts +532 -657
- package/dist/abi/defi-wrapper/Factory.js +1083 -647
- package/dist/abi/defi-wrapper/Factory.js.map +1 -1
- package/dist/abi/defi-wrapper/OssifiableProxy.d.ts +71 -0
- package/dist/abi/defi-wrapper/OssifiableProxy.js +93 -0
- package/dist/abi/defi-wrapper/OssifiableProxy.js.map +1 -0
- package/dist/abi/defi-wrapper/StvStETHPool.d.ts +38 -32
- package/dist/abi/defi-wrapper/StvStETHPool.js +50 -42
- package/dist/abi/defi-wrapper/StvStETHPool.js.map +1 -1
- package/dist/abi/defi-wrapper/TimeLock.d.ts +770 -0
- package/dist/abi/defi-wrapper/TimeLock.js +999 -0
- package/dist/abi/defi-wrapper/TimeLock.js.map +1 -0
- package/dist/abi/defi-wrapper/index.d.ts +2 -0
- package/dist/abi/defi-wrapper/index.js +2 -0
- package/dist/abi/defi-wrapper/index.js.map +1 -1
- package/dist/contracts/defi-wrapper/index.d.ts +2 -0
- package/dist/contracts/defi-wrapper/index.js +2 -0
- package/dist/contracts/defi-wrapper/index.js.map +1 -1
- package/dist/contracts/defi-wrapper/ossifiable-proxy.d.ts +4 -0
- package/dist/contracts/defi-wrapper/ossifiable-proxy.js +12 -0
- package/dist/contracts/defi-wrapper/ossifiable-proxy.js.map +1 -0
- package/dist/contracts/defi-wrapper/timelock.d.ts +4 -0
- package/dist/contracts/defi-wrapper/timelock.js +12 -0
- package/dist/contracts/defi-wrapper/timelock.js.map +1 -0
- package/dist/contracts/steth.d.ts +4 -27706
- package/dist/contracts/steth.js +2 -2
- package/dist/contracts/steth.js.map +1 -1
- package/dist/features/consolidation.js +19 -3
- package/dist/features/consolidation.js.map +1 -1
- package/dist/features/defi-wrapper/create-vault.js +16 -13
- package/dist/features/defi-wrapper/create-vault.js.map +1 -1
- package/dist/features/defi-wrapper/defi-wrapper-factory.d.ts +10 -27
- package/dist/features/defi-wrapper/defi-wrapper-factory.js +105 -15
- package/dist/features/defi-wrapper/defi-wrapper-factory.js.map +1 -1
- package/dist/features/defi-wrapper/distributor.d.ts +24 -0
- package/dist/features/defi-wrapper/distributor.js +300 -0
- package/dist/features/defi-wrapper/distributor.js.map +1 -0
- package/dist/features/defi-wrapper/index.d.ts +1 -0
- package/dist/features/defi-wrapper/index.js +1 -0
- package/dist/features/defi-wrapper/index.js.map +1 -1
- package/dist/features/defi-wrapper/pool-info.d.ts +17 -2
- package/dist/features/defi-wrapper/pool-info.js +63 -13
- package/dist/features/defi-wrapper/pool-info.js.map +1 -1
- package/dist/features/defi-wrapper/timelock.d.ts +19 -0
- package/dist/features/defi-wrapper/timelock.js +198 -0
- package/dist/features/defi-wrapper/timelock.js.map +1 -0
- package/dist/features/deposits/check-bls-deposits.js +15 -3
- package/dist/features/deposits/check-bls-deposits.js.map +1 -1
- package/dist/features/deposits/make-pdg-proof.js +15 -3
- package/dist/features/deposits/make-pdg-proof.js.map +1 -1
- package/dist/features/deposits/no-pdg.js +50 -14
- package/dist/features/deposits/no-pdg.js.map +1 -1
- package/dist/features/deposits/pdg.js +5 -1
- package/dist/features/deposits/pdg.js.map +1 -1
- package/dist/features/dev-tools/impersonate.js +5 -1
- package/dist/features/dev-tools/impersonate.js.map +1 -1
- package/dist/features/metrics.js +24 -6
- package/dist/features/metrics.js.map +1 -1
- package/dist/features/mint-burn/allowance.js +15 -6
- package/dist/features/mint-burn/allowance.js.map +1 -1
- package/dist/features/mint-burn/burn-steth.js +5 -1
- package/dist/features/mint-burn/burn-steth.js.map +1 -1
- package/dist/features/mint-burn/index.d.ts +1 -0
- package/dist/features/mint-burn/index.js +1 -0
- package/dist/features/mint-burn/index.js.map +1 -1
- package/dist/features/mint-burn/mint-limit.d.ts +9 -0
- package/dist/features/mint-burn/mint-limit.js +31 -0
- package/dist/features/mint-burn/mint-limit.js.map +1 -0
- package/dist/features/mint-burn/mint-steth.js +5 -1
- package/dist/features/mint-burn/mint-steth.js.map +1 -1
- package/dist/features/pdg.js +5 -1
- package/dist/features/pdg.js.map +1 -1
- package/dist/features/utils/connection.js +5 -1
- package/dist/features/utils/connection.js.map +1 -1
- package/dist/features/utils/index.d.ts +1 -0
- package/dist/features/utils/index.js +1 -0
- package/dist/features/utils/index.js.map +1 -1
- package/dist/features/utils/liability-shares.js +5 -1
- package/dist/features/utils/liability-shares.js.map +1 -1
- package/dist/features/utils/minting-capacity.js +4 -3
- package/dist/features/utils/minting-capacity.js.map +1 -1
- package/dist/features/utils/quarantine.js +5 -1
- package/dist/features/utils/quarantine.js.map +1 -1
- package/dist/features/utils/report-fresh.js +15 -3
- package/dist/features/utils/report-fresh.js.map +1 -1
- package/dist/features/utils/try-fetch.d.ts +5 -0
- package/dist/features/utils/try-fetch.js +26 -0
- package/dist/features/utils/try-fetch.js.map +1 -0
- package/dist/features/vault-factory.js +15 -3
- package/dist/features/vault-factory.js.map +1 -1
- package/dist/features/vault-operations/connect-vault.js +10 -2
- package/dist/features/vault-operations/connect-vault.js.map +1 -1
- package/dist/features/vault-operations/dashboard-by-vault.js +10 -2
- package/dist/features/vault-operations/dashboard-by-vault.js.map +1 -1
- package/dist/features/vault-operations/roles.js +10 -2
- package/dist/features/vault-operations/roles.js.map +1 -1
- package/dist/features/vault-operations/vault-health.js +5 -1
- package/dist/features/vault-operations/vault-health.js.map +1 -1
- package/dist/features/vault-operations/vault-info.js +10 -2
- package/dist/features/vault-operations/vault-info.js.map +1 -1
- package/dist/features/vault-operations/vault-overview.js +25 -5
- package/dist/features/vault-operations/vault-overview.js.map +1 -1
- package/dist/features/vault-operations/vault-roles.js +10 -2
- package/dist/features/vault-operations/vault-roles.js.map +1 -1
- package/dist/features/vault-operations/vaults-by-role.d.ts +24 -0
- package/dist/features/vault-operations/vaults-by-role.js +78 -27
- package/dist/features/vault-operations/vaults-by-role.js.map +1 -1
- package/dist/index.js +9 -5
- package/dist/index.js.map +1 -1
- package/dist/programs/account/read.js +10 -5
- package/dist/programs/account/read.js.map +1 -1
- package/dist/programs/contracts/dashboard/read.js +15 -3
- package/dist/programs/contracts/dashboard/read.js.map +1 -1
- package/dist/programs/contracts/dashboard/write.js +212 -38
- package/dist/programs/contracts/dashboard/write.js.map +1 -1
- package/dist/programs/contracts/hub/read.js +15 -5
- package/dist/programs/contracts/hub/read.js.map +1 -1
- package/dist/programs/contracts/hub/write.js +10 -2
- package/dist/programs/contracts/hub/write.js.map +1 -1
- package/dist/programs/contracts/operator-grid/read.js +5 -1
- package/dist/programs/contracts/operator-grid/read.js.map +1 -1
- package/dist/programs/contracts/operator-grid/write.js +5 -1
- package/dist/programs/contracts/operator-grid/write.js.map +1 -1
- package/dist/programs/contracts/pdg/read.js +5 -1
- package/dist/programs/contracts/pdg/read.js.map +1 -1
- package/dist/programs/contracts/pdg/write.js +33 -3
- package/dist/programs/contracts/pdg/write.js.map +1 -1
- package/dist/programs/contracts/vault/write.js +5 -1
- package/dist/programs/contracts/vault/write.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/distributor/read.js +17 -5
- package/dist/programs/defi-wrapper/contracts/distributor/read.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/factory/read.js +73 -13
- package/dist/programs/defi-wrapper/contracts/factory/read.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/factory/write.js +171 -65
- package/dist/programs/defi-wrapper/contracts/factory/write.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-pool/read.js +62 -18
- package/dist/programs/defi-wrapper/contracts/stv-pool/read.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/read.js +62 -18
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/read.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/read.js +64 -16
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/read.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/write.js +33 -6
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/write.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/distributor/index.d.ts +3 -0
- package/dist/programs/defi-wrapper/use-cases/distributor/index.js +4 -0
- package/dist/programs/defi-wrapper/use-cases/distributor/index.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/distributor/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/distributor/main.js +6 -0
- package/dist/programs/defi-wrapper/use-cases/distributor/main.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/distributor/read.js +86 -0
- package/dist/programs/defi-wrapper/use-cases/distributor/read.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/distributor/write.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/distributor/write.js +191 -0
- package/dist/programs/defi-wrapper/use-cases/distributor/write.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/health/read.js +71 -21
- package/dist/programs/defi-wrapper/use-cases/health/read.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/health/utils.js +10 -2
- package/dist/programs/defi-wrapper/use-cases/health/utils.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/health/write.js +65 -22
- package/dist/programs/defi-wrapper/use-cases/health/write.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/index.d.ts +2 -0
- package/dist/programs/defi-wrapper/use-cases/index.js +2 -0
- package/dist/programs/defi-wrapper/use-cases/index.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/index.d.ts +3 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/index.js +4 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/index.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/main.js +6 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/main.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/read.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/read.js +362 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/read.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/write.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/write.js +86 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/write.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/index.d.ts +2 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/index.js +3 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/index.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/main.js +6 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/main.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/write.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/write.js +369 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/write.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/index.d.ts +6 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/index.js +7 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/index.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/main.js +6 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/main.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/index.d.ts +2 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/index.js +3 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/index.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/main.js +6 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/main.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/write.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/write.js +184 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/write.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/index.d.ts +3 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/index.js +4 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/index.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/main.js +6 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/main.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/read.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/read.js +80 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/read.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/write.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/write.js +139 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/write.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/index.d.ts +2 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/index.js +3 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/index.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/main.js +6 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/main.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/write.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/write.js +118 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/write.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/index.d.ts +1 -1
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/index.js +1 -2
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/index.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/read.js +333 -11
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/read.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/write.js +463 -2
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/write.js.map +1 -1
- package/dist/programs/dev-tools/defi-wrapper/write.js +41 -11
- package/dist/programs/dev-tools/defi-wrapper/write.js.map +1 -1
- package/dist/programs/pdg-helpers.js +55 -19
- package/dist/programs/pdg-helpers.js.map +1 -1
- package/dist/programs/use-cases/consolidation/write.js +5 -1
- package/dist/programs/use-cases/consolidation/write.js.map +1 -1
- package/dist/programs/use-cases/deposits/read.js +40 -8
- package/dist/programs/use-cases/deposits/read.js.map +1 -1
- package/dist/programs/use-cases/deposits/write.js +15 -3
- package/dist/programs/use-cases/deposits/write.js.map +1 -1
- package/dist/programs/use-cases/metrics/read.js +25 -5
- package/dist/programs/use-cases/metrics/read.js.map +1 -1
- package/dist/programs/use-cases/report/read.js +25 -5
- package/dist/programs/use-cases/report/read.js.map +1 -1
- package/dist/programs/use-cases/report/write.js +10 -2
- package/dist/programs/use-cases/report/write.js.map +1 -1
- package/dist/programs/use-cases/vault-operations/write.js +30 -6
- package/dist/programs/use-cases/vault-operations/write.js.map +1 -1
- package/dist/providers/index.d.ts +1 -1
- package/dist/providers/index.js +1 -1
- package/dist/tests/utils/rate-limit.test.d.ts +1 -0
- package/dist/tests/utils/rate-limit.test.js +246 -0
- package/dist/tests/utils/rate-limit.test.js.map +1 -0
- package/dist/types/index.d.ts +2 -2
- package/dist/types/index.js +2 -2
- package/dist/utils/arguments.d.ts +14 -0
- package/dist/utils/arguments.js +28 -0
- package/dist/utils/arguments.js.map +1 -1
- package/dist/utils/cache.d.ts +6 -4
- package/dist/utils/cache.js +14 -11
- package/dist/utils/cache.js.map +1 -1
- package/dist/utils/charts/blessed/charts-apr.js +5 -1
- package/dist/utils/charts/blessed/charts-apr.js.map +1 -1
- package/dist/utils/charts/blessed/charts-rewards.js +5 -1
- package/dist/utils/charts/blessed/charts-rewards.js.map +1 -1
- package/dist/utils/charts/simple/simple-charts.js +5 -1
- package/dist/utils/charts/simple/simple-charts.js.map +1 -1
- package/dist/utils/commands/report.d.ts +5 -2
- package/dist/utils/commands/report.js +21 -7
- package/dist/utils/commands/report.js.map +1 -1
- package/dist/utils/consts.d.ts +1 -0
- package/dist/utils/consts.js +5 -0
- package/dist/utils/consts.js.map +1 -1
- package/dist/utils/fetchCL.d.ts +10 -0
- package/dist/utils/fetchCL.js +19 -0
- package/dist/utils/fetchCL.js.map +1 -1
- package/dist/utils/health/health-utils.d.ts +2 -27707
- package/dist/utils/health/health-utils.js +26 -8
- package/dist/utils/health/health-utils.js.map +1 -1
- package/dist/utils/index.d.ts +1 -0
- package/dist/utils/index.js +1 -0
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/prompts/operations.js +1 -3
- package/dist/utils/prompts/operations.js.map +1 -1
- package/dist/utils/rate-limit.d.ts +10 -0
- package/dist/utils/rate-limit.js +30 -0
- package/dist/utils/rate-limit.js.map +1 -0
- package/dist/utils/read-programs-by-abi.js +22 -4
- package/dist/utils/read-programs-by-abi.js.map +1 -1
- package/dist/utils/report/statistic-data.js +8 -2
- package/dist/utils/report/statistic-data.js.map +1 -1
- package/dist/utils/share-rate.js +16 -4
- package/dist/utils/share-rate.js.map +1 -1
- package/dist/utils/sleep.js.map +1 -1
- package/dist/utils/transactions/tx-private-key.d.ts +3 -5
- package/dist/utils/transactions/tx-private-key.js +13 -10
- package/dist/utils/transactions/tx-private-key.js.map +1 -1
- package/dist/utils/transactions/types.d.ts +7 -0
- package/dist/utils/transactions/utils.js +2 -2
- package/dist/utils/transactions/utils.js.map +1 -1
- package/dist/version/index.js +1 -1
- package/package.json +3 -12
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/create-pool.js +0 -180
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/create-pool.js.map +0 -1
- /package/dist/programs/defi-wrapper/use-cases/{wrapper-operations/create-pool.d.ts → distributor/read.d.ts} +0 -0
|
@@ -0,0 +1,198 @@
|
|
|
1
|
+
import { logInfo, callWriteMethodWithReceipt, confirmOperation, callReadMethodSilent, stringToAddress, addressPrompt, stringToHash, textPrompt, stringToHex, } from '../../utils/index.js';
|
|
2
|
+
import { zeroHash, isHash, formatEther, } from 'viem';
|
|
3
|
+
import { getTimeLockContract } from '../../contracts/defi-wrapper/index.js';
|
|
4
|
+
// Common constants
|
|
5
|
+
export const DEFAULT_SALT = zeroHash;
|
|
6
|
+
export const DEFAULT_PREDECESSOR = zeroHash;
|
|
7
|
+
// Common argument and option definitions
|
|
8
|
+
export const TIMELOCK_ARGUMENT = [
|
|
9
|
+
'[timelock]',
|
|
10
|
+
'timelock contract address',
|
|
11
|
+
stringToAddress,
|
|
12
|
+
];
|
|
13
|
+
export const OPERATION_ID_ARGUMENT = [
|
|
14
|
+
'[operationId]',
|
|
15
|
+
'operation ID (bytes32 hash)',
|
|
16
|
+
stringToHash,
|
|
17
|
+
];
|
|
18
|
+
export const ROLE_ARGUMENT = [
|
|
19
|
+
'[role]',
|
|
20
|
+
'role (bytes32 hex or role name like DEFAULT_ADMIN_ROLE)',
|
|
21
|
+
];
|
|
22
|
+
export const ACCOUNT_GRANT_ARGUMENT = [
|
|
23
|
+
'[account]',
|
|
24
|
+
'account address to grant role to',
|
|
25
|
+
stringToAddress,
|
|
26
|
+
];
|
|
27
|
+
export const ACCOUNT_REVOKE_ARGUMENT = [
|
|
28
|
+
'[account]',
|
|
29
|
+
'account address to revoke role from',
|
|
30
|
+
stringToAddress,
|
|
31
|
+
];
|
|
32
|
+
export const SALT_OPTION = [
|
|
33
|
+
'-s, --salt <salt>',
|
|
34
|
+
'salt for operation (bytes32 hex, default: 0x0)',
|
|
35
|
+
stringToHash,
|
|
36
|
+
DEFAULT_SALT,
|
|
37
|
+
];
|
|
38
|
+
// Helper function to get timelock from argument or prompt user
|
|
39
|
+
export const getPromptTimelock = async (argAddress) => {
|
|
40
|
+
if (argAddress)
|
|
41
|
+
return getTimeLockContract(argAddress);
|
|
42
|
+
const timelockPrompt = await addressPrompt('Enter timelock contract address', 'timelock');
|
|
43
|
+
return getTimeLockContract(timelockPrompt.timelock);
|
|
44
|
+
};
|
|
45
|
+
export const promptRole = async (roleInput,
|
|
46
|
+
// hard to match correct type here
|
|
47
|
+
contract) => {
|
|
48
|
+
if (!roleInput) {
|
|
49
|
+
const rolePrompt = await textPrompt('Enter role (bytes32 hex or role name like DEFAULT_ADMIN_ROLE)', 'role');
|
|
50
|
+
roleInput = rolePrompt.role;
|
|
51
|
+
}
|
|
52
|
+
const role = await resolveRole(roleInput, contract);
|
|
53
|
+
return role;
|
|
54
|
+
};
|
|
55
|
+
export const promptAccount = async (accountInput, message) => {
|
|
56
|
+
let account;
|
|
57
|
+
if (!accountInput) {
|
|
58
|
+
const accountPrompt = await addressPrompt(message, 'account');
|
|
59
|
+
account = accountPrompt.account;
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
account = stringToAddress(accountInput);
|
|
63
|
+
}
|
|
64
|
+
return account;
|
|
65
|
+
};
|
|
66
|
+
export const promptOperationId = async (operationIdInput) => {
|
|
67
|
+
let operationId;
|
|
68
|
+
if (!operationIdInput) {
|
|
69
|
+
const operationIdPrompt = await textPrompt('Enter operation ID (bytes32 hash)', 'operationId');
|
|
70
|
+
operationIdInput = operationIdPrompt.operationId;
|
|
71
|
+
}
|
|
72
|
+
// Validate and convert to hex - if already hex, use as is
|
|
73
|
+
if (isHash(operationIdInput)) {
|
|
74
|
+
operationId = operationIdInput;
|
|
75
|
+
}
|
|
76
|
+
else {
|
|
77
|
+
operationId = stringToHash(operationIdInput);
|
|
78
|
+
}
|
|
79
|
+
return operationId;
|
|
80
|
+
};
|
|
81
|
+
// Helper function to process salt option
|
|
82
|
+
export const processSalt = (saltOption) => {
|
|
83
|
+
return saltOption ? stringToHex(saltOption) : DEFAULT_SALT;
|
|
84
|
+
};
|
|
85
|
+
// Helper function to resolve role
|
|
86
|
+
export const resolveRole = async (roleInput, contract) => {
|
|
87
|
+
if (isHash(roleInput))
|
|
88
|
+
return roleInput;
|
|
89
|
+
try {
|
|
90
|
+
const role = (await callReadMethodSilent({
|
|
91
|
+
contract,
|
|
92
|
+
methodName: roleInput,
|
|
93
|
+
payload: [],
|
|
94
|
+
}));
|
|
95
|
+
logInfo(`Resolved role "${roleInput}" to ${role}`);
|
|
96
|
+
return role;
|
|
97
|
+
}
|
|
98
|
+
catch {
|
|
99
|
+
throw new Error(`Failed to resolve role "${roleInput}". Please provide a valid role name (e.g., DEFAULT_ADMIN_ROLE) or bytes32 hex.`);
|
|
100
|
+
}
|
|
101
|
+
};
|
|
102
|
+
export const waitTimeTo = (timestamp) => {
|
|
103
|
+
const now = BigInt(Math.floor(Date.now() / 1000));
|
|
104
|
+
return timestamp > now ? timestamp - now : 0n;
|
|
105
|
+
};
|
|
106
|
+
// Helper function for propose operations
|
|
107
|
+
export const proposeOperation = async (timelock, target, data, salt, functionName, confirmationMessage) => {
|
|
108
|
+
const timelockContract = await getTimeLockContract(timelock);
|
|
109
|
+
const minDelay = await callReadMethodSilent({
|
|
110
|
+
contract: timelockContract,
|
|
111
|
+
methodName: 'getMinDelay',
|
|
112
|
+
payload: [],
|
|
113
|
+
});
|
|
114
|
+
const predecessor = DEFAULT_PREDECESSOR;
|
|
115
|
+
const operationId = await callReadMethodSilent({
|
|
116
|
+
contract: timelockContract,
|
|
117
|
+
methodName: 'hashOperation',
|
|
118
|
+
payload: [[target, 0n, data, predecessor, salt]],
|
|
119
|
+
});
|
|
120
|
+
logInfo('Proposing operation:');
|
|
121
|
+
logInfo(` Operation ID: ${operationId}`);
|
|
122
|
+
logInfo(` Target: ${target}`);
|
|
123
|
+
logInfo(` Value: 0`);
|
|
124
|
+
logInfo(` Payload: ${data}`);
|
|
125
|
+
logInfo(` Predecessor: ${predecessor}`);
|
|
126
|
+
logInfo(` Salt: ${salt}`);
|
|
127
|
+
logInfo(` Function: ${functionName}`);
|
|
128
|
+
logInfo(` Min delay: ${minDelay} seconds`);
|
|
129
|
+
const confirm = await confirmOperation(confirmationMessage);
|
|
130
|
+
if (!confirm) {
|
|
131
|
+
throw new Error('Operation cancelled by user');
|
|
132
|
+
}
|
|
133
|
+
await callWriteMethodWithReceipt({
|
|
134
|
+
contract: timelockContract,
|
|
135
|
+
methodName: 'schedule',
|
|
136
|
+
payload: [target, 0n, data, predecessor, salt, minDelay],
|
|
137
|
+
});
|
|
138
|
+
logInfo(`✅ Operation proposed successfully!`);
|
|
139
|
+
logInfo(` Operation ID: ${operationId}`);
|
|
140
|
+
logInfo(` Execute after: ${minDelay} seconds`);
|
|
141
|
+
return operationId;
|
|
142
|
+
};
|
|
143
|
+
// Helper function for execute operations
|
|
144
|
+
export const executeOperation = async (timelock, target, data, salt, functionName, confirmationMessage, value = 0n, predecessor = DEFAULT_PREDECESSOR) => {
|
|
145
|
+
const timelockContract = await getTimeLockContract(timelock);
|
|
146
|
+
const operationId = await callReadMethodSilent({
|
|
147
|
+
contract: timelockContract,
|
|
148
|
+
methodName: 'hashOperation',
|
|
149
|
+
payload: [[target, value, data, predecessor, salt]],
|
|
150
|
+
});
|
|
151
|
+
logInfo('Calculated operation details:');
|
|
152
|
+
logInfo(` Operation ID: ${operationId}`);
|
|
153
|
+
logInfo(` Target: ${target}`);
|
|
154
|
+
logInfo(` Value: ${formatEther(value)} ETH`);
|
|
155
|
+
logInfo(` Payload: ${data}`);
|
|
156
|
+
logInfo(` Predecessor: ${predecessor}`);
|
|
157
|
+
logInfo(` Salt: ${salt}`);
|
|
158
|
+
const state = await callReadMethodSilent({
|
|
159
|
+
contract: timelockContract,
|
|
160
|
+
methodName: 'getOperationState',
|
|
161
|
+
payload: [[operationId]],
|
|
162
|
+
});
|
|
163
|
+
if (state === 0) {
|
|
164
|
+
logInfo('❌ Operation not found (Unset)');
|
|
165
|
+
logInfo(` Operation ID: ${operationId}`);
|
|
166
|
+
return;
|
|
167
|
+
}
|
|
168
|
+
if (state === 3) {
|
|
169
|
+
logInfo('✅ Operation already executed (Done)');
|
|
170
|
+
return;
|
|
171
|
+
}
|
|
172
|
+
if (state === 1) {
|
|
173
|
+
const timestamp = await callReadMethodSilent({
|
|
174
|
+
contract: timelockContract,
|
|
175
|
+
methodName: 'getTimestamp',
|
|
176
|
+
payload: [[operationId]],
|
|
177
|
+
});
|
|
178
|
+
const waitTime = waitTimeTo(timestamp);
|
|
179
|
+
logInfo(`⏳ Operation is waiting. Will be ready at timestamp ${timestamp} (in ${waitTime} seconds)`);
|
|
180
|
+
return;
|
|
181
|
+
}
|
|
182
|
+
logInfo('Executing operation:');
|
|
183
|
+
logInfo(` Operation ID: ${operationId}`);
|
|
184
|
+
logInfo(` Target: ${target}`);
|
|
185
|
+
logInfo(` Function: ${functionName}`);
|
|
186
|
+
const confirm = await confirmOperation(confirmationMessage);
|
|
187
|
+
if (!confirm)
|
|
188
|
+
return;
|
|
189
|
+
await callWriteMethodWithReceipt({
|
|
190
|
+
contract: timelockContract,
|
|
191
|
+
methodName: 'execute',
|
|
192
|
+
payload: [target, value, data, predecessor, salt],
|
|
193
|
+
value: value,
|
|
194
|
+
});
|
|
195
|
+
logInfo(`✅ Operation executed successfully!`);
|
|
196
|
+
logInfo(` Operation ID: ${operationId}`);
|
|
197
|
+
};
|
|
198
|
+
//# sourceMappingURL=timelock.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"timelock.js","sourceRoot":"","sources":["../../../features/defi-wrapper/timelock.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,10 @@
|
|
|
1
1
|
import { callReadMethod, isValidBLSDeposit } from '../../utils/index.js';
|
|
2
2
|
export const checkBLSDeposits = async (vaultContract, deposits) => {
|
|
3
|
-
const withdrawalCredentials = await callReadMethod(
|
|
3
|
+
const withdrawalCredentials = await callReadMethod({
|
|
4
|
+
contract: vaultContract,
|
|
5
|
+
methodName: 'withdrawalCredentials',
|
|
6
|
+
payload: [],
|
|
7
|
+
});
|
|
4
8
|
for (const deposit of deposits) {
|
|
5
9
|
const isBLSValid = await isValidBLSDeposit(deposit, withdrawalCredentials);
|
|
6
10
|
if (!isBLSValid) {
|
|
@@ -9,8 +13,16 @@ export const checkBLSDeposits = async (vaultContract, deposits) => {
|
|
|
9
13
|
}
|
|
10
14
|
};
|
|
11
15
|
export const checkBLSWithAmountDeposits = async (pdgContract, vaultContract, deposits) => {
|
|
12
|
-
const PREDEPOSIT_AMOUNT = await callReadMethod(
|
|
13
|
-
|
|
16
|
+
const PREDEPOSIT_AMOUNT = await callReadMethod({
|
|
17
|
+
contract: pdgContract,
|
|
18
|
+
methodName: 'PREDEPOSIT_AMOUNT',
|
|
19
|
+
payload: [],
|
|
20
|
+
});
|
|
21
|
+
const withdrawalCredentials = await callReadMethod({
|
|
22
|
+
contract: vaultContract,
|
|
23
|
+
methodName: 'withdrawalCredentials',
|
|
24
|
+
payload: [],
|
|
25
|
+
});
|
|
14
26
|
for (const deposit of deposits) {
|
|
15
27
|
const isBLSValid = await isValidBLSDeposit(deposit, withdrawalCredentials);
|
|
16
28
|
if (deposit.amount !== PREDEPOSIT_AMOUNT) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"check-bls-deposits.js","sourceRoot":"","sources":["../../../features/deposits/check-bls-deposits.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,OAAO,CAAC;AAI1D,MAAM,CAAC,MAAM,gBAAgB,GAAG,KAAK,EACnC,aAAmC,EACnC,QAAmB,EACnB,EAAE;IACF,MAAM,qBAAqB,GAAG,MAAM,cAAc,
|
|
1
|
+
{"version":3,"file":"check-bls-deposits.js","sourceRoot":"","sources":["../../../features/deposits/check-bls-deposits.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,OAAO,CAAC;AAI1D,MAAM,CAAC,MAAM,gBAAgB,GAAG,KAAK,EACnC,aAAmC,EACnC,QAAmB,EACnB,EAAE;IACF,MAAM,qBAAqB,GAAG,MAAM,cAAc,CAAC;QACjD,QAAQ,EAAE,aAAa;QACvB,UAAU,EAAE,uBAAuB;QACnC,OAAO,EAAE,EAAE;KACZ,CAAC,CAAC;IAEH,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;QAC/B,MAAM,UAAU,GAAG,MAAM,iBAAiB,CAAC,OAAO,EAAE,qBAAqB,CAAC,CAAC;QAE3E,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,MAAM,IAAI,KAAK,CACb,sDAAsD,OAAO,CAAC,MAAM,EAAE,CACvE,CAAC;QACJ,CAAC;IACH,CAAC;AACH,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,0BAA0B,GAAG,KAAK,EAC7C,WAAwC,EACxC,aAAmC,EACnC,QAAmB,EACnB,EAAE;IACF,MAAM,iBAAiB,GAAG,MAAM,cAAc,CAAC;QAC7C,QAAQ,EAAE,WAAW;QACrB,UAAU,EAAE,mBAAmB;QAC/B,OAAO,EAAE,EAAE;KACZ,CAAC,CAAC;IACH,MAAM,qBAAqB,GAAG,MAAM,cAAc,CAAC;QACjD,QAAQ,EAAE,aAAa;QACvB,UAAU,EAAE,uBAAuB;QACnC,OAAO,EAAE,EAAE;KACZ,CAAC,CAAC;IAEH,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;QAC/B,MAAM,UAAU,GAAG,MAAM,iBAAiB,CAAC,OAAO,EAAE,qBAAqB,CAAC,CAAC;QAE3E,IAAI,OAAO,CAAC,MAAM,KAAK,iBAAiB,EAAE,CAAC;YACzC,MAAM,IAAI,KAAK,CACb,iEAAiE,OAAO,CAAC,MAAM,EAAE,CAClF,CAAC;QACJ,CAAC;QACD,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,MAAM,IAAI,KAAK,CACb,sDAAsD,OAAO,CAAC,MAAM,EAAE,CACvE,CAAC;QACJ,CAAC;IACH,CAAC;AACH,CAAC,CAAC"}
|
|
@@ -3,9 +3,21 @@ import { logInfo, logResult, logTable, printError, showSpinner, createPDGProof,
|
|
|
3
3
|
import { getStakingVaultContract, } from '../../contracts/index.js';
|
|
4
4
|
import { VALIDATOR_STAGES } from '../../features/pdg.js';
|
|
5
5
|
export const checkValidatorStageAndStagedBalanceForActivation = async (pdgContract, pubkey) => {
|
|
6
|
-
const { stage, stakingVault } = await callReadMethodSilent(
|
|
7
|
-
|
|
8
|
-
|
|
6
|
+
const { stage, stakingVault } = await callReadMethodSilent({
|
|
7
|
+
contract: pdgContract,
|
|
8
|
+
methodName: 'validatorStatus',
|
|
9
|
+
payload: [[pubkey]],
|
|
10
|
+
});
|
|
11
|
+
const vaultStagedBalance = await callReadMethodSilent({
|
|
12
|
+
contract: await getStakingVaultContract(stakingVault),
|
|
13
|
+
methodName: 'stagedBalance',
|
|
14
|
+
payload: [],
|
|
15
|
+
});
|
|
16
|
+
const ACTIVATION_DEPOSIT_AMOUNT = await callReadMethodSilent({
|
|
17
|
+
contract: pdgContract,
|
|
18
|
+
methodName: 'ACTIVATION_DEPOSIT_AMOUNT',
|
|
19
|
+
payload: [],
|
|
20
|
+
});
|
|
9
21
|
if (vaultStagedBalance < ACTIVATION_DEPOSIT_AMOUNT) {
|
|
10
22
|
throw new Error(`Staged balance is less than ${formatEther(ACTIVATION_DEPOSIT_AMOUNT)} ETH (current: ${formatEther(vaultStagedBalance)} ETH)`);
|
|
11
23
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"make-pdg-proof.js","sourceRoot":"","sources":["../../../features/deposits/make-pdg-proof.ts"],"names":[],"mappings":"AAAA,OAAO,EAAO,WAAW,EAAE,MAAM,MAAM,CAAC;AAExC,OAAO,EACL,OAAO,EACP,SAAS,EACT,QAAQ,EACR,UAAU,EACV,WAAW,EACX,cAAc,EAEd,gBAAgB,EAChB,oBAAoB,GACrB,MAAM,OAAO,CAAC;AACf,OAAO,EAEL,uBAAuB,GACxB,MAAM,WAAW,CAAC;AACnB,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAEnD,MAAM,CAAC,MAAM,gDAAgD,GAAG,KAAK,EACnE,WAAwC,EACxC,MAAW,EACX,EAAE;IACF,MAAM,EAAE,KAAK,EAAE,YAAY,EAAE,GAAG,MAAM,oBAAoB,
|
|
1
|
+
{"version":3,"file":"make-pdg-proof.js","sourceRoot":"","sources":["../../../features/deposits/make-pdg-proof.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,9 +3,21 @@ import { callReadMethodSilent, confirmOperation, logInfo, numberPrompt, addressP
|
|
|
3
3
|
import { getAccount } from '../../providers/index.js';
|
|
4
4
|
export const checkNOBalancePDGforDeposit = async (pdgContract, nodeOperator) => {
|
|
5
5
|
const currentAccount = await getAccount();
|
|
6
|
-
const balance = await callReadMethodSilent(
|
|
7
|
-
|
|
8
|
-
|
|
6
|
+
const balance = await callReadMethodSilent({
|
|
7
|
+
contract: pdgContract,
|
|
8
|
+
methodName: 'nodeOperatorBalance',
|
|
9
|
+
payload: [[nodeOperator]],
|
|
10
|
+
});
|
|
11
|
+
const unlockedBalance = await callReadMethodSilent({
|
|
12
|
+
contract: pdgContract,
|
|
13
|
+
methodName: 'unlockedBalance',
|
|
14
|
+
payload: [[nodeOperator]],
|
|
15
|
+
});
|
|
16
|
+
const nodeOperatorGuarantor = await callReadMethodSilent({
|
|
17
|
+
contract: pdgContract,
|
|
18
|
+
methodName: 'nodeOperatorGuarantor',
|
|
19
|
+
payload: [[nodeOperator]],
|
|
20
|
+
});
|
|
9
21
|
let amountToTopUp = 0n;
|
|
10
22
|
let isNeedTopUp = false;
|
|
11
23
|
if (balance.total === 0n || unlockedBalance === 0n) {
|
|
@@ -26,8 +38,16 @@ export const checkNOBalancePDGforDeposit = async (pdgContract, nodeOperator) =>
|
|
|
26
38
|
return { balance, unlockedBalance, amountToTopUp, isNeedTopUp };
|
|
27
39
|
};
|
|
28
40
|
export const checkNOBalancePDGforDeposits = async (pdgContract, nodeOperator, countOfDeposits) => {
|
|
29
|
-
const PREDEPOSIT_AMOUNT = await callReadMethodSilent(
|
|
30
|
-
|
|
41
|
+
const PREDEPOSIT_AMOUNT = await callReadMethodSilent({
|
|
42
|
+
contract: pdgContract,
|
|
43
|
+
methodName: 'PREDEPOSIT_AMOUNT',
|
|
44
|
+
payload: [],
|
|
45
|
+
});
|
|
46
|
+
const unlockedBalance = await callReadMethodSilent({
|
|
47
|
+
contract: pdgContract,
|
|
48
|
+
methodName: 'unlockedBalance',
|
|
49
|
+
payload: [[nodeOperator]],
|
|
50
|
+
});
|
|
31
51
|
const amountToTopUp = PREDEPOSIT_AMOUNT * BigInt(countOfDeposits);
|
|
32
52
|
const isNeedTopUp = unlockedBalance < amountToTopUp;
|
|
33
53
|
if (isNeedTopUp) {
|
|
@@ -39,10 +59,16 @@ export const checkNOBalancePDGforDeposits = async (pdgContract, nodeOperator, co
|
|
|
39
59
|
};
|
|
40
60
|
export const checkNodeOperatorOrDepositorForDeposit = async (vault, pdg) => {
|
|
41
61
|
const currentAccount = await getAccount();
|
|
42
|
-
const vaultNodeOperator = await callReadMethodSilent(
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
62
|
+
const vaultNodeOperator = await callReadMethodSilent({
|
|
63
|
+
contract: vault,
|
|
64
|
+
methodName: 'nodeOperator',
|
|
65
|
+
payload: [],
|
|
66
|
+
});
|
|
67
|
+
const noDepositor = await callReadMethodSilent({
|
|
68
|
+
contract: pdg,
|
|
69
|
+
methodName: 'nodeOperatorDepositor',
|
|
70
|
+
payload: [[vaultNodeOperator]],
|
|
71
|
+
});
|
|
46
72
|
if (noDepositor.toLocaleLowerCase() !==
|
|
47
73
|
currentAccount.address.toLocaleLowerCase()) {
|
|
48
74
|
throw new Error(`You are not the depositor of the node operator ${vaultNodeOperator}. Only depositor can deposit from the vault.`);
|
|
@@ -51,10 +77,16 @@ export const checkNodeOperatorOrDepositorForDeposit = async (vault, pdg) => {
|
|
|
51
77
|
};
|
|
52
78
|
export const checkAndSpecifyNodeOperatorForTopUpOrWithdraw = async (vault, pdg, isTopUp) => {
|
|
53
79
|
const currentAccount = await getAccount();
|
|
54
|
-
const vaultNodeOperator = await callReadMethodSilent(
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
80
|
+
const vaultNodeOperator = await callReadMethodSilent({
|
|
81
|
+
contract: vault,
|
|
82
|
+
methodName: 'nodeOperator',
|
|
83
|
+
payload: [],
|
|
84
|
+
});
|
|
85
|
+
const noGuarantor = await callReadMethodSilent({
|
|
86
|
+
contract: pdg,
|
|
87
|
+
methodName: 'nodeOperatorGuarantor',
|
|
88
|
+
payload: [[vaultNodeOperator]],
|
|
89
|
+
});
|
|
58
90
|
const isNoGuarantor = noGuarantor.toLocaleLowerCase() ===
|
|
59
91
|
currentAccount.address.toLocaleLowerCase();
|
|
60
92
|
const isNodeOperator = vaultNodeOperator.toLocaleLowerCase() ===
|
|
@@ -73,7 +105,11 @@ export const checkAndSpecifyNodeOperatorForTopUpOrWithdraw = async (vault, pdg,
|
|
|
73
105
|
};
|
|
74
106
|
export const getGuarantor = async (pdgContract) => {
|
|
75
107
|
const currentAccount = await getAccount();
|
|
76
|
-
const balance = await callReadMethodSilent(
|
|
108
|
+
const balance = await callReadMethodSilent({
|
|
109
|
+
contract: pdgContract,
|
|
110
|
+
methodName: 'nodeOperatorBalance',
|
|
111
|
+
payload: [[currentAccount.address]],
|
|
112
|
+
});
|
|
77
113
|
if (balance.locked > 0n) {
|
|
78
114
|
throw new Error(`You have locked balance in PDG. You can't change the guarantor.`);
|
|
79
115
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"no-pdg.js","sourceRoot":"","sources":["../../../features/deposits/no-pdg.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,WAAW,EAAE,MAAM,MAAM,CAAC;AAG5C,OAAO,EACL,oBAAoB,EACpB,gBAAgB,EAChB,OAAO,EACP,YAAY,EACZ,aAAa,GACd,MAAM,OAAO,CAAC;AACf,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAEvC,MAAM,CAAC,MAAM,2BAA2B,GAAG,KAAK,EAC9C,WAAwC,EACxC,YAAqB,EACrB,EAAE;IACF,MAAM,cAAc,GAAG,MAAM,UAAU,EAAE,CAAC;IAE1C,MAAM,OAAO,GAAG,MAAM,oBAAoB,
|
|
1
|
+
{"version":3,"file":"no-pdg.js","sourceRoot":"","sources":["../../../features/deposits/no-pdg.ts"],"names":[],"mappings":"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"}
|
|
@@ -4,7 +4,11 @@ import { getChain } from '../../configs/index.js';
|
|
|
4
4
|
export const checkPdgIsPaused = async (pdgContract) => {
|
|
5
5
|
const chain = await getChain();
|
|
6
6
|
const isMainnet = chain.id === mainnet.id;
|
|
7
|
-
const isPaused = await callReadMethodSilent(
|
|
7
|
+
const isPaused = await callReadMethodSilent({
|
|
8
|
+
contract: pdgContract,
|
|
9
|
+
methodName: 'isPaused',
|
|
10
|
+
payload: [],
|
|
11
|
+
});
|
|
8
12
|
if (isPaused) {
|
|
9
13
|
const message = isMainnet
|
|
10
14
|
? 'PredepositGuarantee contract is paused until Phase 2'
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pdg.js","sourceRoot":"","sources":["../../../features/deposits/pdg.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAEtC,OAAO,EAAE,oBAAoB,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACtD,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAEnC,MAAM,CAAC,MAAM,gBAAgB,GAAG,KAAK,EACnC,WAAwC,EACxC,EAAE;IACF,MAAM,KAAK,GAAG,MAAM,QAAQ,EAAE,CAAC;IAC/B,MAAM,SAAS,GAAG,KAAK,CAAC,EAAE,KAAK,OAAO,CAAC,EAAE,CAAC;IAE1C,MAAM,QAAQ,GAAG,MAAM,oBAAoB,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"pdg.js","sourceRoot":"","sources":["../../../features/deposits/pdg.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAEtC,OAAO,EAAE,oBAAoB,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACtD,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAEnC,MAAM,CAAC,MAAM,gBAAgB,GAAG,KAAK,EACnC,WAAwC,EACxC,EAAE;IACF,MAAM,KAAK,GAAG,MAAM,QAAQ,EAAE,CAAC;IAC/B,MAAM,SAAS,GAAG,KAAK,CAAC,EAAE,KAAK,OAAO,CAAC,EAAE,CAAC;IAE1C,MAAM,QAAQ,GAAG,MAAM,oBAAoB,CAAC;QAC1C,QAAQ,EAAE,WAAW;QACrB,UAAU,EAAE,UAAU;QACtB,OAAO,EAAE,EAAE;KACZ,CAAC,CAAC;IAEH,IAAI,QAAQ,EAAE,CAAC;QACb,MAAM,OAAO,GAAG,SAAS;YACvB,CAAC,CAAC,sDAAsD;YACxD,CAAC,CAAC,oEAAoE,CAAC;QACzE,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;QAC1B,OAAO,CAAC,OAAO,CAAC,CAAC;QACjB,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5B,CAAC;IAED,OAAO,QAAQ,CAAC;AAClB,CAAC,CAAC"}
|
|
@@ -28,7 +28,11 @@ export const grantRoleFromImpersonatedAccount = async ({ currentAccount, contrac
|
|
|
28
28
|
functionName: 'grantRole',
|
|
29
29
|
args: [role, currentAccount],
|
|
30
30
|
});
|
|
31
|
-
const roleMembersAfter = await callReadMethodSilent(
|
|
31
|
+
const roleMembersAfter = await callReadMethodSilent({
|
|
32
|
+
contract: contract,
|
|
33
|
+
methodName: 'getRoleMembers',
|
|
34
|
+
payload: [[role]],
|
|
35
|
+
});
|
|
32
36
|
logInfo('Role members after granting: ', roleMembersAfter);
|
|
33
37
|
if (!roleMembersAfter.includes(currentAccount)) {
|
|
34
38
|
logInfo(`Address ${currentAccount} does not have the ${roleName} role`);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"impersonate.js","sourceRoot":"","sources":["../../../features/dev-tools/impersonate.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,gBAAgB,EAChB,IAAI,EACJ,aAAa,EACb,aAAa,EACb,kBAAkB,EAClB,UAAU,GACX,MAAM,MAAM,CAAC;AACd,OAAO,EAAE,OAAO,EAAE,oBAAoB,EAAE,MAAM,OAAO,CAAC;AACtD,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAE7C,MAAM,CAAC,MAAM,gCAAgC,GAAG,KAAK,EAAE,EACrD,cAAc,EACd,QAAQ,EACR,kBAAkB,EAClB,IAAI,EACJ,QAAQ,GAOT,EAAE,EAAE;IACH,MAAM,UAAU,GAAG,gBAAgB,CAAC;QAClC,KAAK,EAAE,MAAM,QAAQ,EAAE;QACvB,IAAI,EAAE,OAAO;QACb,SAAS,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC;KAC5B,CAAC;SACC,MAAM,CAAC,aAAa,CAAC;SACrB,MAAM,CAAC,aAAa,CAAC,CAAC;IAEzB,MAAM,UAAU,CAAC,kBAAkB,CAAC;QAClC,OAAO,EAAE,kBAAkB;KAC5B,CAAC,CAAC;IACH,MAAM,UAAU,CAAC,UAAU,CAAC;QAC1B,OAAO,EAAE,kBAAkB;QAC3B,KAAK,EAAE,UAAU,CAAC,IAAI,CAAC;KACxB,CAAC,CAAC;IAEH,MAAM,YAAY,GAAG,kBAAkB,CAAC;QACtC,OAAO,EAAE,kBAAkB;QAC3B,KAAK,EAAE,MAAM,QAAQ,EAAE;QACvB,SAAS,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC;KAC5B,CAAC,CAAC;IAEH,OAAO,CAAC,YAAY,QAAQ,gBAAgB,CAAC,CAAC;IAE9C,MAAM,YAAY,CAAC,aAAa,CAAC;QAC/B,OAAO,EAAE,QAAQ,CAAC,OAAO;QACzB,GAAG,EAAE,QAAQ,CAAC,GAAG;QACjB,YAAY,EAAE,WAAW;QACzB,IAAI,EAAE,CAAC,IAAI,EAAE,cAAc,CAAC;KAC7B,CAAC,CAAC;IAEH,MAAM,gBAAgB,GAAG,MAAM,oBAAoB,
|
|
1
|
+
{"version":3,"file":"impersonate.js","sourceRoot":"","sources":["../../../features/dev-tools/impersonate.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,gBAAgB,EAChB,IAAI,EACJ,aAAa,EACb,aAAa,EACb,kBAAkB,EAClB,UAAU,GACX,MAAM,MAAM,CAAC;AACd,OAAO,EAAE,OAAO,EAAE,oBAAoB,EAAE,MAAM,OAAO,CAAC;AACtD,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAE7C,MAAM,CAAC,MAAM,gCAAgC,GAAG,KAAK,EAAE,EACrD,cAAc,EACd,QAAQ,EACR,kBAAkB,EAClB,IAAI,EACJ,QAAQ,GAOT,EAAE,EAAE;IACH,MAAM,UAAU,GAAG,gBAAgB,CAAC;QAClC,KAAK,EAAE,MAAM,QAAQ,EAAE;QACvB,IAAI,EAAE,OAAO;QACb,SAAS,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC;KAC5B,CAAC;SACC,MAAM,CAAC,aAAa,CAAC;SACrB,MAAM,CAAC,aAAa,CAAC,CAAC;IAEzB,MAAM,UAAU,CAAC,kBAAkB,CAAC;QAClC,OAAO,EAAE,kBAAkB;KAC5B,CAAC,CAAC;IACH,MAAM,UAAU,CAAC,UAAU,CAAC;QAC1B,OAAO,EAAE,kBAAkB;QAC3B,KAAK,EAAE,UAAU,CAAC,IAAI,CAAC;KACxB,CAAC,CAAC;IAEH,MAAM,YAAY,GAAG,kBAAkB,CAAC;QACtC,OAAO,EAAE,kBAAkB;QAC3B,KAAK,EAAE,MAAM,QAAQ,EAAE;QACvB,SAAS,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC;KAC5B,CAAC,CAAC;IAEH,OAAO,CAAC,YAAY,QAAQ,gBAAgB,CAAC,CAAC;IAE9C,MAAM,YAAY,CAAC,aAAa,CAAC;QAC/B,OAAO,EAAE,QAAQ,CAAC,OAAO;QACzB,GAAG,EAAE,QAAQ,CAAC,GAAG;QACjB,YAAY,EAAE,WAAW;QACzB,IAAI,EAAE,CAAC,IAAI,EAAE,cAAc,CAAC;KAC7B,CAAC,CAAC;IAEH,MAAM,gBAAgB,GAAG,MAAM,oBAAoB,CAAC;QAClD,QAAQ,EAAE,QAAQ;QAClB,UAAU,EAAE,gBAAgB;QAC5B,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC;KAClB,CAAC,CAAC;IACH,OAAO,CAAC,+BAA+B,EAAE,gBAAgB,CAAC,CAAC;IAC3D,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC;QAC/C,OAAO,CAAC,WAAW,cAAc,sBAAsB,QAAQ,OAAO,CAAC,CAAC;QACxE,OAAO;IACT,CAAC;IAED,OAAO,CAAC,GAAG,QAAQ,uBAAuB,CAAC,CAAC;AAC9C,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,iCAAiC,GAAG,KAAK,EAAE,EACtD,QAAQ,EACR,YAAY,EACZ,IAAI,EACJ,kBAAkB,GAMnB,EAAE,EAAE;IACH,MAAM,UAAU,GAAG,gBAAgB,CAAC;QAClC,KAAK,EAAE,MAAM,QAAQ,EAAE;QACvB,IAAI,EAAE,OAAO;QACb,SAAS,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC;KAC5B,CAAC;SACC,MAAM,CAAC,aAAa,CAAC;SACrB,MAAM,CAAC,aAAa,CAAC,CAAC;IAEzB,MAAM,UAAU,CAAC,kBAAkB,CAAC;QAClC,OAAO,EAAE,kBAAkB;KAC5B,CAAC,CAAC;IAEH,MAAM,YAAY,GAAG,kBAAkB,CAAC;QACtC,OAAO,EAAE,kBAAkB;QAC3B,KAAK,EAAE,MAAM,QAAQ,EAAE;QACvB,SAAS,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC;KAC5B,CAAC,CAAC;IAEH,OAAO,CAAC,WAAW,YAAY,cAAc,IAAI,KAAK,CAAC,CAAC;IAExD,MAAM,YAAY,CAAC,aAAa,CAAC;QAC/B,OAAO,EAAE,QAAQ,CAAC,OAAO;QACzB,GAAG,EAAE,QAAQ,CAAC,GAAG;QACjB,YAAY,EAAE,YAAY;QAC1B,IAAI,EAAE,IAAI;KACX,CAAC,CAAC;IAEH,OAAO,CAAC,GAAG,YAAY,sBAAsB,CAAC,CAAC;AACjD,CAAC,CAAC"}
|
package/dist/features/metrics.js
CHANGED
|
@@ -5,8 +5,14 @@ export const getNodeOperatorFeeRatesByBlockNumbers = async (vaultAddress, blockN
|
|
|
5
5
|
for (const blockNumber of blockNumbers) {
|
|
6
6
|
let fee = await cache.getNodeOperatorFeeRate(vaultAddress, blockNumber);
|
|
7
7
|
if (fee === null) {
|
|
8
|
-
const feeRate = await callReadMethodSilent(
|
|
9
|
-
|
|
8
|
+
const feeRate = await callReadMethodSilent({
|
|
9
|
+
contract: dashboardContract,
|
|
10
|
+
methodName: 'feeRate',
|
|
11
|
+
payload: [
|
|
12
|
+
{
|
|
13
|
+
blockNumber: BigInt(blockNumber),
|
|
14
|
+
},
|
|
15
|
+
],
|
|
10
16
|
});
|
|
11
17
|
fee = BigInt(feeRate);
|
|
12
18
|
await cache.setNodeOperatorFeeRate(vaultAddress, blockNumber, fee);
|
|
@@ -21,8 +27,14 @@ export const getSettledGrowthsByBlockNumbers = async (vaultAddress, blockNumbers
|
|
|
21
27
|
for (const blockNumber of blockNumbers) {
|
|
22
28
|
let settledGrowth = await cache.getSettledGrowth(vaultAddress, blockNumber);
|
|
23
29
|
if (settledGrowth === null) {
|
|
24
|
-
settledGrowth = await callReadMethodSilent(
|
|
25
|
-
|
|
30
|
+
settledGrowth = await callReadMethodSilent({
|
|
31
|
+
contract: dashboardContract,
|
|
32
|
+
methodName: 'settledGrowth',
|
|
33
|
+
payload: [
|
|
34
|
+
{
|
|
35
|
+
blockNumber: BigInt(blockNumber),
|
|
36
|
+
},
|
|
37
|
+
],
|
|
26
38
|
});
|
|
27
39
|
await cache.setSettledGrowth(vaultAddress, blockNumber, settledGrowth);
|
|
28
40
|
}
|
|
@@ -36,8 +48,14 @@ export const getNodeOperatorAccruedFeeByBlockNumbers = async (vaultAddress, bloc
|
|
|
36
48
|
for (const blockNumber of blockNumbers) {
|
|
37
49
|
let nodeOperatorAccruedFee = await cache.getNodeOperatorAccruedFee(vaultAddress, blockNumber);
|
|
38
50
|
if (nodeOperatorAccruedFee === null) {
|
|
39
|
-
nodeOperatorAccruedFee = await callReadMethodSilent(
|
|
40
|
-
|
|
51
|
+
nodeOperatorAccruedFee = await callReadMethodSilent({
|
|
52
|
+
contract: dashboardContract,
|
|
53
|
+
methodName: 'accruedFee',
|
|
54
|
+
payload: [
|
|
55
|
+
{
|
|
56
|
+
blockNumber: BigInt(blockNumber),
|
|
57
|
+
},
|
|
58
|
+
],
|
|
41
59
|
});
|
|
42
60
|
await cache.setNodeOperatorAccruedFee(vaultAddress, blockNumber, nodeOperatorAccruedFee);
|
|
43
61
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"metrics.js","sourceRoot":"","sources":["../../features/metrics.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,KAAK,EAAE,MAAM,OAAO,CAAC;AAGpD,MAAM,CAAC,MAAM,qCAAqC,GAAG,KAAK,EACxD,YAAoB,EACpB,YAAsB,EACtB,iBAAoC,EACpC,EAAE;IACF,2DAA2D;IAC3D,MAAM,kBAAkB,GAAa,EAAE,CAAC;IACxC,KAAK,MAAM,WAAW,IAAI,YAAY,EAAE,CAAC;QACvC,IAAI,GAAG,GAAG,MAAM,KAAK,CAAC,sBAAsB,CAAC,YAAY,EAAE,WAAW,CAAC,CAAC;QACxE,IAAI,GAAG,KAAK,IAAI,EAAE,CAAC;YACjB,MAAM,OAAO,GAAG,MAAM,oBAAoB,CAAC,iBAAiB,EAAE,SAAS,EAAE;
|
|
1
|
+
{"version":3,"file":"metrics.js","sourceRoot":"","sources":["../../features/metrics.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,KAAK,EAAE,MAAM,OAAO,CAAC;AAGpD,MAAM,CAAC,MAAM,qCAAqC,GAAG,KAAK,EACxD,YAAoB,EACpB,YAAsB,EACtB,iBAAoC,EACpC,EAAE;IACF,2DAA2D;IAC3D,MAAM,kBAAkB,GAAa,EAAE,CAAC;IACxC,KAAK,MAAM,WAAW,IAAI,YAAY,EAAE,CAAC;QACvC,IAAI,GAAG,GAAG,MAAM,KAAK,CAAC,sBAAsB,CAAC,YAAY,EAAE,WAAW,CAAC,CAAC;QACxE,IAAI,GAAG,KAAK,IAAI,EAAE,CAAC;YACjB,MAAM,OAAO,GAAG,MAAM,oBAAoB,CAAC;gBACzC,QAAQ,EAAE,iBAAiB;gBAC3B,UAAU,EAAE,SAAS;gBACrB,OAAO,EAAE;oBACP;wBACE,WAAW,EAAE,MAAM,CAAC,WAAW,CAAC;qBACjC;iBACF;aACF,CAAC,CAAC;YACH,GAAG,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC;YACtB,MAAM,KAAK,CAAC,sBAAsB,CAAC,YAAY,EAAE,WAAW,EAAE,GAAG,CAAC,CAAC;QACrE,CAAC;QAED,kBAAkB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC/B,CAAC;IAED,OAAO,kBAAkB,CAAC;AAC5B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,+BAA+B,GAAG,KAAK,EAClD,YAAoB,EACpB,YAAsB,EACtB,iBAAoC,EACpC,EAAE;IACF,wDAAwD;IACxD,MAAM,cAAc,GAAa,EAAE,CAAC;IACpC,KAAK,MAAM,WAAW,IAAI,YAAY,EAAE,CAAC;QACvC,IAAI,aAAa,GAAG,MAAM,KAAK,CAAC,gBAAgB,CAAC,YAAY,EAAE,WAAW,CAAC,CAAC;QAC5E,IAAI,aAAa,KAAK,IAAI,EAAE,CAAC;YAC3B,aAAa,GAAG,MAAM,oBAAoB,CAAC;gBACzC,QAAQ,EAAE,iBAAiB;gBAC3B,UAAU,EAAE,eAAe;gBAC3B,OAAO,EAAE;oBACP;wBACE,WAAW,EAAE,MAAM,CAAC,WAAW,CAAC;qBACjC;iBACF;aACF,CAAC,CAAC;YACH,MAAM,KAAK,CAAC,gBAAgB,CAAC,YAAY,EAAE,WAAW,EAAE,aAAa,CAAC,CAAC;QACzE,CAAC;QAED,cAAc,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IACrC,CAAC;IAED,OAAO,cAAc,CAAC;AACxB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,uCAAuC,GAAG,KAAK,EAC1D,YAAoB,EACpB,YAAsB,EACtB,iBAAoC,EACpC,EAAE;IACF,mEAAmE;IACnE,MAAM,uBAAuB,GAAa,EAAE,CAAC;IAC7C,KAAK,MAAM,WAAW,IAAI,YAAY,EAAE,CAAC;QACvC,IAAI,sBAAsB,GAAG,MAAM,KAAK,CAAC,yBAAyB,CAChE,YAAY,EACZ,WAAW,CACZ,CAAC;QACF,IAAI,sBAAsB,KAAK,IAAI,EAAE,CAAC;YACpC,sBAAsB,GAAG,MAAM,oBAAoB,CAAC;gBAClD,QAAQ,EAAE,iBAAiB;gBAC3B,UAAU,EAAE,YAAY;gBACxB,OAAO,EAAE;oBACP;wBACE,WAAW,EAAE,MAAM,CAAC,WAAW,CAAC;qBACjC;iBACF;aACF,CAAC,CAAC;YACH,MAAM,KAAK,CAAC,yBAAyB,CACnC,YAAY,EACZ,WAAW,EACX,sBAAsB,CACvB,CAAC;QACJ,CAAC;QAED,uBAAuB,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;IACvD,CAAC;IAED,OAAO,uBAAuB,CAAC;AACjC,CAAC,CAAC"}
|
|
@@ -8,12 +8,17 @@ export const checkAllowance = async (contract, amount, token, populateTx) => {
|
|
|
8
8
|
let currentAmount = amount;
|
|
9
9
|
if (token === 'steth' || isShares) {
|
|
10
10
|
const stethContract = await getStethContract();
|
|
11
|
-
const allowance = await callReadMethodSilent(
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
11
|
+
const allowance = await callReadMethodSilent({
|
|
12
|
+
contract: stethContract,
|
|
13
|
+
methodName: 'allowance',
|
|
14
|
+
payload: [[accountAddress, contract.address]],
|
|
15
|
+
});
|
|
15
16
|
if (isShares) {
|
|
16
|
-
currentAmount = await callReadMethodSilent(
|
|
17
|
+
currentAmount = await callReadMethodSilent({
|
|
18
|
+
contract: stethContract,
|
|
19
|
+
methodName: 'getPooledEthByShares',
|
|
20
|
+
payload: [[amount]],
|
|
21
|
+
});
|
|
17
22
|
}
|
|
18
23
|
if (allowance < currentAmount) {
|
|
19
24
|
logInfo('Insufficient allowance');
|
|
@@ -30,7 +35,11 @@ export const checkAllowance = async (contract, amount, token, populateTx) => {
|
|
|
30
35
|
}
|
|
31
36
|
else {
|
|
32
37
|
const wstethContract = await getWstethContract();
|
|
33
|
-
const wstethAllowance = await callReadMethodSilent(
|
|
38
|
+
const wstethAllowance = await callReadMethodSilent({
|
|
39
|
+
contract: wstethContract,
|
|
40
|
+
methodName: 'allowance',
|
|
41
|
+
payload: [[accountAddress, contract.address]],
|
|
42
|
+
});
|
|
34
43
|
if (wstethAllowance < amount) {
|
|
35
44
|
logInfo('Insufficient allowance');
|
|
36
45
|
const confirm = await confirmOperation(`Do you want to set allowance for ${formatEther(amount)} ${token} to ${contract.address} (Dashboard contract)? Current allowance: ${formatEther(wstethAllowance)} wstETH`);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"allowance.js","sourceRoot":"","sources":["../../../features/mint-burn/allowance.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAA2B,MAAM,MAAM,CAAC;AAE5D,OAAO,EACL,gBAAgB,EAEhB,iBAAiB,GAClB,MAAM,WAAW,CAAC;AACnB,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AACvC,OAAO,EACL,oBAAoB,EACpB,0BAA0B,EAC1B,gBAAgB,EAChB,OAAO,GAER,MAAM,OAAO,CAAC;AAEf,MAAM,CAAC,MAAM,cAAc,GAAG,KAAK,EACjC,QAA2B,EAC3B,MAAc,EACd,KAAoC,EACpC,UAAoB,EAKZ,EAAE;IACV,MAAM,cAAc,GAAG,CAAC,MAAM,UAAU,EAAE,CAAC,CAAC,OAAO,CAAC;IACpD,MAAM,QAAQ,GAAG,KAAK,KAAK,QAAQ,CAAC;IACpC,IAAI,aAAa,GAAG,MAAM,CAAC;IAE3B,IAAI,KAAK,KAAK,OAAO,IAAI,QAAQ,EAAE,CAAC;QAClC,MAAM,aAAa,GAAG,MAAM,gBAAgB,EAAE,CAAC;QAE/C,MAAM,SAAS,GAAG,MAAM,oBAAoB,CAAC,aAAa,EAAE,WAAW,EAAE
|
|
1
|
+
{"version":3,"file":"allowance.js","sourceRoot":"","sources":["../../../features/mint-burn/allowance.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAA2B,MAAM,MAAM,CAAC;AAE5D,OAAO,EACL,gBAAgB,EAEhB,iBAAiB,GAClB,MAAM,WAAW,CAAC;AACnB,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AACvC,OAAO,EACL,oBAAoB,EACpB,0BAA0B,EAC1B,gBAAgB,EAChB,OAAO,GAER,MAAM,OAAO,CAAC;AAEf,MAAM,CAAC,MAAM,cAAc,GAAG,KAAK,EACjC,QAA2B,EAC3B,MAAc,EACd,KAAoC,EACpC,UAAoB,EAKZ,EAAE;IACV,MAAM,cAAc,GAAG,CAAC,MAAM,UAAU,EAAE,CAAC,CAAC,OAAO,CAAC;IACpD,MAAM,QAAQ,GAAG,KAAK,KAAK,QAAQ,CAAC;IACpC,IAAI,aAAa,GAAG,MAAM,CAAC;IAE3B,IAAI,KAAK,KAAK,OAAO,IAAI,QAAQ,EAAE,CAAC;QAClC,MAAM,aAAa,GAAG,MAAM,gBAAgB,EAAE,CAAC;QAE/C,MAAM,SAAS,GAAG,MAAM,oBAAoB,CAAC;YAC3C,QAAQ,EAAE,aAAa;YACvB,UAAU,EAAE,WAAW;YACvB,OAAO,EAAE,CAAC,CAAC,cAAc,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC;SAC9C,CAAC,CAAC;QACH,IAAI,QAAQ,EAAE,CAAC;YACb,aAAa,GAAG,MAAM,oBAAoB,CAAC;gBACzC,QAAQ,EAAE,aAAa;gBACvB,UAAU,EAAE,sBAAsB;gBAClC,OAAO,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC;aACpB,CAAC,CAAC;QACL,CAAC;QAED,IAAI,SAAS,GAAG,aAAa,EAAE,CAAC;YAC9B,OAAO,CAAC,wBAAwB,CAAC,CAAC;YAElC,MAAM,OAAO,GAAG,MAAM,gBAAgB,CACpC,oCAAoC,WAAW,CAAC,MAAM,CAAC,IAAI,KAAK,KAAK,WAAW,CAAC,aAAa,CAAC,cAAc,QAAQ,CAAC,OAAO,6CAA6C,WAAW,CAAC,SAAS,CAAC,QAAQ,CACzM,CAAC;YACF,IAAI,CAAC,OAAO;gBAAE,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;YAEnD,OAAO,MAAM,0BAA0B,CAAC;gBACtC,QAAQ,EAAE,aAAa;gBACvB,UAAU,EAAE,SAAS;gBACrB,OAAO,EAAE,CAAC,QAAQ,CAAC,OAAO,EAAE,aAAa,CAAC;gBAC1C,UAAU;aACX,CAAC,CAAC;QACL,CAAC;IACH,CAAC;SAAM,CAAC;QACN,MAAM,cAAc,GAAG,MAAM,iBAAiB,EAAE,CAAC;QAEjD,MAAM,eAAe,GAAG,MAAM,oBAAoB,CAAC;YACjD,QAAQ,EAAE,cAAc;YACxB,UAAU,EAAE,WAAW;YACvB,OAAO,EAAE,CAAC,CAAC,cAAc,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC;SAC9C,CAAC,CAAC;QACH,IAAI,eAAe,GAAG,MAAM,EAAE,CAAC;YAC7B,OAAO,CAAC,wBAAwB,CAAC,CAAC;YAElC,MAAM,OAAO,GAAG,MAAM,gBAAgB,CACpC,oCAAoC,WAAW,CAAC,MAAM,CAAC,IAAI,KAAK,OAAO,QAAQ,CAAC,OAAO,6CAA6C,WAAW,CAAC,eAAe,CAAC,SAAS,CAC1K,CAAC;YACF,IAAI,CAAC,OAAO;gBAAE,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;YAEnD,OAAO,MAAM,0BAA0B,CAAC;gBACtC,QAAQ,EAAE,cAAc;gBACxB,UAAU,EAAE,SAAS;gBACrB,OAAO,EAAE,CAAC,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;gBACnC,UAAU;aACX,CAAC,CAAC;QACL,CAAC;IACH,CAAC;AACH,CAAC,CAAC"}
|
|
@@ -3,7 +3,11 @@ import { fetchAndCalculateVaultHealthWithNewValue, showSpinner, confirmBurn, cal
|
|
|
3
3
|
import { checkLiabilityShares } from '../index.js';
|
|
4
4
|
export const burnSteth = async (contract, amountOfSteth, vault, populatedAllowance) => {
|
|
5
5
|
const stethContract = await getStethContract();
|
|
6
|
-
const amountOfShares = await callReadMethodSilent(
|
|
6
|
+
const amountOfShares = await callReadMethodSilent({
|
|
7
|
+
contract: stethContract,
|
|
8
|
+
methodName: 'getSharesByPooledEth',
|
|
9
|
+
payload: [[amountOfSteth]],
|
|
10
|
+
});
|
|
7
11
|
const isLiabilitySharesOk = await checkLiabilityShares(contract, amountOfShares);
|
|
8
12
|
if (!isLiabilitySharesOk)
|
|
9
13
|
return;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"burn-steth.js","sourceRoot":"","sources":["../../../features/mint-burn/burn-steth.ts"],"names":[],"mappings":"AAEA,OAAO,EAAqB,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAChE,OAAO,EACL,wCAAwC,EACxC,WAAW,EACX,WAAW,EACX,oBAAoB,EAEpB,wBAAwB,GACzB,MAAM,OAAO,CAAC;AACf,OAAO,EAAE,oBAAoB,EAAE,MAAM,UAAU,CAAC;AAEhD,MAAM,CAAC,MAAM,SAAS,GAAG,KAAK,EAC5B,QAA2B,EAC3B,aAAqB,EACrB,KAAc,EACd,kBAAgC,EAChC,EAAE;IACF,MAAM,aAAa,GAAG,MAAM,gBAAgB,EAAE,CAAC;IAC/C,MAAM,cAAc,GAAG,MAAM,oBAAoB,
|
|
1
|
+
{"version":3,"file":"burn-steth.js","sourceRoot":"","sources":["../../../features/mint-burn/burn-steth.ts"],"names":[],"mappings":"AAEA,OAAO,EAAqB,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAChE,OAAO,EACL,wCAAwC,EACxC,WAAW,EACX,WAAW,EACX,oBAAoB,EAEpB,wBAAwB,GACzB,MAAM,OAAO,CAAC;AACf,OAAO,EAAE,oBAAoB,EAAE,MAAM,UAAU,CAAC;AAEhD,MAAM,CAAC,MAAM,SAAS,GAAG,KAAK,EAC5B,QAA2B,EAC3B,aAAqB,EACrB,KAAc,EACd,kBAAgC,EAChC,EAAE;IACF,MAAM,aAAa,GAAG,MAAM,gBAAgB,EAAE,CAAC;IAC/C,MAAM,cAAc,GAAG,MAAM,oBAAoB,CAAC;QAChD,QAAQ,EAAE,aAAa;QACvB,UAAU,EAAE,sBAAsB;QAClC,OAAO,EAAE,CAAC,CAAC,aAAa,CAAC,CAAC;KAC3B,CAAC,CAAC;IAEH,MAAM,mBAAmB,GAAG,MAAM,oBAAoB,CACpD,QAAQ,EACR,cAAc,CACf,CAAC;IACF,IAAI,CAAC,mBAAmB;QAAE,OAAO;IAEjC,MAAM,WAAW,GAAG,WAAW,EAAE,CAAC;IAClC,MAAM,EACJ,kBAAkB,EAClB,cAAc,EACd,kBAAkB,EAClB,4BAA4B,EAC5B,eAAe,EACf,eAAe,EACf,yBAAyB,GAC1B,GAAG,MAAM,wCAAwC,CAChD,QAAQ,EACR,cAAc,EACd,MAAM,CACP,CAAC;IACF,WAAW,EAAE,CAAC;IAEd,MAAM,OAAO,GAAG,MAAM,WAAW,CAAC;QAChC,YAAY,EAAE,KAAK;QACnB,YAAY,EAAE,aAAa;QAC3B,sBAAsB,EAAE,eAAe;QACvC,kBAAkB,EAAE,kBAAkB;QACtC,4BAA4B,EAAE,4BAA4B;QAC1D,sBAAsB,EAAE,eAAe;QACvC,gCAAgC,EAAE,yBAAyB;QAC3D,cAAc,EAAE,cAAc,CAAC,WAAW;QAC1C,kBAAkB,EAAE,kBAAkB,CAAC,WAAW;QAClD,YAAY,EAAE,cAAc,CAAC,SAAS;QACtC,gBAAgB,EAAE,kBAAkB,CAAC,SAAS;QAC9C,IAAI,EAAE,OAAO;KACd,CAAC,CAAC;IACH,IAAI,CAAC,OAAO;QAAE,OAAO;IAErB,MAAM,wBAAwB,CAAC;QAC7B,QAAQ;QACR,UAAU,EAAE,WAAW;QACvB,OAAO,EAAE,CAAC,aAAa,CAAC;QACxB,KAAK,EAAE,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;KAC7D,CAAC,CAAC;AACL,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../features/mint-burn/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,iBAAiB,CAAC;AAChC,cAAc,kBAAkB,CAAC;AACjC,cAAc,iBAAiB,CAAC;AAChC,cAAc,gBAAgB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../features/mint-burn/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,iBAAiB,CAAC;AAChC,cAAc,kBAAkB,CAAC;AACjC,cAAc,iBAAiB,CAAC;AAChC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,iBAAiB,CAAC"}
|