@rosen-bridge/watcher-data-extractor 2.0.0 → 2.1.2
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/dist/actions/{EventTriggerDB.d.ts → EventTriggerAction.d.ts} +7 -5
- package/dist/actions/EventTriggerAction.d.ts.map +1 -0
- package/dist/actions/EventTriggerAction.js +123 -0
- package/dist/actions/{commitmentDB.d.ts → commitmentAction.d.ts} +8 -7
- package/dist/actions/commitmentAction.d.ts.map +1 -0
- package/dist/actions/commitmentAction.js +111 -0
- package/dist/actions/permitAction.d.ts +64 -0
- package/dist/actions/permitAction.d.ts.map +1 -0
- package/dist/actions/permitAction.js +171 -0
- package/dist/constants.d.ts +2 -1
- package/dist/constants.d.ts.map +1 -1
- package/dist/constants.js +3 -2
- package/dist/entities/CommitmentEntity.d.ts +1 -1
- package/dist/entities/CommitmentEntity.d.ts.map +1 -1
- package/dist/entities/CommitmentEntity.js +3 -3
- package/dist/entities/EventTriggerEntity.d.ts +1 -1
- package/dist/entities/EventTriggerEntity.d.ts.map +1 -1
- package/dist/entities/EventTriggerEntity.js +3 -3
- package/dist/entities/PermitEntity.d.ts +1 -1
- package/dist/entities/PermitEntity.d.ts.map +1 -1
- package/dist/entities/PermitEntity.js +3 -3
- package/dist/extractor/EventTriggerExtractor.d.ts.map +1 -1
- package/dist/extractor/EventTriggerExtractor.js +5 -5
- package/dist/extractor/commitmentExtractor.d.ts.map +1 -1
- package/dist/extractor/commitmentExtractor.js +5 -5
- package/dist/extractor/permitExtractor.d.ts +114 -5
- package/dist/extractor/permitExtractor.d.ts.map +1 -1
- package/dist/extractor/permitExtractor.js +129 -33
- package/dist/interfaces/extractedPermit.d.ts +2 -0
- package/dist/interfaces/extractedPermit.d.ts.map +1 -1
- package/dist/interfaces/extractedPermit.js +1 -1
- package/dist/migrations/index.d.ts.map +1 -1
- package/dist/migrations/index.js +5 -3
- package/dist/migrations/postgres/1689175974257-migration.d.ts +7 -0
- package/dist/migrations/postgres/1689175974257-migration.d.ts.map +1 -0
- package/dist/migrations/postgres/1689175974257-migration.js +50 -0
- package/dist/migrations/sqlite/1689175103163-migration.d.ts +7 -0
- package/dist/migrations/sqlite/1689175103163-migration.d.ts.map +1 -0
- package/dist/migrations/sqlite/1689175103163-migration.js +392 -0
- package/dist/{network/parser.d.ts → utils.d.ts} +3 -2
- package/dist/utils.d.ts.map +1 -0
- package/dist/utils.js +6 -0
- package/package.json +3 -2
- package/dist/actions/EventTriggerDB.d.ts.map +0 -1
- package/dist/actions/EventTriggerDB.js +0 -145
- package/dist/actions/commitmentDB.d.ts.map +0 -1
- package/dist/actions/commitmentDB.js +0 -129
- package/dist/actions/permitDB.d.ts +0 -39
- package/dist/actions/permitDB.d.ts.map +0 -1
- package/dist/actions/permitDB.js +0 -166
- package/dist/network/ergoNetworkApi.d.ts +0 -15
- package/dist/network/ergoNetworkApi.d.ts.map +0 -1
- package/dist/network/ergoNetworkApi.js +0 -27
- package/dist/network/parser.d.ts.map +0 -1
- package/dist/network/parser.js +0 -5
|
@@ -0,0 +1,392 @@
|
|
|
1
|
+
export class migration1689175103163 {
|
|
2
|
+
name = 'migration1689175103163';
|
|
3
|
+
async up(queryRunner) {
|
|
4
|
+
await queryRunner.query(`
|
|
5
|
+
CREATE TABLE "temporary_event_trigger_entity" (
|
|
6
|
+
"id" integer PRIMARY KEY AUTOINCREMENT NOT NULL,
|
|
7
|
+
"eventId" varchar NOT NULL DEFAULT ('Not-set'),
|
|
8
|
+
"txId" varchar NOT NULL,
|
|
9
|
+
"extractor" varchar NOT NULL,
|
|
10
|
+
"boxId" varchar NOT NULL,
|
|
11
|
+
"boxSerialized" varchar NOT NULL,
|
|
12
|
+
"block" varchar NOT NULL,
|
|
13
|
+
"height" integer NOT NULL,
|
|
14
|
+
"fromChain" varchar NOT NULL,
|
|
15
|
+
"toChain" varchar NOT NULL,
|
|
16
|
+
"fromAddress" varchar NOT NULL,
|
|
17
|
+
"toAddress" varchar NOT NULL,
|
|
18
|
+
"amount" varchar NOT NULL,
|
|
19
|
+
"bridgeFee" varchar NOT NULL,
|
|
20
|
+
"networkFee" varchar NOT NULL,
|
|
21
|
+
"sourceChainTokenId" varchar NOT NULL,
|
|
22
|
+
"sourceChainHeight" integer NOT NULL,
|
|
23
|
+
"targetChainTokenId" varchar NOT NULL,
|
|
24
|
+
"sourceTxId" varchar NOT NULL,
|
|
25
|
+
"sourceBlockId" varchar NOT NULL,
|
|
26
|
+
"WIDs" varchar NOT NULL,
|
|
27
|
+
"spendBlock" text,
|
|
28
|
+
"spendHeight" integer,
|
|
29
|
+
"spendTxId" varchar,
|
|
30
|
+
CONSTRAINT "UQ_c905f221a1b6271ca4405dbbe5f" UNIQUE ("boxId", "extractor")
|
|
31
|
+
)
|
|
32
|
+
`);
|
|
33
|
+
await queryRunner.query(`
|
|
34
|
+
INSERT INTO "temporary_event_trigger_entity"(
|
|
35
|
+
"id",
|
|
36
|
+
"eventId",
|
|
37
|
+
"txId",
|
|
38
|
+
"extractor",
|
|
39
|
+
"boxId",
|
|
40
|
+
"boxSerialized",
|
|
41
|
+
"block",
|
|
42
|
+
"height",
|
|
43
|
+
"fromChain",
|
|
44
|
+
"toChain",
|
|
45
|
+
"fromAddress",
|
|
46
|
+
"toAddress",
|
|
47
|
+
"amount",
|
|
48
|
+
"bridgeFee",
|
|
49
|
+
"networkFee",
|
|
50
|
+
"sourceChainTokenId",
|
|
51
|
+
"sourceChainHeight",
|
|
52
|
+
"targetChainTokenId",
|
|
53
|
+
"sourceTxId",
|
|
54
|
+
"sourceBlockId",
|
|
55
|
+
"WIDs",
|
|
56
|
+
"spendBlock",
|
|
57
|
+
"spendHeight",
|
|
58
|
+
"spendTxId"
|
|
59
|
+
)
|
|
60
|
+
SELECT "id",
|
|
61
|
+
"eventId",
|
|
62
|
+
"txId",
|
|
63
|
+
"extractor",
|
|
64
|
+
"boxId",
|
|
65
|
+
"boxSerialized",
|
|
66
|
+
"block",
|
|
67
|
+
"height",
|
|
68
|
+
"fromChain",
|
|
69
|
+
"toChain",
|
|
70
|
+
"fromAddress",
|
|
71
|
+
"toAddress",
|
|
72
|
+
"amount",
|
|
73
|
+
"bridgeFee",
|
|
74
|
+
"networkFee",
|
|
75
|
+
"sourceChainTokenId",
|
|
76
|
+
"sourceChainHeight",
|
|
77
|
+
"targetChainTokenId",
|
|
78
|
+
"sourceTxId",
|
|
79
|
+
"sourceBlockId",
|
|
80
|
+
"WIDs",
|
|
81
|
+
"spendBlock",
|
|
82
|
+
"spendHeight",
|
|
83
|
+
"spendTxId"
|
|
84
|
+
FROM "event_trigger_entity"
|
|
85
|
+
`);
|
|
86
|
+
await queryRunner.query(`
|
|
87
|
+
DROP TABLE "event_trigger_entity"
|
|
88
|
+
`);
|
|
89
|
+
await queryRunner.query(`
|
|
90
|
+
ALTER TABLE "temporary_event_trigger_entity"
|
|
91
|
+
RENAME TO "event_trigger_entity"
|
|
92
|
+
`);
|
|
93
|
+
await queryRunner.query(`
|
|
94
|
+
CREATE TABLE "temporary_commitment_entity" (
|
|
95
|
+
"id" integer PRIMARY KEY AUTOINCREMENT NOT NULL,
|
|
96
|
+
"txId" varchar NOT NULL,
|
|
97
|
+
"extractor" varchar NOT NULL,
|
|
98
|
+
"eventId" varchar NOT NULL,
|
|
99
|
+
"commitment" varchar NOT NULL,
|
|
100
|
+
"WID" varchar NOT NULL,
|
|
101
|
+
"boxId" varchar NOT NULL,
|
|
102
|
+
"block" varchar NOT NULL,
|
|
103
|
+
"height" integer NOT NULL,
|
|
104
|
+
"boxSerialized" varchar NOT NULL,
|
|
105
|
+
"spendBlock" text,
|
|
106
|
+
"spendHeight" integer,
|
|
107
|
+
"rwtCount" varchar,
|
|
108
|
+
CONSTRAINT "UQ_cc294fc304a66f8f194840f1ece" UNIQUE ("boxId", "extractor")
|
|
109
|
+
)
|
|
110
|
+
`);
|
|
111
|
+
await queryRunner.query(`
|
|
112
|
+
INSERT INTO "temporary_commitment_entity"(
|
|
113
|
+
"id",
|
|
114
|
+
"txId",
|
|
115
|
+
"extractor",
|
|
116
|
+
"eventId",
|
|
117
|
+
"commitment",
|
|
118
|
+
"WID",
|
|
119
|
+
"boxId",
|
|
120
|
+
"block",
|
|
121
|
+
"height",
|
|
122
|
+
"boxSerialized",
|
|
123
|
+
"spendBlock",
|
|
124
|
+
"spendHeight",
|
|
125
|
+
"rwtCount"
|
|
126
|
+
)
|
|
127
|
+
SELECT "id",
|
|
128
|
+
"txId",
|
|
129
|
+
"extractor",
|
|
130
|
+
"eventId",
|
|
131
|
+
"commitment",
|
|
132
|
+
"WID",
|
|
133
|
+
"boxId",
|
|
134
|
+
"block",
|
|
135
|
+
"height",
|
|
136
|
+
"boxSerialized",
|
|
137
|
+
"spendBlock",
|
|
138
|
+
"spendHeight",
|
|
139
|
+
"rwtCount"
|
|
140
|
+
FROM "commitment_entity"
|
|
141
|
+
`);
|
|
142
|
+
await queryRunner.query(`
|
|
143
|
+
DROP TABLE "commitment_entity"
|
|
144
|
+
`);
|
|
145
|
+
await queryRunner.query(`
|
|
146
|
+
ALTER TABLE "temporary_commitment_entity"
|
|
147
|
+
RENAME TO "commitment_entity"
|
|
148
|
+
`);
|
|
149
|
+
await queryRunner.query(`
|
|
150
|
+
CREATE TABLE "temporary_permit_entity" (
|
|
151
|
+
"id" integer PRIMARY KEY AUTOINCREMENT NOT NULL,
|
|
152
|
+
"extractor" varchar NOT NULL,
|
|
153
|
+
"boxId" varchar NOT NULL,
|
|
154
|
+
"boxSerialized" varchar NOT NULL,
|
|
155
|
+
"WID" varchar NOT NULL,
|
|
156
|
+
"block" varchar NOT NULL,
|
|
157
|
+
"height" integer NOT NULL,
|
|
158
|
+
"spendBlock" text,
|
|
159
|
+
"spendHeight" integer,
|
|
160
|
+
"txId" varchar NOT NULL,
|
|
161
|
+
CONSTRAINT "UQ_d3226602b909b64bcaeadc39c3c" UNIQUE ("boxId", "extractor")
|
|
162
|
+
)
|
|
163
|
+
`);
|
|
164
|
+
await queryRunner.query(`
|
|
165
|
+
INSERT INTO "temporary_permit_entity"(
|
|
166
|
+
"id",
|
|
167
|
+
"extractor",
|
|
168
|
+
"boxId",
|
|
169
|
+
"boxSerialized",
|
|
170
|
+
"WID",
|
|
171
|
+
"block",
|
|
172
|
+
"height",
|
|
173
|
+
"spendBlock",
|
|
174
|
+
"spendHeight",
|
|
175
|
+
"txId"
|
|
176
|
+
)
|
|
177
|
+
SELECT "id",
|
|
178
|
+
"extractor",
|
|
179
|
+
"boxId",
|
|
180
|
+
"boxSerialized",
|
|
181
|
+
"WID",
|
|
182
|
+
"block",
|
|
183
|
+
"height",
|
|
184
|
+
"spendBlock",
|
|
185
|
+
"spendHeight",
|
|
186
|
+
"txId"
|
|
187
|
+
FROM "permit_entity"
|
|
188
|
+
`);
|
|
189
|
+
await queryRunner.query(`
|
|
190
|
+
DROP TABLE "permit_entity"
|
|
191
|
+
`);
|
|
192
|
+
await queryRunner.query(`
|
|
193
|
+
ALTER TABLE "temporary_permit_entity"
|
|
194
|
+
RENAME TO "permit_entity"
|
|
195
|
+
`);
|
|
196
|
+
}
|
|
197
|
+
async down(queryRunner) {
|
|
198
|
+
await queryRunner.query(`
|
|
199
|
+
ALTER TABLE "permit_entity"
|
|
200
|
+
RENAME TO "temporary_permit_entity"
|
|
201
|
+
`);
|
|
202
|
+
await queryRunner.query(`
|
|
203
|
+
CREATE TABLE "permit_entity" (
|
|
204
|
+
"id" integer PRIMARY KEY AUTOINCREMENT NOT NULL,
|
|
205
|
+
"extractor" varchar NOT NULL,
|
|
206
|
+
"boxId" varchar NOT NULL,
|
|
207
|
+
"boxSerialized" varchar NOT NULL,
|
|
208
|
+
"WID" varchar NOT NULL,
|
|
209
|
+
"block" varchar NOT NULL,
|
|
210
|
+
"height" integer NOT NULL,
|
|
211
|
+
"spendBlock" varchar,
|
|
212
|
+
"spendHeight" integer,
|
|
213
|
+
"txId" varchar NOT NULL,
|
|
214
|
+
CONSTRAINT "UQ_d3226602b909b64bcaeadc39c3c" UNIQUE ("boxId", "extractor")
|
|
215
|
+
)
|
|
216
|
+
`);
|
|
217
|
+
await queryRunner.query(`
|
|
218
|
+
INSERT INTO "permit_entity"(
|
|
219
|
+
"id",
|
|
220
|
+
"extractor",
|
|
221
|
+
"boxId",
|
|
222
|
+
"boxSerialized",
|
|
223
|
+
"WID",
|
|
224
|
+
"block",
|
|
225
|
+
"height",
|
|
226
|
+
"spendBlock",
|
|
227
|
+
"spendHeight",
|
|
228
|
+
"txId"
|
|
229
|
+
)
|
|
230
|
+
SELECT "id",
|
|
231
|
+
"extractor",
|
|
232
|
+
"boxId",
|
|
233
|
+
"boxSerialized",
|
|
234
|
+
"WID",
|
|
235
|
+
"block",
|
|
236
|
+
"height",
|
|
237
|
+
"spendBlock",
|
|
238
|
+
"spendHeight",
|
|
239
|
+
"txId"
|
|
240
|
+
FROM "temporary_permit_entity"
|
|
241
|
+
`);
|
|
242
|
+
await queryRunner.query(`
|
|
243
|
+
DROP TABLE "temporary_permit_entity"
|
|
244
|
+
`);
|
|
245
|
+
await queryRunner.query(`
|
|
246
|
+
ALTER TABLE "commitment_entity"
|
|
247
|
+
RENAME TO "temporary_commitment_entity"
|
|
248
|
+
`);
|
|
249
|
+
await queryRunner.query(`
|
|
250
|
+
CREATE TABLE "commitment_entity" (
|
|
251
|
+
"id" integer PRIMARY KEY AUTOINCREMENT NOT NULL,
|
|
252
|
+
"txId" varchar NOT NULL,
|
|
253
|
+
"extractor" varchar NOT NULL,
|
|
254
|
+
"eventId" varchar NOT NULL,
|
|
255
|
+
"commitment" varchar NOT NULL,
|
|
256
|
+
"WID" varchar NOT NULL,
|
|
257
|
+
"boxId" varchar NOT NULL,
|
|
258
|
+
"block" varchar NOT NULL,
|
|
259
|
+
"height" integer NOT NULL,
|
|
260
|
+
"boxSerialized" varchar NOT NULL,
|
|
261
|
+
"spendBlock" varchar,
|
|
262
|
+
"spendHeight" integer,
|
|
263
|
+
"rwtCount" varchar,
|
|
264
|
+
CONSTRAINT "UQ_cc294fc304a66f8f194840f1ece" UNIQUE ("boxId", "extractor")
|
|
265
|
+
)
|
|
266
|
+
`);
|
|
267
|
+
await queryRunner.query(`
|
|
268
|
+
INSERT INTO "commitment_entity"(
|
|
269
|
+
"id",
|
|
270
|
+
"txId",
|
|
271
|
+
"extractor",
|
|
272
|
+
"eventId",
|
|
273
|
+
"commitment",
|
|
274
|
+
"WID",
|
|
275
|
+
"boxId",
|
|
276
|
+
"block",
|
|
277
|
+
"height",
|
|
278
|
+
"boxSerialized",
|
|
279
|
+
"spendBlock",
|
|
280
|
+
"spendHeight",
|
|
281
|
+
"rwtCount"
|
|
282
|
+
)
|
|
283
|
+
SELECT "id",
|
|
284
|
+
"txId",
|
|
285
|
+
"extractor",
|
|
286
|
+
"eventId",
|
|
287
|
+
"commitment",
|
|
288
|
+
"WID",
|
|
289
|
+
"boxId",
|
|
290
|
+
"block",
|
|
291
|
+
"height",
|
|
292
|
+
"boxSerialized",
|
|
293
|
+
"spendBlock",
|
|
294
|
+
"spendHeight",
|
|
295
|
+
"rwtCount"
|
|
296
|
+
FROM "temporary_commitment_entity"
|
|
297
|
+
`);
|
|
298
|
+
await queryRunner.query(`
|
|
299
|
+
DROP TABLE "temporary_commitment_entity"
|
|
300
|
+
`);
|
|
301
|
+
await queryRunner.query(`
|
|
302
|
+
ALTER TABLE "event_trigger_entity"
|
|
303
|
+
RENAME TO "temporary_event_trigger_entity"
|
|
304
|
+
`);
|
|
305
|
+
await queryRunner.query(`
|
|
306
|
+
CREATE TABLE "event_trigger_entity" (
|
|
307
|
+
"id" integer PRIMARY KEY AUTOINCREMENT NOT NULL,
|
|
308
|
+
"eventId" varchar NOT NULL DEFAULT ('Not-set'),
|
|
309
|
+
"txId" varchar NOT NULL,
|
|
310
|
+
"extractor" varchar NOT NULL,
|
|
311
|
+
"boxId" varchar NOT NULL,
|
|
312
|
+
"boxSerialized" varchar NOT NULL,
|
|
313
|
+
"block" varchar NOT NULL,
|
|
314
|
+
"height" integer NOT NULL,
|
|
315
|
+
"fromChain" varchar NOT NULL,
|
|
316
|
+
"toChain" varchar NOT NULL,
|
|
317
|
+
"fromAddress" varchar NOT NULL,
|
|
318
|
+
"toAddress" varchar NOT NULL,
|
|
319
|
+
"amount" varchar NOT NULL,
|
|
320
|
+
"bridgeFee" varchar NOT NULL,
|
|
321
|
+
"networkFee" varchar NOT NULL,
|
|
322
|
+
"sourceChainTokenId" varchar NOT NULL,
|
|
323
|
+
"sourceChainHeight" integer NOT NULL,
|
|
324
|
+
"targetChainTokenId" varchar NOT NULL,
|
|
325
|
+
"sourceTxId" varchar NOT NULL,
|
|
326
|
+
"sourceBlockId" varchar NOT NULL,
|
|
327
|
+
"WIDs" varchar NOT NULL,
|
|
328
|
+
"spendBlock" varchar,
|
|
329
|
+
"spendHeight" integer,
|
|
330
|
+
"spendTxId" varchar,
|
|
331
|
+
CONSTRAINT "UQ_c905f221a1b6271ca4405dbbe5f" UNIQUE ("boxId", "extractor")
|
|
332
|
+
)
|
|
333
|
+
`);
|
|
334
|
+
await queryRunner.query(`
|
|
335
|
+
INSERT INTO "event_trigger_entity"(
|
|
336
|
+
"id",
|
|
337
|
+
"eventId",
|
|
338
|
+
"txId",
|
|
339
|
+
"extractor",
|
|
340
|
+
"boxId",
|
|
341
|
+
"boxSerialized",
|
|
342
|
+
"block",
|
|
343
|
+
"height",
|
|
344
|
+
"fromChain",
|
|
345
|
+
"toChain",
|
|
346
|
+
"fromAddress",
|
|
347
|
+
"toAddress",
|
|
348
|
+
"amount",
|
|
349
|
+
"bridgeFee",
|
|
350
|
+
"networkFee",
|
|
351
|
+
"sourceChainTokenId",
|
|
352
|
+
"sourceChainHeight",
|
|
353
|
+
"targetChainTokenId",
|
|
354
|
+
"sourceTxId",
|
|
355
|
+
"sourceBlockId",
|
|
356
|
+
"WIDs",
|
|
357
|
+
"spendBlock",
|
|
358
|
+
"spendHeight",
|
|
359
|
+
"spendTxId"
|
|
360
|
+
)
|
|
361
|
+
SELECT "id",
|
|
362
|
+
"eventId",
|
|
363
|
+
"txId",
|
|
364
|
+
"extractor",
|
|
365
|
+
"boxId",
|
|
366
|
+
"boxSerialized",
|
|
367
|
+
"block",
|
|
368
|
+
"height",
|
|
369
|
+
"fromChain",
|
|
370
|
+
"toChain",
|
|
371
|
+
"fromAddress",
|
|
372
|
+
"toAddress",
|
|
373
|
+
"amount",
|
|
374
|
+
"bridgeFee",
|
|
375
|
+
"networkFee",
|
|
376
|
+
"sourceChainTokenId",
|
|
377
|
+
"sourceChainHeight",
|
|
378
|
+
"targetChainTokenId",
|
|
379
|
+
"sourceTxId",
|
|
380
|
+
"sourceBlockId",
|
|
381
|
+
"WIDs",
|
|
382
|
+
"spendBlock",
|
|
383
|
+
"spendHeight",
|
|
384
|
+
"spendTxId"
|
|
385
|
+
FROM "temporary_event_trigger_entity"
|
|
386
|
+
`);
|
|
387
|
+
await queryRunner.query(`
|
|
388
|
+
DROP TABLE "temporary_event_trigger_entity"
|
|
389
|
+
`);
|
|
390
|
+
}
|
|
391
|
+
}
|
|
392
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"1689175103163-migration.js","sourceRoot":"","sources":["../../../lib/migrations/sqlite/1689175103163-migration.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,sBAAsB;IACjC,IAAI,GAAG,wBAAwB,CAAC;IAEzB,KAAK,CAAC,EAAE,CAAC,WAAwB;QACtC,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA4BnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SAoDnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;SAEnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;SAGnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;SAiBnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA8BnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;SAEnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;SAGnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;SAcnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;SAwBnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;SAEnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;SAGnB,CAAC,CAAC;IACT,CAAC;IAEM,KAAK,CAAC,IAAI,CAAC,WAAwB;QACxC,MAAM,WAAW,CAAC,KAAK,CAAC;;;SAGnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;SAcnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;SAwBnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;SAEnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;SAGnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;SAiBnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA8BnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;SAEnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;SAGnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA4BnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SAoDnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;SAEnB,CAAC,CAAC;IACT,CAAC;CACF","sourcesContent":["import { MigrationInterface, QueryRunner } from 'typeorm';\n\nexport class migration1689175103163 implements MigrationInterface {\n  name = 'migration1689175103163';\n\n  public async up(queryRunner: QueryRunner): Promise<void> {\n    await queryRunner.query(`\n            CREATE TABLE \"temporary_event_trigger_entity\" (\n                \"id\" integer PRIMARY KEY AUTOINCREMENT NOT NULL,\n                \"eventId\" varchar NOT NULL DEFAULT ('Not-set'),\n                \"txId\" varchar NOT NULL,\n                \"extractor\" varchar NOT NULL,\n                \"boxId\" varchar NOT NULL,\n                \"boxSerialized\" varchar NOT NULL,\n                \"block\" varchar NOT NULL,\n                \"height\" integer NOT NULL,\n                \"fromChain\" varchar NOT NULL,\n                \"toChain\" varchar NOT NULL,\n                \"fromAddress\" varchar NOT NULL,\n                \"toAddress\" varchar NOT NULL,\n                \"amount\" varchar NOT NULL,\n                \"bridgeFee\" varchar NOT NULL,\n                \"networkFee\" varchar NOT NULL,\n                \"sourceChainTokenId\" varchar NOT NULL,\n                \"sourceChainHeight\" integer NOT NULL,\n                \"targetChainTokenId\" varchar NOT NULL,\n                \"sourceTxId\" varchar NOT NULL,\n                \"sourceBlockId\" varchar NOT NULL,\n                \"WIDs\" varchar NOT NULL,\n                \"spendBlock\" text,\n                \"spendHeight\" integer,\n                \"spendTxId\" varchar,\n                CONSTRAINT \"UQ_c905f221a1b6271ca4405dbbe5f\" UNIQUE (\"boxId\", \"extractor\")\n            )\n        `);\n    await queryRunner.query(`\n            INSERT INTO \"temporary_event_trigger_entity\"(\n                    \"id\",\n                    \"eventId\",\n                    \"txId\",\n                    \"extractor\",\n                    \"boxId\",\n                    \"boxSerialized\",\n                    \"block\",\n                    \"height\",\n                    \"fromChain\",\n                    \"toChain\",\n                    \"fromAddress\",\n                    \"toAddress\",\n                    \"amount\",\n                    \"bridgeFee\",\n                    \"networkFee\",\n                    \"sourceChainTokenId\",\n                    \"sourceChainHeight\",\n                    \"targetChainTokenId\",\n                    \"sourceTxId\",\n                    \"sourceBlockId\",\n                    \"WIDs\",\n                    \"spendBlock\",\n                    \"spendHeight\",\n                    \"spendTxId\"\n                )\n            SELECT \"id\",\n                \"eventId\",\n                \"txId\",\n                \"extractor\",\n                \"boxId\",\n                \"boxSerialized\",\n                \"block\",\n                \"height\",\n                \"fromChain\",\n                \"toChain\",\n                \"fromAddress\",\n                \"toAddress\",\n                \"amount\",\n                \"bridgeFee\",\n                \"networkFee\",\n                \"sourceChainTokenId\",\n                \"sourceChainHeight\",\n                \"targetChainTokenId\",\n                \"sourceTxId\",\n                \"sourceBlockId\",\n                \"WIDs\",\n                \"spendBlock\",\n                \"spendHeight\",\n                \"spendTxId\"\n            FROM \"event_trigger_entity\"\n        `);\n    await queryRunner.query(`\n            DROP TABLE \"event_trigger_entity\"\n        `);\n    await queryRunner.query(`\n            ALTER TABLE \"temporary_event_trigger_entity\"\n                RENAME TO \"event_trigger_entity\"\n        `);\n    await queryRunner.query(`\n            CREATE TABLE \"temporary_commitment_entity\" (\n                \"id\" integer PRIMARY KEY AUTOINCREMENT NOT NULL,\n                \"txId\" varchar NOT NULL,\n                \"extractor\" varchar NOT NULL,\n                \"eventId\" varchar NOT NULL,\n                \"commitment\" varchar NOT NULL,\n                \"WID\" varchar NOT NULL,\n                \"boxId\" varchar NOT NULL,\n                \"block\" varchar NOT NULL,\n                \"height\" integer NOT NULL,\n                \"boxSerialized\" varchar NOT NULL,\n                \"spendBlock\" text,\n                \"spendHeight\" integer,\n                \"rwtCount\" varchar,\n                CONSTRAINT \"UQ_cc294fc304a66f8f194840f1ece\" UNIQUE (\"boxId\", \"extractor\")\n            )\n        `);\n    await queryRunner.query(`\n            INSERT INTO \"temporary_commitment_entity\"(\n                    \"id\",\n                    \"txId\",\n                    \"extractor\",\n                    \"eventId\",\n                    \"commitment\",\n                    \"WID\",\n                    \"boxId\",\n                    \"block\",\n                    \"height\",\n                    \"boxSerialized\",\n                    \"spendBlock\",\n                    \"spendHeight\",\n                    \"rwtCount\"\n                )\n            SELECT \"id\",\n                \"txId\",\n                \"extractor\",\n                \"eventId\",\n                \"commitment\",\n                \"WID\",\n                \"boxId\",\n                \"block\",\n                \"height\",\n                \"boxSerialized\",\n                \"spendBlock\",\n                \"spendHeight\",\n                \"rwtCount\"\n            FROM \"commitment_entity\"\n        `);\n    await queryRunner.query(`\n            DROP TABLE \"commitment_entity\"\n        `);\n    await queryRunner.query(`\n            ALTER TABLE \"temporary_commitment_entity\"\n                RENAME TO \"commitment_entity\"\n        `);\n    await queryRunner.query(`\n            CREATE TABLE \"temporary_permit_entity\" (\n                \"id\" integer PRIMARY KEY AUTOINCREMENT NOT NULL,\n                \"extractor\" varchar NOT NULL,\n                \"boxId\" varchar NOT NULL,\n                \"boxSerialized\" varchar NOT NULL,\n                \"WID\" varchar NOT NULL,\n                \"block\" varchar NOT NULL,\n                \"height\" integer NOT NULL,\n                \"spendBlock\" text,\n                \"spendHeight\" integer,\n                \"txId\" varchar NOT NULL,\n                CONSTRAINT \"UQ_d3226602b909b64bcaeadc39c3c\" UNIQUE (\"boxId\", \"extractor\")\n            )\n        `);\n    await queryRunner.query(`\n            INSERT INTO \"temporary_permit_entity\"(\n                    \"id\",\n                    \"extractor\",\n                    \"boxId\",\n                    \"boxSerialized\",\n                    \"WID\",\n                    \"block\",\n                    \"height\",\n                    \"spendBlock\",\n                    \"spendHeight\",\n                    \"txId\"\n                )\n            SELECT \"id\",\n                \"extractor\",\n                \"boxId\",\n                \"boxSerialized\",\n                \"WID\",\n                \"block\",\n                \"height\",\n                \"spendBlock\",\n                \"spendHeight\",\n                \"txId\"\n            FROM \"permit_entity\"\n        `);\n    await queryRunner.query(`\n            DROP TABLE \"permit_entity\"\n        `);\n    await queryRunner.query(`\n            ALTER TABLE \"temporary_permit_entity\"\n                RENAME TO \"permit_entity\"\n        `);\n  }\n\n  public async down(queryRunner: QueryRunner): Promise<void> {\n    await queryRunner.query(`\n            ALTER TABLE \"permit_entity\"\n                RENAME TO \"temporary_permit_entity\"\n        `);\n    await queryRunner.query(`\n            CREATE TABLE \"permit_entity\" (\n                \"id\" integer PRIMARY KEY AUTOINCREMENT NOT NULL,\n                \"extractor\" varchar NOT NULL,\n                \"boxId\" varchar NOT NULL,\n                \"boxSerialized\" varchar NOT NULL,\n                \"WID\" varchar NOT NULL,\n                \"block\" varchar NOT NULL,\n                \"height\" integer NOT NULL,\n                \"spendBlock\" varchar,\n                \"spendHeight\" integer,\n                \"txId\" varchar NOT NULL,\n                CONSTRAINT \"UQ_d3226602b909b64bcaeadc39c3c\" UNIQUE (\"boxId\", \"extractor\")\n            )\n        `);\n    await queryRunner.query(`\n            INSERT INTO \"permit_entity\"(\n                    \"id\",\n                    \"extractor\",\n                    \"boxId\",\n                    \"boxSerialized\",\n                    \"WID\",\n                    \"block\",\n                    \"height\",\n                    \"spendBlock\",\n                    \"spendHeight\",\n                    \"txId\"\n                )\n            SELECT \"id\",\n                \"extractor\",\n                \"boxId\",\n                \"boxSerialized\",\n                \"WID\",\n                \"block\",\n                \"height\",\n                \"spendBlock\",\n                \"spendHeight\",\n                \"txId\"\n            FROM \"temporary_permit_entity\"\n        `);\n    await queryRunner.query(`\n            DROP TABLE \"temporary_permit_entity\"\n        `);\n    await queryRunner.query(`\n            ALTER TABLE \"commitment_entity\"\n                RENAME TO \"temporary_commitment_entity\"\n        `);\n    await queryRunner.query(`\n            CREATE TABLE \"commitment_entity\" (\n                \"id\" integer PRIMARY KEY AUTOINCREMENT NOT NULL,\n                \"txId\" varchar NOT NULL,\n                \"extractor\" varchar NOT NULL,\n                \"eventId\" varchar NOT NULL,\n                \"commitment\" varchar NOT NULL,\n                \"WID\" varchar NOT NULL,\n                \"boxId\" varchar NOT NULL,\n                \"block\" varchar NOT NULL,\n                \"height\" integer NOT NULL,\n                \"boxSerialized\" varchar NOT NULL,\n                \"spendBlock\" varchar,\n                \"spendHeight\" integer,\n                \"rwtCount\" varchar,\n                CONSTRAINT \"UQ_cc294fc304a66f8f194840f1ece\" UNIQUE (\"boxId\", \"extractor\")\n            )\n        `);\n    await queryRunner.query(`\n            INSERT INTO \"commitment_entity\"(\n                    \"id\",\n                    \"txId\",\n                    \"extractor\",\n                    \"eventId\",\n                    \"commitment\",\n                    \"WID\",\n                    \"boxId\",\n                    \"block\",\n                    \"height\",\n                    \"boxSerialized\",\n                    \"spendBlock\",\n                    \"spendHeight\",\n                    \"rwtCount\"\n                )\n            SELECT \"id\",\n                \"txId\",\n                \"extractor\",\n                \"eventId\",\n                \"commitment\",\n                \"WID\",\n                \"boxId\",\n                \"block\",\n                \"height\",\n                \"boxSerialized\",\n                \"spendBlock\",\n                \"spendHeight\",\n                \"rwtCount\"\n            FROM \"temporary_commitment_entity\"\n        `);\n    await queryRunner.query(`\n            DROP TABLE \"temporary_commitment_entity\"\n        `);\n    await queryRunner.query(`\n            ALTER TABLE \"event_trigger_entity\"\n                RENAME TO \"temporary_event_trigger_entity\"\n        `);\n    await queryRunner.query(`\n            CREATE TABLE \"event_trigger_entity\" (\n                \"id\" integer PRIMARY KEY AUTOINCREMENT NOT NULL,\n                \"eventId\" varchar NOT NULL DEFAULT ('Not-set'),\n                \"txId\" varchar NOT NULL,\n                \"extractor\" varchar NOT NULL,\n                \"boxId\" varchar NOT NULL,\n                \"boxSerialized\" varchar NOT NULL,\n                \"block\" varchar NOT NULL,\n                \"height\" integer NOT NULL,\n                \"fromChain\" varchar NOT NULL,\n                \"toChain\" varchar NOT NULL,\n                \"fromAddress\" varchar NOT NULL,\n                \"toAddress\" varchar NOT NULL,\n                \"amount\" varchar NOT NULL,\n                \"bridgeFee\" varchar NOT NULL,\n                \"networkFee\" varchar NOT NULL,\n                \"sourceChainTokenId\" varchar NOT NULL,\n                \"sourceChainHeight\" integer NOT NULL,\n                \"targetChainTokenId\" varchar NOT NULL,\n                \"sourceTxId\" varchar NOT NULL,\n                \"sourceBlockId\" varchar NOT NULL,\n                \"WIDs\" varchar NOT NULL,\n                \"spendBlock\" varchar,\n                \"spendHeight\" integer,\n                \"spendTxId\" varchar,\n                CONSTRAINT \"UQ_c905f221a1b6271ca4405dbbe5f\" UNIQUE (\"boxId\", \"extractor\")\n            )\n        `);\n    await queryRunner.query(`\n            INSERT INTO \"event_trigger_entity\"(\n                    \"id\",\n                    \"eventId\",\n                    \"txId\",\n                    \"extractor\",\n                    \"boxId\",\n                    \"boxSerialized\",\n                    \"block\",\n                    \"height\",\n                    \"fromChain\",\n                    \"toChain\",\n                    \"fromAddress\",\n                    \"toAddress\",\n                    \"amount\",\n                    \"bridgeFee\",\n                    \"networkFee\",\n                    \"sourceChainTokenId\",\n                    \"sourceChainHeight\",\n                    \"targetChainTokenId\",\n                    \"sourceTxId\",\n                    \"sourceBlockId\",\n                    \"WIDs\",\n                    \"spendBlock\",\n                    \"spendHeight\",\n                    \"spendTxId\"\n                )\n            SELECT \"id\",\n                \"eventId\",\n                \"txId\",\n                \"extractor\",\n                \"boxId\",\n                \"boxSerialized\",\n                \"block\",\n                \"height\",\n                \"fromChain\",\n                \"toChain\",\n                \"fromAddress\",\n                \"toAddress\",\n                \"amount\",\n                \"bridgeFee\",\n                \"networkFee\",\n                \"sourceChainTokenId\",\n                \"sourceChainHeight\",\n                \"targetChainTokenId\",\n                \"sourceTxId\",\n                \"sourceBlockId\",\n                \"WIDs\",\n                \"spendBlock\",\n                \"spendHeight\",\n                \"spendTxId\"\n            FROM \"temporary_event_trigger_entity\"\n        `);\n    await queryRunner.query(`\n            DROP TABLE \"temporary_event_trigger_entity\"\n        `);\n  }\n}\n"]}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
|
|
1
|
+
declare const JsonBI: {
|
|
2
2
|
parse: (text: string, reviver?: ((this: any, key: string, value: any) => any) | undefined) => any;
|
|
3
3
|
stringify: {
|
|
4
4
|
(value: any, replacer?: ((this: any, key: string, value: any) => any) | undefined, space?: string | number | undefined): string;
|
|
5
5
|
(value: any, replacer?: (string | number)[] | null | undefined, space?: string | number | undefined): string;
|
|
6
6
|
};
|
|
7
7
|
};
|
|
8
|
-
|
|
8
|
+
export { JsonBI };
|
|
9
|
+
//# sourceMappingURL=utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../lib/utils.ts"],"names":[],"mappings":"AAEA,QAAA,MAAM,MAAM;;;;;;CAEV,CAAC;AAEH,OAAO,EAAE,MAAM,EAAE,CAAC"}
|
package/dist/utils.js
ADDED
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import JSONBigInt from 'json-bigint';
|
|
2
|
+
const JsonBI = JSONBigInt({
|
|
3
|
+
useNativeBigInt: true,
|
|
4
|
+
});
|
|
5
|
+
export { JsonBI };
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9saWIvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxVQUFVLE1BQU0sYUFBYSxDQUFDO0FBRXJDLE1BQU0sTUFBTSxHQUFHLFVBQVUsQ0FBQztJQUN4QixlQUFlLEVBQUUsSUFBSTtDQUN0QixDQUFDLENBQUM7QUFFSCxPQUFPLEVBQUUsTUFBTSxFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgSlNPTkJpZ0ludCBmcm9tICdqc29uLWJpZ2ludCc7XG5cbmNvbnN0IEpzb25CSSA9IEpTT05CaWdJbnQoe1xuICB1c2VOYXRpdmVCaWdJbnQ6IHRydWUsXG59KTtcblxuZXhwb3J0IHsgSnNvbkJJIH07XG4iXX0=
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@rosen-bridge/watcher-data-extractor",
|
|
3
|
-
"version": "2.
|
|
3
|
+
"version": "2.1.2",
|
|
4
4
|
"description": "Extractor for rosen specific boxes on ergo blockchain",
|
|
5
5
|
"author": "Rosen Team",
|
|
6
6
|
"license": "GPL-3.0",
|
|
@@ -20,7 +20,8 @@
|
|
|
20
20
|
],
|
|
21
21
|
"dependencies": {
|
|
22
22
|
"@rosen-bridge/logger-interface": "^0.1.0",
|
|
23
|
-
"@rosen-bridge/scanner": "^2.
|
|
23
|
+
"@rosen-bridge/scanner": "^2.1.1",
|
|
24
|
+
"@rosen-clients/ergo-explorer": "^1.0.0",
|
|
24
25
|
"@types/lodash-es": "^4.17.6",
|
|
25
26
|
"blakejs": "^1.2.1",
|
|
26
27
|
"ergo-lib-wasm-nodejs": "^0.24.0-alpha-1f24f53",
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"EventTriggerDB.d.ts","sourceRoot":"","sources":["../../lib/actions/EventTriggerDB.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAkB,MAAM,SAAS,CAAC;AAErD,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,gCAAgC,CAAC;AAChE,OAAO,EAAE,qBAAqB,EAAE,MAAM,qCAAqC,CAAC;AAK5E,cAAM,cAAc;IAClB,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC;IAChC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;IACxC,OAAO,CAAC,QAAQ,CAAC,sBAAsB,CAAiC;gBAE5D,UAAU,EAAE,UAAU,EAAE,MAAM,EAAE,cAAc;IAM1D;;;;;OAKG;IACH,kBAAkB,kBACD,MAAM,qBAAqB,CAAC,SACpC,WAAW,aACP,MAAM,sBAqEjB;IAEF;;;;;;OAMG;IACH,kBAAkB,YACP,MAAM,MAAM,CAAC,SACf,WAAW,aACP,MAAM,QACX,MAAM,KACX,QAAQ,IAAI,CAAC,CA4Bd;IAEF;;;;OAIG;IACH,WAAW,UAAiB,MAAM,aAAa,MAAM,mBAsBnD;CACH;AAED,eAAe,cAAc,CAAC"}
|
|
@@ -1,145 +0,0 @@
|
|
|
1
|
-
import { In } from 'typeorm';
|
|
2
|
-
import EventTriggerEntity from '../entities/EventTriggerEntity';
|
|
3
|
-
import eventTriggerEntity from '../entities/EventTriggerEntity';
|
|
4
|
-
import { chunk } from 'lodash-es';
|
|
5
|
-
import { dbIdChunkSize } from '../constants';
|
|
6
|
-
class EventTriggerDB {
|
|
7
|
-
logger;
|
|
8
|
-
datasource;
|
|
9
|
-
triggerEventRepository;
|
|
10
|
-
constructor(dataSource, logger) {
|
|
11
|
-
this.datasource = dataSource;
|
|
12
|
-
this.logger = logger;
|
|
13
|
-
this.triggerEventRepository = dataSource.getRepository(EventTriggerEntity);
|
|
14
|
-
}
|
|
15
|
-
/**
|
|
16
|
-
* It stores list of eventTriggers in the dataSource with block id
|
|
17
|
-
* @param eventTriggers
|
|
18
|
-
* @param block
|
|
19
|
-
* @param extractor
|
|
20
|
-
*/
|
|
21
|
-
storeEventTriggers = async (eventTriggers, block, extractor) => {
|
|
22
|
-
if (eventTriggers.length === 0)
|
|
23
|
-
return true;
|
|
24
|
-
const boxIds = eventTriggers.map((trigger) => trigger.boxId);
|
|
25
|
-
const savedTriggers = await this.triggerEventRepository.findBy({
|
|
26
|
-
boxId: In(boxIds),
|
|
27
|
-
extractor: extractor,
|
|
28
|
-
});
|
|
29
|
-
let success = true;
|
|
30
|
-
const queryRunner = this.datasource.createQueryRunner();
|
|
31
|
-
await queryRunner.connect();
|
|
32
|
-
await queryRunner.startTransaction();
|
|
33
|
-
try {
|
|
34
|
-
for (const trigger of eventTriggers) {
|
|
35
|
-
const saved = savedTriggers.some((entity) => {
|
|
36
|
-
return entity.boxId === trigger.boxId;
|
|
37
|
-
});
|
|
38
|
-
const entity = {
|
|
39
|
-
txId: trigger.txId,
|
|
40
|
-
eventId: trigger.eventId,
|
|
41
|
-
boxId: trigger.boxId,
|
|
42
|
-
boxSerialized: trigger.boxSerialized,
|
|
43
|
-
block: block.hash,
|
|
44
|
-
height: block.height,
|
|
45
|
-
extractor: extractor,
|
|
46
|
-
WIDs: trigger.WIDs,
|
|
47
|
-
amount: trigger.amount,
|
|
48
|
-
bridgeFee: trigger.bridgeFee,
|
|
49
|
-
fromAddress: trigger.fromAddress,
|
|
50
|
-
toAddress: trigger.toAddress,
|
|
51
|
-
fromChain: trigger.fromChain,
|
|
52
|
-
networkFee: trigger.networkFee,
|
|
53
|
-
sourceChainTokenId: trigger.sourceChainTokenId,
|
|
54
|
-
targetChainTokenId: trigger.targetChainTokenId,
|
|
55
|
-
sourceBlockId: trigger.sourceBlockId,
|
|
56
|
-
toChain: trigger.toChain,
|
|
57
|
-
sourceTxId: trigger.sourceTxId,
|
|
58
|
-
sourceChainHeight: trigger.sourceChainHeight,
|
|
59
|
-
};
|
|
60
|
-
if (!saved) {
|
|
61
|
-
this.logger.info(`Storing event trigger [${trigger.boxId}] for event [${trigger.eventId}] at height ${block.height} and extractor ${extractor}`);
|
|
62
|
-
await queryRunner.manager.insert(EventTriggerEntity, entity);
|
|
63
|
-
}
|
|
64
|
-
else {
|
|
65
|
-
this.logger.info(`Updating event trigger ${trigger.boxId} for event [${trigger.eventId}] at height ${block.height} and extractor ${extractor}`);
|
|
66
|
-
await queryRunner.manager.update(EventTriggerEntity, {
|
|
67
|
-
boxId: trigger.boxId,
|
|
68
|
-
}, entity);
|
|
69
|
-
}
|
|
70
|
-
this.logger.debug(`Entity: ${JSON.stringify(entity)}`);
|
|
71
|
-
}
|
|
72
|
-
await queryRunner.commitTransaction();
|
|
73
|
-
}
|
|
74
|
-
catch (e) {
|
|
75
|
-
this.logger.error(`An error occurred during store eventTrigger action: ${e}`);
|
|
76
|
-
await queryRunner.rollbackTransaction();
|
|
77
|
-
success = false;
|
|
78
|
-
}
|
|
79
|
-
finally {
|
|
80
|
-
await queryRunner.release();
|
|
81
|
-
}
|
|
82
|
-
return success;
|
|
83
|
-
};
|
|
84
|
-
/**
|
|
85
|
-
* update spendBlock Column of the commitments in the dataBase
|
|
86
|
-
* @param spendId
|
|
87
|
-
* @param block
|
|
88
|
-
* @param extractor
|
|
89
|
-
* @param txId
|
|
90
|
-
*/
|
|
91
|
-
spendEventTriggers = async (spendId, block, extractor, txId) => {
|
|
92
|
-
const spendIdChunks = chunk(spendId, dbIdChunkSize);
|
|
93
|
-
for (const spendIdChunk of spendIdChunks) {
|
|
94
|
-
const updateResult = await this.datasource
|
|
95
|
-
.createQueryBuilder()
|
|
96
|
-
.update(eventTriggerEntity)
|
|
97
|
-
.set({
|
|
98
|
-
spendBlock: block.hash,
|
|
99
|
-
spendHeight: block.height,
|
|
100
|
-
spendTxId: txId,
|
|
101
|
-
})
|
|
102
|
-
.where({ boxId: In(spendIdChunk) })
|
|
103
|
-
.andWhere({ extractor: extractor })
|
|
104
|
-
.execute();
|
|
105
|
-
if (updateResult.affected && updateResult.affected > 0) {
|
|
106
|
-
const spentRows = await this.triggerEventRepository.findBy({
|
|
107
|
-
boxId: In(spendIdChunk),
|
|
108
|
-
spendBlock: block.hash,
|
|
109
|
-
});
|
|
110
|
-
for (const row of spentRows) {
|
|
111
|
-
this.logger.info(`Spent trigger [${row.boxId}] of event [${row.eventId}] at height ${block.height}`);
|
|
112
|
-
this.logger.debug(`Spent trigger: [${JSON.stringify(row)}]`);
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
};
|
|
117
|
-
/**
|
|
118
|
-
* deleting all permits corresponding to the block(id) and extractor(id)
|
|
119
|
-
* @param block
|
|
120
|
-
* @param extractor
|
|
121
|
-
*/
|
|
122
|
-
deleteBlock = async (block, extractor) => {
|
|
123
|
-
this.logger.info(`Deleting event triggers at block ${block} and extractor ${extractor}`);
|
|
124
|
-
await this.datasource
|
|
125
|
-
.createQueryBuilder()
|
|
126
|
-
.delete()
|
|
127
|
-
.from(EventTriggerEntity)
|
|
128
|
-
.where('extractor = :extractor AND block = :block', {
|
|
129
|
-
block: block,
|
|
130
|
-
extractor: extractor,
|
|
131
|
-
})
|
|
132
|
-
.execute();
|
|
133
|
-
//TODO: should handled null value in spendBlockHeight
|
|
134
|
-
await this.datasource
|
|
135
|
-
.createQueryBuilder()
|
|
136
|
-
.update(EventTriggerEntity)
|
|
137
|
-
.set({ spendBlock: undefined, spendHeight: 0 })
|
|
138
|
-
.where('spendBlock = :block AND block = :block', {
|
|
139
|
-
block: block,
|
|
140
|
-
})
|
|
141
|
-
.execute();
|
|
142
|
-
};
|
|
143
|
-
}
|
|
144
|
-
export default EventTriggerDB;
|
|
145
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"EventTriggerDB.js","sourceRoot":"","sources":["../../lib/actions/EventTriggerDB.ts"],"names":[],"mappings":"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","sourcesContent":["import { DataSource, In, Repository } from 'typeorm';\nimport EventTriggerEntity from '../entities/EventTriggerEntity';\nimport { BlockEntity } from '@rosen-bridge/scanner';\nimport { AbstractLogger } from '@rosen-bridge/logger-interface';\nimport { ExtractedEventTrigger } from '../interfaces/extractedEventTrigger';\nimport eventTriggerEntity from '../entities/EventTriggerEntity';\nimport { chunk } from 'lodash-es';\nimport { dbIdChunkSize } from '../constants';\n\nclass EventTriggerDB {\n  readonly logger: AbstractLogger;\n  private readonly datasource: DataSource;\n  private readonly triggerEventRepository: Repository<EventTriggerEntity>;\n\n  constructor(dataSource: DataSource, logger: AbstractLogger) {\n    this.datasource = dataSource;\n    this.logger = logger;\n    this.triggerEventRepository = dataSource.getRepository(EventTriggerEntity);\n  }\n\n  /**\n   * It stores list of eventTriggers in the dataSource with block id\n   * @param eventTriggers\n   * @param block\n   * @param extractor\n   */\n  storeEventTriggers = async (\n    eventTriggers: Array<ExtractedEventTrigger>,\n    block: BlockEntity,\n    extractor: string\n  ) => {\n    if (eventTriggers.length === 0) return true;\n    const boxIds = eventTriggers.map((trigger) => trigger.boxId);\n    const savedTriggers = await this.triggerEventRepository.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    try {\n      for (const trigger of eventTriggers) {\n        const saved = savedTriggers.some((entity) => {\n          return entity.boxId === trigger.boxId;\n        });\n        const entity = {\n          txId: trigger.txId,\n          eventId: trigger.eventId,\n          boxId: trigger.boxId,\n          boxSerialized: trigger.boxSerialized,\n          block: block.hash,\n          height: block.height,\n          extractor: extractor,\n          WIDs: trigger.WIDs,\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        if (!saved) {\n          this.logger.info(\n            `Storing event trigger [${trigger.boxId}] for event [${trigger.eventId}] at height ${block.height} and extractor ${extractor}`\n          );\n          await queryRunner.manager.insert(EventTriggerEntity, entity);\n        } else {\n          this.logger.info(\n            `Updating event trigger ${trigger.boxId} for event [${trigger.eventId}] at height ${block.height} and extractor ${extractor}`\n          );\n          await queryRunner.manager.update(\n            EventTriggerEntity,\n            {\n              boxId: trigger.boxId,\n            },\n            entity\n          );\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 eventTrigger 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 Column of the commitments in the dataBase\n   * @param spendId\n   * @param block\n   * @param extractor\n   * @param txId\n   */\n  spendEventTriggers = async (\n    spendId: Array<string>,\n    block: BlockEntity,\n    extractor: string,\n    txId: string\n  ): Promise<void> => {\n    const spendIdChunks = chunk(spendId, dbIdChunkSize);\n    for (const spendIdChunk of spendIdChunks) {\n      const updateResult = await this.datasource\n        .createQueryBuilder()\n        .update(eventTriggerEntity)\n        .set({\n          spendBlock: block.hash,\n          spendHeight: block.height,\n          spendTxId: txId,\n        })\n        .where({ boxId: In(spendIdChunk) })\n        .andWhere({ extractor: extractor })\n        .execute();\n\n      if (updateResult.affected && updateResult.affected > 0) {\n        const spentRows = await this.triggerEventRepository.findBy({\n          boxId: In(spendIdChunk),\n          spendBlock: block.hash,\n        });\n        for (const row of spentRows) {\n          this.logger.info(\n            `Spent trigger [${row.boxId}] of event [${row.eventId}] at height ${block.height}`\n          );\n          this.logger.debug(`Spent trigger: [${JSON.stringify(row)}]`);\n        }\n      }\n    }\n  };\n\n  /**\n   * deleting all permits corresponding to the block(id) and extractor(id)\n   * @param block\n   * @param extractor\n   */\n  deleteBlock = async (block: string, extractor: string) => {\n    this.logger.info(\n      `Deleting event triggers at block ${block} and extractor ${extractor}`\n    );\n    await this.datasource\n      .createQueryBuilder()\n      .delete()\n      .from(EventTriggerEntity)\n      .where('extractor = :extractor AND block = :block', {\n        block: block,\n        extractor: extractor,\n      })\n      .execute();\n    //TODO: should handled null value in spendBlockHeight\n    await this.datasource\n      .createQueryBuilder()\n      .update(EventTriggerEntity)\n      .set({ spendBlock: undefined, spendHeight: 0 })\n      .where('spendBlock = :block AND block = :block', {\n        block: block,\n      })\n      .execute();\n  };\n}\n\nexport default EventTriggerDB;\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"commitmentDB.d.ts","sourceRoot":"","sources":["../../lib/actions/commitmentDB.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAkB,MAAM,SAAS,CAAC;AACrD,OAAO,EAAE,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AAExE,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,gCAAgC,CAAC;AAIhE,cAAM,sBAAsB;IAC1B,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,EAAE,cAAc;IAM1D;;;;;OAKG;IACH,gBAAgB,gBACD,MAAM,mBAAmB,CAAC,SAChC,WAAW,aACP,MAAM,KAChB,QAAQ,OAAO,CAAC,CA0DjB;IAEF;;;;;OAKG;IACH,gBAAgB,YACL,MAAM,MAAM,CAAC,SACf,WAAW,aACP,MAAM,KAChB,QAAQ,IAAI,CAAC,CAwBd;IAEF;;;;OAIG;IACH,qBAAqB,UAAiB,MAAM,aAAa,MAAM,mBAsB7D;CACH;AAED,eAAe,sBAAsB,CAAC"}
|