@centrifuge/sdk 0.0.0-alpha.8 → 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +16 -13
- package/dist/Centrifuge.d.ts +309 -231
- package/dist/Centrifuge.d.ts.map +1 -1
- package/dist/Centrifuge.js +700 -155
- package/dist/Centrifuge.js.map +1 -1
- package/dist/Centrifuge.test.d.ts +2 -0
- package/dist/Centrifuge.test.d.ts.map +1 -0
- package/dist/Centrifuge.test.js +531 -0
- package/dist/Centrifuge.test.js.map +1 -0
- package/dist/abi/Accounting.abi.d.ts +3 -0
- package/dist/abi/Accounting.abi.d.ts.map +1 -0
- package/dist/abi/Accounting.abi.js +33 -0
- package/dist/abi/Accounting.abi.js.map +1 -0
- package/dist/abi/AsyncRequestManager.abi.d.ts +3 -0
- package/dist/abi/AsyncRequestManager.abi.d.ts.map +1 -0
- package/dist/abi/AsyncRequestManager.abi.js +78 -0
- package/dist/abi/AsyncRequestManager.abi.js.map +1 -0
- package/dist/abi/AsyncVault.abi.d.ts +3 -0
- package/dist/abi/AsyncVault.abi.d.ts.map +1 -0
- package/dist/abi/AsyncVault.abi.js +101 -0
- package/dist/abi/AsyncVault.abi.js.map +1 -0
- package/dist/abi/BalanceSheet.abi.d.ts +3 -0
- package/dist/abi/BalanceSheet.abi.d.ts.map +1 -0
- package/dist/abi/BalanceSheet.abi.js +55 -0
- package/dist/abi/BalanceSheet.abi.js.map +1 -0
- package/dist/abi/Currency.abi.d.ts +3 -0
- package/dist/abi/Currency.abi.d.ts.map +1 -0
- package/dist/abi/Currency.abi.js +16 -0
- package/dist/abi/Currency.abi.js.map +1 -0
- package/dist/abi/ERC6909.abi.d.ts +3 -0
- package/dist/abi/ERC6909.abi.d.ts.map +1 -0
- package/dist/abi/ERC6909.abi.js +22 -0
- package/dist/abi/ERC6909.abi.js.map +1 -0
- package/dist/abi/GasService.abi.d.ts +3 -0
- package/dist/abi/GasService.abi.d.ts.map +1 -0
- package/dist/abi/GasService.abi.js +32 -0
- package/dist/abi/GasService.abi.js.map +1 -0
- package/dist/abi/Gateway.abi.d.ts +3 -0
- package/dist/abi/Gateway.abi.d.ts.map +1 -0
- package/dist/abi/Gateway.abi.js +62 -0
- package/dist/abi/Gateway.abi.js.map +1 -0
- package/dist/abi/Holdings.abi.d.ts +3 -0
- package/dist/abi/Holdings.abi.d.ts.map +1 -0
- package/dist/abi/Holdings.abi.js +43 -0
- package/dist/abi/Holdings.abi.js.map +1 -0
- package/dist/abi/Hub.abi.d.ts +3 -0
- package/dist/abi/Hub.abi.d.ts.map +1 -0
- package/dist/abi/Hub.abi.js +89 -0
- package/dist/abi/Hub.abi.js.map +1 -0
- package/dist/abi/HubRegistry.abi.d.ts +3 -0
- package/dist/abi/HubRegistry.abi.d.ts.map +1 -0
- package/dist/abi/HubRegistry.abi.js +39 -0
- package/dist/abi/HubRegistry.abi.js.map +1 -0
- package/dist/abi/MerkleProofManager.abi.d.ts +3 -0
- package/dist/abi/MerkleProofManager.abi.d.ts.map +1 -0
- package/dist/abi/MerkleProofManager.abi.js +26 -0
- package/dist/abi/MerkleProofManager.abi.js.map +1 -0
- package/dist/abi/MessageDispatcher.abi.d.ts +3 -0
- package/dist/abi/MessageDispatcher.abi.d.ts.map +1 -0
- package/dist/abi/MessageDispatcher.abi.js +49 -0
- package/dist/abi/MessageDispatcher.abi.js.map +1 -0
- package/dist/abi/MultiAdapter.abi.d.ts +3 -0
- package/dist/abi/MultiAdapter.abi.d.ts.map +1 -0
- package/dist/abi/MultiAdapter.abi.js +53 -0
- package/dist/abi/MultiAdapter.abi.js.map +1 -0
- package/dist/abi/OnOffRampManager.abi.d.ts +3 -0
- package/dist/abi/OnOffRampManager.abi.d.ts.map +1 -0
- package/dist/abi/OnOffRampManager.abi.js +31 -0
- package/dist/abi/OnOffRampManager.abi.js.map +1 -0
- package/dist/abi/OnOffRampManagerFactory.abi.d.ts +3 -0
- package/dist/abi/OnOffRampManagerFactory.abi.d.ts.map +1 -0
- package/dist/abi/OnOffRampManagerFactory.abi.js +2 -0
- package/dist/abi/OnOffRampManagerFactory.abi.js.map +1 -0
- package/dist/abi/PoolEscrow.abi.d.ts +3 -0
- package/dist/abi/PoolEscrow.abi.d.ts.map +1 -0
- package/dist/abi/PoolEscrow.abi.js +32 -0
- package/dist/abi/PoolEscrow.abi.js.map +1 -0
- package/dist/abi/PoolEscrowFactory.abi.d.ts +3 -0
- package/dist/abi/PoolEscrowFactory.abi.d.ts.map +1 -0
- package/dist/abi/PoolEscrowFactory.abi.js +19 -0
- package/dist/abi/PoolEscrowFactory.abi.js.map +1 -0
- package/dist/abi/RestrictionManager.abi.d.ts +3 -0
- package/dist/abi/RestrictionManager.abi.d.ts.map +1 -0
- package/dist/abi/RestrictionManager.abi.js +23 -0
- package/dist/abi/RestrictionManager.abi.js.map +1 -0
- package/dist/abi/ShareClassManager.abi.d.ts +3 -0
- package/dist/abi/ShareClassManager.abi.d.ts.map +1 -0
- package/dist/abi/ShareClassManager.abi.js +89 -0
- package/dist/abi/ShareClassManager.abi.js.map +1 -0
- package/dist/abi/Spoke.abi.d.ts +3 -0
- package/dist/abi/Spoke.abi.d.ts.map +1 -0
- package/dist/abi/Spoke.abi.js +90 -0
- package/dist/abi/Spoke.abi.js.map +1 -0
- package/dist/abi/SyncRequestManager.abi.d.ts +3 -0
- package/dist/abi/SyncRequestManager.abi.d.ts.map +1 -0
- package/dist/abi/SyncRequestManager.abi.js +61 -0
- package/dist/abi/SyncRequestManager.abi.js.map +1 -0
- package/dist/abi/Valuation.abi.d.ts +3 -0
- package/dist/abi/Valuation.abi.d.ts.map +1 -0
- package/dist/abi/Valuation.abi.js +2 -0
- package/dist/abi/Valuation.abi.js.map +1 -0
- package/dist/abi/VaultRouter.abi.d.ts +3 -0
- package/dist/abi/VaultRouter.abi.d.ts.map +1 -0
- package/dist/abi/VaultRouter.abi.js +50 -0
- package/dist/abi/VaultRouter.abi.js.map +1 -0
- package/dist/abi/index.d.ts +9027 -8
- package/dist/abi/index.d.ts.map +1 -1
- package/dist/abi/index.js +48 -16
- package/dist/abi/index.js.map +1 -1
- package/dist/config/chains.d.ts +202 -941
- package/dist/config/chains.d.ts.map +1 -1
- package/dist/config/chains.js +2 -2
- package/dist/config/chains.js.map +1 -1
- package/dist/config/protocol.d.ts +3 -0
- package/dist/config/protocol.d.ts.map +1 -0
- package/dist/config/protocol.js +7 -0
- package/dist/config/protocol.js.map +1 -0
- package/dist/constants.d.ts +1 -0
- package/dist/constants.d.ts.map +1 -1
- package/dist/constants.js +1 -0
- package/dist/constants.js.map +1 -1
- package/dist/entities/BalanceSheet.d.ts +48 -0
- package/dist/entities/BalanceSheet.d.ts.map +1 -0
- package/dist/entities/BalanceSheet.js +94 -0
- package/dist/entities/BalanceSheet.js.map +1 -0
- package/dist/entities/BalanceSheet.test.d.ts +2 -0
- package/dist/entities/BalanceSheet.test.d.ts.map +1 -0
- package/dist/entities/BalanceSheet.test.js +64 -0
- package/dist/entities/BalanceSheet.test.js.map +1 -0
- package/dist/{Entity.d.ts → entities/Entity.d.ts} +1 -1
- package/dist/entities/Entity.d.ts.map +1 -0
- package/dist/{Entity.js → entities/Entity.js} +0 -3
- package/dist/entities/Entity.js.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/assetSnapshots.d.ts +14 -14
- package/dist/entities/IndexerQueries/assetSnapshots.d.ts.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/assetSnapshots.js +15 -17
- package/dist/entities/IndexerQueries/assetSnapshots.js.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/assetTransactions.d.ts +7 -6
- package/dist/entities/IndexerQueries/assetTransactions.d.ts.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/assetTransactions.js +8 -7
- package/dist/entities/IndexerQueries/assetTransactions.js.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/epochs.d.ts +7 -7
- package/dist/entities/IndexerQueries/epochs.d.ts.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/epochs.js +7 -7
- package/dist/entities/IndexerQueries/epochs.js.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/index.d.ts +24 -24
- package/dist/entities/IndexerQueries/index.d.ts.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/index.js +7 -7
- package/dist/entities/IndexerQueries/index.js.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/investorTransactions.d.ts +4 -4
- package/dist/entities/IndexerQueries/investorTransactions.d.ts.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/investorTransactions.js +4 -4
- package/dist/entities/IndexerQueries/investorTransactions.js.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/poolFeeSnapshots.d.ts +8 -8
- package/dist/entities/IndexerQueries/poolFeeSnapshots.d.ts.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/poolFeeSnapshots.js +8 -8
- package/dist/entities/IndexerQueries/poolFeeSnapshots.js.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/poolFeeTransactions.d.ts +3 -3
- package/dist/entities/IndexerQueries/poolFeeTransactions.d.ts.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/poolFeeTransactions.js +3 -3
- package/dist/entities/IndexerQueries/poolFeeTransactions.js.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/poolSnapshots.d.ts +30 -24
- package/dist/entities/IndexerQueries/poolSnapshots.d.ts.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/poolSnapshots.js +29 -23
- package/dist/entities/IndexerQueries/poolSnapshots.js.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/trancheCurrencyBalance.d.ts +15 -15
- package/dist/entities/IndexerQueries/trancheCurrencyBalance.d.ts.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/trancheCurrencyBalance.js +8 -8
- package/dist/entities/IndexerQueries/trancheCurrencyBalance.js.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/trancheSnapshots.d.ts +6 -6
- package/dist/entities/IndexerQueries/trancheSnapshots.d.ts.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/trancheSnapshots.js +6 -6
- package/dist/entities/IndexerQueries/trancheSnapshots.js.map +1 -0
- package/dist/entities/Investor.d.ts +47 -0
- package/dist/entities/Investor.d.ts.map +1 -0
- package/dist/entities/Investor.js +93 -0
- package/dist/entities/Investor.js.map +1 -0
- package/dist/entities/Investor.test.d.ts +2 -0
- package/dist/entities/Investor.test.d.ts.map +1 -0
- package/dist/entities/Investor.test.js +78 -0
- package/dist/entities/Investor.test.js.map +1 -0
- package/dist/entities/MerkleProofManager.d.ts +37 -0
- package/dist/entities/MerkleProofManager.d.ts.map +1 -0
- package/dist/entities/MerkleProofManager.js +210 -0
- package/dist/entities/MerkleProofManager.js.map +1 -0
- package/dist/entities/MerkleProofManager.test.d.ts +2 -0
- package/dist/entities/MerkleProofManager.test.d.ts.map +1 -0
- package/dist/entities/MerkleProofManager.test.js +241 -0
- package/dist/entities/MerkleProofManager.test.js.map +1 -0
- package/dist/entities/OnOffRampManager.d.ts +34 -0
- package/dist/entities/OnOffRampManager.d.ts.map +1 -0
- package/dist/entities/OnOffRampManager.js +191 -0
- package/dist/entities/OnOffRampManager.js.map +1 -0
- package/dist/entities/OnOffRampManager.test.d.ts +2 -0
- package/dist/entities/OnOffRampManager.test.d.ts.map +1 -0
- package/dist/entities/OnOffRampManager.test.js +170 -0
- package/dist/entities/OnOffRampManager.test.js.map +1 -0
- package/dist/entities/Pool.d.ts +157 -0
- package/dist/entities/Pool.d.ts.map +1 -0
- package/dist/entities/Pool.js +591 -0
- package/dist/entities/Pool.js.map +1 -0
- package/dist/entities/Pool.test.d.ts +2 -0
- package/dist/entities/Pool.test.d.ts.map +1 -0
- package/dist/entities/Pool.test.js +271 -0
- package/dist/entities/Pool.test.js.map +1 -0
- package/dist/entities/PoolNetwork.d.ts +77 -0
- package/dist/entities/PoolNetwork.d.ts.map +1 -0
- package/dist/entities/PoolNetwork.js +360 -0
- package/dist/entities/PoolNetwork.js.map +1 -0
- package/dist/entities/PoolNetwork.test.d.ts +2 -0
- package/dist/entities/PoolNetwork.test.d.ts.map +1 -0
- package/dist/entities/PoolNetwork.test.js +166 -0
- package/dist/entities/PoolNetwork.test.js.map +1 -0
- package/dist/entities/Reports/PoolReports.d.ts +8 -0
- package/dist/entities/Reports/PoolReports.d.ts.map +1 -0
- package/dist/entities/Reports/PoolReports.js +14 -0
- package/dist/entities/Reports/PoolReports.js.map +1 -0
- package/dist/entities/Reports/PoolSharePricesReport.d.ts +25 -0
- package/dist/entities/Reports/PoolSharePricesReport.d.ts.map +1 -0
- package/dist/entities/Reports/PoolSharePricesReport.js +64 -0
- package/dist/entities/Reports/PoolSharePricesReport.js.map +1 -0
- package/dist/entities/Reports/PoolSharePricesReport.test.d.ts +2 -0
- package/dist/entities/Reports/PoolSharePricesReport.test.d.ts.map +1 -0
- package/dist/entities/Reports/PoolSharePricesReport.test.js +35 -0
- package/dist/entities/Reports/PoolSharePricesReport.test.js.map +1 -0
- package/dist/{Reports → entities/Reports}/Processor.d.ts +1 -1
- package/dist/entities/Reports/Processor.d.ts.map +1 -0
- package/dist/{Reports → entities/Reports}/Processor.js +27 -13
- package/dist/entities/Reports/Processor.js.map +1 -0
- package/dist/entities/Reports/Processor.test.d.ts +2 -0
- package/dist/entities/Reports/Processor.test.d.ts.map +1 -0
- package/dist/entities/Reports/Processor.test.js +767 -0
- package/dist/entities/Reports/Processor.test.js.map +1 -0
- package/dist/entities/Reports/Reports.test.d.ts +2 -0
- package/dist/entities/Reports/Reports.test.d.ts.map +1 -0
- package/dist/entities/Reports/Reports.test.js +559 -0
- package/dist/entities/Reports/Reports.test.js.map +1 -0
- package/dist/{Reports → entities/Reports}/index.d.ts +2 -2
- package/dist/entities/Reports/index.d.ts.map +1 -0
- package/dist/{Reports → entities/Reports}/index.js +4 -4
- package/dist/entities/Reports/index.js.map +1 -0
- package/dist/entities/Reports/types.d.ts +9 -0
- package/dist/entities/Reports/types.d.ts.map +1 -0
- package/dist/entities/Reports/types.js +2 -0
- package/dist/entities/Reports/types.js.map +1 -0
- package/dist/entities/Reports/utils.d.ts +20 -0
- package/dist/entities/Reports/utils.d.ts.map +1 -0
- package/dist/entities/Reports/utils.js +47 -0
- package/dist/entities/Reports/utils.js.map +1 -0
- package/dist/entities/ShareClass.d.ts +215 -0
- package/dist/entities/ShareClass.d.ts.map +1 -0
- package/dist/entities/ShareClass.js +1321 -0
- package/dist/entities/ShareClass.js.map +1 -0
- package/dist/entities/ShareClass.test.d.ts +2 -0
- package/dist/entities/ShareClass.test.d.ts.map +1 -0
- package/dist/entities/ShareClass.test.js +528 -0
- package/dist/entities/ShareClass.test.js.map +1 -0
- package/dist/entities/Vault.d.ts +92 -0
- package/dist/entities/Vault.d.ts.map +1 -0
- package/dist/entities/Vault.js +433 -0
- package/dist/entities/Vault.js.map +1 -0
- package/dist/entities/Vault.test.d.ts +2 -0
- package/dist/entities/Vault.test.d.ts.map +1 -0
- package/dist/entities/Vault.test.js +309 -0
- package/dist/entities/Vault.test.js.map +1 -0
- package/dist/index.d.ts +15 -8
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +13 -5
- package/dist/index.js.map +1 -1
- package/dist/tests/forkServer.d.mts +2 -0
- package/dist/tests/forkServer.d.mts.map +1 -0
- package/dist/tests/forkServer.mjs +104 -0
- package/dist/tests/forkServer.mjs.map +1 -0
- package/dist/tests/mocks/mockAssetSnapshots.d.ts +1 -1
- package/dist/tests/mocks/mockAssetSnapshots.d.ts.map +1 -1
- package/dist/tests/mocks/mockAssetSnapshots.js +27 -27
- package/dist/tests/mocks/mockAssetSnapshots.js.map +1 -1
- package/dist/tests/mocks/mockAssetTransactions.d.ts +1 -1
- package/dist/tests/mocks/mockAssetTransactions.d.ts.map +1 -1
- package/dist/tests/mocks/mockAssetTransactions.js +17 -14
- package/dist/tests/mocks/mockAssetTransactions.js.map +1 -1
- package/dist/tests/mocks/mockEpochs.d.ts +1 -1
- package/dist/tests/mocks/mockEpochs.d.ts.map +1 -1
- package/dist/tests/mocks/mockEpochs.js +13 -13
- package/dist/tests/mocks/mockEpochs.js.map +1 -1
- package/dist/tests/mocks/mockInvestorCurrencyBalance.d.ts +1 -1
- package/dist/tests/mocks/mockInvestorCurrencyBalance.d.ts.map +1 -1
- package/dist/tests/mocks/mockInvestorCurrencyBalance.js +15 -15
- package/dist/tests/mocks/mockInvestorCurrencyBalance.js.map +1 -1
- package/dist/tests/mocks/mockInvestorTransactions.d.ts +1 -1
- package/dist/tests/mocks/mockInvestorTransactions.d.ts.map +1 -1
- package/dist/tests/mocks/mockInvestorTransactions.js +5 -5
- package/dist/tests/mocks/mockInvestorTransactions.js.map +1 -1
- package/dist/tests/mocks/mockPoolFeeSnapshot.d.ts +1 -1
- package/dist/tests/mocks/mockPoolFeeSnapshot.d.ts.map +1 -1
- package/dist/tests/mocks/mockPoolFeeSnapshot.js +29 -29
- package/dist/tests/mocks/mockPoolFeeSnapshot.js.map +1 -1
- package/dist/tests/mocks/mockPoolFeeTransactions.d.ts +3 -3
- package/dist/tests/mocks/mockPoolFeeTransactions.d.ts.map +1 -1
- package/dist/tests/mocks/mockPoolFeeTransactions.js +3 -3
- package/dist/tests/mocks/mockPoolFeeTransactions.js.map +1 -1
- package/dist/tests/mocks/mockPoolMetadata.d.ts.map +1 -1
- package/dist/tests/mocks/mockPoolMetadata.js +7 -17
- package/dist/tests/mocks/mockPoolMetadata.js.map +1 -1
- package/dist/tests/mocks/mockPoolSnapshots.d.ts +1 -1
- package/dist/tests/mocks/mockPoolSnapshots.d.ts.map +1 -1
- package/dist/tests/mocks/mockPoolSnapshots.js +47 -45
- package/dist/tests/mocks/mockPoolSnapshots.js.map +1 -1
- package/dist/tests/mocks/mockTrancheSnapshots.d.ts +1 -1
- package/dist/tests/mocks/mockTrancheSnapshots.d.ts.map +1 -1
- package/dist/tests/mocks/mockTrancheSnapshots.js +21 -21
- package/dist/tests/mocks/mockTrancheSnapshots.js.map +1 -1
- package/dist/tests/setup.d.ts.map +1 -1
- package/dist/tests/setup.js +4 -3
- package/dist/tests/setup.js.map +1 -1
- package/dist/tests/tenderly.d.ts +15 -2
- package/dist/tests/tenderly.d.ts.map +1 -1
- package/dist/tests/tenderly.js +74 -67
- package/dist/tests/tenderly.js.map +1 -1
- package/dist/tests/utils.d.ts +3 -0
- package/dist/tests/utils.d.ts.map +1 -0
- package/dist/tests/utils.js +4 -0
- package/dist/tests/utils.js.map +1 -0
- package/dist/types/holdings.d.ts +9 -0
- package/dist/types/holdings.d.ts.map +1 -0
- package/dist/types/holdings.js +10 -0
- package/dist/types/holdings.js.map +1 -0
- package/dist/types/index.d.ts +52 -5
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/indexer.d.ts +4189 -0
- package/dist/types/indexer.d.ts.map +1 -0
- package/dist/types/indexer.js +56 -0
- package/dist/types/indexer.js.map +1 -0
- package/dist/types/poolInput.d.ts +79 -0
- package/dist/types/poolInput.d.ts.map +1 -0
- package/dist/types/poolInput.js +2 -0
- package/dist/types/poolInput.js.map +1 -0
- package/dist/types/poolMetadata.d.ts +41 -13
- package/dist/types/poolMetadata.d.ts.map +1 -1
- package/dist/types/reports.d.ts +71 -66
- package/dist/types/reports.d.ts.map +1 -1
- package/dist/types/transaction.d.ts +102 -3
- package/dist/types/transaction.d.ts.map +1 -1
- package/dist/types/transaction.js +55 -1
- package/dist/types/transaction.js.map +1 -1
- package/dist/utils/BigInt.d.ts +17 -23
- package/dist/utils/BigInt.d.ts.map +1 -1
- package/dist/utils/BigInt.js +18 -25
- package/dist/utils/BigInt.js.map +1 -1
- package/dist/utils/BigInt.test.d.ts +2 -0
- package/dist/utils/BigInt.test.d.ts.map +1 -0
- package/dist/utils/BigInt.test.js +298 -0
- package/dist/utils/BigInt.test.js.map +1 -0
- package/dist/utils/currencies.d.ts +5 -0
- package/dist/utils/currencies.d.ts.map +1 -0
- package/dist/utils/currencies.js +7 -0
- package/dist/utils/currencies.js.map +1 -0
- package/dist/utils/decimal.d.ts +2 -2
- package/dist/utils/decimal.d.ts.map +1 -1
- package/dist/utils/decimal.js.map +1 -1
- package/dist/utils/index.d.ts +4 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +24 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/ipfs.d.ts +7 -0
- package/dist/utils/ipfs.d.ts.map +1 -0
- package/dist/utils/ipfs.js +64 -0
- package/dist/utils/ipfs.js.map +1 -0
- package/dist/utils/ipfs.test.d.ts +2 -0
- package/dist/utils/ipfs.test.d.ts.map +1 -0
- package/dist/utils/ipfs.test.js +54 -0
- package/dist/utils/ipfs.test.js.map +1 -0
- package/dist/utils/permit.d.ts +13 -0
- package/dist/utils/permit.d.ts.map +1 -0
- package/dist/utils/permit.js +82 -0
- package/dist/utils/permit.js.map +1 -0
- package/dist/utils/permit.test.d.ts +2 -0
- package/dist/utils/permit.test.d.ts.map +1 -0
- package/dist/utils/permit.test.js +22 -0
- package/dist/utils/permit.test.js.map +1 -0
- package/dist/utils/rx.d.ts +3 -3
- package/dist/utils/rx.d.ts.map +1 -1
- package/dist/utils/rx.js +5 -1
- package/dist/utils/rx.js.map +1 -1
- package/dist/utils/transaction.d.ts +20 -10
- package/dist/utils/transaction.d.ts.map +1 -1
- package/dist/utils/transaction.js +162 -23
- package/dist/utils/transaction.js.map +1 -1
- package/dist/utils/types.d.ts +39 -0
- package/dist/utils/types.d.ts.map +1 -0
- package/dist/utils/types.js +89 -0
- package/dist/utils/types.js.map +1 -0
- package/dist/utils/types.test.d.ts +2 -0
- package/dist/utils/types.test.d.ts.map +1 -0
- package/dist/utils/types.test.js +89 -0
- package/dist/utils/types.test.js.map +1 -0
- package/package.json +12 -12
- package/dist/Account.d.ts +0 -11
- package/dist/Account.d.ts.map +0 -1
- package/dist/Account.js +0 -46
- package/dist/Account.js.map +0 -1
- package/dist/Entity.d.ts.map +0 -1
- package/dist/Entity.js.map +0 -1
- package/dist/IndexerQueries/assetSnapshots.d.ts.map +0 -1
- package/dist/IndexerQueries/assetSnapshots.js.map +0 -1
- package/dist/IndexerQueries/assetTransactions.d.ts.map +0 -1
- package/dist/IndexerQueries/assetTransactions.js.map +0 -1
- package/dist/IndexerQueries/epochs.d.ts.map +0 -1
- package/dist/IndexerQueries/epochs.js.map +0 -1
- package/dist/IndexerQueries/index.d.ts.map +0 -1
- package/dist/IndexerQueries/index.js.map +0 -1
- package/dist/IndexerQueries/investorTransactions.d.ts.map +0 -1
- package/dist/IndexerQueries/investorTransactions.js.map +0 -1
- package/dist/IndexerQueries/poolFeeSnapshots.d.ts.map +0 -1
- package/dist/IndexerQueries/poolFeeSnapshots.js.map +0 -1
- package/dist/IndexerQueries/poolFeeTransactions.d.ts.map +0 -1
- package/dist/IndexerQueries/poolFeeTransactions.js.map +0 -1
- package/dist/IndexerQueries/poolSnapshots.d.ts.map +0 -1
- package/dist/IndexerQueries/poolSnapshots.js.map +0 -1
- package/dist/IndexerQueries/trancheCurrencyBalance.d.ts.map +0 -1
- package/dist/IndexerQueries/trancheCurrencyBalance.js.map +0 -1
- package/dist/IndexerQueries/trancheSnapshots.d.ts.map +0 -1
- package/dist/IndexerQueries/trancheSnapshots.js.map +0 -1
- package/dist/Pool.d.ts +0 -25
- package/dist/Pool.d.ts.map +0 -1
- package/dist/Pool.js +0 -79
- package/dist/Pool.js.map +0 -1
- package/dist/PoolNetwork.d.ts +0 -54
- package/dist/PoolNetwork.d.ts.map +0 -1
- package/dist/PoolNetwork.js +0 -238
- package/dist/PoolNetwork.js.map +0 -1
- package/dist/Reports/Processor.d.ts.map +0 -1
- package/dist/Reports/Processor.js.map +0 -1
- package/dist/Reports/index.d.ts.map +0 -1
- package/dist/Reports/index.js.map +0 -1
- package/dist/Vault.d.ts +0 -84
- package/dist/Vault.d.ts.map +0 -1
- package/dist/Vault.js +0 -331
- package/dist/Vault.js.map +0 -1
- package/dist/abi/CentrifugeRouter.abi.json +0 -43
- package/dist/abi/Currency.abi.json +0 -14
- package/dist/abi/Gateway.abi.json +0 -1
- package/dist/abi/InvestmentManager.abi.json +0 -4
- package/dist/abi/LiquidityPool.abi.json +0 -79
- package/dist/abi/PoolManager.abi.json +0 -55
- package/dist/abi/RestrictionManager.abi.json +0 -22
- package/dist/abi/Router.abi.json +0 -1
- package/dist/config/lp.d.ts +0 -17
- package/dist/config/lp.d.ts.map +0 -1
- package/dist/config/lp.js +0 -35
- package/dist/config/lp.js.map +0 -1
- package/dist/utils/pinToApi.d.ts +0 -2
- package/dist/utils/pinToApi.d.ts.map +0 -1
- package/dist/utils/pinToApi.js +0 -10
- package/dist/utils/pinToApi.js.map +0 -1
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { hexToNumber, maxUint256, slice } from 'viem';
|
|
2
|
+
import { ABI } from '../abi/index.js';
|
|
3
|
+
export async function signPermit(ctx, currencyAddress, spender, amount) {
|
|
4
|
+
let domainOrCurrency = currencyAddress;
|
|
5
|
+
const USDC = '0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48';
|
|
6
|
+
if (currencyAddress.toLowerCase() === USDC) {
|
|
7
|
+
// USDC has a custom version
|
|
8
|
+
domainOrCurrency = { name: 'USD Coin', version: '2', chainId: ctx.chainId, verifyingContract: currencyAddress };
|
|
9
|
+
}
|
|
10
|
+
else if (ctx.root.getChainConfig(ctx.chainId).testnet) {
|
|
11
|
+
// Assume that the currencies used on testnets have our custom domain
|
|
12
|
+
domainOrCurrency = { name: 'Centrifuge', version: '1', chainId: ctx.chainId, verifyingContract: currencyAddress };
|
|
13
|
+
}
|
|
14
|
+
const deadline = Math.floor(Date.now() / 1000) + 3600; // 1 hour
|
|
15
|
+
const permit = await signERC2612Permit(ctx, domainOrCurrency, spender, amount, deadline);
|
|
16
|
+
return permit;
|
|
17
|
+
}
|
|
18
|
+
export async function signERC2612Permit(ctx, currencyOrDomain, spender, value, deadline, nonce) {
|
|
19
|
+
const types = {
|
|
20
|
+
Permit: [
|
|
21
|
+
{ name: 'owner', type: 'address' },
|
|
22
|
+
{ name: 'spender', type: 'address' },
|
|
23
|
+
{ name: 'value', type: 'uint256' },
|
|
24
|
+
{ name: 'nonce', type: 'uint256' },
|
|
25
|
+
{ name: 'deadline', type: 'uint256' },
|
|
26
|
+
],
|
|
27
|
+
};
|
|
28
|
+
const domainData = typeof currencyOrDomain === 'string'
|
|
29
|
+
? {
|
|
30
|
+
name: await getName(ctx.publicClient, currencyOrDomain),
|
|
31
|
+
version: '1',
|
|
32
|
+
chainId: ctx.chainId,
|
|
33
|
+
verifyingContract: currencyOrDomain,
|
|
34
|
+
}
|
|
35
|
+
: currencyOrDomain;
|
|
36
|
+
const owner = ctx.signingAddress;
|
|
37
|
+
const message = {
|
|
38
|
+
owner,
|
|
39
|
+
spender,
|
|
40
|
+
value: value ? BigInt(value) : maxUint256,
|
|
41
|
+
nonce: nonce ?? (await getNonce(ctx.publicClient, domainData.verifyingContract, owner)),
|
|
42
|
+
deadline: deadline ? BigInt(deadline) : maxUint256,
|
|
43
|
+
};
|
|
44
|
+
const signature = await ctx.walletClient.signTypedData({
|
|
45
|
+
message,
|
|
46
|
+
domain: domainData,
|
|
47
|
+
primaryType: 'Permit',
|
|
48
|
+
types,
|
|
49
|
+
});
|
|
50
|
+
return {
|
|
51
|
+
...splitSignature(signature),
|
|
52
|
+
deadline: message.deadline,
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
function splitSignature(signature) {
|
|
56
|
+
const r = slice(signature, 0, 32);
|
|
57
|
+
const s = slice(signature, 32, 64);
|
|
58
|
+
const v = hexToNumber(slice(signature, 64, 65));
|
|
59
|
+
return {
|
|
60
|
+
r,
|
|
61
|
+
s,
|
|
62
|
+
v: v < 27 ? v + 27 : v,
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
async function getName(publicClient, contractAddress) {
|
|
66
|
+
const name = await publicClient.readContract({
|
|
67
|
+
address: contractAddress,
|
|
68
|
+
abi: ABI.Currency,
|
|
69
|
+
functionName: 'name',
|
|
70
|
+
});
|
|
71
|
+
return name;
|
|
72
|
+
}
|
|
73
|
+
async function getNonce(publicClient, contractAddress, ownerAddress) {
|
|
74
|
+
const nonce = await publicClient.readContract({
|
|
75
|
+
address: contractAddress,
|
|
76
|
+
abi: ABI.Currency,
|
|
77
|
+
functionName: 'nonces',
|
|
78
|
+
args: [ownerAddress],
|
|
79
|
+
});
|
|
80
|
+
return nonce;
|
|
81
|
+
}
|
|
82
|
+
//# sourceMappingURL=permit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"permit.js","sourceRoot":"","sources":["../../src/utils/permit.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"permit.test.d.ts","sourceRoot":"","sources":["../../src/utils/permit.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { expect } from 'chai';
|
|
2
|
+
import { generatePrivateKey, privateKeyToAccount } from 'viem/accounts';
|
|
3
|
+
import { Centrifuge } from '../Centrifuge.js';
|
|
4
|
+
import { randomAddress } from '../tests/utils.js';
|
|
5
|
+
import { signPermit } from './permit.js';
|
|
6
|
+
import { doSignMessage } from './transaction.js';
|
|
7
|
+
const chainId = 11155111;
|
|
8
|
+
const someErc20 = '0x3aaaa86458d576BafCB1B7eD290434F0696dA65c';
|
|
9
|
+
describe('Permit utils', () => {
|
|
10
|
+
it('can sign a permit', async () => {
|
|
11
|
+
const account = privateKeyToAccount(generatePrivateKey());
|
|
12
|
+
const centrifuge = new Centrifuge({ environment: 'testnet' });
|
|
13
|
+
centrifuge.setSigner(account);
|
|
14
|
+
await centrifuge._transact(async function* (ctx) {
|
|
15
|
+
const permit = yield* doSignMessage('signPermit', () => signPermit(ctx, someErc20, randomAddress(), 100n));
|
|
16
|
+
expect(permit.r.startsWith('0x')).to.be.true;
|
|
17
|
+
expect(permit.s.startsWith('0x')).to.be.true;
|
|
18
|
+
expect(permit.v).to.be.oneOf([27, 28]);
|
|
19
|
+
}, chainId);
|
|
20
|
+
});
|
|
21
|
+
});
|
|
22
|
+
//# sourceMappingURL=permit.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"permit.test.js","sourceRoot":"","sources":["../../src/utils/permit.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAA;AAC7B,OAAO,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAA;AACvE,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAA;AAC7C,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AACxC,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAA;AAEhD,MAAM,OAAO,GAAG,QAAQ,CAAA;AACxB,MAAM,SAAS,GAAG,4CAA4C,CAAA;AAE9D,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,EAAE,CAAC,mBAAmB,EAAE,KAAK,IAAI,EAAE;QACjC,MAAM,OAAO,GAAG,mBAAmB,CAAC,kBAAkB,EAAE,CAAC,CAAA;QACzD,MAAM,UAAU,GAAG,IAAI,UAAU,CAAC,EAAE,WAAW,EAAE,SAAS,EAAE,CAAC,CAAA;QAC7D,UAAU,CAAC,SAAS,CAAC,OAAO,CAAC,CAAA;QAC7B,MAAM,UAAU,CAAC,SAAS,CAAC,KAAK,SAAS,CAAC,EAAE,GAAG;YAC7C,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,aAAa,CAAC,YAAY,EAAE,GAAG,EAAE,CAAC,UAAU,CAAC,GAAG,EAAE,SAAS,EAAE,aAAa,EAAE,EAAE,IAAI,CAAC,CAAC,CAAA;YAC1G,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAA;YAC5C,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAA;YAC5C,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAA;QACxC,CAAC,EAAE,OAAO,CAAC,CAAA;IACb,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
package/dist/utils/rx.d.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import type { MonoTypeOperatorFunction, Observable } from 'rxjs';
|
|
2
2
|
import type { Abi, Log } from 'viem';
|
|
3
3
|
import type { Centrifuge } from '../Centrifuge.js';
|
|
4
|
+
import { HexString } from '../types/index.js';
|
|
4
5
|
import type { Query } from '../types/query.js';
|
|
5
6
|
export declare function shareReplayWithDelayedReset<T>(config?: {
|
|
6
7
|
bufferSize?: number;
|
|
@@ -8,12 +9,11 @@ export declare function shareReplayWithDelayedReset<T>(config?: {
|
|
|
8
9
|
resetDelay?: number;
|
|
9
10
|
}): MonoTypeOperatorFunction<T>;
|
|
10
11
|
export declare function repeatOnEvents<T>(centrifuge: Centrifuge, opts: {
|
|
11
|
-
address
|
|
12
|
-
abi: Abi | Abi[];
|
|
12
|
+
address: HexString | HexString[];
|
|
13
13
|
eventName: string | string[];
|
|
14
14
|
filter?: (events: (Log<bigint, number, false, undefined, true, Abi, string> & {
|
|
15
15
|
args: any;
|
|
16
16
|
})[]) => boolean;
|
|
17
|
-
}, chainId
|
|
17
|
+
}, chainId: number): MonoTypeOperatorFunction<T>;
|
|
18
18
|
export declare function makeThenable<T>($query: Observable<T>, exhaust?: boolean): Query<T>;
|
|
19
19
|
//# sourceMappingURL=rx.d.ts.map
|
package/dist/utils/rx.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rx.d.ts","sourceRoot":"","sources":["../../src/utils/rx.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,wBAAwB,EAAE,UAAU,EAA4B,MAAM,MAAM,CAAA;AAE1F,OAAO,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,MAAM,MAAM,CAAA;AACpC,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAA;AAClD,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAA;AAE9C,wBAAgB,2BAA2B,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE;IACtD,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,UAAU,CAAC,EAAE,MAAM,CAAA;CACpB,GAAG,wBAAwB,CAAC,CAAC,CAAC,CAS9B;AAED,wBAAgB,cAAc,CAAC,CAAC,EAC9B,UAAU,EAAE,UAAU,EACtB,IAAI,EAAE;IACJ,OAAO,
|
|
1
|
+
{"version":3,"file":"rx.d.ts","sourceRoot":"","sources":["../../src/utils/rx.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,wBAAwB,EAAE,UAAU,EAA4B,MAAM,MAAM,CAAA;AAE1F,OAAO,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,MAAM,MAAM,CAAA;AACpC,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAA;AAClD,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAA;AAC7C,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAA;AAE9C,wBAAgB,2BAA2B,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE;IACtD,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,UAAU,CAAC,EAAE,MAAM,CAAA;CACpB,GAAG,wBAAwB,CAAC,CAAC,CAAC,CAS9B;AAED,wBAAgB,cAAc,CAAC,CAAC,EAC9B,UAAU,EAAE,UAAU,EACtB,IAAI,EAAE;IACJ,OAAO,EAAE,SAAS,GAAG,SAAS,EAAE,CAAA;IAChC,SAAS,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;IAC5B,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,CAAC,GAAG;QAAE,IAAI,EAAE,GAAG,CAAA;KAAE,CAAC,EAAE,KAAK,OAAO,CAAA;CAC3G,EACD,OAAO,EAAE,MAAM,GACd,wBAAwB,CAAC,CAAC,CAAC,CAS7B;AAED,wBAAgB,YAAY,CAAC,CAAC,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,OAAO,UAAQ,YAUrE"}
|
package/dist/utils/rx.js
CHANGED
|
@@ -11,7 +11,7 @@ export function shareReplayWithDelayedReset(config) {
|
|
|
11
11
|
}
|
|
12
12
|
export function repeatOnEvents(centrifuge, opts, chainId) {
|
|
13
13
|
return repeat({
|
|
14
|
-
delay: () => centrifuge._filteredEvents(opts.address
|
|
14
|
+
delay: () => centrifuge._filteredEvents(opts.address, opts.eventName, chainId).pipe(filter((events) => {
|
|
15
15
|
return opts.filter ? opts.filter(events) : true;
|
|
16
16
|
})),
|
|
17
17
|
});
|
|
@@ -31,11 +31,15 @@ export function makeThenable($query, exhaust = false) {
|
|
|
31
31
|
class ExpiringReplaySubject extends ReplaySubject {
|
|
32
32
|
// @ts-expect-error
|
|
33
33
|
_subscribe(subscriber) {
|
|
34
|
+
// Get the initial buffer length
|
|
34
35
|
// @ts-expect-error
|
|
35
36
|
const { _buffer } = this;
|
|
36
37
|
const length = _buffer.length;
|
|
38
|
+
// The ReplaySubject will remove expired items from the buffer
|
|
37
39
|
// @ts-expect-error
|
|
38
40
|
const subscription = super._subscribe(subscriber);
|
|
41
|
+
// If the buffer is now empty, complete the subject.
|
|
42
|
+
// Necessary for `createShared()` to be called again in Centrifuge._query()
|
|
39
43
|
if (length && _buffer.length === 0) {
|
|
40
44
|
this.complete();
|
|
41
45
|
}
|
package/dist/utils/rx.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rx.js","sourceRoot":"","sources":["../../src/utils/rx.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,EAAE,aAAa,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,MAAM,CAAA;
|
|
1
|
+
{"version":3,"file":"rx.js","sourceRoot":"","sources":["../../src/utils/rx.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,EAAE,aAAa,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,MAAM,CAAA;AAM1G,MAAM,UAAU,2BAA2B,CAAI,MAI9C;IACC,MAAM,EAAE,UAAU,GAAG,QAAQ,EAAE,UAAU,GAAG,QAAQ,EAAE,UAAU,GAAG,IAAI,EAAE,GAAG,MAAM,IAAI,EAAE,CAAA;IACxF,MAAM,KAAK,GAAG,UAAU,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,KAAK,CAAA;IAC9F,OAAO,KAAK,CAAI;QACd,SAAS,EAAE,GAAG,EAAE,CAAC,CAAC,UAAU,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,OAAO,EAAE,CAAC,CAAC,CAAC,IAAI,qBAAqB,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;QACvG,YAAY,EAAE,IAAI;QAClB,eAAe,EAAE,KAAK;QACtB,mBAAmB,EAAE,KAAK;KAC3B,CAAC,CAAA;AACJ,CAAC;AAED,MAAM,UAAU,cAAc,CAC5B,UAAsB,EACtB,IAIC,EACD,OAAe;IAEf,OAAO,MAAM,CAAC;QACZ,KAAK,EAAE,GAAG,EAAE,CACV,UAAU,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC,IAAI,CACpE,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE;YAChB,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;QACjD,CAAC,CAAC,CACH;KACJ,CAAC,CAAA;AACJ,CAAC;AAED,MAAM,UAAU,YAAY,CAAI,MAAqB,EAAE,OAAO,GAAG,KAAK;IACpE,MAAM,aAAa,GAAa,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE;QACpD,IAAI,CAAC,WAA8B,EAAE,UAAgC;YACnE,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,UAAU,CAAC,CAAA;QACzF,CAAC;QACD,SAAS;YACP,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,CAAA;QAC3D,CAAC;KACF,CAAC,CAAA;IACF,OAAO,aAAa,CAAA;AACtB,CAAC;AAED,oEAAoE;AACpE,MAAM,qBAAyB,SAAQ,aAAgB;IACrD,mBAAmB;IACA,UAAU,CAAC,UAAyB;QACrD,gCAAgC;QAChC,mBAAmB;QACnB,MAAM,EAAE,OAAO,EAAE,GAAG,IAAI,CAAA;QACxB,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAA;QAE7B,8DAA8D;QAC9D,mBAAmB;QACnB,MAAM,YAAY,GAAG,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,CAAA;QAEjD,oDAAoD;QACpD,2EAA2E;QAC3E,IAAI,MAAM,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACnC,IAAI,CAAC,QAAQ,EAAE,CAAA;QACjB,CAAC;QACD,OAAO,YAAY,CAAA;IACrB,CAAC;CACF"}
|
|
@@ -1,14 +1,24 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { LocalAccount, Log, RpcLog, type Abi } from 'viem';
|
|
2
2
|
import type { HexString } from '../types/index.js';
|
|
3
|
-
import type { OperationStatus, Signer } from '../types/transaction.js';
|
|
4
|
-
export
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
s: string;
|
|
10
|
-
v: number;
|
|
3
|
+
import type { MessageTypeWithSubType, OperationStatus, Signer, TransactionContext } from '../types/transaction.js';
|
|
4
|
+
export type BatchTransactionData = {
|
|
5
|
+
contract: HexString;
|
|
6
|
+
data: HexString[];
|
|
7
|
+
value?: bigint;
|
|
8
|
+
messages?: Record<number, MessageTypeWithSubType[]>;
|
|
11
9
|
};
|
|
12
|
-
export declare function
|
|
10
|
+
export declare function wrapTransaction(title: string, ctx: TransactionContext, { contract, data: data_, value: value_, messages, }: {
|
|
11
|
+
contract: HexString;
|
|
12
|
+
data: HexString | HexString[];
|
|
13
|
+
value?: bigint;
|
|
14
|
+
messages?: Record<number, MessageTypeWithSubType[]>;
|
|
15
|
+
}): AsyncGenerator<OperationStatus | BatchTransactionData>;
|
|
16
|
+
export declare function doTransaction(title: string, ctx: TransactionContext, transactionCallback: () => Promise<HexString>): AsyncGenerator<OperationStatus>;
|
|
17
|
+
export declare function doSignMessage<T = any>(title: string, transactionCallback: () => Promise<T>): AsyncGenerator<OperationStatus, T>;
|
|
13
18
|
export declare function isLocalAccount(signer: Signer): signer is LocalAccount;
|
|
19
|
+
export declare function parseEventLogs(parameters: {
|
|
20
|
+
logs: (Log | RpcLog)[];
|
|
21
|
+
eventName: string | string[];
|
|
22
|
+
address: HexString | HexString[];
|
|
23
|
+
}): Log<bigint, number, false, undefined, true, Abi, string>[];
|
|
14
24
|
//# sourceMappingURL=transaction.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../src/utils/transaction.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../src/utils/transaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,YAAY,EACZ,GAAG,EAEH,MAAM,EAGN,KAAK,GAAG,EAET,MAAM,MAAM,CAAA;AAIb,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAA;AAClD,OAAO,KAAK,EACV,sBAAsB,EACtB,eAAe,EAEf,MAAM,EACN,kBAAkB,EACnB,MAAM,yBAAyB,CAAA;AAShC,MAAM,MAAM,oBAAoB,GAAG;IACjC,QAAQ,EAAE,SAAS,CAAA;IACnB,IAAI,EAAE,SAAS,EAAE,CAAA;IACjB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,sBAAsB,EAAE,CAAC,CAAA;CACpD,CAAA;AAED,wBAAuB,eAAe,CACpC,KAAK,EAAE,MAAM,EACb,GAAG,EAAE,kBAAkB,EACvB,EACE,QAAQ,EACR,IAAI,EAAE,KAAK,EACX,KAAK,EAAE,MAAM,EACb,QAAQ,GACT,EAAE;IACD,QAAQ,EAAE,SAAS,CAAA;IACnB,IAAI,EAAE,SAAS,GAAG,SAAS,EAAE,CAAA;IAC7B,KAAK,CAAC,EAAE,MAAM,CAAA;IAId,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAsB,sBAAsB,EAAE,CAAC,CAAA;CACxE,GACA,cAAc,CAAC,eAAe,GAAG,oBAAoB,CAAC,CAqCxD;AAED,wBAAuB,aAAa,CAClC,KAAK,EAAE,MAAM,EACb,GAAG,EAAE,kBAAkB,EACvB,mBAAmB,EAAE,MAAM,OAAO,CAAC,SAAS,CAAC,GAC5C,cAAc,CAAC,eAAe,CAAC,CAmBjC;AAmCD,wBAAuB,aAAa,CAAC,CAAC,GAAG,GAAG,EAC1C,KAAK,EAAE,MAAM,EACb,mBAAmB,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GACpC,cAAc,CAAC,eAAe,EAAE,CAAC,CAAC,CAMpC;AAED,wBAAgB,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,IAAI,YAAY,CAErE;AAuBD,wBAAgB,cAAc,CAAC,UAAU,EAAE;IACzC,IAAI,EAAE,CAAC,GAAG,GAAG,MAAM,CAAC,EAAE,CAAA;IACtB,SAAS,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;IAC5B,OAAO,EAAE,SAAS,GAAG,SAAS,EAAE,CAAA;CACjC,GAAG,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,CAAC,EAAE,CA2B7D"}
|
|
@@ -1,33 +1,172 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import { decodeEventLog, parseAbi, toEventSelector, withRetry, } from 'viem';
|
|
2
|
+
import { arbitrum, arbitrumSepolia, avalanche, base, baseSepolia, mainnet, sepolia } from 'viem/chains';
|
|
3
|
+
import { ABI } from '../abi/index.js';
|
|
4
|
+
import { SAFE_PROXY_BYTECODE } from '../constants.js';
|
|
5
|
+
class TransactionError extends Error {
|
|
6
|
+
receipt;
|
|
7
|
+
name = 'TransactionError';
|
|
8
|
+
constructor(receipt) {
|
|
9
|
+
super('Transaction reverted');
|
|
10
|
+
this.receipt = receipt;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
export async function* wrapTransaction(title, ctx, { contract, data: data_, value: value_, messages, }) {
|
|
14
|
+
const data = Array.isArray(data_) ? data_ : [data_];
|
|
15
|
+
if (ctx.isBatching) {
|
|
16
|
+
yield {
|
|
17
|
+
contract,
|
|
18
|
+
data,
|
|
19
|
+
value: value_,
|
|
20
|
+
messages,
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
const messagesEstimates = messages
|
|
25
|
+
? await Promise.all(Object.entries(messages).map(async ([centId, messageTypes]) => ctx.root._estimate(ctx.chainId, { centId: Number(centId) }, messageTypes)))
|
|
26
|
+
: [];
|
|
27
|
+
const estimate = messagesEstimates.reduce((acc, val) => acc + val, 0n);
|
|
28
|
+
const value = (value_ ?? 0n) + estimate;
|
|
29
|
+
const result = yield* doTransaction(title, ctx, async () => {
|
|
30
|
+
if (data.length === 1) {
|
|
31
|
+
return ctx.walletClient.sendTransaction({
|
|
32
|
+
to: contract,
|
|
33
|
+
data: data[0],
|
|
34
|
+
value,
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
return ctx.walletClient.writeContract({
|
|
38
|
+
address: contract,
|
|
39
|
+
abi: parseAbi(['function multicall(bytes[] data) payable']),
|
|
40
|
+
functionName: 'multicall',
|
|
41
|
+
args: [data],
|
|
42
|
+
value,
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
return result;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
export async function* doTransaction(title, ctx, transactionCallback) {
|
|
49
|
+
const id = Math.random().toString(36).substring(2);
|
|
50
|
+
yield { id, type: 'SigningTransaction', title };
|
|
4
51
|
const hash = await transactionCallback();
|
|
5
|
-
yield { type: 'TransactionPending', title, hash };
|
|
6
|
-
const
|
|
7
|
-
|
|
52
|
+
yield { id, type: 'TransactionPending', title, hash };
|
|
53
|
+
const code = await ctx.publicClient.getCode({ address: ctx.signingAddress });
|
|
54
|
+
if (code === SAFE_PROXY_BYTECODE) {
|
|
55
|
+
return yield* waitForSafeTransaction(id, title, hash, ctx);
|
|
56
|
+
}
|
|
57
|
+
const receipt = await ctx.publicClient.waitForTransactionReceipt({ hash });
|
|
58
|
+
if (receipt.status === 'reverted') {
|
|
59
|
+
console.error('Transaction reverted', receipt);
|
|
60
|
+
throw new TransactionError(receipt);
|
|
61
|
+
}
|
|
62
|
+
const result = { id, type: 'TransactionConfirmed', title, hash, receipt };
|
|
63
|
+
yield result;
|
|
64
|
+
return result;
|
|
65
|
+
}
|
|
66
|
+
// TODO: maybe yield Safe Transaction updates as well
|
|
67
|
+
async function* waitForSafeTransaction(id, title, hash, ctx) {
|
|
68
|
+
// First check if tx is actually a safe tx
|
|
69
|
+
let safeTx = await withRetry(() => getSafeTransaction(hash, ctx.chainId), {
|
|
70
|
+
retryCount: 5,
|
|
71
|
+
delay: 5000,
|
|
72
|
+
});
|
|
73
|
+
if (safeTx.isExecuted)
|
|
74
|
+
return safeTx;
|
|
75
|
+
safeTx = await withRetry(async () => {
|
|
76
|
+
const status = await getSafeTransaction(hash, ctx.chainId);
|
|
77
|
+
if (status.isExecuted)
|
|
78
|
+
return status;
|
|
79
|
+
throw new Error(`Timeout waiting for safe transaction to be executed. Transaction hash: ${hash}`);
|
|
80
|
+
}, {
|
|
81
|
+
retryCount: 360,
|
|
82
|
+
delay: 10000,
|
|
83
|
+
});
|
|
84
|
+
const receipt = await ctx.publicClient.waitForTransactionReceipt({ hash: safeTx.transactionHash });
|
|
85
|
+
const result = { id, type: 'TransactionConfirmed', title, hash, receipt };
|
|
86
|
+
yield result;
|
|
87
|
+
return result;
|
|
8
88
|
}
|
|
9
89
|
export async function* doSignMessage(title, transactionCallback) {
|
|
10
|
-
|
|
90
|
+
const id = Math.random().toString(36).substring(2);
|
|
91
|
+
yield { id, type: 'SigningMessage', title };
|
|
11
92
|
const message = await transactionCallback();
|
|
12
|
-
yield { type: 'SignedMessage', title, signed: message };
|
|
93
|
+
yield { id, type: 'SignedMessage', title, signed: message };
|
|
13
94
|
return message;
|
|
14
95
|
}
|
|
15
|
-
export async function signPermit(_, signer, chainId, signingAddress, currencyAddress, spender, amount) {
|
|
16
|
-
let domainOrCurrency = currencyAddress;
|
|
17
|
-
const USDC = '0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48';
|
|
18
|
-
if (currencyAddress.toLowerCase() === USDC) {
|
|
19
|
-
// USDC has custom version
|
|
20
|
-
domainOrCurrency = { name: 'USD Coin', version: '2', chainId, verifyingContract: currencyAddress };
|
|
21
|
-
}
|
|
22
|
-
else if (chainId === 5 || chainId === 84531 || chainId === 421613 || chainId === 11155111) {
|
|
23
|
-
// Assume on testnets the LP currencies are used which have custom domains
|
|
24
|
-
domainOrCurrency = { name: 'Centrifuge', version: '1', chainId, verifyingContract: currencyAddress };
|
|
25
|
-
}
|
|
26
|
-
const deadline = Math.floor(Date.now() / 1000) + 3600; // 1 hour
|
|
27
|
-
const permit = await signERC2612Permit(signer, domainOrCurrency, signingAddress, spender, amount.toString(), deadline);
|
|
28
|
-
return permit;
|
|
29
|
-
}
|
|
30
96
|
export function isLocalAccount(signer) {
|
|
31
97
|
return 'type' in signer && signer.type === 'local';
|
|
32
98
|
}
|
|
99
|
+
// Cached ABI events by their selector
|
|
100
|
+
let abiCache;
|
|
101
|
+
function getAbiCache() {
|
|
102
|
+
if (abiCache)
|
|
103
|
+
return abiCache;
|
|
104
|
+
abiCache = new Map();
|
|
105
|
+
Object.values(ABI)
|
|
106
|
+
.flat()
|
|
107
|
+
.forEach((abiItem) => {
|
|
108
|
+
if (abiItem.type === 'event') {
|
|
109
|
+
abiCache.set(toEventSelector(abiItem), abiItem);
|
|
110
|
+
}
|
|
111
|
+
});
|
|
112
|
+
return abiCache;
|
|
113
|
+
}
|
|
114
|
+
function getAbiEvent(selector) {
|
|
115
|
+
const cache = getAbiCache();
|
|
116
|
+
return cache.get(selector);
|
|
117
|
+
}
|
|
118
|
+
// Match a block's event logs to all available ABIs' events.
|
|
119
|
+
export function parseEventLogs(parameters) {
|
|
120
|
+
const { logs, eventName: eventName_, address: address_ } = parameters;
|
|
121
|
+
const eventName = new Set(Array.isArray(eventName_) ? eventName_ : [eventName_]);
|
|
122
|
+
const address = new Set((Array.isArray(address_) ? address_ : [address_]).map((a) => a.toLowerCase()));
|
|
123
|
+
return logs
|
|
124
|
+
.map((log) => {
|
|
125
|
+
try {
|
|
126
|
+
const abiItem = getAbiEvent(log.topics[0]);
|
|
127
|
+
if (!abiItem)
|
|
128
|
+
return null;
|
|
129
|
+
// Check that the event is one we care about
|
|
130
|
+
if (!eventName.has(abiItem.name))
|
|
131
|
+
return null;
|
|
132
|
+
if (!address.has(log.address))
|
|
133
|
+
return null;
|
|
134
|
+
const event = decodeEventLog({
|
|
135
|
+
...log,
|
|
136
|
+
abi: [abiItem],
|
|
137
|
+
strict: true,
|
|
138
|
+
});
|
|
139
|
+
return { ...event, ...log };
|
|
140
|
+
}
|
|
141
|
+
catch {
|
|
142
|
+
return null;
|
|
143
|
+
}
|
|
144
|
+
})
|
|
145
|
+
.filter(Boolean);
|
|
146
|
+
}
|
|
147
|
+
function safeApiNetworkName(chainId) {
|
|
148
|
+
const name = {
|
|
149
|
+
[mainnet.id]: 'mainnet',
|
|
150
|
+
[base.id]: 'base',
|
|
151
|
+
[arbitrum.id]: 'arbitrum',
|
|
152
|
+
[sepolia.id]: 'sepolia',
|
|
153
|
+
[baseSepolia.id]: 'base-sepolia',
|
|
154
|
+
[arbitrumSepolia.id]: 'arbitrum-sepolia',
|
|
155
|
+
[avalanche.id]: 'avalanche',
|
|
156
|
+
}[chainId];
|
|
157
|
+
if (name)
|
|
158
|
+
return name;
|
|
159
|
+
throw new Error(`Safe API does not support chainId "${chainId}"`);
|
|
160
|
+
}
|
|
161
|
+
async function getSafeTransaction(hash, chainId) {
|
|
162
|
+
const networkName = safeApiNetworkName(chainId);
|
|
163
|
+
const endpoint = `https://safe-transaction-${networkName}.safe.global`;
|
|
164
|
+
const url = `${endpoint}/api/v1/multisig-transactions/${hash}`;
|
|
165
|
+
const response = await fetch(url);
|
|
166
|
+
if (!response.ok) {
|
|
167
|
+
throw new Error(`Error fetching Safe transaction: ${response.statusText}`);
|
|
168
|
+
}
|
|
169
|
+
const data = await response.json();
|
|
170
|
+
return data;
|
|
171
|
+
}
|
|
33
172
|
//# sourceMappingURL=transaction.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../src/utils/transaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAA;
|
|
1
|
+
{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../src/utils/transaction.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
export declare class PoolId {
|
|
2
|
+
#private;
|
|
3
|
+
/**
|
|
4
|
+
* Creates a PoolId from a centrifuge ID and a pool counter.
|
|
5
|
+
* @param centrifugeId - uint16
|
|
6
|
+
* @param poolCounter - uint48
|
|
7
|
+
* @returns A new PoolId instance.
|
|
8
|
+
*/
|
|
9
|
+
static from(centrifugeId: number, poolCounter: number | bigint): PoolId;
|
|
10
|
+
constructor(id: string | bigint | number);
|
|
11
|
+
get centrifugeId(): number;
|
|
12
|
+
get raw(): bigint;
|
|
13
|
+
toString(): string;
|
|
14
|
+
equals(other: PoolId | string | bigint | number): boolean;
|
|
15
|
+
}
|
|
16
|
+
export declare class ShareClassId {
|
|
17
|
+
#private;
|
|
18
|
+
static from(poolId: PoolId, shareClassCounter: number): ShareClassId;
|
|
19
|
+
constructor(id: string);
|
|
20
|
+
get poolId(): PoolId;
|
|
21
|
+
get centrifugeId(): number;
|
|
22
|
+
get raw(): `0x${string}`;
|
|
23
|
+
toString(): `0x${string}`;
|
|
24
|
+
equals(other: ShareClassId | string): boolean;
|
|
25
|
+
}
|
|
26
|
+
export declare class AssetId {
|
|
27
|
+
#private;
|
|
28
|
+
static from(centrifugeId: number, assetCounter: number): AssetId;
|
|
29
|
+
static fromIso(countryCode: number): AssetId;
|
|
30
|
+
constructor(id: string | bigint);
|
|
31
|
+
get centrifugeId(): number;
|
|
32
|
+
get isNationalCurrency(): boolean;
|
|
33
|
+
get addr(): `0x${string}`;
|
|
34
|
+
get raw(): bigint;
|
|
35
|
+
get nationalCurrencyCode(): number | null;
|
|
36
|
+
toString(): string;
|
|
37
|
+
equals(other: AssetId | string | bigint): boolean;
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/utils/types.ts"],"names":[],"mappings":"AAEA,qBAAa,MAAM;;IACjB;;;;;OAKG;IACH,MAAM,CAAC,IAAI,CAAC,YAAY,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,MAAM;gBAMlD,EAAE,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM;IAIxC,IAAI,YAAY,WAEf;IAED,IAAI,GAAG,WAEN;IAED,QAAQ;IAIR,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM;CAGhD;AAED,qBAAa,YAAY;;IACvB,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,MAAM,EAAE,iBAAiB,EAAE,MAAM;gBAMzC,EAAE,EAAE,MAAM;IAOtB,IAAI,MAAM,WAET;IAED,IAAI,YAAY,WAEf;IAED,IAAI,GAAG,kBAEN;IAED,QAAQ;IAIR,MAAM,CAAC,KAAK,EAAE,YAAY,GAAG,MAAM;CAGpC;AAED,qBAAa,OAAO;;IAClB,MAAM,CAAC,IAAI,CAAC,YAAY,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM;IAGtD,MAAM,CAAC,OAAO,CAAC,WAAW,EAAE,MAAM;gBAMtB,EAAE,EAAE,MAAM,GAAG,MAAM;IAI/B,IAAI,YAAY,WAEf;IAED,IAAI,kBAAkB,YAErB;IAED,IAAI,IAAI,kBAEP;IAED,IAAI,GAAG,WAEN;IAED,IAAI,oBAAoB,kBAEvB;IAED,QAAQ;IAIR,MAAM,CAAC,KAAK,EAAE,OAAO,GAAG,MAAM,GAAG,MAAM;CAGxC"}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { toHex } from 'viem';
|
|
2
|
+
export class PoolId {
|
|
3
|
+
/**
|
|
4
|
+
* Creates a PoolId from a centrifuge ID and a pool counter.
|
|
5
|
+
* @param centrifugeId - uint16
|
|
6
|
+
* @param poolCounter - uint48
|
|
7
|
+
* @returns A new PoolId instance.
|
|
8
|
+
*/
|
|
9
|
+
static from(centrifugeId, poolCounter) {
|
|
10
|
+
return new PoolId((BigInt(centrifugeId) << 48n) + BigInt(poolCounter));
|
|
11
|
+
}
|
|
12
|
+
#id;
|
|
13
|
+
constructor(id) {
|
|
14
|
+
this.#id = BigInt(id);
|
|
15
|
+
}
|
|
16
|
+
get centrifugeId() {
|
|
17
|
+
return Number(this.#id >> 48n);
|
|
18
|
+
}
|
|
19
|
+
get raw() {
|
|
20
|
+
return this.#id;
|
|
21
|
+
}
|
|
22
|
+
toString() {
|
|
23
|
+
return this.#id.toString();
|
|
24
|
+
}
|
|
25
|
+
equals(other) {
|
|
26
|
+
return this.raw === (other instanceof PoolId ? other : new PoolId(other)).raw;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
export class ShareClassId {
|
|
30
|
+
static from(poolId, shareClassCounter) {
|
|
31
|
+
return new ShareClassId(toHex((BigInt(poolId.raw) << 64n) + BigInt(shareClassCounter), { size: 16 }));
|
|
32
|
+
}
|
|
33
|
+
#id;
|
|
34
|
+
constructor(id) {
|
|
35
|
+
if (!id.startsWith('0x') || id.length !== 34) {
|
|
36
|
+
throw new Error(`Invalid share class ID: ${id}`);
|
|
37
|
+
}
|
|
38
|
+
this.#id = BigInt(id);
|
|
39
|
+
}
|
|
40
|
+
get poolId() {
|
|
41
|
+
return new PoolId(this.#id >> 64n);
|
|
42
|
+
}
|
|
43
|
+
get centrifugeId() {
|
|
44
|
+
return Number(this.#id >> 112n);
|
|
45
|
+
}
|
|
46
|
+
get raw() {
|
|
47
|
+
return toHex(this.#id, { size: 16 });
|
|
48
|
+
}
|
|
49
|
+
toString() {
|
|
50
|
+
return toHex(this.#id, { size: 16 });
|
|
51
|
+
}
|
|
52
|
+
equals(other) {
|
|
53
|
+
return this.raw === (other instanceof ShareClassId ? other : new ShareClassId(other)).raw;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
export class AssetId {
|
|
57
|
+
static from(centrifugeId, assetCounter) {
|
|
58
|
+
return new AssetId((BigInt(centrifugeId) << 112n) + BigInt(assetCounter));
|
|
59
|
+
}
|
|
60
|
+
static fromIso(countryCode) {
|
|
61
|
+
return new AssetId(BigInt(countryCode));
|
|
62
|
+
}
|
|
63
|
+
#id;
|
|
64
|
+
constructor(id) {
|
|
65
|
+
this.#id = BigInt(id);
|
|
66
|
+
}
|
|
67
|
+
get centrifugeId() {
|
|
68
|
+
return Number(this.#id >> 112n);
|
|
69
|
+
}
|
|
70
|
+
get isNationalCurrency() {
|
|
71
|
+
return this.centrifugeId === 0;
|
|
72
|
+
}
|
|
73
|
+
get addr() {
|
|
74
|
+
return toHex(this.#id, { size: 20 });
|
|
75
|
+
}
|
|
76
|
+
get raw() {
|
|
77
|
+
return this.#id;
|
|
78
|
+
}
|
|
79
|
+
get nationalCurrencyCode() {
|
|
80
|
+
return this.isNationalCurrency ? Number(this.#id) : null;
|
|
81
|
+
}
|
|
82
|
+
toString() {
|
|
83
|
+
return this.#id.toString();
|
|
84
|
+
}
|
|
85
|
+
equals(other) {
|
|
86
|
+
return this.raw === (other instanceof AssetId ? other : new AssetId(other)).raw;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/utils/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.test.d.ts","sourceRoot":"","sources":["../../src/utils/types.test.ts"],"names":[],"mappings":""}
|