@cardano-sdk/projection-typeorm 0.2.0-nightly.5 → 0.2.2-patch.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/README.md +1 -10
- package/dist/cjs/TypeormStabilityWindowBuffer.d.ts +6 -6
- package/dist/cjs/TypeormStabilityWindowBuffer.d.ts.map +1 -1
- package/dist/cjs/TypeormStabilityWindowBuffer.js +21 -42
- package/dist/cjs/TypeormStabilityWindowBuffer.js.map +1 -1
- package/dist/cjs/createDataSource.d.ts +4 -9
- package/dist/cjs/createDataSource.d.ts.map +1 -1
- package/dist/cjs/createDataSource.js +34 -49
- package/dist/cjs/createDataSource.js.map +1 -1
- package/dist/cjs/createSinks.d.ts +19 -0
- package/dist/cjs/createSinks.d.ts.map +1 -0
- package/dist/cjs/createSinks.js +101 -0
- package/dist/cjs/createSinks.js.map +1 -0
- package/dist/cjs/entity/Block.entity.d.ts.map +1 -1
- package/dist/cjs/entity/Block.entity.js +3 -3
- package/dist/cjs/entity/Block.entity.js.map +1 -1
- package/dist/cjs/entity/BlockData.entity.js +1 -1
- package/dist/cjs/entity/BlockData.entity.js.map +1 -1
- package/dist/cjs/entity/index.d.ts +0 -4
- package/dist/cjs/entity/index.d.ts.map +1 -1
- package/dist/cjs/entity/index.js +0 -4
- package/dist/cjs/entity/index.js.map +1 -1
- package/dist/cjs/index.d.ts +1 -6
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +1 -9
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/operators/withTypeormTransaction.d.ts +2 -0
- package/dist/cjs/operators/withTypeormTransaction.d.ts.map +1 -1
- package/dist/cjs/operators/withTypeormTransaction.js.map +1 -1
- package/dist/cjs/sinks/index.d.ts +3 -0
- package/dist/cjs/sinks/index.d.ts.map +1 -0
- package/dist/cjs/sinks/index.js +8 -0
- package/dist/cjs/sinks/index.js.map +1 -0
- package/dist/cjs/sinks/stakeKeys.sink.d.ts +4 -0
- package/dist/cjs/sinks/stakeKeys.sink.d.ts.map +1 -0
- package/dist/cjs/sinks/stakeKeys.sink.js +15 -0
- package/dist/cjs/sinks/stakeKeys.sink.js.map +1 -0
- package/dist/cjs/sinks/stakePools.sink.d.ts +4 -0
- package/dist/cjs/sinks/stakePools.sink.d.ts.map +1 -0
- package/dist/cjs/sinks/stakePools.sink.js +224 -0
- package/dist/cjs/sinks/stakePools.sink.js.map +1 -0
- package/dist/cjs/sinks/util.d.ts +5 -0
- package/dist/cjs/sinks/util.d.ts.map +1 -0
- package/dist/cjs/sinks/util.js +8 -0
- package/dist/cjs/sinks/util.js.map +1 -0
- package/dist/cjs/tsconfig.tsbuildinfo +1 -1
- package/dist/cjs/types.d.ts +16 -0
- package/dist/cjs/types.d.ts.map +1 -0
- package/dist/cjs/types.js +3 -0
- package/dist/cjs/types.js.map +1 -0
- package/dist/cjs/util.d.ts +2 -0
- package/dist/cjs/util.d.ts.map +1 -0
- package/dist/cjs/util.js +25 -0
- package/dist/cjs/util.js.map +1 -0
- package/dist/esm/TypeormStabilityWindowBuffer.d.ts +6 -6
- package/dist/esm/TypeormStabilityWindowBuffer.d.ts.map +1 -1
- package/dist/esm/TypeormStabilityWindowBuffer.js +21 -42
- package/dist/esm/TypeormStabilityWindowBuffer.js.map +1 -1
- package/dist/esm/createDataSource.d.ts +4 -9
- package/dist/esm/createDataSource.d.ts.map +1 -1
- package/dist/esm/createDataSource.js +10 -47
- package/dist/esm/createDataSource.js.map +1 -1
- package/dist/esm/createSinks.d.ts +19 -0
- package/dist/esm/createSinks.d.ts.map +1 -0
- package/dist/esm/createSinks.js +70 -0
- package/dist/esm/createSinks.js.map +1 -0
- package/dist/esm/entity/Block.entity.d.ts.map +1 -1
- package/dist/esm/entity/Block.entity.js +3 -3
- package/dist/esm/entity/Block.entity.js.map +1 -1
- package/dist/esm/entity/BlockData.entity.js +1 -1
- package/dist/esm/entity/BlockData.entity.js.map +1 -1
- package/dist/esm/entity/index.d.ts +0 -4
- package/dist/esm/entity/index.d.ts.map +1 -1
- package/dist/esm/entity/index.js +0 -4
- package/dist/esm/entity/index.js.map +1 -1
- package/dist/esm/index.d.ts +1 -6
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +1 -6
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/operators/withTypeormTransaction.d.ts +2 -0
- package/dist/esm/operators/withTypeormTransaction.d.ts.map +1 -1
- package/dist/esm/operators/withTypeormTransaction.js.map +1 -1
- package/dist/esm/sinks/index.d.ts +3 -0
- package/dist/esm/sinks/index.d.ts.map +1 -0
- package/dist/esm/sinks/index.js +3 -0
- package/dist/esm/sinks/index.js.map +1 -0
- package/dist/esm/sinks/stakeKeys.sink.d.ts +4 -0
- package/dist/esm/sinks/stakeKeys.sink.d.ts.map +1 -0
- package/dist/esm/sinks/stakeKeys.sink.js +12 -0
- package/dist/esm/sinks/stakeKeys.sink.js.map +1 -0
- package/dist/esm/sinks/stakePools.sink.d.ts +4 -0
- package/dist/esm/sinks/stakePools.sink.d.ts.map +1 -0
- package/dist/esm/sinks/stakePools.sink.js +218 -0
- package/dist/esm/sinks/stakePools.sink.js.map +1 -0
- package/dist/esm/sinks/util.d.ts +5 -0
- package/dist/esm/sinks/util.d.ts.map +1 -0
- package/dist/esm/sinks/util.js +4 -0
- package/dist/esm/sinks/util.js.map +1 -0
- package/dist/esm/tsconfig.tsbuildinfo +1 -1
- package/dist/esm/types.d.ts +16 -0
- package/dist/esm/types.d.ts.map +1 -0
- package/dist/esm/types.js +2 -0
- package/dist/esm/types.js.map +1 -0
- package/dist/esm/util.d.ts +2 -0
- package/dist/esm/util.d.ts.map +1 -0
- package/dist/esm/util.js +21 -0
- package/dist/esm/util.js.map +1 -0
- package/package.json +11 -12
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { BlockEntity } from './entity/Block.entity';
|
|
2
|
+
import { Projections, Sink, UnifiedProjectorEvent } from '@cardano-sdk/projection';
|
|
3
|
+
import { QueryRunner } from 'typeorm';
|
|
4
|
+
import { Subject } from 'rxjs';
|
|
5
|
+
import { WithNetworkInfo } from '@cardano-sdk/projection/dist/cjs/operators';
|
|
6
|
+
export interface WithTypeormContext {
|
|
7
|
+
queryRunner: QueryRunner;
|
|
8
|
+
transactionCommitted$: Subject<void>;
|
|
9
|
+
blockEntity: BlockEntity;
|
|
10
|
+
}
|
|
11
|
+
export interface WithTypeormSinkMetadata {
|
|
12
|
+
entities: Function[];
|
|
13
|
+
}
|
|
14
|
+
export declare type TypeormSink<P> = Sink<P, WithTypeormContext> & WithTypeormSinkMetadata;
|
|
15
|
+
export declare type TypeormSinkEvent<P> = P extends Projections.Projection<infer ExtraProps> ? UnifiedProjectorEvent<ExtraProps & WithNetworkInfo & WithTypeormContext> : never;
|
|
16
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,IAAI,EAAE,qBAAqB,EAAE,MAAM,yBAAyB,CAAC;AACnF,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AACtC,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,eAAe,EAAE,MAAM,4CAA4C,CAAC;AAE7E,MAAM,WAAW,kBAAkB;IACjC,WAAW,EAAE,WAAW,CAAC;IACzB,qBAAqB,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;IACrC,WAAW,EAAE,WAAW,CAAC;CAC1B;AAED,MAAM,WAAW,uBAAuB;IACtC,QAAQ,EAAE,QAAQ,EAAE,CAAC;CACtB;AAED,oBAAY,WAAW,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,EAAE,kBAAkB,CAAC,GAAG,uBAAuB,CAAC;AAEnF,oBAAY,gBAAgB,CAAC,CAAC,IAAI,CAAC,SAAS,WAAW,CAAC,UAAU,CAAC,MAAM,UAAU,CAAC,GAChF,qBAAqB,CAAC,UAAU,GAAG,eAAe,GAAG,kBAAkB,CAAC,GACxE,KAAK,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../src/util.ts"],"names":[],"mappings":"AAuCA,eAAO,MAAM,yBAAyB,UAAW,OAAO,YACS,CAAC"}
|
package/dist/cjs/util.js
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isRecoverableTypeormError = void 0;
|
|
4
|
+
const typeorm_1 = require("typeorm");
|
|
5
|
+
const recoverableErrorClasses = [
|
|
6
|
+
typeorm_1.AlreadyHasActiveConnectionError,
|
|
7
|
+
typeorm_1.CannotConnectAlreadyConnectedError,
|
|
8
|
+
typeorm_1.CannotExecuteNotConnectedError,
|
|
9
|
+
typeorm_1.CannotGetEntityManagerNotConnectedError,
|
|
10
|
+
typeorm_1.ConnectionIsNotSetError,
|
|
11
|
+
typeorm_1.ConnectionNotFoundError,
|
|
12
|
+
typeorm_1.NoConnectionForRepositoryError,
|
|
13
|
+
typeorm_1.NoConnectionOptionError,
|
|
14
|
+
typeorm_1.NoNeedToReleaseEntityManagerError,
|
|
15
|
+
typeorm_1.NoVersionOrUpdateDateColumnError,
|
|
16
|
+
typeorm_1.PersistedEntityNotFoundError,
|
|
17
|
+
typeorm_1.PessimisticLockTransactionRequiredError,
|
|
18
|
+
typeorm_1.QueryRunnerAlreadyReleasedError,
|
|
19
|
+
typeorm_1.QueryRunnerProviderAlreadyReleasedError,
|
|
20
|
+
typeorm_1.TransactionAlreadyStartedError,
|
|
21
|
+
typeorm_1.TransactionNotStartedError
|
|
22
|
+
];
|
|
23
|
+
const isRecoverableTypeormError = (error) => recoverableErrorClasses.some((Class) => error instanceof Class);
|
|
24
|
+
exports.isRecoverableTypeormError = isRecoverableTypeormError;
|
|
25
|
+
//# sourceMappingURL=util.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/util.ts"],"names":[],"mappings":";;;AAAA,qCAiBiB;AAGjB,MAAM,uBAAuB,GAAG;IAC9B,yCAA+B;IAC/B,4CAAkC;IAClC,wCAA8B;IAC9B,iDAAuC;IACvC,iCAAuB;IACvB,iCAAuB;IACvB,wCAA8B;IAC9B,iCAAuB;IACvB,2CAAiC;IACjC,0CAAgC;IAChC,sCAA4B;IAC5B,iDAAuC;IACvC,yCAA+B;IAC/B,iDAAuC;IACvC,wCAA8B;IAC9B,oCAA0B;CAC3B,CAAC;AAEK,MAAM,yBAAyB,GAAG,CAAC,KAAc,EAAE,EAAE,CAC1D,uBAAuB,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,YAAY,KAAK,CAAC,CAAC;AADrD,QAAA,yBAAyB,6BAC4B"}
|
|
@@ -1,19 +1,19 @@
|
|
|
1
1
|
import { Cardano } from '@cardano-sdk/core';
|
|
2
2
|
import { QueryRunner } from 'typeorm';
|
|
3
3
|
import { Observable } from 'rxjs';
|
|
4
|
-
import {
|
|
4
|
+
import { Operators, StabilityWindowBuffer, UnifiedProjectorOperator } from '@cardano-sdk/projection';
|
|
5
5
|
import { WithLogger } from '@cardano-sdk/util';
|
|
6
|
-
import { WithTypeormContext } from './
|
|
7
|
-
export interface TypeormStabilityWindowBufferProps
|
|
6
|
+
import { WithTypeormContext } from './types';
|
|
7
|
+
export interface TypeormStabilityWindowBufferProps {
|
|
8
8
|
compactBufferEveryNBlocks?: number;
|
|
9
9
|
allowNonSequentialBlockHeights?: boolean;
|
|
10
10
|
}
|
|
11
|
-
export declare class TypeormStabilityWindowBuffer implements StabilityWindowBuffer {
|
|
11
|
+
export declare class TypeormStabilityWindowBuffer implements StabilityWindowBuffer<Operators.WithNetworkInfo & WithTypeormContext> {
|
|
12
12
|
#private;
|
|
13
13
|
readonly tip$: Observable<Cardano.Block | 'origin'>;
|
|
14
14
|
readonly tail$: Observable<Cardano.Block | 'origin'>;
|
|
15
|
-
|
|
16
|
-
|
|
15
|
+
readonly handleEvents: UnifiedProjectorOperator<Operators.WithNetworkInfo & WithTypeormContext, Operators.WithNetworkInfo & WithTypeormContext>;
|
|
16
|
+
constructor({ allowNonSequentialBlockHeights, compactBufferEveryNBlocks }: TypeormStabilityWindowBufferProps, dependencies: WithLogger);
|
|
17
17
|
initialize(queryRunner: QueryRunner): Promise<void>;
|
|
18
18
|
shutdown(): void;
|
|
19
19
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TypeormStabilityWindowBuffer.d.ts","sourceRoot":"","sources":["../../src/TypeormStabilityWindowBuffer.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,OAAO,EAAsB,MAAM,mBAAmB,CAAC;AAChE,OAAO,EAA+B,WAAW,EAAc,MAAM,SAAS,CAAC;AAE/E,OAAO,EAAE,UAAU,EAAuC,MAAM,MAAM,CAAC;AACvE,OAAO,EACL,
|
|
1
|
+
{"version":3,"file":"TypeormStabilityWindowBuffer.d.ts","sourceRoot":"","sources":["../../src/TypeormStabilityWindowBuffer.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,OAAO,EAAsB,MAAM,mBAAmB,CAAC;AAChE,OAAO,EAA+B,WAAW,EAAc,MAAM,SAAS,CAAC;AAE/E,OAAO,EAAE,UAAU,EAAuC,MAAM,MAAM,CAAC;AACvE,OAAO,EACL,SAAS,EAGT,qBAAqB,EACrB,wBAAwB,EAEzB,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,UAAU,EAAiB,MAAM,mBAAmB,CAAC;AAC9D,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAS7C,MAAM,WAAW,iCAAiC;IAIhD,yBAAyB,CAAC,EAAE,MAAM,CAAC;IAInC,8BAA8B,CAAC,EAAE,OAAO,CAAC;CAC1C;AAED,qBAAa,4BACX,YAAW,qBAAqB,CAAC,SAAS,CAAC,eAAe,GAAG,kBAAkB,CAAC;;IAQhF,QAAQ,CAAC,IAAI,EAAE,UAAU,CAAC,OAAO,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC;IACpD,QAAQ,CAAC,KAAK,EAAE,UAAU,CAAC,OAAO,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC;IACrD,QAAQ,CAAC,YAAY,EAAE,wBAAwB,CAC7C,SAAS,CAAC,eAAe,GAAG,kBAAkB,EAC9C,SAAS,CAAC,eAAe,GAAG,kBAAkB,CAC/C,CAAC;gBAGA,EAAE,8BAA8B,EAAE,yBAA+B,EAAE,EAAE,iCAAiC,EACtG,YAAY,EAAE,UAAU;IAiBpB,UAAU,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAiBzD,QAAQ,IAAI,IAAI;CAwGjB"}
|
|
@@ -1,50 +1,38 @@
|
|
|
1
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
2
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
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");
|
|
4
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
5
|
+
};
|
|
1
6
|
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
|
|
2
7
|
if (kind === "m") throw new TypeError("Private method is not writable");
|
|
3
8
|
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
|
4
9
|
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
10
|
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
6
11
|
};
|
|
7
|
-
var
|
|
8
|
-
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
9
|
-
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
|
-
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
11
|
-
};
|
|
12
|
-
var _TypeormStabilityWindowBuffer_instances, _TypeormStabilityWindowBuffer_tail, _TypeormStabilityWindowBuffer_tip, _TypeormStabilityWindowBuffer_tip$, _TypeormStabilityWindowBuffer_tail$, _TypeormStabilityWindowBuffer_logger, _TypeormStabilityWindowBuffer_compactEvery, _TypeormStabilityWindowBuffer_allowNonSequentialBlockHeights, _TypeormStabilityWindowBuffer_findTail, _TypeormStabilityWindowBuffer_rollForward, _TypeormStabilityWindowBuffer_rollBackward, _TypeormStabilityWindowBuffer_deleteOldBlockData, _TypeormStabilityWindowBuffer_setTail, _TypeormStabilityWindowBuffer_setTip;
|
|
12
|
+
var _TypeormStabilityWindowBuffer_instances, _TypeormStabilityWindowBuffer_tail, _TypeormStabilityWindowBuffer_logger, _TypeormStabilityWindowBuffer_compactEvery, _TypeormStabilityWindowBuffer_allowNonSequentialBlockHeights, _TypeormStabilityWindowBuffer_tip$, _TypeormStabilityWindowBuffer_tail$, _TypeormStabilityWindowBuffer_findTail, _TypeormStabilityWindowBuffer_rollForward, _TypeormStabilityWindowBuffer_rollBackward, _TypeormStabilityWindowBuffer_deleteOldBlockData, _TypeormStabilityWindowBuffer_setTail;
|
|
13
13
|
import { BlockDataEntity } from './entity';
|
|
14
14
|
import { ChainSyncEventType } from '@cardano-sdk/core';
|
|
15
15
|
import { LessThan } from 'typeorm';
|
|
16
16
|
import { ReplaySubject, concatMap, from, map } from 'rxjs';
|
|
17
17
|
import { contextLogger } from '@cardano-sdk/util';
|
|
18
|
-
const pointEquals = (point1, point2) => {
|
|
19
|
-
if (typeof point1 !== 'object') {
|
|
20
|
-
return point1 === point2;
|
|
21
|
-
}
|
|
22
|
-
if (typeof point2 !== 'object') {
|
|
23
|
-
return false;
|
|
24
|
-
}
|
|
25
|
-
return point1.header.hash === point2.header.hash;
|
|
26
|
-
};
|
|
27
18
|
const blockDataSelect = {
|
|
28
19
|
data: true
|
|
29
20
|
};
|
|
30
21
|
export class TypeormStabilityWindowBuffer {
|
|
31
|
-
constructor({ allowNonSequentialBlockHeights, compactBufferEveryNBlocks = 100,
|
|
22
|
+
constructor({ allowNonSequentialBlockHeights, compactBufferEveryNBlocks = 100 }, dependencies) {
|
|
32
23
|
_TypeormStabilityWindowBuffer_instances.add(this);
|
|
33
24
|
_TypeormStabilityWindowBuffer_tail.set(this, void 0);
|
|
34
|
-
_TypeormStabilityWindowBuffer_tip.set(this, void 0);
|
|
35
|
-
_TypeormStabilityWindowBuffer_tip$.set(this, new ReplaySubject(1));
|
|
36
|
-
_TypeormStabilityWindowBuffer_tail$.set(this, new ReplaySubject(1));
|
|
37
25
|
_TypeormStabilityWindowBuffer_logger.set(this, void 0);
|
|
38
26
|
_TypeormStabilityWindowBuffer_compactEvery.set(this, void 0);
|
|
39
27
|
_TypeormStabilityWindowBuffer_allowNonSequentialBlockHeights.set(this, void 0);
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
__classPrivateFieldSet(this, _TypeormStabilityWindowBuffer_logger, contextLogger(logger, 'TypeormStabilityWindowBuffer'), "f");
|
|
28
|
+
_TypeormStabilityWindowBuffer_tip$.set(this, new ReplaySubject(1));
|
|
29
|
+
_TypeormStabilityWindowBuffer_tail$.set(this, new ReplaySubject(1));
|
|
43
30
|
this.tip$ = __classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tip$, "f").asObservable();
|
|
44
31
|
this.tail$ = __classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tail$, "f").asObservable();
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
32
|
+
__classPrivateFieldSet(this, _TypeormStabilityWindowBuffer_compactEvery, compactBufferEveryNBlocks, "f");
|
|
33
|
+
__classPrivateFieldSet(this, _TypeormStabilityWindowBuffer_allowNonSequentialBlockHeights, allowNonSequentialBlockHeights, "f");
|
|
34
|
+
__classPrivateFieldSet(this, _TypeormStabilityWindowBuffer_logger, contextLogger(dependencies.logger, 'PgStabilityWindowBuffer'), "f");
|
|
35
|
+
this.handleEvents = (evt$) => evt$.pipe(concatMap((evt) => from(evt.eventType === ChainSyncEventType.RollForward ? __classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_instances, "m", _TypeormStabilityWindowBuffer_rollForward).call(this, evt) : __classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_instances, "m", _TypeormStabilityWindowBuffer_rollBackward).call(this, evt)).pipe(map(() => evt))));
|
|
48
36
|
}
|
|
49
37
|
async initialize(queryRunner) {
|
|
50
38
|
const repository = queryRunner.manager.getRepository(BlockDataEntity);
|
|
@@ -56,7 +44,7 @@ export class TypeormStabilityWindowBuffer {
|
|
|
56
44
|
}),
|
|
57
45
|
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_instances, "m", _TypeormStabilityWindowBuffer_findTail).call(this, repository)
|
|
58
46
|
]);
|
|
59
|
-
__classPrivateFieldGet(this,
|
|
47
|
+
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tip$, "f").next(tip[0]?.data || 'origin');
|
|
60
48
|
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_instances, "m", _TypeormStabilityWindowBuffer_setTail).call(this, tail[0]?.data || 'origin');
|
|
61
49
|
}
|
|
62
50
|
shutdown() {
|
|
@@ -64,27 +52,25 @@ export class TypeormStabilityWindowBuffer {
|
|
|
64
52
|
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tail$, "f").complete();
|
|
65
53
|
}
|
|
66
54
|
}
|
|
67
|
-
_TypeormStabilityWindowBuffer_tail = new WeakMap(),
|
|
55
|
+
_TypeormStabilityWindowBuffer_tail = new WeakMap(), _TypeormStabilityWindowBuffer_logger = new WeakMap(), _TypeormStabilityWindowBuffer_compactEvery = new WeakMap(), _TypeormStabilityWindowBuffer_allowNonSequentialBlockHeights = new WeakMap(), _TypeormStabilityWindowBuffer_tip$ = new WeakMap(), _TypeormStabilityWindowBuffer_tail$ = new WeakMap(), _TypeormStabilityWindowBuffer_instances = new WeakSet(), _TypeormStabilityWindowBuffer_findTail = async function _TypeormStabilityWindowBuffer_findTail(repository) {
|
|
68
56
|
return repository.find({
|
|
69
57
|
order: { blockHeight: 'ASC' },
|
|
70
58
|
select: blockDataSelect,
|
|
71
59
|
take: 1
|
|
72
60
|
});
|
|
73
61
|
}, _TypeormStabilityWindowBuffer_rollForward = async function _TypeormStabilityWindowBuffer_rollForward(evt) {
|
|
74
|
-
const { eventType, transactionCommitted$, queryRunner, block } = evt;
|
|
62
|
+
const { eventType, transactionCommitted$, queryRunner, blockEntity, block } = evt;
|
|
75
63
|
const { header: { blockNo } } = block;
|
|
76
64
|
const repository = queryRunner.manager.getRepository(BlockDataEntity);
|
|
77
65
|
if (eventType === ChainSyncEventType.RollForward) {
|
|
78
66
|
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_logger, "f").debug('Add block data at height', blockNo);
|
|
79
67
|
const blockData = repository.create({
|
|
80
|
-
block:
|
|
81
|
-
height: blockNo
|
|
82
|
-
},
|
|
68
|
+
block: blockEntity,
|
|
83
69
|
data: block
|
|
84
70
|
});
|
|
85
71
|
await Promise.all([repository.insert(blockData), __classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_instances, "m", _TypeormStabilityWindowBuffer_deleteOldBlockData).call(this, evt)]);
|
|
86
72
|
transactionCommitted$.subscribe(() => {
|
|
87
|
-
__classPrivateFieldGet(this,
|
|
73
|
+
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tip$, "f").next(block);
|
|
88
74
|
if (__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tail, "f") === 'origin') {
|
|
89
75
|
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_instances, "m", _TypeormStabilityWindowBuffer_setTail).call(this, block);
|
|
90
76
|
}
|
|
@@ -105,7 +91,7 @@ _TypeormStabilityWindowBuffer_tail = new WeakMap(), _TypeormStabilityWindowBuffe
|
|
|
105
91
|
throw new Error('Assert: inconsistent PgStabilityWindowBuffer at rollBackward');
|
|
106
92
|
}
|
|
107
93
|
transactionCommitted$.subscribe(() => {
|
|
108
|
-
__classPrivateFieldGet(this,
|
|
94
|
+
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tip$, "f").next(prevTip?.data || 'origin');
|
|
109
95
|
if (!prevTip?.data) {
|
|
110
96
|
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_instances, "m", _TypeormStabilityWindowBuffer_setTail).call(this, 'origin');
|
|
111
97
|
}
|
|
@@ -139,14 +125,7 @@ _TypeormStabilityWindowBuffer_tail = new WeakMap(), _TypeormStabilityWindowBuffe
|
|
|
139
125
|
}
|
|
140
126
|
transactionCommitted$.subscribe(() => __classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_instances, "m", _TypeormStabilityWindowBuffer_setTail).call(this, nextTailEntity.data));
|
|
141
127
|
}, _TypeormStabilityWindowBuffer_setTail = function _TypeormStabilityWindowBuffer_setTail(tail) {
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tail$, "f").next(tail);
|
|
145
|
-
}
|
|
146
|
-
}, _TypeormStabilityWindowBuffer_setTip = function _TypeormStabilityWindowBuffer_setTip(tip) {
|
|
147
|
-
if (!pointEquals(tip, __classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tip, "f"))) {
|
|
148
|
-
__classPrivateFieldSet(this, _TypeormStabilityWindowBuffer_tip, tip, "f");
|
|
149
|
-
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tip$, "f").next(tip);
|
|
150
|
-
}
|
|
128
|
+
__classPrivateFieldSet(this, _TypeormStabilityWindowBuffer_tail, tail, "f");
|
|
129
|
+
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tail$, "f").next(tail);
|
|
151
130
|
};
|
|
152
131
|
//# sourceMappingURL=TypeormStabilityWindowBuffer.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TypeormStabilityWindowBuffer.js","sourceRoot":"","sources":["../../src/TypeormStabilityWindowBuffer.ts"],"names":[],"mappings":";;;;;;;;;;;;AAEA,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAC3C,OAAO,EAAW,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAChE,OAAO,EAAqB,QAAQ,EAA2B,MAAM,SAAS,CAAC;AAE/E,OAAO,EAAc,aAAa,EAAE,SAAS,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AASvE,OAAO,EAAc,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAG9D,MAAM,
|
|
1
|
+
{"version":3,"file":"TypeormStabilityWindowBuffer.js","sourceRoot":"","sources":["../../src/TypeormStabilityWindowBuffer.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,24 +1,19 @@
|
|
|
1
1
|
import 'reflect-metadata';
|
|
2
|
-
import { DataSource, DataSourceOptions
|
|
2
|
+
import { DataSource, DataSourceOptions } from 'typeorm';
|
|
3
3
|
import { Logger } from 'ts-log';
|
|
4
|
-
export interface DataSourceExtensions {
|
|
5
|
-
pgBoss?: boolean;
|
|
6
|
-
}
|
|
7
4
|
declare type PostgresConnectionOptions = DataSourceOptions & {
|
|
8
5
|
type: 'postgres';
|
|
9
6
|
};
|
|
10
7
|
export declare type PgConnectionConfig = Pick<PostgresConnectionOptions, 'host' | 'port' | 'database' | 'username' | 'password' | 'ssl'>;
|
|
11
8
|
export declare type TypeormDevOptions = Pick<PostgresConnectionOptions, 'synchronize' | 'dropSchema'>;
|
|
12
9
|
export declare type TypeormOptions = Pick<PostgresConnectionOptions, 'connectTimeoutMS' | 'logNotifications' | 'installExtensions' | 'extra' | 'maxQueryExecutionTime' | 'poolSize' | 'cache' | 'migrationsRun' | 'migrations'> & {};
|
|
13
|
-
export interface CreateDataSourceProps {
|
|
14
|
-
|
|
10
|
+
export interface CreateDataSourceProps<P extends object> {
|
|
11
|
+
projections: P;
|
|
15
12
|
connectionConfig: PgConnectionConfig;
|
|
16
13
|
options?: TypeormOptions;
|
|
17
14
|
devOptions?: TypeormDevOptions;
|
|
18
|
-
extensions?: DataSourceExtensions;
|
|
19
15
|
logger: Logger;
|
|
20
16
|
}
|
|
21
|
-
export declare const
|
|
22
|
-
export declare const createDataSource: ({ connectionConfig, devOptions, options, entities, extensions, logger }: CreateDataSourceProps) => DataSource;
|
|
17
|
+
export declare const createDataSource: <P extends object>({ connectionConfig, devOptions, options, projections, logger }: CreateDataSourceProps<P>) => DataSource;
|
|
23
18
|
export {};
|
|
24
19
|
//# sourceMappingURL=createDataSource.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createDataSource.d.ts","sourceRoot":"","sources":["../../src/createDataSource.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"createDataSource.d.ts","sourceRoot":"","sources":["../../src/createDataSource.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,CAAC;AAI1B,OAAO,EAAE,UAAU,EAAE,iBAAiB,EAAkD,MAAM,SAAS,CAAC;AACxG,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAMhC,aAAK,yBAAyB,GAAG,iBAAiB,GAAG;IAAE,IAAI,EAAE,UAAU,CAAA;CAAE,CAAC;AAE1E,oBAAY,kBAAkB,GAAG,IAAI,CACnC,yBAAyB,EACzB,MAAM,GAAG,MAAM,GAAG,UAAU,GAAG,UAAU,GAAG,UAAU,GAAG,KAAK,CAC/D,CAAC;AAEF,oBAAY,iBAAiB,GAAG,IAAI,CAAC,yBAAyB,EAAE,aAAa,GAAG,YAAY,CAAC,CAAC;AAE9F,oBAAY,cAAc,GAAG,IAAI,CAC/B,yBAAyB,EACvB,kBAAkB,GAClB,kBAAkB,GAClB,mBAAmB,GACnB,OAAO,GACP,uBAAuB,GACvB,UAAU,GACV,OAAO,GACP,eAAe,GACf,YAAY,CACf,GAAG,EAAE,CAAC;AAEP,MAAM,WAAW,qBAAqB,CAAC,CAAC,SAAS,MAAM;IACrD,WAAW,EAAE,CAAC,CAAC;IACf,gBAAgB,EAAE,kBAAkB,CAAC;IACrC,OAAO,CAAC,EAAE,cAAc,CAAC;IACzB,UAAU,CAAC,EAAE,iBAAiB,CAAC;IAC/B,MAAM,EAAE,MAAM,CAAC;CAChB;AAiDD,eAAO,MAAM,gBAAgB,4HAqB5B,CAAC"}
|
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import 'reflect-metadata';
|
|
2
|
-
import
|
|
2
|
+
import * as supportedSinks from './sinks';
|
|
3
|
+
import { BlockDataEntity } from './entity';
|
|
4
|
+
import { BlockEntity } from './entity/Block.entity';
|
|
3
5
|
import { DataSource, DefaultNamingStrategy } from 'typeorm';
|
|
4
|
-
import { contextLogger, patchObject } from '@cardano-sdk/util';
|
|
5
6
|
import { typeormLogger } from './logger';
|
|
6
|
-
import PgBoss from 'pg-boss';
|
|
7
7
|
import snakeCase from 'lodash/snakeCase';
|
|
8
|
+
import uniq from 'lodash/uniq';
|
|
8
9
|
const toTableName = (tableOrName) => (typeof tableOrName === 'string' ? tableOrName : tableOrName.name).replace('_entity', '');
|
|
9
10
|
const namingOverrides = {
|
|
10
11
|
columnName(propertyName, customName, _embeddedPrefixes) {
|
|
@@ -48,43 +49,12 @@ const namingStrategy = new Proxy(defaultStrategy, {
|
|
|
48
49
|
return value;
|
|
49
50
|
}
|
|
50
51
|
});
|
|
51
|
-
export const
|
|
52
|
-
const
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
const
|
|
56
|
-
|
|
57
|
-
try {
|
|
58
|
-
if (dropSchema) {
|
|
59
|
-
await queryRunner.query('DROP SCHEMA IF EXISTS pgboss CASCADE;');
|
|
60
|
-
}
|
|
61
|
-
else if (await pgBossSchemaExists(queryRunner)) {
|
|
62
|
-
return;
|
|
63
|
-
}
|
|
64
|
-
if (!usePgBoss) {
|
|
65
|
-
return;
|
|
66
|
-
}
|
|
67
|
-
const boss = new PgBoss({
|
|
68
|
-
db: new BossDb(queryRunner)
|
|
69
|
-
});
|
|
70
|
-
await queryRunner.query('CREATE EXTENSION IF NOT EXISTS pgcrypto;');
|
|
71
|
-
await boss.start();
|
|
72
|
-
await boss.stop();
|
|
73
|
-
await queryRunner.query(`
|
|
74
|
-
ALTER TABLE pgboss.job
|
|
75
|
-
ADD COLUMN block_slot INTEGER,
|
|
76
|
-
ADD CONSTRAINT job_block_slot_fkey
|
|
77
|
-
FOREIGN KEY (block_slot) REFERENCES public.block(slot)
|
|
78
|
-
ON DELETE CASCADE;
|
|
79
|
-
`);
|
|
80
|
-
logger.info('"pgboss" schema created');
|
|
81
|
-
}
|
|
82
|
-
finally {
|
|
83
|
-
await queryRunner.release();
|
|
84
|
-
}
|
|
85
|
-
};
|
|
86
|
-
export const createDataSource = ({ connectionConfig, devOptions, options, entities, extensions, logger }) => {
|
|
87
|
-
const dataSource = new DataSource({
|
|
52
|
+
export const createDataSource = ({ connectionConfig, devOptions, options, projections, logger }) => {
|
|
53
|
+
const requestedProjectionEntities = Object.entries(supportedSinks)
|
|
54
|
+
.filter(([projectionName]) => projectionName in projections)
|
|
55
|
+
.flatMap(([_, sink]) => sink.entities);
|
|
56
|
+
const entities = uniq([BlockEntity, BlockDataEntity, ...requestedProjectionEntities]);
|
|
57
|
+
return new DataSource({
|
|
88
58
|
...connectionConfig,
|
|
89
59
|
...devOptions,
|
|
90
60
|
...options,
|
|
@@ -94,12 +64,5 @@ export const createDataSource = ({ connectionConfig, devOptions, options, entiti
|
|
|
94
64
|
namingStrategy,
|
|
95
65
|
type: 'postgres'
|
|
96
66
|
});
|
|
97
|
-
return patchObject(dataSource, {
|
|
98
|
-
async initialize() {
|
|
99
|
-
await dataSource.initialize();
|
|
100
|
-
await initializePgBoss(dataSource, contextLogger(logger, 'createDataSource'), extensions?.pgBoss, devOptions?.dropSchema);
|
|
101
|
-
return dataSource;
|
|
102
|
-
}
|
|
103
|
-
});
|
|
104
67
|
};
|
|
105
68
|
//# sourceMappingURL=createDataSource.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createDataSource.js","sourceRoot":"","sources":["../../src/createDataSource.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,CAAC;AAC1B,OAAO,
|
|
1
|
+
{"version":3,"file":"createDataSource.js","sourceRoot":"","sources":["../../src/createDataSource.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import 'reflect-metadata';
|
|
2
|
+
import * as supportedSinks from './sinks';
|
|
3
|
+
import { DataSource } from 'typeorm';
|
|
4
|
+
import { Observable } from 'rxjs';
|
|
5
|
+
import { Projections, Sinks } from '@cardano-sdk/projection';
|
|
6
|
+
import { RetryBackoffConfig } from 'backoff-rxjs';
|
|
7
|
+
import { TypeormStabilityWindowBufferProps } from './TypeormStabilityWindowBuffer';
|
|
8
|
+
import { WithLogger } from '@cardano-sdk/util';
|
|
9
|
+
export declare type ReconnectionConfig = Omit<RetryBackoffConfig, 'shouldRetry'>;
|
|
10
|
+
export interface TypeormSinksProps extends TypeormStabilityWindowBufferProps, WithLogger {
|
|
11
|
+
dataSource$: Observable<DataSource>;
|
|
12
|
+
reconnectionConfig?: ReconnectionConfig;
|
|
13
|
+
}
|
|
14
|
+
export declare type SupportedProjections = Pick<Projections.AllProjections, keyof typeof supportedSinks>;
|
|
15
|
+
export declare const createSinks: ({ dataSource$, reconnectionConfig, logger, compactBufferEveryNBlocks, allowNonSequentialBlockHeights }: TypeormSinksProps) => Sinks<SupportedProjections>;
|
|
16
|
+
export declare const createSinksFactory: (props: TypeormSinksProps) => () => Sinks<SupportedProjections>;
|
|
17
|
+
export declare type TypeormSinks = ReturnType<typeof createSinks>;
|
|
18
|
+
export declare type TypeormSinksFactory = () => TypeormSinks;
|
|
19
|
+
//# sourceMappingURL=createSinks.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createSinks.d.ts","sourceRoot":"","sources":["../../src/createSinks.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,CAAC;AAC1B,OAAO,KAAK,cAAc,MAAM,SAAS,CAAC;AAG1C,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAErC,OAAO,EAEL,UAAU,EAYX,MAAM,MAAM,CAAC;AACd,OAAO,EAGL,WAAW,EACX,KAAK,EAGN,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,kBAAkB,EAAgB,MAAM,cAAc,CAAC;AAChE,OAAO,EAAgC,iCAAiC,EAAE,MAAM,gCAAgC,CAAC;AACjH,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAM/C,oBAAY,kBAAkB,GAAG,IAAI,CAAC,kBAAkB,EAAE,aAAa,CAAC,CAAC;AAGzE,MAAM,WAAW,iBAAkB,SAAQ,iCAAiC,EAAE,UAAU;IAItF,WAAW,EAAE,UAAU,CAAC,UAAU,CAAC,CAAC;IACpC,kBAAkB,CAAC,EAAE,kBAAkB,CAAC;CACzC;AAID,oBAAY,oBAAoB,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,EAAE,MAAM,OAAO,cAAc,CAAC,CAAC;AAmCjG,eAAO,MAAM,WAAW,2GAMrB,iBAAiB,KAAG,MAAM,oBAAoB,CA2EhD,CAAC;AAEF,eAAO,MAAM,kBAAkB,UAAW,iBAAiB,sCAA6B,CAAC;AAEzF,oBAAY,YAAY,GAAG,UAAU,CAAC,OAAO,WAAW,CAAC,CAAC;AAE1D,oBAAY,mBAAmB,GAAG,MAAM,YAAY,CAAC"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import 'reflect-metadata';
|
|
2
|
+
import * as supportedSinks from './sinks';
|
|
3
|
+
import { BlockEntity } from './entity/Block.entity';
|
|
4
|
+
import { ChainSyncEventType } from '@cardano-sdk/core';
|
|
5
|
+
import { NEVER, ReplaySubject, Subject, concat, concatMap, finalize, from, map, share, switchMap, tap, timer } from 'rxjs';
|
|
6
|
+
import { Operators } from '@cardano-sdk/projection';
|
|
7
|
+
import { retryBackoff } from 'backoff-rxjs';
|
|
8
|
+
import { TypeormStabilityWindowBuffer } from './TypeormStabilityWindowBuffer';
|
|
9
|
+
import { finalizeWithLatest } from '@cardano-sdk/util-rxjs';
|
|
10
|
+
import { isRecoverableTypeormError } from './util';
|
|
11
|
+
import omit from 'lodash/omit';
|
|
12
|
+
const defaultReconnectionConfig = { initialInterval: 10, maxInterval: 5000 };
|
|
13
|
+
const TypeormContextProps = ['blockEntity', 'queryRunner', 'transactionCommitted$'];
|
|
14
|
+
const withQueryRunner = (dataSource, buffer, logger) => concat(from((async () => {
|
|
15
|
+
const queryRunner = dataSource.createQueryRunner('master');
|
|
16
|
+
await queryRunner.connect();
|
|
17
|
+
await buffer.initialize(queryRunner);
|
|
18
|
+
return { queryRunner };
|
|
19
|
+
})()), NEVER).pipe(finalizeWithLatest(async (evt) => {
|
|
20
|
+
if (!evt)
|
|
21
|
+
return;
|
|
22
|
+
if (evt.queryRunner.isTransactionActive) {
|
|
23
|
+
try {
|
|
24
|
+
await evt.queryRunner.rollbackTransaction();
|
|
25
|
+
}
|
|
26
|
+
catch (error) {
|
|
27
|
+
logger.error('Failed to rollback transaction', error);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
if (!evt.queryRunner.isReleased) {
|
|
31
|
+
try {
|
|
32
|
+
await evt.queryRunner.release();
|
|
33
|
+
}
|
|
34
|
+
catch (error) {
|
|
35
|
+
logger.error('Failed to "release" query runner', error);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}));
|
|
39
|
+
export const createSinks = ({ dataSource$, reconnectionConfig, logger, compactBufferEveryNBlocks, allowNonSequentialBlockHeights }) => {
|
|
40
|
+
const buffer = new TypeormStabilityWindowBuffer({ allowNonSequentialBlockHeights, compactBufferEveryNBlocks }, { logger });
|
|
41
|
+
return {
|
|
42
|
+
after: (evt$) => evt$.pipe(concatMap((evt) => from(evt.queryRunner.commitTransaction()).pipe(tap(() => evt.transactionCommitted$.next()), map(() => omit(evt, TypeormContextProps)))), retryBackoff({
|
|
43
|
+
...reconnectionConfig,
|
|
44
|
+
...defaultReconnectionConfig,
|
|
45
|
+
shouldRetry: (error) => isRecoverableTypeormError(error)
|
|
46
|
+
}), finalize(() => buffer.shutdown())),
|
|
47
|
+
before: (evt$) => evt$.pipe(share({
|
|
48
|
+
connector: () => new ReplaySubject(1),
|
|
49
|
+
resetOnComplete: false,
|
|
50
|
+
resetOnError: true,
|
|
51
|
+
resetOnRefCountZero: () => timer(3000)
|
|
52
|
+
}), Operators.withStaticContext(dataSource$.pipe(switchMap((dataSource) => withQueryRunner(dataSource, buffer, logger)))), Operators.withEventContext(({ queryRunner }) => from(queryRunner.startTransaction('SERIALIZABLE').then(() => ({ transactionCommitted$: new Subject() })))), Operators.withEventContext(({ block, queryRunner, eventType }) => {
|
|
53
|
+
const repository = queryRunner.manager.getRepository(BlockEntity);
|
|
54
|
+
const blockEntity = repository.create({
|
|
55
|
+
hash: block.header.hash,
|
|
56
|
+
height: block.header.blockNo,
|
|
57
|
+
slot: block.header.slot
|
|
58
|
+
});
|
|
59
|
+
return from(eventType === ChainSyncEventType.RollForward
|
|
60
|
+
? repository.insert(blockEntity)
|
|
61
|
+
: repository.delete({
|
|
62
|
+
hash: blockEntity.hash
|
|
63
|
+
})).pipe(map(() => ({ blockEntity })));
|
|
64
|
+
})),
|
|
65
|
+
buffer,
|
|
66
|
+
projectionSinks: supportedSinks
|
|
67
|
+
};
|
|
68
|
+
};
|
|
69
|
+
export const createSinksFactory = (props) => () => createSinks(props);
|
|
70
|
+
//# sourceMappingURL=createSinks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createSinks.js","sourceRoot":"","sources":["../../src/createSinks.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Block.entity.d.ts","sourceRoot":"","sources":["../../../src/entity/Block.entity.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAG5C,qBACa,WAAW;
|
|
1
|
+
{"version":3,"file":"Block.entity.d.ts","sourceRoot":"","sources":["../../../src/entity/Block.entity.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAG5C,qBACa,WAAW;IAEtB,MAAM,CAAC,EAAE,OAAO,CAAC,OAAO,CAAC;IAIzB,IAAI,CAAC,EAAE,OAAO,CAAC,OAAO,CAAC;IAIvB,IAAI,CAAC,EAAE,OAAO,CAAC,IAAI,CAAC;CACrB"}
|
|
@@ -12,8 +12,7 @@ import { Column, Entity, Index, PrimaryColumn } from 'typeorm';
|
|
|
12
12
|
let BlockEntity = class BlockEntity {
|
|
13
13
|
};
|
|
14
14
|
__decorate([
|
|
15
|
-
|
|
16
|
-
Column(),
|
|
15
|
+
PrimaryColumn(),
|
|
17
16
|
__metadata("design:type", Number)
|
|
18
17
|
], BlockEntity.prototype, "height", void 0);
|
|
19
18
|
__decorate([
|
|
@@ -22,7 +21,8 @@ __decorate([
|
|
|
22
21
|
__metadata("design:type", String)
|
|
23
22
|
], BlockEntity.prototype, "hash", void 0);
|
|
24
23
|
__decorate([
|
|
25
|
-
|
|
24
|
+
Index({ unique: true }),
|
|
25
|
+
Column(),
|
|
26
26
|
__metadata("design:type", Number)
|
|
27
27
|
], BlockEntity.prototype, "slot", void 0);
|
|
28
28
|
BlockEntity = __decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Block.entity.js","sourceRoot":"","sources":["../../../src/entity/Block.entity.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAC5C,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAGxD,IAAM,WAAW,GAAjB,MAAM,WAAW;CAWvB,CAAA;AAVC;IAAC,
|
|
1
|
+
{"version":3,"file":"Block.entity.js","sourceRoot":"","sources":["../../../src/entity/Block.entity.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAC5C,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAGxD,IAAM,WAAW,GAAjB,MAAM,WAAW;CAWvB,CAAA;AAVC;IAAC,aAAa,EAAE;;2CACS;AAEzB;IAAC,KAAK,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;IACvB,MAAM,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;yCACd;AAEvB;IAAC,KAAK,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;IACvB,MAAM,EAAE;;yCACW;AAVT,WAAW;IADvB,MAAM,EAAE;GACI,WAAW,CAWvB;SAXY,WAAW"}
|
|
@@ -20,7 +20,7 @@ __decorate([
|
|
|
20
20
|
], BlockDataEntity.prototype, "blockHeight", void 0);
|
|
21
21
|
__decorate([
|
|
22
22
|
OneToOne(() => BlockEntity, DeleteCascadeRelationOptions),
|
|
23
|
-
JoinColumn(
|
|
23
|
+
JoinColumn(),
|
|
24
24
|
__metadata("design:type", BlockEntity)
|
|
25
25
|
], BlockDataEntity.prototype, "block", void 0);
|
|
26
26
|
__decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BlockData.entity.js","sourceRoot":"","sources":["../../../src/entity/BlockData.entity.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAC5C,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAC9E,OAAO,EAAE,4BAA4B,EAAE,MAAM,QAAQ,CAAC;AACtD,OAAO,EAAE,IAAI,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAG7D,IAAM,eAAe,GAArB,MAAM,eAAe;CAW3B,CAAA;AATC;IAAC,aAAa,EAAE;;oDACK;AAErB;IAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,WAAW,EAAE,4BAA4B,CAAC;IACzD,UAAU,
|
|
1
|
+
{"version":3,"file":"BlockData.entity.js","sourceRoot":"","sources":["../../../src/entity/BlockData.entity.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAC5C,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAC9E,OAAO,EAAE,4BAA4B,EAAE,MAAM,QAAQ,CAAC;AACtD,OAAO,EAAE,IAAI,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAG7D,IAAM,eAAe,GAArB,MAAM,eAAe;CAW3B,CAAA;AATC;IAAC,aAAa,EAAE;;oDACK;AAErB;IAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,WAAW,EAAE,4BAA4B,CAAC;IACzD,UAAU,EAAE;8BACL,WAAW;8CAAC;AAEpB;IAAC,MAAM,CAAC,EAAE,WAAW,EAAE,CAAC,eAAe,EAAE,IAAI,EAAE,WAAW,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;;6CACxD;AAVV,eAAe;IAD3B,MAAM,EAAE;GACI,eAAe,CAW3B;SAXY,eAAe"}
|
|
@@ -4,8 +4,4 @@ export * from './StakeKey.entity';
|
|
|
4
4
|
export * from './StakePool.entity';
|
|
5
5
|
export * from './PoolRetirement.entity';
|
|
6
6
|
export * from './PoolRegistration.entity';
|
|
7
|
-
export * from './PoolMetadata.entity';
|
|
8
|
-
export * from './Asset.entity';
|
|
9
|
-
export * from './Tokens.entity';
|
|
10
|
-
export * from './Output.entity';
|
|
11
7
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/entity/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC;AAClC,cAAc,oBAAoB,CAAC;AACnC,cAAc,yBAAyB,CAAC;AACxC,cAAc,2BAA2B,CAAC
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/entity/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC;AAClC,cAAc,oBAAoB,CAAC;AACnC,cAAc,yBAAyB,CAAC;AACxC,cAAc,2BAA2B,CAAC"}
|
package/dist/esm/entity/index.js
CHANGED
|
@@ -4,8 +4,4 @@ export * from './StakeKey.entity';
|
|
|
4
4
|
export * from './StakePool.entity';
|
|
5
5
|
export * from './PoolRetirement.entity';
|
|
6
6
|
export * from './PoolRegistration.entity';
|
|
7
|
-
export * from './PoolMetadata.entity';
|
|
8
|
-
export * from './Asset.entity';
|
|
9
|
-
export * from './Tokens.entity';
|
|
10
|
-
export * from './Output.entity';
|
|
11
7
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/entity/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC;AAClC,cAAc,oBAAoB,CAAC;AACnC,cAAc,yBAAyB,CAAC;AACxC,cAAc,2BAA2B,CAAC
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/entity/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC;AAClC,cAAc,oBAAoB,CAAC;AACnC,cAAc,yBAAyB,CAAC;AACxC,cAAc,2BAA2B,CAAC"}
|
package/dist/esm/index.d.ts
CHANGED
|
@@ -1,9 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
export * from './operators/withTypeormTransaction';
|
|
1
|
+
export * from './createSinks';
|
|
3
2
|
export * from './createDataSource';
|
|
4
3
|
export * from './entity';
|
|
5
|
-
export * from './operators';
|
|
6
|
-
export * from './TypeormStabilityWindowBuffer';
|
|
7
|
-
export * from './isRecoverableTypeormError';
|
|
8
|
-
export { BossDb, STAKE_POOL_METADATA_QUEUE, StakePoolMetadataJob as StakePoolMetadataTask } from './pgBoss';
|
|
9
4
|
//# sourceMappingURL=index.d.ts.map
|