@cardano-sdk/projection-typeorm 0.1.1-nightly.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/LICENSE +201 -0
- package/NOTICE +5 -0
- package/README.md +3 -0
- package/dist/cjs/TypeormStabilityWindowBuffer.d.ts +19 -0
- package/dist/cjs/TypeormStabilityWindowBuffer.d.ts.map +1 -0
- package/dist/cjs/TypeormStabilityWindowBuffer.js +152 -0
- package/dist/cjs/TypeormStabilityWindowBuffer.js.map +1 -0
- package/dist/cjs/createDataSource.d.ts +19 -0
- package/dist/cjs/createDataSource.d.ts.map +1 -0
- package/dist/cjs/createDataSource.js +98 -0
- package/dist/cjs/createDataSource.js.map +1 -0
- 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 +10 -0
- package/dist/cjs/entity/Block.entity.d.ts.map +1 -0
- package/dist/cjs/entity/Block.entity.js +44 -0
- package/dist/cjs/entity/Block.entity.js.map +1 -0
- package/dist/cjs/entity/BlockData.entity.d.ts +8 -0
- package/dist/cjs/entity/BlockData.entity.d.ts.map +1 -0
- package/dist/cjs/entity/BlockData.entity.js +36 -0
- package/dist/cjs/entity/BlockData.entity.js.map +1 -0
- package/dist/cjs/entity/StakeKey.entity.d.ts +5 -0
- package/dist/cjs/entity/StakeKey.entity.d.ts.map +1 -0
- package/dist/cjs/entity/StakeKey.entity.js +25 -0
- package/dist/cjs/entity/StakeKey.entity.js.map +1 -0
- package/dist/cjs/entity/index.d.ts +4 -0
- package/dist/cjs/entity/index.d.ts.map +1 -0
- package/dist/cjs/entity/index.js +20 -0
- package/dist/cjs/entity/index.js.map +1 -0
- package/dist/cjs/entity/transformers.d.ts +5 -0
- package/dist/cjs/entity/transformers.d.ts.map +1 -0
- package/dist/cjs/entity/transformers.js +29 -0
- package/dist/cjs/entity/transformers.js.map +1 -0
- package/dist/cjs/index.d.ts +4 -0
- package/dist/cjs/index.d.ts.map +1 -0
- package/dist/cjs/index.js +20 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/logger.d.ts +15 -0
- package/dist/cjs/logger.d.ts.map +1 -0
- package/dist/cjs/logger.js +45 -0
- package/dist/cjs/logger.js.map +1 -0
- package/dist/cjs/package.json +3 -0
- package/dist/cjs/sinks/index.d.ts +2 -0
- package/dist/cjs/sinks/index.d.ts.map +1 -0
- package/dist/cjs/sinks/index.js +6 -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/tsconfig.tsbuildinfo +1 -0
- package/dist/cjs/types.d.ts +14 -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 +19 -0
- package/dist/esm/TypeormStabilityWindowBuffer.d.ts.map +1 -0
- package/dist/esm/TypeormStabilityWindowBuffer.js +148 -0
- package/dist/esm/TypeormStabilityWindowBuffer.js.map +1 -0
- package/dist/esm/createDataSource.d.ts +19 -0
- package/dist/esm/createDataSource.d.ts.map +1 -0
- package/dist/esm/createDataSource.js +68 -0
- package/dist/esm/createDataSource.js.map +1 -0
- 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 +10 -0
- package/dist/esm/entity/Block.entity.d.ts.map +1 -0
- package/dist/esm/entity/Block.entity.js +41 -0
- package/dist/esm/entity/Block.entity.js.map +1 -0
- package/dist/esm/entity/BlockData.entity.d.ts +8 -0
- package/dist/esm/entity/BlockData.entity.d.ts.map +1 -0
- package/dist/esm/entity/BlockData.entity.js +33 -0
- package/dist/esm/entity/BlockData.entity.js.map +1 -0
- package/dist/esm/entity/StakeKey.entity.d.ts +5 -0
- package/dist/esm/entity/StakeKey.entity.d.ts.map +1 -0
- package/dist/esm/entity/StakeKey.entity.js +22 -0
- package/dist/esm/entity/StakeKey.entity.js.map +1 -0
- package/dist/esm/entity/index.d.ts +4 -0
- package/dist/esm/entity/index.d.ts.map +1 -0
- package/dist/esm/entity/index.js +4 -0
- package/dist/esm/entity/index.js.map +1 -0
- package/dist/esm/entity/transformers.d.ts +5 -0
- package/dist/esm/entity/transformers.d.ts.map +1 -0
- package/dist/esm/entity/transformers.js +26 -0
- package/dist/esm/entity/transformers.js.map +1 -0
- package/dist/esm/index.d.ts +4 -0
- package/dist/esm/index.d.ts.map +1 -0
- package/dist/esm/index.js +4 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/logger.d.ts +15 -0
- package/dist/esm/logger.d.ts.map +1 -0
- package/dist/esm/logger.js +41 -0
- package/dist/esm/logger.js.map +1 -0
- package/dist/esm/package.json +4 -0
- package/dist/esm/sinks/index.d.ts +2 -0
- package/dist/esm/sinks/index.d.ts.map +1 -0
- package/dist/esm/sinks/index.js +2 -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/tsconfig.tsbuildinfo +1 -0
- package/dist/esm/types.d.ts +14 -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 +82 -0
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { BlockEntity } from './entity/Block.entity';
|
|
2
|
+
import { QueryRunner } from 'typeorm';
|
|
3
|
+
import { Sink } from '@cardano-sdk/projection';
|
|
4
|
+
import { Subject } from 'rxjs';
|
|
5
|
+
export interface WithTypeormContext {
|
|
6
|
+
queryRunner: QueryRunner;
|
|
7
|
+
transactionCommitted$: Subject<void>;
|
|
8
|
+
blockEntity: BlockEntity;
|
|
9
|
+
}
|
|
10
|
+
export interface WithTypeormSinkMetadata {
|
|
11
|
+
entities: Function[];
|
|
12
|
+
}
|
|
13
|
+
export declare type TypeormSink<P> = Sink<P, WithTypeormContext> & WithTypeormSinkMetadata;
|
|
14
|
+
//# 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,MAAM,SAAS,CAAC;AACtC,OAAO,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAC/C,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAE/B,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"}
|
|
@@ -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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { Cardano } from '@cardano-sdk/core';
|
|
2
|
+
import { QueryRunner } from 'typeorm';
|
|
3
|
+
import { Observable } from 'rxjs';
|
|
4
|
+
import { Operators, StabilityWindowBuffer, UnifiedProjectorOperator } from '@cardano-sdk/projection';
|
|
5
|
+
import { WithLogger } from '@cardano-sdk/util';
|
|
6
|
+
import { WithTypeormContext } from './types';
|
|
7
|
+
export interface TypeormStabilityWindowBufferProps {
|
|
8
|
+
compactBufferEveryNBlocks?: number;
|
|
9
|
+
}
|
|
10
|
+
export declare class TypeormStabilityWindowBuffer implements StabilityWindowBuffer<Operators.WithNetworkInfo & WithTypeormContext> {
|
|
11
|
+
#private;
|
|
12
|
+
readonly tip$: Observable<Cardano.Block | 'origin'>;
|
|
13
|
+
readonly tail$: Observable<Cardano.Block | 'origin'>;
|
|
14
|
+
readonly handleEvents: UnifiedProjectorOperator<Operators.WithNetworkInfo & WithTypeormContext, Operators.WithNetworkInfo & WithTypeormContext>;
|
|
15
|
+
constructor({ compactBufferEveryNBlocks }: TypeormStabilityWindowBufferProps, dependencies: WithLogger);
|
|
16
|
+
initialize(queryRunner: QueryRunner): Promise<void>;
|
|
17
|
+
shutdown(): void;
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=TypeormStabilityWindowBuffer.d.ts.map
|
|
@@ -0,0 +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,EAAE,MAAM,SAAS,CAAC;AAEnE,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;AAa7C,MAAM,WAAW,iCAAiC;IAIhD,yBAAyB,CAAC,EAAE,MAAM,CAAC;CACpC;AAED,qBAAa,4BACX,YAAW,qBAAqB,CAAC,SAAS,CAAC,eAAe,GAAG,kBAAkB,CAAC;;IAOhF,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;gBAEU,EAAE,yBAA+B,EAAE,EAAE,iCAAiC,EAAE,YAAY,EAAE,UAAU;IAetG,UAAU,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IA2BzD,QAAQ,IAAI,IAAI;CA4GjB"}
|
|
@@ -0,0 +1,148 @@
|
|
|
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
|
+
};
|
|
6
|
+
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
|
|
7
|
+
if (kind === "m") throw new TypeError("Private method is not writable");
|
|
8
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
|
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");
|
|
10
|
+
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
11
|
+
};
|
|
12
|
+
var _TypeormStabilityWindowBuffer_instances, _TypeormStabilityWindowBuffer_tail, _TypeormStabilityWindowBuffer_logger, _TypeormStabilityWindowBuffer_compactEvery, _TypeormStabilityWindowBuffer_tip$, _TypeormStabilityWindowBuffer_tail$, _TypeormStabilityWindowBuffer_rollForward, _TypeormStabilityWindowBuffer_rollBackward, _TypeormStabilityWindowBuffer_deleteOldBlockData, _TypeormStabilityWindowBuffer_setTail;
|
|
13
|
+
import { BlockDataEntity } from './entity';
|
|
14
|
+
import { ChainSyncEventType } from '@cardano-sdk/core';
|
|
15
|
+
import { LessThan } from 'typeorm';
|
|
16
|
+
import { ReplaySubject, concatMap, from, map } from 'rxjs';
|
|
17
|
+
import { contextLogger } from '@cardano-sdk/util';
|
|
18
|
+
const blockDataSelect = {
|
|
19
|
+
block: {
|
|
20
|
+
slot: true
|
|
21
|
+
},
|
|
22
|
+
data: true,
|
|
23
|
+
id: true
|
|
24
|
+
};
|
|
25
|
+
export class TypeormStabilityWindowBuffer {
|
|
26
|
+
constructor({ compactBufferEveryNBlocks = 100 }, dependencies) {
|
|
27
|
+
_TypeormStabilityWindowBuffer_instances.add(this);
|
|
28
|
+
_TypeormStabilityWindowBuffer_tail.set(this, void 0);
|
|
29
|
+
_TypeormStabilityWindowBuffer_logger.set(this, void 0);
|
|
30
|
+
_TypeormStabilityWindowBuffer_compactEvery.set(this, void 0);
|
|
31
|
+
_TypeormStabilityWindowBuffer_tip$.set(this, new ReplaySubject(1));
|
|
32
|
+
_TypeormStabilityWindowBuffer_tail$.set(this, new ReplaySubject(1));
|
|
33
|
+
this.tip$ = __classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tip$, "f").asObservable();
|
|
34
|
+
this.tail$ = __classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tail$, "f").asObservable();
|
|
35
|
+
__classPrivateFieldSet(this, _TypeormStabilityWindowBuffer_compactEvery, compactBufferEveryNBlocks, "f");
|
|
36
|
+
__classPrivateFieldSet(this, _TypeormStabilityWindowBuffer_logger, contextLogger(dependencies.logger, 'PgStabilityWindowBuffer'), "f");
|
|
37
|
+
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))));
|
|
38
|
+
}
|
|
39
|
+
async initialize(queryRunner) {
|
|
40
|
+
const repository = queryRunner.manager.getRepository(BlockDataEntity);
|
|
41
|
+
const [tip, tail] = await Promise.all([
|
|
42
|
+
repository.find({
|
|
43
|
+
order: { block: { slot: 'DESC' } },
|
|
44
|
+
relations: {
|
|
45
|
+
block: true
|
|
46
|
+
},
|
|
47
|
+
select: blockDataSelect,
|
|
48
|
+
take: 1
|
|
49
|
+
}),
|
|
50
|
+
repository.find({
|
|
51
|
+
order: { block: { slot: 'ASC' } },
|
|
52
|
+
relations: {
|
|
53
|
+
block: true
|
|
54
|
+
},
|
|
55
|
+
select: blockDataSelect,
|
|
56
|
+
take: 1
|
|
57
|
+
})
|
|
58
|
+
]);
|
|
59
|
+
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tip$, "f").next(tip[0]?.data || 'origin');
|
|
60
|
+
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_instances, "m", _TypeormStabilityWindowBuffer_setTail).call(this, tail[0]?.data || 'origin');
|
|
61
|
+
}
|
|
62
|
+
shutdown() {
|
|
63
|
+
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tip$, "f").complete();
|
|
64
|
+
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tail$, "f").complete();
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
_TypeormStabilityWindowBuffer_tail = new WeakMap(), _TypeormStabilityWindowBuffer_logger = new WeakMap(), _TypeormStabilityWindowBuffer_compactEvery = new WeakMap(), _TypeormStabilityWindowBuffer_tip$ = new WeakMap(), _TypeormStabilityWindowBuffer_tail$ = new WeakMap(), _TypeormStabilityWindowBuffer_instances = new WeakSet(), _TypeormStabilityWindowBuffer_rollForward = async function _TypeormStabilityWindowBuffer_rollForward(evt) {
|
|
68
|
+
const { eventType, transactionCommitted$, queryRunner, blockEntity, block } = evt;
|
|
69
|
+
const { header: { blockNo } } = block;
|
|
70
|
+
const repository = queryRunner.manager.getRepository(BlockDataEntity);
|
|
71
|
+
if (eventType === ChainSyncEventType.RollForward) {
|
|
72
|
+
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_logger, "f").debug('Add block data at height', blockNo);
|
|
73
|
+
const blockData = repository.create({
|
|
74
|
+
block: blockEntity,
|
|
75
|
+
data: block
|
|
76
|
+
});
|
|
77
|
+
await Promise.all([repository.insert(blockData), __classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_instances, "m", _TypeormStabilityWindowBuffer_deleteOldBlockData).call(this, evt)]);
|
|
78
|
+
transactionCommitted$.subscribe(() => {
|
|
79
|
+
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tip$, "f").next(block);
|
|
80
|
+
if (__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tail, "f") === 'origin') {
|
|
81
|
+
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_instances, "m", _TypeormStabilityWindowBuffer_setTail).call(this, block);
|
|
82
|
+
}
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
}, _TypeormStabilityWindowBuffer_rollBackward = async function _TypeormStabilityWindowBuffer_rollBackward({ transactionCommitted$, queryRunner, block: { header: { slot, blockNo } } }) {
|
|
86
|
+
const repository = queryRunner.manager.getRepository(BlockDataEntity);
|
|
87
|
+
const prevTip = await repository.findOne({
|
|
88
|
+
order: {
|
|
89
|
+
block: {
|
|
90
|
+
slot: 'DESC'
|
|
91
|
+
}
|
|
92
|
+
},
|
|
93
|
+
relations: {
|
|
94
|
+
block: true
|
|
95
|
+
},
|
|
96
|
+
select: blockDataSelect,
|
|
97
|
+
where: {
|
|
98
|
+
block: {
|
|
99
|
+
slot: LessThan(slot)
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
});
|
|
103
|
+
if (prevTip?.data && blockNo !== prevTip?.data.header.blockNo + 1) {
|
|
104
|
+
throw new Error('Assert: inconsistent PgStabilityWindowBuffer at rollBackward');
|
|
105
|
+
}
|
|
106
|
+
transactionCommitted$.subscribe(() => {
|
|
107
|
+
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tip$, "f").next(prevTip?.data || 'origin');
|
|
108
|
+
if (!prevTip?.data) {
|
|
109
|
+
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_instances, "m", _TypeormStabilityWindowBuffer_setTail).call(this, 'origin');
|
|
110
|
+
}
|
|
111
|
+
});
|
|
112
|
+
}, _TypeormStabilityWindowBuffer_deleteOldBlockData = async function _TypeormStabilityWindowBuffer_deleteOldBlockData({ genesisParameters: { securityParameter }, block: { header: { blockNo } }, queryRunner, transactionCommitted$ }) {
|
|
113
|
+
if (blockNo < securityParameter || blockNo % __classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_compactEvery, "f") !== 0) {
|
|
114
|
+
return;
|
|
115
|
+
}
|
|
116
|
+
const repository = queryRunner.manager.getRepository(BlockDataEntity);
|
|
117
|
+
const nextTailBlockHeight = blockNo - securityParameter;
|
|
118
|
+
const [nextTailEntity] = await Promise.all([
|
|
119
|
+
repository.findOne({
|
|
120
|
+
relations: {
|
|
121
|
+
block: true
|
|
122
|
+
},
|
|
123
|
+
select: {
|
|
124
|
+
block: { height: true },
|
|
125
|
+
data: true,
|
|
126
|
+
id: true
|
|
127
|
+
},
|
|
128
|
+
where: {
|
|
129
|
+
block: {
|
|
130
|
+
height: nextTailBlockHeight
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
}),
|
|
134
|
+
queryRunner.query(`
|
|
135
|
+
DELETE FROM block_data
|
|
136
|
+
WHERE block_id IN (SELECT id FROM block WHERE height < ${nextTailBlockHeight})
|
|
137
|
+
`)
|
|
138
|
+
]);
|
|
139
|
+
const nextTail = nextTailEntity?.data;
|
|
140
|
+
if (!nextTail) {
|
|
141
|
+
throw new Error('Assert: inconsistent PgStabilityWindowBuffer at #deleteOldBlockData');
|
|
142
|
+
}
|
|
143
|
+
transactionCommitted$.subscribe(() => __classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_instances, "m", _TypeormStabilityWindowBuffer_setTail).call(this, nextTail));
|
|
144
|
+
}, _TypeormStabilityWindowBuffer_setTail = function _TypeormStabilityWindowBuffer_setTail(tail) {
|
|
145
|
+
__classPrivateFieldSet(this, _TypeormStabilityWindowBuffer_tail, tail, "f");
|
|
146
|
+
__classPrivateFieldGet(this, _TypeormStabilityWindowBuffer_tail$, "f").next(tail);
|
|
147
|
+
};
|
|
148
|
+
//# sourceMappingURL=TypeormStabilityWindowBuffer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TypeormStabilityWindowBuffer.js","sourceRoot":"","sources":["../../src/TypeormStabilityWindowBuffer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import 'reflect-metadata';
|
|
2
|
+
import { DataSource, DataSourceOptions } from 'typeorm';
|
|
3
|
+
import { Logger } from 'ts-log';
|
|
4
|
+
declare type PostgresConnectionOptions = DataSourceOptions & {
|
|
5
|
+
type: 'postgres';
|
|
6
|
+
};
|
|
7
|
+
export declare type PgConnectionConfig = Pick<PostgresConnectionOptions, 'host' | 'port' | 'database' | 'username' | 'password' | 'ssl'>;
|
|
8
|
+
export declare type TypeormDevOptions = Pick<PostgresConnectionOptions, 'synchronize' | 'dropSchema'>;
|
|
9
|
+
export declare type TypeormOptions = Pick<PostgresConnectionOptions, 'connectTimeoutMS' | 'logNotifications' | 'installExtensions' | 'extra' | 'maxQueryExecutionTime' | 'poolSize' | 'cache' | 'migrationsRun' | 'migrations'> & {};
|
|
10
|
+
export interface CreateDataSourceProps<P extends object> {
|
|
11
|
+
projections: P;
|
|
12
|
+
connectionConfig: PgConnectionConfig;
|
|
13
|
+
options?: TypeormOptions;
|
|
14
|
+
devOptions?: TypeormDevOptions;
|
|
15
|
+
logger: Logger;
|
|
16
|
+
}
|
|
17
|
+
export declare const createDataSource: <P extends object>({ connectionConfig, devOptions, options, projections, logger }: CreateDataSourceProps<P>) => DataSource;
|
|
18
|
+
export {};
|
|
19
|
+
//# sourceMappingURL=createDataSource.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
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"}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import 'reflect-metadata';
|
|
2
|
+
import * as supportedSinks from './sinks';
|
|
3
|
+
import { BlockDataEntity } from './entity';
|
|
4
|
+
import { BlockEntity } from './entity/Block.entity';
|
|
5
|
+
import { DataSource, DefaultNamingStrategy } from 'typeorm';
|
|
6
|
+
import { typeormLogger } from './logger';
|
|
7
|
+
import snakeCase from 'lodash/snakeCase';
|
|
8
|
+
import uniq from 'lodash/uniq';
|
|
9
|
+
const toTableName = (tableOrName) => (typeof tableOrName === 'string' ? tableOrName : tableOrName.name).replace('_entity', '');
|
|
10
|
+
const namingOverrides = {
|
|
11
|
+
columnName(propertyName, customName, _embeddedPrefixes) {
|
|
12
|
+
return customName || snakeCase(propertyName);
|
|
13
|
+
},
|
|
14
|
+
defaultConstraintName(tableOrName, columnName) {
|
|
15
|
+
return `DF_${toTableName(tableOrName)}_${columnName}`;
|
|
16
|
+
},
|
|
17
|
+
foreignKeyName(tableOrName, columnNames, _referencedTablePath, _referencedColumnNames) {
|
|
18
|
+
return `FK_${toTableName(tableOrName)}_${columnNames.join('_')}`;
|
|
19
|
+
},
|
|
20
|
+
indexName(tableOrName, columns, _where) {
|
|
21
|
+
return `IDX_${toTableName(tableOrName)}_${columns.join('_')}`;
|
|
22
|
+
},
|
|
23
|
+
joinColumnName(relationName, referencedColumnName) {
|
|
24
|
+
return `${snakeCase(relationName)}_${referencedColumnName}`;
|
|
25
|
+
},
|
|
26
|
+
joinTableColumnName(tableName, _propertyName, columnName) {
|
|
27
|
+
return `${tableName}_${columnName}`;
|
|
28
|
+
},
|
|
29
|
+
primaryKeyName(tableOrName, columnNames) {
|
|
30
|
+
return `PK_${toTableName(tableOrName)}_${columnNames.join('_')}`;
|
|
31
|
+
},
|
|
32
|
+
relationConstraintName(tableOrName, columnNames, _where) {
|
|
33
|
+
return `REL_${toTableName(tableOrName)}_${columnNames.join('_')}`;
|
|
34
|
+
},
|
|
35
|
+
tableName(targetName, userSpecifiedName) {
|
|
36
|
+
return userSpecifiedName || toTableName(snakeCase(targetName));
|
|
37
|
+
}
|
|
38
|
+
};
|
|
39
|
+
const defaultStrategy = new DefaultNamingStrategy();
|
|
40
|
+
const namingStrategy = new Proxy(defaultStrategy, {
|
|
41
|
+
get(target, p, receiver) {
|
|
42
|
+
if (p in namingOverrides) {
|
|
43
|
+
return namingOverrides[p];
|
|
44
|
+
}
|
|
45
|
+
const value = target[p];
|
|
46
|
+
if (typeof value === 'function') {
|
|
47
|
+
return value.bind(receiver);
|
|
48
|
+
}
|
|
49
|
+
return value;
|
|
50
|
+
}
|
|
51
|
+
});
|
|
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({
|
|
58
|
+
...connectionConfig,
|
|
59
|
+
...devOptions,
|
|
60
|
+
...options,
|
|
61
|
+
entities,
|
|
62
|
+
logger: typeormLogger(logger),
|
|
63
|
+
logging: true,
|
|
64
|
+
namingStrategy,
|
|
65
|
+
type: 'postgres'
|
|
66
|
+
});
|
|
67
|
+
};
|
|
68
|
+
//# sourceMappingURL=createDataSource.js.map
|
|
@@ -0,0 +1 @@
|
|
|
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 }: 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,2EAKrB,iBAAiB,KAAG,MAAM,oBAAoB,CAwEhD,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 }) => {
|
|
40
|
+
const buffer = new TypeormStabilityWindowBuffer({ 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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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Cardano } from '@cardano-sdk/core';
|
|
2
|
+
import { RelationOptions } from 'typeorm';
|
|
3
|
+
export declare class BlockEntity {
|
|
4
|
+
id?: number;
|
|
5
|
+
hash?: Cardano.BlockId;
|
|
6
|
+
slot?: number;
|
|
7
|
+
height?: number;
|
|
8
|
+
}
|
|
9
|
+
export declare const BlockCascadeRelationOptions: RelationOptions;
|
|
10
|
+
//# sourceMappingURL=Block.entity.d.ts.map
|
|
@@ -0,0 +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;AAC5C,OAAO,EAAiD,eAAe,EAAE,MAAM,SAAS,CAAC;AAEzF,qBACa,WAAW;IAEtB,EAAE,CAAC,EAAE,MAAM,CAAC;IAIZ,IAAI,CAAC,EAAE,OAAO,CAAC,OAAO,CAAC;IAIvB,IAAI,CAAC,EAAE,MAAM,CAAC;IAId,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAMD,eAAO,MAAM,2BAA2B,EAAE,eAGzC,CAAC"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
|
+
};
|
|
10
|
+
import { Cardano } from '@cardano-sdk/core';
|
|
11
|
+
import { Column, Entity, Index, PrimaryGeneratedColumn } from 'typeorm';
|
|
12
|
+
let BlockEntity = class BlockEntity {
|
|
13
|
+
};
|
|
14
|
+
__decorate([
|
|
15
|
+
PrimaryGeneratedColumn(),
|
|
16
|
+
__metadata("design:type", Number)
|
|
17
|
+
], BlockEntity.prototype, "id", void 0);
|
|
18
|
+
__decorate([
|
|
19
|
+
Index({ unique: true }),
|
|
20
|
+
Column({ length: 64, type: 'char' }),
|
|
21
|
+
__metadata("design:type", String)
|
|
22
|
+
], BlockEntity.prototype, "hash", void 0);
|
|
23
|
+
__decorate([
|
|
24
|
+
Index({ unique: true }),
|
|
25
|
+
Column({ type: 'int' }),
|
|
26
|
+
__metadata("design:type", Number)
|
|
27
|
+
], BlockEntity.prototype, "slot", void 0);
|
|
28
|
+
__decorate([
|
|
29
|
+
Index({ unique: true }),
|
|
30
|
+
Column({ type: 'int' }),
|
|
31
|
+
__metadata("design:type", Number)
|
|
32
|
+
], BlockEntity.prototype, "height", void 0);
|
|
33
|
+
BlockEntity = __decorate([
|
|
34
|
+
Entity()
|
|
35
|
+
], BlockEntity);
|
|
36
|
+
export { BlockEntity };
|
|
37
|
+
export const BlockCascadeRelationOptions = {
|
|
38
|
+
nullable: false,
|
|
39
|
+
onDelete: 'CASCADE'
|
|
40
|
+
};
|
|
41
|
+
//# sourceMappingURL=Block.entity.js.map
|
|
@@ -0,0 +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,sBAAsB,EAAmB,MAAM,SAAS,CAAC;AAGlF,IAAM,WAAW,GAAjB,MAAM,WAAW;CAevB,CAAA;AAdC;IAAC,sBAAsB,EAAE;;uCACb;AAEZ;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,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;;yCACV;AAEd;IAAC,KAAK,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;IACvB,MAAM,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;;2CACR;AAdL,WAAW;IADvB,MAAM,EAAE;GACI,WAAW,CAevB;SAfY,WAAW;AAqBxB,MAAM,CAAC,MAAM,2BAA2B,GAAoB;IAC1D,QAAQ,EAAE,KAAK;IACf,QAAQ,EAAE,SAAS;CACpB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BlockData.entity.d.ts","sourceRoot":"","sources":["../../../src/entity/BlockData.entity.ts"],"names":[],"mappings":"AAAA,OAAO,EAA+B,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC1E,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAI5C,qBACa,eAAe;IAE1B,EAAE,CAAC,EAAE,MAAM,CAAC;IAIZ,KAAK,CAAC,EAAE,WAAW,CAAC;IAGpB,IAAI,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC;CACtB"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
|
+
};
|
|
10
|
+
import { BlockCascadeRelationOptions, BlockEntity } from './Block.entity';
|
|
11
|
+
import { Cardano } from '@cardano-sdk/core';
|
|
12
|
+
import { Column, Entity, JoinColumn, OneToOne, PrimaryGeneratedColumn } from 'typeorm';
|
|
13
|
+
import { json, serializableObj, stringBytea } from './transformers';
|
|
14
|
+
let BlockDataEntity = class BlockDataEntity {
|
|
15
|
+
};
|
|
16
|
+
__decorate([
|
|
17
|
+
PrimaryGeneratedColumn(),
|
|
18
|
+
__metadata("design:type", Number)
|
|
19
|
+
], BlockDataEntity.prototype, "id", void 0);
|
|
20
|
+
__decorate([
|
|
21
|
+
OneToOne(() => BlockEntity, BlockCascadeRelationOptions),
|
|
22
|
+
JoinColumn(),
|
|
23
|
+
__metadata("design:type", BlockEntity)
|
|
24
|
+
], BlockDataEntity.prototype, "block", void 0);
|
|
25
|
+
__decorate([
|
|
26
|
+
Column({ transformer: [serializableObj, json, stringBytea], type: 'bytea' }),
|
|
27
|
+
__metadata("design:type", Object)
|
|
28
|
+
], BlockDataEntity.prototype, "data", void 0);
|
|
29
|
+
BlockDataEntity = __decorate([
|
|
30
|
+
Entity()
|
|
31
|
+
], BlockDataEntity);
|
|
32
|
+
export { BlockDataEntity };
|
|
33
|
+
//# sourceMappingURL=BlockData.entity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BlockData.entity.js","sourceRoot":"","sources":["../../../src/entity/BlockData.entity.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,2BAA2B,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC1E,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAC5C,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,sBAAsB,EAAE,MAAM,SAAS,CAAC;AACvF,OAAO,EAAE,IAAI,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAG7D,IAAM,eAAe,GAArB,MAAM,eAAe;CAU3B,CAAA;AATC;IAAC,sBAAsB,EAAE;;2CACb;AAEZ;IAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,WAAW,EAAE,2BAA2B,CAAC;IACxD,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;AATV,eAAe;IAD3B,MAAM,EAAE;GACI,eAAe,CAU3B;SAVY,eAAe"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StakeKey.entity.d.ts","sourceRoot":"","sources":["../../../src/entity/StakeKey.entity.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAGxD,qBACa,cAAc;IAEzB,IAAI,CAAC,EAAE,iBAAiB,CAAC;CAC1B"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
|
+
};
|
|
10
|
+
import { Ed25519KeyHashHex } from '@cardano-sdk/crypto';
|
|
11
|
+
import { Entity, PrimaryColumn } from 'typeorm';
|
|
12
|
+
let StakeKeyEntity = class StakeKeyEntity {
|
|
13
|
+
};
|
|
14
|
+
__decorate([
|
|
15
|
+
PrimaryColumn({ length: 56, type: 'char' }),
|
|
16
|
+
__metadata("design:type", String)
|
|
17
|
+
], StakeKeyEntity.prototype, "hash", void 0);
|
|
18
|
+
StakeKeyEntity = __decorate([
|
|
19
|
+
Entity()
|
|
20
|
+
], StakeKeyEntity);
|
|
21
|
+
export { StakeKeyEntity };
|
|
22
|
+
//# sourceMappingURL=StakeKey.entity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StakeKey.entity.js","sourceRoot":"","sources":["../../../src/entity/StakeKey.entity.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAGzC,IAAM,cAAc,GAApB,MAAM,cAAc;CAG1B,CAAA;AAFC;IAAC,aAAa,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;4CACnB;AAFd,cAAc;IAD1B,MAAM,EAAE;GACI,cAAc,CAG1B;SAHY,cAAc"}
|
|
@@ -0,0 +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"}
|