@rosen-bridge/fraud-extractor 3.0.0-8f3c7016 → 3.0.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/CHANGELOG.md CHANGED
@@ -1,18 +1,21 @@
1
1
  # @rosen-bridge/fraud-extractor
2
2
 
3
- ## 3.0.0-8f3c7016
3
+ ## 3.0.0
4
4
 
5
5
  ### Major Changes
6
6
 
7
+ - Refactor fraud extractor to extend AbstractErgoBoxExtractor
7
8
  - Update AbstractExtractor interface; use `BlockInfo` in `processTransactions` and rename `initializeBoxes` to `initializeData`
8
9
 
10
+ ### Minor Changes
11
+
12
+ - Update AbstractExtractor interface; add `createUsedBlocksQuery` method that returns the query for used blocks
13
+
9
14
  ### Patch Changes
10
15
 
11
16
  - Update dependencies
12
- - Update dependencies
13
- - Update dependencies
14
- - Update dependencies
15
- - @rosen-bridge/abstract-extractor@3.0.0-8f3c7016
17
+ - @rosen-bridge/abstract-logger@4.0.0
18
+ - @rosen-bridge/abstract-extractor@3.0.0
16
19
 
17
20
  ## 2.2.3
18
21
 
@@ -1,64 +1,24 @@
1
+ import { AbstractErgoBoxAction } from '@rosen-bridge/abstract-extractor';
1
2
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
2
3
  import { DataSource } from '@rosen-bridge/extended-typeorm';
3
4
  import { BlockInfo } from '@rosen-bridge/scanner-interfaces';
5
+ import { FraudEntity } from '../entities/fraudEntity';
4
6
  import { ExtractedFraud } from '../interfaces/types';
5
- export declare class FraudAction {
6
- private readonly datasource;
7
- private readonly logger;
8
- private readonly repository;
7
+ export declare class FraudAction extends AbstractErgoBoxAction<ExtractedFraud, FraudEntity> {
9
8
  constructor(dataSource: DataSource, logger?: AbstractLogger);
10
9
  /**
11
- * Store a list of frauds in a specific block
10
+ * create the fraud entity from extracted data and block information
12
11
  * @param frauds
13
- * @param spendBoxes
14
12
  * @param block
15
13
  * @param extractor
14
+ * @returns the fraud entities (without the id)
16
15
  */
17
- storeBlockFrauds: (frauds: Array<ExtractedFraud>, block: BlockInfo, extractor: string) => Promise<boolean>;
16
+ protected createEntity: (frauds: ExtractedFraud[], block: BlockInfo, extractor: string) => Array<Omit<FraudEntity, "id">>;
18
17
  /**
19
- * Insert a new fraud into database
20
- * @param fraud
21
- * @param extractor
22
- */
23
- insertFraud: (fraud: ExtractedFraud, extractor: string) => Promise<import("@rosen-bridge/extended-typeorm").InsertResult>;
24
- /**
25
- * Update an unspent fraud information in the database
26
- * @param fraud
27
- * @param extractor
28
- */
29
- updateFraud: (fraud: ExtractedFraud, extractor: string) => Promise<import("@rosen-bridge/extended-typeorm").UpdateResult>;
30
- /**
31
- * Update spendBlock and spendHeight of frauds spent on the block
32
- * @param spendIds
33
- * @param block
34
- * @param extractor
35
- */
36
- spendFrauds: (spendIds: Array<string>, block: BlockInfo, extractor: string, txId: string) => Promise<void>;
37
- /**
38
- * Update all frauds related to an specific invalid block
39
- * if box had been spent in the block mark it as unspent,
40
- * and if it was created within the block remove it from database
41
- * @param block
42
- * @param extractor
43
- */
44
- deleteBlock: (block: string, extractor: string) => Promise<void>;
45
- /**
46
- * Return all stored fraud box ids
47
- */
48
- getAllBoxIds: (extractor: string) => Promise<Array<string>>;
49
- /**
50
- * Remove an specified fraud
51
- * @param boxId
52
- * @param extractor
53
- */
54
- removeFraud: (boxId: string, extractor: string) => Promise<import("@rosen-bridge/extended-typeorm").DeleteResult>;
55
- /**
56
- * Update the fraud spending information
57
- * @param boxId
58
- * @param extractor
59
- * @param blockId
60
- * @param blockHeight
18
+ * convert the database entity back to raw data
19
+ * @param entities
20
+ * @returns the extracted fraud data
61
21
  */
62
- updateSpendBlock: (boxId: string, extractor: string, blockId: string, blockHeight: number) => Promise<import("@rosen-bridge/extended-typeorm").UpdateResult>;
22
+ protected convertEntityToData: (entities: FraudEntity[]) => ExtractedFraud[];
63
23
  }
64
24
  //# sourceMappingURL=fraudAction.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"fraudAction.d.ts","sourceRoot":"","sources":["../../lib/actions/fraudAction.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,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAErD,qBAAa,WAAW;IACtB,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;IACxC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAiB;IACxC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAA0B;gBAEzC,UAAU,EAAE,UAAU,EAAE,MAAM,CAAC,EAAE,cAAc;IAK3D;;;;;;OAMG;IACH,gBAAgB,GACd,QAAQ,KAAK,CAAC,cAAc,CAAC,EAC7B,OAAO,SAAS,EAChB,WAAW,MAAM,sBAgDjB;IAEF;;;;OAIG;IACH,WAAW,GAAU,OAAO,cAAc,EAAE,WAAW,MAAM,oEAY3D;IAEF;;;;OAIG;IACH,WAAW,GAAU,OAAO,cAAc,EAAE,WAAW,MAAM,oEAe3D;IAEF;;;;;OAKG;IACH,WAAW,GACT,UAAU,KAAK,CAAC,MAAM,CAAC,EACvB,OAAO,SAAS,EAChB,WAAW,MAAM,EACjB,MAAM,MAAM,KACX,OAAO,CAAC,IAAI,CAAC,CAqBd;IAEF;;;;;;OAMG;IACH,WAAW,GAAU,OAAO,MAAM,EAAE,WAAW,MAAM,KAAG,OAAO,CAAC,IAAI,CAAC,CAgCnE;IAEF;;OAEG;IACH,YAAY,GAAU,WAAW,MAAM,KAAG,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAU9D;IAEF;;;;OAIG;IACH,WAAW,GAAU,OAAO,MAAM,EAAE,WAAW,MAAM,oEAEnD;IAEF;;;;;;OAMG;IACH,gBAAgB,GACd,OAAO,MAAM,EACb,WAAW,MAAM,EACjB,SAAS,MAAM,EACf,aAAa,MAAM,oEAMnB;CACH"}
1
+ {"version":3,"file":"fraudAction.d.ts","sourceRoot":"","sources":["../../lib/actions/fraudAction.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,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAErD,qBAAa,WAAY,SAAQ,qBAAqB,CACpD,cAAc,EACd,WAAW,CACZ;gBACa,UAAU,EAAE,UAAU,EAAE,MAAM,CAAC,EAAE,cAAc;IAI3D;;;;;;OAMG;IACH,SAAS,CAAC,YAAY,GACpB,QAAQ,cAAc,EAAE,EACxB,OAAO,SAAS,EAChB,WAAW,MAAM,KAChB,KAAK,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC,CAU/B;IAEF;;;;OAIG;IACH,SAAS,CAAC,mBAAmB,GAC3B,UAAU,WAAW,EAAE,KACtB,cAAc,EAAE,CAEjB;CACH"}
@@ -1,197 +1,34 @@
1
- import { chunk } from 'lodash-es';
2
- import { DummyLogger } from '@rosen-bridge/abstract-logger';
3
- import { In } from '@rosen-bridge/extended-typeorm';
4
- import { dbIdChunkSize } from '../constants';
1
+ import { AbstractErgoBoxAction } from '@rosen-bridge/abstract-extractor';
5
2
  import { FraudEntity } from '../entities/fraudEntity';
6
- export class FraudAction {
7
- datasource;
8
- logger;
9
- repository;
3
+ export class FraudAction extends AbstractErgoBoxAction {
10
4
  constructor(dataSource, logger) {
11
- this.datasource = dataSource;
12
- this.logger = logger ? logger : new DummyLogger();
13
- this.repository = dataSource.getRepository(FraudEntity);
5
+ super(dataSource, FraudEntity, logger);
14
6
  }
15
7
  /**
16
- * Store a list of frauds in a specific block
8
+ * create the fraud entity from extracted data and block information
17
9
  * @param frauds
18
- * @param spendBoxes
19
10
  * @param block
20
11
  * @param extractor
12
+ * @returns the fraud entities (without the id)
21
13
  */
22
- storeBlockFrauds = async (frauds, block, extractor) => {
23
- const boxIds = frauds.map((item) => item.boxId);
24
- const dbBoxes = await this.repository.findBy({
25
- boxId: In(boxIds),
26
- extractor: extractor,
27
- });
28
- let success = true;
29
- const queryRunner = this.datasource.createQueryRunner();
30
- await queryRunner.connect();
31
- await queryRunner.startTransaction();
32
- const repository = await queryRunner.manager.getRepository(FraudEntity);
33
- try {
34
- for (const fraud of frauds) {
35
- const entity = {
36
- triggerBoxId: fraud.triggerBoxId,
37
- boxId: fraud.boxId,
38
- wid: fraud.wid,
39
- rwtCount: fraud.rwtCount,
40
- creationBlock: block.hash,
41
- creationHeight: block.height,
42
- creationTxId: fraud.txId,
43
- serialized: fraud.serialized,
44
- extractor: extractor,
45
- spendBlock: undefined,
46
- spendHeight: undefined,
47
- spendTxId: undefined,
48
- };
49
- const dbBox = dbBoxes.filter((item) => item.boxId === fraud.boxId);
50
- if (dbBox.length > 0) {
51
- this.logger.info(`Updating fraud with boxId [${fraud.boxId}]`);
52
- this.logger.debug(`Updated fraud: [${JSON.stringify(entity)}]`);
53
- await repository.update({ id: dbBox[0].id }, entity);
54
- }
55
- else {
56
- this.logger.info(`Storing fraud with boxId: [${fraud.boxId}]`);
57
- this.logger.debug(`Inserted fraud: [${JSON.stringify(entity)}]`);
58
- await repository.insert(entity);
59
- }
60
- }
61
- await queryRunner.commitTransaction();
62
- }
63
- catch (e) {
64
- this.logger.error(`An error occurred during storing fraud boxes: ${e}`);
65
- await queryRunner.rollbackTransaction();
66
- success = false;
67
- }
68
- finally {
69
- await queryRunner.release();
70
- }
71
- return success;
14
+ createEntity = (frauds, block, extractor) => {
15
+ return frauds.map((fraud) => ({
16
+ ...fraud,
17
+ block: block.hash,
18
+ height: block.height,
19
+ extractor,
20
+ spendBlock: fraud.spendBlock ?? null,
21
+ spendHeight: fraud.spendHeight ?? null,
22
+ spendTxId: fraud.spendTxId ?? null,
23
+ }));
72
24
  };
73
25
  /**
74
- * Insert a new fraud into database
75
- * @param fraud
76
- * @param extractor
77
- */
78
- insertFraud = async (fraud, extractor) => {
79
- return this.repository.insert({
80
- boxId: fraud.boxId,
81
- triggerBoxId: fraud.triggerBoxId,
82
- wid: fraud.wid,
83
- rwtCount: fraud.rwtCount,
84
- creationBlock: fraud.blockId,
85
- creationHeight: fraud.height,
86
- creationTxId: fraud.txId,
87
- serialized: fraud.serialized,
88
- extractor: extractor,
89
- });
90
- };
91
- /**
92
- * Update an unspent fraud information in the database
93
- * @param fraud
94
- * @param extractor
95
- */
96
- updateFraud = async (fraud, extractor) => {
97
- return this.repository.update({ boxId: fraud.boxId, extractor: extractor }, {
98
- triggerBoxId: fraud.triggerBoxId,
99
- creationBlock: fraud.blockId,
100
- creationHeight: fraud.height,
101
- creationTxId: fraud.txId,
102
- serialized: fraud.serialized,
103
- wid: fraud.wid,
104
- rwtCount: fraud.rwtCount,
105
- spendBlock: null,
106
- spendHeight: 0,
107
- });
108
- };
109
- /**
110
- * Update spendBlock and spendHeight of frauds spent on the block
111
- * @param spendIds
112
- * @param block
113
- * @param extractor
114
- */
115
- spendFrauds = async (spendIds, block, extractor, txId) => {
116
- const spendIdChunks = chunk(spendIds, dbIdChunkSize);
117
- for (const spendIdChunk of spendIdChunks) {
118
- const updateResult = await this.repository.update({ boxId: In(spendIdChunk), extractor: extractor }, { spendBlock: block.hash, spendHeight: block.height, spendTxId: txId });
119
- if (updateResult.affected && updateResult.affected > 0) {
120
- const spentRows = await this.repository.findBy({
121
- boxId: In(spendIdChunk),
122
- spendBlock: block.hash,
123
- spendTxId: txId,
124
- });
125
- for (const row of spentRows) {
126
- this.logger.debug(`Spent box with boxId [${row.boxId}] at transaction [${txId}] at height ${block.height}`);
127
- }
128
- }
129
- }
130
- };
131
- /**
132
- * Update all frauds related to an specific invalid block
133
- * if box had been spent in the block mark it as unspent,
134
- * and if it was created within the block remove it from database
135
- * @param block
136
- * @param extractor
137
- */
138
- deleteBlock = async (block, extractor) => {
139
- this.logger.info(`Deleting frauds in block [${block}]`);
140
- const invalidRows = await this.repository.findBy({
141
- extractor: extractor,
142
- creationBlock: block,
143
- });
144
- if (invalidRows.length > 0) {
145
- await this.repository.delete({
146
- extractor: extractor,
147
- creationBlock: block,
148
- });
149
- for (const row of invalidRows) {
150
- this.logger.debug(`deleted invalid fraud with boxId [${row.boxId}] at the forked block [${block}]`);
151
- }
152
- }
153
- const updatingRows = await this.repository.findBy({
154
- extractor: extractor,
155
- spendBlock: block,
156
- });
157
- if (updatingRows.length > 0) {
158
- await this.repository.update({ spendBlock: block, extractor: extractor }, { spendBlock: null, spendHeight: 0, spendTxId: null });
159
- for (const row of updatingRows) {
160
- this.logger.debug(`removed spending information of the fraud with boxId [${row.boxId}], spent at the forked block [${block}]`);
161
- }
162
- }
163
- };
164
- /**
165
- * Return all stored fraud box ids
166
- */
167
- getAllBoxIds = async (extractor) => {
168
- const boxIds = await this.repository.find({
169
- select: {
170
- boxId: true,
171
- },
172
- where: {
173
- extractor: extractor,
174
- },
175
- });
176
- return boxIds.map((item) => item.boxId);
177
- };
178
- /**
179
- * Remove an specified fraud
180
- * @param boxId
181
- * @param extractor
182
- */
183
- removeFraud = async (boxId, extractor) => {
184
- return await this.repository.delete({ boxId: boxId, extractor: extractor });
185
- };
186
- /**
187
- * Update the fraud spending information
188
- * @param boxId
189
- * @param extractor
190
- * @param blockId
191
- * @param blockHeight
26
+ * convert the database entity back to raw data
27
+ * @param entities
28
+ * @returns the extracted fraud data
192
29
  */
193
- updateSpendBlock = async (boxId, extractor, blockId, blockHeight) => {
194
- return await this.repository.update({ boxId: boxId, extractor: extractor }, { spendBlock: blockId, spendHeight: blockHeight });
30
+ convertEntityToData = (entities) => {
31
+ return entities;
195
32
  };
196
33
  }
197
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fraudAction.js","sourceRoot":"","sources":["../../lib/actions/fraudAction.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 { FraudEntity } from '../entities/fraudEntity';\nimport { ExtractedFraud } from '../interfaces/types';\n\nexport class FraudAction {\n  private readonly datasource: DataSource;\n  private readonly logger: AbstractLogger;\n  private readonly repository: Repository<FraudEntity>;\n\n  constructor(dataSource: DataSource, logger?: AbstractLogger) {\n    this.datasource = dataSource;\n    this.logger = logger ? logger : new DummyLogger();\n    this.repository = dataSource.getRepository(FraudEntity);\n  }\n  /**\n   * Store a list of frauds in a specific block\n   * @param frauds\n   * @param spendBoxes\n   * @param block\n   * @param extractor\n   */\n  storeBlockFrauds = async (\n    frauds: Array<ExtractedFraud>,\n    block: BlockInfo,\n    extractor: string,\n  ) => {\n    const boxIds = frauds.map((item) => item.boxId);\n    const dbBoxes = await this.repository.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 = await queryRunner.manager.getRepository(FraudEntity);\n    try {\n      for (const fraud of frauds) {\n        const entity = {\n          triggerBoxId: fraud.triggerBoxId,\n          boxId: fraud.boxId,\n          wid: fraud.wid,\n          rwtCount: fraud.rwtCount,\n          creationBlock: block.hash,\n          creationHeight: block.height,\n          creationTxId: fraud.txId,\n          serialized: fraud.serialized,\n          extractor: extractor,\n          spendBlock: undefined,\n          spendHeight: undefined,\n          spendTxId: undefined,\n        };\n        const dbBox = dbBoxes.filter((item) => item.boxId === fraud.boxId);\n        if (dbBox.length > 0) {\n          this.logger.info(`Updating fraud with boxId [${fraud.boxId}]`);\n          this.logger.debug(`Updated fraud: [${JSON.stringify(entity)}]`);\n          await repository.update({ id: dbBox[0].id }, entity);\n        } else {\n          this.logger.info(`Storing fraud with boxId: [${fraud.boxId}]`);\n          this.logger.debug(`Inserted fraud: [${JSON.stringify(entity)}]`);\n          await repository.insert(entity);\n        }\n      }\n      await queryRunner.commitTransaction();\n    } catch (e) {\n      this.logger.error(`An error occurred during storing fraud boxes: ${e}`);\n      await queryRunner.rollbackTransaction();\n      success = false;\n    } finally {\n      await queryRunner.release();\n    }\n    return success;\n  };\n\n  /**\n   * Insert a new fraud into database\n   * @param fraud\n   * @param extractor\n   */\n  insertFraud = async (fraud: ExtractedFraud, extractor: string) => {\n    return this.repository.insert({\n      boxId: fraud.boxId,\n      triggerBoxId: fraud.triggerBoxId,\n      wid: fraud.wid,\n      rwtCount: fraud.rwtCount,\n      creationBlock: fraud.blockId,\n      creationHeight: fraud.height,\n      creationTxId: fraud.txId,\n      serialized: fraud.serialized,\n      extractor: extractor,\n    });\n  };\n\n  /**\n   * Update an unspent fraud information in the database\n   * @param fraud\n   * @param extractor\n   */\n  updateFraud = async (fraud: ExtractedFraud, extractor: string) => {\n    return this.repository.update(\n      { boxId: fraud.boxId, extractor: extractor },\n      {\n        triggerBoxId: fraud.triggerBoxId,\n        creationBlock: fraud.blockId,\n        creationHeight: fraud.height,\n        creationTxId: fraud.txId,\n        serialized: fraud.serialized,\n        wid: fraud.wid,\n        rwtCount: fraud.rwtCount,\n        spendBlock: null,\n        spendHeight: 0,\n      },\n    );\n  };\n\n  /**\n   * Update spendBlock and spendHeight of frauds spent on the block\n   * @param spendIds\n   * @param block\n   * @param extractor\n   */\n  spendFrauds = async (\n    spendIds: Array<string>,\n    block: BlockInfo,\n    extractor: string,\n    txId: string,\n  ): Promise<void> => {\n    const spendIdChunks = chunk(spendIds, dbIdChunkSize);\n    for (const spendIdChunk of spendIdChunks) {\n      const updateResult = await this.repository.update(\n        { boxId: In(spendIdChunk), extractor: extractor },\n        { spendBlock: block.hash, spendHeight: block.height, spendTxId: txId },\n      );\n\n      if (updateResult.affected && updateResult.affected > 0) {\n        const spentRows = await this.repository.findBy({\n          boxId: In(spendIdChunk),\n          spendBlock: block.hash,\n          spendTxId: txId,\n        });\n        for (const row of spentRows) {\n          this.logger.debug(\n            `Spent box with boxId [${row.boxId}] at transaction [${txId}] at height ${block.height}`,\n          );\n        }\n      }\n    }\n  };\n\n  /**\n   * Update all frauds related to an specific invalid block\n   * if box had been spent in the block mark it as unspent,\n   * and if it was created within the block remove it from database\n   * @param block\n   * @param extractor\n   */\n  deleteBlock = async (block: string, extractor: string): Promise<void> => {\n    this.logger.info(`Deleting frauds in block [${block}]`);\n    const invalidRows = await this.repository.findBy({\n      extractor: extractor,\n      creationBlock: block,\n    });\n    if (invalidRows.length > 0) {\n      await this.repository.delete({\n        extractor: extractor,\n        creationBlock: block,\n      });\n      for (const row of invalidRows) {\n        this.logger.debug(\n          `deleted invalid fraud with boxId [${row.boxId}] at the forked block [${block}]`,\n        );\n      }\n    }\n    const updatingRows = await this.repository.findBy({\n      extractor: extractor,\n      spendBlock: block,\n    });\n    if (updatingRows.length > 0) {\n      await this.repository.update(\n        { spendBlock: block, extractor: extractor },\n        { spendBlock: null, spendHeight: 0, spendTxId: null },\n      );\n      for (const row of updatingRows) {\n        this.logger.debug(\n          `removed spending information of the fraud with boxId [${row.boxId}], spent at the forked block [${block}]`,\n        );\n      }\n    }\n  };\n\n  /**\n   * Return all stored fraud box ids\n   */\n  getAllBoxIds = async (extractor: string): Promise<Array<string>> => {\n    const boxIds = await this.repository.find({\n      select: {\n        boxId: true,\n      },\n      where: {\n        extractor: extractor,\n      },\n    });\n    return boxIds.map((item: { boxId: string }) => item.boxId);\n  };\n\n  /**\n   * Remove an specified fraud\n   * @param boxId\n   * @param extractor\n   */\n  removeFraud = async (boxId: string, extractor: string) => {\n    return await this.repository.delete({ boxId: boxId, extractor: extractor });\n  };\n\n  /**\n   * Update the fraud spending information\n   * @param boxId\n   * @param extractor\n   * @param blockId\n   * @param blockHeight\n   */\n  updateSpendBlock = async (\n    boxId: string,\n    extractor: string,\n    blockId: string,\n    blockHeight: number,\n  ) => {\n    return await this.repository.update(\n      { boxId: boxId, extractor: extractor },\n      { spendBlock: blockId, spendHeight: blockHeight },\n    );\n  };\n}\n"]}
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnJhdWRBY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9saWIvYWN0aW9ucy9mcmF1ZEFjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUt6RSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFHdEQsTUFBTSxPQUFPLFdBQVksU0FBUSxxQkFHaEM7SUFDQyxZQUFZLFVBQXNCLEVBQUUsTUFBdUI7UUFDekQsS0FBSyxDQUFDLFVBQVUsRUFBRSxXQUFXLEVBQUUsTUFBTSxDQUFDLENBQUM7SUFDekMsQ0FBQztJQUVEOzs7Ozs7T0FNRztJQUNPLFlBQVksR0FBRyxDQUN2QixNQUF3QixFQUN4QixLQUFnQixFQUNoQixTQUFpQixFQUNlLEVBQUU7UUFDbEMsT0FBTyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBQzVCLEdBQUcsS0FBSztZQUNSLEtBQUssRUFBRSxLQUFLLENBQUMsSUFBSTtZQUNqQixNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU07WUFDcEIsU0FBUztZQUNULFVBQVUsRUFBRSxLQUFLLENBQUMsVUFBVSxJQUFJLElBQUk7WUFDcEMsV0FBVyxFQUFFLEtBQUssQ0FBQyxXQUFXLElBQUksSUFBSTtZQUN0QyxTQUFTLEVBQUUsS0FBSyxDQUFDLFNBQVMsSUFBSSxJQUFJO1NBQ25DLENBQUMsQ0FBQyxDQUFDO0lBQ04sQ0FBQyxDQUFDO0lBRUY7Ozs7T0FJRztJQUNPLG1CQUFtQixHQUFHLENBQzlCLFFBQXVCLEVBQ0wsRUFBRTtRQUNwQixPQUFPLFFBQVEsQ0FBQztJQUNsQixDQUFDLENBQUM7Q0FDSCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFic3RyYWN0RXJnb0JveEFjdGlvbiB9IGZyb20gJ0Byb3Nlbi1icmlkZ2UvYWJzdHJhY3QtZXh0cmFjdG9yJztcbmltcG9ydCB7IEFic3RyYWN0TG9nZ2VyIH0gZnJvbSAnQHJvc2VuLWJyaWRnZS9hYnN0cmFjdC1sb2dnZXInO1xuaW1wb3J0IHsgRGF0YVNvdXJjZSB9IGZyb20gJ0Byb3Nlbi1icmlkZ2UvZXh0ZW5kZWQtdHlwZW9ybSc7XG5pbXBvcnQgeyBCbG9ja0luZm8gfSBmcm9tICdAcm9zZW4tYnJpZGdlL3NjYW5uZXItaW50ZXJmYWNlcyc7XG5cbmltcG9ydCB7IEZyYXVkRW50aXR5IH0gZnJvbSAnLi4vZW50aXRpZXMvZnJhdWRFbnRpdHknO1xuaW1wb3J0IHsgRXh0cmFjdGVkRnJhdWQgfSBmcm9tICcuLi9pbnRlcmZhY2VzL3R5cGVzJztcblxuZXhwb3J0IGNsYXNzIEZyYXVkQWN0aW9uIGV4dGVuZHMgQWJzdHJhY3RFcmdvQm94QWN0aW9uPFxuICBFeHRyYWN0ZWRGcmF1ZCxcbiAgRnJhdWRFbnRpdHlcbj4ge1xuICBjb25zdHJ1Y3RvcihkYXRhU291cmNlOiBEYXRhU291cmNlLCBsb2dnZXI/OiBBYnN0cmFjdExvZ2dlcikge1xuICAgIHN1cGVyKGRhdGFTb3VyY2UsIEZyYXVkRW50aXR5LCBsb2dnZXIpO1xuICB9XG5cbiAgLyoqXG4gICAqIGNyZWF0ZSB0aGUgZnJhdWQgZW50aXR5IGZyb20gZXh0cmFjdGVkIGRhdGEgYW5kIGJsb2NrIGluZm9ybWF0aW9uXG4gICAqIEBwYXJhbSBmcmF1ZHNcbiAgICogQHBhcmFtIGJsb2NrXG4gICAqIEBwYXJhbSBleHRyYWN0b3JcbiAgICogQHJldHVybnMgdGhlIGZyYXVkIGVudGl0aWVzICh3aXRob3V0IHRoZSBpZClcbiAgICovXG4gIHByb3RlY3RlZCBjcmVhdGVFbnRpdHkgPSAoXG4gICAgZnJhdWRzOiBFeHRyYWN0ZWRGcmF1ZFtdLFxuICAgIGJsb2NrOiBCbG9ja0luZm8sXG4gICAgZXh0cmFjdG9yOiBzdHJpbmcsXG4gICk6IEFycmF5PE9taXQ8RnJhdWRFbnRpdHksICdpZCc+PiA9PiB7XG4gICAgcmV0dXJuIGZyYXVkcy5tYXAoKGZyYXVkKSA9PiAoe1xuICAgICAgLi4uZnJhdWQsXG4gICAgICBibG9jazogYmxvY2suaGFzaCxcbiAgICAgIGhlaWdodDogYmxvY2suaGVpZ2h0LFxuICAgICAgZXh0cmFjdG9yLFxuICAgICAgc3BlbmRCbG9jazogZnJhdWQuc3BlbmRCbG9jayA/PyBudWxsLFxuICAgICAgc3BlbmRIZWlnaHQ6IGZyYXVkLnNwZW5kSGVpZ2h0ID8/IG51bGwsXG4gICAgICBzcGVuZFR4SWQ6IGZyYXVkLnNwZW5kVHhJZCA/PyBudWxsLFxuICAgIH0pKTtcbiAgfTtcblxuICAvKipcbiAgICogY29udmVydCB0aGUgZGF0YWJhc2UgZW50aXR5IGJhY2sgdG8gcmF3IGRhdGFcbiAgICogQHBhcmFtIGVudGl0aWVzXG4gICAqIEByZXR1cm5zIHRoZSBleHRyYWN0ZWQgZnJhdWQgZGF0YVxuICAgKi9cbiAgcHJvdGVjdGVkIGNvbnZlcnRFbnRpdHlUb0RhdGEgPSAoXG4gICAgZW50aXRpZXM6IEZyYXVkRW50aXR5W10sXG4gICk6IEV4dHJhY3RlZEZyYXVkW10gPT4ge1xuICAgIHJldHVybiBlbnRpdGllcztcbiAgfTtcbn1cbiJdfQ==
@@ -1,16 +1,8 @@
1
- export declare class FraudEntity {
2
- id: number;
3
- boxId: string;
4
- creationBlock: string;
5
- creationHeight: number;
6
- creationTxId: string;
7
- serialized: string;
1
+ import { AbstractErgoBoxEntity } from '@rosen-bridge/abstract-extractor';
2
+ export declare class FraudEntity extends AbstractErgoBoxEntity {
8
3
  triggerBoxId: string;
4
+ txId: string;
9
5
  wid: string;
10
6
  rwtCount: string;
11
- spendBlock?: string | null;
12
- spendHeight?: number;
13
- spendTxId?: string | null;
14
- extractor: string;
15
7
  }
16
8
  //# sourceMappingURL=fraudEntity.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"fraudEntity.d.ts","sourceRoot":"","sources":["../../lib/entities/fraudEntity.ts"],"names":[],"mappings":"AAMA,qBACa,WAAW;IAEtB,EAAE,EAAE,MAAM,CAAC;IAGX,KAAK,EAAE,MAAM,CAAC;IAGd,aAAa,EAAE,MAAM,CAAC;IAGtB,cAAc,EAAE,MAAM,CAAC;IAGvB,YAAY,EAAE,MAAM,CAAC;IAGrB,UAAU,EAAE,MAAM,CAAC;IAGnB,YAAY,EAAE,MAAM,CAAC;IAGrB,GAAG,EAAE,MAAM,CAAC;IAGZ,QAAQ,EAAE,MAAM,CAAC;IAGjB,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAG3B,WAAW,CAAC,EAAE,MAAM,CAAC;IAGrB,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAG1B,SAAS,EAAE,MAAM,CAAC;CACnB"}
1
+ {"version":3,"file":"fraudEntity.d.ts","sourceRoot":"","sources":["../../lib/entities/fraudEntity.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,kCAAkC,CAAC;AAGzE,qBACa,WAAY,SAAQ,qBAAqB;IAEpD,YAAY,EAAE,MAAM,CAAC;IAGrB,IAAI,EAAE,MAAM,CAAC;IAGb,GAAG,EAAE,MAAM,CAAC;IAGZ,QAAQ,EAAE,MAAM,CAAC;CAClB"}
@@ -7,50 +7,22 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
7
7
  var __metadata = (this && this.__metadata) || function (k, v) {
8
8
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
9
9
  };
10
- import { Column, Entity, PrimaryGeneratedColumn, } from '@rosen-bridge/extended-typeorm';
11
- let FraudEntity = class FraudEntity {
12
- id;
13
- boxId;
14
- creationBlock;
15
- creationHeight;
16
- creationTxId;
17
- serialized;
10
+ import { AbstractErgoBoxEntity } from '@rosen-bridge/abstract-extractor';
11
+ import { Column, Entity } from '@rosen-bridge/extended-typeorm';
12
+ let FraudEntity = class FraudEntity extends AbstractErgoBoxEntity {
18
13
  triggerBoxId;
14
+ txId;
19
15
  wid;
20
16
  rwtCount;
21
- spendBlock;
22
- spendHeight;
23
- spendTxId;
24
- extractor;
25
17
  };
26
- __decorate([
27
- PrimaryGeneratedColumn(),
28
- __metadata("design:type", Number)
29
- ], FraudEntity.prototype, "id", void 0);
30
- __decorate([
31
- Column({ type: 'varchar' }),
32
- __metadata("design:type", String)
33
- ], FraudEntity.prototype, "boxId", void 0);
34
- __decorate([
35
- Column({ type: 'varchar' }),
36
- __metadata("design:type", String)
37
- ], FraudEntity.prototype, "creationBlock", void 0);
38
- __decorate([
39
- Column({ type: 'int' }),
40
- __metadata("design:type", Number)
41
- ], FraudEntity.prototype, "creationHeight", void 0);
42
18
  __decorate([
43
19
  Column({ type: 'varchar' }),
44
20
  __metadata("design:type", String)
45
- ], FraudEntity.prototype, "creationTxId", void 0);
46
- __decorate([
47
- Column({ type: 'varchar' }),
48
- __metadata("design:type", String)
49
- ], FraudEntity.prototype, "serialized", void 0);
21
+ ], FraudEntity.prototype, "triggerBoxId", void 0);
50
22
  __decorate([
51
23
  Column({ type: 'varchar' }),
52
24
  __metadata("design:type", String)
53
- ], FraudEntity.prototype, "triggerBoxId", void 0);
25
+ ], FraudEntity.prototype, "txId", void 0);
54
26
  __decorate([
55
27
  Column({ type: 'varchar' }),
56
28
  __metadata("design:type", String)
@@ -59,24 +31,8 @@ __decorate([
59
31
  Column({ type: 'varchar' }),
60
32
  __metadata("design:type", String)
61
33
  ], FraudEntity.prototype, "rwtCount", void 0);
62
- __decorate([
63
- Column({ nullable: true, type: 'text' }),
64
- __metadata("design:type", Object)
65
- ], FraudEntity.prototype, "spendBlock", void 0);
66
- __decorate([
67
- Column({ nullable: true, type: 'int' }),
68
- __metadata("design:type", Number)
69
- ], FraudEntity.prototype, "spendHeight", void 0);
70
- __decorate([
71
- Column({ nullable: true, type: 'text' }),
72
- __metadata("design:type", Object)
73
- ], FraudEntity.prototype, "spendTxId", void 0);
74
- __decorate([
75
- Column({ type: 'varchar' }),
76
- __metadata("design:type", String)
77
- ], FraudEntity.prototype, "extractor", void 0);
78
34
  FraudEntity = __decorate([
79
35
  Entity('fraud_entity')
80
36
  ], FraudEntity);
81
37
  export { FraudEntity };
82
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnJhdWRFbnRpdHkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9saWIvZW50aXRpZXMvZnJhdWRFbnRpdHkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUEsT0FBTyxFQUNMLE1BQU0sRUFDTixNQUFNLEVBQ04sc0JBQXNCLEdBQ3ZCLE1BQU0sZ0NBQWdDLENBQUM7QUFHakMsSUFBTSxXQUFXLEdBQWpCLE1BQU0sV0FBVztJQUV0QixFQUFFLENBQVM7SUFHWCxLQUFLLENBQVM7SUFHZCxhQUFhLENBQVM7SUFHdEIsY0FBYyxDQUFTO0lBR3ZCLFlBQVksQ0FBUztJQUdyQixVQUFVLENBQVM7SUFHbkIsWUFBWSxDQUFTO0lBR3JCLEdBQUcsQ0FBUztJQUdaLFFBQVEsQ0FBUztJQUdqQixVQUFVLENBQWlCO0lBRzNCLFdBQVcsQ0FBVTtJQUdyQixTQUFTLENBQWlCO0lBRzFCLFNBQVMsQ0FBUztDQUNuQixDQUFBO0FBckNDO0lBREMsc0JBQXNCLEVBQUU7O3VDQUNkO0FBR1g7SUFEQyxNQUFNLENBQUMsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLENBQUM7OzBDQUNkO0FBR2Q7SUFEQyxNQUFNLENBQUMsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLENBQUM7O2tEQUNOO0FBR3RCO0lBREMsTUFBTSxDQUFDLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxDQUFDOzttREFDRDtBQUd2QjtJQURDLE1BQU0sQ0FBQyxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsQ0FBQzs7aURBQ1A7QUFHckI7SUFEQyxNQUFNLENBQUMsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLENBQUM7OytDQUNUO0FBR25CO0lBREMsTUFBTSxDQUFDLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxDQUFDOztpREFDUDtBQUdyQjtJQURDLE1BQU0sQ0FBQyxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsQ0FBQzs7d0NBQ2hCO0FBR1o7SUFEQyxNQUFNLENBQUMsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLENBQUM7OzZDQUNYO0FBR2pCO0lBREMsTUFBTSxDQUFDLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLENBQUM7OytDQUNkO0FBRzNCO0lBREMsTUFBTSxDQUFDLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLENBQUM7O2dEQUNuQjtBQUdyQjtJQURDLE1BQU0sQ0FBQyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxDQUFDOzs4Q0FDZjtBQUcxQjtJQURDLE1BQU0sQ0FBQyxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsQ0FBQzs7OENBQ1Y7QUF0Q1AsV0FBVztJQUR2QixNQUFNLENBQUMsY0FBYyxDQUFDO0dBQ1YsV0FBVyxDQXVDdkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDb2x1bW4sXG4gIEVudGl0eSxcbiAgUHJpbWFyeUdlbmVyYXRlZENvbHVtbixcbn0gZnJvbSAnQHJvc2VuLWJyaWRnZS9leHRlbmRlZC10eXBlb3JtJztcblxuQEVudGl0eSgnZnJhdWRfZW50aXR5JylcbmV4cG9ydCBjbGFzcyBGcmF1ZEVudGl0eSB7XG4gIEBQcmltYXJ5R2VuZXJhdGVkQ29sdW1uKClcbiAgaWQ6IG51bWJlcjtcblxuICBAQ29sdW1uKHsgdHlwZTogJ3ZhcmNoYXInIH0pXG4gIGJveElkOiBzdHJpbmc7XG5cbiAgQENvbHVtbih7IHR5cGU6ICd2YXJjaGFyJyB9KVxuICBjcmVhdGlvbkJsb2NrOiBzdHJpbmc7XG5cbiAgQENvbHVtbih7IHR5cGU6ICdpbnQnIH0pXG4gIGNyZWF0aW9uSGVpZ2h0OiBudW1iZXI7XG5cbiAgQENvbHVtbih7IHR5cGU6ICd2YXJjaGFyJyB9KVxuICBjcmVhdGlvblR4SWQ6IHN0cmluZztcblxuICBAQ29sdW1uKHsgdHlwZTogJ3ZhcmNoYXInIH0pXG4gIHNlcmlhbGl6ZWQ6IHN0cmluZztcblxuICBAQ29sdW1uKHsgdHlwZTogJ3ZhcmNoYXInIH0pXG4gIHRyaWdnZXJCb3hJZDogc3RyaW5nO1xuXG4gIEBDb2x1bW4oeyB0eXBlOiAndmFyY2hhcicgfSlcbiAgd2lkOiBzdHJpbmc7XG5cbiAgQENvbHVtbih7IHR5cGU6ICd2YXJjaGFyJyB9KVxuICByd3RDb3VudDogc3RyaW5nO1xuXG4gIEBDb2x1bW4oeyBudWxsYWJsZTogdHJ1ZSwgdHlwZTogJ3RleHQnIH0pXG4gIHNwZW5kQmxvY2s/OiBzdHJpbmcgfCBudWxsO1xuXG4gIEBDb2x1bW4oeyBudWxsYWJsZTogdHJ1ZSwgdHlwZTogJ2ludCcgfSlcbiAgc3BlbmRIZWlnaHQ/OiBudW1iZXI7XG5cbiAgQENvbHVtbih7IG51bGxhYmxlOiB0cnVlLCB0eXBlOiAndGV4dCcgfSlcbiAgc3BlbmRUeElkPzogc3RyaW5nIHwgbnVsbDtcblxuICBAQ29sdW1uKHsgdHlwZTogJ3ZhcmNoYXInIH0pXG4gIGV4dHJhY3Rvcjogc3RyaW5nO1xufVxuIl19
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnJhdWRFbnRpdHkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9saWIvZW50aXRpZXMvZnJhdWRFbnRpdHkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUEsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFDekUsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUd6RCxJQUFNLFdBQVcsR0FBakIsTUFBTSxXQUFZLFNBQVEscUJBQXFCO0lBRXBELFlBQVksQ0FBUztJQUdyQixJQUFJLENBQVM7SUFHYixHQUFHLENBQVM7SUFHWixRQUFRLENBQVM7Q0FDbEIsQ0FBQTtBQVZDO0lBREMsTUFBTSxDQUFDLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxDQUFDOztpREFDUDtBQUdyQjtJQURDLE1BQU0sQ0FBQyxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsQ0FBQzs7eUNBQ2Y7QUFHYjtJQURDLE1BQU0sQ0FBQyxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsQ0FBQzs7d0NBQ2hCO0FBR1o7SUFEQyxNQUFNLENBQUMsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLENBQUM7OzZDQUNYO0FBWE4sV0FBVztJQUR2QixNQUFNLENBQUMsY0FBYyxDQUFDO0dBQ1YsV0FBVyxDQVl2QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFic3RyYWN0RXJnb0JveEVudGl0eSB9IGZyb20gJ0Byb3Nlbi1icmlkZ2UvYWJzdHJhY3QtZXh0cmFjdG9yJztcbmltcG9ydCB7IENvbHVtbiwgRW50aXR5IH0gZnJvbSAnQHJvc2VuLWJyaWRnZS9leHRlbmRlZC10eXBlb3JtJztcblxuQEVudGl0eSgnZnJhdWRfZW50aXR5JylcbmV4cG9ydCBjbGFzcyBGcmF1ZEVudGl0eSBleHRlbmRzIEFic3RyYWN0RXJnb0JveEVudGl0eSB7XG4gIEBDb2x1bW4oeyB0eXBlOiAndmFyY2hhcicgfSlcbiAgdHJpZ2dlckJveElkOiBzdHJpbmc7XG5cbiAgQENvbHVtbih7IHR5cGU6ICd2YXJjaGFyJyB9KVxuICB0eElkOiBzdHJpbmc7XG5cbiAgQENvbHVtbih7IHR5cGU6ICd2YXJjaGFyJyB9KVxuICB3aWQ6IHN0cmluZztcblxuICBAQ29sdW1uKHsgdHlwZTogJ3ZhcmNoYXInIH0pXG4gIHJ3dENvdW50OiBzdHJpbmc7XG59XG4iXX0=