@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.
- package/CHANGELOG.md +20 -0
- package/dist/actions/collateralAction.d.ts +15 -66
- package/dist/actions/collateralAction.d.ts.map +1 -1
- package/dist/actions/collateralAction.js +21 -181
- package/dist/actions/commitmentAction.d.ts +3 -3
- package/dist/actions/commitmentAction.d.ts.map +1 -1
- package/dist/actions/commitmentAction.js +2 -2
- package/dist/actions/eventTriggerAction.d.ts +3 -4
- package/dist/actions/eventTriggerAction.d.ts.map +1 -1
- package/dist/actions/eventTriggerAction.js +11 -13
- package/dist/actions/permitAction.d.ts +3 -3
- package/dist/actions/permitAction.d.ts.map +1 -1
- package/dist/actions/permitAction.js +1 -1
- package/dist/entities/collateralEntity.d.ts +3 -11
- package/dist/entities/collateralEntity.d.ts.map +1 -1
- package/dist/entities/collateralEntity.js +7 -52
- package/dist/entities/eventTriggerEntity.d.ts +2 -2
- package/dist/entities/eventTriggerEntity.d.ts.map +1 -1
- package/dist/entities/eventTriggerEntity.js +3 -3
- package/dist/extractor/collateralExtractor.d.ts +17 -72
- package/dist/extractor/collateralExtractor.d.ts.map +1 -1
- package/dist/extractor/collateralExtractor.js +48 -212
- package/dist/extractor/commitmentExtractor.d.ts +3 -3
- package/dist/extractor/commitmentExtractor.d.ts.map +1 -1
- package/dist/extractor/commitmentExtractor.js +3 -3
- package/dist/extractor/eventTriggerExtractor.d.ts +3 -3
- package/dist/extractor/eventTriggerExtractor.d.ts.map +1 -1
- package/dist/extractor/eventTriggerExtractor.js +9 -9
- package/dist/extractor/permitExtractor.d.ts +3 -3
- package/dist/extractor/permitExtractor.d.ts.map +1 -1
- package/dist/extractor/permitExtractor.js +3 -3
- package/dist/interfaces/extractedCollateral.d.ts +3 -7
- package/dist/interfaces/extractedCollateral.d.ts.map +1 -1
- package/dist/interfaces/extractedCollateral.js +1 -1
- package/dist/interfaces/extractedEventTrigger.d.ts +1 -1
- package/dist/interfaces/extractedEventTrigger.d.ts.map +1 -1
- package/dist/interfaces/extractedEventTrigger.js +1 -1
- package/dist/migrations/index.d.ts.map +1 -1
- package/dist/migrations/index.js +9 -1
- package/dist/migrations/postgres/1758958886549-migration.d.ts +7 -0
- package/dist/migrations/postgres/1758958886549-migration.d.ts.map +1 -0
- package/dist/migrations/postgres/1758958886549-migration.js +30 -0
- package/dist/migrations/postgres/1766843825000-migration.d.ts +7 -0
- package/dist/migrations/postgres/1766843825000-migration.d.ts.map +1 -0
- package/dist/migrations/postgres/1766843825000-migration.js +42 -0
- package/dist/migrations/sqlite/1762768664031-migration.d.ts +7 -0
- package/dist/migrations/sqlite/1762768664031-migration.d.ts.map +1 -0
- package/dist/migrations/sqlite/1762768664031-migration.js +204 -0
- package/dist/migrations/sqlite/1766843824000-migration.d.ts +7 -0
- package/dist/migrations/sqlite/1766843824000-migration.d.ts.map +1 -0
- package/dist/migrations/sqlite/1766843824000-migration.js +109 -0
- 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
|
|
3
|
-
import {
|
|
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
|
-
|
|
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
|
-
*
|
|
13
|
-
*
|
|
14
|
-
* @param
|
|
15
|
-
* @param
|
|
16
|
-
* @
|
|
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
|
-
|
|
16
|
+
protected createEntity: (collaterals: ExtractedCollateral[], block: BlockInfo, extractor: string) => Array<Omit<CollateralEntity, "id">>;
|
|
19
17
|
/**
|
|
20
|
-
*
|
|
21
|
-
*
|
|
22
|
-
* @
|
|
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
|
-
|
|
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":"
|
|
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 {
|
|
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
|
-
|
|
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
|
-
*
|
|
17
|
-
*
|
|
18
|
-
* @param
|
|
19
|
-
* @param
|
|
20
|
-
* @
|
|
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
|
-
|
|
23
|
-
return
|
|
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:
|
|
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
|
-
*
|
|
109
|
-
*
|
|
110
|
-
* @
|
|
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
|
-
|
|
187
|
-
return
|
|
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":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAEvC,OAAO,EAAkB,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAGL,EAAE,EACF,MAAM,GAEP,MAAM,gCAAgC,CAAC;AACxC,OAAO,UAAU,MAAM,2BAA2B,CAAC;AAGnD,OAAO,gBAAgB,MAAM,8BAA8B,CAAC;AAI5D,MAAM,gBAAgB;IAID;IACR;IAJM,oBAAoB,CAA+B;IAEpE,YACmB,UAAsB,EAC9B,SAAyB,IAAI,WAAW,EAAE;QADlC,eAAU,GAAV,UAAU,CAAY;QAC9B,WAAM,GAAN,MAAM,CAAoC;QAEnD,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;IAC9E,CAAC;IAED;;;;;;OAMG;IACH,gBAAgB,GAAG,KAAK,EACtB,UAA+B,EAC/B,SAAiB,EACjB,EAAE;QACF,OAAO,MAAM,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC;YAC5C,GAAG,UAAU;YACb,SAAS;SACV,CAAC,CAAC;IACL,CAAC,CAAC;IAEF;;;;;;OAMG;IACH,gBAAgB,GAAG,KAAK,EACtB,UACoC,EACpC,SAAiB,EACjB,EAAE;QACF,OAAO,MAAM,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAC3C;YACE,SAAS;YACT,KAAK,EAAE,UAAU,CAAC,KAAK;SACxB,EACD,UAAU,CACX,CAAC;IACJ,CAAC,CAAC;IAEF;;;;;;;;OAQG;IACH,gBAAgB,GAAG,KAAK,EACtB,WAAuC,EACvC,KAAY,EACZ,SAAiB,EACC,EAAE;QACpB,IAAI,WAAW,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;YAC5B,OAAO,IAAI,CAAC;QACd,CAAC;QAED,MAAM,kBAAkB,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;YACnD,SAAS,EAAE,SAAS;YACpB,KAAK,EAAE,GAAG,CAAC,KAAK;YAChB,aAAa,EAAE,GAAG,CAAC,aAAa;YAChC,GAAG,EAAE,GAAG,CAAC,GAAG;YACZ,QAAQ,EAAE,GAAG,CAAC,QAAQ;YACtB,IAAI,EAAE,GAAG,CAAC,IAAI;YACd,KAAK,EAAE,KAAK,CAAC,IAAI;YACjB,MAAM,EAAE,GAAG,CAAC,MAAM,IAAI,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM;SAC5D,CAAC,CAAC,CAAC;QAEJ,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,iBAAiB,EAAE,CAAC;QACxD,MAAM,WAAW,CAAC,OAAO,EAAE,CAAC;QAC5B,MAAM,WAAW,CAAC,gBAAgB,EAAE,CAAC;QACrC,IAAI,CAAC;YACH,MAAM,UAAU,GACd,MAAM,WAAW,CAAC,OAAO,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;YAC5D,MAAM,cAAc,GAAG,CACrB,MAAM,UAAU,CAAC,IAAI,CAAC;gBACpB,KAAK,EAAE;oBACL,KAAK,EAAE,EAAE,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;oBACrD,SAAS,EAAE,SAAS;iBACrB;gBACD,MAAM,EAAE;oBACN,KAAK,EAAE,IAAI;iBACZ;aACF,CAAC,CACH,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YAE1B,MAAM,mBAAmB,GAAG,kBAAkB,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAC5D,cAAc,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CACnC,CAAC;YAEF,MAAM,mBAAmB,GAAG,UAAU,CACpC,kBAAkB,EAClB,mBAAmB,CACpB,CAAC;YAEF,IAAI,mBAAmB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACnC,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,0DAA0D,mBAAmB;qBAC1E,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC;qBACvB,IAAI,CAAC,IAAI,CAAC,GAAG,CACjB,CAAC;gBACF,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,+BAA+B,UAAU,CAAC,SAAS,CACjD,mBAAmB,CACpB,GAAG,CACL,CAAC;YACJ,CAAC;YACD,MAAM,UAAU,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC;YAE7C,IAAI,mBAAmB,CAAC,MAAM,GAAG,CAAC;gBAChC,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,uDAAuD,mBAAmB;qBACvE,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC;qBACvB,IAAI,CAAC,IAAI,CAAC,GAAG,CACjB,CAAC;YACJ,mBAAmB,CAAC,OAAO,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE;gBAC/C,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,wCAAwC,UAAU,CAAC,SAAS,CAC1D,UAAU,CACX,GAAG,CACL,CAAC;gBACF,MAAM,UAAU,CAAC,MAAM,CACrB,EAAE,KAAK,EAAE,UAAU,CAAC,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,EACjD,UAAU,CACX,CAAC;YACJ,CAAC,CAAC,CAAC;YAEH,MAAM,WAAW,CAAC,iBAAiB,EAAE,CAAC;QACxC,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,MAAM,WAAW,CAAC,mBAAmB,EAAE,CAAC;YACxC,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,qDAAqD,CAAC,EAAE,CACzD,CAAC;YACF,OAAO,KAAK,CAAC;QACf,CAAC;gBAAS,CAAC;YACT,MAAM,WAAW,CAAC,OAAO,EAAE,CAAC;QAC9B,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC,CAAC;IAEF;;;;;;;;OAQG;IACH,gBAAgB,GAAG,KAAK,EACtB,UAA4B,EAC5B,KAAY,EACZ,SAAiB,EACF,EAAE;QACjB,KAAK,MAAM,SAAS,IAAI,UAAU,EAAE,CAAC;YACnC,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,MAAM,CACzD;gBACE,KAAK,EAAE,SAAS,CAAC,KAAK;gBACtB,SAAS,EAAE,SAAS;aACrB,EACD;gBACE,UAAU,EAAE,KAAK,CAAC,IAAI;gBACtB,WAAW,EAAE,KAAK,CAAC,MAAM;gBACzB,SAAS,EAAE,SAAS,CAAC,IAAI;aAC1B,CACF,CAAC;YAEF,IAAI,YAAY,CAAC,QAAQ,IAAI,YAAY,CAAC,QAAQ,GAAG,CAAC,EAAE,CAAC;gBACvD,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC;oBACzD,KAAK,EAAE,SAAS,CAAC,KAAK;oBACtB,UAAU,EAAE,KAAK,CAAC,IAAI;iBACvB,CAAC,CAAC;gBACH,KAAK,MAAM,GAAG,IAAI,WAAW,EAAE,CAAC;oBAC9B,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,gCAAgC,GAAG,CAAC,KAAK,oCAAoC,GAAG,CAAC,GAAG,eAAe,KAAK,CAAC,MAAM,EAAE,CAClH,CAAC;gBACJ,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC,CAAC;IAEF;;;;;;OAMG;IACH,0BAA0B,GAAG,KAAK,EAChC,SAAiB,EACO,EAAE;QAC1B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC;YAClD,KAAK,EAAE;gBACL,SAAS,EAAE,SAAS;gBACpB,UAAU,EAAE,MAAM,EAAE;aACrB;YACD,MAAM,EAAE;gBACN,KAAK,EAAE,IAAI;aACZ;SACF,CAAC,CAAC;QACH,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC,CAAC;IAEF;;;;;;;;OAQG;IACH,KAAK,CAAC,WAAW,CAAC,KAAa,EAAE,SAAiB;QAChD,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,kCAAkC,KAAK,oBAAoB,SAAS,GAAG,CACxE,CAAC;QAEF,MAAM,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC;YACrC,KAAK,EAAE,KAAK;YACZ,SAAS,EAAE,SAAS;SACrB,CAAC,CAAC;QAEH,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,wCAAwC,KAAK,oBAAoB,SAAS,qBAAqB,CAChG,CAAC;QAEF,MAAM,IAAI,CAAC,oBAAoB,CAAC,MAAM,CACpC,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,EAC3C;YACE,UAAU,EAAE,IAAI;YAChB,WAAW,EAAE,IAAI;YACjB,SAAS,EAAE,IAAI;SAChB,CACF,CAAC;IACJ,CAAC;IAED;;;;;;;OAOG;IACH,gBAAgB,GAAG,KAAK,EACtB,KAAa,EACb,SAAiB,EACM,EAAE;QACzB,OAAO,MAAM,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC;YAC5C,KAAK,EAAE,KAAK;YACZ,SAAS,EAAE,SAAS;SACrB,CAAC,CAAC;IACL,CAAC,CAAC;CACH;AAED,eAAe,gBAAgB,CAAC","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 {
|
|
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:
|
|
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:
|
|
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,
|
|
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(`
|
|
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":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,WAAW,CAAC;AAElC,OAAO,EAAkB,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAc,EAAE,EAAc,MAAM,gCAAgC,CAAC;AAG5E,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,gBAAgB,MAAM,8BAA8B,CAAC;AAI5D,MAAM,gBAAgB;IACX,MAAM,CAAiB;IACf,UAAU,CAAa;IACvB,oBAAoB,CAA+B;IAEpE,YAAY,UAAsB,EAAE,MAAuB;QACzD,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,WAAW,EAAE,CAAC;QAClD,IAAI,CAAC,oBAAoB,GAAG,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;IACzE,CAAC;IAED;;;;;OAKG;IACH,gBAAgB,GAAG,KAAK,EACtB,WAAuC,EACvC,KAAY,EACZ,SAAiB,EACC,EAAE;QACpB,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,IAAI,CAAC;QAC1C,MAAM,MAAM,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACjE,MAAM,gBAAgB,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC;YAC9D,KAAK,EAAE,EAAE,CAAC,MAAM,CAAC;YACjB,SAAS,EAAE,SAAS;SACrB,CAAC,CAAC;QACH,IAAI,OAAO,GAAG,IAAI,CAAC;QACnB,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,iBAAiB,EAAE,CAAC;QACxD,MAAM,WAAW,CAAC,OAAO,EAAE,CAAC;QAC5B,MAAM,WAAW,CAAC,gBAAgB,EAAE,CAAC;QACrC,MAAM,UAAU,GACd,MAAM,WAAW,CAAC,OAAO,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;QAC5D,IAAI,CAAC;YACH,KAAK,MAAM,UAAU,IAAI,WAAW,EAAE,CAAC;gBACrC,MAAM,KAAK,GAAG,gBAAgB,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE;oBAC7C,OAAO,MAAM,CAAC,KAAK,KAAK,UAAU,CAAC,KAAK,CAAC;gBAC3C,CAAC,CAAC,CAAC;gBACH,MAAM,MAAM,GAAG;oBACb,IAAI,EAAE,UAAU,CAAC,IAAI;oBACrB,UAAU,EAAE,UAAU,CAAC,UAAU;oBACjC,OAAO,EAAE,UAAU,CAAC,OAAO;oBAC3B,KAAK,EAAE,UAAU,CAAC,KAAK;oBACvB,GAAG,EAAE,UAAU,CAAC,GAAG;oBACnB,SAAS,EAAE,SAAS;oBACpB,KAAK,EAAE,KAAK,CAAC,IAAI;oBACjB,MAAM,EAAE,KAAK,CAAC,MAAM;oBACpB,aAAa,EAAE,UAAU,CAAC,aAAa;oBACvC,QAAQ,EAAE,UAAU,CAAC,QAAQ;iBAC9B,CAAC;gBACF,IAAI,CAAC,KAAK,EAAE,CAAC;oBACX,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,sBAAsB,UAAU,CAAC,KAAK,gBAAgB,UAAU,CAAC,OAAO,mBAAmB,UAAU,CAAC,GAAG,eAAe,KAAK,CAAC,MAAM,kBAAkB,SAAS,EAAE,CAClK,CAAC;oBACF,MAAM,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;gBAClC,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,wBAAwB,UAAU,CAAC,KAAK,gBAAgB,UAAU,CAAC,OAAO,mBAAmB,UAAU,CAAC,GAAG,eAAe,KAAK,CAAC,MAAM,kBAAkB,SAAS,EAAE,CACpK,CAAC;oBACF,MAAM,UAAU,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,UAAU,CAAC,KAAK,EAAE,EAAE,MAAM,CAAC,CAAC;gBAC/D,CAAC;gBACD,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,WAAW,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;YACzD,CAAC;YACD,MAAM,WAAW,CAAC,iBAAiB,EAAE,CAAC;QACxC,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,sDAAsD,CAAC,EAAE,CAC1D,CAAC;YACF,MAAM,WAAW,CAAC,mBAAmB,EAAE,CAAC;YACxC,OAAO,GAAG,KAAK,CAAC;QAClB,CAAC;gBAAS,CAAC;YACT,MAAM,WAAW,CAAC,OAAO,EAAE,CAAC;QAC9B,CAAC;QACD,OAAO,OAAO,CAAC;IACjB,CAAC,CAAC;IAEF;;;;;OAKG;IACH,gBAAgB,GAAG,KAAK,EACtB,OAAyB,EACzB,KAAY,EACZ,SAAiB,EACF,EAAE;QACjB,8DAA8D;QAC9D,MAAM,aAAa,GAAG,KAAK,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;QACpD,KAAK,MAAM,YAAY,IAAI,aAAa,EAAE,CAAC;YACzC,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC;gBACzD,KAAK,EAAE,EAAE,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBACjD,SAAS,EAAE,SAAS;aACrB,CAAC,CAAC;YAEH,KAAK,MAAM,UAAU,IAAI,WAAW,EAAE,CAAC;gBACrC,MAAM,SAAS,GAAG,YAAY,CAAC,IAAI,CACjC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,KAAK,UAAU,CAAC,KAAK,CAC1C,CAAC;gBACF,IAAI,CAAC,SAAS;oBACZ,MAAM,IAAI,KAAK,CACb,6BAA6B,UAAU,CAAC,KAAK,sCAAsC,CACpF,CAAC;gBAEJ,MAAM,IAAI,CAAC,oBAAoB,CAAC,MAAM,CACpC;oBACE,EAAE,EAAE,UAAU,CAAC,EAAE;iBAClB,EACD;oBACE,UAAU,EAAE,KAAK,CAAC,IAAI;oBACtB,WAAW,EAAE,KAAK,CAAC,MAAM;oBACzB,SAAS,EAAE,SAAS,CAAC,IAAI;oBACzB,UAAU,EAAE,SAAS,CAAC,KAAK;iBAC5B,CACF,CAAC;gBACF,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,qBAAqB,UAAU,CAAC,KAAK,gBAAgB,UAAU,CAAC,OAAO,eAAe,KAAK,CAAC,MAAM,EAAE,CACrG,CAAC;gBACF,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,qBAAqB,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;YACxE,CAAC;QACH,CAAC;IACH,CAAC,CAAC;IAEF;;;;;OAKG;IACH,WAAW,GAAG,KAAK,EAAE,KAAa,EAAE,SAAiB,EAAE,EAAE;QACvD,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,kCAAkC,KAAK,mBAAmB,SAAS,EAAE,CACtE,CAAC;QACF,MAAM,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC;YACrC,KAAK,EAAE,KAAK;YACZ,SAAS,EAAE,SAAS;SACrB,CAAC,CAAC;QACH,MAAM,IAAI,CAAC,oBAAoB,CAAC,MAAM,CACpC,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,EAC3C;YACE,UAAU,EAAE,IAAI;YAChB,WAAW,EAAE,IAAI;YACjB,SAAS,EAAE,IAAI;YACf,UAAU,EAAE,IAAI;SACjB,CACF,CAAC;IACJ,CAAC,CAAC;CACH;AAED,eAAe,gBAAgB,CAAC","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 {
|
|
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
|
|
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<
|
|
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,
|
|
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"}
|