@cardano-sdk/projection 0.4.1-nightly.0 → 0.5.0-nightly.1
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/operators/certificates/withCertificates.d.ts.map +1 -1
- package/dist/cjs/operators/certificates/withCertificates.js +4 -1
- package/dist/cjs/operators/certificates/withCertificates.js.map +1 -1
- package/dist/cjs/operators/certificates/withStakeKeys.d.ts +2 -2
- package/dist/cjs/operators/certificates/withStakeKeys.d.ts.map +1 -1
- package/dist/cjs/operators/certificates/withStakeKeys.js +7 -3
- package/dist/cjs/operators/certificates/withStakeKeys.js.map +1 -1
- package/dist/cjs/projectIntoSink.d.ts +4 -4
- package/dist/cjs/projectIntoSink.d.ts.map +1 -1
- package/dist/cjs/projectIntoSink.js +70 -61
- package/dist/cjs/projectIntoSink.js.map +1 -1
- package/dist/cjs/sinks/inMemory/InMemoryStabilityWindowBuffer.d.ts +5 -4
- package/dist/cjs/sinks/inMemory/InMemoryStabilityWindowBuffer.d.ts.map +1 -1
- package/dist/cjs/sinks/inMemory/InMemoryStabilityWindowBuffer.js +20 -19
- package/dist/cjs/sinks/inMemory/InMemoryStabilityWindowBuffer.js.map +1 -1
- package/dist/cjs/sinks/inMemory/create.d.ts +2 -1
- package/dist/cjs/sinks/inMemory/create.d.ts.map +1 -1
- package/dist/cjs/sinks/inMemory/create.js +3 -1
- package/dist/cjs/sinks/inMemory/create.js.map +1 -1
- package/dist/cjs/sinks/inMemory/stakeKeys.d.ts.map +1 -1
- package/dist/cjs/sinks/inMemory/stakeKeys.js +3 -10
- package/dist/cjs/sinks/inMemory/stakeKeys.js.map +1 -1
- package/dist/cjs/sinks/index.d.ts +0 -1
- package/dist/cjs/sinks/index.d.ts.map +1 -1
- package/dist/cjs/sinks/index.js +0 -1
- package/dist/cjs/sinks/index.js.map +1 -1
- package/dist/cjs/sinks/types.d.ts +10 -4
- package/dist/cjs/sinks/types.d.ts.map +1 -1
- package/dist/cjs/tsconfig.tsbuildinfo +1 -1
- package/dist/esm/operators/certificates/withCertificates.d.ts.map +1 -1
- package/dist/esm/operators/certificates/withCertificates.js +4 -1
- package/dist/esm/operators/certificates/withCertificates.js.map +1 -1
- package/dist/esm/operators/certificates/withStakeKeys.d.ts +2 -2
- package/dist/esm/operators/certificates/withStakeKeys.d.ts.map +1 -1
- package/dist/esm/operators/certificates/withStakeKeys.js +8 -4
- package/dist/esm/operators/certificates/withStakeKeys.js.map +1 -1
- package/dist/esm/projectIntoSink.d.ts +4 -4
- package/dist/esm/projectIntoSink.d.ts.map +1 -1
- package/dist/esm/projectIntoSink.js +70 -61
- package/dist/esm/projectIntoSink.js.map +1 -1
- package/dist/esm/sinks/inMemory/InMemoryStabilityWindowBuffer.d.ts +5 -4
- package/dist/esm/sinks/inMemory/InMemoryStabilityWindowBuffer.d.ts.map +1 -1
- package/dist/esm/sinks/inMemory/InMemoryStabilityWindowBuffer.js +21 -20
- package/dist/esm/sinks/inMemory/InMemoryStabilityWindowBuffer.js.map +1 -1
- package/dist/esm/sinks/inMemory/create.d.ts +2 -1
- package/dist/esm/sinks/inMemory/create.d.ts.map +1 -1
- package/dist/esm/sinks/inMemory/create.js +1 -0
- package/dist/esm/sinks/inMemory/create.js.map +1 -1
- package/dist/esm/sinks/inMemory/stakeKeys.d.ts.map +1 -1
- package/dist/esm/sinks/inMemory/stakeKeys.js +3 -10
- package/dist/esm/sinks/inMemory/stakeKeys.js.map +1 -1
- package/dist/esm/sinks/index.d.ts +0 -1
- package/dist/esm/sinks/index.d.ts.map +1 -1
- package/dist/esm/sinks/index.js +0 -1
- package/dist/esm/sinks/index.js.map +1 -1
- package/dist/esm/sinks/types.d.ts +10 -4
- package/dist/esm/sinks/types.d.ts.map +1 -1
- package/dist/esm/tsconfig.tsbuildinfo +1 -1
- package/package.json +8 -8
- package/dist/cjs/sinks/util.d.ts +0 -5
- package/dist/cjs/sinks/util.d.ts.map +0 -1
- package/dist/cjs/sinks/util.js +0 -7
- package/dist/cjs/sinks/util.js.map +0 -1
- package/dist/esm/sinks/util.d.ts +0 -5
- package/dist/esm/sinks/util.d.ts.map +0 -1
- package/dist/esm/sinks/util.js +0 -3
- package/dist/esm/sinks/util.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"withCertificates.d.ts","sourceRoot":"","sources":["../../../../src/operators/certificates/withCertificates.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAC5C,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAGxC,MAAM,WAAW,kBAAkB;IACjC,IAAI,EAAE,OAAO,CAAC,IAAI,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,kBAAkB;IACjC,OAAO,EAAE,kBAAkB,CAAC;IAC5B,WAAW,EAAE,OAAO,CAAC,WAAW,CAAC;CAClC;AAED,MAAM,WAAW,gBAAgB;IAI/B,YAAY,EAAE,kBAAkB,EAAE,CAAC;CACpC;
|
|
1
|
+
{"version":3,"file":"withCertificates.d.ts","sourceRoot":"","sources":["../../../../src/operators/certificates/withCertificates.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAC5C,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAGxC,MAAM,WAAW,kBAAkB;IACjC,IAAI,EAAE,OAAO,CAAC,IAAI,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,kBAAkB;IACjC,OAAO,EAAE,kBAAkB,CAAC;IAC5B,WAAW,EAAE,OAAO,CAAC,WAAW,CAAC;CAClC;AAED,MAAM,WAAW,gBAAgB;IAI/B,YAAY,EAAE,kBAAkB,EAAE,CAAC;CACpC;AAwBD,eAAO,MAAM,gBAAgB,8OAG1B,CAAC"}
|
|
@@ -1,8 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.withCertificates = void 0;
|
|
4
|
+
const core_1 = require("@cardano-sdk/core");
|
|
4
5
|
const utils_1 = require("../utils");
|
|
5
|
-
const blockCertificates = ({ block: { header: { slot }, body } }) => body
|
|
6
|
+
const blockCertificates = ({ block: { header: { slot }, body } }) => body
|
|
7
|
+
.filter((tx) => !core_1.Cardano.util.isPhase2ValidationErrTx(tx))
|
|
8
|
+
.flatMap(({ body: { certificates = [] } }, txIndex) => certificates.map((certificate, certIndex) => ({
|
|
6
9
|
certificate,
|
|
7
10
|
pointer: {
|
|
8
11
|
certIndex,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"withCertificates.js","sourceRoot":"","sources":["../../../../src/operators/certificates/withCertificates.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"withCertificates.js","sourceRoot":"","sources":["../../../../src/operators/certificates/withCertificates.ts"],"names":[],"mappings":";;;AAAA,4CAA4C;AAE5C,oCAAoD;AAoBpD,MAAM,iBAAiB,GAAG,CAAC,EACzB,KAAK,EAAE,EACL,MAAM,EAAE,EAAE,IAAI,EAAE,EAChB,IAAI,EACL,EACS,EAAE,EAAE,CACd,IAAI;KACD,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,cAAO,CAAC,IAAI,CAAC,uBAAuB,CAAC,EAAE,CAAC,CAAC;KACzD,OAAO,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,YAAY,GAAG,EAAE,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,CACpD,YAAY,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC;IAC5C,WAAW;IACX,OAAO,EAAE;QACP,SAAS;QACT,IAAI;QACJ,OAAO;KACR;CACF,CAAC,CAAC,CACJ,CAAC;AAKO,QAAA,gBAAgB,GAAG,IAAA,gCAAwB,EAAuB,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;IACvF,GAAG,GAAG;IACN,YAAY,EAAE,iBAAiB,CAAC,GAAG,CAAC;CACrC,CAAC,CAAC,CAAC"}
|
|
@@ -2,8 +2,8 @@ import * as Crypto from '@cardano-sdk/crypto';
|
|
|
2
2
|
import { WithCertificates } from './withCertificates';
|
|
3
3
|
export interface WithStakeKeys {
|
|
4
4
|
stakeKeys: {
|
|
5
|
-
|
|
6
|
-
|
|
5
|
+
insert: Crypto.Ed25519KeyHashHex[];
|
|
6
|
+
del: Crypto.Ed25519KeyHashHex[];
|
|
7
7
|
};
|
|
8
8
|
}
|
|
9
9
|
export declare const withStakeKeys: <SourceExtraRollForwardPropsIn extends WithCertificates, SourceExtraRollBackwardPropsIn extends WithCertificates & import("../..").WithBlock>() => import("../..").ProjectorOperator<SourceExtraRollForwardPropsIn, SourceExtraRollBackwardPropsIn, WithStakeKeys, WithStakeKeys>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"withStakeKeys.d.ts","sourceRoot":"","sources":["../../../../src/operators/certificates/withStakeKeys.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,qBAAqB,CAAC;AAE9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAGtD,MAAM,WAAW,aAAa;IAC5B,SAAS,EAAE;QACT,
|
|
1
|
+
{"version":3,"file":"withStakeKeys.d.ts","sourceRoot":"","sources":["../../../../src/operators/certificates/withStakeKeys.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,qBAAqB,CAAC;AAE9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAGtD,MAAM,WAAW,aAAa;IAC5B,SAAS,EAAE;QACT,MAAM,EAAE,MAAM,CAAC,iBAAiB,EAAE,CAAC;QACnC,GAAG,EAAE,MAAM,CAAC,iBAAiB,EAAE,CAAC;KACjC,CAAC;CACH;AAYD,eAAO,MAAM,aAAa,mRAgCxB,CAAC"}
|
|
@@ -6,7 +6,7 @@ const utils_1 = require("../utils");
|
|
|
6
6
|
exports.withStakeKeys = (0, utils_1.unifiedProjectorOperator)((evt) => {
|
|
7
7
|
const register = new Set();
|
|
8
8
|
const deregister = new Set();
|
|
9
|
-
for (const { certificate } of evt.certificates)
|
|
9
|
+
for (const { certificate } of evt.certificates) {
|
|
10
10
|
switch (certificate.__typename) {
|
|
11
11
|
case core_1.Cardano.CertificateType.StakeKeyRegistration:
|
|
12
12
|
if (deregister.has(certificate.stakeKeyHash)) {
|
|
@@ -25,11 +25,15 @@ exports.withStakeKeys = (0, utils_1.unifiedProjectorOperator)((evt) => {
|
|
|
25
25
|
}
|
|
26
26
|
break;
|
|
27
27
|
}
|
|
28
|
+
}
|
|
29
|
+
const [insert, del] = evt.eventType === core_1.ChainSyncEventType.RollForward
|
|
30
|
+
? [[...register], [...deregister]]
|
|
31
|
+
: [[...deregister], [...register]];
|
|
28
32
|
return {
|
|
29
33
|
...evt,
|
|
30
34
|
stakeKeys: {
|
|
31
|
-
|
|
32
|
-
|
|
35
|
+
del,
|
|
36
|
+
insert
|
|
33
37
|
}
|
|
34
38
|
};
|
|
35
39
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"withStakeKeys.js","sourceRoot":"","sources":["../../../../src/operators/certificates/withStakeKeys.ts"],"names":[],"mappings":";;;AACA,
|
|
1
|
+
{"version":3,"file":"withStakeKeys.js","sourceRoot":"","sources":["../../../../src/operators/certificates/withStakeKeys.ts"],"names":[],"mappings":";;;AACA,4CAAgE;AAEhE,oCAAoD;AAmBvC,QAAA,aAAa,GAAG,IAAA,gCAAwB,EAAkC,CAAC,GAAG,EAAE,EAAE;IAC7F,MAAM,QAAQ,GAAG,IAAI,GAAG,EAA4B,CAAC;IACrD,MAAM,UAAU,GAAG,IAAI,GAAG,EAA4B,CAAC;IACvD,KAAK,MAAM,EAAE,WAAW,EAAE,IAAI,GAAG,CAAC,YAAY,EAAE;QAC9C,QAAQ,WAAW,CAAC,UAAU,EAAE;YAC9B,KAAK,cAAO,CAAC,eAAe,CAAC,oBAAoB;gBAC/C,IAAI,UAAU,CAAC,GAAG,CAAC,WAAW,CAAC,YAAY,CAAC,EAAE;oBAC5C,UAAU,CAAC,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;iBAC7C;qBAAM;oBACL,QAAQ,CAAC,GAAG,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;iBACxC;gBACD,MAAM;YACR,KAAK,cAAO,CAAC,eAAe,CAAC,sBAAsB;gBACjD,IAAI,QAAQ,CAAC,GAAG,CAAC,WAAW,CAAC,YAAY,CAAC,EAAE;oBAC1C,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;iBAC3C;qBAAM;oBACL,UAAU,CAAC,GAAG,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;iBAC1C;gBACD,MAAM;SACT;KACF;IACD,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GACjB,GAAG,CAAC,SAAS,KAAK,yBAAkB,CAAC,WAAW;QAC9C,CAAC,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC;IACvC,OAAO;QACL,GAAG,GAAG;QACN,SAAS,EAAE;YACT,GAAG;YACH,MAAM;SACP;KACF,CAAC;AACJ,CAAC,CAAC,CAAC"}
|
|
@@ -2,11 +2,11 @@ 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
|
-
import {
|
|
5
|
+
import { SinksFactory } from './sinks';
|
|
6
6
|
import { UnifiedProjectorEvent } from './types';
|
|
7
7
|
export interface ProjectIntoSinkProps<P, PS extends P> {
|
|
8
8
|
projections: P;
|
|
9
|
-
|
|
9
|
+
sinksFactory: SinksFactory<PS>;
|
|
10
10
|
cardanoNode: ObservableCardanoNode;
|
|
11
11
|
logger: Logger;
|
|
12
12
|
}
|
|
@@ -14,7 +14,7 @@ declare type ProjectionTypes<P> = {
|
|
|
14
14
|
[k in keyof P]: P[k] extends Projection<infer Props> ? Props : never;
|
|
15
15
|
};
|
|
16
16
|
declare type UnionToIntersection<U> = (U extends any ? (k: U) => void : never) extends (k: infer I) => void ? I : never;
|
|
17
|
-
declare type ProjectionsEvent<P extends object> = UnifiedProjectorEvent<UnionToIntersection<ProjectionTypes<P>[keyof P]>>;
|
|
18
|
-
export declare const projectIntoSink: <P extends object, PS extends P>(
|
|
17
|
+
export declare type ProjectionsEvent<P extends object> = UnifiedProjectorEvent<UnionToIntersection<ProjectionTypes<P>[keyof P]>>;
|
|
18
|
+
export declare const projectIntoSink: <P extends object, PS extends P>({ cardanoNode, logger: baseLogger, projections, sinksFactory }: ProjectIntoSinkProps<P, PS>) => Observable<ProjectionsEvent<P>>;
|
|
19
19
|
export {};
|
|
20
20
|
//# sourceMappingURL=projectIntoSink.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
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,
|
|
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,EAAe,YAAY,EAAE,MAAM,SAAS,CAAC;AACpD,OAAO,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAC;AAOhD,MAAM,WAAW,oBAAoB,CAAC,CAAC,EAAE,EAAE,SAAS,CAAC;IACnD,WAAW,EAAE,CAAC,CAAC;IACf,YAAY,EAAE,YAAY,CAAC,EAAE,CAAC,CAAC;IAC/B,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,oBAAY,gBAAgB,CAAC,CAAC,SAAS,MAAM,IAAI,qBAAqB,CACpE,mBAAmB,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CACjD,CAAC;AA+IF,eAAO,MAAM,eAAe,kKAuC3B,CAAC"}
|
|
@@ -6,7 +6,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
6
6
|
exports.projectIntoSink = void 0;
|
|
7
7
|
const core_1 = require("@cardano-sdk/core");
|
|
8
8
|
const rxjs_1 = require("rxjs");
|
|
9
|
-
const sinks_1 = require("./sinks");
|
|
10
9
|
const operators_1 = require("./operators");
|
|
11
10
|
const combineProjections_1 = require("./combineProjections");
|
|
12
11
|
const util_1 = require("@cardano-sdk/util");
|
|
@@ -20,67 +19,77 @@ const isIntersectionBlock = (block, intersection) => {
|
|
|
20
19
|
};
|
|
21
20
|
const blocksToPoints = (blocks) => (0, uniq_1.default)([...blocks.map((p) => (p === 'origin' ? p : p.header)), 'origin']);
|
|
22
21
|
const pointDescription = (point) => point === 'origin' ? 'origin' : `slot ${point.slot}, block ${point.hash}`;
|
|
23
|
-
const
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
22
|
+
const syncFromIntersection = ({ chainSync: { intersection, chainSync$ }, logger, sinks }) => new rxjs_1.Observable((observer) => {
|
|
23
|
+
logger.info(`Starting ChainSync from ${pointDescription(intersection.point)}`);
|
|
24
|
+
return chainSync$.pipe((0, operators_1.withRolledBackBlock)(sinks.buffer)).subscribe(observer);
|
|
25
|
+
});
|
|
26
|
+
const rollbackAndSyncFromIntersection = ({ sinks, cardanoNode, initialChainSync, logger, tail }) => new rxjs_1.Observable((subscriber) => {
|
|
27
|
+
logger.warn('Rolling back to find intersection');
|
|
28
|
+
let skipFindingNewIntersection = true;
|
|
29
|
+
let chainSync = initialChainSync;
|
|
30
|
+
const rollback$ = sinks.buffer.tip$.pipe((0, rxjs_1.takeWhile)((block) => block !== 'origin'), (0, rxjs_1.mergeMap)((block) => {
|
|
31
|
+
if (skipFindingNewIntersection) {
|
|
32
|
+
skipFindingNewIntersection = false;
|
|
33
|
+
return (0, rxjs_1.of)(block);
|
|
34
|
+
}
|
|
35
|
+
return cardanoNode.findIntersect(blocksToPoints([block, tail, 'origin'])).pipe((0, rxjs_1.take)(1), (0, rxjs_1.tap)((newChainSync) => {
|
|
36
|
+
chainSync = newChainSync;
|
|
37
|
+
}), (0, rxjs_1.map)(() => block));
|
|
38
|
+
}), (0, rxjs_1.takeWhile)((block) => !isIntersectionBlock(block, chainSync.intersection)), (0, rxjs_1.mergeMap)((block) => (0, rxjs_1.of)({
|
|
39
|
+
block,
|
|
40
|
+
eventType: core_1.ChainSyncEventType.RollBackward,
|
|
41
|
+
point: chainSync.intersection.point,
|
|
42
|
+
requestNext: rxjs_1.noop,
|
|
43
|
+
tip: chainSync.intersection.tip
|
|
44
|
+
})));
|
|
45
|
+
return (0, rxjs_1.concat)(rollback$, (0, rxjs_1.defer)(() => syncFromIntersection({ chainSync, logger, sinks }))).subscribe(subscriber);
|
|
46
|
+
});
|
|
47
|
+
const createChainSyncSource = ({ sinks, logger, cardanoNode }) => (0, rxjs_1.combineLatest)([sinks.buffer.tip$, sinks.buffer.tail$]).pipe((0, rxjs_1.take)(1), (0, rxjs_1.mergeMap)((blocks) => {
|
|
48
|
+
const points = blocksToPoints(blocks);
|
|
49
|
+
logger.info(`Starting projector with local tip at ${pointDescription(points[0])}`);
|
|
50
|
+
return cardanoNode.findIntersect(points).pipe((0, rxjs_1.take)(1), (0, rxjs_1.mergeMap)((initialChainSync) => {
|
|
51
|
+
if (initialChainSync.intersection.point === 'origin') {
|
|
52
|
+
if (blocks[0] !== 'origin') {
|
|
53
|
+
throw new core_1.CardanoNodeErrors.CardanoClientErrors.IntersectionNotFoundError(points.map((point) => point === 'origin'
|
|
54
|
+
? 'origin'
|
|
55
|
+
: {
|
|
56
|
+
hash: point.hash,
|
|
57
|
+
slot: point.slot
|
|
58
|
+
}));
|
|
37
59
|
}
|
|
38
|
-
return
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
}));
|
|
70
|
-
})
|
|
71
|
-
const projected$ = source$.pipe.apply(source$, (0, combineProjections_1.combineProjections)(props.projections));
|
|
72
|
-
const sinks = Object.keys(props.sinks.projectionSinks)
|
|
73
|
-
.filter((k) => k in props.projections)
|
|
74
|
-
.map((k) => props.sinks.projectionSinks[k]);
|
|
75
|
-
return projected$.pipe(props.sinks.before || (0, util_rxjs_1.passthrough)(), (0, rxjs_1.concatMap)((evt) => {
|
|
76
|
-
const projectionSinks = sinks.map((sink) => sink.sink(evt));
|
|
77
|
-
const projectorEvent = evt;
|
|
78
|
-
const bufferSink$ = (0, sinks_1.manageStabilityWindowBuffer)(projectorEvent, props.sinks.buffer);
|
|
79
|
-
return (0, rxjs_1.combineLatest)([...projectionSinks, bufferSink$].map((o$) => o$.pipe((0, rxjs_1.defaultIfEmpty)(null)))).pipe((0, rxjs_1.map)(() => projectorEvent));
|
|
80
|
-
}), props.sinks.after || (0, util_rxjs_1.passthrough)(), (0, rxjs_1.tap)((evt) => {
|
|
81
|
-
logger.debug(`Processed event ${evt.eventType === core_1.ChainSyncEventType.RollForward ? 'RollForward' : 'RollBackward'} ${pointDescription(evt.block.header)}`);
|
|
82
|
-
evt.requestNext();
|
|
83
|
-
}), (0, rxjs_1.finalize)(() => logger.info('Stopped')));
|
|
60
|
+
return syncFromIntersection({ chainSync: initialChainSync, logger, sinks });
|
|
61
|
+
}
|
|
62
|
+
if (blocks[0] !== 'origin' && initialChainSync.intersection.point.hash !== blocks[0].header.hash) {
|
|
63
|
+
return rollbackAndSyncFromIntersection({
|
|
64
|
+
cardanoNode,
|
|
65
|
+
initialChainSync,
|
|
66
|
+
logger,
|
|
67
|
+
sinks,
|
|
68
|
+
tail: blocks[1]
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
return syncFromIntersection({ chainSync: initialChainSync, logger, sinks });
|
|
72
|
+
}));
|
|
73
|
+
}), (0, operators_1.withNetworkInfo)(cardanoNode));
|
|
74
|
+
const projectIntoSink = ({ cardanoNode, logger: baseLogger, projections, sinksFactory }) => {
|
|
75
|
+
const logger = (0, util_1.contextLogger)(baseLogger, 'Projector');
|
|
76
|
+
return (0, rxjs_1.defer)(() => (0, rxjs_1.of)(sinksFactory())).pipe((0, rxjs_1.mergeMap)((sinks) => {
|
|
77
|
+
const source$ = createChainSyncSource({ cardanoNode, logger, sinks });
|
|
78
|
+
const projected$ = source$.pipe.apply(source$, (0, combineProjections_1.combineProjections)(projections));
|
|
79
|
+
const selectedSinks = Object.keys(sinks.projectionSinks)
|
|
80
|
+
.filter((k) => k in projections)
|
|
81
|
+
.map((k) => sinks.projectionSinks[k]);
|
|
82
|
+
return projected$.pipe(sinks.before || (0, util_rxjs_1.passthrough)(), (0, rxjs_1.concatMap)((evt) => {
|
|
83
|
+
const projectionSinks = selectedSinks.map((sink) => sink.sink(evt));
|
|
84
|
+
const projectorEvent = evt;
|
|
85
|
+
return projectionSinks.length > 0
|
|
86
|
+
? (0, rxjs_1.combineLatest)(projectionSinks.map((o$) => o$.pipe((0, rxjs_1.defaultIfEmpty)(null)))).pipe((0, rxjs_1.map)(() => projectorEvent))
|
|
87
|
+
: (0, rxjs_1.of)(projectorEvent);
|
|
88
|
+
}), sinks.buffer.handleEvents, sinks.after || (0, util_rxjs_1.passthrough)(), (0, rxjs_1.tap)((evt) => {
|
|
89
|
+
logger.debug(`Processed event ${evt.eventType === core_1.ChainSyncEventType.RollForward ? 'RollForward' : 'RollBackward'} ${pointDescription(evt.block.header)}`);
|
|
90
|
+
evt.requestNext();
|
|
91
|
+
}), (0, rxjs_1.finalize)(() => logger.info('Stopped')));
|
|
92
|
+
}));
|
|
84
93
|
};
|
|
85
94
|
exports.projectIntoSink = projectIntoSink;
|
|
86
95
|
//# sourceMappingURL=projectIntoSink.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"projectIntoSink.js","sourceRoot":"","sources":["../../src/projectIntoSink.ts"],"names":[],"mappings":";;;;;;AAGA,4CAQ2B;AAE3B,+BAec;
|
|
1
|
+
{"version":3,"file":"projectIntoSink.js","sourceRoot":"","sources":["../../src/projectIntoSink.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,13 +1,14 @@
|
|
|
1
|
-
import { BehaviorSubject
|
|
1
|
+
import { BehaviorSubject } from 'rxjs';
|
|
2
2
|
import { Cardano } from '@cardano-sdk/core';
|
|
3
|
-
import { RollForwardEvent } from '../../types';
|
|
4
3
|
import { StabilityWindowBuffer } from '../types';
|
|
4
|
+
import { UnifiedProjectorOperator } from '../../types';
|
|
5
5
|
import { WithNetworkInfo } from '../../operators';
|
|
6
6
|
export declare class InMemoryStabilityWindowBuffer<E extends WithNetworkInfo> implements StabilityWindowBuffer<E> {
|
|
7
7
|
#private;
|
|
8
8
|
readonly tip$: BehaviorSubject<"origin" | Cardano.Block>;
|
|
9
9
|
readonly tail$: BehaviorSubject<"origin" | Cardano.Block>;
|
|
10
|
-
|
|
11
|
-
|
|
10
|
+
readonly handleEvents: UnifiedProjectorOperator<E, E>;
|
|
11
|
+
constructor();
|
|
12
|
+
shutdown(): void;
|
|
12
13
|
}
|
|
13
14
|
//# 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,
|
|
1
|
+
{"version":3,"file":"InMemoryStabilityWindowBuffer.d.ts","sourceRoot":"","sources":["../../../../src/sinks/inMemory/InMemoryStabilityWindowBuffer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAO,MAAM,MAAM,CAAC;AAC5C,OAAO,EAAE,OAAO,EAAsB,MAAM,mBAAmB,CAAC;AAChE,OAAO,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAC;AACjD,OAAO,EAAE,wBAAwB,EAAE,MAAM,aAAa,CAAC;AACvD,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;IACzE,QAAQ,CAAC,YAAY,EAAE,wBAAwB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;;IAyBtD,QAAQ,IAAI,IAAI;CAUjB"}
|
|
@@ -8,33 +8,34 @@ var _InMemoryStabilityWindowBuffer_instances, _InMemoryStabilityWindowBuffer_blo
|
|
|
8
8
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
9
|
exports.InMemoryStabilityWindowBuffer = void 0;
|
|
10
10
|
const rxjs_1 = require("rxjs");
|
|
11
|
+
const core_1 = require("@cardano-sdk/core");
|
|
11
12
|
class InMemoryStabilityWindowBuffer {
|
|
12
13
|
constructor() {
|
|
13
14
|
_InMemoryStabilityWindowBuffer_instances.add(this);
|
|
14
15
|
_InMemoryStabilityWindowBuffer_blocks.set(this, []);
|
|
15
16
|
this.tip$ = new rxjs_1.BehaviorSubject('origin');
|
|
16
17
|
this.tail$ = new rxjs_1.BehaviorSubject('origin');
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
18
|
+
this.handleEvents = (evt$) => evt$.pipe((0, rxjs_1.tap)(({ eventType, block, genesisParameters: { securityParameter } }) => {
|
|
19
|
+
if (eventType === core_1.ChainSyncEventType.RollForward) {
|
|
20
|
+
while (__classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_blocks, "f").length > securityParameter)
|
|
21
|
+
__classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_blocks, "f").shift();
|
|
22
|
+
__classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_blocks, "f").push(block);
|
|
23
|
+
this.tip$.next(block);
|
|
24
|
+
__classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_instances, "m", _InMemoryStabilityWindowBuffer_setTail).call(this, __classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_blocks, "f")[0]);
|
|
25
|
+
}
|
|
26
|
+
else if (eventType === core_1.ChainSyncEventType.RollBackward) {
|
|
27
|
+
const lastBlock = __classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_blocks, "f").pop();
|
|
28
|
+
if (lastBlock?.header.hash !== block.header.hash) {
|
|
29
|
+
throw new Error('Assert: inconsistent stability window buffer at RollBackward');
|
|
30
|
+
}
|
|
31
|
+
this.tip$.next(__classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_blocks, "f")[__classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_blocks, "f").length - 1] || 'origin');
|
|
32
|
+
__classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_instances, "m", _InMemoryStabilityWindowBuffer_setTail).call(this, __classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_blocks, "f")[0] || 'origin');
|
|
24
33
|
}
|
|
25
|
-
}
|
|
26
|
-
this.tip$.next(__classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_blocks, "f")[__classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_blocks, "f").length - 1] || 'origin');
|
|
27
|
-
const newTail = __classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_blocks, "f")[0] || 'origin';
|
|
28
|
-
__classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_instances, "m", _InMemoryStabilityWindowBuffer_setTail).call(this, newTail);
|
|
29
|
-
return rxjs_1.EMPTY;
|
|
34
|
+
}));
|
|
30
35
|
}
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
__classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_blocks, "f").push(block);
|
|
35
|
-
this.tip$.next(block);
|
|
36
|
-
__classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_instances, "m", _InMemoryStabilityWindowBuffer_setTail).call(this, __classPrivateFieldGet(this, _InMemoryStabilityWindowBuffer_blocks, "f")[0]);
|
|
37
|
-
return rxjs_1.EMPTY;
|
|
36
|
+
shutdown() {
|
|
37
|
+
this.tip$.complete();
|
|
38
|
+
this.tail$.complete();
|
|
38
39
|
}
|
|
39
40
|
}
|
|
40
41
|
exports.InMemoryStabilityWindowBuffer = InMemoryStabilityWindowBuffer;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"InMemoryStabilityWindowBuffer.js","sourceRoot":"","sources":["../../../../src/sinks/inMemory/InMemoryStabilityWindowBuffer.ts"],"names":[],"mappings":";;;;;;;;;AAAA,+
|
|
1
|
+
{"version":3,"file":"InMemoryStabilityWindowBuffer.js","sourceRoot":"","sources":["../../../../src/sinks/inMemory/InMemoryStabilityWindowBuffer.ts"],"names":[],"mappings":";;;;;;;;;AAAA,+BAA4C;AAC5C,4CAAgE;AAKhE,MAAa,6BAA6B;IAMxC;;QALA,gDAAoC,EAAE,EAAC;QAC9B,SAAI,GAAG,IAAI,sBAAe,CAA2B,QAAQ,CAAC,CAAC;QAC/D,UAAK,GAAG,IAAI,sBAAe,CAA2B,QAAQ,CAAC,CAAC;QAIvE,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,EAAE,EAAE,CAC3B,IAAI,CAAC,IAAI,CACP,IAAA,UAAG,EAAC,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,iBAAiB,EAAE,EAAE,iBAAiB,EAAE,EAAE,EAAE,EAAE;YACrE,IAAI,SAAS,KAAK,yBAAkB,CAAC,WAAW,EAAE;gBAEhD,OAAO,uBAAA,IAAI,6CAAQ,CAAC,MAAM,GAAG,iBAAiB;oBAAE,uBAAA,IAAI,6CAAQ,CAAC,KAAK,EAAE,CAAC;gBAErE,uBAAA,IAAI,6CAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBACzB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBACtB,uBAAA,IAAI,wFAAS,MAAb,IAAI,EAAU,uBAAA,IAAI,6CAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;aAChC;iBAAM,IAAI,SAAS,KAAK,yBAAkB,CAAC,YAAY,EAAE;gBACxD,MAAM,SAAS,GAAG,uBAAA,IAAI,6CAAQ,CAAC,GAAG,EAAE,CAAC;gBACrC,IAAI,SAAS,EAAE,MAAM,CAAC,IAAI,KAAK,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE;oBAChD,MAAM,IAAI,KAAK,CAAC,8DAA8D,CAAC,CAAC;iBACjF;gBACD,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,uBAAA,IAAI,6CAAQ,CAAC,uBAAA,IAAI,6CAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,IAAI,QAAQ,CAAC,CAAC;gBAClE,uBAAA,IAAI,wFAAS,MAAb,IAAI,EAAU,uBAAA,IAAI,6CAAQ,CAAC,CAAC,CAAC,IAAI,QAAQ,CAAC,CAAC;aAC5C;QACH,CAAC,CAAC,CACH,CAAC;IACN,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;QACrB,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;IACxB,CAAC;CAOF;AAvCD,sEAuCC;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"}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { AllProjections } from '../../projections';
|
|
2
2
|
import { InMemoryStore } from './types';
|
|
3
|
-
import { Sinks } from '../types';
|
|
3
|
+
import { Sinks, SinksFactory } from '../types';
|
|
4
4
|
export declare const createStore: () => InMemoryStore;
|
|
5
5
|
export declare const createSinks: (store: InMemoryStore) => Sinks<AllProjections>;
|
|
6
|
+
export declare const createSinksFactory: (store: InMemoryStore) => SinksFactory<AllProjections>;
|
|
6
7
|
export declare type InMemorySinks = ReturnType<typeof createSinks>;
|
|
7
8
|
//# sourceMappingURL=create.d.ts.map
|
|
@@ -1 +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;
|
|
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,YAAY,EAAE,MAAM,UAAU,CAAC;AAK/C,eAAO,MAAM,WAAW,QAAO,aAG7B,CAAC;AAEH,eAAO,MAAM,WAAW,UAAW,aAAa,KAAG,MAAM,cAAc,CAOrE,CAAC;AAEH,eAAO,MAAM,kBAAkB,UACrB,aAAa,KAAG,aAAa,cAAc,CAE/B,CAAC;AAEvB,oBAAY,aAAa,GAAG,UAAU,CAAC,OAAO,WAAW,CAAC,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.createSinks = exports.createStore = void 0;
|
|
3
|
+
exports.createSinksFactory = exports.createSinks = exports.createStore = void 0;
|
|
4
4
|
const InMemoryStabilityWindowBuffer_1 = require("./InMemoryStabilityWindowBuffer");
|
|
5
5
|
const stakeKeys_1 = require("./stakeKeys");
|
|
6
6
|
const stakePools_1 = require("./stakePools");
|
|
@@ -19,4 +19,6 @@ const createSinks = (store) => ({
|
|
|
19
19
|
}
|
|
20
20
|
});
|
|
21
21
|
exports.createSinks = createSinks;
|
|
22
|
+
const createSinksFactory = (store) => () => (0, exports.createSinks)(store);
|
|
23
|
+
exports.createSinksFactory = createSinksFactory;
|
|
22
24
|
//# sourceMappingURL=create.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create.js","sourceRoot":"","sources":["../../../../src/sinks/inMemory/create.ts"],"names":[],"mappings":";;;AACA,mFAAgF;AAGhF,2CAAwC;AACxC,6CAA0C;AAC1C,+CAAoD;AAE7C,MAAM,WAAW,GAAG,GAAkB,EAAE,CAAC,CAAC;IAC/C,SAAS,EAAE,IAAI,GAAG,EAAE;IACpB,UAAU,EAAE,IAAI,GAAG,EAAE;CACtB,CAAC,CAAC;AAHU,QAAA,WAAW,eAGrB;AAEI,MAAM,WAAW,GAAG,CAAC,KAAoB,EAAyB,EAAE,CAAC,CAAC;IAC3E,MAAM,EAAE,IAAA,6BAAiB,EAAC,EAAE,KAAK,EAAE,CAAC;IACpC,MAAM,EAAE,IAAI,6DAA6B,EAAE;IAC3C,eAAe,EAAE;QACf,SAAS,EAAT,qBAAS;QACT,UAAU,EAAV,uBAAU;KACX;CACF,CAAC,CAAC;AAPU,QAAA,WAAW,eAOrB"}
|
|
1
|
+
{"version":3,"file":"create.js","sourceRoot":"","sources":["../../../../src/sinks/inMemory/create.ts"],"names":[],"mappings":";;;AACA,mFAAgF;AAGhF,2CAAwC;AACxC,6CAA0C;AAC1C,+CAAoD;AAE7C,MAAM,WAAW,GAAG,GAAkB,EAAE,CAAC,CAAC;IAC/C,SAAS,EAAE,IAAI,GAAG,EAAE;IACpB,UAAU,EAAE,IAAI,GAAG,EAAE;CACtB,CAAC,CAAC;AAHU,QAAA,WAAW,eAGrB;AAEI,MAAM,WAAW,GAAG,CAAC,KAAoB,EAAyB,EAAE,CAAC,CAAC;IAC3E,MAAM,EAAE,IAAA,6BAAiB,EAAC,EAAE,KAAK,EAAE,CAAC;IACpC,MAAM,EAAE,IAAI,6DAA6B,EAAE;IAC3C,eAAe,EAAE;QACf,SAAS,EAAT,qBAAS;QACT,UAAU,EAAV,uBAAU;KACX;CACF,CAAC,CAAC;AAPU,QAAA,WAAW,eAOrB;AAEI,MAAM,kBAAkB,GAC7B,CAAC,KAAoB,EAAgC,EAAE,CACvD,GAAG,EAAE,CACH,IAAA,mBAAW,EAAC,KAAK,CAAC,CAAC;AAHV,QAAA,kBAAkB,sBAGR"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"stakeKeys.d.ts","sourceRoot":"","sources":["../../../../src/sinks/inMemory/stakeKeys.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"stakeKeys.d.ts","sourceRoot":"","sources":["../../../../src/sinks/inMemory/stakeKeys.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAE,MAAM,UAAU,CAAC;AAChC,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AACxD,OAAO,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;AAE5C,eAAO,MAAM,SAAS,EAAE,IAAI,CAAC,mBAAmB,EAAE,iBAAiB,CAUlE,CAAC"}
|
|
@@ -1,20 +1,13 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.stakeKeys = void 0;
|
|
4
|
-
const core_1 = require("@cardano-sdk/core");
|
|
5
4
|
const rxjs_1 = require("rxjs");
|
|
6
5
|
exports.stakeKeys = {
|
|
7
|
-
sink({ stakeKeys:
|
|
8
|
-
const
|
|
9
|
-
? eventStakeKeys
|
|
10
|
-
: {
|
|
11
|
-
deregister: eventStakeKeys.register,
|
|
12
|
-
register: eventStakeKeys.deregister
|
|
13
|
-
};
|
|
14
|
-
for (const stakeKey of operations.register) {
|
|
6
|
+
sink({ stakeKeys: { insert, del }, store }) {
|
|
7
|
+
for (const stakeKey of insert) {
|
|
15
8
|
store.stakeKeys.add(stakeKey);
|
|
16
9
|
}
|
|
17
|
-
for (const stakeKey of
|
|
10
|
+
for (const stakeKey of del) {
|
|
18
11
|
store.stakeKeys.delete(stakeKey);
|
|
19
12
|
}
|
|
20
13
|
return rxjs_1.EMPTY;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"stakeKeys.js","sourceRoot":"","sources":["../../../../src/sinks/inMemory/stakeKeys.ts"],"names":[],"mappings":";;;AAAA
|
|
1
|
+
{"version":3,"file":"stakeKeys.js","sourceRoot":"","sources":["../../../../src/sinks/inMemory/stakeKeys.ts"],"names":[],"mappings":";;;AAAA,+BAA6B;AAKhB,QAAA,SAAS,GAAiD;IACrE,IAAI,CAAC,EAAE,SAAS,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,EAAE,KAAK,EAAE;QACxC,KAAK,MAAM,QAAQ,IAAI,MAAM,EAAE;YAC7B,KAAK,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;SAC/B;QACD,KAAK,MAAM,QAAQ,IAAI,GAAG,EAAE;YAC1B,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;SAClC;QACD,OAAO,YAAK,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,OAAO,KAAK,QAAQ,MAAM,YAAY,CAAC
|
|
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"}
|
package/dist/cjs/sinks/index.js
CHANGED
|
@@ -29,5 +29,4 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
29
29
|
exports.InMemory = void 0;
|
|
30
30
|
__exportStar(require("./types"), exports);
|
|
31
31
|
exports.InMemory = __importStar(require("./inMemory"));
|
|
32
|
-
__exportStar(require("./util"), exports);
|
|
33
32
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/sinks/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,0CAAwB;AACxB,uDAAuC
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/sinks/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,0CAAwB;AACxB,uDAAuC"}
|
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
import { Cardano } from '@cardano-sdk/core';
|
|
2
2
|
import { Observable } from 'rxjs';
|
|
3
3
|
import { ProjectionExtraProps } from '../projections';
|
|
4
|
-
import {
|
|
4
|
+
import { Shutdown } from '@cardano-sdk/util';
|
|
5
|
+
import { UnifiedProjectorEvent, UnifiedProjectorOperator } from '../types';
|
|
5
6
|
import { WithNetworkInfo } from '../operators';
|
|
6
|
-
export interface StabilityWindowBuffer<E extends WithNetworkInfo> {
|
|
7
|
+
export interface StabilityWindowBuffer<E extends WithNetworkInfo> extends Shutdown {
|
|
7
8
|
tip$: Observable<Cardano.Block | 'origin'>;
|
|
8
9
|
tail$: Observable<Cardano.Block | 'origin'>;
|
|
9
|
-
|
|
10
|
-
deleteBlock(evt: Cardano.Block): Observable<void>;
|
|
10
|
+
handleEvents: UnifiedProjectorOperator<E, E>;
|
|
11
11
|
}
|
|
12
12
|
export interface Sink<P, SinkSpecificProps = {}> {
|
|
13
13
|
sink: (evt: UnifiedProjectorEvent<ProjectionExtraProps<P> & SinkSpecificProps>) => Observable<void>;
|
|
@@ -22,4 +22,10 @@ export declare type Sinks<Projections> = {
|
|
|
22
22
|
before?: SinkLifecycleOperator;
|
|
23
23
|
after?: SinkLifecycleOperator;
|
|
24
24
|
};
|
|
25
|
+
declare type InferArg<T> = T extends (arg: infer Arg) => any ? Arg : never;
|
|
26
|
+
export declare type SinkEventType<S extends {
|
|
27
|
+
sink: any;
|
|
28
|
+
}> = InferArg<S['sink']>;
|
|
29
|
+
export declare type SinksFactory<P> = () => Sinks<P>;
|
|
30
|
+
export {};
|
|
25
31
|
//# sourceMappingURL=types.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/sinks/types.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/sinks/types.ts"],"names":[],"mappings":"AACA,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,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAE,qBAAqB,EAAE,wBAAwB,EAAE,MAAM,UAAU,CAAC;AAC3E,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAY/C,MAAM,WAAW,qBAAqB,CAAC,CAAC,SAAS,eAAe,CAAE,SAAQ,QAAQ;IAMhF,IAAI,EAAE,UAAU,CAAC,OAAO,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC;IAK3C,KAAK,EAAE,UAAU,CAAC,OAAO,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC;IAQ5C,YAAY,EAAE,wBAAwB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;CAC9C;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;AAEF,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;AAEF,aAAK,QAAQ,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,MAAM,GAAG,KAAK,GAAG,GAAG,GAAG,GAAG,KAAK,CAAC;AACnE,oBAAY,aAAa,CAAC,CAAC,SAAS;IAAE,IAAI,EAAE,GAAG,CAAA;CAAE,IAAI,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;AAEzE,oBAAY,YAAY,CAAC,CAAC,IAAI,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC"}
|