@centrifuge/sdk 0.55.1 → 0.55.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/entities/BalanceSheet.js +3 -3
- package/dist/entities/BalanceSheet.js.map +1 -1
- package/dist/entities/IndexerQueries/assetSnapshots.d.ts +69 -0
- package/dist/entities/IndexerQueries/assetSnapshots.d.ts.map +1 -0
- package/dist/entities/IndexerQueries/assetSnapshots.js +91 -0
- package/dist/entities/IndexerQueries/assetSnapshots.js.map +1 -0
- package/dist/entities/IndexerQueries/assetTransactions.d.ts +93 -0
- package/dist/entities/IndexerQueries/assetTransactions.d.ts.map +1 -0
- package/dist/entities/IndexerQueries/assetTransactions.js +75 -0
- package/dist/entities/IndexerQueries/assetTransactions.js.map +1 -0
- package/dist/entities/IndexerQueries/epochs.d.ts +45 -0
- package/dist/entities/IndexerQueries/epochs.d.ts.map +1 -0
- package/dist/entities/IndexerQueries/epochs.js +51 -0
- package/dist/entities/IndexerQueries/epochs.js.map +1 -0
- package/dist/entities/IndexerQueries/index.d.ts +40 -0
- package/dist/entities/IndexerQueries/index.d.ts.map +1 -0
- package/dist/entities/IndexerQueries/index.js +45 -0
- package/dist/entities/IndexerQueries/index.js.map +1 -0
- package/dist/entities/IndexerQueries/investorTransactions.d.ts +50 -0
- package/dist/entities/IndexerQueries/investorTransactions.d.ts.map +1 -0
- package/dist/entities/IndexerQueries/investorTransactions.js +55 -0
- package/dist/entities/IndexerQueries/investorTransactions.js.map +1 -0
- package/dist/entities/IndexerQueries/poolFeeSnapshots.d.ts +48 -0
- package/dist/entities/IndexerQueries/poolFeeSnapshots.d.ts.map +1 -0
- package/dist/entities/IndexerQueries/poolFeeSnapshots.js +62 -0
- package/dist/entities/IndexerQueries/poolFeeSnapshots.js.map +1 -0
- package/dist/entities/IndexerQueries/poolFeeTransactions.d.ts +34 -0
- package/dist/entities/IndexerQueries/poolFeeTransactions.d.ts.map +1 -0
- package/dist/entities/IndexerQueries/poolFeeTransactions.js +37 -0
- package/dist/entities/IndexerQueries/poolFeeTransactions.js.map +1 -0
- package/dist/entities/IndexerQueries/poolSnapshots.d.ts +79 -0
- package/dist/entities/IndexerQueries/poolSnapshots.d.ts.map +1 -0
- package/dist/entities/IndexerQueries/poolSnapshots.js +112 -0
- package/dist/entities/IndexerQueries/poolSnapshots.js.map +1 -0
- package/dist/entities/IndexerQueries/trancheCurrencyBalance.d.ts +76 -0
- package/dist/entities/IndexerQueries/trancheCurrencyBalance.d.ts.map +1 -0
- package/dist/entities/IndexerQueries/trancheCurrencyBalance.js +63 -0
- package/dist/entities/IndexerQueries/trancheCurrencyBalance.js.map +1 -0
- package/dist/entities/IndexerQueries/trancheSnapshots.d.ts +70 -0
- package/dist/entities/IndexerQueries/trancheSnapshots.d.ts.map +1 -0
- package/dist/entities/IndexerQueries/trancheSnapshots.js +76 -0
- package/dist/entities/IndexerQueries/trancheSnapshots.js.map +1 -0
- package/dist/entities/Reports/Processor.d.ts +46 -0
- package/dist/entities/Reports/Processor.d.ts.map +1 -0
- package/dist/entities/Reports/Processor.js +471 -0
- 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/entities/Reports/index.d.ts +21 -0
- package/dist/entities/Reports/index.d.ts.map +1 -0
- package/dist/entities/Reports/index.js +144 -0
- package/dist/entities/Reports/index.js.map +1 -0
- package/dist/entities/ShareClass.d.ts +2 -0
- package/dist/entities/ShareClass.d.ts.map +1 -1
- package/dist/entities/ShareClass.js +5 -1
- package/dist/entities/ShareClass.js.map +1 -1
- package/dist/tests/mocks/mockAssetSnapshots.d.ts +3 -0
- package/dist/tests/mocks/mockAssetSnapshots.d.ts.map +1 -0
- package/dist/tests/mocks/mockAssetSnapshots.js +56 -0
- package/dist/tests/mocks/mockAssetSnapshots.js.map +1 -0
- package/dist/tests/mocks/mockAssetTransactions.d.ts +3 -0
- package/dist/tests/mocks/mockAssetTransactions.d.ts.map +1 -0
- package/dist/tests/mocks/mockAssetTransactions.js +86 -0
- package/dist/tests/mocks/mockAssetTransactions.js.map +1 -0
- package/dist/tests/mocks/mockEpochs.d.ts +3 -0
- package/dist/tests/mocks/mockEpochs.d.ts.map +1 -0
- package/dist/tests/mocks/mockEpochs.js +26 -0
- package/dist/tests/mocks/mockEpochs.js.map +1 -0
- package/dist/tests/mocks/mockInvestorCurrencyBalance.d.ts +3 -0
- package/dist/tests/mocks/mockInvestorCurrencyBalance.d.ts.map +1 -0
- package/dist/tests/mocks/mockInvestorCurrencyBalance.js +29 -0
- package/dist/tests/mocks/mockInvestorCurrencyBalance.js.map +1 -0
- package/dist/tests/mocks/mockInvestorTransactions.d.ts +3 -0
- package/dist/tests/mocks/mockInvestorTransactions.d.ts.map +1 -0
- package/dist/tests/mocks/mockInvestorTransactions.js +35 -0
- package/dist/tests/mocks/mockInvestorTransactions.js.map +1 -0
- package/dist/tests/mocks/mockPoolFeeSnapshot.d.ts +3 -0
- package/dist/tests/mocks/mockPoolFeeSnapshot.d.ts.map +1 -0
- package/dist/tests/mocks/mockPoolFeeSnapshot.js +68 -0
- package/dist/tests/mocks/mockPoolFeeSnapshot.js.map +1 -0
- package/dist/tests/mocks/mockPoolFeeTransactions.d.ts +11 -0
- package/dist/tests/mocks/mockPoolFeeTransactions.d.ts.map +1 -0
- package/dist/tests/mocks/mockPoolFeeTransactions.js +20 -0
- package/dist/tests/mocks/mockPoolFeeTransactions.js.map +1 -0
- package/dist/tests/mocks/mockPoolSnapshots.d.ts +3 -0
- package/dist/tests/mocks/mockPoolSnapshots.d.ts.map +1 -0
- package/dist/tests/mocks/mockPoolSnapshots.js +66 -0
- package/dist/tests/mocks/mockPoolSnapshots.js.map +1 -0
- package/dist/tests/mocks/mockTrancheSnapshots.d.ts +3 -0
- package/dist/tests/mocks/mockTrancheSnapshots.d.ts.map +1 -0
- package/dist/tests/mocks/mockTrancheSnapshots.js +112 -0
- package/dist/tests/mocks/mockTrancheSnapshots.js.map +1 -0
- package/dist/types/reports.d.ts +336 -0
- package/dist/types/reports.d.ts.map +1 -0
- package/dist/types/reports.js +2 -0
- package/dist/types/reports.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { Balance } from '../../utils/BigInt.js';
|
|
2
|
+
export function trancheCurrencyBalancePostProcessor(data) {
|
|
3
|
+
const currencyBalancesByAccountId = {};
|
|
4
|
+
data.currencyBalances.nodes.forEach((balance) => {
|
|
5
|
+
const trancheId = balance.currency.trancheId?.split('-')[1] ?? '';
|
|
6
|
+
currencyBalancesByAccountId[`${balance.accountId}-${trancheId}`] = balance;
|
|
7
|
+
});
|
|
8
|
+
return data.trancheBalances.nodes.map((balance) => {
|
|
9
|
+
const currencyDecimals = balance.pool.currency.decimals;
|
|
10
|
+
return {
|
|
11
|
+
accountId: balance.accountId,
|
|
12
|
+
chainId: balance.account?.chainId !== '0' ? Number(balance.account?.chainId) : 'centrifuge',
|
|
13
|
+
trancheId: balance.trancheId.split('-')[1] ?? '',
|
|
14
|
+
evmAddress: balance.account?.evmAddress,
|
|
15
|
+
balance: new Balance(currencyBalancesByAccountId[`${balance.accountId}-${balance.trancheId.split('-')[1]}`]?.amount ?? 0, currencyDecimals),
|
|
16
|
+
pendingInvestCurrency: new Balance(balance.pendingInvestCurrency, currencyDecimals),
|
|
17
|
+
claimableTrancheTokens: new Balance(balance.claimableTrancheTokens, currencyDecimals),
|
|
18
|
+
sumClaimedTrancheTokens: new Balance(balance.sumClaimedTrancheTokens, currencyDecimals),
|
|
19
|
+
pendingRedeemTrancheTokens: new Balance(balance.pendingRedeemTrancheTokens, currencyDecimals),
|
|
20
|
+
claimableCurrency: new Balance(balance.claimableCurrency, currencyDecimals),
|
|
21
|
+
sumClaimedCurrency: new Balance(balance.sumClaimedCurrency, currencyDecimals),
|
|
22
|
+
};
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
export const trancheCurrencyBalanceQuery = `
|
|
26
|
+
query($filterTranches: TrancheBalanceFilter, $filterCurrencies: CurrencyBalanceFilter) {
|
|
27
|
+
trancheBalances(filter: $filterTranches) {
|
|
28
|
+
nodes {
|
|
29
|
+
accountId
|
|
30
|
+
trancheId
|
|
31
|
+
account {
|
|
32
|
+
chainId
|
|
33
|
+
evmAddress
|
|
34
|
+
}
|
|
35
|
+
pool {
|
|
36
|
+
currency {
|
|
37
|
+
decimals
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
pendingInvestCurrency
|
|
41
|
+
claimableTrancheTokens
|
|
42
|
+
sumClaimedTrancheTokens
|
|
43
|
+
pendingRedeemTrancheTokens
|
|
44
|
+
claimableCurrency
|
|
45
|
+
sumClaimedCurrency
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
currencyBalances(filter: $filterCurrencies) {
|
|
49
|
+
nodes {
|
|
50
|
+
accountId
|
|
51
|
+
account {
|
|
52
|
+
chainId
|
|
53
|
+
evmAddress
|
|
54
|
+
}
|
|
55
|
+
currency {
|
|
56
|
+
trancheId
|
|
57
|
+
}
|
|
58
|
+
amount
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
`;
|
|
63
|
+
//# sourceMappingURL=trancheCurrencyBalance.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"trancheCurrencyBalance.js","sourceRoot":"","sources":["../../../src/entities/IndexerQueries/trancheCurrencyBalance.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAA;AAS/C,MAAM,UAAU,mCAAmC,CAAC,IAAwD;IAC1G,MAAM,2BAA2B,GAA6E,EAAE,CAAA;IAChH,IAAK,CAAC,gBAAgB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;QAC/C,MAAM,SAAS,GAAG,OAAO,CAAC,QAAQ,CAAC,SAAS,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAA;QACjE,2BAA2B,CAAC,GAAG,OAAO,CAAC,SAAS,IAAI,SAAS,EAAE,CAAC,GAAG,OAAO,CAAA;IAC5E,CAAC,CAAC,CAAA;IAEF,OAAO,IAAK,CAAC,eAAe,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;QACjD,MAAM,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAA;QACvD,OAAO;YACL,SAAS,EAAE,OAAO,CAAC,SAAS;YAC5B,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,OAAO,KAAK,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,YAAY;YAC3F,SAAS,EAAE,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE;YAChD,UAAU,EAAE,OAAO,CAAC,OAAO,EAAE,UAAU;YACvC,OAAO,EAAE,IAAI,OAAO,CAClB,2BAA2B,CAAC,GAAG,OAAO,CAAC,SAAS,IAAI,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,MAAM,IAAI,CAAC,EACnG,gBAAgB,CACjB;YACD,qBAAqB,EAAE,IAAI,OAAO,CAAC,OAAO,CAAC,qBAAqB,EAAE,gBAAgB,CAAC;YACnF,sBAAsB,EAAE,IAAI,OAAO,CAAC,OAAO,CAAC,sBAAsB,EAAE,gBAAgB,CAAC;YACrF,uBAAuB,EAAE,IAAI,OAAO,CAAC,OAAO,CAAC,uBAAuB,EAAE,gBAAgB,CAAC;YACvF,0BAA0B,EAAE,IAAI,OAAO,CAAC,OAAO,CAAC,0BAA0B,EAAE,gBAAgB,CAAC;YAC7F,iBAAiB,EAAE,IAAI,OAAO,CAAC,OAAO,CAAC,iBAAiB,EAAE,gBAAgB,CAAC;YAC3E,kBAAkB,EAAE,IAAI,OAAO,CAAC,OAAO,CAAC,kBAAkB,EAAE,gBAAgB,CAAC;SAC7C,CAAA;IACpC,CAAC,CAAC,CAAA;AACJ,CAAC;AA8DD,MAAM,CAAC,MAAM,2BAA2B,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAqC1C,CAAA"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { Balance, Perquintill, Price } from '../../utils/BigInt.js';
|
|
2
|
+
export type TrancheSnapshotFilter = Partial<Record<keyof SubqueryTrancheSnapshot['trancheSnapshots']['nodes'][0], any>>;
|
|
3
|
+
export declare const trancheSnapshotsQuery = "\nquery($filter: TrancheSnapshotFilter) {\n trancheSnapshots(\n orderBy: BLOCK_NUMBER_ASC,\n filter: $filter\n) {\n nodes {\n tranche {\n poolId\n trancheId\n pool {\n currency {\n decimals\n symbol\n }\n }\n }\n timestamp\n tokenSupply\n tokenPrice\n sumOutstandingInvestOrdersByPeriod\n sumOutstandingRedeemOrdersByPeriod\n sumFulfilledInvestOrdersByPeriod\n sumFulfilledRedeemOrdersByPeriod\n yield7DaysAnnualized\n yield30DaysAnnualized\n yield90DaysAnnualized\n yieldSinceInception\n yieldMTD\n yieldQTD\n yieldYTD\n yieldSinceLastPeriod\n }\n }\n}\n";
|
|
4
|
+
export type SubqueryTrancheSnapshot = {
|
|
5
|
+
trancheSnapshots: {
|
|
6
|
+
nodes: {
|
|
7
|
+
id: string;
|
|
8
|
+
tokenPrice: string;
|
|
9
|
+
blockNumber: number;
|
|
10
|
+
timestamp: string;
|
|
11
|
+
trancheId: string;
|
|
12
|
+
tranche: {
|
|
13
|
+
poolId: string;
|
|
14
|
+
trancheId: string;
|
|
15
|
+
pool: {
|
|
16
|
+
currency: {
|
|
17
|
+
decimals: number;
|
|
18
|
+
symbol: string;
|
|
19
|
+
};
|
|
20
|
+
};
|
|
21
|
+
};
|
|
22
|
+
tokenSupply: string;
|
|
23
|
+
sumOutstandingInvestOrdersByPeriod: string;
|
|
24
|
+
sumOutstandingRedeemOrdersByPeriod: string;
|
|
25
|
+
sumFulfilledInvestOrdersByPeriod: string;
|
|
26
|
+
sumFulfilledRedeemOrdersByPeriod: string;
|
|
27
|
+
yield7DaysAnnualized: string;
|
|
28
|
+
yield30DaysAnnualized: string;
|
|
29
|
+
yield90DaysAnnualized: string;
|
|
30
|
+
yieldSinceInception: string;
|
|
31
|
+
yieldMTD: string;
|
|
32
|
+
yieldQTD: string;
|
|
33
|
+
yieldYTD: string;
|
|
34
|
+
yieldSinceLastPeriod: string;
|
|
35
|
+
}[];
|
|
36
|
+
};
|
|
37
|
+
};
|
|
38
|
+
export type TrancheSnapshot = {
|
|
39
|
+
id: string;
|
|
40
|
+
price: Price;
|
|
41
|
+
timestamp: string;
|
|
42
|
+
trancheId: string;
|
|
43
|
+
poolId: string;
|
|
44
|
+
tokenSupply: Balance;
|
|
45
|
+
pool: {
|
|
46
|
+
currency: {
|
|
47
|
+
decimals: number;
|
|
48
|
+
symbol: string;
|
|
49
|
+
};
|
|
50
|
+
};
|
|
51
|
+
outstandingInvestOrders: Balance;
|
|
52
|
+
outstandingRedeemOrders: Balance;
|
|
53
|
+
fulfilledInvestOrders: Balance;
|
|
54
|
+
fulfilledRedeemOrders: Balance;
|
|
55
|
+
yield7DaysAnnualized: Perquintill | null;
|
|
56
|
+
yield30DaysAnnualized: Perquintill | null;
|
|
57
|
+
yield90DaysAnnualized: Perquintill | null;
|
|
58
|
+
yieldSinceInception: Perquintill;
|
|
59
|
+
yieldMTD: Perquintill | null;
|
|
60
|
+
yieldQTD: Perquintill | null;
|
|
61
|
+
yieldYTD: Perquintill | null;
|
|
62
|
+
yieldSinceLastPeriod: Perquintill | null;
|
|
63
|
+
};
|
|
64
|
+
export type TrancheSnapshotsByDate = {
|
|
65
|
+
[timestamp: string]: TrancheSnapshot[];
|
|
66
|
+
};
|
|
67
|
+
export declare function trancheSnapshotsPostProcess(data: SubqueryTrancheSnapshot): {
|
|
68
|
+
[date: string]: TrancheSnapshot[];
|
|
69
|
+
};
|
|
70
|
+
//# sourceMappingURL=trancheSnapshots.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"trancheSnapshots.d.ts","sourceRoot":"","sources":["../../../src/entities/IndexerQueries/trancheSnapshots.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAA;AAGnE,MAAM,MAAM,qBAAqB,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,uBAAuB,CAAC,kBAAkB,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAA;AAEvH,eAAO,MAAM,qBAAqB,utBAmCjC,CAAA;AACD,MAAM,MAAM,uBAAuB,GAAG;IACpC,gBAAgB,EAAE;QAChB,KAAK,EAAE;YACL,EAAE,EAAE,MAAM,CAAA;YACV,UAAU,EAAE,MAAM,CAAA;YAClB,WAAW,EAAE,MAAM,CAAA;YACnB,SAAS,EAAE,MAAM,CAAA;YACjB,SAAS,EAAE,MAAM,CAAA;YACjB,OAAO,EAAE;gBACP,MAAM,EAAE,MAAM,CAAA;gBACd,SAAS,EAAE,MAAM,CAAA;gBACjB,IAAI,EAAE;oBACJ,QAAQ,EAAE;wBACR,QAAQ,EAAE,MAAM,CAAA;wBAChB,MAAM,EAAE,MAAM,CAAA;qBACf,CAAA;iBACF,CAAA;aACF,CAAA;YACD,WAAW,EAAE,MAAM,CAAA;YACnB,kCAAkC,EAAE,MAAM,CAAA;YAC1C,kCAAkC,EAAE,MAAM,CAAA;YAC1C,gCAAgC,EAAE,MAAM,CAAA;YACxC,gCAAgC,EAAE,MAAM,CAAA;YACxC,oBAAoB,EAAE,MAAM,CAAA;YAC5B,qBAAqB,EAAE,MAAM,CAAA;YAC7B,qBAAqB,EAAE,MAAM,CAAA;YAC7B,mBAAmB,EAAE,MAAM,CAAA;YAC3B,QAAQ,EAAE,MAAM,CAAA;YAChB,QAAQ,EAAE,MAAM,CAAA;YAChB,QAAQ,EAAE,MAAM,CAAA;YAChB,oBAAoB,EAAE,MAAM,CAAA;SAC7B,EAAE,CAAA;KACJ,CAAA;CACF,CAAA;AAED,MAAM,MAAM,eAAe,GAAG;IAC5B,EAAE,EAAE,MAAM,CAAA;IACV,KAAK,EAAE,KAAK,CAAA;IACZ,SAAS,EAAE,MAAM,CAAA;IACjB,SAAS,EAAE,MAAM,CAAA;IACjB,MAAM,EAAE,MAAM,CAAA;IACd,WAAW,EAAE,OAAO,CAAA;IACpB,IAAI,EAAE;QACJ,QAAQ,EAAE;YACR,QAAQ,EAAE,MAAM,CAAA;YAChB,MAAM,EAAE,MAAM,CAAA;SACf,CAAA;KACF,CAAA;IACD,uBAAuB,EAAE,OAAO,CAAA;IAChC,uBAAuB,EAAE,OAAO,CAAA;IAChC,qBAAqB,EAAE,OAAO,CAAA;IAC9B,qBAAqB,EAAE,OAAO,CAAA;IAC9B,oBAAoB,EAAE,WAAW,GAAG,IAAI,CAAA;IACxC,qBAAqB,EAAE,WAAW,GAAG,IAAI,CAAA;IACzC,qBAAqB,EAAE,WAAW,GAAG,IAAI,CAAA;IACzC,mBAAmB,EAAE,WAAW,CAAA;IAChC,QAAQ,EAAE,WAAW,GAAG,IAAI,CAAA;IAC5B,QAAQ,EAAE,WAAW,GAAG,IAAI,CAAA;IAC5B,QAAQ,EAAE,WAAW,GAAG,IAAI,CAAA;IAC5B,oBAAoB,EAAE,WAAW,GAAG,IAAI,CAAA;CACzC,CAAA;AAED,MAAM,MAAM,sBAAsB,GAAG;IACnC,CAAC,SAAS,EAAE,MAAM,GAAG,eAAe,EAAE,CAAA;CACvC,CAAA;AAED,wBAAgB,2BAA2B,CAAC,IAAI,EAAE,uBAAuB,GAAG;IAAE,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe,EAAE,CAAA;CAAE,CAyChH"}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { Balance, Perquintill, Price } from '../../utils/BigInt.js';
|
|
2
|
+
export const trancheSnapshotsQuery = `
|
|
3
|
+
query($filter: TrancheSnapshotFilter) {
|
|
4
|
+
trancheSnapshots(
|
|
5
|
+
orderBy: BLOCK_NUMBER_ASC,
|
|
6
|
+
filter: $filter
|
|
7
|
+
) {
|
|
8
|
+
nodes {
|
|
9
|
+
tranche {
|
|
10
|
+
poolId
|
|
11
|
+
trancheId
|
|
12
|
+
pool {
|
|
13
|
+
currency {
|
|
14
|
+
decimals
|
|
15
|
+
symbol
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
timestamp
|
|
20
|
+
tokenSupply
|
|
21
|
+
tokenPrice
|
|
22
|
+
sumOutstandingInvestOrdersByPeriod
|
|
23
|
+
sumOutstandingRedeemOrdersByPeriod
|
|
24
|
+
sumFulfilledInvestOrdersByPeriod
|
|
25
|
+
sumFulfilledRedeemOrdersByPeriod
|
|
26
|
+
yield7DaysAnnualized
|
|
27
|
+
yield30DaysAnnualized
|
|
28
|
+
yield90DaysAnnualized
|
|
29
|
+
yieldSinceInception
|
|
30
|
+
yieldMTD
|
|
31
|
+
yieldQTD
|
|
32
|
+
yieldYTD
|
|
33
|
+
yieldSinceLastPeriod
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
`;
|
|
38
|
+
export function trancheSnapshotsPostProcess(data) {
|
|
39
|
+
const tranchesByDate = {};
|
|
40
|
+
data?.trancheSnapshots?.nodes?.forEach((tranche) => {
|
|
41
|
+
const date = tranche.timestamp.slice(0, 10);
|
|
42
|
+
if (!tranchesByDate[date]) {
|
|
43
|
+
tranchesByDate[date] = [];
|
|
44
|
+
}
|
|
45
|
+
const poolCurrency = tranche.tranche.pool.currency;
|
|
46
|
+
const trancheSnapshot = {
|
|
47
|
+
id: tranche.trancheId,
|
|
48
|
+
timestamp: tranche.timestamp,
|
|
49
|
+
poolId: tranche.tranche.poolId,
|
|
50
|
+
trancheId: tranche.tranche.trancheId,
|
|
51
|
+
pool: {
|
|
52
|
+
currency: {
|
|
53
|
+
decimals: poolCurrency.decimals,
|
|
54
|
+
symbol: poolCurrency.symbol,
|
|
55
|
+
},
|
|
56
|
+
},
|
|
57
|
+
price: new Price(tranche.tokenPrice ?? 0),
|
|
58
|
+
tokenSupply: new Balance(tranche.tokenSupply, poolCurrency.decimals),
|
|
59
|
+
fulfilledInvestOrders: new Balance(tranche.sumFulfilledInvestOrdersByPeriod, poolCurrency.decimals),
|
|
60
|
+
fulfilledRedeemOrders: new Balance(tranche.sumFulfilledRedeemOrdersByPeriod, poolCurrency.decimals),
|
|
61
|
+
outstandingInvestOrders: new Balance(tranche.sumOutstandingInvestOrdersByPeriod, poolCurrency.decimals),
|
|
62
|
+
outstandingRedeemOrders: new Balance(tranche.sumOutstandingRedeemOrdersByPeriod, poolCurrency.decimals),
|
|
63
|
+
yield7DaysAnnualized: new Perquintill(tranche.yield7DaysAnnualized ?? 0),
|
|
64
|
+
yield30DaysAnnualized: new Perquintill(tranche.yield30DaysAnnualized ?? 0),
|
|
65
|
+
yield90DaysAnnualized: new Perquintill(tranche.yield90DaysAnnualized ?? 0),
|
|
66
|
+
yieldSinceInception: new Perquintill(tranche.yieldSinceInception ?? 0),
|
|
67
|
+
yieldMTD: new Perquintill(tranche.yieldMTD ?? 0),
|
|
68
|
+
yieldQTD: new Perquintill(tranche.yieldQTD ?? 0),
|
|
69
|
+
yieldYTD: new Perquintill(tranche.yieldYTD ?? 0),
|
|
70
|
+
yieldSinceLastPeriod: new Perquintill(tranche.yieldSinceLastPeriod ?? 0),
|
|
71
|
+
};
|
|
72
|
+
tranchesByDate[date].push(trancheSnapshot);
|
|
73
|
+
});
|
|
74
|
+
return tranchesByDate;
|
|
75
|
+
}
|
|
76
|
+
//# sourceMappingURL=trancheSnapshots.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"trancheSnapshots.js","sourceRoot":"","sources":["../../../src/entities/IndexerQueries/trancheSnapshots.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAA;AAKnE,MAAM,CAAC,MAAM,qBAAqB,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAmCpC,CAAA;AAmED,MAAM,UAAU,2BAA2B,CAAC,IAA6B;IACvE,MAAM,cAAc,GAA2B,EAAE,CAAA;IAEjD,IAAI,EAAE,gBAAgB,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;QACjD,MAAM,IAAI,GAAG,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAA;QAC3C,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,CAAC;YAC1B,cAAc,CAAC,IAAI,CAAC,GAAG,EAAE,CAAA;QAC3B,CAAC;QAED,MAAM,YAAY,GAAG,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAA;QAClD,MAAM,eAAe,GAAoB;YACvC,EAAE,EAAE,OAAO,CAAC,SAAS;YACrB,SAAS,EAAE,OAAO,CAAC,SAAS;YAC5B,MAAM,EAAE,OAAO,CAAC,OAAO,CAAC,MAAM;YAC9B,SAAS,EAAE,OAAO,CAAC,OAAO,CAAC,SAAS;YACpC,IAAI,EAAE;gBACJ,QAAQ,EAAE;oBACR,QAAQ,EAAE,YAAY,CAAC,QAAQ;oBAC/B,MAAM,EAAE,YAAY,CAAC,MAAM;iBAC5B;aACF;YACD,KAAK,EAAE,IAAI,KAAK,CAAC,OAAO,CAAC,UAAU,IAAI,CAAC,CAAC;YACzC,WAAW,EAAE,IAAI,OAAO,CAAC,OAAO,CAAC,WAAW,EAAE,YAAY,CAAC,QAAQ,CAAC;YACpE,qBAAqB,EAAE,IAAI,OAAO,CAAC,OAAO,CAAC,gCAAgC,EAAE,YAAY,CAAC,QAAQ,CAAC;YACnG,qBAAqB,EAAE,IAAI,OAAO,CAAC,OAAO,CAAC,gCAAgC,EAAE,YAAY,CAAC,QAAQ,CAAC;YACnG,uBAAuB,EAAE,IAAI,OAAO,CAAC,OAAO,CAAC,kCAAkC,EAAE,YAAY,CAAC,QAAQ,CAAC;YACvG,uBAAuB,EAAE,IAAI,OAAO,CAAC,OAAO,CAAC,kCAAkC,EAAE,YAAY,CAAC,QAAQ,CAAC;YACvG,oBAAoB,EAAE,IAAI,WAAW,CAAC,OAAO,CAAC,oBAAoB,IAAI,CAAC,CAAC;YACxE,qBAAqB,EAAE,IAAI,WAAW,CAAC,OAAO,CAAC,qBAAqB,IAAI,CAAC,CAAC;YAC1E,qBAAqB,EAAE,IAAI,WAAW,CAAC,OAAO,CAAC,qBAAqB,IAAI,CAAC,CAAC;YAC1E,mBAAmB,EAAE,IAAI,WAAW,CAAC,OAAO,CAAC,mBAAmB,IAAI,CAAC,CAAC;YACtE,QAAQ,EAAE,IAAI,WAAW,CAAC,OAAO,CAAC,QAAQ,IAAI,CAAC,CAAC;YAChD,QAAQ,EAAE,IAAI,WAAW,CAAC,OAAO,CAAC,QAAQ,IAAI,CAAC,CAAC;YAChD,QAAQ,EAAE,IAAI,WAAW,CAAC,OAAO,CAAC,QAAQ,IAAI,CAAC,CAAC;YAChD,oBAAoB,EAAE,IAAI,WAAW,CAAC,OAAO,CAAC,oBAAoB,IAAI,CAAC,CAAC;SACzE,CAAA;QAED,cAAc,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAA;IAC5C,CAAC,CAAC,CAAA;IAEF,OAAO,cAAc,CAAA;AACvB,CAAC"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { AssetListData, AssetListReport, AssetListReportFilter, AssetTimeSeriesData, AssetTimeSeriesReport, AssetTimeSeriesReportFilter, AssetTransactionReport, AssetTransactionReportFilter, AssetTransactionsData, BalanceSheetData, BalanceSheetReport, CashflowData, CashflowReport, FeeTransactionReport, FeeTransactionReportFilter, FeeTransactionsData, InvestorListData, InvestorListReport, InvestorListReportFilter, InvestorTransactionsData, InvestorTransactionsReport, InvestorTransactionsReportFilter, OrdersListData, OrdersListReport, ProfitAndLossData, ProfitAndLossReport, ReportFilter, TokenPriceData, TokenPriceReport, TokenPriceReportFilter } from '../../types/reports.js';
|
|
2
|
+
export declare class Processor {
|
|
3
|
+
/**
|
|
4
|
+
* Process raw data into a balance sheet report
|
|
5
|
+
* @param data Pool and tranche snapshot data
|
|
6
|
+
* @param filter Optional filtering and grouping options
|
|
7
|
+
* @returns Processed balance sheet report at the end of each period
|
|
8
|
+
*/
|
|
9
|
+
balanceSheet(data: BalanceSheetData, filter?: Omit<ReportFilter, 'to' | 'from'>): BalanceSheetReport[];
|
|
10
|
+
/**
|
|
11
|
+
* Process raw data into an aggregated cashflow report, fees and endCashBalance are NOT aggregated by period
|
|
12
|
+
* @param data Pool snapshot data
|
|
13
|
+
* @param filter Optional filtering and grouping options
|
|
14
|
+
* @returns Processed cashflow report at the end of each period
|
|
15
|
+
*/
|
|
16
|
+
cashflow(data: CashflowData, filter?: Omit<ReportFilter, 'to' | 'from'>): CashflowReport[];
|
|
17
|
+
/**
|
|
18
|
+
* Process raw data into an aggregated profit and loss report, fees and endCashBalance are NOT aggregated by period
|
|
19
|
+
* @param data Pool snapshot data
|
|
20
|
+
* @param filter Optional filtering and grouping options
|
|
21
|
+
* @returns Processed profit and loss report at the end of each period
|
|
22
|
+
*/
|
|
23
|
+
profitAndLoss(data: ProfitAndLossData, filter?: Omit<ReportFilter, 'to' | 'from'>): ProfitAndLossReport[];
|
|
24
|
+
investorTransactions(data: InvestorTransactionsData, filter?: Omit<InvestorTransactionsReportFilter, 'to' | 'from'>): InvestorTransactionsReport[];
|
|
25
|
+
assetTransactions(data: AssetTransactionsData, filter?: Omit<AssetTransactionReportFilter, 'to' | 'from'>): AssetTransactionReport[];
|
|
26
|
+
feeTransactions(data: FeeTransactionsData, filter?: Omit<FeeTransactionReportFilter, 'to' | 'from'>): FeeTransactionReport[];
|
|
27
|
+
tokenPrice(data: TokenPriceData, filter?: Omit<TokenPriceReportFilter, 'to' | 'from'>): TokenPriceReport[];
|
|
28
|
+
assetList(data: AssetListData, filter?: Omit<AssetListReportFilter, 'to' | 'from'>): AssetListReport[];
|
|
29
|
+
investorList(data: InvestorListData, filter?: Omit<InvestorListReportFilter, 'to' | 'from'>): InvestorListReport[];
|
|
30
|
+
ordersList(data: OrdersListData): OrdersListReport[];
|
|
31
|
+
assetTimeSeries(data: AssetTimeSeriesData, filter?: Omit<AssetTimeSeriesReportFilter, 'to' | 'from'>): AssetTimeSeriesReport[];
|
|
32
|
+
/**
|
|
33
|
+
* Apply grouping to a report.
|
|
34
|
+
* @param items Report items
|
|
35
|
+
* @param filter Optional filtering and grouping options
|
|
36
|
+
* @param strategy Grouping strategy, sum aggregates data by period, latest returns the latest item in the period
|
|
37
|
+
* @returns Grouped report
|
|
38
|
+
*
|
|
39
|
+
* Note: if strategy is 'sum', only Decimal values that are not nested are aggregated, all
|
|
40
|
+
* other values are overwritten with the last value in the period
|
|
41
|
+
*/
|
|
42
|
+
private applyGrouping;
|
|
43
|
+
private getDateKey;
|
|
44
|
+
}
|
|
45
|
+
export declare const processor: Processor;
|
|
46
|
+
//# sourceMappingURL=Processor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Processor.d.ts","sourceRoot":"","sources":["../../../src/entities/Reports/Processor.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,aAAa,EACb,eAAe,EACf,qBAAqB,EAGrB,mBAAmB,EACnB,qBAAqB,EACrB,2BAA2B,EAC3B,sBAAsB,EACtB,4BAA4B,EAC5B,qBAAqB,EACrB,gBAAgB,EAChB,kBAAkB,EAClB,YAAY,EACZ,cAAc,EACd,oBAAoB,EACpB,0BAA0B,EAC1B,mBAAmB,EACnB,gBAAgB,EAChB,kBAAkB,EAClB,wBAAwB,EACxB,wBAAwB,EACxB,0BAA0B,EAC1B,gCAAgC,EAChC,cAAc,EACd,gBAAgB,EAChB,iBAAiB,EACjB,mBAAmB,EACnB,YAAY,EACZ,cAAc,EACd,gBAAgB,EAChB,sBAAsB,EACvB,MAAM,wBAAwB,CAAA;AAO/B,qBAAa,SAAS;IACpB;;;;;OAKG;IACH,YAAY,CAAC,IAAI,EAAE,gBAAgB,EAAE,MAAM,CAAC,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,GAAG,MAAM,CAAC,GAAG,kBAAkB,EAAE;IA2CtG;;;;;OAKG;IACH,QAAQ,CAAC,IAAI,EAAE,YAAY,EAAE,MAAM,CAAC,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,GAAG,MAAM,CAAC,GAAG,cAAc,EAAE;IA+C1F;;;;;OAKG;IACH,aAAa,CAAC,IAAI,EAAE,iBAAiB,EAAE,MAAM,CAAC,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,GAAG,MAAM,CAAC,GAAG,mBAAmB,EAAE;IA+CzG,oBAAoB,CAClB,IAAI,EAAE,wBAAwB,EAC9B,MAAM,CAAC,EAAE,IAAI,CAAC,gCAAgC,EAAE,IAAI,GAAG,MAAM,CAAC,GAC7D,0BAA0B,EAAE;IAuD/B,iBAAiB,CACf,IAAI,EAAE,qBAAqB,EAC3B,MAAM,CAAC,EAAE,IAAI,CAAC,4BAA4B,EAAE,IAAI,GAAG,MAAM,CAAC,GACzD,sBAAsB,EAAE;IAmD3B,eAAe,CACb,IAAI,EAAE,mBAAmB,EACzB,MAAM,CAAC,EAAE,IAAI,CAAC,0BAA0B,EAAE,IAAI,GAAG,MAAM,CAAC,GACvD,oBAAoB,EAAE;IA+BzB,UAAU,CAAC,IAAI,EAAE,cAAc,EAAE,MAAM,CAAC,EAAE,IAAI,CAAC,sBAAsB,EAAE,IAAI,GAAG,MAAM,CAAC,GAAG,gBAAgB,EAAE;IAuB1G,SAAS,CAAC,IAAI,EAAE,aAAa,EAAE,MAAM,CAAC,EAAE,IAAI,CAAC,qBAAqB,EAAE,IAAI,GAAG,MAAM,CAAC,GAAG,eAAe,EAAE;IAuEtG,YAAY,CAAC,IAAI,EAAE,gBAAgB,EAAE,MAAM,CAAC,EAAE,IAAI,CAAC,wBAAwB,EAAE,IAAI,GAAG,MAAM,CAAC,GAAG,kBAAkB,EAAE;IA0ClH,UAAU,CAAC,IAAI,EAAE,cAAc,GAAG,gBAAgB,EAAE;IAoBpD,eAAe,CACb,IAAI,EAAE,mBAAmB,EACzB,MAAM,CAAC,EAAE,IAAI,CAAC,2BAA2B,EAAE,IAAI,GAAG,MAAM,CAAC,GACxD,qBAAqB,EAAE;IAsB1B;;;;;;;;;OASG;IACH,OAAO,CAAC,aAAa;IAkCrB,OAAO,CAAC,UAAU;CAcnB;AAED,eAAO,MAAM,SAAS,WAAkB,CAAA"}
|