@rosen-bridge/watcher-data-extractor 12.1.4 → 12.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (83) hide show
  1. package/CHANGELOG.md +273 -0
  2. package/dist/actions/EventTriggerAction.d.ts +2 -2
  3. package/dist/actions/EventTriggerAction.d.ts.map +1 -1
  4. package/dist/actions/EventTriggerAction.js +2 -2
  5. package/dist/actions/collateralAction.d.ts +3 -3
  6. package/dist/actions/collateralAction.d.ts.map +1 -1
  7. package/dist/actions/collateralAction.js +2 -2
  8. package/dist/actions/commitmentAction.d.ts +1 -1
  9. package/dist/actions/commitmentAction.d.ts.map +1 -1
  10. package/dist/actions/commitmentAction.js +8 -3
  11. package/dist/actions/permitAction.d.ts +4 -4
  12. package/dist/actions/permitAction.d.ts.map +1 -1
  13. package/dist/actions/permitAction.js +2 -2
  14. package/dist/entities/CollateralEntity.d.ts.map +1 -1
  15. package/dist/entities/CollateralEntity.js +9 -9
  16. package/dist/entities/CommitmentEntity.d.ts.map +1 -1
  17. package/dist/entities/CommitmentEntity.js +12 -12
  18. package/dist/entities/EventTriggerEntity.js +18 -18
  19. package/dist/entities/PermitEntity.d.ts.map +1 -1
  20. package/dist/entities/PermitEntity.js +9 -9
  21. package/dist/extractor/EventTriggerExtractor.d.ts +2 -2
  22. package/dist/extractor/EventTriggerExtractor.d.ts.map +1 -1
  23. package/dist/extractor/EventTriggerExtractor.js +1 -1
  24. package/dist/extractor/collateralExtractor.d.ts +1 -1
  25. package/dist/extractor/collateralExtractor.d.ts.map +1 -1
  26. package/dist/extractor/collateralExtractor.js +1 -1
  27. package/dist/extractor/commitmentExtractor.d.ts +1 -1
  28. package/dist/extractor/commitmentExtractor.d.ts.map +1 -1
  29. package/dist/extractor/commitmentExtractor.js +1 -1
  30. package/dist/extractor/permitExtractor.d.ts +34 -34
  31. package/dist/extractor/permitExtractor.d.ts.map +1 -1
  32. package/dist/extractor/permitExtractor.js +1 -1
  33. package/dist/index.d.ts +0 -1
  34. package/dist/index.d.ts.map +1 -1
  35. package/dist/index.js +1 -2
  36. package/dist/migrations/index.d.ts +2 -2
  37. package/dist/migrations/index.d.ts.map +1 -1
  38. package/dist/migrations/postgres/1688554842087-migration.d.ts +1 -1
  39. package/dist/migrations/postgres/1688554842087-migration.d.ts.map +1 -1
  40. package/dist/migrations/postgres/1688554842087-migration.js +1 -1
  41. package/dist/migrations/postgres/1689175974257-migration.d.ts +1 -1
  42. package/dist/migrations/postgres/1689175974257-migration.d.ts.map +1 -1
  43. package/dist/migrations/postgres/1689175974257-migration.js +1 -1
  44. package/dist/migrations/postgres/1699874447928-migration.d.ts +1 -1
  45. package/dist/migrations/postgres/1699874447928-migration.d.ts.map +1 -1
  46. package/dist/migrations/postgres/1699874447928-migration.js +1 -1
  47. package/dist/migrations/postgres/1706610773315-migration.d.ts +1 -1
  48. package/dist/migrations/postgres/1706610773315-migration.d.ts.map +1 -1
  49. package/dist/migrations/postgres/1706610773315-migration.js +1 -1
  50. package/dist/migrations/postgres/1709388482275-migration.d.ts +1 -1
  51. package/dist/migrations/postgres/1709388482275-migration.d.ts.map +1 -1
  52. package/dist/migrations/postgres/1709388482275-migration.js +1 -1
  53. package/dist/migrations/postgres/1737785036299-migration.d.ts +1 -1
  54. package/dist/migrations/postgres/1737785036299-migration.d.ts.map +1 -1
  55. package/dist/migrations/postgres/1737785036299-migration.js +1 -1
  56. package/dist/migrations/postgres/1746354253000-migration.d.ts +1 -1
  57. package/dist/migrations/postgres/1746354253000-migration.d.ts.map +1 -1
  58. package/dist/migrations/postgres/1746354253000-migration.js +1 -1
  59. package/dist/migrations/sqlite/1688555766601-migration.d.ts +1 -1
  60. package/dist/migrations/sqlite/1688555766601-migration.d.ts.map +1 -1
  61. package/dist/migrations/sqlite/1688555766601-migration.js +1 -1
  62. package/dist/migrations/sqlite/1689175103163-migration.d.ts +1 -1
  63. package/dist/migrations/sqlite/1689175103163-migration.d.ts.map +1 -1
  64. package/dist/migrations/sqlite/1689175103163-migration.js +1 -1
  65. package/dist/migrations/sqlite/1699872205117-migration.d.ts +1 -1
  66. package/dist/migrations/sqlite/1699872205117-migration.d.ts.map +1 -1
  67. package/dist/migrations/sqlite/1699872205117-migration.js +1 -1
  68. package/dist/migrations/sqlite/1706610773176-migration.d.ts +1 -1
  69. package/dist/migrations/sqlite/1706610773176-migration.d.ts.map +1 -1
  70. package/dist/migrations/sqlite/1706610773176-migration.js +1 -1
  71. package/dist/migrations/sqlite/1709388134975-migration.d.ts +1 -1
  72. package/dist/migrations/sqlite/1709388134975-migration.d.ts.map +1 -1
  73. package/dist/migrations/sqlite/1709388134975-migration.js +1 -1
  74. package/dist/migrations/sqlite/1737547743177-migration.d.ts +1 -1
  75. package/dist/migrations/sqlite/1737547743177-migration.d.ts.map +1 -1
  76. package/dist/migrations/sqlite/1737547743177-migration.js +1 -1
  77. package/dist/migrations/sqlite/1746354254000-migration.d.ts +1 -1
  78. package/dist/migrations/sqlite/1746354254000-migration.d.ts.map +1 -1
  79. package/dist/migrations/sqlite/1746354254000-migration.js +1 -1
  80. package/dist/utils.d.ts +3 -3
  81. package/dist/utils.d.ts.map +1 -1
  82. package/dist/utils.js +1 -1
  83. package/package.json +28 -34
package/CHANGELOG.md ADDED
@@ -0,0 +1,273 @@
1
+ # @rosen-bridge/watcher-data-extractor
2
+
3
+ ## 12.2.1
4
+
5
+ ### Patch Changes
6
+
7
+ - Update dependencies
8
+ - @rosen-bridge/abstract-extractor@2.1.1
9
+ - @rosen-bridge/extended-typeorm@1.0.0
10
+ - @rosen-bridge/tokens@4.0.0
11
+ - @rosen-bridge/json-bigint@1.0.0
12
+ - @rosen-bridge/abstract-logger@3.0.0
13
+ - @rosen-clients/ergo-explorer@2.0.0
14
+
15
+ ## 12.2.0
16
+
17
+ ### Minor Changes
18
+
19
+ - Upgrade to Node.js version 22.18.0
20
+
21
+ ### Patch Changes
22
+
23
+ - Update dependencies
24
+ - @rosen-bridge/abstract-extractor@2.1.0
25
+ - @rosen-bridge/scanner-interfaces@0.2.0
26
+
27
+ ## 12.1.4
28
+
29
+ ### Patch Changes
30
+
31
+ - Update package license to MIT
32
+ - Update dependencies
33
+ - @rosen-bridge/abstract-extractor@2.0.3
34
+ - @rosen-bridge/scanner-interfaces@0.1.1
35
+
36
+ ## 12.1.3
37
+
38
+ ### Patch Changes
39
+
40
+ - Update network clients and ethers and rateLimitedAxios packages
41
+ - Update dependencies
42
+ - @rosen-bridge/abstract-extractor@2.0.2
43
+
44
+ ## 12.1.2
45
+
46
+ ### Patch Changes
47
+
48
+ - Use rate limiting methods using @rosen-bridge/rate-limited-axios to prevent overwhelming the endpoints
49
+ - Updated dependencies
50
+ - @rosen-bridge/abstract-extractor@2.0.1
51
+
52
+ ## 12.1.1
53
+
54
+ ### Patch Changes
55
+
56
+ - Fix event result extraction in EventTriggerExtractor
57
+ - Fix fraud result storage in database
58
+
59
+ ## 12.1.0
60
+
61
+ ### Minor Changes
62
+
63
+ - Unify and move shared interfaces and update all package dependencies
64
+ - Update extra information interfaces and extraction functions
65
+
66
+ ### Patch Changes
67
+
68
+ - Updated dependencies
69
+ - @rosen-bridge/abstract-extractor@2.0.0
70
+ - @rosen-bridge/tokens@3.1.0
71
+ - @rosen-bridge/rosen-extractor@7.2.2
72
+
73
+ ## 12.0.0
74
+
75
+ ### Major Changes
76
+
77
+ - Update tokens package to v3.0.0
78
+
79
+ ### Patch Changes
80
+
81
+ - Updated dependencies
82
+ - @rosen-bridge/scanner@5.1.0
83
+ - @rosen-bridge/abstract-extractor@1.0.2
84
+
85
+ ## 11.0.0
86
+
87
+ ### Major Changes
88
+
89
+ - Update tokens package version to 2.0.0
90
+
91
+ ## 10.0.1
92
+
93
+ ### Patch Changes
94
+
95
+ - Update node version to 20
96
+ - Updated dependencies
97
+ - @rosen-bridge/abstract-extractor@1.0.1
98
+ - @rosen-bridge/scanner@5.0.2
99
+
100
+ ## 10.0.0
101
+
102
+ ### Major Changes
103
+
104
+ - Update database entity and action to extend the abstract class
105
+
106
+ ### Minor Changes
107
+
108
+ - Update db action interface to support callbacks
109
+
110
+ ### Patch Changes
111
+
112
+ - Optimize `hasData` function not to deserialize all unrelated boxes
113
+ - Updated dependencies
114
+ - @rosen-bridge/abstract-extractor@1.0.0
115
+ - @rosen-bridge/scanner@5.0.1
116
+
117
+ ## 9.0.0
118
+
119
+ ### Major Changes
120
+
121
+ - Refactor event trigger extractor to extend abstract initializable class
122
+
123
+ ### Patch Changes
124
+
125
+ - Updated dependencies
126
+ - @rosen-bridge/scanner@5.0.0
127
+ - @rosen-bridge/abstract-extractor@0.3.1
128
+
129
+ ## 8.0.2
130
+
131
+ ### Patch Changes
132
+
133
+ - Updated dependencies
134
+ - @rosen-bridge/scanner@4.1.3
135
+
136
+ ## 8.0.1
137
+
138
+ ### Patch Changes
139
+
140
+ - improve event result extractor to avoid unnecessary errors
141
+
142
+ ## 8.0.0
143
+
144
+ ### Major Changes
145
+
146
+ - change paymentTxId format in R4 from hex string to string
147
+
148
+ ## 7.0.3
149
+
150
+ ### Patch Changes
151
+
152
+ - Updated dependencies
153
+ - @rosen-bridge/abstract-extractor@0.3.0
154
+ - @rosen-bridge/scanner@4.1.2
155
+
156
+ ## 7.0.2
157
+
158
+ ### Patch Changes
159
+
160
+ - Updated dependencies
161
+ - @rosen-bridge/scanner@4.1.1
162
+
163
+ ## 7.0.1
164
+
165
+ ### Patch Changes
166
+
167
+ - Updated dependencies
168
+ - @rosen-bridge/abstract-extractor@0.2.0
169
+ - @rosen-bridge/scanner@4.1.0
170
+
171
+ ## 7.0.0
172
+
173
+ ### Major Changes
174
+
175
+ - wrap rwtCount in CommitmentEntity
176
+ - add token map to commitmentExtractor constructor arguments
177
+
178
+ ## 6.0.5
179
+
180
+ ### Patch Changes
181
+
182
+ - Updated dependencies
183
+ - @rosen-bridge/abstract-extractor@0.1.5
184
+ - @rosen-bridge/scanner@4.0.5
185
+
186
+ ## 6.0.4
187
+
188
+ ### Patch Changes
189
+
190
+ - Updated dependencies
191
+ - @rosen-bridge/abstract-extractor@0.1.4
192
+ - @rosen-bridge/scanner@4.0.4
193
+
194
+ ## 6.0.3
195
+
196
+ ### Patch Changes
197
+
198
+ - Updated dependencies
199
+ - @rosen-bridge/abstract-extractor@0.1.3
200
+ - @rosen-bridge/scanner@4.0.3
201
+
202
+ ## 6.0.2
203
+
204
+ ### Patch Changes
205
+
206
+ - Updated dependencies
207
+ - @rosen-bridge/abstract-extractor@0.1.2
208
+ - @rosen-bridge/scanner@4.0.2
209
+
210
+ ## 6.0.1
211
+
212
+ ### Patch Changes
213
+
214
+ - Updated dependencies
215
+ - @rosen-bridge/abstract-extractor@0.1.1
216
+ - @rosen-bridge/scanner@4.0.1
217
+
218
+ ## 6.0.0
219
+
220
+ ### Major Changes
221
+
222
+ - Updated the InitializeBoxes interface to include the block hash. Previously, only block height was used as initialization point.
223
+
224
+ ### Patch Changes
225
+
226
+ - Update abstract extractor interface
227
+ - Updated dependencies
228
+ - @rosen-bridge/scanner@4.0.0
229
+
230
+ ## 5.1.3
231
+
232
+ ### Patch Changes
233
+
234
+ - Update Ergo explorer client
235
+ - Updated dependencies
236
+ - @rosen-bridge/scanner@3.2.9
237
+
238
+ ## 5.1.2
239
+
240
+ ### Patch Changes
241
+
242
+ - Updated dependencies
243
+ - @rosen-bridge/scanner@3.2.8
244
+
245
+ ## 5.1.1
246
+
247
+ ### Patch Changes
248
+
249
+ - Update typeorm version
250
+ - Updated dependencies
251
+ - @rosen-bridge/scanner@3.2.7
252
+
253
+ ## 5.1.0
254
+
255
+ ### Minor Changes
256
+
257
+ - implemented CollateralExtractor to validate and store collateral boxes
258
+
259
+ ### Patch Changes
260
+
261
+ - Fix spend height column in all entities
262
+
263
+ ## 5.0.1
264
+
265
+ ### Patch Changes
266
+
267
+ - fix WIDsHash calculation in migrations
268
+
269
+ ## 5.0.0
270
+
271
+ ### Major Changes
272
+
273
+ - update extractors according to latest version of contracts
@@ -1,4 +1,4 @@
1
- import { DataSource } from 'typeorm';
1
+ import { DataSource } from '@rosen-bridge/extended-typeorm';
2
2
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
3
3
  import { AbstractInitializableErgoExtractorAction, BoxInfo, SpendInfo } from '@rosen-bridge/abstract-extractor';
4
4
  import { BlockInfo } from '@rosen-bridge/scanner-interfaces';
@@ -10,7 +10,7 @@ declare class EventTriggerAction extends AbstractInitializableErgoExtractorActio
10
10
  /**
11
11
  * create the box entity from extracted data and block information
12
12
  */
13
- createEntity: (triggerBoxes: ExtractedEventTrigger[], block: BlockInfo, extractor: string) => Omit<EventTriggerEntity, 'id'>[];
13
+ createEntity: (triggerBoxes: ExtractedEventTrigger[], block: BlockInfo, extractor: string) => Omit<EventTriggerEntity, "id">[];
14
14
  /**
15
15
  * convert the database entity back to raw data
16
16
  */
@@ -1 +1 @@
1
- {"version":3,"file":"EventTriggerAction.d.ts","sourceRoot":"","sources":["../../lib/actions/EventTriggerAction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAM,MAAM,SAAS,CAAC;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EACL,wCAAwC,EACxC,OAAO,EAEP,SAAS,EACV,MAAM,kCAAkC,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,kCAAkC,CAAC;AAE7D,OAAO,kBAAkB,MAAM,gCAAgC,CAAC;AAChE,OAAO,EAAE,qBAAqB,EAAE,MAAM,qCAAqC,CAAC;AAI5E,cAAM,kBAAmB,SAAQ,wCAAwC,CACvE,qBAAqB,EACrB,kBAAkB,CACnB;IACC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;gBAE5B,UAAU,EAAE,UAAU,EAAE,MAAM,CAAC,EAAE,cAAc;IAK3D;;OAEG;IACH,YAAY,iBACI,qBAAqB,EAAE,SAC9B,SAAS,aACL,MAAM,KAChB,KAAK,kBAAkB,EAAE,IAAI,CAAC,EAAE,CAwBjC;IAEF;;OAEG;IACH,mBAAmB,aACP,kBAAkB,EAAE,KAC7B,qBAAqB,EAAE,CAuBxB;IAEF;;;;;;;;OAQG;IACH,UAAU,mBACQ,MAAM,SAAS,CAAC,SACzB,SAAS,eACH,MAAM,KAClB,QAAQ,OAAO,EAAE,CAAC,CAyCnB;CACH;AAED,eAAe,kBAAkB,CAAC"}
1
+ {"version":3,"file":"EventTriggerAction.d.ts","sourceRoot":"","sources":["../../lib/actions/EventTriggerAction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAM,MAAM,gCAAgC,CAAC;AAChE,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EACL,wCAAwC,EACxC,OAAO,EAEP,SAAS,EACV,MAAM,kCAAkC,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,kCAAkC,CAAC;AAE7D,OAAO,kBAAkB,MAAM,gCAAgC,CAAC;AAChE,OAAO,EAAE,qBAAqB,EAAE,MAAM,qCAAqC,CAAC;AAI5E,cAAM,kBAAmB,SAAQ,wCAAwC,CACvE,qBAAqB,EACrB,kBAAkB,CACnB;IACC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;gBAE5B,UAAU,EAAE,UAAU,EAAE,MAAM,CAAC,EAAE,cAAc;IAK3D;;OAEG;IACH,YAAY,GACV,cAAc,qBAAqB,EAAE,EACrC,OAAO,SAAS,EAChB,WAAW,MAAM,KAChB,IAAI,CAAC,kBAAkB,EAAE,IAAI,CAAC,EAAE,CAwBjC;IAEF;;OAEG;IACH,mBAAmB,GACjB,UAAU,kBAAkB,EAAE,KAC7B,qBAAqB,EAAE,CAuBxB;IAEF;;;;;;;;OAQG;IACH,UAAU,GACR,gBAAgB,KAAK,CAAC,SAAS,CAAC,EAChC,OAAO,SAAS,EAChB,aAAa,MAAM,KAClB,OAAO,CAAC,OAAO,EAAE,CAAC,CAyCnB;CACH;AAED,eAAe,kBAAkB,CAAC"}
@@ -1,4 +1,4 @@
1
- import { In } from 'typeorm';
1
+ import { In } from '@rosen-bridge/extended-typeorm';
2
2
  import { AbstractInitializableErgoExtractorAction, DB_CHUNK_SIZE, } from '@rosen-bridge/abstract-extractor';
3
3
  import EventTriggerEntity from '../entities/EventTriggerEntity';
4
4
  import { JsonBI } from '../utils';
@@ -100,4 +100,4 @@ class EventTriggerAction extends AbstractInitializableErgoExtractorAction {
100
100
  };
101
101
  }
102
102
  export default EventTriggerAction;
103
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"EventTriggerAction.js","sourceRoot":"","sources":["../../lib/actions/EventTriggerAction.ts"],"names":[],"mappings":"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","sourcesContent":["import { DataSource, In } from 'typeorm';\nimport { AbstractLogger } from '@rosen-bridge/abstract-logger';\nimport {\n  AbstractInitializableErgoExtractorAction,\n  BoxInfo,\n  DB_CHUNK_SIZE,\n  SpendInfo,\n} from '@rosen-bridge/abstract-extractor';\nimport { BlockInfo } from '@rosen-bridge/scanner-interfaces';\n\nimport EventTriggerEntity from '../entities/EventTriggerEntity';\nimport { ExtractedEventTrigger } from '../interfaces/extractedEventTrigger';\nimport { JsonBI } from '../utils';\nimport { chunk, pick } from 'lodash-es';\n\nclass EventTriggerAction extends AbstractInitializableErgoExtractorAction<\n  ExtractedEventTrigger,\n  EventTriggerEntity\n> {\n  private readonly dataSource: DataSource;\n\n  constructor(dataSource: DataSource, logger?: AbstractLogger) {\n    super(dataSource, EventTriggerEntity, logger);\n    this.dataSource = dataSource;\n  }\n\n  /**\n   * create the box entity from extracted data and block information\n   */\n  createEntity = (\n    triggerBoxes: ExtractedEventTrigger[],\n    block: BlockInfo,\n    extractor: string\n  ): Omit<EventTriggerEntity, 'id'>[] => {\n    return triggerBoxes.map((trigger) => ({\n      txId: trigger.txId,\n      eventId: trigger.eventId,\n      boxId: trigger.boxId,\n      serialized: trigger.serialized,\n      block: block.hash,\n      height: block.height,\n      extractor: extractor,\n      WIDsCount: trigger.WIDsCount,\n      WIDsHash: trigger.WIDsHash,\n      amount: trigger.amount,\n      bridgeFee: trigger.bridgeFee,\n      fromAddress: trigger.fromAddress,\n      toAddress: trigger.toAddress,\n      fromChain: trigger.fromChain,\n      networkFee: trigger.networkFee,\n      sourceChainTokenId: trigger.sourceChainTokenId,\n      targetChainTokenId: trigger.targetChainTokenId,\n      sourceBlockId: trigger.sourceBlockId,\n      toChain: trigger.toChain,\n      sourceTxId: trigger.sourceTxId,\n      sourceChainHeight: trigger.sourceChainHeight,\n    }));\n  };\n\n  /**\n   * convert the database entity back to raw data\n   */\n  convertEntityToData = (\n    entities: EventTriggerEntity[]\n  ): ExtractedEventTrigger[] => {\n    return entities.map((data) =>\n      pick(data, [\n        'eventId',\n        'txId',\n        'boxId',\n        'serialized',\n        'fromChain',\n        'toChain',\n        'fromAddress',\n        'toAddress',\n        'amount',\n        'bridgeFee',\n        'networkFee',\n        'sourceChainTokenId',\n        'targetChainTokenId',\n        'sourceBlockId',\n        'sourceTxId',\n        'WIDsCount',\n        'WIDsHash',\n        'sourceChainHeight',\n      ])\n    );\n  };\n\n  /**\n   * update spending information of stored event triggers\n   * and set result and paymentTxId of the event\n   * chunk spendInfos to prevent large database queries\n   * @param spendInfArray\n   * @param block\n   * @param extractorId\n   * @returns spent box ids\n   */\n  spendBoxes = async (\n    spendInfoArray: Array<SpendInfo>,\n    block: BlockInfo,\n    extractorId: string\n  ): Promise<BoxInfo[]> => {\n    const spentData = [];\n    const spendInfoChunks = chunk(spendInfoArray, DB_CHUNK_SIZE);\n    for (const spendInfoChunk of spendInfoChunks) {\n      const spentTriggers = await this.repository.findBy({\n        boxId: In(spendInfoChunk.map((spendInfo) => spendInfo.boxId)),\n        extractor: extractorId,\n      });\n      for (const spentTrigger of spentTriggers) {\n        const spendInfo = spendInfoChunk.find(\n          (info) => info.boxId === spentTrigger.boxId\n        );\n        if (!spendInfo || !spendInfo.extras || !spendInfo.extras.result) {\n          throw Error(\n            `Impossible case: spending information extras does not contain result, ${JsonBI.stringify(\n              spendInfo\n            )}`\n          );\n        }\n        await this.repository.update(\n          { boxId: spendInfo.boxId, extractor: extractorId },\n          {\n            spendBlock: block.hash,\n            spendHeight: block.height,\n            spendTxId: spendInfo.txId,\n            result: spendInfo.extras.result,\n            paymentTxId: spendInfo.extras.paymentTxId || '',\n          }\n        );\n        spentData.push(pick(spendInfo, ['boxId']));\n        this.logger.info(\n          `Spent trigger [${spentTrigger.boxId}] of event [${spentTrigger.eventId}] at height ${block.height}`\n        );\n        this.logger.debug(\n          `Spent trigger: [${JSON.stringify(\n            spentTrigger\n          )}] with spending information [${JsonBI.stringify(spendInfo)}]`\n        );\n      }\n    }\n    return spentData;\n  };\n}\n\nexport default EventTriggerAction;\n"]}
103
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"EventTriggerAction.js","sourceRoot":"","sources":["../../lib/actions/EventTriggerAction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,EAAE,EAAE,MAAM,gCAAgC,CAAC;AAEhE,OAAO,EACL,wCAAwC,EAExC,aAAa,GAEd,MAAM,kCAAkC,CAAC;AAG1C,OAAO,kBAAkB,MAAM,gCAAgC,CAAC;AAEhE,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAExC,MAAM,kBAAmB,SAAQ,wCAGhC;IACkB,UAAU,CAAa;IAExC,YAAY,UAAsB,EAAE,MAAuB;QACzD,KAAK,CAAC,UAAU,EAAE,kBAAkB,EAAE,MAAM,CAAC,CAAC;QAC9C,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IAC/B,CAAC;IAED;;OAEG;IACH,YAAY,GAAG,CACb,YAAqC,EACrC,KAAgB,EAChB,SAAiB,EACiB,EAAE;QACpC,OAAO,YAAY,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;YACpC,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,KAAK,EAAE,OAAO,CAAC,KAAK;YACpB,UAAU,EAAE,OAAO,CAAC,UAAU;YAC9B,KAAK,EAAE,KAAK,CAAC,IAAI;YACjB,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,SAAS,EAAE,SAAS;YACpB,SAAS,EAAE,OAAO,CAAC,SAAS;YAC5B,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,MAAM,EAAE,OAAO,CAAC,MAAM;YACtB,SAAS,EAAE,OAAO,CAAC,SAAS;YAC5B,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,SAAS,EAAE,OAAO,CAAC,SAAS;YAC5B,SAAS,EAAE,OAAO,CAAC,SAAS;YAC5B,UAAU,EAAE,OAAO,CAAC,UAAU;YAC9B,kBAAkB,EAAE,OAAO,CAAC,kBAAkB;YAC9C,kBAAkB,EAAE,OAAO,CAAC,kBAAkB;YAC9C,aAAa,EAAE,OAAO,CAAC,aAAa;YACpC,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,UAAU,EAAE,OAAO,CAAC,UAAU;YAC9B,iBAAiB,EAAE,OAAO,CAAC,iBAAiB;SAC7C,CAAC,CAAC,CAAC;IACN,CAAC,CAAC;IAEF;;OAEG;IACH,mBAAmB,GAAG,CACpB,QAA8B,EACL,EAAE;QAC3B,OAAO,QAAQ,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAC3B,IAAI,CAAC,IAAI,EAAE;YACT,SAAS;YACT,MAAM;YACN,OAAO;YACP,YAAY;YACZ,WAAW;YACX,SAAS;YACT,aAAa;YACb,WAAW;YACX,QAAQ;YACR,WAAW;YACX,YAAY;YACZ,oBAAoB;YACpB,oBAAoB;YACpB,eAAe;YACf,YAAY;YACZ,WAAW;YACX,UAAU;YACV,mBAAmB;SACpB,CAAC,CACH,CAAC;IACJ,CAAC,CAAC;IAEF;;;;;;;;OAQG;IACH,UAAU,GAAG,KAAK,EAChB,cAAgC,EAChC,KAAgB,EAChB,WAAmB,EACC,EAAE;QACtB,MAAM,SAAS,GAAG,EAAE,CAAC;QACrB,MAAM,eAAe,GAAG,KAAK,CAAC,cAAc,EAAE,aAAa,CAAC,CAAC;QAC7D,KAAK,MAAM,cAAc,IAAI,eAAe,EAAE,CAAC;YAC7C,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC;gBACjD,KAAK,EAAE,EAAE,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;gBAC7D,SAAS,EAAE,WAAW;aACvB,CAAC,CAAC;YACH,KAAK,MAAM,YAAY,IAAI,aAAa,EAAE,CAAC;gBACzC,MAAM,SAAS,GAAG,cAAc,CAAC,IAAI,CACnC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,KAAK,YAAY,CAAC,KAAK,CAC5C,CAAC;gBACF,IAAI,CAAC,SAAS,IAAI,CAAC,SAAS,CAAC,MAAM,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;oBAChE,MAAM,KAAK,CACT,yEAAyE,MAAM,CAAC,SAAS,CACvF,SAAS,CACV,EAAE,CACJ,CAAC;gBACJ,CAAC;gBACD,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,CAC1B,EAAE,KAAK,EAAE,SAAS,CAAC,KAAK,EAAE,SAAS,EAAE,WAAW,EAAE,EAClD;oBACE,UAAU,EAAE,KAAK,CAAC,IAAI;oBACtB,WAAW,EAAE,KAAK,CAAC,MAAM;oBACzB,SAAS,EAAE,SAAS,CAAC,IAAI;oBACzB,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,MAAM;oBAC/B,WAAW,EAAE,SAAS,CAAC,MAAM,CAAC,WAAW,IAAI,EAAE;iBAChD,CACF,CAAC;gBACF,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;gBAC3C,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,kBAAkB,YAAY,CAAC,KAAK,eAAe,YAAY,CAAC,OAAO,eAAe,KAAK,CAAC,MAAM,EAAE,CACrG,CAAC;gBACF,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,mBAAmB,IAAI,CAAC,SAAS,CAC/B,YAAY,CACb,gCAAgC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,CAChE,CAAC;YACJ,CAAC;QACH,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC,CAAC;CACH;AAED,eAAe,kBAAkB,CAAC","sourcesContent":["import { DataSource, In } from '@rosen-bridge/extended-typeorm';\nimport { AbstractLogger } from '@rosen-bridge/abstract-logger';\nimport {\n  AbstractInitializableErgoExtractorAction,\n  BoxInfo,\n  DB_CHUNK_SIZE,\n  SpendInfo,\n} from '@rosen-bridge/abstract-extractor';\nimport { BlockInfo } from '@rosen-bridge/scanner-interfaces';\n\nimport EventTriggerEntity from '../entities/EventTriggerEntity';\nimport { ExtractedEventTrigger } from '../interfaces/extractedEventTrigger';\nimport { JsonBI } from '../utils';\nimport { chunk, pick } from 'lodash-es';\n\nclass EventTriggerAction extends AbstractInitializableErgoExtractorAction<\n  ExtractedEventTrigger,\n  EventTriggerEntity\n> {\n  private readonly dataSource: DataSource;\n\n  constructor(dataSource: DataSource, logger?: AbstractLogger) {\n    super(dataSource, EventTriggerEntity, logger);\n    this.dataSource = dataSource;\n  }\n\n  /**\n   * create the box entity from extracted data and block information\n   */\n  createEntity = (\n    triggerBoxes: ExtractedEventTrigger[],\n    block: BlockInfo,\n    extractor: string,\n  ): Omit<EventTriggerEntity, 'id'>[] => {\n    return triggerBoxes.map((trigger) => ({\n      txId: trigger.txId,\n      eventId: trigger.eventId,\n      boxId: trigger.boxId,\n      serialized: trigger.serialized,\n      block: block.hash,\n      height: block.height,\n      extractor: extractor,\n      WIDsCount: trigger.WIDsCount,\n      WIDsHash: trigger.WIDsHash,\n      amount: trigger.amount,\n      bridgeFee: trigger.bridgeFee,\n      fromAddress: trigger.fromAddress,\n      toAddress: trigger.toAddress,\n      fromChain: trigger.fromChain,\n      networkFee: trigger.networkFee,\n      sourceChainTokenId: trigger.sourceChainTokenId,\n      targetChainTokenId: trigger.targetChainTokenId,\n      sourceBlockId: trigger.sourceBlockId,\n      toChain: trigger.toChain,\n      sourceTxId: trigger.sourceTxId,\n      sourceChainHeight: trigger.sourceChainHeight,\n    }));\n  };\n\n  /**\n   * convert the database entity back to raw data\n   */\n  convertEntityToData = (\n    entities: EventTriggerEntity[],\n  ): ExtractedEventTrigger[] => {\n    return entities.map((data) =>\n      pick(data, [\n        'eventId',\n        'txId',\n        'boxId',\n        'serialized',\n        'fromChain',\n        'toChain',\n        'fromAddress',\n        'toAddress',\n        'amount',\n        'bridgeFee',\n        'networkFee',\n        'sourceChainTokenId',\n        'targetChainTokenId',\n        'sourceBlockId',\n        'sourceTxId',\n        'WIDsCount',\n        'WIDsHash',\n        'sourceChainHeight',\n      ]),\n    );\n  };\n\n  /**\n   * update spending information of stored event triggers\n   * and set result and paymentTxId of the event\n   * chunk spendInfos to prevent large database queries\n   * @param spendInfArray\n   * @param block\n   * @param extractorId\n   * @returns spent box ids\n   */\n  spendBoxes = async (\n    spendInfoArray: Array<SpendInfo>,\n    block: BlockInfo,\n    extractorId: string,\n  ): Promise<BoxInfo[]> => {\n    const spentData = [];\n    const spendInfoChunks = chunk(spendInfoArray, DB_CHUNK_SIZE);\n    for (const spendInfoChunk of spendInfoChunks) {\n      const spentTriggers = await this.repository.findBy({\n        boxId: In(spendInfoChunk.map((spendInfo) => spendInfo.boxId)),\n        extractor: extractorId,\n      });\n      for (const spentTrigger of spentTriggers) {\n        const spendInfo = spendInfoChunk.find(\n          (info) => info.boxId === spentTrigger.boxId,\n        );\n        if (!spendInfo || !spendInfo.extras || !spendInfo.extras.result) {\n          throw Error(\n            `Impossible case: spending information extras does not contain result, ${JsonBI.stringify(\n              spendInfo,\n            )}`,\n          );\n        }\n        await this.repository.update(\n          { boxId: spendInfo.boxId, extractor: extractorId },\n          {\n            spendBlock: block.hash,\n            spendHeight: block.height,\n            spendTxId: spendInfo.txId,\n            result: spendInfo.extras.result,\n            paymentTxId: spendInfo.extras.paymentTxId || '',\n          },\n        );\n        spentData.push(pick(spendInfo, ['boxId']));\n        this.logger.info(\n          `Spent trigger [${spentTrigger.boxId}] of event [${spentTrigger.eventId}] at height ${block.height}`,\n        );\n        this.logger.debug(\n          `Spent trigger: [${JSON.stringify(\n            spentTrigger,\n          )}] with spending information [${JsonBI.stringify(spendInfo)}]`,\n        );\n      }\n    }\n    return spentData;\n  };\n}\n\nexport default EventTriggerAction;\n"]}
@@ -1,5 +1,5 @@
1
1
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
2
- import { DataSource, DeleteResult } from 'typeorm';
2
+ import { DataSource, DeleteResult } from '@rosen-bridge/extended-typeorm';
3
3
  import { Block } from '@rosen-bridge/scanner-interfaces';
4
4
  import { ExtractedCollateral } from '../interfaces/extractedCollateral';
5
5
  import { SpendInfo } from '../interfaces/types';
@@ -15,7 +15,7 @@ declare class CollateralAction {
15
15
  * @param {string} extractor
16
16
  * @memberof CollateralAction
17
17
  */
18
- insertCollateral: (collateral: ExtractedCollateral, extractor: string) => Promise<import("typeorm").InsertResult>;
18
+ insertCollateral: (collateral: ExtractedCollateral, extractor: string) => Promise<import("@rosen-bridge/extended-typeorm").InsertResult>;
19
19
  /**
20
20
  * updates a collateral into the database
21
21
  *
@@ -23,7 +23,7 @@ declare class CollateralAction {
23
23
  * @param {string} extractor
24
24
  * @memberof CollateralAction
25
25
  */
26
- updateCollateral: (collateral: Partial<ExtractedCollateral> & Pick<ExtractedCollateral, 'boxId'>, extractor: string) => Promise<import("typeorm").UpdateResult>;
26
+ updateCollateral: (collateral: Partial<ExtractedCollateral> & Pick<ExtractedCollateral, "boxId">, extractor: string) => Promise<import("@rosen-bridge/extended-typeorm").UpdateResult>;
27
27
  /**
28
28
  * stores list of collaterals
29
29
  *
@@ -1 +1 @@
1
- {"version":3,"file":"collateralAction.d.ts","sourceRoot":"","sources":["../../lib/actions/collateralAction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAG5E,OAAO,EAAE,UAAU,EAAE,YAAY,EAA0B,MAAM,SAAS,CAAC;AAC3E,OAAO,EAAE,KAAK,EAAE,MAAM,kCAAkC,CAAC;AAGzD,OAAO,EAAE,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AACxE,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAEhD,cAAM,gBAAgB;IAIlB,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,QAAQ,CAAC,MAAM,EAAE,cAAc;IAJjC,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAA+B;gBAGjD,UAAU,EAAE,UAAU,EAC9B,MAAM,GAAE,cAAkC;IAKrD;;;;;;OAMG;IACH,gBAAgB,eACF,mBAAmB,aACpB,MAAM,6CAMjB;IAEF;;;;;;OAMG;IACH,gBAAgB,eACF,QAAQ,mBAAmB,CAAC,GACtC,KAAK,mBAAmB,EAAE,OAAO,CAAC,aACzB,MAAM,6CASjB;IAEF;;;;;;;;OAQG;IACH,gBAAgB,gBACD,MAAM,mBAAmB,CAAC,SAChC,KAAK,aACD,MAAM,KAChB,QAAQ,OAAO,CAAC,CAwFjB;IAEF;;;;;;;;OAQG;IACH,gBAAgB,eACF,MAAM,SAAS,CAAC,SACrB,KAAK,aACD,MAAM,KAChB,QAAQ,IAAI,CAAC,CA0Bd;IAEF;;;;;;OAMG;IACH,0BAA0B,cACb,MAAM,KAChB,QAAQ,MAAM,MAAM,CAAC,CAAC,CAWvB;IAEF;;;;;;;;OAQG;IACG,WAAW,CAAC,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAwBlE;;;;;;;OAOG;IACH,gBAAgB,UACP,MAAM,aACF,MAAM,KAChB,QAAQ,YAAY,CAAC,CAKtB;CACH;AAED,eAAe,gBAAgB,CAAC"}
1
+ {"version":3,"file":"collateralAction.d.ts","sourceRoot":"","sources":["../../lib/actions/collateralAction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAG5E,OAAO,EACL,UAAU,EACV,YAAY,EAIb,MAAM,gCAAgC,CAAC;AACxC,OAAO,EAAE,KAAK,EAAE,MAAM,kCAAkC,CAAC;AAGzD,OAAO,EAAE,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AACxE,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAEhD,cAAM,gBAAgB;IAIlB,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,QAAQ,CAAC,MAAM,EAAE,cAAc;IAJjC,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAA+B;gBAGjD,UAAU,EAAE,UAAU,EAC9B,MAAM,GAAE,cAAkC;IAKrD;;;;;;OAMG;IACH,gBAAgB,GACd,YAAY,mBAAmB,EAC/B,WAAW,MAAM,oEAMjB;IAEF;;;;;;OAMG;IACH,gBAAgB,GACd,YAAY,OAAO,CAAC,mBAAmB,CAAC,GACtC,IAAI,CAAC,mBAAmB,EAAE,OAAO,CAAC,EACpC,WAAW,MAAM,oEASjB;IAEF;;;;;;;;OAQG;IACH,gBAAgB,GACd,aAAa,KAAK,CAAC,mBAAmB,CAAC,EACvC,OAAO,KAAK,EACZ,WAAW,MAAM,KAChB,OAAO,CAAC,OAAO,CAAC,CAuFjB;IAEF;;;;;;;;OAQG;IACH,gBAAgB,GACd,YAAY,KAAK,CAAC,SAAS,CAAC,EAC5B,OAAO,KAAK,EACZ,WAAW,MAAM,KAChB,OAAO,CAAC,IAAI,CAAC,CA0Bd;IAEF;;;;;;OAMG;IACH,0BAA0B,GACxB,WAAW,MAAM,KAChB,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAWvB;IAEF;;;;;;;;OAQG;IACG,WAAW,CAAC,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAwBlE;;;;;;;OAOG;IACH,gBAAgB,GACd,OAAO,MAAM,EACb,WAAW,MAAM,KAChB,OAAO,CAAC,YAAY,CAAC,CAKtB;CACH;AAED,eAAe,gBAAgB,CAAC"}
@@ -1,7 +1,7 @@
1
1
  import { DummyLogger } from '@rosen-bridge/abstract-logger';
2
2
  import JsonBigInt from '@rosen-bridge/json-bigint';
3
3
  import { difference } from 'lodash-es';
4
- import { In, IsNull } from 'typeorm';
4
+ import { In, IsNull, } from '@rosen-bridge/extended-typeorm';
5
5
  import CollateralEntity from '../entities/CollateralEntity';
6
6
  class CollateralAction {
7
7
  dataSource;
@@ -191,4 +191,4 @@ class CollateralAction {
191
191
  };
192
192
  }
193
193
  export default CollateralAction;
194
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collateralAction.js","sourceRoot":"","sources":["../../lib/actions/collateralAction.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport JsonBigInt from '@rosen-bridge/json-bigint';\nimport { difference } from 'lodash-es';\nimport { DataSource, DeleteResult, In, IsNull, Repository } from 'typeorm';\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 = await queryRunner.manager.getRepository(\n        CollateralEntity\n      );\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"]}
194
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collateralAction.js","sourceRoot":"","sources":["../../lib/actions/collateralAction.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport JsonBigInt from '@rosen-bridge/json-bigint';\nimport { difference } from 'lodash-es';\nimport {\n  DataSource,\n  DeleteResult,\n  In,\n  IsNull,\n  Repository,\n} from '@rosen-bridge/extended-typeorm';\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"]}
@@ -1,4 +1,4 @@
1
- import { DataSource } from 'typeorm';
1
+ import { DataSource } from '@rosen-bridge/extended-typeorm';
2
2
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
3
3
  import { Block } from '@rosen-bridge/scanner-interfaces';
4
4
  import { extractedCommitment } from '../interfaces/extractedCommitment';
@@ -1 +1 @@
1
- {"version":3,"file":"commitmentAction.d.ts","sourceRoot":"","sources":["../../lib/actions/commitmentAction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAkB,MAAM,SAAS,CAAC;AAErD,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,KAAK,EAAE,MAAM,kCAAkC,CAAC;AAEzD,OAAO,EAAE,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AAGxE,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,gBACD,MAAM,mBAAmB,CAAC,SAChC,KAAK,aACD,MAAM,KAChB,QAAQ,OAAO,CAAC,CAuDjB;IAEF;;;;;OAKG;IACH,gBAAgB,YACL,MAAM,SAAS,CAAC,SAClB,KAAK,aACD,MAAM,KAChB,QAAQ,IAAI,CAAC,CAmCd;IAEF;;;;;OAKG;IACH,WAAW,UAAiB,MAAM,aAAa,MAAM,mBAYnD;CACH;AAED,eAAe,gBAAgB,CAAC"}
1
+ {"version":3,"file":"commitmentAction.d.ts","sourceRoot":"","sources":["../../lib/actions/commitmentAction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAkB,MAAM,gCAAgC,CAAC;AAE5E,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,KAAK,EAAE,MAAM,kCAAkC,CAAC;AAEzD,OAAO,EAAE,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AAGxE,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAEhD,cAAM,gBAAgB;IACpB,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC;IAChC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;IACxC,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAA+B;gBAExD,UAAU,EAAE,UAAU,EAAE,MAAM,CAAC,EAAE,cAAc;IAM3D;;;;;OAKG;IACH,gBAAgB,GACd,aAAa,KAAK,CAAC,mBAAmB,CAAC,EACvC,OAAO,KAAK,EACZ,WAAW,MAAM,KAChB,OAAO,CAAC,OAAO,CAAC,CAsDjB;IAEF;;;;;OAKG;IACH,gBAAgB,GACd,SAAS,KAAK,CAAC,SAAS,CAAC,EACzB,OAAO,KAAK,EACZ,WAAW,MAAM,KAChB,OAAO,CAAC,IAAI,CAAC,CAmCd;IAEF;;;;;OAKG;IACH,WAAW,GAAU,OAAO,MAAM,EAAE,WAAW,MAAM,mBAiBnD;CACH;AAED,eAAe,gBAAgB,CAAC"}
@@ -1,4 +1,4 @@
1
- import { In } from 'typeorm';
1
+ import { In } from '@rosen-bridge/extended-typeorm';
2
2
  import { chunk } from 'lodash-es';
3
3
  import { DummyLogger } from '@rosen-bridge/abstract-logger';
4
4
  import CommitmentEntity from '../entities/CommitmentEntity';
@@ -113,8 +113,13 @@ class CommitmentAction {
113
113
  block: block,
114
114
  extractor: extractor,
115
115
  });
116
- await this.commitmentRepository.update({ spendBlock: block, extractor: extractor }, { spendBlock: null, spendHeight: null, spendTxId: null, spendIndex: null });
116
+ await this.commitmentRepository.update({ spendBlock: block, extractor: extractor }, {
117
+ spendBlock: null,
118
+ spendHeight: null,
119
+ spendTxId: null,
120
+ spendIndex: null,
121
+ });
117
122
  };
118
123
  }
119
124
  export default CommitmentAction;
120
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"commitmentAction.js","sourceRoot":"","sources":["../../lib/actions/commitmentAction.ts"],"names":[],"mappings":"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","sourcesContent":["import { DataSource, In, Repository } from 'typeorm';\nimport { chunk } from 'lodash-es';\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport { Block } from '@rosen-bridge/scanner-interfaces';\n\nimport { extractedCommitment } from '../interfaces/extractedCommitment';\nimport CommitmentEntity from '../entities/CommitmentEntity';\nimport { dbIdChunkSize } from '../constants';\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 = await queryRunner.manager.getRepository(\n      CommitmentEntity\n    );\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      { spendBlock: null, spendHeight: null, spendTxId: null, spendIndex: null }\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 { DataSource, In, Repository } from '@rosen-bridge/extended-typeorm';\nimport { chunk } from 'lodash-es';\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport { Block } from '@rosen-bridge/scanner-interfaces';\n\nimport { extractedCommitment } from '../interfaces/extractedCommitment';\nimport CommitmentEntity from '../entities/CommitmentEntity';\nimport { dbIdChunkSize } from '../constants';\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"]}
@@ -1,4 +1,4 @@
1
- import { DataSource } from 'typeorm';
1
+ import { DataSource } from '@rosen-bridge/extended-typeorm';
2
2
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
3
3
  import { Block } from '@rosen-bridge/scanner-interfaces';
4
4
  import { ExtractedPermit } from '../interfaces/extractedPermit';
@@ -13,7 +13,7 @@ declare class PermitAction {
13
13
  * @param initialHeight
14
14
  * @param extractor
15
15
  */
16
- insertPermit: (permit: ExtractedPermit, extractor: string) => Promise<import("typeorm").InsertResult>;
16
+ insertPermit: (permit: ExtractedPermit, extractor: string) => Promise<import("@rosen-bridge/extended-typeorm").InsertResult>;
17
17
  /**
18
18
  * update an unspent permit in the database
19
19
  * @param permit
@@ -50,7 +50,7 @@ declare class PermitAction {
50
50
  * @param boxId
51
51
  * @param extractor
52
52
  */
53
- removePermit: (boxId: string, extractor: string) => Promise<import("typeorm").DeleteResult>;
53
+ removePermit: (boxId: string, extractor: string) => Promise<import("@rosen-bridge/extended-typeorm").DeleteResult>;
54
54
  /**
55
55
  * Update the permit spending information
56
56
  * @param boxId
@@ -58,7 +58,7 @@ declare class PermitAction {
58
58
  * @param blockId
59
59
  * @param blockHeight
60
60
  */
61
- updateSpendBlock: (boxId: string, extractor: string, blockId: string, blockHeight: number) => Promise<import("typeorm").UpdateResult>;
61
+ updateSpendBlock: (boxId: string, extractor: string, blockId: string, blockHeight: number) => Promise<import("@rosen-bridge/extended-typeorm").UpdateResult>;
62
62
  }
63
63
  export default PermitAction;
64
64
  //# sourceMappingURL=permitAction.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"permitAction.d.ts","sourceRoot":"","sources":["../../lib/actions/permitAction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAkB,MAAM,SAAS,CAAC;AAErD,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,KAAK,EAAE,MAAM,kCAAkC,CAAC;AAEzD,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAIhE,cAAM,YAAY;IAChB,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC;IAChC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;IACxC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAA2B;gBAEhD,UAAU,EAAE,UAAU,EAAE,MAAM,CAAC,EAAE,cAAc;IAM3D;;;;;OAKG;IACH,YAAY,WAAkB,eAAe,aAAa,MAAM,6CAY9D;IAEF;;;;OAIG;IACH,YAAY,WAAkB,eAAe,aAAa,MAAM,mBAa9D;IAEF;;;;;OAKG;IACH,YAAY,YACD,MAAM,eAAe,CAAC,SACxB,KAAK,aACD,MAAM,sBAiDjB;IAEF;;;;;OAKG;IACH,YAAY,YACD,MAAM,MAAM,CAAC,SACf,KAAK,aACD,MAAM,KAChB,QAAQ,IAAI,CAAC,CAoBd;IAEF;;;;;OAKG;IACH,WAAW,UAAiB,MAAM,aAAa,MAAM,KAAG,QAAQ,IAAI,CAAC,CASnE;IAEF;;OAEG;IACH,kBAAkB,cAAqB,MAAM,KAAG,QAAQ,MAAM,MAAM,CAAC,CAAC,CAUpE;IAEF;;;;OAIG;IACH,YAAY,UAAiB,MAAM,aAAa,MAAM,6CAKpD;IAEF;;;;;;OAMG;IACH,gBAAgB,UACP,MAAM,aACF,MAAM,WACR,MAAM,eACF,MAAM,6CAMnB;CACH;AAED,eAAe,YAAY,CAAC"}
1
+ {"version":3,"file":"permitAction.d.ts","sourceRoot":"","sources":["../../lib/actions/permitAction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAkB,MAAM,gCAAgC,CAAC;AAE5E,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,KAAK,EAAE,MAAM,kCAAkC,CAAC;AAEzD,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAIhE,cAAM,YAAY;IAChB,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC;IAChC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;IACxC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAA2B;gBAEhD,UAAU,EAAE,UAAU,EAAE,MAAM,CAAC,EAAE,cAAc;IAM3D;;;;;OAKG;IACH,YAAY,GAAU,QAAQ,eAAe,EAAE,WAAW,MAAM,oEAY9D;IAEF;;;;OAIG;IACH,YAAY,GAAU,QAAQ,eAAe,EAAE,WAAW,MAAM,mBAa9D;IAEF;;;;;OAKG;IACH,YAAY,GACV,SAAS,KAAK,CAAC,eAAe,CAAC,EAC/B,OAAO,KAAK,EACZ,WAAW,MAAM,sBAiDjB;IAEF;;;;;OAKG;IACH,YAAY,GACV,SAAS,KAAK,CAAC,MAAM,CAAC,EACtB,OAAO,KAAK,EACZ,WAAW,MAAM,KAChB,OAAO,CAAC,IAAI,CAAC,CAoBd;IAEF;;;;;OAKG;IACH,WAAW,GAAU,OAAO,MAAM,EAAE,WAAW,MAAM,KAAG,OAAO,CAAC,IAAI,CAAC,CASnE;IAEF;;OAEG;IACH,kBAAkB,GAAU,WAAW,MAAM,KAAG,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAUpE;IAEF;;;;OAIG;IACH,YAAY,GAAU,OAAO,MAAM,EAAE,WAAW,MAAM,oEAKpD;IAEF;;;;;;OAMG;IACH,gBAAgB,GACd,OAAO,MAAM,EACb,WAAW,MAAM,EACjB,SAAS,MAAM,EACf,aAAa,MAAM,oEAMnB;CACH;AAED,eAAe,YAAY,CAAC"}