@centrifuge/sdk 0.0.0-alpha.12 → 0.0.0-alpha.15
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 +7 -7
- package/dist/Centrifuge.d.ts +103 -53
- package/dist/Centrifuge.d.ts.map +1 -1
- package/dist/Centrifuge.js +272 -58
- 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 +369 -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 +32 -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 +79 -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 +100 -0
- package/dist/abi/AsyncVault.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 +15 -0
- package/dist/abi/Currency.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 +38 -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 +82 -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/IERC7726.abi.d.ts +3 -0
- package/dist/abi/IERC7726.abi.d.ts.map +1 -0
- package/dist/abi/IERC7726.abi.js +2 -0
- package/dist/abi/IERC7726.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/PoolManager.abi.d.ts +3 -0
- package/dist/abi/PoolManager.abi.d.ts.map +1 -0
- package/dist/abi/PoolManager.abi.js +89 -0
- package/dist/abi/PoolManager.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 +84 -0
- package/dist/abi/ShareClassManager.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 +59 -0
- package/dist/abi/SyncRequestManager.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 +58 -0
- package/dist/abi/VaultRouter.abi.js.map +1 -0
- package/dist/abi/index.d.ts +7703 -8
- package/dist/abi/index.d.ts.map +1 -1
- package/dist/abi/index.js +28 -16
- package/dist/abi/index.js.map +1 -1
- package/dist/config/chains.d.ts +457 -449
- package/dist/config/chains.d.ts.map +1 -1
- package/dist/config/chains.js +9 -1
- 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 +4 -0
- package/dist/config/protocol.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/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 +6 -6
- package/dist/entities/IndexerQueries/assetTransactions.d.ts.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/assetTransactions.js +7 -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 +2 -2
- package/dist/entities/IndexerQueries/poolFeeTransactions.d.ts.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/poolFeeTransactions.js +2 -2
- package/dist/entities/IndexerQueries/poolFeeTransactions.js.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/poolSnapshots.d.ts +23 -23
- package/dist/entities/IndexerQueries/poolSnapshots.d.ts.map +1 -0
- package/dist/{IndexerQueries → entities/IndexerQueries}/poolSnapshots.js +23 -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 +36 -0
- package/dist/entities/Investor.d.ts.map +1 -0
- package/dist/entities/Investor.js +26 -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 +16 -0
- package/dist/entities/Investor.test.js.map +1 -0
- package/dist/entities/Pool.d.ts +68 -0
- package/dist/entities/Pool.d.ts.map +1 -0
- package/dist/entities/Pool.js +176 -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 +67 -0
- package/dist/entities/Pool.test.js.map +1 -0
- package/dist/entities/PoolNetwork.d.ts +39 -0
- package/dist/entities/PoolNetwork.d.ts.map +1 -0
- package/dist/entities/PoolNetwork.js +134 -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 +64 -0
- package/dist/entities/PoolNetwork.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 +9 -12
- 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 +1 -1
- package/dist/entities/Reports/index.js.map +1 -0
- package/dist/entities/ShareClass.d.ts +61 -0
- package/dist/entities/ShareClass.d.ts.map +1 -0
- package/dist/entities/ShareClass.js +420 -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 +72 -0
- package/dist/entities/ShareClass.test.js.map +1 -0
- package/dist/entities/Vault.d.ts +85 -0
- package/dist/entities/Vault.d.ts.map +1 -0
- package/dist/{Vault.js → entities/Vault.js} +215 -145
- 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 +252 -0
- package/dist/entities/Vault.test.js.map +1 -0
- package/dist/index.d.ts +10 -6
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +9 -5
- package/dist/index.js.map +1 -1
- package/dist/tests/contracts.d.ts +2 -0
- package/dist/tests/contracts.d.ts.map +1 -0
- package/dist/tests/contracts.js +40 -0
- package/dist/tests/contracts.js.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 +12 -12
- 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 +5 -15
- 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 +45 -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 +2 -1
- package/dist/tests/setup.js.map +1 -1
- package/dist/tests/tenderly.js +1 -1
- package/dist/tests/tenderly.js.map +1 -1
- 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 +46 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/poolInput.d.ts +70 -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 +5 -12
- package/dist/types/poolMetadata.d.ts.map +1 -1
- package/dist/types/reports.d.ts +68 -68
- package/dist/types/reports.d.ts.map +1 -1
- package/dist/types/transaction.d.ts +5 -0
- package/dist/types/transaction.d.ts.map +1 -1
- package/dist/utils/BigInt.d.ts +10 -17
- package/dist/utils/BigInt.d.ts.map +1 -1
- package/dist/utils/BigInt.js +8 -24
- 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/createPinning.d.ts +5 -0
- package/dist/utils/createPinning.d.ts.map +1 -0
- package/dist/utils/createPinning.js +16 -0
- package/dist/utils/createPinning.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/index.d.ts +3 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +4 -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/pinToApi.d.ts +1 -1
- package/dist/utils/pinToApi.d.ts.map +1 -1
- package/dist/utils/pinToApi.js +6 -7
- package/dist/utils/pinToApi.js.map +1 -1
- package/dist/utils/pinToApi.test.d.ts +2 -0
- package/dist/utils/pinToApi.test.d.ts.map +1 -0
- package/dist/utils/pinToApi.test.js +54 -0
- package/dist/utils/pinToApi.test.js.map +1 -0
- package/dist/utils/rx.d.ts +1 -1
- package/dist/utils/rx.d.ts.map +1 -1
- package/dist/utils/rx.js +4 -0
- package/dist/utils/rx.js.map +1 -1
- package/dist/utils/transaction.d.ts.map +1 -1
- package/dist/utils/transaction.js +21 -5
- package/dist/utils/transaction.js.map +1 -1
- package/dist/utils/types.d.ts +33 -0
- package/dist/utils/types.d.ts.map +1 -0
- package/dist/utils/types.js +83 -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 +8 -6
- 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.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/{Entity.js → entities/Entity.js} +0 -0
|
@@ -0,0 +1,252 @@
|
|
|
1
|
+
import { expect } from 'chai';
|
|
2
|
+
import { firstValueFrom, lastValueFrom, skip, skipWhile, tap, toArray } from 'rxjs';
|
|
3
|
+
import { encodePacked } from 'viem';
|
|
4
|
+
import { currencies } from '../config/protocol.js';
|
|
5
|
+
import { context } from '../tests/setup.js';
|
|
6
|
+
import { Balance, Price } from '../utils/BigInt.js';
|
|
7
|
+
import { AssetId, PoolId, ShareClassId } from '../utils/types.js';
|
|
8
|
+
import { Pool } from './Pool.js';
|
|
9
|
+
import { PoolNetwork } from './PoolNetwork.js';
|
|
10
|
+
import { ShareClass } from './ShareClass.js';
|
|
11
|
+
import { Vault } from './Vault.js';
|
|
12
|
+
const chainId = 11155111;
|
|
13
|
+
const asset = currencies[chainId][0];
|
|
14
|
+
// Pool with async vault, permissioned redeem
|
|
15
|
+
const poolId = PoolId.from(1, 1);
|
|
16
|
+
const scId = ShareClassId.from(poolId, 1);
|
|
17
|
+
const assetId = AssetId.from(1, 1);
|
|
18
|
+
// Async deposit/redeem vault with permissioned redeem
|
|
19
|
+
const asyncVaultAddress = '0x914fd615c6dae76085579edec2fdda1b039184ca';
|
|
20
|
+
// Pool with sync deposit vault, and permissioned async redeem
|
|
21
|
+
const poolId2 = PoolId.from(1, 2);
|
|
22
|
+
const scId2 = ShareClassId.from(poolId2, 1);
|
|
23
|
+
const syncVaultAddress = '0x4c6df866387fe755bd61583a3a1772e7c0dc8903';
|
|
24
|
+
// Active investor with a pending redeem order
|
|
25
|
+
// Investor with a pending invest order on async vault
|
|
26
|
+
// Investor with a claimable cancel deposit on async vault
|
|
27
|
+
// Investor with a claimable invest order
|
|
28
|
+
// Investor with no orders on async vault
|
|
29
|
+
const investorA = '0x5b66af49742157E360A2897e3F480d192305B2b5';
|
|
30
|
+
// Investor with a pending invest order on async vault
|
|
31
|
+
const investorB = '0x54b1d961678C145a444765bB2d7aD6B029770D35';
|
|
32
|
+
const investorC = '0x95d340e6d34418D9eBFD2e826b8f61967654C33e';
|
|
33
|
+
// const investorD = '0x41fe7c3D0b4d8107929c08615adF5038Cb3EAf5C'
|
|
34
|
+
// const investorE = '0x897100032Fb126228dB14D7bD24d770770569AC9'
|
|
35
|
+
const fundManager = '0x423420Ae467df6e90291fd0252c0A8a637C1e03f';
|
|
36
|
+
const defaultAssetsAmount = Balance.fromFloat(100, 6);
|
|
37
|
+
const defaultSharesAmount = Balance.fromFloat(100, 18);
|
|
38
|
+
describe('Vault - Async', () => {
|
|
39
|
+
let vault;
|
|
40
|
+
beforeEach(() => {
|
|
41
|
+
const { centrifuge } = context;
|
|
42
|
+
const pool = new Pool(centrifuge, poolId.raw, chainId);
|
|
43
|
+
const sc = new ShareClass(centrifuge, pool, scId.raw);
|
|
44
|
+
const poolNetwork = new PoolNetwork(centrifuge, pool, chainId);
|
|
45
|
+
vault = new Vault(centrifuge, poolNetwork, sc, asset, asyncVaultAddress);
|
|
46
|
+
});
|
|
47
|
+
it('completes the invest/redeem flow', async () => {
|
|
48
|
+
const addresses = await context.centrifuge._protocolAddresses(11155111);
|
|
49
|
+
let investment = await vault.investment(investorA);
|
|
50
|
+
expect(investment.isAllowedToRedeem).to.equal(false);
|
|
51
|
+
expect(investment.isSyncInvest).to.equal(false);
|
|
52
|
+
context.tenderlyFork.impersonateAddress = fundManager;
|
|
53
|
+
context.centrifuge.setSigner(context.tenderlyFork.signer);
|
|
54
|
+
// Set max age of asset price
|
|
55
|
+
const payload = encodePacked(['uint8', 'uint128', 'uint64'], [/* UpdateContract.MaxAssetPriceAge */ 3, assetId.raw, 9999999999999n]);
|
|
56
|
+
await vault.shareClass._updateContract(11155111, addresses.poolManager, payload);
|
|
57
|
+
// Make sure price is up-to-date
|
|
58
|
+
await vault.shareClass.notifyAssetPrice(assetId);
|
|
59
|
+
[, investment] = await Promise.all([
|
|
60
|
+
vault.shareClass.updateMember(investorA, 1800000000, 11155111),
|
|
61
|
+
firstValueFrom(vault.investment(investorA).pipe(skip(1))),
|
|
62
|
+
]);
|
|
63
|
+
expect(investment.isAllowedToInvest).to.equal(true);
|
|
64
|
+
expect(investment.isAllowedToRedeem).to.equal(true);
|
|
65
|
+
expect(investment.shareBalance.toBigInt()).to.equal(0n);
|
|
66
|
+
expect(investment.pendingInvestCurrency.toBigInt()).to.equal(0n);
|
|
67
|
+
expect(investment.pendingRedeemShares.toBigInt()).to.equal(0n);
|
|
68
|
+
expect(investment.claimableInvestShares.toBigInt()).to.equal(0n);
|
|
69
|
+
expect(investment.claimableInvestCurrencyEquivalent.toBigInt()).to.equal(0n);
|
|
70
|
+
context.tenderlyFork.impersonateAddress = investorA;
|
|
71
|
+
context.centrifuge.setSigner(context.tenderlyFork.signer);
|
|
72
|
+
// Invest
|
|
73
|
+
let result;
|
|
74
|
+
[result, investment] = await Promise.all([
|
|
75
|
+
lastValueFrom(vault.increaseInvestOrder(defaultAssetsAmount).pipe(toArray())),
|
|
76
|
+
firstValueFrom(vault.investment(investorA).pipe(skipWhile((i) => !i.pendingInvestCurrency.eq(defaultAssetsAmount.toBigInt())))),
|
|
77
|
+
]);
|
|
78
|
+
expect(result[2]?.type).to.equal('TransactionConfirmed');
|
|
79
|
+
expect(result[2].title).to.equal('Approve');
|
|
80
|
+
expect(result[5]?.type).to.equal('TransactionConfirmed');
|
|
81
|
+
expect(result[5].title).to.equal('Invest');
|
|
82
|
+
expect(investment.pendingInvestCurrency.toBigInt()).to.equal(defaultAssetsAmount.toBigInt());
|
|
83
|
+
context.tenderlyFork.impersonateAddress = fundManager;
|
|
84
|
+
context.centrifuge.setSigner(context.tenderlyFork.signer);
|
|
85
|
+
let epoch = await vault.shareClass._epoch(assetId);
|
|
86
|
+
// Approve deposits
|
|
87
|
+
await vault.shareClass.approveDeposits(assetId, epoch.pendingDeposit, Price.fromFloat(1));
|
|
88
|
+
[, investment] = await Promise.all([
|
|
89
|
+
vault.shareClass.claimDeposit(assetId, investorA),
|
|
90
|
+
firstValueFrom(vault.investment(investorA).pipe(skipWhile((i) => !i.claimableInvestShares.eq(defaultSharesAmount.toBigInt())))),
|
|
91
|
+
]);
|
|
92
|
+
expect(investment.claimableInvestCurrencyEquivalent.toBigInt()).to.equal(defaultAssetsAmount.toBigInt());
|
|
93
|
+
context.tenderlyFork.impersonateAddress = investorA;
|
|
94
|
+
context.centrifuge.setSigner(context.tenderlyFork.signer);
|
|
95
|
+
[, investment] = await Promise.all([
|
|
96
|
+
vault.claim(),
|
|
97
|
+
firstValueFrom(vault.investment(investorA).pipe(skipWhile((i) => !i.claimableInvestShares.eq(0n)))),
|
|
98
|
+
]);
|
|
99
|
+
expect(investment.shareBalance.toBigInt()).to.equal(defaultSharesAmount.toBigInt());
|
|
100
|
+
const redeemShares = Balance.fromFloat(40, 18);
|
|
101
|
+
[, investment, epoch] = await Promise.all([
|
|
102
|
+
vault.increaseRedeemOrder(redeemShares),
|
|
103
|
+
firstValueFrom(vault.investment(investorA).pipe(skipWhile((i) => !i.pendingRedeemShares.eq(redeemShares.toBigInt())))),
|
|
104
|
+
firstValueFrom(vault.shareClass._epoch(assetId).pipe(skipWhile((e) => e.pendingRedeem.eq(0n)))),
|
|
105
|
+
]);
|
|
106
|
+
expect(investment.pendingRedeemShares.toBigInt()).to.equal(redeemShares.toBigInt());
|
|
107
|
+
expect(investment.shareBalance.toBigInt()).to.equal(defaultSharesAmount.toBigInt() - redeemShares.toBigInt());
|
|
108
|
+
context.tenderlyFork.impersonateAddress = fundManager;
|
|
109
|
+
context.centrifuge.setSigner(context.tenderlyFork.signer);
|
|
110
|
+
// Approve redeems
|
|
111
|
+
await Promise.all([
|
|
112
|
+
vault.shareClass.approveRedeems(assetId, epoch.pendingRedeem, Price.fromFloat(1)),
|
|
113
|
+
// claimRedeem() relies on the investOrder being up-to-date, so waiting here for it to be updated
|
|
114
|
+
// TODO: Fix this somehow
|
|
115
|
+
firstValueFrom(vault.shareClass.investorOrder(assetId, investorA).pipe(skipWhile((o) => o.maxRedeemClaims === 0))),
|
|
116
|
+
]);
|
|
117
|
+
[, investment] = await Promise.all([
|
|
118
|
+
vault.shareClass.claimRedeem(assetId, investorA),
|
|
119
|
+
firstValueFrom(vault.investment(investorA).pipe(skipWhile((i) => i.claimableRedeemCurrency.eq(0n)))),
|
|
120
|
+
]);
|
|
121
|
+
context.tenderlyFork.impersonateAddress = investorA;
|
|
122
|
+
context.centrifuge.setSigner(context.tenderlyFork.signer);
|
|
123
|
+
[result, investment] = await Promise.all([
|
|
124
|
+
vault.claim(),
|
|
125
|
+
firstValueFrom(vault.investment(investorA).pipe(skipWhile((i) => i.claimableRedeemCurrency.gt(0n)))),
|
|
126
|
+
]);
|
|
127
|
+
expect(result.type).to.equal('TransactionConfirmed');
|
|
128
|
+
expect(investment.shareBalance.toBigInt()).to.equal(Balance.fromFloat(60, 18).toBigInt());
|
|
129
|
+
});
|
|
130
|
+
it("should throw when placing an invest order larger than the users's balance", async () => {
|
|
131
|
+
context.tenderlyFork.impersonateAddress = investorB;
|
|
132
|
+
context.centrifuge.setSigner(context.tenderlyFork.signer);
|
|
133
|
+
let error = null;
|
|
134
|
+
let emittedSigningStatus = false;
|
|
135
|
+
try {
|
|
136
|
+
await lastValueFrom(vault.increaseInvestOrder(Balance.fromFloat(100000000000, 6)).pipe(tap(() => (emittedSigningStatus = true))));
|
|
137
|
+
}
|
|
138
|
+
catch (e) {
|
|
139
|
+
error = e;
|
|
140
|
+
}
|
|
141
|
+
expect(error?.message).to.equal('Insufficient balance');
|
|
142
|
+
expect(emittedSigningStatus).to.equal(false);
|
|
143
|
+
});
|
|
144
|
+
// TODO: Set up an account with an claimed invest order, but not whitelisted
|
|
145
|
+
// it('throws when not allowed to redeem', async () => {
|
|
146
|
+
// context.tenderlyFork.impersonateAddress = investorD
|
|
147
|
+
// context.centrifuge.setSigner(context.tenderlyFork.signer)
|
|
148
|
+
// let error: Error | null = null
|
|
149
|
+
// let emittedSigningStatus = false
|
|
150
|
+
// try {
|
|
151
|
+
// await lastValueFrom(vault.increaseInvestOrder(defaultAssetsAmount).pipe(tap(() => (emittedSigningStatus = true))))
|
|
152
|
+
// } catch (e: any) {
|
|
153
|
+
// error = e
|
|
154
|
+
// }
|
|
155
|
+
// expect(error?.message).to.equal('Not allowed to invest')
|
|
156
|
+
// expect(emittedSigningStatus).to.equal(false)
|
|
157
|
+
// })
|
|
158
|
+
it('cancels an invest order and claims the tokens back', async () => {
|
|
159
|
+
context.tenderlyFork.impersonateAddress = investorC;
|
|
160
|
+
context.centrifuge.setSigner(context.tenderlyFork.signer);
|
|
161
|
+
let investment = await vault.investment(investorC);
|
|
162
|
+
[, investment] = await Promise.all([
|
|
163
|
+
lastValueFrom(vault.increaseInvestOrder(defaultAssetsAmount).pipe(toArray())),
|
|
164
|
+
firstValueFrom(vault.investment(investorC).pipe(skipWhile((i) => !i.pendingInvestCurrency.eq(defaultAssetsAmount.toBigInt())))),
|
|
165
|
+
]);
|
|
166
|
+
expect(investment.hasPendingCancelInvestRequest).to.equal(false);
|
|
167
|
+
[, investment] = await Promise.all([
|
|
168
|
+
vault.cancelInvestOrder(),
|
|
169
|
+
firstValueFrom(vault.investment(investorC).pipe(skip(1))),
|
|
170
|
+
]);
|
|
171
|
+
// Same chain so cancellation is immediate
|
|
172
|
+
expect(investment.hasPendingCancelInvestRequest).to.equal(false);
|
|
173
|
+
expect(investment.claimableCancelInvestCurrency.toBigInt()).to.equal(defaultAssetsAmount.toBigInt());
|
|
174
|
+
[, investment] = await Promise.all([
|
|
175
|
+
vault.claim(),
|
|
176
|
+
firstValueFrom(vault.investment(investorC).pipe(skipWhile((i) => !i.claimableCancelInvestCurrency.isZero()))),
|
|
177
|
+
]);
|
|
178
|
+
expect(investment.claimableCancelInvestCurrency.toBigInt()).to.equal(0n);
|
|
179
|
+
});
|
|
180
|
+
it('should throw when trying to cancel a non-existing order', async () => {
|
|
181
|
+
context.tenderlyFork.impersonateAddress = investorA;
|
|
182
|
+
context.centrifuge.setSigner(context.tenderlyFork.signer);
|
|
183
|
+
let thrown = false;
|
|
184
|
+
let emittedSigningStatus = false;
|
|
185
|
+
try {
|
|
186
|
+
await lastValueFrom(vault.cancelRedeemOrder().pipe(tap(() => (emittedSigningStatus = true))));
|
|
187
|
+
}
|
|
188
|
+
catch {
|
|
189
|
+
thrown = true;
|
|
190
|
+
}
|
|
191
|
+
expect(thrown).to.equal(true);
|
|
192
|
+
expect(emittedSigningStatus).to.equal(false);
|
|
193
|
+
});
|
|
194
|
+
// TODO: Set up an account with a redeem order
|
|
195
|
+
// it('should cancel a redeem order', async () => {
|
|
196
|
+
// const investmentBefore = await vault.investment(investorA)
|
|
197
|
+
// expect(investmentBefore.hasPendingCancelRedeemRequest).to.equal(false)
|
|
198
|
+
// context.tenderlyFork.impersonateAddress = investorA
|
|
199
|
+
// context.centrifuge.setSigner(context.tenderlyFork.signer)
|
|
200
|
+
// const [result, investmentAfter] = await Promise.all([
|
|
201
|
+
// vault.cancelRedeemOrder(),
|
|
202
|
+
// firstValueFrom(vault.investment(investorA).pipe(skip(1))),
|
|
203
|
+
// ])
|
|
204
|
+
// expect(result.type).to.equal('TransactionConfirmed')
|
|
205
|
+
// expect(investmentAfter.hasPendingCancelRedeemRequest).to.equal(true)
|
|
206
|
+
// })
|
|
207
|
+
});
|
|
208
|
+
describe('Vault - Sync invest', () => {
|
|
209
|
+
let vault;
|
|
210
|
+
beforeEach(() => {
|
|
211
|
+
const { centrifuge } = context;
|
|
212
|
+
const pool = new Pool(centrifuge, poolId2.raw, chainId);
|
|
213
|
+
const sc = new ShareClass(centrifuge, pool, scId2.raw);
|
|
214
|
+
const poolNetwork = new PoolNetwork(centrifuge, pool, chainId);
|
|
215
|
+
vault = new Vault(centrifuge, poolNetwork, sc, asset, syncVaultAddress);
|
|
216
|
+
});
|
|
217
|
+
it('invests', async () => {
|
|
218
|
+
const addresses = await context.centrifuge._protocolAddresses(11155111);
|
|
219
|
+
const investmentBefore = await vault.investment(investorA);
|
|
220
|
+
context.tenderlyFork.impersonateAddress = fundManager;
|
|
221
|
+
context.centrifuge.setSigner(context.tenderlyFork.signer);
|
|
222
|
+
// Set max age of asset/share price
|
|
223
|
+
const payload = encodePacked(['uint8', 'uint128', 'uint64'], [/* UpdateContract.MaxAssetPriceAge */ 3, assetId.raw, 9999999999999n]);
|
|
224
|
+
await vault.shareClass._updateContract(11155111, addresses.poolManager, payload);
|
|
225
|
+
const payload2 = encodePacked(['uint8', 'uint64'], [/* UpdateContract.MaxSharePriceAge */ 4, 9999999999999n]);
|
|
226
|
+
await vault.shareClass._updateContract(11155111, addresses.poolManager, payload2);
|
|
227
|
+
// Make sure price is up-to-date
|
|
228
|
+
await vault.shareClass.notifyAssetPrice(assetId);
|
|
229
|
+
await vault.shareClass.notifySharePrice(11155111);
|
|
230
|
+
expect(investmentBefore.isSyncInvest).to.equal(true);
|
|
231
|
+
expect(investmentBefore.isAllowedToInvest).to.equal(true);
|
|
232
|
+
expect(investmentBefore.shareBalance.toBigInt()).to.equal(0n);
|
|
233
|
+
expect(investmentBefore.pendingInvestCurrency.toBigInt()).to.equal(0n);
|
|
234
|
+
expect(investmentBefore.pendingRedeemShares.toBigInt()).to.equal(0n);
|
|
235
|
+
expect(investmentBefore.claimableInvestShares.toBigInt()).to.equal(0n);
|
|
236
|
+
expect(investmentBefore.claimableInvestCurrencyEquivalent.toBigInt()).to.equal(0n);
|
|
237
|
+
expect(investmentBefore.maxInvest.toFloat()).to.be.gt(0);
|
|
238
|
+
context.tenderlyFork.impersonateAddress = investorA;
|
|
239
|
+
context.centrifuge.setSigner(context.tenderlyFork.signer);
|
|
240
|
+
// Invest
|
|
241
|
+
const [result, investmentAfter] = await Promise.all([
|
|
242
|
+
lastValueFrom(vault.increaseInvestOrder(defaultAssetsAmount).pipe(toArray())),
|
|
243
|
+
firstValueFrom(vault.investment(investorA).pipe(skipWhile((i) => i.shareBalance.eq(0n)))),
|
|
244
|
+
]);
|
|
245
|
+
expect(result[2]?.type).to.equal('TransactionConfirmed');
|
|
246
|
+
expect(result[2].title).to.equal('Approve');
|
|
247
|
+
expect(result[5]?.type).to.equal('TransactionConfirmed');
|
|
248
|
+
expect(result[5].title).to.equal('Invest');
|
|
249
|
+
expect(investmentAfter.shareBalance.toBigInt()).to.equal(defaultSharesAmount.toBigInt());
|
|
250
|
+
});
|
|
251
|
+
});
|
|
252
|
+
//# sourceMappingURL=Vault.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Vault.test.js","sourceRoot":"","sources":["../../src/entities/Vault.test.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,15 +1,19 @@
|
|
|
1
1
|
import { Centrifuge } from './Centrifuge.js';
|
|
2
|
-
export
|
|
3
|
-
export * from './Pool.js';
|
|
4
|
-
export * from './PoolNetwork.js';
|
|
5
|
-
export * from './Reports/index.js';
|
|
2
|
+
export * from './entities/Investor.js';
|
|
3
|
+
export * from './entities/Pool.js';
|
|
4
|
+
export * from './entities/PoolNetwork.js';
|
|
5
|
+
export * from './entities/Reports/index.js';
|
|
6
|
+
export * from './entities/ShareClass.js';
|
|
7
|
+
export * from './entities/Vault.js';
|
|
6
8
|
export type { Client, Config, HexString } from './types/index.js';
|
|
9
|
+
export type { IssuerDetail, PoolMetadataInput, PoolReport, ShareClassInput } from './types/poolInput.js';
|
|
10
|
+
export * from './types/poolMetadata.js';
|
|
7
11
|
export type { Query } from './types/query.js';
|
|
8
12
|
export type { AssetListReport, AssetListReportBase, AssetListReportFilter, AssetListReportPrivateCredit, AssetListReportPublicCredit, AssetTransactionReport, AssetTransactionReportFilter, BalanceSheetReport, CashflowReport, CashflowReportBase, CashflowReportPrivateCredit, CashflowReportPublicCredit, FeeTransactionReport, FeeTransactionReportFilter, InvestorListReport, InvestorListReportFilter, InvestorTransactionsReport, InvestorTransactionsReportFilter, ProfitAndLossReport, ProfitAndLossReportBase, ProfitAndLossReportPrivateCredit, ProfitAndLossReportPublicCredit, ReportFilter, TokenPriceReport, TokenPriceReportFilter, } from './types/reports.js';
|
|
9
13
|
export type { EIP1193ProviderLike, OperationConfirmedStatus, OperationPendingStatus, OperationSignedMessageStatus, OperationSigningMessageStatus, OperationSigningStatus, OperationStatus, OperationStatusType, OperationSwitchChainStatus, Signer, Transaction, } from './types/transaction.js';
|
|
10
|
-
export {
|
|
14
|
+
export { Balance, Perquintill, Price, Rate } from './utils/BigInt.js';
|
|
11
15
|
export type { GroupBy } from './utils/date.js';
|
|
12
|
-
export * from './
|
|
16
|
+
export * from './utils/types.js';
|
|
13
17
|
export { Centrifuge };
|
|
14
18
|
export default Centrifuge;
|
|
15
19
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAC5C,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAC5C,cAAc,wBAAwB,CAAA;AACtC,cAAc,oBAAoB,CAAA;AAClC,cAAc,2BAA2B,CAAA;AACzC,cAAc,6BAA6B,CAAA;AAC3C,cAAc,0BAA0B,CAAA;AACxC,cAAc,qBAAqB,CAAA;AACnC,YAAY,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAA;AACjE,YAAY,EAAE,YAAY,EAAE,iBAAiB,EAAE,UAAU,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AACxG,cAAc,yBAAyB,CAAA;AACvC,YAAY,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAA;AAC7C,YAAY,EACV,eAAe,EACf,mBAAmB,EACnB,qBAAqB,EACrB,4BAA4B,EAC5B,2BAA2B,EAC3B,sBAAsB,EACtB,4BAA4B,EAC5B,kBAAkB,EAClB,cAAc,EACd,kBAAkB,EAClB,2BAA2B,EAC3B,0BAA0B,EAC1B,oBAAoB,EACpB,0BAA0B,EAC1B,kBAAkB,EAClB,wBAAwB,EACxB,0BAA0B,EAC1B,gCAAgC,EAChC,mBAAmB,EACnB,uBAAuB,EACvB,gCAAgC,EAChC,+BAA+B,EAC/B,YAAY,EACZ,gBAAgB,EAChB,sBAAsB,GACvB,MAAM,oBAAoB,CAAA;AAC3B,YAAY,EACV,mBAAmB,EACnB,wBAAwB,EACxB,sBAAsB,EACtB,4BAA4B,EAC5B,6BAA6B,EAC7B,sBAAsB,EACtB,eAAe,EACf,mBAAmB,EACnB,0BAA0B,EAC1B,MAAM,EACN,WAAW,GACZ,MAAM,wBAAwB,CAAA;AAC/B,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,mBAAmB,CAAA;AACrE,YAAY,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAA;AAC9C,cAAc,kBAAkB,CAAA;AAEhC,OAAO,EAAE,UAAU,EAAE,CAAA;AACrB,eAAe,UAAU,CAAA"}
|
package/dist/index.js
CHANGED
|
@@ -1,9 +1,13 @@
|
|
|
1
1
|
import { Centrifuge } from './Centrifuge.js';
|
|
2
|
-
export * from './
|
|
3
|
-
export * from './
|
|
4
|
-
export * from './
|
|
5
|
-
export
|
|
6
|
-
export * from './
|
|
2
|
+
export * from './entities/Investor.js';
|
|
3
|
+
export * from './entities/Pool.js';
|
|
4
|
+
export * from './entities/PoolNetwork.js';
|
|
5
|
+
export * from './entities/Reports/index.js';
|
|
6
|
+
export * from './entities/ShareClass.js';
|
|
7
|
+
export * from './entities/Vault.js';
|
|
8
|
+
export * from './types/poolMetadata.js';
|
|
9
|
+
export { Balance, Perquintill, Price, Rate } from './utils/BigInt.js';
|
|
10
|
+
export * from './utils/types.js';
|
|
7
11
|
export { Centrifuge };
|
|
8
12
|
export default Centrifuge;
|
|
9
13
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAC5C,cAAc,wBAAwB,CAAA;AACtC,cAAc,oBAAoB,CAAA;AAClC,cAAc,2BAA2B,CAAA;AACzC,cAAc,6BAA6B,CAAA;AAC3C,cAAc,0BAA0B,CAAA;AACxC,cAAc,qBAAqB,CAAA;AAGnC,cAAc,yBAAyB,CAAA;AA0CvC,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,mBAAmB,CAAA;AAErE,cAAc,kBAAkB,CAAA;AAEhC,OAAO,EAAE,UAAU,EAAE,CAAA;AACrB,eAAe,UAAU,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contracts.d.ts","sourceRoot":"","sources":["../../src/tests/contracts.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { expect } from 'chai';
|
|
2
|
+
import { Centrifuge } from '../Centrifuge.js';
|
|
3
|
+
const expectedContractKeys = [
|
|
4
|
+
'root',
|
|
5
|
+
'adminSafe',
|
|
6
|
+
'guardian',
|
|
7
|
+
'gasService',
|
|
8
|
+
'gateway',
|
|
9
|
+
'messageProcessor',
|
|
10
|
+
'messageDispatcher',
|
|
11
|
+
'poolRegistry',
|
|
12
|
+
'assetRegistry',
|
|
13
|
+
'accounting',
|
|
14
|
+
'holdings',
|
|
15
|
+
'multiShareClass',
|
|
16
|
+
'poolRouter',
|
|
17
|
+
'transientValuation',
|
|
18
|
+
'identityValuation',
|
|
19
|
+
'escrow',
|
|
20
|
+
'routerEscrow',
|
|
21
|
+
'restrictionManager',
|
|
22
|
+
'restrictedRedemptions',
|
|
23
|
+
'tokenFactory',
|
|
24
|
+
'investmentManager',
|
|
25
|
+
'vaultFactory',
|
|
26
|
+
'poolManager',
|
|
27
|
+
'vaultRouter',
|
|
28
|
+
'currencies',
|
|
29
|
+
];
|
|
30
|
+
describe('Protocol addresses', () => {
|
|
31
|
+
it('should fetch protocol addresses for the demo chain (sepolia)', async () => {
|
|
32
|
+
const centrifuge = new Centrifuge({ environment: 'demo' });
|
|
33
|
+
const chainId = centrifuge.config.defaultChain;
|
|
34
|
+
const result = await centrifuge._protocolAddresses(chainId);
|
|
35
|
+
expect(result).to.be.an('object');
|
|
36
|
+
expect(Object.keys(result)).to.be.eql(expectedContractKeys);
|
|
37
|
+
expect(result.currencies).to.be.an('array');
|
|
38
|
+
});
|
|
39
|
+
});
|
|
40
|
+
//# sourceMappingURL=contracts.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contracts.js","sourceRoot":"","sources":["../../src/tests/contracts.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAA;AAC7B,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAA;AAE7C,MAAM,oBAAoB,GAAG;IAC3B,MAAM;IACN,WAAW;IACX,UAAU;IACV,YAAY;IACZ,SAAS;IACT,kBAAkB;IAClB,mBAAmB;IACnB,cAAc;IACd,eAAe;IACf,YAAY;IACZ,UAAU;IACV,iBAAiB;IACjB,YAAY;IACZ,oBAAoB;IACpB,mBAAmB;IACnB,QAAQ;IACR,cAAc;IACd,oBAAoB;IACpB,uBAAuB;IACvB,cAAc;IACd,mBAAmB;IACnB,cAAc;IACd,aAAa;IACb,aAAa;IACb,YAAY;CACb,CAAA;AAED,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IAClC,EAAE,CAAC,8DAA8D,EAAE,KAAK,IAAI,EAAE;QAC5E,MAAM,UAAU,GAAG,IAAI,UAAU,CAAC,EAAE,WAAW,EAAE,MAAM,EAAE,CAAC,CAAA;QAC1D,MAAM,OAAO,GAAG,UAAU,CAAC,MAAM,CAAC,YAAY,CAAA;QAE9C,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAA;QAE3D,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAA;QACjC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAA;QAC3D,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,OAAO,CAAC,CAAA;IAC7C,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mockAssetSnapshots.d.ts","sourceRoot":"","sources":["../../../src/tests/mocks/mockAssetSnapshots.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"mockAssetSnapshots.d.ts","sourceRoot":"","sources":["../../../src/tests/mocks/mockAssetSnapshots.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,iDAAiD,CAAA;AAG/E,eAAO,MAAM,kBAAkB,EAAE,aAAa,EAqD7C,CAAA"}
|
|
@@ -1,29 +1,29 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { Balance, Rate } from '../../utils/BigInt.js';
|
|
2
2
|
export const mockAssetSnapshots = [
|
|
3
3
|
{
|
|
4
4
|
actualMaturityDate: '2030-01-01',
|
|
5
5
|
actualOriginationDate: 1704067200, // 2024-01-01
|
|
6
6
|
advanceRate: new Rate('800000000000000000'), // 0.8
|
|
7
7
|
assetId: 'asset-1',
|
|
8
|
-
collateralValue:
|
|
9
|
-
currentPrice:
|
|
8
|
+
collateralValue: Balance.fromFloat(125000, 6), // 125k
|
|
9
|
+
currentPrice: Balance.fromFloat(1, 6),
|
|
10
10
|
discountRate: new Rate('100000000000000000'), // 0.1
|
|
11
|
-
faceValue:
|
|
11
|
+
faceValue: Balance.fromFloat(100000, 6), // 100k
|
|
12
12
|
lossGivenDefault: new Rate('400000000000000000'), // 0.4
|
|
13
13
|
name: 'Asset 1',
|
|
14
|
-
outstandingDebt:
|
|
15
|
-
outstandingInterest:
|
|
16
|
-
outstandingPrincipal:
|
|
17
|
-
outstandingQuantity:
|
|
18
|
-
presentValue:
|
|
14
|
+
outstandingDebt: Balance.fromFloat(80000, 6), // 80k
|
|
15
|
+
outstandingInterest: Balance.fromFloat(2000, 6), // 2k
|
|
16
|
+
outstandingPrincipal: Balance.fromFloat(78000, 6), // 78k
|
|
17
|
+
outstandingQuantity: Balance.fromFloat(78000, 6), // 78k
|
|
18
|
+
presentValue: Balance.fromFloat(77000, 6), // 77k
|
|
19
19
|
probabilityOfDefault: new Rate('50000000000000000'), // 0.05
|
|
20
20
|
status: 'ACTIVE',
|
|
21
|
-
sumRealizedProfitFifo:
|
|
21
|
+
sumRealizedProfitFifo: Balance.fromFloat(1000, 6), // 1k
|
|
22
22
|
timestamp: '2024-01-01T12:00:00Z',
|
|
23
|
-
totalRepaidInterest:
|
|
24
|
-
totalRepaidPrincipal:
|
|
25
|
-
totalRepaidUnscheduled:
|
|
26
|
-
unrealizedProfitAtMarketPrice:
|
|
23
|
+
totalRepaidInterest: Balance.fromFloat(500, 6), // 500
|
|
24
|
+
totalRepaidPrincipal: Balance.fromFloat(22000, 6), // 22k
|
|
25
|
+
totalRepaidUnscheduled: Balance.fromFloat(0, 6),
|
|
26
|
+
unrealizedProfitAtMarketPrice: Balance.fromFloat(-1000, 6), // -1k
|
|
27
27
|
valuationMethod: 'DiscountedCashFlow',
|
|
28
28
|
},
|
|
29
29
|
{
|
|
@@ -31,25 +31,25 @@ export const mockAssetSnapshots = [
|
|
|
31
31
|
actualOriginationDate: 1704067200, // 2024-01-01
|
|
32
32
|
advanceRate: new Rate('800000000000000000'), // 0.8
|
|
33
33
|
assetId: 'asset-1',
|
|
34
|
-
collateralValue:
|
|
35
|
-
currentPrice:
|
|
34
|
+
collateralValue: Balance.fromFloat(125000, 6),
|
|
35
|
+
currentPrice: Balance.fromFloat(1.02, 6), // Price increased
|
|
36
36
|
discountRate: new Rate('100000000000000000'),
|
|
37
|
-
faceValue:
|
|
37
|
+
faceValue: Balance.fromFloat(100000, 6),
|
|
38
38
|
lossGivenDefault: new Rate('400000000000000000'),
|
|
39
39
|
name: 'Asset 1',
|
|
40
|
-
outstandingDebt:
|
|
41
|
-
outstandingInterest:
|
|
42
|
-
outstandingPrincipal:
|
|
43
|
-
outstandingQuantity:
|
|
44
|
-
presentValue:
|
|
40
|
+
outstandingDebt: Balance.fromFloat(75000, 6), // Decreased by 5k
|
|
41
|
+
outstandingInterest: Balance.fromFloat(1800, 6), // Decreased
|
|
42
|
+
outstandingPrincipal: Balance.fromFloat(73200, 6), // Decreased
|
|
43
|
+
outstandingQuantity: Balance.fromFloat(73200, 6),
|
|
44
|
+
presentValue: Balance.fromFloat(74000, 6),
|
|
45
45
|
probabilityOfDefault: new Rate('50000000000000000'),
|
|
46
46
|
status: 'ACTIVE',
|
|
47
|
-
sumRealizedProfitFifo:
|
|
47
|
+
sumRealizedProfitFifo: Balance.fromFloat(1200, 6), // Increased
|
|
48
48
|
timestamp: '2024-01-02T12:00:00Z',
|
|
49
|
-
totalRepaidInterest:
|
|
50
|
-
totalRepaidPrincipal:
|
|
51
|
-
totalRepaidUnscheduled:
|
|
52
|
-
unrealizedProfitAtMarketPrice:
|
|
49
|
+
totalRepaidInterest: Balance.fromFloat(700, 6), // Increased
|
|
50
|
+
totalRepaidPrincipal: Balance.fromFloat(26800, 6), // Increased
|
|
51
|
+
totalRepaidUnscheduled: Balance.fromFloat(0, 6),
|
|
52
|
+
unrealizedProfitAtMarketPrice: Balance.fromFloat(1000, 6), // Changed to profit
|
|
53
53
|
valuationMethod: 'DiscountedCashFlow',
|
|
54
54
|
},
|
|
55
55
|
];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mockAssetSnapshots.js","sourceRoot":"","sources":["../../../src/tests/mocks/mockAssetSnapshots.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"mockAssetSnapshots.js","sourceRoot":"","sources":["../../../src/tests/mocks/mockAssetSnapshots.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,uBAAuB,CAAA;AAErD,MAAM,CAAC,MAAM,kBAAkB,GAAoB;IACjD;QACE,kBAAkB,EAAE,YAAY;QAChC,qBAAqB,EAAE,UAAU,EAAE,aAAa;QAChD,WAAW,EAAE,IAAI,IAAI,CAAC,oBAAoB,CAAC,EAAE,MAAM;QACnD,OAAO,EAAE,SAAS;QAClB,eAAe,EAAE,OAAO,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,OAAO;QACtD,YAAY,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC;QACrC,YAAY,EAAE,IAAI,IAAI,CAAC,oBAAoB,CAAC,EAAE,MAAM;QACpD,SAAS,EAAE,OAAO,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,OAAO;QAChD,gBAAgB,EAAE,IAAI,IAAI,CAAC,oBAAoB,CAAC,EAAE,MAAM;QACxD,IAAI,EAAE,SAAS;QACf,eAAe,EAAE,OAAO,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC,EAAE,MAAM;QACpD,mBAAmB,EAAE,OAAO,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,KAAK;QACtD,oBAAoB,EAAE,OAAO,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC,EAAE,MAAM;QACzD,mBAAmB,EAAE,OAAO,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC,EAAE,MAAM;QACxD,YAAY,EAAE,OAAO,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC,EAAE,MAAM;QACjD,oBAAoB,EAAE,IAAI,IAAI,CAAC,mBAAmB,CAAC,EAAE,OAAO;QAC5D,MAAM,EAAE,QAAQ;QAChB,qBAAqB,EAAE,OAAO,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,KAAK;QACxD,SAAS,EAAE,sBAAsB;QACjC,mBAAmB,EAAE,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,MAAM;QACtD,oBAAoB,EAAE,OAAO,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC,EAAE,MAAM;QACzD,sBAAsB,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC;QAC/C,6BAA6B,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,MAAM;QAClE,eAAe,EAAE,oBAAoB;KACtC;IACD;QACE,kBAAkB,EAAE,YAAY;QAChC,qBAAqB,EAAE,UAAU,EAAE,aAAa;QAChD,WAAW,EAAE,IAAI,IAAI,CAAC,oBAAoB,CAAC,EAAE,MAAM;QACnD,OAAO,EAAE,SAAS;QAClB,eAAe,EAAE,OAAO,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC;QAC7C,YAAY,EAAE,OAAO,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,kBAAkB;QAC5D,YAAY,EAAE,IAAI,IAAI,CAAC,oBAAoB,CAAC;QAC5C,SAAS,EAAE,OAAO,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC;QACvC,gBAAgB,EAAE,IAAI,IAAI,CAAC,oBAAoB,CAAC;QAChD,IAAI,EAAE,SAAS;QACf,eAAe,EAAE,OAAO,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC,EAAE,kBAAkB;QAChE,mBAAmB,EAAE,OAAO,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,YAAY;QAC7D,oBAAoB,EAAE,OAAO,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC,EAAE,YAAY;QAC/D,mBAAmB,EAAE,OAAO,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC;QAChD,YAAY,EAAE,OAAO,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC;QACzC,oBAAoB,EAAE,IAAI,IAAI,CAAC,mBAAmB,CAAC;QACnD,MAAM,EAAE,QAAQ;QAChB,qBAAqB,EAAE,OAAO,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,YAAY;QAC/D,SAAS,EAAE,sBAAsB;QACjC,mBAAmB,EAAE,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,YAAY;QAC5D,oBAAoB,EAAE,OAAO,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC,EAAE,YAAY;QAC/D,sBAAsB,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC;QAC/C,6BAA6B,EAAE,OAAO,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,oBAAoB;QAC/E,eAAe,EAAE,oBAAoB;KACtC;CACF,CAAA"}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import { AssetTransaction } from '../../IndexerQueries/assetTransactions.js';
|
|
1
|
+
import { AssetTransaction } from '../../entities/IndexerQueries/assetTransactions.js';
|
|
2
2
|
export declare const mockAssetTransactions: AssetTransaction[];
|
|
3
3
|
//# sourceMappingURL=mockAssetTransactions.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mockAssetTransactions.d.ts","sourceRoot":"","sources":["../../../src/tests/mocks/mockAssetTransactions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAmC,MAAM,
|
|
1
|
+
{"version":3,"file":"mockAssetTransactions.d.ts","sourceRoot":"","sources":["../../../src/tests/mocks/mockAssetTransactions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAmC,MAAM,oDAAoD,CAAA;AAGtH,eAAO,MAAM,qBAAqB,EAAE,gBAAgB,EAkFnD,CAAA"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { AssetType } from '../../IndexerQueries/assetTransactions.js';
|
|
2
|
-
import {
|
|
1
|
+
import { AssetType } from '../../entities/IndexerQueries/assetTransactions.js';
|
|
2
|
+
import { Balance, Price } from '../../utils/BigInt.js';
|
|
3
3
|
export const mockAssetTransactions = [
|
|
4
4
|
{
|
|
5
5
|
id: 'asset-tx-1',
|
|
@@ -8,14 +8,14 @@ export const mockAssetTransactions = [
|
|
|
8
8
|
accountId: 'account-1',
|
|
9
9
|
epochId: 'epoch-1',
|
|
10
10
|
type: 'BORROWED',
|
|
11
|
-
amount:
|
|
11
|
+
amount: Balance.fromFloat(100000, 6), // 100k
|
|
12
12
|
settlementPrice: new Price(1000000000000000000n), // 1.0
|
|
13
13
|
quantity: '100000',
|
|
14
|
-
principalAmount:
|
|
15
|
-
interestAmount:
|
|
14
|
+
principalAmount: Balance.fromFloat(100000, 6),
|
|
15
|
+
interestAmount: Balance.fromFloat(0, 6),
|
|
16
16
|
hash: '0xabc123',
|
|
17
|
-
realizedProfitFifo:
|
|
18
|
-
unrealizedProfitAtMarketPrice:
|
|
17
|
+
realizedProfitFifo: Balance.fromFloat(0, 6),
|
|
18
|
+
unrealizedProfitAtMarketPrice: Balance.fromFloat(0, 6),
|
|
19
19
|
asset: {
|
|
20
20
|
id: 'poolId-1',
|
|
21
21
|
metadata: 'Asset 1 metadata',
|
|
@@ -31,13 +31,13 @@ export const mockAssetTransactions = [
|
|
|
31
31
|
accountId: 'account-1',
|
|
32
32
|
epochId: 'epoch-1',
|
|
33
33
|
type: 'REPAID',
|
|
34
|
-
amount:
|
|
34
|
+
amount: Balance.fromFloat(20000, 6), // 20k
|
|
35
35
|
settlementPrice: new Price(1000000000000000000n), // 1.0
|
|
36
36
|
quantity: '20000',
|
|
37
|
-
principalAmount:
|
|
38
|
-
interestAmount:
|
|
37
|
+
principalAmount: Balance.fromFloat(19000, 6),
|
|
38
|
+
interestAmount: Balance.fromFloat(1000, 6),
|
|
39
39
|
hash: '0xdef456',
|
|
40
|
-
realizedProfitFifo:
|
|
40
|
+
realizedProfitFifo: Balance.fromFloat(1000, 6),
|
|
41
41
|
unrealizedProfitAtMarketPrice: undefined,
|
|
42
42
|
asset: {
|
|
43
43
|
id: 'poolId-1',
|
|
@@ -60,7 +60,7 @@ export const mockAssetTransactions = [
|
|
|
60
60
|
accountId: 'account-1',
|
|
61
61
|
epochId: 'epoch-1',
|
|
62
62
|
type: 'CASH_TRANSFER',
|
|
63
|
-
amount:
|
|
63
|
+
amount: Balance.fromFloat(5000, 6),
|
|
64
64
|
settlementPrice: null,
|
|
65
65
|
quantity: null,
|
|
66
66
|
principalAmount: null,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mockAssetTransactions.js","sourceRoot":"","sources":["../../../src/tests/mocks/mockAssetTransactions.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"mockAssetTransactions.js","sourceRoot":"","sources":["../../../src/tests/mocks/mockAssetTransactions.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mockEpochs.d.ts","sourceRoot":"","sources":["../../../src/tests/mocks/mockEpochs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"mockEpochs.d.ts","sourceRoot":"","sources":["../../../src/tests/mocks/mockEpochs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,yCAAyC,CAAA;AAG/D,eAAO,MAAM,UAAU,EAAE,KAAK,EAuB7B,CAAA"}
|