@cardano-sdk/projection 0.3.1-nightly.1 → 0.4.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/cjs/index.d.ts +3 -3
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +4 -4
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/operators/withNetworkInfo.d.ts +2 -2
- package/dist/cjs/operators/withNetworkInfo.d.ts.map +1 -1
- package/dist/cjs/operators/withNetworkInfo.js +2 -4
- package/dist/cjs/operators/withNetworkInfo.js.map +1 -1
- package/dist/cjs/operators/withRolledBackBlock.d.ts +2 -1
- package/dist/cjs/operators/withRolledBackBlock.d.ts.map +1 -1
- package/dist/cjs/operators/withRolledBackBlock.js +1 -1
- package/dist/cjs/operators/withRolledBackBlock.js.map +1 -1
- package/dist/cjs/projectIntoSink.d.ts +3 -4
- package/dist/cjs/projectIntoSink.d.ts.map +1 -1
- package/dist/cjs/projectIntoSink.js +31 -25
- package/dist/cjs/projectIntoSink.js.map +1 -1
- package/dist/cjs/sinks/inMemory/InMemoryStabilityWindowBuffer.d.ts +4 -4
- package/dist/cjs/sinks/inMemory/InMemoryStabilityWindowBuffer.d.ts.map +1 -1
- package/dist/cjs/sinks/inMemory/InMemoryStabilityWindowBuffer.js +6 -16
- package/dist/cjs/sinks/inMemory/InMemoryStabilityWindowBuffer.js.map +1 -1
- package/dist/cjs/sinks/inMemory/create.d.ts +7 -0
- package/dist/cjs/sinks/inMemory/create.d.ts.map +1 -0
- package/dist/cjs/sinks/inMemory/{createInMemorySinks.js → create.js} +11 -6
- package/dist/cjs/sinks/inMemory/create.js.map +1 -0
- package/dist/cjs/sinks/inMemory/index.d.ts +1 -1
- package/dist/cjs/sinks/inMemory/index.d.ts.map +1 -1
- package/dist/cjs/sinks/inMemory/index.js +1 -1
- package/dist/cjs/sinks/inMemory/index.js.map +1 -1
- package/dist/cjs/sinks/inMemory/stakePools.js +1 -1
- package/dist/cjs/sinks/inMemory/stakePools.js.map +1 -1
- package/dist/cjs/sinks/index.d.ts +1 -1
- package/dist/cjs/sinks/index.d.ts.map +1 -1
- package/dist/cjs/sinks/index.js +14 -1
- package/dist/cjs/sinks/index.js.map +1 -1
- package/dist/cjs/sinks/types.d.ts +6 -5
- package/dist/cjs/sinks/types.d.ts.map +1 -1
- package/dist/cjs/sinks/util.d.ts +2 -1
- package/dist/cjs/sinks/util.d.ts.map +1 -1
- package/dist/cjs/sinks/util.js +3 -5
- package/dist/cjs/sinks/util.js.map +1 -1
- package/dist/cjs/tsconfig.tsbuildinfo +1 -1
- package/dist/cjs/types.d.ts +1 -12
- package/dist/cjs/types.d.ts.map +1 -1
- package/dist/cjs/types.js +0 -5
- package/dist/cjs/types.js.map +1 -1
- package/dist/esm/index.d.ts +3 -3
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +3 -3
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/operators/withNetworkInfo.d.ts +2 -2
- package/dist/esm/operators/withNetworkInfo.d.ts.map +1 -1
- package/dist/esm/operators/withNetworkInfo.js +2 -4
- package/dist/esm/operators/withNetworkInfo.js.map +1 -1
- package/dist/esm/operators/withRolledBackBlock.d.ts +2 -1
- package/dist/esm/operators/withRolledBackBlock.d.ts.map +1 -1
- package/dist/esm/operators/withRolledBackBlock.js +1 -1
- package/dist/esm/operators/withRolledBackBlock.js.map +1 -1
- package/dist/esm/projectIntoSink.d.ts +3 -4
- package/dist/esm/projectIntoSink.d.ts.map +1 -1
- package/dist/esm/projectIntoSink.js +34 -28
- package/dist/esm/projectIntoSink.js.map +1 -1
- package/dist/esm/sinks/inMemory/InMemoryStabilityWindowBuffer.d.ts +4 -4
- package/dist/esm/sinks/inMemory/InMemoryStabilityWindowBuffer.d.ts.map +1 -1
- package/dist/esm/sinks/inMemory/InMemoryStabilityWindowBuffer.js +6 -16
- package/dist/esm/sinks/inMemory/InMemoryStabilityWindowBuffer.js.map +1 -1
- package/dist/esm/sinks/inMemory/create.d.ts +7 -0
- package/dist/esm/sinks/inMemory/create.d.ts.map +1 -0
- package/dist/esm/sinks/inMemory/{createInMemorySinks.js → create.js} +8 -4
- package/dist/esm/sinks/inMemory/create.js.map +1 -0
- package/dist/esm/sinks/inMemory/index.d.ts +1 -1
- package/dist/esm/sinks/inMemory/index.d.ts.map +1 -1
- package/dist/esm/sinks/inMemory/index.js +1 -1
- package/dist/esm/sinks/inMemory/index.js.map +1 -1
- package/dist/esm/sinks/inMemory/stakePools.js +1 -1
- package/dist/esm/sinks/inMemory/stakePools.js.map +1 -1
- package/dist/esm/sinks/index.d.ts +1 -1
- package/dist/esm/sinks/index.d.ts.map +1 -1
- package/dist/esm/sinks/index.js +1 -1
- package/dist/esm/sinks/index.js.map +1 -1
- package/dist/esm/sinks/types.d.ts +6 -5
- package/dist/esm/sinks/types.d.ts.map +1 -1
- package/dist/esm/sinks/util.d.ts +2 -1
- package/dist/esm/sinks/util.d.ts.map +1 -1
- package/dist/esm/sinks/util.js +1 -3
- package/dist/esm/sinks/util.js.map +1 -1
- package/dist/esm/tsconfig.tsbuildinfo +1 -1
- package/dist/esm/types.d.ts +1 -12
- package/dist/esm/types.d.ts.map +1 -1
- package/dist/esm/types.js +1 -3
- package/dist/esm/types.js.map +1 -1
- package/package.json +8 -8
- package/dist/cjs/sinks/inMemory/createInMemorySinks.d.ts +0 -7
- package/dist/cjs/sinks/inMemory/createInMemorySinks.d.ts.map +0 -1
- package/dist/cjs/sinks/inMemory/createInMemorySinks.js.map +0 -1
- package/dist/esm/sinks/inMemory/createInMemorySinks.d.ts +0 -7
- package/dist/esm/sinks/inMemory/createInMemorySinks.d.ts.map +0 -1
- package/dist/esm/sinks/inMemory/createInMemorySinks.js.map +0 -1
package/dist/cjs/types.d.ts
CHANGED
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { CustomError } from 'ts-custom-error';
|
|
1
|
+
import { ChainSyncRollBackward, ChainSyncRollForward } from '@cardano-sdk/core';
|
|
3
2
|
import { Observable } from 'rxjs';
|
|
4
3
|
import { ObservableType } from '@cardano-sdk/util-rxjs';
|
|
5
4
|
export declare type RollForwardEvent<ExtraProps = {}> = ExtraProps & ChainSyncRollForward;
|
|
@@ -12,14 +11,4 @@ export declare type UnifiedProjectorOperator<ExtraPropsIn, ExtraPropsOut> = Proj
|
|
|
12
11
|
export declare type UnifiedProjectorEvent<ExtraProps> = ProjectorEvent<ExtraProps, ExtraProps & WithBlock>;
|
|
13
12
|
export declare type UnifiedProjectorObservable<ExtraProps> = ProjectorObservable<ExtraProps, ExtraProps & WithBlock>;
|
|
14
13
|
export declare type OperatorEventType<T extends (...args: any[]) => any> = ReturnType<T> extends (...args: any[]) => any ? OperatorEventType<ReturnType<T>> : ObservableType<ReturnType<T>>;
|
|
15
|
-
export interface ChainSyncProps {
|
|
16
|
-
points: PointOrOrigin[];
|
|
17
|
-
}
|
|
18
|
-
export declare class InvalidIntersectionError extends CustomError {
|
|
19
|
-
}
|
|
20
|
-
export interface ObservableChainSync {
|
|
21
|
-
chainSync$: Observable<ChainSyncEvent>;
|
|
22
|
-
intersection: Intersection;
|
|
23
|
-
}
|
|
24
|
-
export declare type ObservableChainSyncClient = (props: ChainSyncProps) => Observable<ObservableChainSync>;
|
|
25
14
|
//# sourceMappingURL=types.d.ts.map
|
package/dist/cjs/types.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"AACA,OAAO,
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAChF,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAClC,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAExD,oBAAY,gBAAgB,CAAC,UAAU,GAAG,EAAE,IAAI,UAAU,GAAG,oBAAoB,CAAC;AAElF,oBAAY,iBAAiB,CAAC,UAAU,GAAG,EAAE,IAAI,UAAU,GAAG,qBAAqB,CAAC;AAEpF,oBAAY,cAAc,CAAC,qBAAqB,GAAG,EAAE,EAAE,sBAAsB,GAAG,EAAE,IAC9E,gBAAgB,CAAC,qBAAqB,CAAC,GACvC,iBAAiB,CAAC,sBAAsB,CAAC,CAAC;AAE9C,oBAAY,mBAAmB,CAAC,qBAAqB,GAAG,EAAE,EAAE,sBAAsB,GAAG,EAAE,IAAI,UAAU,CACnG,cAAc,CAAC,qBAAqB,EAAE,sBAAsB,CAAC,CAC9D,CAAC;AAEF,oBAAY,iBAAiB,CAC3B,uBAAuB,EACvB,wBAAwB,EACxB,wBAAwB,EACxB,yBAAyB,IACvB,CACF,IAAI,EAAE,mBAAmB,CAAC,uBAAuB,EAAE,wBAAwB,CAAC,KACzE,UAAU,CACb,cAAc,CACZ,uBAAuB,GAAG,wBAAwB,EAClD,wBAAwB,GAAG,yBAAyB,CACrD,CACF,CAAC;AAEF,oBAAY,SAAS,GAAG,IAAI,CAAC,oBAAoB,EAAE,OAAO,CAAC,CAAC;AAC5D,oBAAY,wBAAwB,CAAC,YAAY,EAAE,aAAa,IAAI,iBAAiB,CACnF,YAAY,EACZ,YAAY,GAAG,SAAS,EACxB,aAAa,EACb,aAAa,CACd,CAAC;AACF,oBAAY,qBAAqB,CAAC,UAAU,IAAI,cAAc,CAAC,UAAU,EAAE,UAAU,GAAG,SAAS,CAAC,CAAC;AACnG,oBAAY,0BAA0B,CAAC,UAAU,IAAI,mBAAmB,CAAC,UAAU,EAAE,UAAU,GAAG,SAAS,CAAC,CAAC;AAG7G,oBAAY,iBAAiB,CAAC,CAAC,SAAS,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,GAAG,IAAI,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,GAAG,GAC5G,iBAAiB,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,GAChC,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC"}
|
package/dist/cjs/types.js
CHANGED
|
@@ -1,8 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.InvalidIntersectionError = void 0;
|
|
4
|
-
const ts_custom_error_1 = require("ts-custom-error");
|
|
5
|
-
class InvalidIntersectionError extends ts_custom_error_1.CustomError {
|
|
6
|
-
}
|
|
7
|
-
exports.InvalidIntersectionError = InvalidIntersectionError;
|
|
8
3
|
//# sourceMappingURL=types.js.map
|
package/dist/cjs/types.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":""}
|
package/dist/esm/index.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
export * as
|
|
2
|
-
export * as
|
|
3
|
-
export *
|
|
1
|
+
export * as Operators from './operators';
|
|
2
|
+
export * as Projections from './projections';
|
|
3
|
+
export * from './sinks';
|
|
4
4
|
export * from './projectIntoSink';
|
|
5
5
|
export * from './types';
|
|
6
6
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/esm/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,aAAa,CAAC;AACzC,OAAO,KAAK,WAAW,MAAM,eAAe,CAAC;AAC7C,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,aAAa,CAAC;AACzC,OAAO,KAAK,WAAW,MAAM,eAAe,CAAC;AAC7C,cAAc,SAAS,CAAC;AACxB,cAAc,mBAAmB,CAAC;AAClC,cAAc,SAAS,CAAC"}
|
package/dist/esm/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
export * as
|
|
2
|
-
export * as
|
|
3
|
-
export *
|
|
1
|
+
export * as Operators from './operators';
|
|
2
|
+
export * as Projections from './projections';
|
|
3
|
+
export * from './sinks';
|
|
4
4
|
export * from './projectIntoSink';
|
|
5
5
|
export * from './types';
|
|
6
6
|
//# sourceMappingURL=index.js.map
|
package/dist/esm/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,aAAa,CAAC;AACzC,OAAO,KAAK,WAAW,MAAM,eAAe,CAAC;AAC7C,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,aAAa,CAAC;AACzC,OAAO,KAAK,WAAW,MAAM,eAAe,CAAC;AAC7C,cAAc,SAAS,CAAC;AACxB,cAAc,mBAAmB,CAAC;AAClC,cAAc,SAAS,CAAC"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { Cardano, EraSummary } from '@cardano-sdk/core';
|
|
1
|
+
import { Cardano, EraSummary, ObservableCardanoNode } from '@cardano-sdk/core';
|
|
2
2
|
export declare type WithNetworkInfo = {
|
|
3
3
|
eraSummaries: EraSummary[];
|
|
4
4
|
genesisParameters: Cardano.CompactGenesis;
|
|
5
5
|
};
|
|
6
|
-
export declare const withNetworkInfo: <RollForwardPropsIn, RollBackwardPropsIn>(
|
|
6
|
+
export declare const withNetworkInfo: <RollForwardPropsIn, RollBackwardPropsIn>(cardanoNode: Pick<ObservableCardanoNode, 'eraSummaries$' | 'genesisParameters$'>) => import("..").ProjectorOperator<RollForwardPropsIn, RollBackwardPropsIn, WithNetworkInfo, WithNetworkInfo>;
|
|
7
7
|
//# sourceMappingURL=withNetworkInfo.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"withNetworkInfo.d.ts","sourceRoot":"","sources":["../../../src/operators/withNetworkInfo.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;
|
|
1
|
+
{"version":3,"file":"withNetworkInfo.d.ts","sourceRoot":"","sources":["../../../src/operators/withNetworkInfo.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAC;AAI/E,oBAAY,eAAe,GAAG;IAC5B,YAAY,EAAE,UAAU,EAAE,CAAC;IAC3B,iBAAiB,EAAE,OAAO,CAAC,cAAc,CAAC;CAC3C,CAAC;AAEF,eAAO,MAAM,eAAe,yDACb,KAAK,qBAAqB,EAAE,eAAe,GAAG,oBAAoB,CAAC,8GAO/E,CAAC"}
|
|
@@ -1,6 +1,4 @@
|
|
|
1
|
+
import { combineLatest, map, take } from 'rxjs';
|
|
1
2
|
import { withStaticContext } from './withStaticContext';
|
|
2
|
-
export const withNetworkInfo = (
|
|
3
|
-
eraSummaries: networkInfo.eraSummaries,
|
|
4
|
-
genesisParameters: networkInfo.genesisParameters
|
|
5
|
-
});
|
|
3
|
+
export const withNetworkInfo = (cardanoNode) => withStaticContext(combineLatest([cardanoNode.genesisParameters$, cardanoNode.eraSummaries$]).pipe(map(([genesisParameters, eraSummaries]) => ({ eraSummaries, genesisParameters })), take(1)));
|
|
6
4
|
//# sourceMappingURL=withNetworkInfo.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"withNetworkInfo.js","sourceRoot":"","sources":["../../../src/operators/withNetworkInfo.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAOxD,MAAM,CAAC,MAAM,eAAe,GAAG,
|
|
1
|
+
{"version":3,"file":"withNetworkInfo.js","sourceRoot":"","sources":["../../../src/operators/withNetworkInfo.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAChD,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAOxD,MAAM,CAAC,MAAM,eAAe,GAAG,CAC7B,WAAgF,EAChF,EAAE,CACF,iBAAiB,CACf,aAAa,CAAC,CAAC,WAAW,CAAC,kBAAkB,EAAE,WAAW,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAC7E,GAAG,CAAC,CAAC,CAAC,iBAAiB,EAAE,YAAY,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,YAAY,EAAE,iBAAiB,EAAE,CAAC,CAAC,EACjF,IAAI,CAAC,CAAC,CAAC,CACR,CACF,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { ProjectorOperator, WithBlock } from '../types';
|
|
2
2
|
import { StabilityWindowBuffer } from '../sinks';
|
|
3
|
-
|
|
3
|
+
import { WithNetworkInfo } from './withNetworkInfo';
|
|
4
|
+
export declare const withRolledBackBlock: (buffer: StabilityWindowBuffer<WithNetworkInfo>) => ProjectorOperator<{}, {}, {}, WithBlock>;
|
|
4
5
|
//# sourceMappingURL=withRolledBackBlock.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"withRolledBackBlock.d.ts","sourceRoot":"","sources":["../../../src/operators/withRolledBackBlock.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AACxD,OAAO,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"withRolledBackBlock.d.ts","sourceRoot":"","sources":["../../../src/operators/withRolledBackBlock.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AACxD,OAAO,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAMpD,eAAO,MAAM,mBAAmB,WACrB,sBAAsB,eAAe,CAAC,KAAG,kBAAkB,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,SAAS,CAwBtF,CAAC"}
|
|
@@ -6,7 +6,7 @@ export const withRolledBackBlock = (buffer) => (evt$) => evt$.pipe(concatMap((ch
|
|
|
6
6
|
return of(chainSyncEvent);
|
|
7
7
|
case ChainSyncEventType.RollBackward:
|
|
8
8
|
return buffer.tip$.pipe(takeWhile((block) => block !== 'origin' &&
|
|
9
|
-
(chainSyncEvent.
|
|
9
|
+
(chainSyncEvent.point === 'origin' || chainSyncEvent.point.hash !== block.header.hash)), map((block) => ({
|
|
10
10
|
...chainSyncEvent,
|
|
11
11
|
block,
|
|
12
12
|
requestNext: noop
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"withRolledBackBlock.js","sourceRoot":"","sources":["../../../src/operators/withRolledBackBlock.ts"],"names":[],"mappings":"AAAA,OAAO,EAA2B,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAChF,OAAO,EAAc,SAAS,EAAE,QAAQ,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"withRolledBackBlock.js","sourceRoot":"","sources":["../../../src/operators/withRolledBackBlock.ts"],"names":[],"mappings":"AAAA,OAAO,EAA2B,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAChF,OAAO,EAAc,SAAS,EAAE,QAAQ,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AASjF,MAAM,CAAC,MAAM,mBAAmB,GAC9B,CAAC,MAA8C,EAA4C,EAAE,CAC7F,CAAC,IAAgC,EAAE,EAAE,CACnC,IAAI,CAAC,IAAI,CACP,SAAS,CAAC,CAAC,cAAc,EAAE,EAAE;IAC3B,QAAQ,cAAc,CAAC,SAAS,EAAE;QAChC,KAAK,kBAAkB,CAAC,WAAW;YACjC,OAAO,EAAE,CAAC,cAAc,CAAC,CAAC;QAC5B,KAAK,kBAAkB,CAAC,YAAY;YAClC,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CACrB,SAAS,CACP,CAAC,KAAK,EAA0B,EAAE,CAChC,KAAK,KAAK,QAAQ;gBAClB,CAAC,cAAc,CAAC,KAAK,KAAK,QAAQ,IAAI,cAAc,CAAC,KAAK,CAAC,IAAI,KAAK,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CACzF,EACD,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;gBACd,GAAG,cAAc;gBACjB,KAAK;gBACL,WAAW,EAAE,IAAI;aAClB,CAAC,CAAC,EAEH,QAAQ,CAAC,cAAc,CAAC,WAAW,CAAC,CACrC,CAAC;KACL;AACH,CAAC,CAAC,CACH,CAAC"}
|
|
@@ -1,14 +1,13 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ObservableCardanoNode } from '@cardano-sdk/core';
|
|
2
2
|
import { Logger } from 'ts-log';
|
|
3
3
|
import { Observable } from 'rxjs';
|
|
4
4
|
import { Projection } from './projections';
|
|
5
5
|
import { Sinks } from './sinks';
|
|
6
|
-
import {
|
|
6
|
+
import { UnifiedProjectorEvent } from './types';
|
|
7
7
|
export interface ProjectIntoSinkProps<P, PS extends P> {
|
|
8
8
|
projections: P;
|
|
9
9
|
sinks: Sinks<PS>;
|
|
10
|
-
|
|
11
|
-
networkInfo: WithNetworkInfo;
|
|
10
|
+
cardanoNode: ObservableCardanoNode;
|
|
12
11
|
logger: Logger;
|
|
13
12
|
}
|
|
14
13
|
declare type ProjectionTypes<P> = {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"projectIntoSink.d.ts","sourceRoot":"","sources":["../../src/projectIntoSink.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"projectIntoSink.d.ts","sourceRoot":"","sources":["../../src/projectIntoSink.ts"],"names":[],"mappings":"AAGA,OAAO,EAKL,qBAAqB,EAGtB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAChC,OAAO,EACL,UAAU,EAcX,MAAM,MAAM,CAAC;AACd,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAQ,KAAK,EAA+B,MAAM,SAAS,CAAC;AACnE,OAAO,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAC;AAOhD,MAAM,WAAW,oBAAoB,CAAC,CAAC,EAAE,EAAE,SAAS,CAAC;IACnD,WAAW,EAAE,CAAC,CAAC;IACf,KAAK,EAAE,KAAK,CAAC,EAAE,CAAC,CAAC;IACjB,WAAW,EAAE,qBAAqB,CAAC;IACnC,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,aAAK,eAAe,CAAC,CAAC,IAAI;KACvB,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,UAAU,CAAC,MAAM,KAAK,CAAC,GAAG,KAAK,GAAG,KAAK;CACrE,CAAC;AAEF,aAAK,mBAAmB,CAAC,CAAC,IAAI,CAAC,CAAC,SAAS,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,KAAK,IAAI,GAAG,KAAK,CAAC,SAAS,CAAC,CAAC,EAAE,MAAM,CAAC,KAAK,IAAI,GAAG,CAAC,GAAG,KAAK,CAAC;AAChH,aAAK,gBAAgB,CAAC,CAAC,SAAS,MAAM,IAAI,qBAAqB,CAAC,mBAAmB,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAoBlH,eAAO,MAAM,eAAe,yGAsH3B,CAAC"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { ChainSyncEventType } from '@cardano-sdk/core';
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import { manageBuffer } from './sinks';
|
|
1
|
+
import { CardanoNodeErrors, ChainSyncEventType } from '@cardano-sdk/core';
|
|
2
|
+
import { Observable, combineLatest, concat, concatMap, defaultIfEmpty, defer, finalize, map, mergeMap, noop, of, take, takeWhile, tap } from 'rxjs';
|
|
3
|
+
import { manageStabilityWindowBuffer } from './sinks';
|
|
5
4
|
import { withNetworkInfo, withRolledBackBlock } from './operators';
|
|
6
5
|
import { combineProjections } from './combineProjections';
|
|
6
|
+
import { contextLogger } from '@cardano-sdk/util';
|
|
7
7
|
import { passthrough } from '@cardano-sdk/util-rxjs';
|
|
8
8
|
import uniq from 'lodash/uniq';
|
|
9
9
|
const isIntersectionBlock = (block, intersection) => {
|
|
@@ -13,14 +13,15 @@ const isIntersectionBlock = (block, intersection) => {
|
|
|
13
13
|
return block.header.hash === intersection.point.hash;
|
|
14
14
|
};
|
|
15
15
|
const blocksToPoints = (blocks) => uniq([...blocks.map((p) => (p === 'origin' ? p : p.header)), 'origin']);
|
|
16
|
-
const
|
|
16
|
+
const pointDescription = (point) => point === 'origin' ? 'origin' : `slot ${point.slot}, block ${point.hash}`;
|
|
17
17
|
export const projectIntoSink = (props) => {
|
|
18
|
+
const logger = contextLogger(props.logger, 'Projector');
|
|
18
19
|
const syncFromIntersection = ({ intersection, chainSync$ }) => new Observable((observer) => {
|
|
19
|
-
|
|
20
|
+
logger.info(`Starting ChainSync from ${pointDescription(intersection.point)}`);
|
|
20
21
|
return chainSync$.pipe(withRolledBackBlock(props.sinks.buffer)).subscribe(observer);
|
|
21
22
|
});
|
|
22
23
|
const rollbackAndSyncFromIntersection = (initialChainSync, tail) => new Observable((subscriber) => {
|
|
23
|
-
|
|
24
|
+
logger.warn('Rolling back to find intersection');
|
|
24
25
|
let skipFindingNewIntersection = true;
|
|
25
26
|
let chainSync = initialChainSync;
|
|
26
27
|
const rollback$ = props.sinks.buffer.tip$.pipe(takeWhile((block) => block !== 'origin'), mergeMap((block) => {
|
|
@@ -28,37 +29,39 @@ export const projectIntoSink = (props) => {
|
|
|
28
29
|
skipFindingNewIntersection = false;
|
|
29
30
|
return of(block);
|
|
30
31
|
}
|
|
31
|
-
return props
|
|
32
|
-
.chainSync({
|
|
33
|
-
points: blocksToPoints([block, tail, 'origin'])
|
|
34
|
-
})
|
|
35
|
-
.pipe(tap((newChainSync) => {
|
|
32
|
+
return props.cardanoNode.findIntersect(blocksToPoints([block, tail, 'origin'])).pipe(take(1), tap((newChainSync) => {
|
|
36
33
|
chainSync = newChainSync;
|
|
37
34
|
}), map(() => block));
|
|
38
35
|
}), takeWhile((block) => !isIntersectionBlock(block, chainSync.intersection)), mergeMap((block) => of({
|
|
39
36
|
block,
|
|
40
37
|
eventType: ChainSyncEventType.RollBackward,
|
|
38
|
+
point: chainSync.intersection.point,
|
|
41
39
|
requestNext: noop,
|
|
42
40
|
tip: chainSync.intersection.tip
|
|
43
41
|
})));
|
|
44
42
|
return concat(rollback$, defer(() => syncFromIntersection(chainSync))).subscribe(subscriber);
|
|
45
43
|
});
|
|
46
|
-
const source$ = combineLatest([props.sinks.buffer.tip$, props.sinks.buffer.tail$]).pipe(take(1), mergeMap((blocks) =>
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
44
|
+
const source$ = combineLatest([props.sinks.buffer.tip$, props.sinks.buffer.tail$]).pipe(take(1), mergeMap((blocks) => {
|
|
45
|
+
const points = blocksToPoints(blocks);
|
|
46
|
+
logger.info(`Starting projector with local tip at ${pointDescription(points[0])}`);
|
|
47
|
+
return props.cardanoNode.findIntersect(points).pipe(take(1), mergeMap((initialChainSync) => {
|
|
48
|
+
if (initialChainSync.intersection.point === 'origin') {
|
|
49
|
+
if (blocks[0] !== 'origin') {
|
|
50
|
+
throw new CardanoNodeErrors.CardanoClientErrors.IntersectionNotFoundError(points.map((point) => point === 'origin'
|
|
51
|
+
? 'origin'
|
|
52
|
+
: {
|
|
53
|
+
hash: point.hash,
|
|
54
|
+
slot: point.slot
|
|
55
|
+
}));
|
|
56
|
+
}
|
|
57
|
+
return syncFromIntersection(initialChainSync);
|
|
58
|
+
}
|
|
59
|
+
if (blocks[0] !== 'origin' && initialChainSync.intersection.point.hash !== blocks[0].header.hash) {
|
|
60
|
+
return rollbackAndSyncFromIntersection(initialChainSync, blocks[1]);
|
|
54
61
|
}
|
|
55
62
|
return syncFromIntersection(initialChainSync);
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
return rollbackAndSyncFromIntersection(initialChainSync, blocks[1]);
|
|
59
|
-
}
|
|
60
|
-
return syncFromIntersection(initialChainSync);
|
|
61
|
-
}))), withNetworkInfo(props.networkInfo));
|
|
63
|
+
}));
|
|
64
|
+
}), withNetworkInfo(props.cardanoNode));
|
|
62
65
|
const projected$ = source$.pipe.apply(source$, combineProjections(props.projections));
|
|
63
66
|
const sinks = Object.keys(props.sinks.projectionSinks)
|
|
64
67
|
.filter((k) => k in props.projections)
|
|
@@ -66,8 +69,11 @@ export const projectIntoSink = (props) => {
|
|
|
66
69
|
return projected$.pipe(props.sinks.before || passthrough(), concatMap((evt) => {
|
|
67
70
|
const projectionSinks = sinks.map((sink) => sink.sink(evt));
|
|
68
71
|
const projectorEvent = evt;
|
|
69
|
-
const bufferSink$ =
|
|
72
|
+
const bufferSink$ = manageStabilityWindowBuffer(projectorEvent, props.sinks.buffer);
|
|
70
73
|
return combineLatest([...projectionSinks, bufferSink$].map((o$) => o$.pipe(defaultIfEmpty(null)))).pipe(map(() => projectorEvent));
|
|
71
|
-
}), props.sinks.after || passthrough(), tap((evt) =>
|
|
74
|
+
}), props.sinks.after || passthrough(), tap((evt) => {
|
|
75
|
+
logger.debug(`Processed event ${evt.eventType === ChainSyncEventType.RollForward ? 'RollForward' : 'RollBackward'} ${pointDescription(evt.block.header)}`);
|
|
76
|
+
evt.requestNext();
|
|
77
|
+
}), finalize(() => logger.info('Stopped')));
|
|
72
78
|
};
|
|
73
79
|
//# sourceMappingURL=projectIntoSink.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"projectIntoSink.js","sourceRoot":"","sources":["../../src/projectIntoSink.ts"],"names":[],"mappings":"AAGA,OAAO,
|
|
1
|
+
{"version":3,"file":"projectIntoSink.js","sourceRoot":"","sources":["../../src/projectIntoSink.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
import { BehaviorSubject, Observable } from 'rxjs';
|
|
2
2
|
import { Cardano } from '@cardano-sdk/core';
|
|
3
|
+
import { RollForwardEvent } from '../../types';
|
|
3
4
|
import { StabilityWindowBuffer } from '../types';
|
|
4
5
|
import { WithNetworkInfo } from '../../operators';
|
|
5
|
-
export declare class InMemoryStabilityWindowBuffer implements StabilityWindowBuffer {
|
|
6
|
+
export declare class InMemoryStabilityWindowBuffer<E extends WithNetworkInfo> implements StabilityWindowBuffer<E> {
|
|
6
7
|
#private;
|
|
7
8
|
readonly tip$: BehaviorSubject<"origin" | Cardano.Block>;
|
|
8
9
|
readonly tail$: BehaviorSubject<"origin" | Cardano.Block>;
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
addStabilityWindowBlock(block: Cardano.Block): Observable<void>;
|
|
10
|
+
deleteBlock(block: Cardano.Block): Observable<void>;
|
|
11
|
+
rollForward({ block, genesisParameters: { securityParameter } }: RollForwardEvent<WithNetworkInfo>): Observable<void>;
|
|
12
12
|
}
|
|
13
13
|
//# sourceMappingURL=InMemoryStabilityWindowBuffer.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"InMemoryStabilityWindowBuffer.d.ts","sourceRoot":"","sources":["../../../../src/sinks/inMemory/InMemoryStabilityWindowBuffer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAS,UAAU,EAAE,MAAM,MAAM,CAAC;AAC1D,OAAO,EAAE,OAAO,
|
|
1
|
+
{"version":3,"file":"InMemoryStabilityWindowBuffer.d.ts","sourceRoot":"","sources":["../../../../src/sinks/inMemory/InMemoryStabilityWindowBuffer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAS,UAAU,EAAE,MAAM,MAAM,CAAC;AAC1D,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAC5C,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAC/C,OAAO,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAElD,qBAAa,6BAA6B,CAAC,CAAC,SAAS,eAAe,CAAE,YAAW,qBAAqB,CAAC,CAAC,CAAC;;IAEvG,QAAQ,CAAC,IAAI,4CAA2D;IACxE,QAAQ,CAAC,KAAK,4CAA2D;IAEzE,WAAW,CAAC,KAAK,EAAE,OAAO,CAAC,KAAK,GAAG,UAAU,CAAC,IAAI,CAAC;IAcnD,WAAW,CAAC,EACV,KAAK,EACL,iBAAiB,EAAE,EAAE,iBAAiB,EAAE,EACzC,EAAE,gBAAgB,CAAC,eAAe,CAAC,GAAG,UAAU,CAAC,IAAI,CAAC;CAexD"}
|
|
@@ -1,27 +1,18 @@
|
|
|
1
|
-
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
|
|
2
|
-
if (kind === "m") throw new TypeError("Private method is not writable");
|
|
3
|
-
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
|
4
|
-
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
|
5
|
-
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
6
|
-
};
|
|
7
1
|
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
8
2
|
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
9
3
|
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
10
4
|
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
11
5
|
};
|
|
12
|
-
var _InMemoryStabilityWindowBuffer_instances,
|
|
6
|
+
var _InMemoryStabilityWindowBuffer_instances, _InMemoryStabilityWindowBuffer_blocks, _InMemoryStabilityWindowBuffer_setTail;
|
|
13
7
|
import { BehaviorSubject, EMPTY } from 'rxjs';
|
|
14
|
-
import { calculateStabilityWindowSlotsCount } from '@cardano-sdk/core';
|
|
15
8
|
export class InMemoryStabilityWindowBuffer {
|
|
16
|
-
constructor(
|
|
9
|
+
constructor() {
|
|
17
10
|
_InMemoryStabilityWindowBuffer_instances.add(this);
|
|
18
|
-
_InMemoryStabilityWindowBuffer_stabilityWindowSlotsCount.set(this, void 0);
|
|
19
11
|
_InMemoryStabilityWindowBuffer_blocks.set(this, []);
|
|
20
12
|
this.tip$ = new BehaviorSubject('origin');
|
|
21
13
|
this.tail$ = new BehaviorSubject('origin');
|
|
22
|
-
__classPrivateFieldSet(this, _InMemoryStabilityWindowBuffer_stabilityWindowSlotsCount, calculateStabilityWindowSlotsCount(genesisParameters), "f");
|
|
23
14
|
}
|
|
24
|
-
|
|
15
|
+
deleteBlock(block) {
|
|
25
16
|
for (let i = __classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_blocks, "f").length - 1; i >= 0; i--) {
|
|
26
17
|
const bufferBlock = __classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_blocks, "f")[i];
|
|
27
18
|
if (bufferBlock.header.hash === block.header.hash) {
|
|
@@ -34,9 +25,8 @@ export class InMemoryStabilityWindowBuffer {
|
|
|
34
25
|
__classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_instances, "m", _InMemoryStabilityWindowBuffer_setTail).call(this, newTail);
|
|
35
26
|
return EMPTY;
|
|
36
27
|
}
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
while (__classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_blocks, "f").length > 0 && __classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_blocks, "f")[0].header.slot.valueOf() < slotThreshold)
|
|
28
|
+
rollForward({ block, genesisParameters: { securityParameter } }) {
|
|
29
|
+
while (__classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_blocks, "f").length > securityParameter)
|
|
40
30
|
__classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_blocks, "f").shift();
|
|
41
31
|
__classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_blocks, "f").push(block);
|
|
42
32
|
this.tip$.next(block);
|
|
@@ -44,7 +34,7 @@ export class InMemoryStabilityWindowBuffer {
|
|
|
44
34
|
return EMPTY;
|
|
45
35
|
}
|
|
46
36
|
}
|
|
47
|
-
|
|
37
|
+
_InMemoryStabilityWindowBuffer_blocks = new WeakMap(), _InMemoryStabilityWindowBuffer_instances = new WeakSet(), _InMemoryStabilityWindowBuffer_setTail = function _InMemoryStabilityWindowBuffer_setTail(tail) {
|
|
48
38
|
if (this.tail$.value !== tail) {
|
|
49
39
|
this.tail$.next(tail);
|
|
50
40
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"InMemoryStabilityWindowBuffer.js","sourceRoot":"","sources":["../../../../src/sinks/inMemory/InMemoryStabilityWindowBuffer.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"InMemoryStabilityWindowBuffer.js","sourceRoot":"","sources":["../../../../src/sinks/inMemory/InMemoryStabilityWindowBuffer.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,eAAe,EAAE,KAAK,EAAc,MAAM,MAAM,CAAC;AAM1D,MAAM,OAAO,6BAA6B;IAA1C;;QACE,gDAAoC,EAAE,EAAC;QAC9B,SAAI,GAAG,IAAI,eAAe,CAA2B,QAAQ,CAAC,CAAC;QAC/D,UAAK,GAAG,IAAI,eAAe,CAA2B,QAAQ,CAAC,CAAC;IAkC3E,CAAC;IAhCC,WAAW,CAAC,KAAoB;QAC9B,KAAK,IAAI,CAAC,GAAG,uBAAA,IAAI,6CAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;YACjD,MAAM,WAAW,GAAG,uBAAA,IAAI,6CAAQ,CAAC,CAAC,CAAC,CAAC;YACpC,IAAI,WAAW,CAAC,MAAM,CAAC,IAAI,KAAK,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE;gBACjD,uBAAA,IAAI,6CAAQ,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;gBAC1B,MAAM;aACP;SACF;QACD,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,uBAAA,IAAI,6CAAQ,CAAC,uBAAA,IAAI,6CAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,IAAI,QAAQ,CAAC,CAAC;QAClE,MAAM,OAAO,GAAG,uBAAA,IAAI,6CAAQ,CAAC,CAAC,CAAC,IAAI,QAAQ,CAAC;QAC5C,uBAAA,IAAI,wFAAS,MAAb,IAAI,EAAU,OAAO,CAAC,CAAC;QACvB,OAAO,KAAK,CAAC;IACf,CAAC;IAED,WAAW,CAAC,EACV,KAAK,EACL,iBAAiB,EAAE,EAAE,iBAAiB,EAAE,EACN;QAElC,OAAO,uBAAA,IAAI,6CAAQ,CAAC,MAAM,GAAG,iBAAiB;YAAE,uBAAA,IAAI,6CAAQ,CAAC,KAAK,EAAE,CAAC;QAErE,uBAAA,IAAI,6CAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACzB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACtB,uBAAA,IAAI,wFAAS,MAAb,IAAI,EAAU,uBAAA,IAAI,6CAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/B,OAAO,KAAK,CAAC;IACf,CAAC;CAOF;0MALU,IAA8B;IACrC,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,KAAK,IAAI,EAAE;QAC7B,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;KACvB;AACH,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { AllProjections } from '../../projections';
|
|
2
|
+
import { InMemoryStore } from './types';
|
|
3
|
+
import { Sinks } from '../types';
|
|
4
|
+
export declare const createStore: () => InMemoryStore;
|
|
5
|
+
export declare const createSinks: (store: InMemoryStore) => Sinks<AllProjections>;
|
|
6
|
+
export declare type InMemorySinks = ReturnType<typeof createSinks>;
|
|
7
|
+
//# sourceMappingURL=create.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create.d.ts","sourceRoot":"","sources":["../../../../src/sinks/inMemory/create.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAEnD,OAAO,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AACxC,OAAO,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC;AAKjC,eAAO,MAAM,WAAW,QAAO,aAG7B,CAAC;AAEH,eAAO,MAAM,WAAW,UAAW,aAAa,KAAG,MAAM,cAAc,CAOrE,CAAC;AAEH,oBAAY,aAAa,GAAG,UAAU,CAAC,OAAO,WAAW,CAAC,CAAC"}
|
|
@@ -1,13 +1,17 @@
|
|
|
1
1
|
import { InMemoryStabilityWindowBuffer } from './InMemoryStabilityWindowBuffer';
|
|
2
|
-
import { withStaticContext } from '../../operators';
|
|
3
2
|
import { stakeKeys } from './stakeKeys';
|
|
4
3
|
import { stakePools } from './stakePools';
|
|
5
|
-
|
|
4
|
+
import { withStaticContext } from '../../operators';
|
|
5
|
+
export const createStore = () => ({
|
|
6
|
+
stakeKeys: new Set(),
|
|
7
|
+
stakePools: new Map()
|
|
8
|
+
});
|
|
9
|
+
export const createSinks = (store) => ({
|
|
6
10
|
before: withStaticContext({ store }),
|
|
7
|
-
buffer: new InMemoryStabilityWindowBuffer(
|
|
11
|
+
buffer: new InMemoryStabilityWindowBuffer(),
|
|
8
12
|
projectionSinks: {
|
|
9
13
|
stakeKeys,
|
|
10
14
|
stakePools
|
|
11
15
|
}
|
|
12
16
|
});
|
|
13
|
-
//# sourceMappingURL=
|
|
17
|
+
//# sourceMappingURL=create.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create.js","sourceRoot":"","sources":["../../../../src/sinks/inMemory/create.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,6BAA6B,EAAE,MAAM,iCAAiC,CAAC;AAGhF,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AAEpD,MAAM,CAAC,MAAM,WAAW,GAAG,GAAkB,EAAE,CAAC,CAAC;IAC/C,SAAS,EAAE,IAAI,GAAG,EAAE;IACpB,UAAU,EAAE,IAAI,GAAG,EAAE;CACtB,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,KAAoB,EAAyB,EAAE,CAAC,CAAC;IAC3E,MAAM,EAAE,iBAAiB,CAAC,EAAE,KAAK,EAAE,CAAC;IACpC,MAAM,EAAE,IAAI,6BAA6B,EAAE;IAC3C,eAAe,EAAE;QACf,SAAS;QACT,UAAU;KACX;CACF,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/sinks/inMemory/index.ts"],"names":[],"mappings":"AAAA,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/sinks/inMemory/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAC;AACzB,cAAc,iCAAiC,CAAC;AAChD,cAAc,SAAS,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/sinks/inMemory/index.ts"],"names":[],"mappings":"AAAA,cAAc,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/sinks/inMemory/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAC;AACzB,cAAc,iCAAiC,CAAC;AAChD,cAAc,SAAS,CAAC"}
|
|
@@ -18,7 +18,7 @@ export const stakePools = {
|
|
|
18
18
|
}
|
|
19
19
|
}
|
|
20
20
|
else {
|
|
21
|
-
const belowTip = ({ source }) => evt.
|
|
21
|
+
const belowTip = ({ source }) => evt.point !== 'origin' && source.slot < evt.block.header.slot;
|
|
22
22
|
for (const [_, stakePool] of evt.store.stakePools) {
|
|
23
23
|
stakePool.updates = stakePool.updates.filter(belowTip);
|
|
24
24
|
stakePool.retirements = stakePool.retirements.filter(belowTip);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"stakePools.js","sourceRoot":"","sources":["../../../../src/sinks/inMemory/stakePools.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAChE,OAAO,EAAE,KAAK,EAAE,MAAM,MAAM,CAAC;AAM7B,MAAM,YAAY,GAAG,CAAC,EAAE,KAAK,EAAE,EAAE,UAAU,EAAE,EAAqB,EAAE,MAAsB,EAAE,EAAE;IAC5F,IAAI,SAAS,GAAG,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IACvC,IAAI,CAAC,SAAS,EAAE;QACd,UAAU,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,SAAS,GAAG,EAAE,WAAW,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;KACxE;IACD,OAAO,SAAS,CAAC;AACnB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,UAAU,GAAkD;IACvE,IAAI,CAAC,GAAG;QACN,IAAI,GAAG,CAAC,SAAS,KAAK,kBAAkB,CAAC,WAAW,EAAE;YACpD,KAAK,MAAM,CAAC,MAAM,EAAE,WAAW,CAAC,IAAI,GAAG,CAAC,UAAU,CAAC,OAAO,EAAE;gBAC1D,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,WAAW,CAAC,CAAC;aACxD;YACD,KAAK,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,IAAI,GAAG,CAAC,UAAU,CAAC,WAAW,EAAE;gBAClE,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,eAAe,CAAC,CAAC;aAChE;SACF;aAAM;YAEL,MAAM,QAAQ,GAAG,CAAC,EAAE,MAAM,EAAyB,EAAE,EAAE,CACrD,GAAG,CAAC,
|
|
1
|
+
{"version":3,"file":"stakePools.js","sourceRoot":"","sources":["../../../../src/sinks/inMemory/stakePools.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAChE,OAAO,EAAE,KAAK,EAAE,MAAM,MAAM,CAAC;AAM7B,MAAM,YAAY,GAAG,CAAC,EAAE,KAAK,EAAE,EAAE,UAAU,EAAE,EAAqB,EAAE,MAAsB,EAAE,EAAE;IAC5F,IAAI,SAAS,GAAG,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IACvC,IAAI,CAAC,SAAS,EAAE;QACd,UAAU,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,SAAS,GAAG,EAAE,WAAW,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;KACxE;IACD,OAAO,SAAS,CAAC;AACnB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,UAAU,GAAkD;IACvE,IAAI,CAAC,GAAG;QACN,IAAI,GAAG,CAAC,SAAS,KAAK,kBAAkB,CAAC,WAAW,EAAE;YACpD,KAAK,MAAM,CAAC,MAAM,EAAE,WAAW,CAAC,IAAI,GAAG,CAAC,UAAU,CAAC,OAAO,EAAE;gBAC1D,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,WAAW,CAAC,CAAC;aACxD;YACD,KAAK,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,IAAI,GAAG,CAAC,UAAU,CAAC,WAAW,EAAE;gBAClE,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,eAAe,CAAC,CAAC;aAChE;SACF;aAAM;YAEL,MAAM,QAAQ,GAAG,CAAC,EAAE,MAAM,EAAyB,EAAE,EAAE,CACrD,GAAG,CAAC,KAAK,KAAK,QAAQ,IAAI,MAAM,CAAC,IAAI,GAAG,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC;YAChE,KAAK,MAAM,CAAC,CAAC,EAAE,SAAS,CAAC,IAAI,GAAG,CAAC,KAAK,CAAC,UAAU,EAAE;gBACjD,SAAS,CAAC,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;gBACvD,SAAS,CAAC,WAAW,GAAG,SAAS,CAAC,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;aAChE;SACF;QACD,OAAO,KAAK,CAAC;IACf,CAAC;CACF,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/sinks/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/sinks/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,OAAO,KAAK,QAAQ,MAAM,YAAY,CAAC;AACvC,cAAc,QAAQ,CAAC"}
|
package/dist/esm/sinks/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/sinks/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/sinks/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,OAAO,KAAK,QAAQ,MAAM,YAAY,CAAC;AACvC,cAAc,QAAQ,CAAC"}
|
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
import { Cardano } from '@cardano-sdk/core';
|
|
2
2
|
import { Observable } from 'rxjs';
|
|
3
3
|
import { ProjectionExtraProps } from '../projections';
|
|
4
|
-
import { UnifiedProjectorEvent } from '../types';
|
|
5
|
-
|
|
4
|
+
import { RollForwardEvent, UnifiedProjectorEvent } from '../types';
|
|
5
|
+
import { WithNetworkInfo } from '../operators';
|
|
6
|
+
export interface StabilityWindowBuffer<E extends WithNetworkInfo> {
|
|
6
7
|
tip$: Observable<Cardano.Block | 'origin'>;
|
|
7
8
|
tail$: Observable<Cardano.Block | 'origin'>;
|
|
8
|
-
|
|
9
|
-
|
|
9
|
+
rollForward(block: RollForwardEvent<E>): Observable<void>;
|
|
10
|
+
deleteBlock(evt: Cardano.Block): Observable<void>;
|
|
10
11
|
}
|
|
11
12
|
export interface Sink<P, SinkSpecificProps = {}> {
|
|
12
13
|
sink: (evt: UnifiedProjectorEvent<ProjectionExtraProps<P> & SinkSpecificProps>) => Observable<void>;
|
|
@@ -17,7 +18,7 @@ export declare type ProjectionSinks<Projections> = {
|
|
|
17
18
|
export declare type SinkLifecycleOperator = (evt$: Observable<any>) => Observable<any>;
|
|
18
19
|
export declare type Sinks<Projections> = {
|
|
19
20
|
projectionSinks: ProjectionSinks<Projections>;
|
|
20
|
-
buffer: StabilityWindowBuffer
|
|
21
|
+
buffer: StabilityWindowBuffer<WithNetworkInfo>;
|
|
21
22
|
before?: SinkLifecycleOperator;
|
|
22
23
|
after?: SinkLifecycleOperator;
|
|
23
24
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/sinks/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAC5C,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAClC,OAAO,EAAE,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;AACtD,OAAO,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/sinks/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAC5C,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAClC,OAAO,EAAE,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;AACtD,OAAO,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAC;AACnE,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAY/C,MAAM,WAAW,qBAAqB,CAAC,CAAC,SAAS,eAAe;IAM9D,IAAI,EAAE,UAAU,CAAC,OAAO,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC;IAK3C,KAAK,EAAE,UAAU,CAAC,OAAO,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC;IAK5C,WAAW,CAAC,KAAK,EAAE,gBAAgB,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC;IAS1D,WAAW,CAAC,GAAG,EAAE,OAAO,CAAC,KAAK,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC;CACnD;AAED,MAAM,WAAW,IAAI,CAAC,CAAC,EAAE,iBAAiB,GAAG,EAAE;IAC7C,IAAI,EAAE,CAAC,GAAG,EAAE,qBAAqB,CAAC,oBAAoB,CAAC,CAAC,CAAC,GAAG,iBAAiB,CAAC,KAAK,UAAU,CAAC,IAAI,CAAC,CAAC;CACrG;AAED,oBAAY,eAAe,CAAC,WAAW,IAAI;KACxC,CAAC,IAAI,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;CAC/C,CAAC;AAGF,oBAAY,qBAAqB,GAAG,CAAC,IAAI,EAAE,UAAU,CAAC,GAAG,CAAC,KAAK,UAAU,CAAC,GAAG,CAAC,CAAC;AAE/E,oBAAY,KAAK,CAAC,WAAW,IAAI;IAC/B,eAAe,EAAE,eAAe,CAAC,WAAW,CAAC,CAAC;IAC9C,MAAM,EAAE,qBAAqB,CAAC,eAAe,CAAC,CAAC;IAC/C,MAAM,CAAC,EAAE,qBAAqB,CAAC;IAC/B,KAAK,CAAC,EAAE,qBAAqB,CAAC;CAC/B,CAAC"}
|
package/dist/esm/sinks/util.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { StabilityWindowBuffer } from './types';
|
|
2
2
|
import { UnifiedProjectorEvent } from '../types';
|
|
3
|
-
|
|
3
|
+
import { WithNetworkInfo } from '../operators';
|
|
4
|
+
export declare const manageStabilityWindowBuffer: <T extends WithNetworkInfo>(evt: UnifiedProjectorEvent<T>, buffer: StabilityWindowBuffer<T>) => import("rxjs").Observable<void>;
|
|
4
5
|
//# sourceMappingURL=util.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../../src/sinks/util.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAC;AAChD,OAAO,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../../src/sinks/util.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAC;AAChD,OAAO,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAE/C,eAAO,MAAM,2BAA2B,iIAGyE,CAAC"}
|
package/dist/esm/sinks/util.js
CHANGED
|
@@ -1,5 +1,3 @@
|
|
|
1
1
|
import { ChainSyncEventType } from '@cardano-sdk/core';
|
|
2
|
-
export const
|
|
3
|
-
? buffer.addStabilityWindowBlock(evt.block)
|
|
4
|
-
: buffer.deleteStabilityWindowBlock(evt.block);
|
|
2
|
+
export const manageStabilityWindowBuffer = (evt, buffer) => (evt.eventType === ChainSyncEventType.RollForward ? buffer.rollForward(evt) : buffer.deleteBlock(evt.block));
|
|
5
3
|
//# sourceMappingURL=util.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../../src/sinks/util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;
|
|
1
|
+
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../../src/sinks/util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAKvD,MAAM,CAAC,MAAM,2BAA2B,GAAG,CACzC,GAA6B,EAC7B,MAAgC,EAChC,EAAE,CAAC,CAAC,GAAG,CAAC,SAAS,KAAK,kBAAkB,CAAC,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC"}
|