@rosen-bridge/abstract-extractor 2.1.2 → 3.0.0-8f3c7016
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/CHANGELOG.md +9 -0
- package/dist/abstractExtractor.d.ts +24 -12
- package/dist/abstractExtractor.d.ts.map +1 -1
- package/dist/abstractExtractor.js +1 -1
- package/dist/constants.d.ts +1 -0
- package/dist/constants.d.ts.map +1 -1
- package/dist/constants.js +2 -1
- package/dist/ergo/database/actions/abstractErgoAction.d.ts +83 -0
- package/dist/ergo/database/actions/abstractErgoAction.d.ts.map +1 -0
- package/dist/ergo/database/actions/abstractErgoAction.js +167 -0
- package/dist/ergo/database/actions/abstractErgoBoxAction.d.ts +31 -0
- package/dist/ergo/database/actions/abstractErgoBoxAction.d.ts.map +1 -0
- package/dist/ergo/database/actions/abstractErgoBoxAction.js +70 -0
- package/dist/ergo/database/entities/abstractErgoBoxEntity.d.ts +18 -0
- package/dist/ergo/database/entities/abstractErgoBoxEntity.d.ts.map +1 -0
- package/dist/ergo/database/entities/abstractErgoBoxEntity.js +36 -0
- package/dist/ergo/database/entities/abstractErgoEntity.d.ts +26 -0
- package/dist/ergo/database/entities/abstractErgoEntity.d.ts.map +1 -0
- package/dist/ergo/database/entities/abstractErgoEntity.js +64 -0
- package/dist/ergo/database/index.d.ts +5 -0
- package/dist/ergo/database/index.d.ts.map +1 -0
- package/dist/ergo/database/index.js +5 -0
- package/dist/ergo/extractors/abstractErgoBoxExtractor.d.ts +67 -0
- package/dist/ergo/extractors/abstractErgoBoxExtractor.d.ts.map +1 -0
- package/dist/ergo/extractors/abstractErgoBoxExtractor.js +106 -0
- package/dist/ergo/extractors/abstractErgoExtractor.d.ts +53 -0
- package/dist/ergo/extractors/abstractErgoExtractor.d.ts.map +1 -0
- package/dist/ergo/extractors/abstractErgoExtractor.js +92 -0
- package/dist/ergo/extractors/abstractErgoTxExtractor.d.ts +56 -0
- package/dist/ergo/extractors/abstractErgoTxExtractor.d.ts.map +1 -0
- package/dist/ergo/extractors/abstractErgoTxExtractor.js +81 -0
- package/dist/ergo/extractors/index.d.ts +4 -0
- package/dist/ergo/extractors/index.d.ts.map +1 -0
- package/dist/ergo/extractors/index.js +4 -0
- package/dist/ergo/index.d.ts +5 -7
- package/dist/ergo/index.d.ts.map +1 -1
- package/dist/ergo/index.js +6 -8
- package/dist/ergo/initializers/ergoBoxInitializer.d.ts +36 -0
- package/dist/ergo/initializers/ergoBoxInitializer.d.ts.map +1 -0
- package/dist/ergo/initializers/ergoBoxInitializer.js +80 -0
- package/dist/ergo/initializers/ergoInitializer.d.ts +39 -0
- package/dist/ergo/initializers/ergoInitializer.d.ts.map +1 -0
- package/dist/ergo/initializers/ergoInitializer.js +80 -0
- package/dist/ergo/initializers/index.d.ts +4 -0
- package/dist/ergo/initializers/index.d.ts.map +1 -0
- package/dist/ergo/initializers/index.js +4 -0
- package/dist/ergo/initializers/strategies/constants.d.ts +3 -0
- package/dist/ergo/initializers/strategies/constants.d.ts.map +1 -0
- package/dist/ergo/initializers/strategies/constants.js +3 -0
- package/dist/ergo/initializers/strategies/explorerInitializationStrategy.d.ts +59 -0
- package/dist/ergo/initializers/strategies/explorerInitializationStrategy.d.ts.map +1 -0
- package/dist/ergo/initializers/strategies/explorerInitializationStrategy.js +141 -0
- package/dist/ergo/initializers/strategies/index.d.ts +4 -0
- package/dist/ergo/initializers/strategies/index.d.ts.map +1 -0
- package/dist/ergo/initializers/strategies/index.js +4 -0
- package/dist/ergo/initializers/strategies/nodeInitializationStrategy.d.ts +29 -0
- package/dist/ergo/initializers/strategies/nodeInitializationStrategy.d.ts.map +1 -0
- package/dist/ergo/initializers/strategies/nodeInitializationStrategy.js +66 -0
- package/dist/ergo/initializers/strategies/workerManager.d.ts +79 -0
- package/dist/ergo/initializers/strategies/workerManager.d.ts.map +1 -0
- package/dist/ergo/initializers/strategies/workerManager.js +183 -0
- package/dist/ergo/interfaces.d.ts +31 -17
- package/dist/ergo/interfaces.d.ts.map +1 -1
- package/dist/ergo/interfaces.js +1 -1
- package/dist/ergo/networks/explorerNetwork.d.ts +52 -0
- package/dist/ergo/networks/explorerNetwork.d.ts.map +1 -0
- package/dist/ergo/networks/explorerNetwork.js +127 -0
- package/dist/ergo/networks/index.d.ts +3 -0
- package/dist/ergo/networks/index.d.ts.map +1 -0
- package/dist/ergo/networks/index.js +3 -0
- package/dist/ergo/networks/nodeNetwork.d.ts +28 -0
- package/dist/ergo/networks/nodeNetwork.d.ts.map +1 -0
- package/dist/ergo/networks/nodeNetwork.js +59 -0
- package/dist/ergo/utils.d.ts +15 -0
- package/dist/ergo/utils.d.ts.map +1 -1
- package/dist/ergo/utils.js +34 -1
- package/package.json +3 -1
- package/dist/ergo/abstractErgoExtractor.d.ts +0 -80
- package/dist/ergo/abstractErgoExtractor.d.ts.map +0 -1
- package/dist/ergo/abstractErgoExtractor.js +0 -142
- package/dist/ergo/abstractErgoExtractorAction.d.ts +0 -89
- package/dist/ergo/abstractErgoExtractorAction.d.ts.map +0 -1
- package/dist/ergo/abstractErgoExtractorAction.js +0 -219
- package/dist/ergo/abstractErgoExtractorEntity.d.ts +0 -11
- package/dist/ergo/abstractErgoExtractorEntity.d.ts.map +0 -1
- package/dist/ergo/abstractErgoExtractorEntity.js +0 -57
- package/dist/ergo/initializable/abstractInitializable.d.ts +0 -48
- package/dist/ergo/initializable/abstractInitializable.d.ts.map +0 -1
- package/dist/ergo/initializable/abstractInitializable.js +0 -162
- package/dist/ergo/initializable/abstractInitializableAction.d.ts +0 -14
- package/dist/ergo/initializable/abstractInitializableAction.d.ts.map +0 -1
- package/dist/ergo/initializable/abstractInitializableAction.js +0 -16
- package/dist/ergo/initializable/index.d.ts +0 -3
- package/dist/ergo/initializable/index.d.ts.map +0 -1
- package/dist/ergo/initializable/index.js +0 -3
- package/dist/ergo/network/abstractNetwork.d.ts +0 -26
- package/dist/ergo/network/abstractNetwork.d.ts.map +0 -1
- package/dist/ergo/network/abstractNetwork.js +0 -3
- package/dist/ergo/network/explorerNetwork.d.ts +0 -74
- package/dist/ergo/network/explorerNetwork.d.ts.map +0 -1
- package/dist/ergo/network/explorerNetwork.js +0 -185
- package/dist/ergo/network/nodeNetwork.d.ts +0 -60
- package/dist/ergo/network/nodeNetwork.d.ts.map +0 -1
- package/dist/ergo/network/nodeNetwork.js +0 -131
|
@@ -1,89 +0,0 @@
|
|
|
1
|
-
import { AbstractLogger } from '@rosen-bridge/abstract-logger';
|
|
2
|
-
import { DataSource, Repository, EntityTarget, QueryRunner } from '@rosen-bridge/extended-typeorm';
|
|
3
|
-
import { BlockInfo } from '@rosen-bridge/scanner-interfaces';
|
|
4
|
-
import { AbstractErgoExtractorEntity } from './abstractErgoExtractorEntity';
|
|
5
|
-
import { AbstractBoxData, BoxInfo, SpendInfo } from './interfaces';
|
|
6
|
-
export declare abstract class AbstractErgoExtractorAction<ExtractedData extends AbstractBoxData, ExtractorEntity extends AbstractErgoExtractorEntity> {
|
|
7
|
-
private readonly datasource;
|
|
8
|
-
readonly logger: AbstractLogger;
|
|
9
|
-
protected readonly repository: Repository<ExtractorEntity>;
|
|
10
|
-
private repo;
|
|
11
|
-
constructor(dataSource: DataSource, repo: EntityTarget<ExtractorEntity>, logger?: AbstractLogger);
|
|
12
|
-
/**
|
|
13
|
-
* create the database entity from extracted data and block information
|
|
14
|
-
*/
|
|
15
|
-
protected createEntity: (data: ExtractedData[], // eslint-disable-line @typescript-eslint/no-unused-vars
|
|
16
|
-
block: BlockInfo, // eslint-disable-line @typescript-eslint/no-unused-vars
|
|
17
|
-
extractor: string) => Array<Omit<ExtractorEntity, "id">>;
|
|
18
|
-
/**
|
|
19
|
-
* convert the database entity back to raw data
|
|
20
|
-
*/
|
|
21
|
-
protected convertEntityToData: (entities: ExtractorEntity[]) => ExtractedData[];
|
|
22
|
-
/**
|
|
23
|
-
* insert entities extracted from a block to database
|
|
24
|
-
* @param queryRunner
|
|
25
|
-
* @param boxesToInsert
|
|
26
|
-
* @param block
|
|
27
|
-
* @param extractor
|
|
28
|
-
*/
|
|
29
|
-
protected insertEntities: (queryRunner: QueryRunner, boxesToInsert: Array<ExtractedData>, block: BlockInfo, extractor: string) => Promise<void>;
|
|
30
|
-
/**
|
|
31
|
-
* update entities related to a box
|
|
32
|
-
* @param queryRunner
|
|
33
|
-
* @param updateBox
|
|
34
|
-
* @param block
|
|
35
|
-
* @param extractor
|
|
36
|
-
*/
|
|
37
|
-
protected updateEntity: (queryRunner: QueryRunner, updateBox: ExtractedData, block: BlockInfo, extractor: string) => Promise<void>;
|
|
38
|
-
/**
|
|
39
|
-
* delete all data extracted from a block
|
|
40
|
-
* @param queryRunner
|
|
41
|
-
* @param extractor
|
|
42
|
-
* @param block
|
|
43
|
-
* @returns
|
|
44
|
-
*/
|
|
45
|
-
protected deleteBlockEntities: (queryRunner: QueryRunner, extractor: string, block: string) => Promise<ExtractedData[]>;
|
|
46
|
-
/**
|
|
47
|
-
* delete all data extracted from a block
|
|
48
|
-
* @param queryRunner
|
|
49
|
-
* @param extractor
|
|
50
|
-
* @param block
|
|
51
|
-
* @returns
|
|
52
|
-
*/
|
|
53
|
-
protected updateBlockEntities: (queryRunner: QueryRunner, extractor: string, block: string) => Promise<ExtractorEntity[]>;
|
|
54
|
-
/**
|
|
55
|
-
* insert all extracted box data in an atomic transaction
|
|
56
|
-
* update the data if a box with the same id is already stored in db
|
|
57
|
-
* @param boxes
|
|
58
|
-
* @param block
|
|
59
|
-
* @param extractor
|
|
60
|
-
* @return inserted items and updated box ids
|
|
61
|
-
* returns undefined in case of any problem
|
|
62
|
-
*/
|
|
63
|
-
storeBoxes: (boxes: Array<ExtractedData>, block: BlockInfo, extractor: string) => Promise<boolean>;
|
|
64
|
-
/**
|
|
65
|
-
* update spending information of stored boxes
|
|
66
|
-
* chunk spendInfos to prevent large database queries
|
|
67
|
-
* Note: It only updates the spendHeight and spendBlock fields. If updating
|
|
68
|
-
* anything else is required, override this implementation to include the
|
|
69
|
-
* additional fields.
|
|
70
|
-
* @param spendInfos
|
|
71
|
-
* @param block
|
|
72
|
-
* @param extractor
|
|
73
|
-
* @returns spent box ids
|
|
74
|
-
*/
|
|
75
|
-
spendBoxes: (spendInfos: Array<SpendInfo>, block: BlockInfo, extractor: string) => Promise<BoxInfo[]>;
|
|
76
|
-
/**
|
|
77
|
-
* delete extracted data from a specific block
|
|
78
|
-
* if a box is spend in this block mark it as unspent
|
|
79
|
-
* if a box is created in this block remove it from database
|
|
80
|
-
* @param block
|
|
81
|
-
* @param extractor
|
|
82
|
-
* @return deleted items and updated box ids
|
|
83
|
-
*/
|
|
84
|
-
deleteBlockBoxes: (block: string, extractor: string) => Promise<{
|
|
85
|
-
deletedData: ExtractedData[];
|
|
86
|
-
updatedData: BoxInfo[];
|
|
87
|
-
}>;
|
|
88
|
-
}
|
|
89
|
-
//# sourceMappingURL=abstractErgoExtractorAction.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"abstractErgoExtractorAction.d.ts","sourceRoot":"","sources":["../../lib/ergo/abstractErgoExtractorAction.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EACL,UAAU,EAEV,UAAU,EAEV,YAAY,EAEZ,WAAW,EACZ,MAAM,gCAAgC,CAAC;AAExC,OAAO,EAAE,SAAS,EAAE,MAAM,kCAAkC,CAAC;AAG7D,OAAO,EAAE,2BAA2B,EAAE,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,eAAe,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEnE,8BAAsB,2BAA2B,CAC/C,aAAa,SAAS,eAAe,EACrC,eAAe,SAAS,2BAA2B;IAEnD,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;IACxC,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC;IAChC,SAAS,CAAC,QAAQ,CAAC,UAAU,EAAE,UAAU,CAAC,eAAe,CAAC,CAAC;IAC3D,OAAO,CAAC,IAAI,CAAgC;gBAG1C,UAAU,EAAE,UAAU,EACtB,IAAI,EAAE,YAAY,CAAC,eAAe,CAAC,EACnC,MAAM,CAAC,EAAE,cAAc;IAQzB;;OAEG;IACH,SAAS,CAAC,YAAY,GACpB,MAAM,aAAa,EAAE,EAAE,wDAAwD;IAC/E,OAAO,SAAS,EAAE,wDAAwD;IAC1E,WAAW,MAAM,KAChB,KAAK,CAAC,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC,CAInC;IAEF;;OAEG;IACH,SAAS,CAAC,mBAAmB,GAC3B,UAAU,eAAe,EAAE,KAC1B,aAAa,EAAE,CAIhB;IAEF;;;;;;OAMG;IACH,SAAS,CAAC,cAAc,GACtB,aAAa,WAAW,EACxB,eAAe,KAAK,CAAC,aAAa,CAAC,EACnC,OAAO,SAAS,EAChB,WAAW,MAAM,mBAMjB;IAEF;;;;;;OAMG;IACH,SAAS,CAAC,YAAY,GACpB,aAAa,WAAW,EACxB,WAAW,aAAa,EACxB,OAAO,SAAS,EAChB,WAAW,MAAM,mBAWjB;IAEF;;;;;;OAMG;IACH,SAAS,CAAC,mBAAmB,GAC3B,aAAa,WAAW,EACxB,WAAW,MAAM,EACjB,OAAO,MAAM,KACZ,OAAO,CAAC,aAAa,EAAE,CAAC,CAazB;IAEF;;;;;;OAMG;IACH,SAAS,CAAC,mBAAmB,GAC3B,aAAa,WAAW,EACxB,WAAW,MAAM,EACjB,OAAO,MAAM,KACZ,OAAO,CAAC,eAAe,EAAE,CAAC,CAsB3B;IAEF;;;;;;;;OAQG;IACH,UAAU,GACR,OAAO,KAAK,CAAC,aAAa,CAAC,EAC3B,OAAO,SAAS,EAChB,WAAW,MAAM,KAChB,OAAO,CAAC,OAAO,CAAC,CA6CjB;IAEF;;;;;;;;;;OAUG;IACH,UAAU,GACR,YAAY,KAAK,CAAC,SAAS,CAAC,EAC5B,OAAO,SAAS,EAChB,WAAW,MAAM,KAChB,OAAO,CAAC,OAAO,EAAE,CAAC,CA8BnB;IAEF;;;;;;;OAOG;IACH,gBAAgB,GACd,OAAO,MAAM,EACb,WAAW,MAAM,KAChB,OAAO,CAAC;QAAE,WAAW,EAAE,aAAa,EAAE,CAAC;QAAC,WAAW,EAAE,OAAO,EAAE,CAAA;KAAE,CAAC,CAiClE;CACH"}
|
|
@@ -1,219 +0,0 @@
|
|
|
1
|
-
import { chunk, difference, pick } from 'lodash-es';
|
|
2
|
-
import { DummyLogger } from '@rosen-bridge/abstract-logger';
|
|
3
|
-
import { In, Not, } from '@rosen-bridge/extended-typeorm';
|
|
4
|
-
import JsonBigInt from '@rosen-bridge/json-bigint';
|
|
5
|
-
import { DB_CHUNK_SIZE } from '../constants';
|
|
6
|
-
export class AbstractErgoExtractorAction {
|
|
7
|
-
datasource;
|
|
8
|
-
logger;
|
|
9
|
-
repository;
|
|
10
|
-
repo;
|
|
11
|
-
constructor(dataSource, repo, logger) {
|
|
12
|
-
this.datasource = dataSource;
|
|
13
|
-
this.logger = logger ? logger : new DummyLogger();
|
|
14
|
-
this.repository = this.datasource.getRepository(repo);
|
|
15
|
-
this.repo = repo;
|
|
16
|
-
}
|
|
17
|
-
/**
|
|
18
|
-
* create the database entity from extracted data and block information
|
|
19
|
-
*/
|
|
20
|
-
createEntity = (data, // eslint-disable-line @typescript-eslint/no-unused-vars
|
|
21
|
-
block, // eslint-disable-line @typescript-eslint/no-unused-vars
|
|
22
|
-
extractor) => {
|
|
23
|
-
throw Error('You must implement `createEntity` or override `insertEntities` and `updateEntities`');
|
|
24
|
-
};
|
|
25
|
-
/**
|
|
26
|
-
* convert the database entity back to raw data
|
|
27
|
-
*/
|
|
28
|
-
convertEntityToData = (entities) => {
|
|
29
|
-
throw Error('You must implement `convertEntityToData` or override `deleteBlockEntities`');
|
|
30
|
-
};
|
|
31
|
-
/**
|
|
32
|
-
* insert entities extracted from a block to database
|
|
33
|
-
* @param queryRunner
|
|
34
|
-
* @param boxesToInsert
|
|
35
|
-
* @param block
|
|
36
|
-
* @param extractor
|
|
37
|
-
*/
|
|
38
|
-
insertEntities = async (queryRunner, boxesToInsert, block, extractor) => {
|
|
39
|
-
const repository = queryRunner.manager.getRepository(this.repo);
|
|
40
|
-
await repository.insert(this.createEntity(boxesToInsert, block, extractor));
|
|
41
|
-
};
|
|
42
|
-
/**
|
|
43
|
-
* update entities related to a box
|
|
44
|
-
* @param queryRunner
|
|
45
|
-
* @param updateBox
|
|
46
|
-
* @param block
|
|
47
|
-
* @param extractor
|
|
48
|
-
*/
|
|
49
|
-
updateEntity = async (queryRunner, updateBox, block, extractor) => {
|
|
50
|
-
const repository = queryRunner.manager.getRepository(this.repo);
|
|
51
|
-
const box = this.createEntity([updateBox], block, extractor)[0];
|
|
52
|
-
await repository.update({
|
|
53
|
-
boxId: box.boxId,
|
|
54
|
-
extractor: extractor,
|
|
55
|
-
}, box);
|
|
56
|
-
};
|
|
57
|
-
/**
|
|
58
|
-
* delete all data extracted from a block
|
|
59
|
-
* @param queryRunner
|
|
60
|
-
* @param extractor
|
|
61
|
-
* @param block
|
|
62
|
-
* @returns
|
|
63
|
-
*/
|
|
64
|
-
deleteBlockEntities = async (queryRunner, extractor, block) => {
|
|
65
|
-
const repository = queryRunner.manager.getRepository(this.repo);
|
|
66
|
-
const deletedData = await repository.find({
|
|
67
|
-
where: {
|
|
68
|
-
extractor: extractor,
|
|
69
|
-
block: block,
|
|
70
|
-
},
|
|
71
|
-
});
|
|
72
|
-
await repository.delete({
|
|
73
|
-
extractor: extractor,
|
|
74
|
-
block: block,
|
|
75
|
-
});
|
|
76
|
-
return this.convertEntityToData(deletedData);
|
|
77
|
-
};
|
|
78
|
-
/**
|
|
79
|
-
* delete all data extracted from a block
|
|
80
|
-
* @param queryRunner
|
|
81
|
-
* @param extractor
|
|
82
|
-
* @param block
|
|
83
|
-
* @returns
|
|
84
|
-
*/
|
|
85
|
-
updateBlockEntities = async (queryRunner, extractor, block) => {
|
|
86
|
-
const repository = this.datasource.getRepository(this.repo);
|
|
87
|
-
const updatedData = await repository.find({
|
|
88
|
-
where: {
|
|
89
|
-
extractor: extractor,
|
|
90
|
-
spendBlock: block,
|
|
91
|
-
block: Not(block),
|
|
92
|
-
},
|
|
93
|
-
});
|
|
94
|
-
await repository.update({
|
|
95
|
-
spendBlock: block,
|
|
96
|
-
extractor: extractor,
|
|
97
|
-
}, {
|
|
98
|
-
spendBlock: null,
|
|
99
|
-
spendHeight: 0,
|
|
100
|
-
});
|
|
101
|
-
return updatedData;
|
|
102
|
-
};
|
|
103
|
-
/**
|
|
104
|
-
* insert all extracted box data in an atomic transaction
|
|
105
|
-
* update the data if a box with the same id is already stored in db
|
|
106
|
-
* @param boxes
|
|
107
|
-
* @param block
|
|
108
|
-
* @param extractor
|
|
109
|
-
* @return inserted items and updated box ids
|
|
110
|
-
* returns undefined in case of any problem
|
|
111
|
-
*/
|
|
112
|
-
storeBoxes = async (boxes, block, extractor) => {
|
|
113
|
-
let boxesToInsert = [], boxesToUpdate = [];
|
|
114
|
-
const queryRunner = this.datasource.createQueryRunner();
|
|
115
|
-
await queryRunner.connect();
|
|
116
|
-
await queryRunner.startTransaction();
|
|
117
|
-
try {
|
|
118
|
-
const repository = queryRunner.manager.getRepository(this.repo);
|
|
119
|
-
const dbBoxIds = (await repository.findBy({
|
|
120
|
-
boxId: In(boxes.map((item) => item.boxId)),
|
|
121
|
-
extractor: extractor,
|
|
122
|
-
})).map((box) => box.boxId);
|
|
123
|
-
if (dbBoxIds.length > 0)
|
|
124
|
-
this.logger.debug(`Found stored boxes with same boxId`, dbBoxIds);
|
|
125
|
-
boxesToUpdate = boxes.filter((box) => dbBoxIds.includes(box.boxId));
|
|
126
|
-
boxesToInsert = difference(boxes, boxesToUpdate);
|
|
127
|
-
if (boxesToInsert.length > 0) {
|
|
128
|
-
this.logger.debug(`Inserting boxes`);
|
|
129
|
-
await this.insertEntities(queryRunner, boxesToInsert, block, extractor);
|
|
130
|
-
}
|
|
131
|
-
if (boxesToUpdate.length > 0)
|
|
132
|
-
this.logger.info(`Updating boxes with following Ids in the database: [${boxesToUpdate
|
|
133
|
-
.map((col) => col.boxId)
|
|
134
|
-
.join(', ')}]`);
|
|
135
|
-
for (const box of boxesToUpdate) {
|
|
136
|
-
this.logger.debug(`Updating boxes in database [${JsonBigInt.stringify(box)}]`);
|
|
137
|
-
await this.updateEntity(queryRunner, box, block, extractor);
|
|
138
|
-
}
|
|
139
|
-
await queryRunner.commitTransaction();
|
|
140
|
-
return true;
|
|
141
|
-
}
|
|
142
|
-
catch (e) {
|
|
143
|
-
this.logger.error(`An error occurred during store boxes action: ${e}`);
|
|
144
|
-
await queryRunner.rollbackTransaction();
|
|
145
|
-
return false;
|
|
146
|
-
}
|
|
147
|
-
finally {
|
|
148
|
-
await queryRunner.release();
|
|
149
|
-
}
|
|
150
|
-
};
|
|
151
|
-
/**
|
|
152
|
-
* update spending information of stored boxes
|
|
153
|
-
* chunk spendInfos to prevent large database queries
|
|
154
|
-
* Note: It only updates the spendHeight and spendBlock fields. If updating
|
|
155
|
-
* anything else is required, override this implementation to include the
|
|
156
|
-
* additional fields.
|
|
157
|
-
* @param spendInfos
|
|
158
|
-
* @param block
|
|
159
|
-
* @param extractor
|
|
160
|
-
* @returns spent box ids
|
|
161
|
-
*/
|
|
162
|
-
spendBoxes = async (spendInfos, block, extractor) => {
|
|
163
|
-
const spentData = [];
|
|
164
|
-
const spendInfoChunks = chunk(spendInfos, DB_CHUNK_SIZE);
|
|
165
|
-
for (const spendInfoChunk of spendInfoChunks) {
|
|
166
|
-
const boxIds = spendInfoChunk.map((info) => info.boxId);
|
|
167
|
-
const updateResult = await this.repository.update({
|
|
168
|
-
boxId: In(boxIds),
|
|
169
|
-
extractor: extractor,
|
|
170
|
-
}, {
|
|
171
|
-
spendBlock: block.hash,
|
|
172
|
-
spendHeight: block.height,
|
|
173
|
-
});
|
|
174
|
-
if (updateResult.affected && updateResult.affected > 0) {
|
|
175
|
-
const spentRows = await this.repository.findBy({
|
|
176
|
-
boxId: In(boxIds),
|
|
177
|
-
spendBlock: block.hash,
|
|
178
|
-
});
|
|
179
|
-
spentData.push(...spentRows);
|
|
180
|
-
for (const row of spentRows) {
|
|
181
|
-
this.logger.debug(`Spent box with boxId [${row.boxId}] at height ${block.height}`);
|
|
182
|
-
}
|
|
183
|
-
}
|
|
184
|
-
}
|
|
185
|
-
return spentData.map((data) => pick(data, 'boxId'));
|
|
186
|
-
};
|
|
187
|
-
/**
|
|
188
|
-
* delete extracted data from a specific block
|
|
189
|
-
* if a box is spend in this block mark it as unspent
|
|
190
|
-
* if a box is created in this block remove it from database
|
|
191
|
-
* @param block
|
|
192
|
-
* @param extractor
|
|
193
|
-
* @return deleted items and updated box ids
|
|
194
|
-
*/
|
|
195
|
-
deleteBlockBoxes = async (block, extractor) => {
|
|
196
|
-
const queryRunner = this.datasource.createQueryRunner();
|
|
197
|
-
await queryRunner.connect();
|
|
198
|
-
await queryRunner.startTransaction();
|
|
199
|
-
try {
|
|
200
|
-
this.logger.info(`Deleting boxes in block ${block} and extractor ${extractor}`);
|
|
201
|
-
const updatedData = await this.updateBlockEntities(queryRunner, extractor, block);
|
|
202
|
-
const deletedData = await this.deleteBlockEntities(queryRunner, extractor, block);
|
|
203
|
-
await queryRunner.commitTransaction();
|
|
204
|
-
return {
|
|
205
|
-
deletedData,
|
|
206
|
-
updatedData: updatedData.map((data) => pick(data, 'boxId')),
|
|
207
|
-
};
|
|
208
|
-
}
|
|
209
|
-
catch (error) {
|
|
210
|
-
await queryRunner.rollbackTransaction();
|
|
211
|
-
this.logger.error(`An error occurred while deleting data extracted from block ${block}`, error);
|
|
212
|
-
throw error;
|
|
213
|
-
}
|
|
214
|
-
finally {
|
|
215
|
-
await queryRunner.release();
|
|
216
|
-
}
|
|
217
|
-
};
|
|
218
|
-
}
|
|
219
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstractErgoExtractorAction.js","sourceRoot":"","sources":["../../lib/ergo/abstractErgoExtractorAction.ts"],"names":[],"mappings":"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","sourcesContent":["import { chunk, difference, pick } from 'lodash-es';\n\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport {\n  DataSource,\n  In,\n  Repository,\n  Not,\n  EntityTarget,\n  FindOptionsWhere,\n  QueryRunner,\n} from '@rosen-bridge/extended-typeorm';\nimport JsonBigInt from '@rosen-bridge/json-bigint';\nimport { BlockInfo } from '@rosen-bridge/scanner-interfaces';\n\nimport { DB_CHUNK_SIZE } from '../constants';\nimport { AbstractErgoExtractorEntity } from './abstractErgoExtractorEntity';\nimport { AbstractBoxData, BoxInfo, SpendInfo } from './interfaces';\n\nexport abstract class AbstractErgoExtractorAction<\n  ExtractedData extends AbstractBoxData,\n  ExtractorEntity extends AbstractErgoExtractorEntity,\n> {\n  private readonly datasource: DataSource;\n  readonly logger: AbstractLogger;\n  protected readonly repository: Repository<ExtractorEntity>;\n  private repo: EntityTarget<ExtractorEntity>;\n\n  constructor(\n    dataSource: DataSource,\n    repo: EntityTarget<ExtractorEntity>,\n    logger?: AbstractLogger,\n  ) {\n    this.datasource = dataSource;\n    this.logger = logger ? logger : new DummyLogger();\n    this.repository = this.datasource.getRepository(repo);\n    this.repo = repo;\n  }\n\n  /**\n   * create the database entity from extracted data and block information\n   */\n  protected createEntity = (\n    data: ExtractedData[], // eslint-disable-line @typescript-eslint/no-unused-vars\n    block: BlockInfo, // eslint-disable-line @typescript-eslint/no-unused-vars\n    extractor: string, // eslint-disable-line @typescript-eslint/no-unused-vars\n  ): Array<Omit<ExtractorEntity, 'id'>> => {\n    throw Error(\n      'You must implement `createEntity` or override `insertEntities` and `updateEntities`',\n    );\n  };\n\n  /**\n   * convert the database entity back to raw data\n   */\n  protected convertEntityToData = (\n    entities: ExtractorEntity[], // eslint-disable-line @typescript-eslint/no-unused-vars\n  ): ExtractedData[] => {\n    throw Error(\n      'You must implement `convertEntityToData` or override `deleteBlockEntities`',\n    );\n  };\n\n  /**\n   * insert entities extracted from a block to database\n   * @param queryRunner\n   * @param boxesToInsert\n   * @param block\n   * @param extractor\n   */\n  protected insertEntities = async (\n    queryRunner: QueryRunner,\n    boxesToInsert: Array<ExtractedData>,\n    block: BlockInfo,\n    extractor: string,\n  ) => {\n    const repository = queryRunner.manager.getRepository(this.repo);\n    await repository.insert(\n      this.createEntity(boxesToInsert, block, extractor) as any, // eslint-disable-line @typescript-eslint/no-explicit-any\n    );\n  };\n\n  /**\n   * update entities related to a box\n   * @param queryRunner\n   * @param updateBox\n   * @param block\n   * @param extractor\n   */\n  protected updateEntity = async (\n    queryRunner: QueryRunner,\n    updateBox: ExtractedData,\n    block: BlockInfo,\n    extractor: string,\n  ) => {\n    const repository = queryRunner.manager.getRepository(this.repo);\n    const box = this.createEntity([updateBox], block, extractor)[0];\n    await repository.update(\n      {\n        boxId: box.boxId,\n        extractor: extractor,\n      } as FindOptionsWhere<ExtractorEntity>,\n      box as any, // eslint-disable-line @typescript-eslint/no-explicit-any\n    );\n  };\n\n  /**\n   * delete all data extracted from a block\n   * @param queryRunner\n   * @param extractor\n   * @param block\n   * @returns\n   */\n  protected deleteBlockEntities = async (\n    queryRunner: QueryRunner,\n    extractor: string,\n    block: string,\n  ): Promise<ExtractedData[]> => {\n    const repository = queryRunner.manager.getRepository(this.repo);\n    const deletedData = await repository.find({\n      where: {\n        extractor: extractor,\n        block: block,\n      } as FindOptionsWhere<ExtractorEntity>,\n    });\n    await repository.delete({\n      extractor: extractor,\n      block: block,\n    } as unknown as FindOptionsWhere<ExtractorEntity>);\n    return this.convertEntityToData(deletedData);\n  };\n\n  /**\n   * delete all data extracted from a block\n   * @param queryRunner\n   * @param extractor\n   * @param block\n   * @returns\n   */\n  protected updateBlockEntities = async (\n    queryRunner: QueryRunner,\n    extractor: string,\n    block: string,\n  ): Promise<ExtractorEntity[]> => {\n    const repository = this.datasource.getRepository(\n      this.repo as EntityTarget<new () => ExtractorEntity>,\n    );\n    const updatedData = await repository.find({\n      where: {\n        extractor: extractor,\n        spendBlock: block,\n        block: Not(block),\n      } as unknown as FindOptionsWhere<ExtractorEntity>,\n    });\n    await repository.update(\n      {\n        spendBlock: block,\n        extractor: extractor,\n      } as unknown as FindOptionsWhere<ExtractorEntity>,\n      {\n        spendBlock: null,\n        spendHeight: 0,\n      },\n    );\n    return updatedData as unknown as ExtractorEntity[];\n  };\n\n  /**\n   * insert all extracted box data in an atomic transaction\n   * update the data if a box with the same id is already stored in db\n   * @param boxes\n   * @param block\n   * @param extractor\n   * @return inserted items and updated box ids\n   * returns undefined in case of any problem\n   */\n  storeBoxes = async (\n    boxes: Array<ExtractedData>,\n    block: BlockInfo,\n    extractor: string,\n  ): Promise<boolean> => {\n    let boxesToInsert: ExtractedData[] = [],\n      boxesToUpdate: ExtractedData[] = [];\n    const queryRunner = this.datasource.createQueryRunner();\n    await queryRunner.connect();\n    await queryRunner.startTransaction();\n    try {\n      const repository = queryRunner.manager.getRepository(this.repo);\n      const dbBoxIds = (\n        await repository.findBy({\n          boxId: In(boxes.map((item) => item.boxId)),\n          extractor: extractor,\n        } as FindOptionsWhere<ExtractorEntity>)\n      ).map((box) => box.boxId);\n      if (dbBoxIds.length > 0)\n        this.logger.debug(`Found stored boxes with same boxId`, dbBoxIds);\n\n      boxesToUpdate = boxes.filter((box) => dbBoxIds.includes(box.boxId));\n      boxesToInsert = difference(boxes, boxesToUpdate);\n\n      if (boxesToInsert.length > 0) {\n        this.logger.debug(`Inserting boxes`);\n        await this.insertEntities(queryRunner, boxesToInsert, block, extractor);\n      }\n      if (boxesToUpdate.length > 0)\n        this.logger.info(\n          `Updating boxes with following Ids in the database: [${boxesToUpdate\n            .map((col) => col.boxId)\n            .join(', ')}]`,\n        );\n      for (const box of boxesToUpdate) {\n        this.logger.debug(\n          `Updating boxes in database [${JsonBigInt.stringify(box)}]`,\n        );\n        await this.updateEntity(queryRunner, box, block, extractor);\n      }\n      await queryRunner.commitTransaction();\n      return true;\n    } catch (e) {\n      this.logger.error(`An error occurred during store boxes action: ${e}`);\n      await queryRunner.rollbackTransaction();\n      return false;\n    } finally {\n      await queryRunner.release();\n    }\n  };\n\n  /**\n   * update spending information of stored boxes\n   * chunk spendInfos to prevent large database queries\n   * Note: It only updates the spendHeight and spendBlock fields. If updating\n   * anything else is required, override this implementation to include the\n   * additional fields.\n   * @param spendInfos\n   * @param block\n   * @param extractor\n   * @returns spent box ids\n   */\n  spendBoxes = async (\n    spendInfos: Array<SpendInfo>,\n    block: BlockInfo,\n    extractor: string,\n  ): Promise<BoxInfo[]> => {\n    const spentData = [];\n    const spendInfoChunks = chunk(spendInfos, DB_CHUNK_SIZE);\n    for (const spendInfoChunk of spendInfoChunks) {\n      const boxIds = spendInfoChunk.map((info) => info.boxId);\n      const updateResult = await this.repository.update(\n        {\n          boxId: In(boxIds),\n          extractor: extractor,\n        } as FindOptionsWhere<ExtractorEntity>,\n        {\n          spendBlock: block.hash,\n          spendHeight: block.height,\n        } as any, // eslint-disable-line @typescript-eslint/no-explicit-any\n      );\n\n      if (updateResult.affected && updateResult.affected > 0) {\n        const spentRows = await this.repository.findBy({\n          boxId: In(boxIds),\n          spendBlock: block.hash,\n        } as FindOptionsWhere<ExtractorEntity>);\n        spentData.push(...spentRows);\n        for (const row of spentRows) {\n          this.logger.debug(\n            `Spent box with boxId [${row.boxId}] at height ${block.height}`,\n          );\n        }\n      }\n    }\n    return spentData.map((data) => pick(data, 'boxId'));\n  };\n\n  /**\n   * delete extracted data from a specific block\n   * if a box is spend in this block mark it as unspent\n   * if a box is created in this block remove it from database\n   * @param block\n   * @param extractor\n   * @return deleted items and updated box ids\n   */\n  deleteBlockBoxes = async (\n    block: string,\n    extractor: string,\n  ): Promise<{ deletedData: ExtractedData[]; updatedData: BoxInfo[] }> => {\n    const queryRunner = this.datasource.createQueryRunner();\n    await queryRunner.connect();\n    await queryRunner.startTransaction();\n    try {\n      this.logger.info(\n        `Deleting boxes in block ${block} and extractor ${extractor}`,\n      );\n      const updatedData = await this.updateBlockEntities(\n        queryRunner,\n        extractor,\n        block,\n      );\n      const deletedData = await this.deleteBlockEntities(\n        queryRunner,\n        extractor,\n        block,\n      );\n      await queryRunner.commitTransaction();\n      return {\n        deletedData,\n        updatedData: updatedData.map((data) => pick(data, 'boxId')),\n      };\n    } catch (error) {\n      await queryRunner.rollbackTransaction();\n      this.logger.error(\n        `An error occurred while deleting data extracted from block ${block}`,\n        error,\n      );\n      throw error;\n    } finally {\n      await queryRunner.release();\n    }\n  };\n}\n"]}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
export declare abstract class AbstractErgoExtractorEntity {
|
|
2
|
-
id: number;
|
|
3
|
-
boxId: string;
|
|
4
|
-
block: string;
|
|
5
|
-
height: number;
|
|
6
|
-
spendBlock?: string | null;
|
|
7
|
-
spendHeight?: number | null;
|
|
8
|
-
extractor: string;
|
|
9
|
-
serialized: string;
|
|
10
|
-
}
|
|
11
|
-
//# sourceMappingURL=abstractErgoExtractorEntity.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"abstractErgoExtractorEntity.d.ts","sourceRoot":"","sources":["../../lib/ergo/abstractErgoExtractorEntity.ts"],"names":[],"mappings":"AAMA,8BACsB,2BAA2B;IAE/C,EAAE,EAAE,MAAM,CAAC;IAGX,KAAK,EAAE,MAAM,CAAC;IAGd,KAAK,EAAE,MAAM,CAAC;IAGd,MAAM,EAAE,MAAM,CAAC;IAGf,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAG3B,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAG5B,SAAS,EAAE,MAAM,CAAC;IAGlB,UAAU,EAAE,MAAM,CAAC;CACpB"}
|
|
@@ -1,57 +0,0 @@
|
|
|
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 { Column, PrimaryGeneratedColumn, Unique, } from '@rosen-bridge/extended-typeorm';
|
|
11
|
-
let AbstractErgoExtractorEntity = class AbstractErgoExtractorEntity {
|
|
12
|
-
id;
|
|
13
|
-
boxId;
|
|
14
|
-
block;
|
|
15
|
-
height;
|
|
16
|
-
spendBlock;
|
|
17
|
-
spendHeight;
|
|
18
|
-
extractor;
|
|
19
|
-
serialized;
|
|
20
|
-
};
|
|
21
|
-
__decorate([
|
|
22
|
-
PrimaryGeneratedColumn(),
|
|
23
|
-
__metadata("design:type", Number)
|
|
24
|
-
], AbstractErgoExtractorEntity.prototype, "id", void 0);
|
|
25
|
-
__decorate([
|
|
26
|
-
Column({ type: 'varchar' }),
|
|
27
|
-
__metadata("design:type", String)
|
|
28
|
-
], AbstractErgoExtractorEntity.prototype, "boxId", void 0);
|
|
29
|
-
__decorate([
|
|
30
|
-
Column({ type: 'varchar' }),
|
|
31
|
-
__metadata("design:type", String)
|
|
32
|
-
], AbstractErgoExtractorEntity.prototype, "block", void 0);
|
|
33
|
-
__decorate([
|
|
34
|
-
Column({ type: 'int' }),
|
|
35
|
-
__metadata("design:type", Number)
|
|
36
|
-
], AbstractErgoExtractorEntity.prototype, "height", void 0);
|
|
37
|
-
__decorate([
|
|
38
|
-
Column({ nullable: true, type: 'varchar' }),
|
|
39
|
-
__metadata("design:type", Object)
|
|
40
|
-
], AbstractErgoExtractorEntity.prototype, "spendBlock", void 0);
|
|
41
|
-
__decorate([
|
|
42
|
-
Column({ nullable: true, type: 'int' }),
|
|
43
|
-
__metadata("design:type", Object)
|
|
44
|
-
], AbstractErgoExtractorEntity.prototype, "spendHeight", void 0);
|
|
45
|
-
__decorate([
|
|
46
|
-
Column({ type: 'varchar' }),
|
|
47
|
-
__metadata("design:type", String)
|
|
48
|
-
], AbstractErgoExtractorEntity.prototype, "extractor", void 0);
|
|
49
|
-
__decorate([
|
|
50
|
-
Column({ type: 'varchar' }),
|
|
51
|
-
__metadata("design:type", String)
|
|
52
|
-
], AbstractErgoExtractorEntity.prototype, "serialized", void 0);
|
|
53
|
-
AbstractErgoExtractorEntity = __decorate([
|
|
54
|
-
Unique(['boxId', 'extractor'])
|
|
55
|
-
], AbstractErgoExtractorEntity);
|
|
56
|
-
export { AbstractErgoExtractorEntity };
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzdHJhY3RFcmdvRXh0cmFjdG9yRW50aXR5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vbGliL2VyZ28vYWJzdHJhY3RFcmdvRXh0cmFjdG9yRW50aXR5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUFBLE9BQU8sRUFDTCxNQUFNLEVBQ04sc0JBQXNCLEVBQ3RCLE1BQU0sR0FDUCxNQUFNLGdDQUFnQyxDQUFDO0FBR2pDLElBQWUsMkJBQTJCLEdBQTFDLE1BQWUsMkJBQTJCO0lBRS9DLEVBQUUsQ0FBUztJQUdYLEtBQUssQ0FBUztJQUdkLEtBQUssQ0FBUztJQUdkLE1BQU0sQ0FBUztJQUdmLFVBQVUsQ0FBaUI7SUFHM0IsV0FBVyxDQUFpQjtJQUc1QixTQUFTLENBQVM7SUFHbEIsVUFBVSxDQUFTO0NBQ3BCLENBQUE7QUF0QkM7SUFEQyxzQkFBc0IsRUFBRTs7dURBQ2Q7QUFHWDtJQURDLE1BQU0sQ0FBQyxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsQ0FBQzs7MERBQ2Q7QUFHZDtJQURDLE1BQU0sQ0FBQyxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsQ0FBQzs7MERBQ2Q7QUFHZDtJQURDLE1BQU0sQ0FBQyxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsQ0FBQzs7MkRBQ1Q7QUFHZjtJQURDLE1BQU0sQ0FBQyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxDQUFDOzsrREFDakI7QUFHM0I7SUFEQyxNQUFNLENBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsQ0FBQzs7Z0VBQ1o7QUFHNUI7SUFEQyxNQUFNLENBQUMsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLENBQUM7OzhEQUNWO0FBR2xCO0lBREMsTUFBTSxDQUFDLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxDQUFDOzsrREFDVDtBQXZCQywyQkFBMkI7SUFEaEQsTUFBTSxDQUFDLENBQUMsT0FBTyxFQUFFLFdBQVcsQ0FBQyxDQUFDO0dBQ1QsMkJBQTJCLENBd0JoRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENvbHVtbixcbiAgUHJpbWFyeUdlbmVyYXRlZENvbHVtbixcbiAgVW5pcXVlLFxufSBmcm9tICdAcm9zZW4tYnJpZGdlL2V4dGVuZGVkLXR5cGVvcm0nO1xuXG5AVW5pcXVlKFsnYm94SWQnLCAnZXh0cmFjdG9yJ10pXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQWJzdHJhY3RFcmdvRXh0cmFjdG9yRW50aXR5IHtcbiAgQFByaW1hcnlHZW5lcmF0ZWRDb2x1bW4oKVxuICBpZDogbnVtYmVyO1xuXG4gIEBDb2x1bW4oeyB0eXBlOiAndmFyY2hhcicgfSlcbiAgYm94SWQ6IHN0cmluZztcblxuICBAQ29sdW1uKHsgdHlwZTogJ3ZhcmNoYXInIH0pXG4gIGJsb2NrOiBzdHJpbmc7XG5cbiAgQENvbHVtbih7IHR5cGU6ICdpbnQnIH0pXG4gIGhlaWdodDogbnVtYmVyO1xuXG4gIEBDb2x1bW4oeyBudWxsYWJsZTogdHJ1ZSwgdHlwZTogJ3ZhcmNoYXInIH0pXG4gIHNwZW5kQmxvY2s/OiBzdHJpbmcgfCBudWxsO1xuXG4gIEBDb2x1bW4oeyBudWxsYWJsZTogdHJ1ZSwgdHlwZTogJ2ludCcgfSlcbiAgc3BlbmRIZWlnaHQ/OiBudW1iZXIgfCBudWxsO1xuXG4gIEBDb2x1bW4oeyB0eXBlOiAndmFyY2hhcicgfSlcbiAgZXh0cmFjdG9yOiBzdHJpbmc7XG5cbiAgQENvbHVtbih7IHR5cGU6ICd2YXJjaGFyJyB9KVxuICBzZXJpYWxpemVkOiBzdHJpbmc7XG59XG4iXX0=
|
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
import { AbstractLogger } from '@rosen-bridge/abstract-logger';
|
|
2
|
-
import { BlockInfo, ErgoNetworkType } from '@rosen-bridge/scanner-interfaces';
|
|
3
|
-
import { AbstractErgoExtractor } from '../abstractErgoExtractor';
|
|
4
|
-
import { AbstractErgoExtractorEntity } from '../abstractErgoExtractorEntity';
|
|
5
|
-
import { AbstractBoxData } from '../interfaces';
|
|
6
|
-
import { AbstractInitializableErgoExtractorAction } from './abstractInitializableAction';
|
|
7
|
-
export declare abstract class AbstractInitializableErgoExtractor<ExtractedData extends AbstractBoxData, ExtractorEntity extends AbstractErgoExtractorEntity> extends AbstractErgoExtractor<ExtractedData, ExtractorEntity> {
|
|
8
|
-
protected initialize: boolean;
|
|
9
|
-
private address;
|
|
10
|
-
protected abstract actions: AbstractInitializableErgoExtractorAction<ExtractedData, ExtractorEntity>;
|
|
11
|
-
private network;
|
|
12
|
-
constructor(type: ErgoNetworkType, url: string, address: string, logger?: AbstractLogger, initialize?: boolean);
|
|
13
|
-
/**
|
|
14
|
-
* Initialize extractor using Explorer network
|
|
15
|
-
* @param initialBlock
|
|
16
|
-
*/
|
|
17
|
-
private initializeWithExplorer;
|
|
18
|
-
/**
|
|
19
|
-
* Get the total tx count from Node network
|
|
20
|
-
* @returns total tx count of the address
|
|
21
|
-
*/
|
|
22
|
-
private getTotalTxCount;
|
|
23
|
-
/**
|
|
24
|
-
* Initialize extractor using Node network
|
|
25
|
-
* @param initialBlock
|
|
26
|
-
*/
|
|
27
|
-
private initializeWithNode;
|
|
28
|
-
/**
|
|
29
|
-
* Process a batch of transactions
|
|
30
|
-
* group txs into blocks and process them using `processTransactions`
|
|
31
|
-
* @param txs
|
|
32
|
-
*/
|
|
33
|
-
private processTransactionBatch;
|
|
34
|
-
/**
|
|
35
|
-
* Initialize the extractor with retrial on any unexpected problem
|
|
36
|
-
* its the common part of initialize with Node and Explorer network
|
|
37
|
-
* @param job
|
|
38
|
-
*/
|
|
39
|
-
private initWithRetrial;
|
|
40
|
-
/**
|
|
41
|
-
* initialize extractor database with data created below the initial height
|
|
42
|
-
* ignore initialization if this feature is off
|
|
43
|
-
* try to get data multiple times to pass accidental network problems
|
|
44
|
-
* @param initialBlock
|
|
45
|
-
*/
|
|
46
|
-
initializeBoxes: (initialBlock: BlockInfo) => Promise<void>;
|
|
47
|
-
}
|
|
48
|
-
//# sourceMappingURL=abstractInitializable.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"abstractInitializable.d.ts","sourceRoot":"","sources":["../../../lib/ergo/initializable/abstractInitializable.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AAG9E,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACjE,OAAO,EAAE,2BAA2B,EAAE,MAAM,gCAAgC,CAAC;AAC7E,OAAO,EAAE,eAAe,EAAuB,MAAM,eAAe,CAAC;AAGrE,OAAO,EAAE,wCAAwC,EAAE,MAAM,+BAA+B,CAAC;AAEzF,8BAAsB,kCAAkC,CACtD,aAAa,SAAS,eAAe,EACrC,eAAe,SAAS,2BAA2B,CACnD,SAAQ,qBAAqB,CAAC,aAAa,EAAE,eAAe,CAAC;IAC7D,SAAS,CAAC,UAAU,EAAE,OAAO,CAAC;IAC9B,OAAO,CAAC,OAAO,CAAS;IACxB,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,wCAAwC,CAClE,aAAa,EACb,eAAe,CAChB,CAAC;IAEF,OAAO,CAAC,OAAO,CAAgC;gBAG7C,IAAI,EAAE,eAAe,EACrB,GAAG,EAAE,MAAM,EACX,OAAO,EAAE,MAAM,EACf,MAAM,CAAC,EAAE,cAAc,EACvB,UAAU,UAAO;IAkBnB;;;OAGG;IACH,OAAO,CAAC,sBAAsB,CA6C5B;IAEF;;;OAGG;IACH,OAAO,CAAC,eAAe,CAKrB;IAEF;;;OAGG;IACH,OAAO,CAAC,kBAAkB,CAuCxB;IAEF;;;;OAIG;IACH,OAAO,CAAC,uBAAuB,CAoB7B;IAEF;;;;OAIG;IACH,OAAO,CAAC,eAAe,CA+BrB;IAEF;;;;;OAKG;IACH,eAAe,EAAE,CAAC,YAAY,EAAE,SAAS,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;CAC7D"}
|