@cardano-sdk/projection-typeorm 0.2.0-nightly.6 → 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
package/README.md
CHANGED
|
@@ -1,12 +1,3 @@
|
|
|
1
1
|
# Cardano JS SDK | projection-typeorm
|
|
2
2
|
|
|
3
|
-
Project Chain Sync events into PostgreSQL via TypeORM
|
|
4
|
-
|
|
5
|
-
## Adding new projections
|
|
6
|
-
|
|
7
|
-
1. Create a new mapper that maps the block into something that you want to project (see [withStakeKeys](../projection/src/operators/Mappers/certificates/withStakeKeys.ts) as an example).
|
|
8
|
-
2. Create a new granular TypeORM store (see [storeStakeKeys](./src/operators/storeStakeKeys.ts)) as an example.
|
|
9
|
-
|
|
10
|
-
### Demo
|
|
11
|
-
|
|
12
|
-
See [demo/projection-typeorm.js](../../demo/)
|
|
3
|
+
Project Chain Sync events into PostgreSQL via TypeORM
|
|
@@ -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,16 +1,16 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
3
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
4
|
+
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");
|
|
5
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
6
|
+
};
|
|
2
7
|
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
|
|
3
8
|
if (kind === "m") throw new TypeError("Private method is not writable");
|
|
4
9
|
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
|
5
10
|
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");
|
|
6
11
|
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
7
12
|
};
|
|
8
|
-
var
|
|
9
|
-
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
10
|
-
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");
|
|
11
|
-
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
12
|
-
};
|
|
13
|
-
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;
|
|
13
|
+
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;
|
|
14
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
15
|
exports.TypeormStabilityWindowBuffer = void 0;
|
|
16
16
|
const entity_1 = require("./entity");
|
|
@@ -18,36 +18,24 @@ const core_1 = require("@cardano-sdk/core");
|
|
|
18
18
|
const typeorm_1 = require("typeorm");
|
|
19
19
|
const rxjs_1 = require("rxjs");
|
|
20
20
|
const util_1 = require("@cardano-sdk/util");
|
|
21
|
-
const pointEquals = (point1, point2) => {
|
|
22
|
-
if (typeof point1 !== 'object') {
|
|
23
|
-
return point1 === point2;
|
|
24
|
-
}
|
|
25
|
-
if (typeof point2 !== 'object') {
|
|
26
|
-
return false;
|
|
27
|
-
}
|
|
28
|
-
return point1.header.hash === point2.header.hash;
|
|
29
|
-
};
|
|
30
21
|
const blockDataSelect = {
|
|
31
22
|
data: true
|
|
32
23
|
};
|
|
33
24
|
class TypeormStabilityWindowBuffer {
|
|
34
|
-
constructor({ allowNonSequentialBlockHeights, compactBufferEveryNBlocks = 100,
|
|
25
|
+
constructor({ allowNonSequentialBlockHeights, compactBufferEveryNBlocks = 100 }, dependencies) {
|
|
35
26
|
_TypeormStabilityWindowBuffer_instances.add(this);
|
|
36
27
|
_TypeormStabilityWindowBuffer_tail.set(this, void 0);
|
|
37
|
-
_TypeormStabilityWindowBuffer_tip.set(this, void 0);
|
|
38
|
-
_TypeormStabilityWindowBuffer_tip$.set(this, new rxjs_1.ReplaySubject(1));
|
|
39
|
-
_TypeormStabilityWindowBuffer_tail$.set(this, new rxjs_1.ReplaySubject(1));
|
|
40
28
|
_TypeormStabilityWindowBuffer_logger.set(this, void 0);
|
|
41
29
|
_TypeormStabilityWindowBuffer_compactEvery.set(this, void 0);
|
|
42
30
|
_TypeormStabilityWindowBuffer_allowNonSequentialBlockHeights.set(this, void 0);
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
__classPrivateFieldSet(this, _TypeormStabilityWindowBuffer_logger, (0, util_1.contextLogger)(logger, 'TypeormStabilityWindowBuffer'), "f");
|
|
31
|
+
_TypeormStabilityWindowBuffer_tip$.set(this, new rxjs_1.ReplaySubject(1));
|
|
32
|
+
_TypeormStabilityWindowBuffer_tail$.set(this, new rxjs_1.ReplaySubject(1));
|
|
46
33
|
this.tip$ = __classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tip$, "f").asObservable();
|
|
47
34
|
this.tail$ = __classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tail$, "f").asObservable();
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
35
|
+
__classPrivateFieldSet(this, _TypeormStabilityWindowBuffer_compactEvery, compactBufferEveryNBlocks, "f");
|
|
36
|
+
__classPrivateFieldSet(this, _TypeormStabilityWindowBuffer_allowNonSequentialBlockHeights, allowNonSequentialBlockHeights, "f");
|
|
37
|
+
__classPrivateFieldSet(this, _TypeormStabilityWindowBuffer_logger, (0, util_1.contextLogger)(dependencies.logger, 'PgStabilityWindowBuffer'), "f");
|
|
38
|
+
this.handleEvents = (evt$) => evt$.pipe((0, rxjs_1.concatMap)((evt) => (0, rxjs_1.from)(evt.eventType === core_1.ChainSyncEventType.RollForward ? __classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_instances, "m", _TypeormStabilityWindowBuffer_rollForward).call(this, evt) : __classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_instances, "m", _TypeormStabilityWindowBuffer_rollBackward).call(this, evt)).pipe((0, rxjs_1.map)(() => evt))));
|
|
51
39
|
}
|
|
52
40
|
async initialize(queryRunner) {
|
|
53
41
|
const repository = queryRunner.manager.getRepository(entity_1.BlockDataEntity);
|
|
@@ -59,7 +47,7 @@ class TypeormStabilityWindowBuffer {
|
|
|
59
47
|
}),
|
|
60
48
|
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_instances, "m", _TypeormStabilityWindowBuffer_findTail).call(this, repository)
|
|
61
49
|
]);
|
|
62
|
-
__classPrivateFieldGet(this,
|
|
50
|
+
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tip$, "f").next(tip[0]?.data || 'origin');
|
|
63
51
|
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_instances, "m", _TypeormStabilityWindowBuffer_setTail).call(this, tail[0]?.data || 'origin');
|
|
64
52
|
}
|
|
65
53
|
shutdown() {
|
|
@@ -68,27 +56,25 @@ class TypeormStabilityWindowBuffer {
|
|
|
68
56
|
}
|
|
69
57
|
}
|
|
70
58
|
exports.TypeormStabilityWindowBuffer = TypeormStabilityWindowBuffer;
|
|
71
|
-
_TypeormStabilityWindowBuffer_tail = new WeakMap(),
|
|
59
|
+
_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) {
|
|
72
60
|
return repository.find({
|
|
73
61
|
order: { blockHeight: 'ASC' },
|
|
74
62
|
select: blockDataSelect,
|
|
75
63
|
take: 1
|
|
76
64
|
});
|
|
77
65
|
}, _TypeormStabilityWindowBuffer_rollForward = async function _TypeormStabilityWindowBuffer_rollForward(evt) {
|
|
78
|
-
const { eventType, transactionCommitted$, queryRunner, block } = evt;
|
|
66
|
+
const { eventType, transactionCommitted$, queryRunner, blockEntity, block } = evt;
|
|
79
67
|
const { header: { blockNo } } = block;
|
|
80
68
|
const repository = queryRunner.manager.getRepository(entity_1.BlockDataEntity);
|
|
81
69
|
if (eventType === core_1.ChainSyncEventType.RollForward) {
|
|
82
70
|
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_logger, "f").debug('Add block data at height', blockNo);
|
|
83
71
|
const blockData = repository.create({
|
|
84
|
-
block:
|
|
85
|
-
height: blockNo
|
|
86
|
-
},
|
|
72
|
+
block: blockEntity,
|
|
87
73
|
data: block
|
|
88
74
|
});
|
|
89
75
|
await Promise.all([repository.insert(blockData), __classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_instances, "m", _TypeormStabilityWindowBuffer_deleteOldBlockData).call(this, evt)]);
|
|
90
76
|
transactionCommitted$.subscribe(() => {
|
|
91
|
-
__classPrivateFieldGet(this,
|
|
77
|
+
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tip$, "f").next(block);
|
|
92
78
|
if (__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tail, "f") === 'origin') {
|
|
93
79
|
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_instances, "m", _TypeormStabilityWindowBuffer_setTail).call(this, block);
|
|
94
80
|
}
|
|
@@ -109,7 +95,7 @@ _TypeormStabilityWindowBuffer_tail = new WeakMap(), _TypeormStabilityWindowBuffe
|
|
|
109
95
|
throw new Error('Assert: inconsistent PgStabilityWindowBuffer at rollBackward');
|
|
110
96
|
}
|
|
111
97
|
transactionCommitted$.subscribe(() => {
|
|
112
|
-
__classPrivateFieldGet(this,
|
|
98
|
+
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tip$, "f").next(prevTip?.data || 'origin');
|
|
113
99
|
if (!prevTip?.data) {
|
|
114
100
|
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_instances, "m", _TypeormStabilityWindowBuffer_setTail).call(this, 'origin');
|
|
115
101
|
}
|
|
@@ -143,14 +129,7 @@ _TypeormStabilityWindowBuffer_tail = new WeakMap(), _TypeormStabilityWindowBuffe
|
|
|
143
129
|
}
|
|
144
130
|
transactionCommitted$.subscribe(() => __classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_instances, "m", _TypeormStabilityWindowBuffer_setTail).call(this, nextTailEntity.data));
|
|
145
131
|
}, _TypeormStabilityWindowBuffer_setTail = function _TypeormStabilityWindowBuffer_setTail(tail) {
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tail$, "f").next(tail);
|
|
149
|
-
}
|
|
150
|
-
}, _TypeormStabilityWindowBuffer_setTip = function _TypeormStabilityWindowBuffer_setTip(tip) {
|
|
151
|
-
if (!pointEquals(tip, __classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tip, "f"))) {
|
|
152
|
-
__classPrivateFieldSet(this, _TypeormStabilityWindowBuffer_tip, tip, "f");
|
|
153
|
-
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tip$, "f").next(tip);
|
|
154
|
-
}
|
|
132
|
+
__classPrivateFieldSet(this, _TypeormStabilityWindowBuffer_tail, tail, "f");
|
|
133
|
+
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tail$, "f").next(tail);
|
|
155
134
|
};
|
|
156
135
|
//# sourceMappingURL=TypeormStabilityWindowBuffer.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TypeormStabilityWindowBuffer.js","sourceRoot":"","sources":["../../src/TypeormStabilityWindowBuffer.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAEA,qCAA2C;AAC3C,4CAAgE;AAChE,qCAA+E;AAE/E,+BAAuE;AASvE,4CAA8D;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,16 +1,40 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
2
25
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
26
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
27
|
};
|
|
5
28
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.createDataSource =
|
|
29
|
+
exports.createDataSource = void 0;
|
|
7
30
|
require("reflect-metadata");
|
|
8
|
-
const
|
|
31
|
+
const supportedSinks = __importStar(require("./sinks"));
|
|
32
|
+
const entity_1 = require("./entity");
|
|
33
|
+
const Block_entity_1 = require("./entity/Block.entity");
|
|
9
34
|
const typeorm_1 = require("typeorm");
|
|
10
|
-
const util_1 = require("@cardano-sdk/util");
|
|
11
35
|
const logger_1 = require("./logger");
|
|
12
|
-
const pg_boss_1 = __importDefault(require("pg-boss"));
|
|
13
36
|
const snakeCase_1 = __importDefault(require("lodash/snakeCase"));
|
|
37
|
+
const uniq_1 = __importDefault(require("lodash/uniq"));
|
|
14
38
|
const toTableName = (tableOrName) => (typeof tableOrName === 'string' ? tableOrName : tableOrName.name).replace('_entity', '');
|
|
15
39
|
const namingOverrides = {
|
|
16
40
|
columnName(propertyName, customName, _embeddedPrefixes) {
|
|
@@ -54,44 +78,12 @@ const namingStrategy = new Proxy(defaultStrategy, {
|
|
|
54
78
|
return value;
|
|
55
79
|
}
|
|
56
80
|
});
|
|
57
|
-
const
|
|
58
|
-
const
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
const queryRunner = dataSource.createQueryRunner('master');
|
|
64
|
-
try {
|
|
65
|
-
if (dropSchema) {
|
|
66
|
-
await queryRunner.query('DROP SCHEMA IF EXISTS pgboss CASCADE;');
|
|
67
|
-
}
|
|
68
|
-
else if (await (0, exports.pgBossSchemaExists)(queryRunner)) {
|
|
69
|
-
return;
|
|
70
|
-
}
|
|
71
|
-
if (!usePgBoss) {
|
|
72
|
-
return;
|
|
73
|
-
}
|
|
74
|
-
const boss = new pg_boss_1.default({
|
|
75
|
-
db: new pgBoss_1.BossDb(queryRunner)
|
|
76
|
-
});
|
|
77
|
-
await queryRunner.query('CREATE EXTENSION IF NOT EXISTS pgcrypto;');
|
|
78
|
-
await boss.start();
|
|
79
|
-
await boss.stop();
|
|
80
|
-
await queryRunner.query(`
|
|
81
|
-
ALTER TABLE pgboss.job
|
|
82
|
-
ADD COLUMN block_slot INTEGER,
|
|
83
|
-
ADD CONSTRAINT job_block_slot_fkey
|
|
84
|
-
FOREIGN KEY (block_slot) REFERENCES public.block(slot)
|
|
85
|
-
ON DELETE CASCADE;
|
|
86
|
-
`);
|
|
87
|
-
logger.info('"pgboss" schema created');
|
|
88
|
-
}
|
|
89
|
-
finally {
|
|
90
|
-
await queryRunner.release();
|
|
91
|
-
}
|
|
92
|
-
};
|
|
93
|
-
const createDataSource = ({ connectionConfig, devOptions, options, entities, extensions, logger }) => {
|
|
94
|
-
const dataSource = new typeorm_1.DataSource({
|
|
81
|
+
const createDataSource = ({ connectionConfig, devOptions, options, projections, logger }) => {
|
|
82
|
+
const requestedProjectionEntities = Object.entries(supportedSinks)
|
|
83
|
+
.filter(([projectionName]) => projectionName in projections)
|
|
84
|
+
.flatMap(([_, sink]) => sink.entities);
|
|
85
|
+
const entities = (0, uniq_1.default)([Block_entity_1.BlockEntity, entity_1.BlockDataEntity, ...requestedProjectionEntities]);
|
|
86
|
+
return new typeorm_1.DataSource({
|
|
95
87
|
...connectionConfig,
|
|
96
88
|
...devOptions,
|
|
97
89
|
...options,
|
|
@@ -101,13 +93,6 @@ const createDataSource = ({ connectionConfig, devOptions, options, entities, ext
|
|
|
101
93
|
namingStrategy,
|
|
102
94
|
type: 'postgres'
|
|
103
95
|
});
|
|
104
|
-
return (0, util_1.patchObject)(dataSource, {
|
|
105
|
-
async initialize() {
|
|
106
|
-
await dataSource.initialize();
|
|
107
|
-
await initializePgBoss(dataSource, (0, util_1.contextLogger)(logger, 'createDataSource'), extensions?.pgBoss, devOptions?.dropSchema);
|
|
108
|
-
return dataSource;
|
|
109
|
-
}
|
|
110
|
-
});
|
|
111
96
|
};
|
|
112
97
|
exports.createDataSource = createDataSource;
|
|
113
98
|
//# sourceMappingURL=createDataSource.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createDataSource.js","sourceRoot":"","sources":["../../src/createDataSource.ts"],"names":[],"mappings":"
|
|
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,101 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
exports.createSinksFactory = exports.createSinks = void 0;
|
|
30
|
+
require("reflect-metadata");
|
|
31
|
+
const supportedSinks = __importStar(require("./sinks"));
|
|
32
|
+
const Block_entity_1 = require("./entity/Block.entity");
|
|
33
|
+
const core_1 = require("@cardano-sdk/core");
|
|
34
|
+
const rxjs_1 = require("rxjs");
|
|
35
|
+
const projection_1 = require("@cardano-sdk/projection");
|
|
36
|
+
const backoff_rxjs_1 = require("backoff-rxjs");
|
|
37
|
+
const TypeormStabilityWindowBuffer_1 = require("./TypeormStabilityWindowBuffer");
|
|
38
|
+
const util_rxjs_1 = require("@cardano-sdk/util-rxjs");
|
|
39
|
+
const util_1 = require("./util");
|
|
40
|
+
const omit_1 = __importDefault(require("lodash/omit"));
|
|
41
|
+
const defaultReconnectionConfig = { initialInterval: 10, maxInterval: 5000 };
|
|
42
|
+
const TypeormContextProps = ['blockEntity', 'queryRunner', 'transactionCommitted$'];
|
|
43
|
+
const withQueryRunner = (dataSource, buffer, logger) => (0, rxjs_1.concat)((0, rxjs_1.from)((async () => {
|
|
44
|
+
const queryRunner = dataSource.createQueryRunner('master');
|
|
45
|
+
await queryRunner.connect();
|
|
46
|
+
await buffer.initialize(queryRunner);
|
|
47
|
+
return { queryRunner };
|
|
48
|
+
})()), rxjs_1.NEVER).pipe((0, util_rxjs_1.finalizeWithLatest)(async (evt) => {
|
|
49
|
+
if (!evt)
|
|
50
|
+
return;
|
|
51
|
+
if (evt.queryRunner.isTransactionActive) {
|
|
52
|
+
try {
|
|
53
|
+
await evt.queryRunner.rollbackTransaction();
|
|
54
|
+
}
|
|
55
|
+
catch (error) {
|
|
56
|
+
logger.error('Failed to rollback transaction', error);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
if (!evt.queryRunner.isReleased) {
|
|
60
|
+
try {
|
|
61
|
+
await evt.queryRunner.release();
|
|
62
|
+
}
|
|
63
|
+
catch (error) {
|
|
64
|
+
logger.error('Failed to "release" query runner', error);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}));
|
|
68
|
+
const createSinks = ({ dataSource$, reconnectionConfig, logger, compactBufferEveryNBlocks, allowNonSequentialBlockHeights }) => {
|
|
69
|
+
const buffer = new TypeormStabilityWindowBuffer_1.TypeormStabilityWindowBuffer({ allowNonSequentialBlockHeights, compactBufferEveryNBlocks }, { logger });
|
|
70
|
+
return {
|
|
71
|
+
after: (evt$) => evt$.pipe((0, rxjs_1.concatMap)((evt) => (0, rxjs_1.from)(evt.queryRunner.commitTransaction()).pipe((0, rxjs_1.tap)(() => evt.transactionCommitted$.next()), (0, rxjs_1.map)(() => (0, omit_1.default)(evt, TypeormContextProps)))), (0, backoff_rxjs_1.retryBackoff)({
|
|
72
|
+
...reconnectionConfig,
|
|
73
|
+
...defaultReconnectionConfig,
|
|
74
|
+
shouldRetry: (error) => (0, util_1.isRecoverableTypeormError)(error)
|
|
75
|
+
}), (0, rxjs_1.finalize)(() => buffer.shutdown())),
|
|
76
|
+
before: (evt$) => evt$.pipe((0, rxjs_1.share)({
|
|
77
|
+
connector: () => new rxjs_1.ReplaySubject(1),
|
|
78
|
+
resetOnComplete: false,
|
|
79
|
+
resetOnError: true,
|
|
80
|
+
resetOnRefCountZero: () => (0, rxjs_1.timer)(3000)
|
|
81
|
+
}), projection_1.Operators.withStaticContext(dataSource$.pipe((0, rxjs_1.switchMap)((dataSource) => withQueryRunner(dataSource, buffer, logger)))), projection_1.Operators.withEventContext(({ queryRunner }) => (0, rxjs_1.from)(queryRunner.startTransaction('SERIALIZABLE').then(() => ({ transactionCommitted$: new rxjs_1.Subject() })))), projection_1.Operators.withEventContext(({ block, queryRunner, eventType }) => {
|
|
82
|
+
const repository = queryRunner.manager.getRepository(Block_entity_1.BlockEntity);
|
|
83
|
+
const blockEntity = repository.create({
|
|
84
|
+
hash: block.header.hash,
|
|
85
|
+
height: block.header.blockNo,
|
|
86
|
+
slot: block.header.slot
|
|
87
|
+
});
|
|
88
|
+
return (0, rxjs_1.from)(eventType === core_1.ChainSyncEventType.RollForward
|
|
89
|
+
? repository.insert(blockEntity)
|
|
90
|
+
: repository.delete({
|
|
91
|
+
hash: blockEntity.hash
|
|
92
|
+
})).pipe((0, rxjs_1.map)(() => ({ blockEntity })));
|
|
93
|
+
})),
|
|
94
|
+
buffer,
|
|
95
|
+
projectionSinks: supportedSinks
|
|
96
|
+
};
|
|
97
|
+
};
|
|
98
|
+
exports.createSinks = createSinks;
|
|
99
|
+
const createSinksFactory = (props) => () => (0, exports.createSinks)(props);
|
|
100
|
+
exports.createSinksFactory = createSinksFactory;
|
|
101
|
+
//# 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"}
|
|
@@ -15,8 +15,7 @@ const typeorm_1 = require("typeorm");
|
|
|
15
15
|
let BlockEntity = class BlockEntity {
|
|
16
16
|
};
|
|
17
17
|
__decorate([
|
|
18
|
-
(0, typeorm_1.
|
|
19
|
-
(0, typeorm_1.Column)(),
|
|
18
|
+
(0, typeorm_1.PrimaryColumn)(),
|
|
20
19
|
__metadata("design:type", Number)
|
|
21
20
|
], BlockEntity.prototype, "height", void 0);
|
|
22
21
|
__decorate([
|
|
@@ -25,7 +24,8 @@ __decorate([
|
|
|
25
24
|
__metadata("design:type", String)
|
|
26
25
|
], BlockEntity.prototype, "hash", void 0);
|
|
27
26
|
__decorate([
|
|
28
|
-
(0, typeorm_1.
|
|
27
|
+
(0, typeorm_1.Index)({ unique: true }),
|
|
28
|
+
(0, typeorm_1.Column)(),
|
|
29
29
|
__metadata("design:type", Number)
|
|
30
30
|
], BlockEntity.prototype, "slot", void 0);
|
|
31
31
|
BlockEntity = __decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Block.entity.js","sourceRoot":"","sources":["../../../src/entity/Block.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,4CAA4C;AAC5C,qCAA+D;AAGxD,IAAM,WAAW,GAAjB,MAAM,WAAW;CAWvB,CAAA;AAVC;IAAC,IAAA,
|
|
1
|
+
{"version":3,"file":"Block.entity.js","sourceRoot":"","sources":["../../../src/entity/Block.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,4CAA4C;AAC5C,qCAA+D;AAGxD,IAAM,WAAW,GAAjB,MAAM,WAAW;CAWvB,CAAA;AAVC;IAAC,IAAA,uBAAa,GAAE;;2CACS;AAEzB;IAAC,IAAA,eAAK,EAAC,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;IACvB,IAAA,gBAAM,EAAC,EAAE,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;yCACd;AAEvB;IAAC,IAAA,eAAK,EAAC,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;IACvB,IAAA,gBAAM,GAAE;;yCACW;AAVT,WAAW;IADvB,IAAA,gBAAM,GAAE;GACI,WAAW,CAWvB;AAXY,kCAAW"}
|
|
@@ -23,7 +23,7 @@ __decorate([
|
|
|
23
23
|
], BlockDataEntity.prototype, "blockHeight", void 0);
|
|
24
24
|
__decorate([
|
|
25
25
|
(0, typeorm_1.OneToOne)(() => Block_entity_1.BlockEntity, util_1.DeleteCascadeRelationOptions),
|
|
26
|
-
(0, typeorm_1.JoinColumn)(
|
|
26
|
+
(0, typeorm_1.JoinColumn)(),
|
|
27
27
|
__metadata("design:type", Block_entity_1.BlockEntity)
|
|
28
28
|
], BlockDataEntity.prototype, "block", void 0);
|
|
29
29
|
__decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BlockData.entity.js","sourceRoot":"","sources":["../../../src/entity/BlockData.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,iDAA6C;AAC7C,4CAA4C;AAC5C,qCAA8E;AAC9E,iCAAsD;AACtD,iDAAoE;AAG7D,IAAM,eAAe,GAArB,MAAM,eAAe;CAW3B,CAAA;AATC;IAAC,IAAA,uBAAa,GAAE;;oDACK;AAErB;IAAC,IAAA,kBAAQ,EAAC,GAAG,EAAE,CAAC,0BAAW,EAAE,mCAA4B,CAAC;IACzD,IAAA,oBAAU,
|
|
1
|
+
{"version":3,"file":"BlockData.entity.js","sourceRoot":"","sources":["../../../src/entity/BlockData.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,iDAA6C;AAC7C,4CAA4C;AAC5C,qCAA8E;AAC9E,iCAAsD;AACtD,iDAAoE;AAG7D,IAAM,eAAe,GAArB,MAAM,eAAe;CAW3B,CAAA;AATC;IAAC,IAAA,uBAAa,GAAE;;oDACK;AAErB;IAAC,IAAA,kBAAQ,EAAC,GAAG,EAAE,CAAC,0BAAW,EAAE,mCAA4B,CAAC;IACzD,IAAA,oBAAU,GAAE;8BACL,0BAAW;8CAAC;AAEpB;IAAC,IAAA,gBAAM,EAAC,EAAE,WAAW,EAAE,CAAC,8BAAe,EAAE,mBAAI,EAAE,0BAAW,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;;6CACxD;AAVV,eAAe;IAD3B,IAAA,gBAAM,GAAE;GACI,eAAe,CAW3B;AAXY,0CAAe"}
|
|
@@ -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/cjs/entity/index.js
CHANGED
|
@@ -20,8 +20,4 @@ __exportStar(require("./StakeKey.entity"), exports);
|
|
|
20
20
|
__exportStar(require("./StakePool.entity"), exports);
|
|
21
21
|
__exportStar(require("./PoolRetirement.entity"), exports);
|
|
22
22
|
__exportStar(require("./PoolRegistration.entity"), exports);
|
|
23
|
-
__exportStar(require("./PoolMetadata.entity"), exports);
|
|
24
|
-
__exportStar(require("./Asset.entity"), exports);
|
|
25
|
-
__exportStar(require("./Tokens.entity"), exports);
|
|
26
|
-
__exportStar(require("./Output.entity"), exports);
|
|
27
23
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/entity/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,qDAAmC;AACnC,iDAA+B;AAC/B,oDAAkC;AAClC,qDAAmC;AACnC,0DAAwC;AACxC,4DAA0C
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/entity/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,qDAAmC;AACnC,iDAA+B;AAC/B,oDAAkC;AAClC,qDAAmC;AACnC,0DAAwC;AACxC,4DAA0C"}
|
package/dist/cjs/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
|