@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 +8 -5
- package/dist/actions/fraudAction.d.ts +10 -50
- package/dist/actions/fraudAction.d.ts.map +1 -1
- package/dist/actions/fraudAction.js +21 -184
- package/dist/entities/fraudEntity.d.ts +3 -11
- package/dist/entities/fraudEntity.d.ts.map +1 -1
- package/dist/entities/fraudEntity.js +7 -51
- package/dist/extractor/fraudExtractor.d.ts +21 -128
- package/dist/extractor/fraudExtractor.d.ts.map +1 -1
- package/dist/extractor/fraudExtractor.js +48 -229
- package/dist/interfaces/types.d.ts +6 -10
- package/dist/interfaces/types.d.ts.map +1 -1
- package/dist/interfaces/types.js +1 -1
- package/dist/migrations/index.d.ts.map +1 -1
- package/dist/migrations/index.js +5 -3
- package/dist/migrations/postgres/1766229066209-migration.d.ts +7 -0
- package/dist/migrations/postgres/1766229066209-migration.d.ts.map +1 -0
- package/dist/migrations/postgres/1766229066209-migration.js +52 -0
- package/dist/migrations/sqlite/1766226220592-migration.d.ts +7 -0
- package/dist/migrations/sqlite/1766226220592-migration.d.ts.map +1 -0
- package/dist/migrations/sqlite/1766226220592-migration.js +114 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +6 -8
- package/dist/constants.d.ts +0 -4
- package/dist/constants.d.ts.map +0 -1
- package/dist/constants.js +0 -4
package/CHANGELOG.md
CHANGED
|
@@ -1,18 +1,21 @@
|
|
|
1
1
|
# @rosen-bridge/fraud-extractor
|
|
2
2
|
|
|
3
|
-
## 3.0.0
|
|
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
|
-
-
|
|
13
|
-
-
|
|
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
|
-
*
|
|
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
|
-
|
|
16
|
+
protected createEntity: (frauds: ExtractedFraud[], block: BlockInfo, extractor: string) => Array<Omit<FraudEntity, "id">>;
|
|
18
17
|
/**
|
|
19
|
-
*
|
|
20
|
-
* @param
|
|
21
|
-
* @
|
|
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
|
-
|
|
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":"
|
|
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 {
|
|
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
|
-
|
|
12
|
-
this.logger = logger ? logger : new DummyLogger();
|
|
13
|
-
this.repository = dataSource.getRepository(FraudEntity);
|
|
5
|
+
super(dataSource, FraudEntity, logger);
|
|
14
6
|
}
|
|
15
7
|
/**
|
|
16
|
-
*
|
|
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
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
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
|
-
*
|
|
75
|
-
* @param
|
|
76
|
-
* @
|
|
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
|
-
|
|
194
|
-
return
|
|
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
|
-
|
|
2
|
-
|
|
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":"
|
|
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 {
|
|
11
|
-
|
|
12
|
-
|
|
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, "
|
|
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, "
|
|
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,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnJhdWRFbnRpdHkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9saWIvZW50aXRpZXMvZnJhdWRFbnRpdHkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUEsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFDekUsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUd6RCxJQUFNLFdBQVcsR0FBakIsTUFBTSxXQUFZLFNBQVEscUJBQXFCO0lBRXBELFlBQVksQ0FBUztJQUdyQixJQUFJLENBQVM7SUFHYixHQUFHLENBQVM7SUFHWixRQUFRLENBQVM7Q0FDbEIsQ0FBQTtBQVZDO0lBREMsTUFBTSxDQUFDLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxDQUFDOztpREFDUDtBQUdyQjtJQURDLE1BQU0sQ0FBQyxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsQ0FBQzs7eUNBQ2Y7QUFHYjtJQURDLE1BQU0sQ0FBQyxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsQ0FBQzs7d0NBQ2hCO0FBR1o7SUFEQyxNQUFNLENBQUMsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLENBQUM7OzZDQUNYO0FBWE4sV0FBVztJQUR2QixNQUFNLENBQUMsY0FBYyxDQUFDO0dBQ1YsV0FBVyxDQVl2QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFic3RyYWN0RXJnb0JveEVudGl0eSB9IGZyb20gJ0Byb3Nlbi1icmlkZ2UvYWJzdHJhY3QtZXh0cmFjdG9yJztcbmltcG9ydCB7IENvbHVtbiwgRW50aXR5IH0gZnJvbSAnQHJvc2VuLWJyaWRnZS9leHRlbmRlZC10eXBlb3JtJztcblxuQEVudGl0eSgnZnJhdWRfZW50aXR5JylcbmV4cG9ydCBjbGFzcyBGcmF1ZEVudGl0eSBleHRlbmRzIEFic3RyYWN0RXJnb0JveEVudGl0eSB7XG4gIEBDb2x1bW4oeyB0eXBlOiAndmFyY2hhcicgfSlcbiAgdHJpZ2dlckJveElkOiBzdHJpbmc7XG5cbiAgQENvbHVtbih7IHR5cGU6ICd2YXJjaGFyJyB9KVxuICB0eElkOiBzdHJpbmc7XG5cbiAgQENvbHVtbih7IHR5cGU6ICd2YXJjaGFyJyB9KVxuICB3aWQ6IHN0cmluZztcblxuICBAQ29sdW1uKHsgdHlwZTogJ3ZhcmNoYXInIH0pXG4gIHJ3dENvdW50OiBzdHJpbmc7XG59XG4iXX0=
|