@rosen-bridge/watcher-data-extractor 12.3.0 → 13.0.0-7b38188a

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.
Files changed (52) hide show
  1. package/CHANGELOG.md +20 -0
  2. package/dist/actions/collateralAction.d.ts +15 -66
  3. package/dist/actions/collateralAction.d.ts.map +1 -1
  4. package/dist/actions/collateralAction.js +21 -181
  5. package/dist/actions/commitmentAction.d.ts +3 -3
  6. package/dist/actions/commitmentAction.d.ts.map +1 -1
  7. package/dist/actions/commitmentAction.js +2 -2
  8. package/dist/actions/eventTriggerAction.d.ts +3 -4
  9. package/dist/actions/eventTriggerAction.d.ts.map +1 -1
  10. package/dist/actions/eventTriggerAction.js +11 -13
  11. package/dist/actions/permitAction.d.ts +3 -3
  12. package/dist/actions/permitAction.d.ts.map +1 -1
  13. package/dist/actions/permitAction.js +1 -1
  14. package/dist/entities/collateralEntity.d.ts +3 -11
  15. package/dist/entities/collateralEntity.d.ts.map +1 -1
  16. package/dist/entities/collateralEntity.js +7 -52
  17. package/dist/entities/eventTriggerEntity.d.ts +2 -2
  18. package/dist/entities/eventTriggerEntity.d.ts.map +1 -1
  19. package/dist/entities/eventTriggerEntity.js +3 -3
  20. package/dist/extractor/collateralExtractor.d.ts +17 -72
  21. package/dist/extractor/collateralExtractor.d.ts.map +1 -1
  22. package/dist/extractor/collateralExtractor.js +48 -212
  23. package/dist/extractor/commitmentExtractor.d.ts +3 -3
  24. package/dist/extractor/commitmentExtractor.d.ts.map +1 -1
  25. package/dist/extractor/commitmentExtractor.js +3 -3
  26. package/dist/extractor/eventTriggerExtractor.d.ts +3 -3
  27. package/dist/extractor/eventTriggerExtractor.d.ts.map +1 -1
  28. package/dist/extractor/eventTriggerExtractor.js +9 -9
  29. package/dist/extractor/permitExtractor.d.ts +3 -3
  30. package/dist/extractor/permitExtractor.d.ts.map +1 -1
  31. package/dist/extractor/permitExtractor.js +3 -3
  32. package/dist/interfaces/extractedCollateral.d.ts +3 -7
  33. package/dist/interfaces/extractedCollateral.d.ts.map +1 -1
  34. package/dist/interfaces/extractedCollateral.js +1 -1
  35. package/dist/interfaces/extractedEventTrigger.d.ts +1 -1
  36. package/dist/interfaces/extractedEventTrigger.d.ts.map +1 -1
  37. package/dist/interfaces/extractedEventTrigger.js +1 -1
  38. package/dist/migrations/index.d.ts.map +1 -1
  39. package/dist/migrations/index.js +9 -1
  40. package/dist/migrations/postgres/1758958886549-migration.d.ts +7 -0
  41. package/dist/migrations/postgres/1758958886549-migration.d.ts.map +1 -0
  42. package/dist/migrations/postgres/1758958886549-migration.js +30 -0
  43. package/dist/migrations/postgres/1766843825000-migration.d.ts +7 -0
  44. package/dist/migrations/postgres/1766843825000-migration.d.ts.map +1 -0
  45. package/dist/migrations/postgres/1766843825000-migration.js +42 -0
  46. package/dist/migrations/sqlite/1762768664031-migration.d.ts +7 -0
  47. package/dist/migrations/sqlite/1762768664031-migration.d.ts.map +1 -0
  48. package/dist/migrations/sqlite/1762768664031-migration.js +204 -0
  49. package/dist/migrations/sqlite/1766843824000-migration.d.ts +7 -0
  50. package/dist/migrations/sqlite/1766843824000-migration.d.ts.map +1 -0
  51. package/dist/migrations/sqlite/1766843824000-migration.js +109 -0
  52. package/package.json +8 -7
package/CHANGELOG.md CHANGED
@@ -1,5 +1,25 @@
1
1
  # @rosen-bridge/watcher-data-extractor
2
2
 
3
+ ## 13.0.0-7b38188a
4
+
5
+ ### Major Changes
6
+
7
+ - Update AbstractExtractor interface; use `BlockInfo` in `processTransactions` and rename `initializeBoxes` to `initializeData`
8
+ - Update abstract database entity to be general; rename `boxId` columnt to `identifier`
9
+ - Refactor collateral extractor to extend AbstractErgoBoxExtractor
10
+
11
+ ### Patch Changes
12
+
13
+ - Update dependencies
14
+ - @rosen-bridge/abstract-logger@4.0.0
15
+
16
+ - Update dependencies
17
+ - Update dependencies
18
+ - Update dependencies
19
+ - Update dependencies
20
+ - Update dependencies
21
+ - @rosen-bridge/abstract-extractor@3.0.0-7b38188a
22
+
3
23
  ## 12.3.0
4
24
 
5
25
  ### Minor Changes
@@ -1,76 +1,25 @@
1
+ import { AbstractErgoBoxAction } from '@rosen-bridge/abstract-extractor';
1
2
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
2
- import { DataSource, DeleteResult } from '@rosen-bridge/extended-typeorm';
3
- import { Block } from '@rosen-bridge/scanner-interfaces';
3
+ import { DataSource } from '@rosen-bridge/extended-typeorm';
4
+ import { BlockInfo } from '@rosen-bridge/scanner-interfaces';
5
+ import CollateralEntity from '../entities/collateralEntity';
4
6
  import { ExtractedCollateral } from '../interfaces/extractedCollateral';
5
- import { SpendInfo } from '../interfaces/types';
6
- declare class CollateralAction {
7
- private readonly dataSource;
8
- readonly logger: AbstractLogger;
9
- private readonly collateralRepository;
7
+ declare class CollateralAction extends AbstractErgoBoxAction<ExtractedCollateral, CollateralEntity> {
10
8
  constructor(dataSource: DataSource, logger?: AbstractLogger);
11
9
  /**
12
- * inserts a collateral into the database
13
- *
14
- * @param {ExtractedCollateral} collateral
15
- * @param {string} extractor
16
- * @memberof CollateralAction
10
+ * create the collateral entity from extracted data and block information
11
+ * @param collaterals
12
+ * @param block
13
+ * @param extractor
14
+ * @returns the collateral entities (without the id)
17
15
  */
18
- insertCollateral: (collateral: ExtractedCollateral, extractor: string) => Promise<import("@rosen-bridge/extended-typeorm").InsertResult>;
16
+ protected createEntity: (collaterals: ExtractedCollateral[], block: BlockInfo, extractor: string) => Array<Omit<CollateralEntity, "id">>;
19
17
  /**
20
- * updates a collateral into the database
21
- *
22
- * @param {ExtractedCollateral} collateral
23
- * @param {string} extractor
24
- * @memberof CollateralAction
18
+ * convert the database entity back to raw data
19
+ * @param entities
20
+ * @returns the extracted collateral data
25
21
  */
26
- updateCollateral: (collateral: Partial<ExtractedCollateral> & Pick<ExtractedCollateral, "boxId">, extractor: string) => Promise<import("@rosen-bridge/extended-typeorm").UpdateResult>;
27
- /**
28
- * stores list of collaterals
29
- *
30
- * @param {Array<ExtractedCollateral>} collaterals
31
- * @param {Block} block
32
- * @param {string} extractor
33
- * @return {Promise<boolean>}
34
- * @memberof CollateralAction
35
- */
36
- storeCollaterals: (collaterals: Array<ExtractedCollateral>, block: Block, extractor: string) => Promise<boolean>;
37
- /**
38
- * Update spendBlock and spendHeight of collaterals spent in the block
39
- *
40
- * @param {Array<SpendInfo>} spendInfos
41
- * @param {Block} block
42
- * @param {string} extractor
43
- * @return {Promise<void>}
44
- * @memberof CollateralAction
45
- */
46
- spendCollaterals: (spendInfos: Array<SpendInfo>, block: Block, extractor: string) => Promise<void>;
47
- /**
48
- * Returns all stored unspent collateral box IDs
49
- *
50
- * @param {string} extractor
51
- * @return {Promise<Array<string>>}
52
- * @memberof CollateralAction
53
- */
54
- getUnspentCollateralBoxIds: (extractor: string) => Promise<Array<string>>;
55
- /**
56
- * Delete all collaterals corresponding to the passed block and extractor and
57
- * update all collaterals spent in the specified block
58
- *
59
- * @param {string} block
60
- * @param {string} extractor
61
- * @return {Promise<void>}
62
- * @memberof CollateralAction
63
- */
64
- deleteBlock(block: string, extractor: string): Promise<void>;
65
- /**
66
- * deletes the specified collateral box from database
67
- *
68
- * @param {string} boxId
69
- * @param {string} extractor
70
- * @return {Promise<DeleteResult>}
71
- * @memberof CollateralAction
72
- */
73
- deleteCollateral: (boxId: string, extractor: string) => Promise<DeleteResult>;
22
+ protected convertEntityToData: (entities: CollateralEntity[]) => ExtractedCollateral[];
74
23
  }
75
24
  export default CollateralAction;
76
25
  //# sourceMappingURL=collateralAction.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"collateralAction.d.ts","sourceRoot":"","sources":["../../lib/actions/collateralAction.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EACL,UAAU,EACV,YAAY,EAIb,MAAM,gCAAgC,CAAC;AAExC,OAAO,EAAE,KAAK,EAAE,MAAM,kCAAkC,CAAC;AAGzD,OAAO,EAAE,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AACxE,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAEhD,cAAM,gBAAgB;IAIlB,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,QAAQ,CAAC,MAAM,EAAE,cAAc;IAJjC,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAA+B;gBAGjD,UAAU,EAAE,UAAU,EAC9B,MAAM,GAAE,cAAkC;IAKrD;;;;;;OAMG;IACH,gBAAgB,GACd,YAAY,mBAAmB,EAC/B,WAAW,MAAM,oEAMjB;IAEF;;;;;;OAMG;IACH,gBAAgB,GACd,YAAY,OAAO,CAAC,mBAAmB,CAAC,GACtC,IAAI,CAAC,mBAAmB,EAAE,OAAO,CAAC,EACpC,WAAW,MAAM,oEASjB;IAEF;;;;;;;;OAQG;IACH,gBAAgB,GACd,aAAa,KAAK,CAAC,mBAAmB,CAAC,EACvC,OAAO,KAAK,EACZ,WAAW,MAAM,KAChB,OAAO,CAAC,OAAO,CAAC,CAuFjB;IAEF;;;;;;;;OAQG;IACH,gBAAgB,GACd,YAAY,KAAK,CAAC,SAAS,CAAC,EAC5B,OAAO,KAAK,EACZ,WAAW,MAAM,KAChB,OAAO,CAAC,IAAI,CAAC,CA0Bd;IAEF;;;;;;OAMG;IACH,0BAA0B,GACxB,WAAW,MAAM,KAChB,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAWvB;IAEF;;;;;;;;OAQG;IACG,WAAW,CAAC,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAwBlE;;;;;;;OAOG;IACH,gBAAgB,GACd,OAAO,MAAM,EACb,WAAW,MAAM,KAChB,OAAO,CAAC,YAAY,CAAC,CAKtB;CACH;AAED,eAAe,gBAAgB,CAAC"}
1
+ {"version":3,"file":"collateralAction.d.ts","sourceRoot":"","sources":["../../lib/actions/collateralAction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,kCAAkC,CAAC;AACzE,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAC5D,OAAO,EAAE,SAAS,EAAE,MAAM,kCAAkC,CAAC;AAE7D,OAAO,gBAAgB,MAAM,8BAA8B,CAAC;AAC5D,OAAO,EAAE,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AAExE,cAAM,gBAAiB,SAAQ,qBAAqB,CAClD,mBAAmB,EACnB,gBAAgB,CACjB;gBACa,UAAU,EAAE,UAAU,EAAE,MAAM,CAAC,EAAE,cAAc;IAI3D;;;;;;OAMG;IACH,SAAS,CAAC,YAAY,GACpB,aAAa,mBAAmB,EAAE,EAClC,OAAO,SAAS,EAChB,WAAW,MAAM,KAChB,KAAK,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,CAAC,CASpC;IAEF;;;;OAIG;IACH,SAAS,CAAC,mBAAmB,GAC3B,UAAU,gBAAgB,EAAE,KAC3B,mBAAmB,EAAE,CAEtB;CACH;AAED,eAAe,gBAAgB,CAAC"}
@@ -1,194 +1,34 @@
1
- import { difference } from 'lodash-es';
2
- import { DummyLogger } from '@rosen-bridge/abstract-logger';
3
- import { In, IsNull, } from '@rosen-bridge/extended-typeorm';
4
- import JsonBigInt from '@rosen-bridge/json-bigint';
1
+ import { AbstractErgoBoxAction } from '@rosen-bridge/abstract-extractor';
5
2
  import CollateralEntity from '../entities/collateralEntity';
6
- class CollateralAction {
7
- dataSource;
8
- logger;
9
- collateralRepository;
10
- constructor(dataSource, logger = new DummyLogger()) {
11
- this.dataSource = dataSource;
12
- this.logger = logger;
13
- this.collateralRepository = this.dataSource.getRepository(CollateralEntity);
3
+ class CollateralAction extends AbstractErgoBoxAction {
4
+ constructor(dataSource, logger) {
5
+ super(dataSource, CollateralEntity, logger);
14
6
  }
15
7
  /**
16
- * inserts a collateral into the database
17
- *
18
- * @param {ExtractedCollateral} collateral
19
- * @param {string} extractor
20
- * @memberof CollateralAction
8
+ * create the collateral entity from extracted data and block information
9
+ * @param collaterals
10
+ * @param block
11
+ * @param extractor
12
+ * @returns the collateral entities (without the id)
21
13
  */
22
- insertCollateral = async (collateral, extractor) => {
23
- return await this.collateralRepository.insert({
14
+ createEntity = (collaterals, block, extractor) => {
15
+ return collaterals.map((collateral) => ({
24
16
  ...collateral,
25
- extractor,
26
- });
27
- };
28
- /**
29
- * updates a collateral into the database
30
- *
31
- * @param {ExtractedCollateral} collateral
32
- * @param {string} extractor
33
- * @memberof CollateralAction
34
- */
35
- updateCollateral = async (collateral, extractor) => {
36
- return await this.collateralRepository.update({
37
- extractor,
38
- boxId: collateral.boxId,
39
- }, collateral);
40
- };
41
- /**
42
- * stores list of collaterals
43
- *
44
- * @param {Array<ExtractedCollateral>} collaterals
45
- * @param {Block} block
46
- * @param {string} extractor
47
- * @return {Promise<boolean>}
48
- * @memberof CollateralAction
49
- */
50
- storeCollaterals = async (collaterals, block, extractor) => {
51
- if (collaterals.length == 0) {
52
- return true;
53
- }
54
- const collateralEntities = collaterals.map((col) => ({
55
- extractor: extractor,
56
- boxId: col.boxId,
57
- boxSerialized: col.boxSerialized,
58
- wid: col.wid,
59
- rwtCount: col.rwtCount,
60
- txId: col.txId,
61
17
  block: block.hash,
62
- height: col.height != undefined ? col.height : block.height,
18
+ height: block.height,
19
+ extractor,
20
+ spendBlock: collateral.spendBlock ?? null,
21
+ spendHeight: collateral.spendHeight ?? null,
63
22
  }));
64
- const queryRunner = this.dataSource.createQueryRunner();
65
- await queryRunner.connect();
66
- await queryRunner.startTransaction();
67
- try {
68
- const repository = await queryRunner.manager.getRepository(CollateralEntity);
69
- const existingBoxIds = (await repository.find({
70
- where: {
71
- boxId: In(collateralEntities.map((box) => box.boxId)),
72
- extractor: extractor,
73
- },
74
- select: {
75
- boxId: true,
76
- },
77
- })).map((col) => col.boxId);
78
- const collateralsToUpdate = collateralEntities.filter((col) => existingBoxIds.includes(col.boxId));
79
- const collateralsToInsert = difference(collateralEntities, collateralsToUpdate);
80
- if (collateralsToUpdate.length > 0) {
81
- this.logger.info(`Inserting boxes with following IDs into the database: [${collateralsToInsert
82
- .map((col) => col.boxId)
83
- .join(', ')}]`);
84
- this.logger.debug(`Inserting collateral boxes [${JsonBigInt.stringify(collateralsToInsert)}]`);
85
- }
86
- await repository.insert(collateralsToInsert);
87
- if (collateralsToUpdate.length > 0)
88
- this.logger.info(`Updating boxes with following IDs in the database: [${collateralsToUpdate
89
- .map((col) => col.boxId)
90
- .join(', ')}]`);
91
- collateralsToUpdate.forEach(async (collateral) => {
92
- this.logger.debug(`Updating collateral box in database [${JsonBigInt.stringify(collateral)}]`);
93
- await repository.update({ boxId: collateral.boxId, extractor: extractor }, collateral);
94
- });
95
- await queryRunner.commitTransaction();
96
- }
97
- catch (e) {
98
- await queryRunner.rollbackTransaction();
99
- this.logger.error(`An error occurred during storeCollaterals action: ${e}`);
100
- return false;
101
- }
102
- finally {
103
- await queryRunner.release();
104
- }
105
- return true;
106
23
  };
107
24
  /**
108
- * Update spendBlock and spendHeight of collaterals spent in the block
109
- *
110
- * @param {Array<SpendInfo>} spendInfos
111
- * @param {Block} block
112
- * @param {string} extractor
113
- * @return {Promise<void>}
114
- * @memberof CollateralAction
115
- */
116
- spendCollaterals = async (spendInfos, block, extractor) => {
117
- for (const spendInfo of spendInfos) {
118
- const updateResult = await this.collateralRepository.update({
119
- boxId: spendInfo.boxId,
120
- extractor: extractor,
121
- }, {
122
- spendBlock: block.hash,
123
- spendHeight: block.height,
124
- spendTxId: spendInfo.txId,
125
- });
126
- if (updateResult.affected && updateResult.affected > 0) {
127
- const updatedRows = await this.collateralRepository.findBy({
128
- boxId: spendInfo.boxId,
129
- spendBlock: block.hash,
130
- });
131
- for (const row of updatedRows) {
132
- this.logger.debug(`Spent collateral with boxId [${row.boxId}] belonging to watcher with WID [${row.wid}] at height ${block.height}`);
133
- }
134
- }
135
- }
136
- };
137
- /**
138
- * Returns all stored unspent collateral box IDs
139
- *
140
- * @param {string} extractor
141
- * @return {Promise<Array<string>>}
142
- * @memberof CollateralAction
143
- */
144
- getUnspentCollateralBoxIds = async (extractor) => {
145
- const boxIds = await this.collateralRepository.find({
146
- where: {
147
- extractor: extractor,
148
- spendBlock: IsNull(),
149
- },
150
- select: {
151
- boxId: true,
152
- },
153
- });
154
- return boxIds.map((box) => box.boxId);
155
- };
156
- /**
157
- * Delete all collaterals corresponding to the passed block and extractor and
158
- * update all collaterals spent in the specified block
159
- *
160
- * @param {string} block
161
- * @param {string} extractor
162
- * @return {Promise<void>}
163
- * @memberof CollateralAction
164
- */
165
- async deleteBlock(block, extractor) {
166
- this.logger.info(`Deleting collaterals in block=[${block}] and extractor=[${extractor}]`);
167
- await this.collateralRepository.delete({
168
- block: block,
169
- extractor: extractor,
170
- });
171
- this.logger.info(`changing spent collaterals in block=[${block}] and extractor=[${extractor}] to unspent status`);
172
- await this.collateralRepository.update({ spendBlock: block, extractor: extractor }, {
173
- spendBlock: null,
174
- spendHeight: null,
175
- spendTxId: null,
176
- });
177
- }
178
- /**
179
- * deletes the specified collateral box from database
180
- *
181
- * @param {string} boxId
182
- * @param {string} extractor
183
- * @return {Promise<DeleteResult>}
184
- * @memberof CollateralAction
25
+ * convert the database entity back to raw data
26
+ * @param entities
27
+ * @returns the extracted collateral data
185
28
  */
186
- deleteCollateral = async (boxId, extractor) => {
187
- return await this.collateralRepository.delete({
188
- boxId: boxId,
189
- extractor: extractor,
190
- });
29
+ convertEntityToData = (entities) => {
30
+ return entities;
191
31
  };
192
32
  }
193
33
  export default CollateralAction;
194
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collateralAction.js","sourceRoot":"","sources":["../../lib/actions/collateralAction.ts"],"names":[],"mappings":"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","sourcesContent":["import { difference } from 'lodash-es';\n\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport {\n  DataSource,\n  DeleteResult,\n  In,\n  IsNull,\n  Repository,\n} from '@rosen-bridge/extended-typeorm';\nimport JsonBigInt from '@rosen-bridge/json-bigint';\nimport { Block } from '@rosen-bridge/scanner-interfaces';\n\nimport CollateralEntity from '../entities/collateralEntity';\nimport { ExtractedCollateral } from '../interfaces/extractedCollateral';\nimport { SpendInfo } from '../interfaces/types';\n\nclass CollateralAction {\n  private readonly collateralRepository: Repository<CollateralEntity>;\n\n  constructor(\n    private readonly dataSource: DataSource,\n    readonly logger: AbstractLogger = new DummyLogger(),\n  ) {\n    this.collateralRepository = this.dataSource.getRepository(CollateralEntity);\n  }\n\n  /**\n   * inserts a collateral into the database\n   *\n   * @param {ExtractedCollateral} collateral\n   * @param {string} extractor\n   * @memberof CollateralAction\n   */\n  insertCollateral = async (\n    collateral: ExtractedCollateral,\n    extractor: string,\n  ) => {\n    return await this.collateralRepository.insert({\n      ...collateral,\n      extractor,\n    });\n  };\n\n  /**\n   * updates a collateral into the database\n   *\n   * @param {ExtractedCollateral} collateral\n   * @param {string} extractor\n   * @memberof CollateralAction\n   */\n  updateCollateral = async (\n    collateral: Partial<ExtractedCollateral> &\n      Pick<ExtractedCollateral, 'boxId'>,\n    extractor: string,\n  ) => {\n    return await this.collateralRepository.update(\n      {\n        extractor,\n        boxId: collateral.boxId,\n      },\n      collateral,\n    );\n  };\n\n  /**\n   * stores list of collaterals\n   *\n   * @param {Array<ExtractedCollateral>} collaterals\n   * @param {Block} block\n   * @param {string} extractor\n   * @return {Promise<boolean>}\n   * @memberof CollateralAction\n   */\n  storeCollaterals = async (\n    collaterals: Array<ExtractedCollateral>,\n    block: Block,\n    extractor: string,\n  ): Promise<boolean> => {\n    if (collaterals.length == 0) {\n      return true;\n    }\n\n    const collateralEntities = collaterals.map((col) => ({\n      extractor: extractor,\n      boxId: col.boxId,\n      boxSerialized: col.boxSerialized,\n      wid: col.wid,\n      rwtCount: col.rwtCount,\n      txId: col.txId,\n      block: block.hash,\n      height: col.height != undefined ? col.height : block.height,\n    }));\n\n    const queryRunner = this.dataSource.createQueryRunner();\n    await queryRunner.connect();\n    await queryRunner.startTransaction();\n    try {\n      const repository =\n        await queryRunner.manager.getRepository(CollateralEntity);\n      const existingBoxIds = (\n        await repository.find({\n          where: {\n            boxId: In(collateralEntities.map((box) => box.boxId)),\n            extractor: extractor,\n          },\n          select: {\n            boxId: true,\n          },\n        })\n      ).map((col) => col.boxId);\n\n      const collateralsToUpdate = collateralEntities.filter((col) =>\n        existingBoxIds.includes(col.boxId),\n      );\n\n      const collateralsToInsert = difference(\n        collateralEntities,\n        collateralsToUpdate,\n      );\n\n      if (collateralsToUpdate.length > 0) {\n        this.logger.info(\n          `Inserting boxes with following IDs into the database: [${collateralsToInsert\n            .map((col) => col.boxId)\n            .join(', ')}]`,\n        );\n        this.logger.debug(\n          `Inserting collateral boxes [${JsonBigInt.stringify(\n            collateralsToInsert,\n          )}]`,\n        );\n      }\n      await repository.insert(collateralsToInsert);\n\n      if (collateralsToUpdate.length > 0)\n        this.logger.info(\n          `Updating boxes with following IDs in the database: [${collateralsToUpdate\n            .map((col) => col.boxId)\n            .join(', ')}]`,\n        );\n      collateralsToUpdate.forEach(async (collateral) => {\n        this.logger.debug(\n          `Updating collateral box in database [${JsonBigInt.stringify(\n            collateral,\n          )}]`,\n        );\n        await repository.update(\n          { boxId: collateral.boxId, extractor: extractor },\n          collateral,\n        );\n      });\n\n      await queryRunner.commitTransaction();\n    } catch (e) {\n      await queryRunner.rollbackTransaction();\n      this.logger.error(\n        `An error occurred during storeCollaterals action: ${e}`,\n      );\n      return false;\n    } finally {\n      await queryRunner.release();\n    }\n\n    return true;\n  };\n\n  /**\n   * Update spendBlock and spendHeight of collaterals spent in the block\n   *\n   * @param {Array<SpendInfo>} spendInfos\n   * @param {Block} block\n   * @param {string} extractor\n   * @return {Promise<void>}\n   * @memberof CollateralAction\n   */\n  spendCollaterals = async (\n    spendInfos: Array<SpendInfo>,\n    block: Block,\n    extractor: string,\n  ): Promise<void> => {\n    for (const spendInfo of spendInfos) {\n      const updateResult = await this.collateralRepository.update(\n        {\n          boxId: spendInfo.boxId,\n          extractor: extractor,\n        },\n        {\n          spendBlock: block.hash,\n          spendHeight: block.height,\n          spendTxId: spendInfo.txId,\n        },\n      );\n\n      if (updateResult.affected && updateResult.affected > 0) {\n        const updatedRows = await this.collateralRepository.findBy({\n          boxId: spendInfo.boxId,\n          spendBlock: block.hash,\n        });\n        for (const row of updatedRows) {\n          this.logger.debug(\n            `Spent collateral with boxId [${row.boxId}] belonging to watcher with WID [${row.wid}] at height ${block.height}`,\n          );\n        }\n      }\n    }\n  };\n\n  /**\n   * Returns all stored unspent collateral box IDs\n   *\n   * @param {string} extractor\n   * @return {Promise<Array<string>>}\n   * @memberof CollateralAction\n   */\n  getUnspentCollateralBoxIds = async (\n    extractor: string,\n  ): Promise<Array<string>> => {\n    const boxIds = await this.collateralRepository.find({\n      where: {\n        extractor: extractor,\n        spendBlock: IsNull(),\n      },\n      select: {\n        boxId: true,\n      },\n    });\n    return boxIds.map((box) => box.boxId);\n  };\n\n  /**\n   * Delete all collaterals corresponding to the passed block and extractor and\n   * update all collaterals spent in the specified block\n   *\n   * @param {string} block\n   * @param {string} extractor\n   * @return {Promise<void>}\n   * @memberof CollateralAction\n   */\n  async deleteBlock(block: string, extractor: string): Promise<void> {\n    this.logger.info(\n      `Deleting collaterals in block=[${block}] and extractor=[${extractor}]`,\n    );\n\n    await this.collateralRepository.delete({\n      block: block,\n      extractor: extractor,\n    });\n\n    this.logger.info(\n      `changing spent collaterals in block=[${block}] and extractor=[${extractor}] to unspent status`,\n    );\n\n    await this.collateralRepository.update(\n      { spendBlock: block, extractor: extractor },\n      {\n        spendBlock: null,\n        spendHeight: null,\n        spendTxId: null,\n      },\n    );\n  }\n\n  /**\n   * deletes the specified collateral box from database\n   *\n   * @param {string} boxId\n   * @param {string} extractor\n   * @return {Promise<DeleteResult>}\n   * @memberof CollateralAction\n   */\n  deleteCollateral = async (\n    boxId: string,\n    extractor: string,\n  ): Promise<DeleteResult> => {\n    return await this.collateralRepository.delete({\n      boxId: boxId,\n      extractor: extractor,\n    });\n  };\n}\n\nexport default CollateralAction;\n"]}
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sbGF0ZXJhbEFjdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9hY3Rpb25zL2NvbGxhdGVyYWxBY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFLekUsT0FBTyxnQkFBZ0IsTUFBTSw4QkFBOEIsQ0FBQztBQUc1RCxNQUFNLGdCQUFpQixTQUFRLHFCQUc5QjtJQUNDLFlBQVksVUFBc0IsRUFBRSxNQUF1QjtRQUN6RCxLQUFLLENBQUMsVUFBVSxFQUFFLGdCQUFnQixFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQzlDLENBQUM7SUFFRDs7Ozs7O09BTUc7SUFDTyxZQUFZLEdBQUcsQ0FDdkIsV0FBa0MsRUFDbEMsS0FBZ0IsRUFDaEIsU0FBaUIsRUFDb0IsRUFBRTtRQUN2QyxPQUFPLFdBQVcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxVQUFVLEVBQUUsRUFBRSxDQUFDLENBQUM7WUFDdEMsR0FBRyxVQUFVO1lBQ2IsS0FBSyxFQUFFLEtBQUssQ0FBQyxJQUFJO1lBQ2pCLE1BQU0sRUFBRSxLQUFLLENBQUMsTUFBTTtZQUNwQixTQUFTO1lBQ1QsVUFBVSxFQUFFLFVBQVUsQ0FBQyxVQUFVLElBQUksSUFBSTtZQUN6QyxXQUFXLEVBQUUsVUFBVSxDQUFDLFdBQVcsSUFBSSxJQUFJO1NBQzVDLENBQUMsQ0FBQyxDQUFDO0lBQ04sQ0FBQyxDQUFDO0lBRUY7Ozs7T0FJRztJQUNPLG1CQUFtQixHQUFHLENBQzlCLFFBQTRCLEVBQ0wsRUFBRTtRQUN6QixPQUFPLFFBQVEsQ0FBQztJQUNsQixDQUFDLENBQUM7Q0FDSDtBQUVELGVBQWUsZ0JBQWdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBYnN0cmFjdEVyZ29Cb3hBY3Rpb24gfSBmcm9tICdAcm9zZW4tYnJpZGdlL2Fic3RyYWN0LWV4dHJhY3Rvcic7XG5pbXBvcnQgeyBBYnN0cmFjdExvZ2dlciB9IGZyb20gJ0Byb3Nlbi1icmlkZ2UvYWJzdHJhY3QtbG9nZ2VyJztcbmltcG9ydCB7IERhdGFTb3VyY2UgfSBmcm9tICdAcm9zZW4tYnJpZGdlL2V4dGVuZGVkLXR5cGVvcm0nO1xuaW1wb3J0IHsgQmxvY2tJbmZvIH0gZnJvbSAnQHJvc2VuLWJyaWRnZS9zY2FubmVyLWludGVyZmFjZXMnO1xuXG5pbXBvcnQgQ29sbGF0ZXJhbEVudGl0eSBmcm9tICcuLi9lbnRpdGllcy9jb2xsYXRlcmFsRW50aXR5JztcbmltcG9ydCB7IEV4dHJhY3RlZENvbGxhdGVyYWwgfSBmcm9tICcuLi9pbnRlcmZhY2VzL2V4dHJhY3RlZENvbGxhdGVyYWwnO1xuXG5jbGFzcyBDb2xsYXRlcmFsQWN0aW9uIGV4dGVuZHMgQWJzdHJhY3RFcmdvQm94QWN0aW9uPFxuICBFeHRyYWN0ZWRDb2xsYXRlcmFsLFxuICBDb2xsYXRlcmFsRW50aXR5XG4+IHtcbiAgY29uc3RydWN0b3IoZGF0YVNvdXJjZTogRGF0YVNvdXJjZSwgbG9nZ2VyPzogQWJzdHJhY3RMb2dnZXIpIHtcbiAgICBzdXBlcihkYXRhU291cmNlLCBDb2xsYXRlcmFsRW50aXR5LCBsb2dnZXIpO1xuICB9XG5cbiAgLyoqXG4gICAqIGNyZWF0ZSB0aGUgY29sbGF0ZXJhbCBlbnRpdHkgZnJvbSBleHRyYWN0ZWQgZGF0YSBhbmQgYmxvY2sgaW5mb3JtYXRpb25cbiAgICogQHBhcmFtIGNvbGxhdGVyYWxzXG4gICAqIEBwYXJhbSBibG9ja1xuICAgKiBAcGFyYW0gZXh0cmFjdG9yXG4gICAqIEByZXR1cm5zIHRoZSBjb2xsYXRlcmFsIGVudGl0aWVzICh3aXRob3V0IHRoZSBpZClcbiAgICovXG4gIHByb3RlY3RlZCBjcmVhdGVFbnRpdHkgPSAoXG4gICAgY29sbGF0ZXJhbHM6IEV4dHJhY3RlZENvbGxhdGVyYWxbXSxcbiAgICBibG9jazogQmxvY2tJbmZvLFxuICAgIGV4dHJhY3Rvcjogc3RyaW5nLFxuICApOiBBcnJheTxPbWl0PENvbGxhdGVyYWxFbnRpdHksICdpZCc+PiA9PiB7XG4gICAgcmV0dXJuIGNvbGxhdGVyYWxzLm1hcCgoY29sbGF0ZXJhbCkgPT4gKHtcbiAgICAgIC4uLmNvbGxhdGVyYWwsXG4gICAgICBibG9jazogYmxvY2suaGFzaCxcbiAgICAgIGhlaWdodDogYmxvY2suaGVpZ2h0LFxuICAgICAgZXh0cmFjdG9yLFxuICAgICAgc3BlbmRCbG9jazogY29sbGF0ZXJhbC5zcGVuZEJsb2NrID8/IG51bGwsXG4gICAgICBzcGVuZEhlaWdodDogY29sbGF0ZXJhbC5zcGVuZEhlaWdodCA/PyBudWxsLFxuICAgIH0pKTtcbiAgfTtcblxuICAvKipcbiAgICogY29udmVydCB0aGUgZGF0YWJhc2UgZW50aXR5IGJhY2sgdG8gcmF3IGRhdGFcbiAgICogQHBhcmFtIGVudGl0aWVzXG4gICAqIEByZXR1cm5zIHRoZSBleHRyYWN0ZWQgY29sbGF0ZXJhbCBkYXRhXG4gICAqL1xuICBwcm90ZWN0ZWQgY29udmVydEVudGl0eVRvRGF0YSA9IChcbiAgICBlbnRpdGllczogQ29sbGF0ZXJhbEVudGl0eVtdLFxuICApOiBFeHRyYWN0ZWRDb2xsYXRlcmFsW10gPT4ge1xuICAgIHJldHVybiBlbnRpdGllcztcbiAgfTtcbn1cblxuZXhwb3J0IGRlZmF1bHQgQ29sbGF0ZXJhbEFjdGlvbjtcbiJdfQ==
@@ -1,6 +1,6 @@
1
1
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
2
2
  import { DataSource } from '@rosen-bridge/extended-typeorm';
3
- import { Block } from '@rosen-bridge/scanner-interfaces';
3
+ import { BlockInfo } from '@rosen-bridge/scanner-interfaces';
4
4
  import { extractedCommitment } from '../interfaces/extractedCommitment';
5
5
  import { SpendInfo } from '../interfaces/types';
6
6
  declare class CommitmentAction {
@@ -14,14 +14,14 @@ declare class CommitmentAction {
14
14
  * @param block
15
15
  * @param extractor
16
16
  */
17
- storeCommitments: (commitments: Array<extractedCommitment>, block: Block, extractor: string) => Promise<boolean>;
17
+ storeCommitments: (commitments: Array<extractedCommitment>, block: BlockInfo, extractor: string) => Promise<boolean>;
18
18
  /**
19
19
  * Update spendBlock and spendHeight of commitments spent on the block
20
20
  * @param spendId
21
21
  * @param block
22
22
  * @param extractor
23
23
  */
24
- spendCommitments: (spendId: Array<SpendInfo>, block: Block, extractor: string) => Promise<void>;
24
+ spendCommitments: (spendId: Array<SpendInfo>, block: BlockInfo, extractor: string) => Promise<void>;
25
25
  /**
26
26
  * Delete all commitments corresponding to the block(id) and extractor(id)
27
27
  * and update all commitments spent on the specified block
@@ -1 +1 @@
1
- {"version":3,"file":"commitmentAction.d.ts","sourceRoot":"","sources":["../../lib/actions/commitmentAction.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,UAAU,EAAkB,MAAM,gCAAgC,CAAC;AAC5E,OAAO,EAAE,KAAK,EAAE,MAAM,kCAAkC,CAAC;AAIzD,OAAO,EAAE,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AACxE,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAEhD,cAAM,gBAAgB;IACpB,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC;IAChC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;IACxC,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAA+B;gBAExD,UAAU,EAAE,UAAU,EAAE,MAAM,CAAC,EAAE,cAAc;IAM3D;;;;;OAKG;IACH,gBAAgB,GACd,aAAa,KAAK,CAAC,mBAAmB,CAAC,EACvC,OAAO,KAAK,EACZ,WAAW,MAAM,KAChB,OAAO,CAAC,OAAO,CAAC,CAsDjB;IAEF;;;;;OAKG;IACH,gBAAgB,GACd,SAAS,KAAK,CAAC,SAAS,CAAC,EACzB,OAAO,KAAK,EACZ,WAAW,MAAM,KAChB,OAAO,CAAC,IAAI,CAAC,CAmCd;IAEF;;;;;OAKG;IACH,WAAW,GAAU,OAAO,MAAM,EAAE,WAAW,MAAM,mBAiBnD;CACH;AAED,eAAe,gBAAgB,CAAC"}
1
+ {"version":3,"file":"commitmentAction.d.ts","sourceRoot":"","sources":["../../lib/actions/commitmentAction.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,UAAU,EAAkB,MAAM,gCAAgC,CAAC;AAC5E,OAAO,EAAE,SAAS,EAAE,MAAM,kCAAkC,CAAC;AAI7D,OAAO,EAAE,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AACxE,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAEhD,cAAM,gBAAgB;IACpB,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC;IAChC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;IACxC,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAA+B;gBAExD,UAAU,EAAE,UAAU,EAAE,MAAM,CAAC,EAAE,cAAc;IAM3D;;;;;OAKG;IACH,gBAAgB,GACd,aAAa,KAAK,CAAC,mBAAmB,CAAC,EACvC,OAAO,SAAS,EAChB,WAAW,MAAM,KAChB,OAAO,CAAC,OAAO,CAAC,CAsDjB;IAEF;;;;;OAKG;IACH,gBAAgB,GACd,SAAS,KAAK,CAAC,SAAS,CAAC,EACzB,OAAO,SAAS,EAChB,WAAW,MAAM,KAChB,OAAO,CAAC,IAAI,CAAC,CAmCd;IAEF;;;;;OAKG;IACH,WAAW,GAAU,OAAO,MAAM,EAAE,WAAW,MAAM,mBAiBnD;CACH;AAED,eAAe,gBAAgB,CAAC"}
@@ -87,7 +87,7 @@ class CommitmentAction {
87
87
  for (const commitment of commitments) {
88
88
  const spendInfo = spendIdChunk.find((info) => info.boxId === commitment.boxId);
89
89
  if (!spendInfo)
90
- throw new Error(`Impossible behavior: box [${commitment.boxId}] is not found in spending info list`);
90
+ throw new Error(`ImpossibleBehavior: box [${commitment.boxId}] is not found in spending info list`);
91
91
  await this.commitmentRepository.update({
92
92
  id: commitment.id,
93
93
  }, {
@@ -122,4 +122,4 @@ class CommitmentAction {
122
122
  };
123
123
  }
124
124
  export default CommitmentAction;
125
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"commitmentAction.js","sourceRoot":"","sources":["../../lib/actions/commitmentAction.ts"],"names":[],"mappings":"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","sourcesContent":["import { chunk } from 'lodash-es';\n\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport { DataSource, In, Repository } from '@rosen-bridge/extended-typeorm';\nimport { Block } from '@rosen-bridge/scanner-interfaces';\n\nimport { dbIdChunkSize } from '../constants';\nimport CommitmentEntity from '../entities/commitmentEntity';\nimport { extractedCommitment } from '../interfaces/extractedCommitment';\nimport { SpendInfo } from '../interfaces/types';\n\nclass CommitmentAction {\n  readonly logger: AbstractLogger;\n  private readonly datasource: DataSource;\n  private readonly commitmentRepository: Repository<CommitmentEntity>;\n\n  constructor(dataSource: DataSource, logger?: AbstractLogger) {\n    this.datasource = dataSource;\n    this.logger = logger ? logger : new DummyLogger();\n    this.commitmentRepository = dataSource.getRepository(CommitmentEntity);\n  }\n\n  /**\n   * It stores list of observations in the dataSource with block id\n   * @param commitments\n   * @param block\n   * @param extractor\n   */\n  storeCommitments = async (\n    commitments: Array<extractedCommitment>,\n    block: Block,\n    extractor: string,\n  ): Promise<boolean> => {\n    if (commitments.length === 0) return true;\n    const boxIds = commitments.map((commitment) => commitment.boxId);\n    const savedCommitments = await this.commitmentRepository.findBy({\n      boxId: In(boxIds),\n      extractor: extractor,\n    });\n    let success = true;\n    const queryRunner = this.datasource.createQueryRunner();\n    await queryRunner.connect();\n    await queryRunner.startTransaction();\n    const repository =\n      await queryRunner.manager.getRepository(CommitmentEntity);\n    try {\n      for (const commitment of commitments) {\n        const saved = savedCommitments.some((entity) => {\n          return entity.boxId === commitment.boxId;\n        });\n        const entity = {\n          txId: commitment.txId,\n          commitment: commitment.commitment,\n          eventId: commitment.eventId,\n          boxId: commitment.boxId,\n          WID: commitment.WID,\n          extractor: extractor,\n          block: block.hash,\n          height: block.height,\n          boxSerialized: commitment.boxSerialized,\n          rwtCount: commitment.rwtCount,\n        };\n        if (!saved) {\n          this.logger.info(\n            `Saving commitment [${commitment.boxId}] for event [${commitment.eventId}] from watcher [${commitment.WID}] at height ${block.height} and extractor ${extractor}`,\n          );\n          await repository.insert(entity);\n        } else {\n          this.logger.info(\n            `Updating commitment [${commitment.boxId}] for event [${commitment.eventId}] from watcher [${commitment.WID}] at height ${block.height} and extractor ${extractor}`,\n          );\n          await repository.update({ boxId: commitment.boxId }, entity);\n        }\n        this.logger.debug(`Entity: ${JSON.stringify(entity)}`);\n      }\n      await queryRunner.commitTransaction();\n    } catch (e) {\n      this.logger.error(\n        `An error occurred during store commitments action: ${e}`,\n      );\n      await queryRunner.rollbackTransaction();\n      success = false;\n    } finally {\n      await queryRunner.release();\n    }\n    return success;\n  };\n\n  /**\n   * Update spendBlock and spendHeight of commitments spent on the block\n   * @param spendId\n   * @param block\n   * @param extractor\n   */\n  spendCommitments = async (\n    spendId: Array<SpendInfo>,\n    block: Block,\n    extractor: string,\n  ): Promise<void> => {\n    // TODO: improve updating (local:ergo/rosen-bridge/scanner#85)\n    const spendIdChunks = chunk(spendId, dbIdChunkSize);\n    for (const spendIdChunk of spendIdChunks) {\n      const commitments = await this.commitmentRepository.findBy({\n        boxId: In(spendIdChunk.map((info) => info.boxId)),\n        extractor: extractor,\n      });\n\n      for (const commitment of commitments) {\n        const spendInfo = spendIdChunk.find(\n          (info) => info.boxId === commitment.boxId,\n        );\n        if (!spendInfo)\n          throw new Error(\n            `Impossible behavior: box [${commitment.boxId}] is not found in spending info list`,\n          );\n\n        await this.commitmentRepository.update(\n          {\n            id: commitment.id,\n          },\n          {\n            spendBlock: block.hash,\n            spendHeight: block.height,\n            spendTxId: spendInfo.txId,\n            spendIndex: spendInfo.index,\n          },\n        );\n        this.logger.info(\n          `Spent commitment [${commitment.boxId}] for event [${commitment.eventId}] at height ${block.height}`,\n        );\n        this.logger.debug(`Spent commitment [${JSON.stringify(commitment)}]`);\n      }\n    }\n  };\n\n  /**\n   * Delete all commitments corresponding to the block(id) and extractor(id)\n   * and update all commitments spent on the specified block\n   * @param block\n   * @param extractor\n   */\n  deleteBlock = async (block: string, extractor: string) => {\n    this.logger.info(\n      `Deleting commitments of block [${block}] and extractor ${extractor}`,\n    );\n    await this.commitmentRepository.delete({\n      block: block,\n      extractor: extractor,\n    });\n    await this.commitmentRepository.update(\n      { spendBlock: block, extractor: extractor },\n      {\n        spendBlock: null,\n        spendHeight: null,\n        spendTxId: null,\n        spendIndex: null,\n      },\n    );\n  };\n}\n\nexport default CommitmentAction;\n"]}
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"commitmentAction.js","sourceRoot":"","sources":["../../lib/actions/commitmentAction.ts"],"names":[],"mappings":"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","sourcesContent":["import { chunk } from 'lodash-es';\n\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport { DataSource, In, Repository } from '@rosen-bridge/extended-typeorm';\nimport { BlockInfo } from '@rosen-bridge/scanner-interfaces';\n\nimport { dbIdChunkSize } from '../constants';\nimport CommitmentEntity from '../entities/commitmentEntity';\nimport { extractedCommitment } from '../interfaces/extractedCommitment';\nimport { SpendInfo } from '../interfaces/types';\n\nclass CommitmentAction {\n  readonly logger: AbstractLogger;\n  private readonly datasource: DataSource;\n  private readonly commitmentRepository: Repository<CommitmentEntity>;\n\n  constructor(dataSource: DataSource, logger?: AbstractLogger) {\n    this.datasource = dataSource;\n    this.logger = logger ? logger : new DummyLogger();\n    this.commitmentRepository = dataSource.getRepository(CommitmentEntity);\n  }\n\n  /**\n   * It stores list of observations in the dataSource with block id\n   * @param commitments\n   * @param block\n   * @param extractor\n   */\n  storeCommitments = async (\n    commitments: Array<extractedCommitment>,\n    block: BlockInfo,\n    extractor: string,\n  ): Promise<boolean> => {\n    if (commitments.length === 0) return true;\n    const boxIds = commitments.map((commitment) => commitment.boxId);\n    const savedCommitments = await this.commitmentRepository.findBy({\n      boxId: In(boxIds),\n      extractor: extractor,\n    });\n    let success = true;\n    const queryRunner = this.datasource.createQueryRunner();\n    await queryRunner.connect();\n    await queryRunner.startTransaction();\n    const repository =\n      await queryRunner.manager.getRepository(CommitmentEntity);\n    try {\n      for (const commitment of commitments) {\n        const saved = savedCommitments.some((entity) => {\n          return entity.boxId === commitment.boxId;\n        });\n        const entity = {\n          txId: commitment.txId,\n          commitment: commitment.commitment,\n          eventId: commitment.eventId,\n          boxId: commitment.boxId,\n          WID: commitment.WID,\n          extractor: extractor,\n          block: block.hash,\n          height: block.height,\n          boxSerialized: commitment.boxSerialized,\n          rwtCount: commitment.rwtCount,\n        };\n        if (!saved) {\n          this.logger.info(\n            `Saving commitment [${commitment.boxId}] for event [${commitment.eventId}] from watcher [${commitment.WID}] at height ${block.height} and extractor ${extractor}`,\n          );\n          await repository.insert(entity);\n        } else {\n          this.logger.info(\n            `Updating commitment [${commitment.boxId}] for event [${commitment.eventId}] from watcher [${commitment.WID}] at height ${block.height} and extractor ${extractor}`,\n          );\n          await repository.update({ boxId: commitment.boxId }, entity);\n        }\n        this.logger.debug(`Entity: ${JSON.stringify(entity)}`);\n      }\n      await queryRunner.commitTransaction();\n    } catch (e) {\n      this.logger.error(\n        `An error occurred during store commitments action: ${e}`,\n      );\n      await queryRunner.rollbackTransaction();\n      success = false;\n    } finally {\n      await queryRunner.release();\n    }\n    return success;\n  };\n\n  /**\n   * Update spendBlock and spendHeight of commitments spent on the block\n   * @param spendId\n   * @param block\n   * @param extractor\n   */\n  spendCommitments = async (\n    spendId: Array<SpendInfo>,\n    block: BlockInfo,\n    extractor: string,\n  ): Promise<void> => {\n    // TODO: improve updating (local:ergo/rosen-bridge/scanner#85)\n    const spendIdChunks = chunk(spendId, dbIdChunkSize);\n    for (const spendIdChunk of spendIdChunks) {\n      const commitments = await this.commitmentRepository.findBy({\n        boxId: In(spendIdChunk.map((info) => info.boxId)),\n        extractor: extractor,\n      });\n\n      for (const commitment of commitments) {\n        const spendInfo = spendIdChunk.find(\n          (info) => info.boxId === commitment.boxId,\n        );\n        if (!spendInfo)\n          throw new Error(\n            `ImpossibleBehavior: box [${commitment.boxId}] is not found in spending info list`,\n          );\n\n        await this.commitmentRepository.update(\n          {\n            id: commitment.id,\n          },\n          {\n            spendBlock: block.hash,\n            spendHeight: block.height,\n            spendTxId: spendInfo.txId,\n            spendIndex: spendInfo.index,\n          },\n        );\n        this.logger.info(\n          `Spent commitment [${commitment.boxId}] for event [${commitment.eventId}] at height ${block.height}`,\n        );\n        this.logger.debug(`Spent commitment [${JSON.stringify(commitment)}]`);\n      }\n    }\n  };\n\n  /**\n   * Delete all commitments corresponding to the block(id) and extractor(id)\n   * and update all commitments spent on the specified block\n   * @param block\n   * @param extractor\n   */\n  deleteBlock = async (block: string, extractor: string) => {\n    this.logger.info(\n      `Deleting commitments of block [${block}] and extractor ${extractor}`,\n    );\n    await this.commitmentRepository.delete({\n      block: block,\n      extractor: extractor,\n    });\n    await this.commitmentRepository.update(\n      { spendBlock: block, extractor: extractor },\n      {\n        spendBlock: null,\n        spendHeight: null,\n        spendTxId: null,\n        spendIndex: null,\n      },\n    );\n  };\n}\n\nexport default CommitmentAction;\n"]}
@@ -1,11 +1,10 @@
1
- import { AbstractInitializableErgoExtractorAction, BoxInfo, SpendInfo } from '@rosen-bridge/abstract-extractor';
1
+ import { AbstractErgoBoxAction, EntityInfo, SpendInfo } from '@rosen-bridge/abstract-extractor';
2
2
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
3
3
  import { DataSource } from '@rosen-bridge/extended-typeorm';
4
4
  import { BlockInfo } from '@rosen-bridge/scanner-interfaces';
5
5
  import EventTriggerEntity from '../entities/eventTriggerEntity';
6
6
  import { ExtractedEventTrigger } from '../interfaces/extractedEventTrigger';
7
- declare class EventTriggerAction extends AbstractInitializableErgoExtractorAction<ExtractedEventTrigger, EventTriggerEntity> {
8
- private readonly dataSource;
7
+ declare class EventTriggerAction extends AbstractErgoBoxAction<ExtractedEventTrigger, EventTriggerEntity> {
9
8
  constructor(dataSource: DataSource, logger?: AbstractLogger);
10
9
  /**
11
10
  * create the box entity from extracted data and block information
@@ -24,7 +23,7 @@ declare class EventTriggerAction extends AbstractInitializableErgoExtractorActio
24
23
  * @param extractorId
25
24
  * @returns spent box ids
26
25
  */
27
- spendBoxes: (spendInfoArray: Array<SpendInfo>, block: BlockInfo, extractorId: string) => Promise<BoxInfo[]>;
26
+ spendBoxes: (spendInfoArray: Array<SpendInfo>, block: BlockInfo, extractorId: string) => Promise<EntityInfo[]>;
28
27
  }
29
28
  export default EventTriggerAction;
30
29
  //# sourceMappingURL=eventTriggerAction.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"eventTriggerAction.d.ts","sourceRoot":"","sources":["../../lib/actions/eventTriggerAction.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,wCAAwC,EACxC,OAAO,EAEP,SAAS,EACV,MAAM,kCAAkC,CAAC;AAC1C,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EAAE,UAAU,EAAM,MAAM,gCAAgC,CAAC;AAChE,OAAO,EAAE,SAAS,EAAE,MAAM,kCAAkC,CAAC;AAE7D,OAAO,kBAAkB,MAAM,gCAAgC,CAAC;AAChE,OAAO,EAAE,qBAAqB,EAAE,MAAM,qCAAqC,CAAC;AAG5E,cAAM,kBAAmB,SAAQ,wCAAwC,CACvE,qBAAqB,EACrB,kBAAkB,CACnB;IACC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;gBAE5B,UAAU,EAAE,UAAU,EAAE,MAAM,CAAC,EAAE,cAAc;IAK3D;;OAEG;IACH,YAAY,GACV,cAAc,qBAAqB,EAAE,EACrC,OAAO,SAAS,EAChB,WAAW,MAAM,KAChB,IAAI,CAAC,kBAAkB,EAAE,IAAI,CAAC,EAAE,CAwBjC;IAEF;;OAEG;IACH,mBAAmB,GACjB,UAAU,kBAAkB,EAAE,KAC7B,qBAAqB,EAAE,CAuBxB;IAEF;;;;;;;;OAQG;IACH,UAAU,GACR,gBAAgB,KAAK,CAAC,SAAS,CAAC,EAChC,OAAO,SAAS,EAChB,aAAa,MAAM,KAClB,OAAO,CAAC,OAAO,EAAE,CAAC,CAyCnB;CACH;AAED,eAAe,kBAAkB,CAAC"}
1
+ {"version":3,"file":"eventTriggerAction.d.ts","sourceRoot":"","sources":["../../lib/actions/eventTriggerAction.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,qBAAqB,EAErB,UAAU,EACV,SAAS,EACV,MAAM,kCAAkC,CAAC;AAC1C,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EAAE,UAAU,EAAM,MAAM,gCAAgC,CAAC;AAChE,OAAO,EAAE,SAAS,EAAE,MAAM,kCAAkC,CAAC;AAE7D,OAAO,kBAAkB,MAAM,gCAAgC,CAAC;AAChE,OAAO,EAAE,qBAAqB,EAAE,MAAM,qCAAqC,CAAC;AAG5E,cAAM,kBAAmB,SAAQ,qBAAqB,CACpD,qBAAqB,EACrB,kBAAkB,CACnB;gBACa,UAAU,EAAE,UAAU,EAAE,MAAM,CAAC,EAAE,cAAc;IAI3D;;OAEG;IACH,YAAY,GACV,cAAc,qBAAqB,EAAE,EACrC,OAAO,SAAS,EAChB,WAAW,MAAM,KAChB,IAAI,CAAC,kBAAkB,EAAE,IAAI,CAAC,EAAE,CAwBjC;IAEF;;OAEG;IACH,mBAAmB,GACjB,UAAU,kBAAkB,EAAE,KAC7B,qBAAqB,EAAE,CAuBxB;IAEF;;;;;;;;OAQG;IACH,UAAU,GACR,gBAAgB,KAAK,CAAC,SAAS,CAAC,EAChC,OAAO,SAAS,EAChB,aAAa,MAAM,KAClB,OAAO,CAAC,UAAU,EAAE,CAAC,CAyCtB;CACH;AAED,eAAe,kBAAkB,CAAC"}