@centrifuge/sdk 1.8.6 → 1.9.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/dist/entities/Reports/PoolReports.d.ts +2 -0
- package/dist/entities/Reports/PoolReports.d.ts.map +1 -1
- package/dist/entities/Reports/PoolReports.js +4 -0
- package/dist/entities/Reports/PoolReports.js.map +1 -1
- package/dist/entities/Reports/PoolShareYieldsReport.d.ts +73 -0
- package/dist/entities/Reports/PoolShareYieldsReport.d.ts.map +1 -0
- package/dist/entities/Reports/PoolShareYieldsReport.js +111 -0
- package/dist/entities/Reports/PoolShareYieldsReport.js.map +1 -0
- package/dist/entities/Reports/PoolShareYieldsReport.test.d.ts +2 -0
- package/dist/entities/Reports/PoolShareYieldsReport.test.d.ts.map +1 -0
- package/dist/entities/Reports/PoolShareYieldsReport.test.js +129 -0
- package/dist/entities/Reports/PoolShareYieldsReport.test.js.map +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
import { Entity } from '../Entity.js';
|
|
2
2
|
import { Pool } from '../Pool.js';
|
|
3
|
+
import { ShareYieldsReportFilter } from './PoolShareYieldsReport.js';
|
|
3
4
|
import { SharePricesReportFilter } from './PoolSharePricesReport.js';
|
|
4
5
|
export declare class PoolReports extends Entity {
|
|
5
6
|
pool: Pool;
|
|
6
7
|
sharePrices(filter?: SharePricesReportFilter): import("../../index.js").Query<import("./PoolSharePricesReport.js").SharePricesReport>;
|
|
8
|
+
shareYields(filter?: ShareYieldsReportFilter): import("../../index.js").Query<import("./PoolShareYieldsReport.js").ShareYieldsReport>;
|
|
7
9
|
}
|
|
8
10
|
//# sourceMappingURL=PoolReports.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PoolReports.d.ts","sourceRoot":"","sources":["../../../src/entities/Reports/PoolReports.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AACrC,OAAO,EAAE,IAAI,EAAE,MAAM,YAAY,CAAA;AACjC,OAAO,EAAyB,uBAAuB,EAAE,MAAM,4BAA4B,CAAA;AAE3F,qBAAa,WAAY,SAAQ,MAAM;IAI5B,IAAI,EAAE,IAAI;IAKnB,WAAW,CAAC,MAAM,CAAC,EAAE,uBAAuB;CAG7C"}
|
|
1
|
+
{"version":3,"file":"PoolReports.d.ts","sourceRoot":"","sources":["../../../src/entities/Reports/PoolReports.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AACrC,OAAO,EAAE,IAAI,EAAE,MAAM,YAAY,CAAA;AACjC,OAAO,EAAyB,uBAAuB,EAAE,MAAM,4BAA4B,CAAA;AAC3F,OAAO,EAAyB,uBAAuB,EAAE,MAAM,4BAA4B,CAAA;AAE3F,qBAAa,WAAY,SAAQ,MAAM;IAI5B,IAAI,EAAE,IAAI;IAKnB,WAAW,CAAC,MAAM,CAAC,EAAE,uBAAuB;IAI5C,WAAW,CAAC,MAAM,CAAC,EAAE,uBAAuB;CAG7C"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { Entity } from '../Entity.js';
|
|
2
|
+
import { PoolShareYieldsReport } from './PoolShareYieldsReport.js';
|
|
2
3
|
import { PoolSharePricesReport } from './PoolSharePricesReport.js';
|
|
3
4
|
export class PoolReports extends Entity {
|
|
4
5
|
pool;
|
|
@@ -10,5 +11,8 @@ export class PoolReports extends Entity {
|
|
|
10
11
|
sharePrices(filter) {
|
|
11
12
|
return new PoolSharePricesReport(this._root, this).report(filter);
|
|
12
13
|
}
|
|
14
|
+
shareYields(filter) {
|
|
15
|
+
return new PoolShareYieldsReport(this._root, this).report(filter);
|
|
16
|
+
}
|
|
13
17
|
}
|
|
14
18
|
//# sourceMappingURL=PoolReports.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PoolReports.js","sourceRoot":"","sources":["../../../src/entities/Reports/PoolReports.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AAErC,OAAO,EAAE,qBAAqB,EAA2B,MAAM,4BAA4B,CAAA;AAE3F,MAAM,OAAO,WAAY,SAAQ,MAAM;IAI5B;IAHT,gBAAgB;IAChB,YACE,UAAsB,EACf,IAAU;QAEjB,KAAK,CAAC,UAAU,EAAE,CAAC,aAAa,EAAE,IAAI,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAA;QAF/C,SAAI,GAAJ,IAAI,CAAM;IAGnB,CAAC;IAED,WAAW,CAAC,MAAgC;QAC1C,OAAO,IAAI,qBAAqB,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IACnE,CAAC;CACF"}
|
|
1
|
+
{"version":3,"file":"PoolReports.js","sourceRoot":"","sources":["../../../src/entities/Reports/PoolReports.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AAErC,OAAO,EAAE,qBAAqB,EAA2B,MAAM,4BAA4B,CAAA;AAC3F,OAAO,EAAE,qBAAqB,EAA2B,MAAM,4BAA4B,CAAA;AAE3F,MAAM,OAAO,WAAY,SAAQ,MAAM;IAI5B;IAHT,gBAAgB;IAChB,YACE,UAAsB,EACf,IAAU;QAEjB,KAAK,CAAC,UAAU,EAAE,CAAC,aAAa,EAAE,IAAI,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAA;QAF/C,SAAI,GAAJ,IAAI,CAAM;IAGnB,CAAC;IAED,WAAW,CAAC,MAAgC;QAC1C,OAAO,IAAI,qBAAqB,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IACnE,CAAC;IAED,WAAW,CAAC,MAAgC;QAC1C,OAAO,IAAI,qBAAqB,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IACnE,CAAC;CACF"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { Centrifuge } from '../../Centrifuge.js';
|
|
2
|
+
import { HexString } from '../../types/index.js';
|
|
3
|
+
import { DecimalJsType } from '../../utils/decimal.js';
|
|
4
|
+
import { ShareClassId } from '../../utils/types.js';
|
|
5
|
+
import { Entity } from '../Entity.js';
|
|
6
|
+
import { Pool } from '../Pool.js';
|
|
7
|
+
import { PoolReports } from './PoolReports.js';
|
|
8
|
+
import { DataReportFilter } from './types.js';
|
|
9
|
+
/**
|
|
10
|
+
* Per-snapshot yield/return figures returned by the indexer.
|
|
11
|
+
*
|
|
12
|
+
* Naming matches the underlying indexer columns. Values are expressed as
|
|
13
|
+
* percentages (e.g. `5.5` = 5.5%). Fields are optional because the indexer
|
|
14
|
+
* may not have a value yet for the corresponding window (e.g. `yield90d`
|
|
15
|
+
* before the share class has 90 days of price history).
|
|
16
|
+
*
|
|
17
|
+
* Window encoding:
|
|
18
|
+
* - `yield{N}d` — simple total return over the trailing N days.
|
|
19
|
+
* - `yield{N}d360` — same window, annualized using a 360-day basis.
|
|
20
|
+
* - `yield{N}d365` — same window, annualized using a 365-day basis.
|
|
21
|
+
* - `yield30dComp*` — 30-day compounded variants (annualized).
|
|
22
|
+
*
|
|
23
|
+
* `yieldTtm` is the trailing ~365 day simple return, `yieldSinceInception`
|
|
24
|
+
* is from the first usable price, and `yieldYtd` is year-to-date (UTC).
|
|
25
|
+
*/
|
|
26
|
+
export type ShareYields = {
|
|
27
|
+
yield1d?: DecimalJsType;
|
|
28
|
+
yield1d360?: DecimalJsType;
|
|
29
|
+
yield1d365?: DecimalJsType;
|
|
30
|
+
yield7d?: DecimalJsType;
|
|
31
|
+
yield7d360?: DecimalJsType;
|
|
32
|
+
yield7d365?: DecimalJsType;
|
|
33
|
+
yield15d?: DecimalJsType;
|
|
34
|
+
yield15d360?: DecimalJsType;
|
|
35
|
+
yield15d365?: DecimalJsType;
|
|
36
|
+
yield30d?: DecimalJsType;
|
|
37
|
+
yield30d360?: DecimalJsType;
|
|
38
|
+
yield30d365?: DecimalJsType;
|
|
39
|
+
yield90d?: DecimalJsType;
|
|
40
|
+
yield90d360?: DecimalJsType;
|
|
41
|
+
yield90d365?: DecimalJsType;
|
|
42
|
+
yield180d?: DecimalJsType;
|
|
43
|
+
yield180d360?: DecimalJsType;
|
|
44
|
+
yield180d365?: DecimalJsType;
|
|
45
|
+
yield30dComp360?: DecimalJsType;
|
|
46
|
+
yield30dComp365?: DecimalJsType;
|
|
47
|
+
yieldTtm?: DecimalJsType;
|
|
48
|
+
yieldSinceInception?: DecimalJsType;
|
|
49
|
+
yieldYtd?: DecimalJsType;
|
|
50
|
+
};
|
|
51
|
+
export type ShareYieldsReport = {
|
|
52
|
+
timestamp: string;
|
|
53
|
+
shareClasses: Record<HexString, ShareYields>;
|
|
54
|
+
}[];
|
|
55
|
+
export type ShareYieldsReportFilter = DataReportFilter & {
|
|
56
|
+
shareClassId?: ShareClassId;
|
|
57
|
+
};
|
|
58
|
+
export declare class PoolShareYieldsReport extends Entity {
|
|
59
|
+
poolReports: PoolReports;
|
|
60
|
+
pool: Pool;
|
|
61
|
+
constructor(centrifuge: Centrifuge, poolReports: PoolReports);
|
|
62
|
+
/**
|
|
63
|
+
* Get the per-day share-class yields report for a pool.
|
|
64
|
+
*
|
|
65
|
+
* Yields live on the share-class-level `token_snapshot` entity (not the
|
|
66
|
+
* per-network `token_instance_snapshot` consumed by `sharePrices`), and are
|
|
67
|
+
* populated on price-update events (`UpdatePricePoolPerShare`,
|
|
68
|
+
* `UpdateShareClass`) rather than on `NewPeriod` snapshots. The
|
|
69
|
+
* `(date, shareClassId)` dedupe keeps the latest snapshot per day.
|
|
70
|
+
*/
|
|
71
|
+
report(filter?: ShareYieldsReportFilter): import("../../index.js").Query<ShareYieldsReport>;
|
|
72
|
+
}
|
|
73
|
+
//# sourceMappingURL=PoolShareYieldsReport.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PoolShareYieldsReport.d.ts","sourceRoot":"","sources":["../../../src/entities/Reports/PoolShareYieldsReport.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAA;AAChD,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAA;AAEhD,OAAO,EAAO,aAAa,EAAE,MAAM,wBAAwB,CAAA;AAC3D,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAA;AACnD,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AACrC,OAAO,EAAE,IAAI,EAAE,MAAM,YAAY,CAAA;AACjC,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAC9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAA;AAG7C;;;;;;;;;;;;;;;;GAgBG;AACH,MAAM,MAAM,WAAW,GAAG;IACxB,OAAO,CAAC,EAAE,aAAa,CAAA;IACvB,UAAU,CAAC,EAAE,aAAa,CAAA;IAC1B,UAAU,CAAC,EAAE,aAAa,CAAA;IAC1B,OAAO,CAAC,EAAE,aAAa,CAAA;IACvB,UAAU,CAAC,EAAE,aAAa,CAAA;IAC1B,UAAU,CAAC,EAAE,aAAa,CAAA;IAC1B,QAAQ,CAAC,EAAE,aAAa,CAAA;IACxB,WAAW,CAAC,EAAE,aAAa,CAAA;IAC3B,WAAW,CAAC,EAAE,aAAa,CAAA;IAC3B,QAAQ,CAAC,EAAE,aAAa,CAAA;IACxB,WAAW,CAAC,EAAE,aAAa,CAAA;IAC3B,WAAW,CAAC,EAAE,aAAa,CAAA;IAC3B,QAAQ,CAAC,EAAE,aAAa,CAAA;IACxB,WAAW,CAAC,EAAE,aAAa,CAAA;IAC3B,WAAW,CAAC,EAAE,aAAa,CAAA;IAC3B,SAAS,CAAC,EAAE,aAAa,CAAA;IACzB,YAAY,CAAC,EAAE,aAAa,CAAA;IAC5B,YAAY,CAAC,EAAE,aAAa,CAAA;IAC5B,eAAe,CAAC,EAAE,aAAa,CAAA;IAC/B,eAAe,CAAC,EAAE,aAAa,CAAA;IAC/B,QAAQ,CAAC,EAAE,aAAa,CAAA;IACxB,mBAAmB,CAAC,EAAE,aAAa,CAAA;IACnC,QAAQ,CAAC,EAAE,aAAa,CAAA;CACzB,CAAA;AAED,MAAM,MAAM,iBAAiB,GAAG;IAC9B,SAAS,EAAE,MAAM,CAAA;IACjB,YAAY,EAAE,MAAM,CAAC,SAAS,EAAE,WAAW,CAAC,CAAA;CAC7C,EAAE,CAAA;AAEH,MAAM,MAAM,uBAAuB,GAAG,gBAAgB,GAAG;IACvD,YAAY,CAAC,EAAE,YAAY,CAAA;CAC5B,CAAA;AAmDD,qBAAa,qBAAsB,SAAQ,MAAM;IAItC,WAAW,EAAE,WAAW;IAH1B,IAAI,EAAE,IAAI,CAAA;gBAEf,UAAU,EAAE,UAAU,EACf,WAAW,EAAE,WAAW;IAMjC;;;;;;;;OAQG;IACH,MAAM,CAAC,MAAM,GAAE,uBAA4B;CAgE5C"}
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
import { map, switchMap } from 'rxjs';
|
|
2
|
+
import { Dec } from '../../utils/decimal.js';
|
|
3
|
+
import { Entity } from '../Entity.js';
|
|
4
|
+
import { applyGrouping } from './utils.js';
|
|
5
|
+
const YIELD_FIELDS = [
|
|
6
|
+
'yield1d',
|
|
7
|
+
'yield1d360',
|
|
8
|
+
'yield1d365',
|
|
9
|
+
'yield7d',
|
|
10
|
+
'yield7d360',
|
|
11
|
+
'yield7d365',
|
|
12
|
+
'yield15d',
|
|
13
|
+
'yield15d360',
|
|
14
|
+
'yield15d365',
|
|
15
|
+
'yield30d',
|
|
16
|
+
'yield30d360',
|
|
17
|
+
'yield30d365',
|
|
18
|
+
'yield90d',
|
|
19
|
+
'yield90d360',
|
|
20
|
+
'yield90d365',
|
|
21
|
+
'yield180d',
|
|
22
|
+
'yield180d360',
|
|
23
|
+
'yield180d365',
|
|
24
|
+
'yield30dComp360',
|
|
25
|
+
'yield30dComp365',
|
|
26
|
+
'yieldTtm',
|
|
27
|
+
'yieldSinceInception',
|
|
28
|
+
'yieldYtd',
|
|
29
|
+
];
|
|
30
|
+
// Yields are stored as Ray (1e27 fixed point) on token_snapshot. Dividing by
|
|
31
|
+
// 1e25 gives the value expressed as a percentage (e.g. Ray * 0.055 -> 5.5).
|
|
32
|
+
const RAY_PER_PERCENT = Dec('1e25');
|
|
33
|
+
function rayPercent(value) {
|
|
34
|
+
if (value == null)
|
|
35
|
+
return undefined;
|
|
36
|
+
try {
|
|
37
|
+
return Dec(value).div(RAY_PER_PERCENT);
|
|
38
|
+
}
|
|
39
|
+
catch {
|
|
40
|
+
return undefined;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
export class PoolShareYieldsReport extends Entity {
|
|
44
|
+
poolReports;
|
|
45
|
+
pool;
|
|
46
|
+
constructor(centrifuge, poolReports) {
|
|
47
|
+
super(centrifuge, ['poolShareYieldsReport', poolReports.pool.id.toString()]);
|
|
48
|
+
this.poolReports = poolReports;
|
|
49
|
+
this.pool = poolReports.pool;
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Get the per-day share-class yields report for a pool.
|
|
53
|
+
*
|
|
54
|
+
* Yields live on the share-class-level `token_snapshot` entity (not the
|
|
55
|
+
* per-network `token_instance_snapshot` consumed by `sharePrices`), and are
|
|
56
|
+
* populated on price-update events (`UpdatePricePoolPerShare`,
|
|
57
|
+
* `UpdateShareClass`) rather than on `NewPeriod` snapshots. The
|
|
58
|
+
* `(date, shareClassId)` dedupe keeps the latest snapshot per day.
|
|
59
|
+
*/
|
|
60
|
+
report(filter = {}) {
|
|
61
|
+
const { groupBy } = filter;
|
|
62
|
+
return this._query(['report', groupBy?.toString()], () => this.pool._shareClassIds().pipe(switchMap((shareClassIds) => this._root
|
|
63
|
+
._queryIndexer(`query ($filter: TokenSnapshotFilter) {
|
|
64
|
+
tokenSnapshots(
|
|
65
|
+
where: $filter
|
|
66
|
+
orderBy: "timestamp"
|
|
67
|
+
orderDirection: "desc"
|
|
68
|
+
limit: 1000
|
|
69
|
+
) {
|
|
70
|
+
items {
|
|
71
|
+
id
|
|
72
|
+
timestamp
|
|
73
|
+
${YIELD_FIELDS.join('\n ')}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
}`, {
|
|
77
|
+
filter: {
|
|
78
|
+
id_in: shareClassIds
|
|
79
|
+
.filter((id) => !filter.shareClassId || filter.shareClassId.equals(id))
|
|
80
|
+
.map((id) => id.toString()),
|
|
81
|
+
},
|
|
82
|
+
}, undefined, 60 * 60 * 1000)
|
|
83
|
+
.pipe(map((data) => this._process(data, filter))))));
|
|
84
|
+
}
|
|
85
|
+
/** @internal */
|
|
86
|
+
_process(data, filter) {
|
|
87
|
+
// Yields are keyed by (date, shareClassId). Results are ordered timestamp
|
|
88
|
+
// DESC; the first row we see for a given (date, id) is the latest snapshot
|
|
89
|
+
// for that date.
|
|
90
|
+
const yieldsByDate = {};
|
|
91
|
+
data.tokenSnapshots.items.forEach((row) => {
|
|
92
|
+
const date = new Date(Number(row.timestamp)).toISOString().slice(0, 10);
|
|
93
|
+
const byTokenId = (yieldsByDate[date] ??= {});
|
|
94
|
+
if (byTokenId[row.id])
|
|
95
|
+
return;
|
|
96
|
+
const yields = {};
|
|
97
|
+
for (const field of YIELD_FIELDS) {
|
|
98
|
+
const value = rayPercent(row[field]);
|
|
99
|
+
if (value !== undefined)
|
|
100
|
+
yields[field] = value;
|
|
101
|
+
}
|
|
102
|
+
byTokenId[row.id] = yields;
|
|
103
|
+
});
|
|
104
|
+
const items = Object.entries(yieldsByDate).map(([date, shareClasses]) => ({
|
|
105
|
+
timestamp: new Date(date).toISOString(),
|
|
106
|
+
shareClasses,
|
|
107
|
+
}));
|
|
108
|
+
return applyGrouping(items, filter.groupBy ?? 'day', 'latest').sort((a, b) => new Date(a.timestamp).getTime() - new Date(b.timestamp).getTime());
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
//# sourceMappingURL=PoolShareYieldsReport.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PoolShareYieldsReport.js","sourceRoot":"","sources":["../../../src/entities/Reports/PoolShareYieldsReport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,MAAM,CAAA;AAIrC,OAAO,EAAE,GAAG,EAAiB,MAAM,wBAAwB,CAAA;AAE3D,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AAIrC,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAA;AAsD1C,MAAM,YAAY,GAAG;IACnB,SAAS;IACT,YAAY;IACZ,YAAY;IACZ,SAAS;IACT,YAAY;IACZ,YAAY;IACZ,UAAU;IACV,aAAa;IACb,aAAa;IACb,UAAU;IACV,aAAa;IACb,aAAa;IACb,UAAU;IACV,aAAa;IACb,aAAa;IACb,WAAW;IACX,cAAc;IACd,cAAc;IACd,iBAAiB;IACjB,iBAAiB;IACjB,UAAU;IACV,qBAAqB;IACrB,UAAU;CACuC,CAAA;AAEnD,6EAA6E;AAC7E,4EAA4E;AAC5E,MAAM,eAAe,GAAG,GAAG,CAAC,MAAM,CAAC,CAAA;AAEnC,SAAS,UAAU,CAAC,KAAgC;IAClD,IAAI,KAAK,IAAI,IAAI;QAAE,OAAO,SAAS,CAAA;IACnC,IAAI,CAAC;QACH,OAAO,GAAG,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,eAAe,CAAC,CAAA;IACxC,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,SAAS,CAAA;IAClB,CAAC;AACH,CAAC;AAYD,MAAM,OAAO,qBAAsB,SAAQ,MAAM;IAItC;IAHF,IAAI,CAAM;IACjB,YACE,UAAsB,EACf,WAAwB;QAE/B,KAAK,CAAC,UAAU,EAAE,CAAC,uBAAuB,EAAE,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAA;QAFrE,gBAAW,GAAX,WAAW,CAAa;QAG/B,IAAI,CAAC,IAAI,GAAG,WAAW,CAAC,IAAI,CAAA;IAC9B,CAAC;IAED;;;;;;;;OAQG;IACH,MAAM,CAAC,SAAkC,EAAE;QACzC,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,CAAA;QAC1B,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC,EAAE,GAAG,EAAE,CACvD,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,IAAI,CAC7B,SAAS,CAAC,CAAC,aAAa,EAAE,EAAE,CAC1B,IAAI,CAAC,KAAK;aACP,aAAa,CACZ;;;;;;;;;;wBAUU,YAAY,CAAC,IAAI,CAAC,0BAA0B,CAAC;;;kBAGnD,EACJ;YACE,MAAM,EAAE;gBACN,KAAK,EAAE,aAAa;qBACjB,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,YAAY,IAAI,MAAM,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;qBACtE,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC;aACA;SAChC,EACD,SAAS,EACT,EAAE,GAAG,EAAE,GAAG,IAAI,CACf;aACA,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC,CACpD,CACF,CACF,CAAA;IACH,CAAC;IAED,gBAAgB;IAChB,QAAQ,CAAC,IAAqB,EAAE,MAAgD;QAC9E,0EAA0E;QAC1E,2EAA2E;QAC3E,iBAAiB;QACjB,MAAM,YAAY,GAAmD,EAAE,CAAA;QACvE,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;YACxC,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAA;YACvE,MAAM,SAAS,GAAG,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAA;YAC7C,IAAI,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC;gBAAE,OAAM;YAC7B,MAAM,MAAM,GAAgB,EAAE,CAAA;YAC9B,KAAK,MAAM,KAAK,IAAI,YAAY,EAAE,CAAC;gBACjC,MAAM,KAAK,GAAG,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAA;gBACpC,IAAI,KAAK,KAAK,SAAS;oBAAE,MAAM,CAAC,KAAK,CAAC,GAAG,KAAK,CAAA;YAChD,CAAC;YACD,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAA;QAC5B,CAAC,CAAC,CAAA;QAEF,MAAM,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,YAAY,CAAC,EAAE,EAAE,CAAC,CAAC;YACxE,SAAS,EAAE,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE;YACvC,YAAY;SACb,CAAC,CAAC,CAAA;QAEH,OAAO,aAAa,CAAC,KAAK,EAAE,MAAM,CAAC,OAAO,IAAI,KAAK,EAAE,QAAQ,CAAC,CAAC,IAAI,CACjE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,CAC5E,CAAA;IACH,CAAC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PoolShareYieldsReport.test.d.ts","sourceRoot":"","sources":["../../../src/entities/Reports/PoolShareYieldsReport.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
import { expect } from 'chai';
|
|
2
|
+
import { context } from '../../tests/setup.js';
|
|
3
|
+
import { PoolId, ShareClassId } from '../../utils/types.js';
|
|
4
|
+
import { Pool } from '../Pool.js';
|
|
5
|
+
import { PoolReports } from './PoolReports.js';
|
|
6
|
+
import { PoolShareYieldsReport } from './PoolShareYieldsReport.js';
|
|
7
|
+
const centId = 1;
|
|
8
|
+
const poolId = PoolId.from(centId, 1);
|
|
9
|
+
const scId = ShareClassId.from(poolId, 1);
|
|
10
|
+
describe('PoolShareYieldsReport', () => {
|
|
11
|
+
let poolShareYieldsReport;
|
|
12
|
+
before(() => {
|
|
13
|
+
const { centrifuge } = context;
|
|
14
|
+
const pool = new Pool(centrifuge, poolId);
|
|
15
|
+
const poolReports = new PoolReports(centrifuge, pool);
|
|
16
|
+
poolShareYieldsReport = new PoolShareYieldsReport(centrifuge, poolReports);
|
|
17
|
+
});
|
|
18
|
+
it('converts Ray-encoded yields to Decimal percentages keyed by (date, shareClassId)', () => {
|
|
19
|
+
const tokenId = scId.raw;
|
|
20
|
+
// Ray-encoded yields: 5.5% -> 0.055 * 1e27 = 5.5e25
|
|
21
|
+
const data = {
|
|
22
|
+
tokenSnapshots: {
|
|
23
|
+
items: [
|
|
24
|
+
{
|
|
25
|
+
id: tokenId,
|
|
26
|
+
timestamp: '1777939200000',
|
|
27
|
+
yieldYtd: '55000000000000000000000000',
|
|
28
|
+
yield30d365: '120000000000000000000000000',
|
|
29
|
+
yield1d: null,
|
|
30
|
+
yield1d360: null,
|
|
31
|
+
yield1d365: null,
|
|
32
|
+
yield7d: null,
|
|
33
|
+
yield7d360: null,
|
|
34
|
+
yield7d365: null,
|
|
35
|
+
yield15d: null,
|
|
36
|
+
yield15d360: null,
|
|
37
|
+
yield15d365: null,
|
|
38
|
+
yield30d: null,
|
|
39
|
+
yield30d360: null,
|
|
40
|
+
yield90d: null,
|
|
41
|
+
yield90d360: null,
|
|
42
|
+
yield90d365: null,
|
|
43
|
+
yield180d: null,
|
|
44
|
+
yield180d360: null,
|
|
45
|
+
yield180d365: null,
|
|
46
|
+
yield30dComp360: null,
|
|
47
|
+
yield30dComp365: null,
|
|
48
|
+
yieldTtm: null,
|
|
49
|
+
yieldSinceInception: null,
|
|
50
|
+
},
|
|
51
|
+
],
|
|
52
|
+
},
|
|
53
|
+
};
|
|
54
|
+
const report = poolShareYieldsReport._process(data, {});
|
|
55
|
+
const entry = report[0].shareClasses[tokenId];
|
|
56
|
+
expect(entry.yieldYtd.toNumber()).to.equal(5.5);
|
|
57
|
+
expect(entry.yield30d365.toNumber()).to.equal(12);
|
|
58
|
+
expect(entry.yield1d).to.equal(undefined);
|
|
59
|
+
});
|
|
60
|
+
it('keeps the latest snapshot per (date, shareClassId)', () => {
|
|
61
|
+
const tokenId = scId.raw;
|
|
62
|
+
const data = {
|
|
63
|
+
tokenSnapshots: {
|
|
64
|
+
items: [
|
|
65
|
+
// Order returned by indexer: timestamp DESC, so the first row is the latest.
|
|
66
|
+
{
|
|
67
|
+
id: tokenId,
|
|
68
|
+
timestamp: '1777982400000',
|
|
69
|
+
yieldYtd: '70000000000000000000000000',
|
|
70
|
+
yield30d365: null,
|
|
71
|
+
yield1d: null,
|
|
72
|
+
yield1d360: null,
|
|
73
|
+
yield1d365: null,
|
|
74
|
+
yield7d: null,
|
|
75
|
+
yield7d360: null,
|
|
76
|
+
yield7d365: null,
|
|
77
|
+
yield15d: null,
|
|
78
|
+
yield15d360: null,
|
|
79
|
+
yield15d365: null,
|
|
80
|
+
yield30d: null,
|
|
81
|
+
yield30d360: null,
|
|
82
|
+
yield90d: null,
|
|
83
|
+
yield90d360: null,
|
|
84
|
+
yield90d365: null,
|
|
85
|
+
yield180d: null,
|
|
86
|
+
yield180d360: null,
|
|
87
|
+
yield180d365: null,
|
|
88
|
+
yield30dComp360: null,
|
|
89
|
+
yield30dComp365: null,
|
|
90
|
+
yieldTtm: null,
|
|
91
|
+
yieldSinceInception: null,
|
|
92
|
+
},
|
|
93
|
+
{
|
|
94
|
+
id: tokenId,
|
|
95
|
+
timestamp: '1777939200000',
|
|
96
|
+
yieldYtd: '55000000000000000000000000',
|
|
97
|
+
yield30d365: null,
|
|
98
|
+
yield1d: null,
|
|
99
|
+
yield1d360: null,
|
|
100
|
+
yield1d365: null,
|
|
101
|
+
yield7d: null,
|
|
102
|
+
yield7d360: null,
|
|
103
|
+
yield7d365: null,
|
|
104
|
+
yield15d: null,
|
|
105
|
+
yield15d360: null,
|
|
106
|
+
yield15d365: null,
|
|
107
|
+
yield30d: null,
|
|
108
|
+
yield30d360: null,
|
|
109
|
+
yield90d: null,
|
|
110
|
+
yield90d360: null,
|
|
111
|
+
yield90d365: null,
|
|
112
|
+
yield180d: null,
|
|
113
|
+
yield180d360: null,
|
|
114
|
+
yield180d365: null,
|
|
115
|
+
yield30dComp360: null,
|
|
116
|
+
yield30dComp365: null,
|
|
117
|
+
yieldTtm: null,
|
|
118
|
+
yieldSinceInception: null,
|
|
119
|
+
},
|
|
120
|
+
],
|
|
121
|
+
},
|
|
122
|
+
};
|
|
123
|
+
const report = poolShareYieldsReport._process(data, {});
|
|
124
|
+
// Both rows share the same UTC date; the first (latest) one wins.
|
|
125
|
+
expect(report).to.have.length(1);
|
|
126
|
+
expect(report[0].shareClasses[tokenId].yieldYtd.toNumber()).to.equal(7);
|
|
127
|
+
});
|
|
128
|
+
});
|
|
129
|
+
//# sourceMappingURL=PoolShareYieldsReport.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PoolShareYieldsReport.test.js","sourceRoot":"","sources":["../../../src/entities/Reports/PoolShareYieldsReport.test.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
CHANGED
|
@@ -7,6 +7,7 @@ export * from './entities/OnOffRampManager.js';
|
|
|
7
7
|
export * from './entities/Pool.js';
|
|
8
8
|
export * from './entities/PoolNetwork.js';
|
|
9
9
|
export * from './entities/Reports/PoolReports.js';
|
|
10
|
+
export * from './entities/Reports/PoolShareYieldsReport.js';
|
|
10
11
|
export * from './entities/Reports/PoolSharePricesReport.js';
|
|
11
12
|
export * from './entities/ShareClass.js';
|
|
12
13
|
export * from './entities/Vault.js';
|
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;AAE5C,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAA;AACpC,cAAc,4BAA4B,CAAA;AAC1C,cAAc,wBAAwB,CAAA;AACtC,cAAc,kCAAkC,CAAA;AAChD,cAAc,gCAAgC,CAAA;AAC9C,cAAc,oBAAoB,CAAA;AAClC,cAAc,2BAA2B,CAAA;AACzC,cAAc,mCAAmC,CAAA;AACjD,cAAc,6CAA6C,CAAA;AAC3D,cAAc,0BAA0B,CAAA;AACxC,cAAc,qBAAqB,CAAA;AACnC,YAAY,EAAE,MAAM,EAAE,MAAM,EAAE,eAAe,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAA;AAClF,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,mBAAmB,EACnB,wBAAwB,EACxB,sBAAsB,EACtB,4BAA4B,EAC5B,6BAA6B,EAC7B,sBAAsB,EACtB,eAAe,EACf,mBAAmB,EACnB,0BAA0B,EAC1B,gBAAgB,EAChB,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;AAChC,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAA;AAC3C,OAAO,EAAE,uBAAuB,EAAE,sBAAsB,EAAE,MAAM,+BAA+B,CAAA;AAC/F,YAAY,EAAE,iBAAiB,EAAE,yBAAyB,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAA;AAChH,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAA;AAC3D,YAAY,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAA;AAE9D,OAAO,EAAE,UAAU,EAAE,CAAA;AACrB,eAAe,UAAU,CAAA;AAEzB,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAA;AACpC,cAAc,4BAA4B,CAAA;AAC1C,cAAc,wBAAwB,CAAA;AACtC,cAAc,kCAAkC,CAAA;AAChD,cAAc,gCAAgC,CAAA;AAC9C,cAAc,oBAAoB,CAAA;AAClC,cAAc,2BAA2B,CAAA;AACzC,cAAc,mCAAmC,CAAA;AACjD,cAAc,6CAA6C,CAAA;AAC3D,cAAc,6CAA6C,CAAA;AAC3D,cAAc,0BAA0B,CAAA;AACxC,cAAc,qBAAqB,CAAA;AACnC,YAAY,EAAE,MAAM,EAAE,MAAM,EAAE,eAAe,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAA;AAClF,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,mBAAmB,EACnB,wBAAwB,EACxB,sBAAsB,EACtB,4BAA4B,EAC5B,6BAA6B,EAC7B,sBAAsB,EACtB,eAAe,EACf,mBAAmB,EACnB,0BAA0B,EAC1B,gBAAgB,EAChB,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;AAChC,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAA;AAC3C,OAAO,EAAE,uBAAuB,EAAE,sBAAsB,EAAE,MAAM,+BAA+B,CAAA;AAC/F,YAAY,EAAE,iBAAiB,EAAE,yBAAyB,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAA;AAChH,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAA;AAC3D,YAAY,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAA;AAE9D,OAAO,EAAE,UAAU,EAAE,CAAA;AACrB,eAAe,UAAU,CAAA;AAEzB,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA"}
|
package/dist/index.js
CHANGED
|
@@ -7,6 +7,7 @@ export * from './entities/OnOffRampManager.js';
|
|
|
7
7
|
export * from './entities/Pool.js';
|
|
8
8
|
export * from './entities/PoolNetwork.js';
|
|
9
9
|
export * from './entities/Reports/PoolReports.js';
|
|
10
|
+
export * from './entities/Reports/PoolShareYieldsReport.js';
|
|
10
11
|
export * from './entities/Reports/PoolSharePricesReport.js';
|
|
11
12
|
export * from './entities/ShareClass.js';
|
|
12
13
|
export * from './entities/Vault.js';
|
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;AAE5C,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAA;AACpC,cAAc,4BAA4B,CAAA;AAC1C,cAAc,wBAAwB,CAAA;AACtC,cAAc,kCAAkC,CAAA;AAChD,cAAc,gCAAgC,CAAA;AAC9C,cAAc,oBAAoB,CAAA;AAClC,cAAc,2BAA2B,CAAA;AACzC,cAAc,mCAAmC,CAAA;AACjD,cAAc,6CAA6C,CAAA;AAC3D,cAAc,0BAA0B,CAAA;AACxC,cAAc,qBAAqB,CAAA;AAGnC,cAAc,yBAAyB,CAAA;AAgBvC,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,mBAAmB,CAAA;AAErE,cAAc,kBAAkB,CAAA;AAChC,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAA;AAC3C,OAAO,EAAE,uBAAuB,EAAE,sBAAsB,EAAE,MAAM,+BAA+B,CAAA;AAE/F,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAA;AAG3D,OAAO,EAAE,UAAU,EAAE,CAAA;AACrB,eAAe,UAAU,CAAA;AAEzB,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAA;AACpC,cAAc,4BAA4B,CAAA;AAC1C,cAAc,wBAAwB,CAAA;AACtC,cAAc,kCAAkC,CAAA;AAChD,cAAc,gCAAgC,CAAA;AAC9C,cAAc,oBAAoB,CAAA;AAClC,cAAc,2BAA2B,CAAA;AACzC,cAAc,mCAAmC,CAAA;AACjD,cAAc,6CAA6C,CAAA;AAC3D,cAAc,6CAA6C,CAAA;AAC3D,cAAc,0BAA0B,CAAA;AACxC,cAAc,qBAAqB,CAAA;AAGnC,cAAc,yBAAyB,CAAA;AAgBvC,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,mBAAmB,CAAA;AAErE,cAAc,kBAAkB,CAAA;AAChC,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAA;AAC3C,OAAO,EAAE,uBAAuB,EAAE,sBAAsB,EAAE,MAAM,+BAA+B,CAAA;AAE/F,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAA;AAG3D,OAAO,EAAE,UAAU,EAAE,CAAA;AACrB,eAAe,UAAU,CAAA;AAEzB,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA"}
|