@rosen-bridge/watcher-data-extractor 9.0.0 → 10.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/actions/EventTriggerAction.d.ts +11 -23
- package/dist/actions/EventTriggerAction.d.ts.map +1 -1
- package/dist/actions/EventTriggerAction.js +57 -102
- package/dist/entities/EventTriggerEntity.d.ts +2 -9
- package/dist/entities/EventTriggerEntity.d.ts.map +1 -1
- package/dist/entities/EventTriggerEntity.js +5 -45
- package/dist/extractor/EventTriggerExtractor.d.ts +3 -2
- package/dist/extractor/EventTriggerExtractor.d.ts.map +1 -1
- package/dist/extractor/EventTriggerExtractor.js +15 -12
- package/dist/interfaces/extractedEventTrigger.d.ts +1 -1
- package/dist/interfaces/extractedEventTrigger.d.ts.map +1 -1
- package/dist/interfaces/extractedEventTrigger.js +1 -1
- package/dist/migrations/index.d.ts +2 -2
- package/dist/migrations/index.d.ts.map +1 -1
- package/dist/migrations/index.js +5 -1
- package/dist/migrations/postgres/1737785036299-migration.d.ts +7 -0
- package/dist/migrations/postgres/1737785036299-migration.d.ts.map +1 -0
- package/dist/migrations/postgres/1737785036299-migration.js +32 -0
- package/dist/migrations/sqlite/1737547743177-migration.d.ts +7 -0
- package/dist/migrations/sqlite/1737547743177-migration.d.ts.map +1 -0
- package/dist/migrations/sqlite/1737547743177-migration.js +204 -0
- package/package.json +4 -4
|
@@ -1,19 +1,19 @@
|
|
|
1
1
|
import { DataSource } from 'typeorm';
|
|
2
2
|
import { AbstractLogger } from '@rosen-bridge/abstract-logger';
|
|
3
|
-
import { AbstractInitializableErgoExtractorAction, BlockInfo, SpendInfo } from '@rosen-bridge/abstract-extractor';
|
|
3
|
+
import { AbstractInitializableErgoExtractorAction, BlockInfo, BoxInfo, SpendInfo } from '@rosen-bridge/abstract-extractor';
|
|
4
|
+
import EventTriggerEntity from '../entities/EventTriggerEntity';
|
|
4
5
|
import { ExtractedEventTrigger } from '../interfaces/extractedEventTrigger';
|
|
5
|
-
declare class EventTriggerAction extends AbstractInitializableErgoExtractorAction<ExtractedEventTrigger> {
|
|
6
|
-
readonly logger: AbstractLogger;
|
|
6
|
+
declare class EventTriggerAction extends AbstractInitializableErgoExtractorAction<ExtractedEventTrigger, EventTriggerEntity> {
|
|
7
7
|
private readonly dataSource;
|
|
8
|
-
private readonly repository;
|
|
9
8
|
constructor(dataSource: DataSource, logger?: AbstractLogger);
|
|
10
9
|
/**
|
|
11
|
-
*
|
|
12
|
-
* @param eventTriggers
|
|
13
|
-
* @param block
|
|
14
|
-
* @param extractorId
|
|
10
|
+
* create the box entity from extracted data and block information
|
|
15
11
|
*/
|
|
16
|
-
|
|
12
|
+
createEntity: (triggerBoxes: ExtractedEventTrigger[], block: BlockInfo, extractor: string) => Omit<EventTriggerEntity, 'id'>[];
|
|
13
|
+
/**
|
|
14
|
+
* convert the database entity back to raw data
|
|
15
|
+
*/
|
|
16
|
+
convertEntityToData: (entities: EventTriggerEntity[]) => ExtractedEventTrigger[];
|
|
17
17
|
/**
|
|
18
18
|
* update spending information of stored event triggers
|
|
19
19
|
* and set result and paymentTxId of the event
|
|
@@ -21,21 +21,9 @@ declare class EventTriggerAction extends AbstractInitializableErgoExtractorActio
|
|
|
21
21
|
* @param spendInfArray
|
|
22
22
|
* @param block
|
|
23
23
|
* @param extractorId
|
|
24
|
+
* @returns spent box ids
|
|
24
25
|
*/
|
|
25
|
-
spendBoxes: (spendInfoArray: Array<SpendInfo>, block: BlockInfo, extractorId: string) => Promise<
|
|
26
|
-
/**
|
|
27
|
-
* remove all existing data for the extractor
|
|
28
|
-
* @param extractorId
|
|
29
|
-
*/
|
|
30
|
-
removeAllData: (extractorId: string) => Promise<void>;
|
|
31
|
-
/**
|
|
32
|
-
* delete extracted data from a specific block for specified extractor
|
|
33
|
-
* if a box is spend in this block mark it as unspent
|
|
34
|
-
* if a box is created in this block remove it from database
|
|
35
|
-
* @param block
|
|
36
|
-
* @param extractor
|
|
37
|
-
*/
|
|
38
|
-
deleteBlockBoxes: (block: string, extractor: string) => Promise<void>;
|
|
26
|
+
spendBoxes: (spendInfoArray: Array<SpendInfo>, block: BlockInfo, extractorId: string) => Promise<BoxInfo[]>;
|
|
39
27
|
}
|
|
40
28
|
export default EventTriggerAction;
|
|
41
29
|
//# sourceMappingURL=EventTriggerAction.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EventTriggerAction.d.ts","sourceRoot":"","sources":["../../lib/actions/EventTriggerAction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,
|
|
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,SAAS,EACT,OAAO,EAEP,SAAS,EACV,MAAM,kCAAkC,CAAC;AAE1C,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,CAuCnB;CACH;AAED,eAAe,kBAAkB,CAAC"}
|
|
@@ -1,87 +1,66 @@
|
|
|
1
1
|
import { In } from 'typeorm';
|
|
2
|
-
import { DummyLogger } from '@rosen-bridge/abstract-logger';
|
|
3
2
|
import { AbstractInitializableErgoExtractorAction, DB_CHUNK_SIZE, } from '@rosen-bridge/abstract-extractor';
|
|
4
3
|
import EventTriggerEntity from '../entities/EventTriggerEntity';
|
|
5
4
|
import { JsonBI } from '../utils';
|
|
6
|
-
import { chunk } from 'lodash-es';
|
|
5
|
+
import { chunk, pick } from 'lodash-es';
|
|
7
6
|
class EventTriggerAction extends AbstractInitializableErgoExtractorAction {
|
|
8
|
-
logger;
|
|
9
7
|
dataSource;
|
|
10
|
-
repository;
|
|
11
8
|
constructor(dataSource, logger) {
|
|
12
|
-
super();
|
|
9
|
+
super(dataSource, EventTriggerEntity, logger);
|
|
13
10
|
this.dataSource = dataSource;
|
|
14
|
-
this.logger = logger ? logger : new DummyLogger();
|
|
15
|
-
this.repository = dataSource.getRepository(EventTriggerEntity);
|
|
16
11
|
}
|
|
17
12
|
/**
|
|
18
|
-
*
|
|
19
|
-
* @param eventTriggers
|
|
20
|
-
* @param block
|
|
21
|
-
* @param extractorId
|
|
13
|
+
* create the box entity from extracted data and block information
|
|
22
14
|
*/
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
this.logger.debug(`Entity: ${JSON.stringify(entity)}`);
|
|
73
|
-
}
|
|
74
|
-
await queryRunner.commitTransaction();
|
|
75
|
-
}
|
|
76
|
-
catch (e) {
|
|
77
|
-
this.logger.error(`An error occurred during store eventTrigger action: ${e}`);
|
|
78
|
-
await queryRunner.rollbackTransaction();
|
|
79
|
-
success = false;
|
|
80
|
-
}
|
|
81
|
-
finally {
|
|
82
|
-
await queryRunner.release();
|
|
83
|
-
}
|
|
84
|
-
return success;
|
|
15
|
+
createEntity = (triggerBoxes, block, extractor) => {
|
|
16
|
+
return triggerBoxes.map((trigger) => ({
|
|
17
|
+
txId: trigger.txId,
|
|
18
|
+
eventId: trigger.eventId,
|
|
19
|
+
boxId: trigger.boxId,
|
|
20
|
+
serialized: trigger.serialized,
|
|
21
|
+
block: block.hash,
|
|
22
|
+
height: block.height,
|
|
23
|
+
extractor: extractor,
|
|
24
|
+
WIDsCount: trigger.WIDsCount,
|
|
25
|
+
WIDsHash: trigger.WIDsHash,
|
|
26
|
+
amount: trigger.amount,
|
|
27
|
+
bridgeFee: trigger.bridgeFee,
|
|
28
|
+
fromAddress: trigger.fromAddress,
|
|
29
|
+
toAddress: trigger.toAddress,
|
|
30
|
+
fromChain: trigger.fromChain,
|
|
31
|
+
networkFee: trigger.networkFee,
|
|
32
|
+
sourceChainTokenId: trigger.sourceChainTokenId,
|
|
33
|
+
targetChainTokenId: trigger.targetChainTokenId,
|
|
34
|
+
sourceBlockId: trigger.sourceBlockId,
|
|
35
|
+
toChain: trigger.toChain,
|
|
36
|
+
sourceTxId: trigger.sourceTxId,
|
|
37
|
+
sourceChainHeight: trigger.sourceChainHeight,
|
|
38
|
+
}));
|
|
39
|
+
};
|
|
40
|
+
/**
|
|
41
|
+
* convert the database entity back to raw data
|
|
42
|
+
*/
|
|
43
|
+
convertEntityToData = (entities) => {
|
|
44
|
+
return entities.map((data) => pick(data, [
|
|
45
|
+
'eventId',
|
|
46
|
+
'txId',
|
|
47
|
+
'boxId',
|
|
48
|
+
'serialized',
|
|
49
|
+
'fromChain',
|
|
50
|
+
'toChain',
|
|
51
|
+
'fromAddress',
|
|
52
|
+
'toAddress',
|
|
53
|
+
'amount',
|
|
54
|
+
'bridgeFee',
|
|
55
|
+
'networkFee',
|
|
56
|
+
'sourceChainTokenId',
|
|
57
|
+
'targetChainTokenId',
|
|
58
|
+
'sourceBlockId',
|
|
59
|
+
'sourceTxId',
|
|
60
|
+
'WIDsCount',
|
|
61
|
+
'WIDsHash',
|
|
62
|
+
'sourceChainHeight',
|
|
63
|
+
]));
|
|
85
64
|
};
|
|
86
65
|
/**
|
|
87
66
|
* update spending information of stored event triggers
|
|
@@ -90,8 +69,10 @@ class EventTriggerAction extends AbstractInitializableErgoExtractorAction {
|
|
|
90
69
|
* @param spendInfArray
|
|
91
70
|
* @param block
|
|
92
71
|
* @param extractorId
|
|
72
|
+
* @returns spent box ids
|
|
93
73
|
*/
|
|
94
74
|
spendBoxes = async (spendInfoArray, block, extractorId) => {
|
|
75
|
+
const spentData = [];
|
|
95
76
|
const spendInfoChunks = chunk(spendInfoArray, DB_CHUNK_SIZE);
|
|
96
77
|
for (const spendInfoChunk of spendInfoChunks) {
|
|
97
78
|
const spentTriggers = await this.repository.findBy({
|
|
@@ -110,39 +91,13 @@ class EventTriggerAction extends AbstractInitializableErgoExtractorAction {
|
|
|
110
91
|
result: spendInfo.extras[0],
|
|
111
92
|
paymentTxId: spendInfo.extras[1],
|
|
112
93
|
});
|
|
94
|
+
spentData.push(pick(spendInfo, ['boxId']));
|
|
113
95
|
this.logger.info(`Spent trigger [${spentTrigger.boxId}] of event [${spentTrigger.eventId}] at height ${block.height}`);
|
|
114
96
|
this.logger.debug(`Spent trigger: [${JSON.stringify(spentTrigger)}] with spending information [${JsonBI.stringify(spendInfo)}]`);
|
|
115
97
|
}
|
|
116
98
|
}
|
|
117
|
-
|
|
118
|
-
/**
|
|
119
|
-
* remove all existing data for the extractor
|
|
120
|
-
* @param extractorId
|
|
121
|
-
*/
|
|
122
|
-
removeAllData = async (extractorId) => {
|
|
123
|
-
await this.repository.delete({ extractor: extractorId });
|
|
124
|
-
};
|
|
125
|
-
/**
|
|
126
|
-
* delete extracted data from a specific block for specified extractor
|
|
127
|
-
* if a box is spend in this block mark it as unspent
|
|
128
|
-
* if a box is created in this block remove it from database
|
|
129
|
-
* @param block
|
|
130
|
-
* @param extractor
|
|
131
|
-
*/
|
|
132
|
-
deleteBlockBoxes = async (block, extractor) => {
|
|
133
|
-
this.logger.info(`Deleting event triggers at block ${block} and extractor ${extractor}`);
|
|
134
|
-
await this.repository.delete({
|
|
135
|
-
block: block,
|
|
136
|
-
extractor: extractor,
|
|
137
|
-
});
|
|
138
|
-
await this.repository.update({ spendBlock: block, extractor: extractor }, {
|
|
139
|
-
spendBlock: null,
|
|
140
|
-
spendTxId: null,
|
|
141
|
-
spendHeight: null,
|
|
142
|
-
result: null,
|
|
143
|
-
paymentTxId: null,
|
|
144
|
-
});
|
|
99
|
+
return spentData;
|
|
145
100
|
};
|
|
146
101
|
}
|
|
147
102
|
export default EventTriggerAction;
|
|
148
|
-
//# 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, Repository } from 'typeorm';\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport {\n  AbstractInitializableErgoExtractorAction,\n  BlockInfo,\n  DB_CHUNK_SIZE,\n  SpendInfo,\n} from '@rosen-bridge/abstract-extractor';\n\nimport EventTriggerEntity from '../entities/EventTriggerEntity';\nimport { ExtractedEventTrigger } from '../interfaces/extractedEventTrigger';\nimport { JsonBI } from '../utils';\nimport { chunk } from 'lodash-es';\n\nclass EventTriggerAction extends AbstractInitializableErgoExtractorAction<ExtractedEventTrigger> {\n  readonly logger: AbstractLogger;\n  private readonly dataSource: DataSource;\n  private readonly repository: Repository<EventTriggerEntity>;\n\n  constructor(dataSource: DataSource, logger?: AbstractLogger) {\n    super();\n    this.dataSource = dataSource;\n    this.logger = logger ? logger : new DummyLogger();\n    this.repository = dataSource.getRepository(EventTriggerEntity);\n  }\n\n  /**\n   * insert all extracted eventTriggers for a block in an atomic db transaction\n   * @param eventTriggers\n   * @param block\n   * @param extractorId\n   */\n  insertBoxes = async (\n    eventTriggers: Array<ExtractedEventTrigger>,\n    block: BlockInfo,\n    extractorId: string\n  ) => {\n    if (eventTriggers.length === 0) return true;\n    const boxIds = eventTriggers.map((trigger) => trigger.boxId);\n    const savedTriggers = await this.repository.findBy({\n      boxId: In(boxIds),\n      extractor: extractorId,\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      EventTriggerEntity\n    );\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: extractorId,\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        if (!saved) {\n          this.logger.info(\n            `Storing event trigger [${trigger.boxId}] for event [${trigger.eventId}] at height ${block.height} and extractor ${extractorId}`\n          );\n          await repository.insert(entity);\n        } else {\n          this.logger.info(\n            `Updating event trigger ${trigger.boxId} for event [${trigger.eventId}] at height ${block.height} and extractor ${extractorId}`\n          );\n          await repository.update({ boxId: trigger.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 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 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   */\n  spendBoxes = async (\n    spendInfoArray: Array<SpendInfo>,\n    block: BlockInfo,\n    extractorId: string\n  ): Promise<void> => {\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.length < 2) {\n          throw Error(\n            `Impossible case: spending information extras does not contain result or paymentTxId, ${spendInfo}`\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[0],\n            paymentTxId: spendInfo.extras[1],\n          }\n        );\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  };\n\n  /**\n   * remove all existing data for the extractor\n   * @param extractorId\n   */\n  removeAllData = async (extractorId: string) => {\n    await this.repository.delete({ extractor: extractorId });\n  };\n\n  /**\n   * delete extracted data from a specific block for specified extractor\n   * if a box is spend in this block mark it as unspent\n   * if a box is created in this block remove it from database\n   * @param block\n   * @param extractor\n   */\n  deleteBlockBoxes = async (block: string, extractor: string) => {\n    this.logger.info(\n      `Deleting event triggers at block ${block} and extractor ${extractor}`\n    );\n    await this.repository.delete({\n      block: block,\n      extractor: extractor,\n    });\n    await this.repository.update(\n      { spendBlock: block, extractor: extractor },\n      {\n        spendBlock: null,\n        spendTxId: null,\n        spendHeight: null,\n        result: null,\n        paymentTxId: null,\n      }\n    );\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":"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","sourcesContent":["import { DataSource, In } from 'typeorm';\nimport { AbstractLogger } from '@rosen-bridge/abstract-logger';\nimport {\n  AbstractInitializableErgoExtractorAction,\n  BlockInfo,\n  BoxInfo,\n  DB_CHUNK_SIZE,\n  SpendInfo,\n} from '@rosen-bridge/abstract-extractor';\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.length < 2) {\n          throw Error(\n            `Impossible case: spending information extras does not contain result or paymentTxId, ${spendInfo}`\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[0],\n            paymentTxId: spendInfo.extras[1],\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,12 +1,7 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import { AbstractErgoExtractorEntity } from '@rosen-bridge/abstract-extractor';
|
|
2
|
+
declare class EventTriggerEntity extends AbstractErgoExtractorEntity {
|
|
3
3
|
eventId: string;
|
|
4
4
|
txId: string;
|
|
5
|
-
extractor: string;
|
|
6
|
-
boxId: string;
|
|
7
|
-
boxSerialized: string;
|
|
8
|
-
block: string;
|
|
9
|
-
height: number;
|
|
10
5
|
fromChain: string;
|
|
11
6
|
toChain: string;
|
|
12
7
|
fromAddress: string;
|
|
@@ -21,8 +16,6 @@ declare class EventTriggerEntity {
|
|
|
21
16
|
sourceBlockId: string;
|
|
22
17
|
WIDsCount: number;
|
|
23
18
|
WIDsHash: string;
|
|
24
|
-
spendBlock?: string | null;
|
|
25
|
-
spendHeight?: number | null;
|
|
26
19
|
spendTxId?: string | null;
|
|
27
20
|
result?: string | null;
|
|
28
21
|
paymentTxId?: string | null;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EventTriggerEntity.d.ts","sourceRoot":"","sources":["../../lib/entities/EventTriggerEntity.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"EventTriggerEntity.d.ts","sourceRoot":"","sources":["../../lib/entities/EventTriggerEntity.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,2BAA2B,EAAE,MAAM,kCAAkC,CAAC;AAG/E,cACM,kBAAmB,SAAQ,2BAA2B;IAE1D,OAAO,EAAE,MAAM,CAAC;IAGhB,IAAI,EAAE,MAAM,CAAC;IAGb,SAAS,EAAE,MAAM,CAAC;IAGlB,OAAO,EAAE,MAAM,CAAC;IAGhB,WAAW,EAAE,MAAM,CAAC;IAGpB,SAAS,EAAE,MAAM,CAAC;IAGlB,MAAM,EAAE,MAAM,CAAC;IAGf,SAAS,EAAE,MAAM,CAAC;IAGlB,UAAU,EAAE,MAAM,CAAC;IAGnB,kBAAkB,EAAE,MAAM,CAAC;IAG3B,iBAAiB,EAAE,MAAM,CAAC;IAG1B,kBAAkB,EAAE,MAAM,CAAC;IAG3B,UAAU,EAAE,MAAM,CAAC;IAGnB,aAAa,EAAE,MAAM,CAAC;IAGtB,SAAS,EAAE,MAAM,CAAC;IAGlB,QAAQ,EAAE,MAAM,CAAC;IAGjB,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAG1B,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAGvB,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CAC7B;AAED,eAAe,kBAAkB,CAAC"}
|
|
@@ -7,16 +7,11 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
7
7
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
8
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
9
|
};
|
|
10
|
-
import {
|
|
11
|
-
|
|
12
|
-
|
|
10
|
+
import { AbstractErgoExtractorEntity } from '@rosen-bridge/abstract-extractor';
|
|
11
|
+
import { Column, Entity } from 'typeorm';
|
|
12
|
+
let EventTriggerEntity = class EventTriggerEntity extends AbstractErgoExtractorEntity {
|
|
13
13
|
eventId;
|
|
14
14
|
txId;
|
|
15
|
-
extractor;
|
|
16
|
-
boxId;
|
|
17
|
-
boxSerialized;
|
|
18
|
-
block;
|
|
19
|
-
height;
|
|
20
15
|
fromChain;
|
|
21
16
|
toChain;
|
|
22
17
|
fromAddress;
|
|
@@ -31,16 +26,10 @@ let EventTriggerEntity = class EventTriggerEntity {
|
|
|
31
26
|
sourceBlockId;
|
|
32
27
|
WIDsCount;
|
|
33
28
|
WIDsHash;
|
|
34
|
-
spendBlock;
|
|
35
|
-
spendHeight;
|
|
36
29
|
spendTxId;
|
|
37
30
|
result;
|
|
38
31
|
paymentTxId;
|
|
39
32
|
};
|
|
40
|
-
__decorate([
|
|
41
|
-
PrimaryGeneratedColumn(),
|
|
42
|
-
__metadata("design:type", Number)
|
|
43
|
-
], EventTriggerEntity.prototype, "id", void 0);
|
|
44
33
|
__decorate([
|
|
45
34
|
Column({ default: 'Not-set' }),
|
|
46
35
|
__metadata("design:type", String)
|
|
@@ -49,26 +38,6 @@ __decorate([
|
|
|
49
38
|
Column(),
|
|
50
39
|
__metadata("design:type", String)
|
|
51
40
|
], EventTriggerEntity.prototype, "txId", void 0);
|
|
52
|
-
__decorate([
|
|
53
|
-
Column(),
|
|
54
|
-
__metadata("design:type", String)
|
|
55
|
-
], EventTriggerEntity.prototype, "extractor", void 0);
|
|
56
|
-
__decorate([
|
|
57
|
-
Column(),
|
|
58
|
-
__metadata("design:type", String)
|
|
59
|
-
], EventTriggerEntity.prototype, "boxId", void 0);
|
|
60
|
-
__decorate([
|
|
61
|
-
Column(),
|
|
62
|
-
__metadata("design:type", String)
|
|
63
|
-
], EventTriggerEntity.prototype, "boxSerialized", void 0);
|
|
64
|
-
__decorate([
|
|
65
|
-
Column(),
|
|
66
|
-
__metadata("design:type", String)
|
|
67
|
-
], EventTriggerEntity.prototype, "block", void 0);
|
|
68
|
-
__decorate([
|
|
69
|
-
Column(),
|
|
70
|
-
__metadata("design:type", Number)
|
|
71
|
-
], EventTriggerEntity.prototype, "height", void 0);
|
|
72
41
|
__decorate([
|
|
73
42
|
Column(),
|
|
74
43
|
__metadata("design:type", String)
|
|
@@ -125,14 +94,6 @@ __decorate([
|
|
|
125
94
|
Column(),
|
|
126
95
|
__metadata("design:type", String)
|
|
127
96
|
], EventTriggerEntity.prototype, "WIDsHash", void 0);
|
|
128
|
-
__decorate([
|
|
129
|
-
Column({ nullable: true, type: 'text' }),
|
|
130
|
-
__metadata("design:type", Object)
|
|
131
|
-
], EventTriggerEntity.prototype, "spendBlock", void 0);
|
|
132
|
-
__decorate([
|
|
133
|
-
Column({ nullable: true, type: 'int' }),
|
|
134
|
-
__metadata("design:type", Object)
|
|
135
|
-
], EventTriggerEntity.prototype, "spendHeight", void 0);
|
|
136
97
|
__decorate([
|
|
137
98
|
Column({ nullable: true, type: 'text' }),
|
|
138
99
|
__metadata("design:type", Object)
|
|
@@ -146,8 +107,7 @@ __decorate([
|
|
|
146
107
|
__metadata("design:type", Object)
|
|
147
108
|
], EventTriggerEntity.prototype, "paymentTxId", void 0);
|
|
148
109
|
EventTriggerEntity = __decorate([
|
|
149
|
-
Entity('event_trigger_entity')
|
|
150
|
-
Unique(['boxId', 'extractor'])
|
|
110
|
+
Entity('event_trigger_entity')
|
|
151
111
|
], EventTriggerEntity);
|
|
152
112
|
export default EventTriggerEntity;
|
|
153
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRXZlbnRUcmlnZ2VyRW50aXR5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vbGliL2VudGl0aWVzL0V2ZW50VHJpZ2dlckVudGl0eS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQSxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUMvRSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUd6QyxJQUFNLGtCQUFrQixHQUF4QixNQUFNLGtCQUFtQixTQUFRLDJCQUEyQjtJQUUxRCxPQUFPLENBQVM7SUFHaEIsSUFBSSxDQUFTO0lBR2IsU0FBUyxDQUFTO0lBR2xCLE9BQU8sQ0FBUztJQUdoQixXQUFXLENBQVM7SUFHcEIsU0FBUyxDQUFTO0lBR2xCLE1BQU0sQ0FBUztJQUdmLFNBQVMsQ0FBUztJQUdsQixVQUFVLENBQVM7SUFHbkIsa0JBQWtCLENBQVM7SUFHM0IsaUJBQWlCLENBQVM7SUFHMUIsa0JBQWtCLENBQVM7SUFHM0IsVUFBVSxDQUFTO0lBR25CLGFBQWEsQ0FBUztJQUd0QixTQUFTLENBQVM7SUFHbEIsUUFBUSxDQUFTO0lBR2pCLFNBQVMsQ0FBaUI7SUFHMUIsTUFBTSxDQUFpQjtJQUd2QixXQUFXLENBQWlCO0NBQzdCLENBQUE7QUF4REM7SUFBQyxNQUFNLENBQUMsRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFLENBQUM7O21EQUNmO0FBRWhCO0lBQUMsTUFBTSxFQUFFOztnREFDSTtBQUViO0lBQUMsTUFBTSxFQUFFOztxREFDUztBQUVsQjtJQUFDLE1BQU0sRUFBRTs7bURBQ087QUFFaEI7SUFBQyxNQUFNLEVBQUU7O3VEQUNXO0FBRXBCO0lBQUMsTUFBTSxFQUFFOztxREFDUztBQUVsQjtJQUFDLE1BQU0sRUFBRTs7a0RBQ007QUFFZjtJQUFDLE1BQU0sRUFBRTs7cURBQ1M7QUFFbEI7SUFBQyxNQUFNLEVBQUU7O3NEQUNVO0FBRW5CO0lBQUMsTUFBTSxFQUFFOzs4REFDa0I7QUFFM0I7SUFBQyxNQUFNLEVBQUU7OzZEQUNpQjtBQUUxQjtJQUFDLE1BQU0sRUFBRTs7OERBQ2tCO0FBRTNCO0lBQUMsTUFBTSxFQUFFOztzREFDVTtBQUVuQjtJQUFDLE1BQU0sRUFBRTs7eURBQ2E7QUFFdEI7SUFBQyxNQUFNLEVBQUU7O3FEQUNTO0FBRWxCO0lBQUMsTUFBTSxFQUFFOztvREFDUTtBQUVqQjtJQUFDLE1BQU0sQ0FBQyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxDQUFDOztxREFDZjtBQUUxQjtJQUFDLE1BQU0sQ0FBQyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxDQUFDOztrREFDbEI7QUFFdkI7SUFBQyxNQUFNLENBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsQ0FBQzs7dURBQ2I7QUF4RHhCLGtCQUFrQjtJQUR2QixNQUFNLENBQUMsc0JBQXNCLENBQUM7R0FDekIsa0JBQWtCLENBeUR2QjtBQUVELGVBQWUsa0JBQWtCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBYnN0cmFjdEVyZ29FeHRyYWN0b3JFbnRpdHkgfSBmcm9tICdAcm9zZW4tYnJpZGdlL2Fic3RyYWN0LWV4dHJhY3Rvcic7XG5pbXBvcnQgeyBDb2x1bW4sIEVudGl0eSB9IGZyb20gJ3R5cGVvcm0nO1xuXG5ARW50aXR5KCdldmVudF90cmlnZ2VyX2VudGl0eScpXG5jbGFzcyBFdmVudFRyaWdnZXJFbnRpdHkgZXh0ZW5kcyBBYnN0cmFjdEVyZ29FeHRyYWN0b3JFbnRpdHkge1xuICBAQ29sdW1uKHsgZGVmYXVsdDogJ05vdC1zZXQnIH0pXG4gIGV2ZW50SWQ6IHN0cmluZztcblxuICBAQ29sdW1uKClcbiAgdHhJZDogc3RyaW5nO1xuXG4gIEBDb2x1bW4oKVxuICBmcm9tQ2hhaW46IHN0cmluZztcblxuICBAQ29sdW1uKClcbiAgdG9DaGFpbjogc3RyaW5nO1xuXG4gIEBDb2x1bW4oKVxuICBmcm9tQWRkcmVzczogc3RyaW5nO1xuXG4gIEBDb2x1bW4oKVxuICB0b0FkZHJlc3M6IHN0cmluZztcblxuICBAQ29sdW1uKClcbiAgYW1vdW50OiBzdHJpbmc7XG5cbiAgQENvbHVtbigpXG4gIGJyaWRnZUZlZTogc3RyaW5nO1xuXG4gIEBDb2x1bW4oKVxuICBuZXR3b3JrRmVlOiBzdHJpbmc7XG5cbiAgQENvbHVtbigpXG4gIHNvdXJjZUNoYWluVG9rZW5JZDogc3RyaW5nO1xuXG4gIEBDb2x1bW4oKVxuICBzb3VyY2VDaGFpbkhlaWdodDogbnVtYmVyO1xuXG4gIEBDb2x1bW4oKVxuICB0YXJnZXRDaGFpblRva2VuSWQ6IHN0cmluZztcblxuICBAQ29sdW1uKClcbiAgc291cmNlVHhJZDogc3RyaW5nO1xuXG4gIEBDb2x1bW4oKVxuICBzb3VyY2VCbG9ja0lkOiBzdHJpbmc7XG5cbiAgQENvbHVtbigpXG4gIFdJRHNDb3VudDogbnVtYmVyO1xuXG4gIEBDb2x1bW4oKVxuICBXSURzSGFzaDogc3RyaW5nO1xuXG4gIEBDb2x1bW4oeyBudWxsYWJsZTogdHJ1ZSwgdHlwZTogJ3RleHQnIH0pXG4gIHNwZW5kVHhJZD86IHN0cmluZyB8IG51bGw7XG5cbiAgQENvbHVtbih7IG51bGxhYmxlOiB0cnVlLCB0eXBlOiAndGV4dCcgfSlcbiAgcmVzdWx0Pzogc3RyaW5nIHwgbnVsbDtcblxuICBAQ29sdW1uKHsgbnVsbGFibGU6IHRydWUsIHR5cGU6ICd0ZXh0JyB9KVxuICBwYXltZW50VHhJZD86IHN0cmluZyB8IG51bGw7XG59XG5cbmV4cG9ydCBkZWZhdWx0IEV2ZW50VHJpZ2dlckVudGl0eTtcbiJdfQ==
|
|
@@ -5,14 +5,15 @@ import { AbstractInitializableErgoExtractor, BlockInfo, ErgoNetworkType, OutputB
|
|
|
5
5
|
import EventTriggerAction from '../actions/EventTriggerAction';
|
|
6
6
|
import { ExtractedEventTrigger } from '../interfaces/extractedEventTrigger';
|
|
7
7
|
import { EventResult } from '../types';
|
|
8
|
-
|
|
8
|
+
import EventTriggerEntity from '../entities/EventTriggerEntity';
|
|
9
|
+
declare class EventTriggerExtractor extends AbstractInitializableErgoExtractor<ExtractedEventTrigger, EventTriggerEntity> {
|
|
9
10
|
id: string;
|
|
10
11
|
protected readonly actions: EventTriggerAction;
|
|
11
12
|
private readonly eventTriggerErgoTree;
|
|
12
13
|
private readonly permitErgoTree;
|
|
13
14
|
private readonly fraudErgoTree;
|
|
14
15
|
private readonly RWT;
|
|
15
|
-
constructor(id: string, dataSource: DataSource, type: ErgoNetworkType, url: string, address: string, RWT: string, permitAddress: string, fraudAddress: string, logger?: AbstractLogger);
|
|
16
|
+
constructor(id: string, dataSource: DataSource, type: ErgoNetworkType, url: string, address: string, RWT: string, permitAddress: string, fraudAddress: string, logger?: AbstractLogger, initialize?: boolean);
|
|
16
17
|
/**
|
|
17
18
|
* get Id for current extractor
|
|
18
19
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EventTriggerExtractor.d.ts","sourceRoot":"","sources":["../../lib/extractor/EventTriggerExtractor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAGrC,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EACL,kCAAkC,EAClC,SAAS,
|
|
1
|
+
{"version":3,"file":"EventTriggerExtractor.d.ts","sourceRoot":"","sources":["../../lib/extractor/EventTriggerExtractor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAGrC,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EACL,kCAAkC,EAClC,SAAS,EAET,eAAe,EACf,SAAS,EAEV,MAAM,kCAAkC,CAAC;AAE1C,OAAO,kBAAkB,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EAAE,qBAAqB,EAAE,MAAM,qCAAqC,CAAC;AAE5E,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AACvC,OAAO,kBAAkB,MAAM,gCAAgC,CAAC;AAEhE,cAAM,qBAAsB,SAAQ,kCAAkC,CACpE,qBAAqB,EACrB,kBAAkB,CACnB;IACC,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,kBAAkB,CAAC;IAC/C,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAS;IAC9C,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAS;IACxC,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAS;IACvC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAS;gBAG3B,EAAE,EAAE,MAAM,EACV,UAAU,EAAE,UAAU,EACtB,IAAI,EAAE,eAAe,EACrB,GAAG,EAAE,MAAM,EACX,OAAO,EAAE,MAAM,EACf,GAAG,EAAE,MAAM,EACX,aAAa,EAAE,MAAM,EACrB,YAAY,EAAE,MAAM,EACpB,MAAM,CAAC,EAAE,cAAc,EACvB,UAAU,UAAO;IAiBnB;;OAEG;IACH,KAAK,eAAiB;IAEtB;;;;;;;;;OASG;IACH,OAAO,QAAS,SAAS,KAAG,OAAO,CA2BjC;IAEF;;;;OAIG;IACH,cAAc,QACP,SAAS,KACb,KAAK,qBAAqB,EAAE,YAAY,GAAG,aAAa,CAAC,GAAG,SAAS,CAwDtE;IAEF;;;;;OAKG;IACH,mBAAmB,QACZ,MAAM,WAAW,CAAC,SAChB,SAAS,KACf,QAAQ,OAAO,CAAC,CAuDjB;IAEF;;;;;OAKG;IACH,SAAS,CAAC,kBAAkB,gBAAiB,WAAW;;;MA0CtD;CACH;AAED,eAAe,qBAAqB,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import * as wasm from 'ergo-lib-wasm-nodejs';
|
|
2
2
|
import { blake2b } from 'blakejs';
|
|
3
|
-
import { AbstractInitializableErgoExtractor, } from '@rosen-bridge/abstract-extractor';
|
|
3
|
+
import { AbstractInitializableErgoExtractor, CallbackType, } from '@rosen-bridge/abstract-extractor';
|
|
4
4
|
import EventTriggerAction from '../actions/EventTriggerAction';
|
|
5
5
|
import { JsonBI } from '../utils';
|
|
6
6
|
import { EventResult } from '../types';
|
|
@@ -11,8 +11,8 @@ class EventTriggerExtractor extends AbstractInitializableErgoExtractor {
|
|
|
11
11
|
permitErgoTree;
|
|
12
12
|
fraudErgoTree;
|
|
13
13
|
RWT;
|
|
14
|
-
constructor(id, dataSource, type, url, address, RWT, permitAddress, fraudAddress, logger) {
|
|
15
|
-
super(type, url, address, logger);
|
|
14
|
+
constructor(id, dataSource, type, url, address, RWT, permitAddress, fraudAddress, logger, initialize = true) {
|
|
15
|
+
super(type, url, address, logger, initialize);
|
|
16
16
|
this.id = id;
|
|
17
17
|
this.eventTriggerErgoTree = wasm.Address.from_base58(address)
|
|
18
18
|
.to_ergo_tree()
|
|
@@ -42,18 +42,15 @@ class EventTriggerExtractor extends AbstractInitializableErgoExtractor {
|
|
|
42
42
|
*/
|
|
43
43
|
hasData = (box) => {
|
|
44
44
|
try {
|
|
45
|
-
const parsedBox = wasm.ErgoBox.from_json(JsonBI.stringify(box));
|
|
46
45
|
if (box.additionalRegisters &&
|
|
47
46
|
box.additionalRegisters.R4 &&
|
|
48
47
|
box.additionalRegisters.R5 &&
|
|
49
48
|
box.additionalRegisters.R7 &&
|
|
50
|
-
parsedBox.register_value(wasm.NonMandatoryRegisterId.R4) &&
|
|
51
|
-
parsedBox.register_value(wasm.NonMandatoryRegisterId.R5) &&
|
|
52
|
-
parsedBox.register_value(wasm.NonMandatoryRegisterId.R7) &&
|
|
53
49
|
box.assets &&
|
|
54
50
|
box.assets.length > 0 &&
|
|
55
51
|
box.assets[0].tokenId === this.RWT &&
|
|
56
52
|
box.ergoTree === this.eventTriggerErgoTree) {
|
|
53
|
+
const parsedBox = wasm.ErgoBox.from_json(JsonBI.stringify(box));
|
|
57
54
|
const R4Serialized = parsedBox
|
|
58
55
|
.register_value(wasm.NonMandatoryRegisterId.R4)
|
|
59
56
|
.to_byte_array();
|
|
@@ -93,7 +90,7 @@ class EventTriggerExtractor extends AbstractInitializableErgoExtractor {
|
|
|
93
90
|
eventId: eventId,
|
|
94
91
|
txId: box.transactionId,
|
|
95
92
|
boxId: box.boxId,
|
|
96
|
-
|
|
93
|
+
serialized: Buffer.from(parsedBox.sigma_serialize_bytes()).toString('base64'),
|
|
97
94
|
toChain: Buffer.from(R5Serialized[2]).toString(),
|
|
98
95
|
toAddress: Buffer.from(R5Serialized[4]).toString(),
|
|
99
96
|
networkFee: BigInt('0x' + Buffer.from(R5Serialized[7]).toString('hex')).toString(10),
|
|
@@ -148,9 +145,15 @@ class EventTriggerExtractor extends AbstractInitializableErgoExtractor {
|
|
|
148
145
|
extras: [result, paymentTxId],
|
|
149
146
|
});
|
|
150
147
|
});
|
|
151
|
-
if (boxes.length > 0)
|
|
152
|
-
await this.actions.
|
|
153
|
-
|
|
148
|
+
if (boxes.length > 0) {
|
|
149
|
+
if (!(await this.actions.storeBoxes(boxes, block, this.getId()))) {
|
|
150
|
+
this.logger.warn(`Data insertion failed at height ${block.height} for extractor ${this.id}`);
|
|
151
|
+
return false;
|
|
152
|
+
}
|
|
153
|
+
this.triggerCallbacks(CallbackType.Insert, boxes);
|
|
154
|
+
}
|
|
155
|
+
const spentData = await this.actions.spendBoxes(spendInfoArray, block, this.id);
|
|
156
|
+
this.triggerCallbacks(CallbackType.Spend, spentData);
|
|
154
157
|
}
|
|
155
158
|
catch (e) {
|
|
156
159
|
this.logger.error(`Error in storing data in ${this.getId()} of the block ${block}: ${e}`);
|
|
@@ -209,4 +212,4 @@ class EventTriggerExtractor extends AbstractInitializableErgoExtractor {
|
|
|
209
212
|
};
|
|
210
213
|
}
|
|
211
214
|
export default EventTriggerExtractor;
|
|
212
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"EventTriggerExtractor.js","sourceRoot":"","sources":["../../lib/extractor/EventTriggerExtractor.ts"],"names":[],"mappings":"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","sourcesContent":["import { DataSource } from 'typeorm';\nimport * as wasm from 'ergo-lib-wasm-nodejs';\nimport { blake2b } from 'blakejs';\nimport { Transaction } from '@rosen-bridge/scanner';\nimport { AbstractLogger } from '@rosen-bridge/abstract-logger';\nimport {\n  AbstractInitializableErgoExtractor,\n  BlockInfo,\n  ErgoNetworkType,\n  OutputBox,\n  SpendInfo,\n} from '@rosen-bridge/abstract-extractor';\n\nimport EventTriggerAction from '../actions/EventTriggerAction';\nimport { ExtractedEventTrigger } from '../interfaces/extractedEventTrigger';\nimport { JsonBI } from '../utils';\nimport { EventResult } from '../types';\n\nclass EventTriggerExtractor extends AbstractInitializableErgoExtractor<ExtractedEventTrigger> {\n  id: string;\n  protected readonly actions: EventTriggerAction;\n  private readonly eventTriggerErgoTree: string;\n  private readonly permitErgoTree: string;\n  private readonly fraudErgoTree: string;\n  private readonly RWT: string;\n\n  constructor(\n    id: string,\n    dataSource: DataSource,\n    type: ErgoNetworkType,\n    url: string,\n    address: string,\n    RWT: string,\n    permitAddress: string,\n    fraudAddress: string,\n    logger?: AbstractLogger\n  ) {\n    super(type, url, address, logger);\n    this.id = id;\n    this.eventTriggerErgoTree = wasm.Address.from_base58(address)\n      .to_ergo_tree()\n      .to_base16_bytes();\n    this.permitErgoTree = wasm.Address.from_base58(permitAddress)\n      .to_ergo_tree()\n      .to_base16_bytes();\n    this.fraudErgoTree = wasm.Address.from_base58(fraudAddress)\n      .to_ergo_tree()\n      .to_base16_bytes();\n    this.RWT = RWT;\n    this.actions = new EventTriggerAction(dataSource, this.logger);\n  }\n\n  /**\n   * get Id for current extractor\n   */\n  getId = () => this.id;\n\n  /**\n   * check proper data format in the box\n   *  - box ergoTree\n   *  - RWT in first token place\n   *  - widListHash in R4\n   *  - event data in R5\n   *  - widCount in R7\n   * @param box\n   * @return true if the box has the required data and false otherwise\n   */\n  hasData = (box: OutputBox): boolean => {\n    try {\n      const parsedBox = wasm.ErgoBox.from_json(JsonBI.stringify(box));\n      if (\n        box.additionalRegisters &&\n        box.additionalRegisters.R4 &&\n        box.additionalRegisters.R5 &&\n        box.additionalRegisters.R7 &&\n        parsedBox.register_value(wasm.NonMandatoryRegisterId.R4) &&\n        parsedBox.register_value(wasm.NonMandatoryRegisterId.R5) &&\n        parsedBox.register_value(wasm.NonMandatoryRegisterId.R7) &&\n        box.assets &&\n        box.assets.length > 0 &&\n        box.assets[0].tokenId === this.RWT &&\n        box.ergoTree === this.eventTriggerErgoTree\n      ) {\n        const R4Serialized = parsedBox\n          .register_value(wasm.NonMandatoryRegisterId.R4)!\n          .to_byte_array();\n        const R5Serialized = parsedBox\n          .register_value(wasm.NonMandatoryRegisterId.R5)!\n          .to_coll_coll_byte();\n        if (R4Serialized.length >= 1 && R5Serialized.length >= 12) return true;\n      }\n    } catch (e) {\n      this.logger.warn(\n        `Unexpected error occurred while checking the proper trigger data format for box ${box.boxId}: ${e}`\n      );\n    }\n    return false;\n  };\n\n  /**\n   * extract box data to proper format (not including spending information)\n   * @param box\n   * @return extracted data in proper format\n   */\n  extractBoxData = (\n    box: OutputBox\n  ): Omit<ExtractedEventTrigger, 'spendBlock' | 'spendHeight'> | undefined => {\n    try {\n      const parsedBox = wasm.ErgoBox.from_json(JsonBI.stringify(box));\n      const R4Serialized = parsedBox\n        .register_value(wasm.NonMandatoryRegisterId.R4)!\n        .to_byte_array();\n      const R5Serialized = parsedBox\n        .register_value(wasm.NonMandatoryRegisterId.R5)!\n        .to_coll_coll_byte();\n\n      const WIDsCount = parsedBox\n        .register_value(wasm.NonMandatoryRegisterId.R7)!\n        .to_i32();\n      const WIDsHash = Buffer.from(R4Serialized).toString('hex');\n      const sourceTxId = Buffer.from(R5Serialized[0]).toString();\n      const eventId = Buffer.from(blake2b(sourceTxId, undefined, 32)).toString(\n        'hex'\n      );\n      return {\n        eventId: eventId,\n        txId: box.transactionId,\n        boxId: box.boxId,\n        boxSerialized: Buffer.from(parsedBox.sigma_serialize_bytes()).toString(\n          'base64'\n        ),\n        toChain: Buffer.from(R5Serialized[2]).toString(),\n        toAddress: Buffer.from(R5Serialized[4]).toString(),\n        networkFee: BigInt(\n          '0x' + Buffer.from(R5Serialized[7]).toString('hex')\n        ).toString(10),\n        bridgeFee: BigInt(\n          '0x' + Buffer.from(R5Serialized[6]).toString('hex')\n        ).toString(10),\n        amount: BigInt(\n          '0x' + Buffer.from(R5Serialized[5]).toString('hex')\n        ).toString(10),\n        sourceChainTokenId: Buffer.from(R5Serialized[8]).toString(),\n        targetChainTokenId: Buffer.from(R5Serialized[9]).toString(),\n        sourceTxId: sourceTxId,\n        fromChain: Buffer.from(R5Serialized[1]).toString(),\n        fromAddress: Buffer.from(R5Serialized[3]).toString(),\n        sourceBlockId: Buffer.from(R5Serialized[10]).toString(),\n        WIDsCount: WIDsCount,\n        WIDsHash: WIDsHash,\n        sourceChainHeight: Number(\n          BigInt('0x' + Buffer.from(R5Serialized[11]).toString('hex')).toString(\n            10\n          )\n        ),\n      };\n    } catch (e) {\n      this.logger.warn(\n        `Unexpected error occurred while extracting trigger data for box ${box.boxId}: ${e}`\n      );\n      return undefined;\n    }\n  };\n\n  /**\n   * gets block id and transactions corresponding to the block and saves if they are valid rosen\n   *  transactions and in case of success return true and in case of failure returns false\n   * @param block\n   * @param txs\n   */\n  processTransactions = async (\n    txs: Array<Transaction>,\n    block: BlockInfo\n  ): Promise<boolean> => {\n    try {\n      const boxes: Array<ExtractedEventTrigger> = [];\n      const spendInfoArray: Array<SpendInfo> = [];\n      txs.forEach((transaction) => {\n        // extract event result\n        const { result, paymentTxId } = this.extractEventResult(transaction);\n        for (const output of transaction.outputs) {\n          // extract output box data\n          if (this.hasData(output)) {\n            this.logger.debug(\n              `Trying to extract data from box ${output.boxId} at height ${block.height}`\n            );\n            const data = this.extractBoxData(output);\n            if (data) {\n              this.logger.debug(\n                `Extracted data ${JsonBI.stringify(data)} from box ${\n                  output.boxId\n                }`\n              );\n              boxes.push(data);\n            }\n          }\n        }\n        // process inputs\n        for (let index = 0; index < transaction.inputs.length; index++)\n          spendInfoArray.push({\n            txId: transaction.id,\n            boxId: transaction.inputs[index].boxId,\n            index: index,\n            extras: [result, paymentTxId],\n          });\n      });\n      if (boxes.length > 0)\n        await this.actions.insertBoxes(boxes, block, this.getId());\n      await this.actions.spendBoxes(spendInfoArray, block, this.id);\n    } catch (e) {\n      this.logger.error(\n        `Error in storing data in ${this.getId()} of the block ${block}: ${e}`\n      );\n      return false;\n    }\n    return true;\n  };\n\n  /**\n   * extracts result and paymentTxId from a transaction\n   * returns 'unknown' as result when tx is neither fraud or successful\n   * @param transaction\n   * @returns\n   */\n  protected extractEventResult = (transaction: Transaction) => {\n    let result = EventResult.unknown;\n    let paymentTxId = '';\n    if (transaction.outputs[0].ergoTree === this.fraudErgoTree)\n      result = EventResult.fraud;\n    else if (transaction.outputs[0].ergoTree === this.permitErgoTree) {\n      result = EventResult.successful;\n      // find first non-watcher box with R4 value\n      for (const box of transaction.outputs) {\n        // if it's watcher box, skip it\n        if (box.ergoTree === this.permitErgoTree) continue;\n        const outputParsed = wasm.ErgoBox.from_json(JsonBI.stringify(box));\n        try {\n          const R4Serialized = outputParsed\n            .register_value(wasm.NonMandatoryRegisterId.R4)\n            ?.to_byte_array();\n          if (R4Serialized !== undefined && R4Serialized.length > 0) {\n            let txId = Buffer.from(R4Serialized).toString();\n            // we assumed txId only includes these characters\n            if (!txId.match(/^[0-9a-zA-Z\\-_.]+$/)) {\n              // backward compatibility\n              txId = Buffer.from(R4Serialized).toString('hex');\n            }\n            paymentTxId = txId;\n            if (txId === '') {\n              paymentTxId = transaction.id;\n              this.logger.debug(\n                `successful event is spent. tx [${transaction.id}] is both payment and reward distribution tx`\n              );\n            }\n            // paymentTxId is extracted. no need to process next boxes\n            break;\n          }\n        } catch (e) {\n          continue;\n        }\n      }\n    }\n    return {\n      result,\n      paymentTxId,\n    };\n  };\n}\n\nexport default EventTriggerExtractor;\n"]}
|
|
215
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"EventTriggerExtractor.js","sourceRoot":"","sources":["../../lib/extractor/EventTriggerExtractor.ts"],"names":[],"mappings":"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","sourcesContent":["import { DataSource } from 'typeorm';\nimport * as wasm from 'ergo-lib-wasm-nodejs';\nimport { blake2b } from 'blakejs';\nimport { Transaction } from '@rosen-bridge/scanner';\nimport { AbstractLogger } from '@rosen-bridge/abstract-logger';\nimport {\n  AbstractInitializableErgoExtractor,\n  BlockInfo,\n  CallbackType,\n  ErgoNetworkType,\n  OutputBox,\n  SpendInfo,\n} from '@rosen-bridge/abstract-extractor';\n\nimport EventTriggerAction from '../actions/EventTriggerAction';\nimport { ExtractedEventTrigger } from '../interfaces/extractedEventTrigger';\nimport { JsonBI } from '../utils';\nimport { EventResult } from '../types';\nimport EventTriggerEntity from '../entities/EventTriggerEntity';\n\nclass EventTriggerExtractor extends AbstractInitializableErgoExtractor<\n  ExtractedEventTrigger,\n  EventTriggerEntity\n> {\n  id: string;\n  protected readonly actions: EventTriggerAction;\n  private readonly eventTriggerErgoTree: string;\n  private readonly permitErgoTree: string;\n  private readonly fraudErgoTree: string;\n  private readonly RWT: string;\n\n  constructor(\n    id: string,\n    dataSource: DataSource,\n    type: ErgoNetworkType,\n    url: string,\n    address: string,\n    RWT: string,\n    permitAddress: string,\n    fraudAddress: string,\n    logger?: AbstractLogger,\n    initialize = true\n  ) {\n    super(type, url, address, logger, initialize);\n    this.id = id;\n    this.eventTriggerErgoTree = wasm.Address.from_base58(address)\n      .to_ergo_tree()\n      .to_base16_bytes();\n    this.permitErgoTree = wasm.Address.from_base58(permitAddress)\n      .to_ergo_tree()\n      .to_base16_bytes();\n    this.fraudErgoTree = wasm.Address.from_base58(fraudAddress)\n      .to_ergo_tree()\n      .to_base16_bytes();\n    this.RWT = RWT;\n    this.actions = new EventTriggerAction(dataSource, this.logger);\n  }\n\n  /**\n   * get Id for current extractor\n   */\n  getId = () => this.id;\n\n  /**\n   * check proper data format in the box\n   *  - box ergoTree\n   *  - RWT in first token place\n   *  - widListHash in R4\n   *  - event data in R5\n   *  - widCount in R7\n   * @param box\n   * @return true if the box has the required data and false otherwise\n   */\n  hasData = (box: OutputBox): boolean => {\n    try {\n      if (\n        box.additionalRegisters &&\n        box.additionalRegisters.R4 &&\n        box.additionalRegisters.R5 &&\n        box.additionalRegisters.R7 &&\n        box.assets &&\n        box.assets.length > 0 &&\n        box.assets[0].tokenId === this.RWT &&\n        box.ergoTree === this.eventTriggerErgoTree\n      ) {\n        const parsedBox = wasm.ErgoBox.from_json(JsonBI.stringify(box));\n        const R4Serialized = parsedBox\n          .register_value(wasm.NonMandatoryRegisterId.R4)!\n          .to_byte_array();\n        const R5Serialized = parsedBox\n          .register_value(wasm.NonMandatoryRegisterId.R5)!\n          .to_coll_coll_byte();\n        if (R4Serialized.length >= 1 && R5Serialized.length >= 12) return true;\n      }\n    } catch (e) {\n      this.logger.warn(\n        `Unexpected error occurred while checking the proper trigger data format for box ${box.boxId}: ${e}`\n      );\n    }\n    return false;\n  };\n\n  /**\n   * extract box data to proper format (not including spending information)\n   * @param box\n   * @return extracted data in proper format\n   */\n  extractBoxData = (\n    box: OutputBox\n  ): Omit<ExtractedEventTrigger, 'spendBlock' | 'spendHeight'> | undefined => {\n    try {\n      const parsedBox = wasm.ErgoBox.from_json(JsonBI.stringify(box));\n      const R4Serialized = parsedBox\n        .register_value(wasm.NonMandatoryRegisterId.R4)!\n        .to_byte_array();\n      const R5Serialized = parsedBox\n        .register_value(wasm.NonMandatoryRegisterId.R5)!\n        .to_coll_coll_byte();\n\n      const WIDsCount = parsedBox\n        .register_value(wasm.NonMandatoryRegisterId.R7)!\n        .to_i32();\n      const WIDsHash = Buffer.from(R4Serialized).toString('hex');\n      const sourceTxId = Buffer.from(R5Serialized[0]).toString();\n      const eventId = Buffer.from(blake2b(sourceTxId, undefined, 32)).toString(\n        'hex'\n      );\n      return {\n        eventId: eventId,\n        txId: box.transactionId,\n        boxId: box.boxId,\n        serialized: Buffer.from(parsedBox.sigma_serialize_bytes()).toString(\n          'base64'\n        ),\n        toChain: Buffer.from(R5Serialized[2]).toString(),\n        toAddress: Buffer.from(R5Serialized[4]).toString(),\n        networkFee: BigInt(\n          '0x' + Buffer.from(R5Serialized[7]).toString('hex')\n        ).toString(10),\n        bridgeFee: BigInt(\n          '0x' + Buffer.from(R5Serialized[6]).toString('hex')\n        ).toString(10),\n        amount: BigInt(\n          '0x' + Buffer.from(R5Serialized[5]).toString('hex')\n        ).toString(10),\n        sourceChainTokenId: Buffer.from(R5Serialized[8]).toString(),\n        targetChainTokenId: Buffer.from(R5Serialized[9]).toString(),\n        sourceTxId: sourceTxId,\n        fromChain: Buffer.from(R5Serialized[1]).toString(),\n        fromAddress: Buffer.from(R5Serialized[3]).toString(),\n        sourceBlockId: Buffer.from(R5Serialized[10]).toString(),\n        WIDsCount: WIDsCount,\n        WIDsHash: WIDsHash,\n        sourceChainHeight: Number(\n          BigInt('0x' + Buffer.from(R5Serialized[11]).toString('hex')).toString(\n            10\n          )\n        ),\n      };\n    } catch (e) {\n      this.logger.warn(\n        `Unexpected error occurred while extracting trigger data for box ${box.boxId}: ${e}`\n      );\n      return undefined;\n    }\n  };\n\n  /**\n   * gets block id and transactions corresponding to the block and saves if they are valid rosen\n   *  transactions and in case of success return true and in case of failure returns false\n   * @param block\n   * @param txs\n   */\n  processTransactions = async (\n    txs: Array<Transaction>,\n    block: BlockInfo\n  ): Promise<boolean> => {\n    try {\n      const boxes: Array<ExtractedEventTrigger> = [];\n      const spendInfoArray: Array<SpendInfo> = [];\n      txs.forEach((transaction) => {\n        // extract event result\n        const { result, paymentTxId } = this.extractEventResult(transaction);\n        for (const output of transaction.outputs) {\n          // extract output box data\n          if (this.hasData(output)) {\n            this.logger.debug(\n              `Trying to extract data from box ${output.boxId} at height ${block.height}`\n            );\n            const data = this.extractBoxData(output);\n            if (data) {\n              this.logger.debug(\n                `Extracted data ${JsonBI.stringify(data)} from box ${\n                  output.boxId\n                }`\n              );\n              boxes.push(data);\n            }\n          }\n        }\n        // process inputs\n        for (let index = 0; index < transaction.inputs.length; index++)\n          spendInfoArray.push({\n            txId: transaction.id,\n            boxId: transaction.inputs[index].boxId,\n            index: index,\n            extras: [result, paymentTxId],\n          });\n      });\n      if (boxes.length > 0) {\n        if (!(await this.actions.storeBoxes(boxes, block, this.getId()))) {\n          this.logger.warn(\n            `Data insertion failed at height ${block.height} for extractor ${this.id}`\n          );\n          return false;\n        }\n        this.triggerCallbacks(CallbackType.Insert, boxes);\n      }\n      const spentData = await this.actions.spendBoxes(\n        spendInfoArray,\n        block,\n        this.id\n      );\n      this.triggerCallbacks(CallbackType.Spend, spentData);\n    } catch (e) {\n      this.logger.error(\n        `Error in storing data in ${this.getId()} of the block ${block}: ${e}`\n      );\n      return false;\n    }\n    return true;\n  };\n\n  /**\n   * extracts result and paymentTxId from a transaction\n   * returns 'unknown' as result when tx is neither fraud or successful\n   * @param transaction\n   * @returns\n   */\n  protected extractEventResult = (transaction: Transaction) => {\n    let result = EventResult.unknown;\n    let paymentTxId = '';\n    if (transaction.outputs[0].ergoTree === this.fraudErgoTree)\n      result = EventResult.fraud;\n    else if (transaction.outputs[0].ergoTree === this.permitErgoTree) {\n      result = EventResult.successful;\n      // find first non-watcher box with R4 value\n      for (const box of transaction.outputs) {\n        // if it's watcher box, skip it\n        if (box.ergoTree === this.permitErgoTree) continue;\n        const outputParsed = wasm.ErgoBox.from_json(JsonBI.stringify(box));\n        try {\n          const R4Serialized = outputParsed\n            .register_value(wasm.NonMandatoryRegisterId.R4)\n            ?.to_byte_array();\n          if (R4Serialized !== undefined && R4Serialized.length > 0) {\n            let txId = Buffer.from(R4Serialized).toString();\n            // we assumed txId only includes these characters\n            if (!txId.match(/^[0-9a-zA-Z\\-_.]+$/)) {\n              // backward compatibility\n              txId = Buffer.from(R4Serialized).toString('hex');\n            }\n            paymentTxId = txId;\n            if (txId === '') {\n              paymentTxId = transaction.id;\n              this.logger.debug(\n                `successful event is spent. tx [${transaction.id}] is both payment and reward distribution tx`\n              );\n            }\n            // paymentTxId is extracted. no need to process next boxes\n            break;\n          }\n        } catch (e) {\n          continue;\n        }\n      }\n    }\n    return {\n      result,\n      paymentTxId,\n    };\n  };\n}\n\nexport default EventTriggerExtractor;\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"extractedEventTrigger.d.ts","sourceRoot":"","sources":["../../lib/interfaces/extractedEventTrigger.ts"],"names":[],"mappings":"AAAA,UAAU,qBAAqB;IAC7B,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,
|
|
1
|
+
{"version":3,"file":"extractedEventTrigger.d.ts","sourceRoot":"","sources":["../../lib/interfaces/extractedEventTrigger.ts"],"names":[],"mappings":"AAAA,UAAU,qBAAqB;IAC7B,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,kBAAkB,EAAE,MAAM,CAAC;IAC3B,aAAa,EAAE,MAAM,CAAC;IACtB,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,iBAAiB,EAAE,MAAM,CAAC;CAC3B;AAED,OAAO,EAAE,qBAAqB,EAAE,CAAC"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXh0cmFjdGVkRXZlbnRUcmlnZ2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vbGliL2ludGVyZmFjZXMvZXh0cmFjdGVkRXZlbnRUcmlnZ2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbnRlcmZhY2UgRXh0cmFjdGVkRXZlbnRUcmlnZ2VyIHtcbiAgZXZlbnRJZDogc3RyaW5nO1xuICB0eElkOiBzdHJpbmc7XG4gIGJveElkOiBzdHJpbmc7XG4gIHNlcmlhbGl6ZWQ6IHN0cmluZztcbiAgZnJvbUNoYWluOiBzdHJpbmc7XG4gIHRvQ2hhaW46IHN0cmluZztcbiAgZnJvbUFkZHJlc3M6IHN0cmluZztcbiAgdG9BZGRyZXNzOiBzdHJpbmc7XG4gIGFtb3VudDogc3RyaW5nO1xuICBicmlkZ2VGZWU6IHN0cmluZztcbiAgbmV0d29ya0ZlZTogc3RyaW5nO1xuICBzb3VyY2VDaGFpblRva2VuSWQ6IHN0cmluZztcbiAgdGFyZ2V0Q2hhaW5Ub2tlbklkOiBzdHJpbmc7XG4gIHNvdXJjZUJsb2NrSWQ6IHN0cmluZztcbiAgc291cmNlVHhJZDogc3RyaW5nO1xuICBXSURzQ291bnQ6IG51bWJlcjtcbiAgV0lEc0hhc2g6IHN0cmluZztcbiAgc291cmNlQ2hhaW5IZWlnaHQ6IG51bWJlcjtcbn1cblxuZXhwb3J0IHsgRXh0cmFjdGVkRXZlbnRUcmlnZ2VyIH07XG4iXX0=
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { Migration1737785036299 } from './postgres/1737785036299-migration';
|
|
2
2
|
import { migration1688555766601 } from './sqlite/1688555766601-migration';
|
|
3
3
|
export declare const migrations: {
|
|
4
4
|
sqlite: (typeof migration1688555766601)[];
|
|
5
|
-
postgres: (typeof
|
|
5
|
+
postgres: (typeof Migration1737785036299)[];
|
|
6
6
|
};
|
|
7
7
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../lib/migrations/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../lib/migrations/index.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,sBAAsB,EAAE,MAAM,oCAAoC,CAAC;AAC5E,OAAO,EAAE,sBAAsB,EAAE,MAAM,kCAAkC,CAAC;AAO1E,eAAO,MAAM,UAAU;;;CAiBtB,CAAC"}
|
package/dist/migrations/index.js
CHANGED
|
@@ -3,11 +3,13 @@ import { migration1689175974257 } from './postgres/1689175974257-migration';
|
|
|
3
3
|
import { migration1699874447928 } from './postgres/1699874447928-migration';
|
|
4
4
|
import { migration1706610773315 } from './postgres/1706610773315-migration';
|
|
5
5
|
import { Migration1709388482275 } from './postgres/1709388482275-migration';
|
|
6
|
+
import { Migration1737785036299 } from './postgres/1737785036299-migration';
|
|
6
7
|
import { migration1688555766601 } from './sqlite/1688555766601-migration';
|
|
7
8
|
import { migration1689175103163 } from './sqlite/1689175103163-migration';
|
|
8
9
|
import { migration1699872205117 } from './sqlite/1699872205117-migration';
|
|
9
10
|
import { migration1706610773176 } from './sqlite/1706610773176-migration';
|
|
10
11
|
import { Migration1709388134975 } from './sqlite/1709388134975-migration';
|
|
12
|
+
import { Migration1737547743177 } from './sqlite/1737547743177-migration';
|
|
11
13
|
export const migrations = {
|
|
12
14
|
sqlite: [
|
|
13
15
|
migration1688555766601,
|
|
@@ -15,6 +17,7 @@ export const migrations = {
|
|
|
15
17
|
migration1699872205117,
|
|
16
18
|
migration1706610773176,
|
|
17
19
|
Migration1709388134975,
|
|
20
|
+
Migration1737547743177,
|
|
18
21
|
],
|
|
19
22
|
postgres: [
|
|
20
23
|
migration1688554842087,
|
|
@@ -22,6 +25,7 @@ export const migrations = {
|
|
|
22
25
|
migration1699874447928,
|
|
23
26
|
migration1706610773315,
|
|
24
27
|
Migration1709388482275,
|
|
28
|
+
Migration1737785036299,
|
|
25
29
|
],
|
|
26
30
|
};
|
|
27
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9saWIvbWlncmF0aW9ucy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUMxRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUMxRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUMxRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUMxRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUMxRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUUxRSxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUc7SUFDeEIsTUFBTSxFQUFFO1FBQ04sc0JBQXNCO1FBQ3RCLHNCQUFzQjtRQUN0QixzQkFBc0I7UUFDdEIsc0JBQXNCO1FBQ3RCLHNCQUFzQjtRQUN0QixzQkFBc0I7S0FDdkI7SUFDRCxRQUFRLEVBQUU7UUFDUixzQkFBc0I7UUFDdEIsc0JBQXNCO1FBQ3RCLHNCQUFzQjtRQUN0QixzQkFBc0I7UUFDdEIsc0JBQXNCO1FBQ3RCLHNCQUFzQjtLQUN2QjtDQUNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBtaWdyYXRpb24xNjg4NTU0ODQyMDg3IH0gZnJvbSAnLi9wb3N0Z3Jlcy8xNjg4NTU0ODQyMDg3LW1pZ3JhdGlvbic7XG5pbXBvcnQgeyBtaWdyYXRpb24xNjg5MTc1OTc0MjU3IH0gZnJvbSAnLi9wb3N0Z3Jlcy8xNjg5MTc1OTc0MjU3LW1pZ3JhdGlvbic7XG5pbXBvcnQgeyBtaWdyYXRpb24xNjk5ODc0NDQ3OTI4IH0gZnJvbSAnLi9wb3N0Z3Jlcy8xNjk5ODc0NDQ3OTI4LW1pZ3JhdGlvbic7XG5pbXBvcnQgeyBtaWdyYXRpb24xNzA2NjEwNzczMzE1IH0gZnJvbSAnLi9wb3N0Z3Jlcy8xNzA2NjEwNzczMzE1LW1pZ3JhdGlvbic7XG5pbXBvcnQgeyBNaWdyYXRpb24xNzA5Mzg4NDgyMjc1IH0gZnJvbSAnLi9wb3N0Z3Jlcy8xNzA5Mzg4NDgyMjc1LW1pZ3JhdGlvbic7XG5pbXBvcnQgeyBNaWdyYXRpb24xNzM3Nzg1MDM2Mjk5IH0gZnJvbSAnLi9wb3N0Z3Jlcy8xNzM3Nzg1MDM2Mjk5LW1pZ3JhdGlvbic7XG5pbXBvcnQgeyBtaWdyYXRpb24xNjg4NTU1NzY2NjAxIH0gZnJvbSAnLi9zcWxpdGUvMTY4ODU1NTc2NjYwMS1taWdyYXRpb24nO1xuaW1wb3J0IHsgbWlncmF0aW9uMTY4OTE3NTEwMzE2MyB9IGZyb20gJy4vc3FsaXRlLzE2ODkxNzUxMDMxNjMtbWlncmF0aW9uJztcbmltcG9ydCB7IG1pZ3JhdGlvbjE2OTk4NzIyMDUxMTcgfSBmcm9tICcuL3NxbGl0ZS8xNjk5ODcyMjA1MTE3LW1pZ3JhdGlvbic7XG5pbXBvcnQgeyBtaWdyYXRpb24xNzA2NjEwNzczMTc2IH0gZnJvbSAnLi9zcWxpdGUvMTcwNjYxMDc3MzE3Ni1taWdyYXRpb24nO1xuaW1wb3J0IHsgTWlncmF0aW9uMTcwOTM4ODEzNDk3NSB9IGZyb20gJy4vc3FsaXRlLzE3MDkzODgxMzQ5NzUtbWlncmF0aW9uJztcbmltcG9ydCB7IE1pZ3JhdGlvbjE3Mzc1NDc3NDMxNzcgfSBmcm9tICcuL3NxbGl0ZS8xNzM3NTQ3NzQzMTc3LW1pZ3JhdGlvbic7XG5cbmV4cG9ydCBjb25zdCBtaWdyYXRpb25zID0ge1xuICBzcWxpdGU6IFtcbiAgICBtaWdyYXRpb24xNjg4NTU1NzY2NjAxLFxuICAgIG1pZ3JhdGlvbjE2ODkxNzUxMDMxNjMsXG4gICAgbWlncmF0aW9uMTY5OTg3MjIwNTExNyxcbiAgICBtaWdyYXRpb24xNzA2NjEwNzczMTc2LFxuICAgIE1pZ3JhdGlvbjE3MDkzODgxMzQ5NzUsXG4gICAgTWlncmF0aW9uMTczNzU0Nzc0MzE3NyxcbiAgXSxcbiAgcG9zdGdyZXM6IFtcbiAgICBtaWdyYXRpb24xNjg4NTU0ODQyMDg3LFxuICAgIG1pZ3JhdGlvbjE2ODkxNzU5NzQyNTcsXG4gICAgbWlncmF0aW9uMTY5OTg3NDQ0NzkyOCxcbiAgICBtaWdyYXRpb24xNzA2NjEwNzczMzE1LFxuICAgIE1pZ3JhdGlvbjE3MDkzODg0ODIyNzUsXG4gICAgTWlncmF0aW9uMTczNzc4NTAzNjI5OSxcbiAgXSxcbn07XG4iXX0=
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { MigrationInterface, QueryRunner } from 'typeorm';
|
|
2
|
+
export declare class Migration1737785036299 implements MigrationInterface {
|
|
3
|
+
name: string;
|
|
4
|
+
up(queryRunner: QueryRunner): Promise<void>;
|
|
5
|
+
down(queryRunner: QueryRunner): Promise<void>;
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=1737785036299-migration.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"1737785036299-migration.d.ts","sourceRoot":"","sources":["../../../lib/migrations/postgres/1737785036299-migration.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAE1D,qBAAa,sBAAuB,YAAW,kBAAkB;IAC/D,IAAI,SAA4B;IAEnB,EAAE,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAe3C,IAAI,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;CAc3D"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
export class Migration1737785036299 {
|
|
2
|
+
name = 'Migration1737785036299';
|
|
3
|
+
async up(queryRunner) {
|
|
4
|
+
await queryRunner.query(`
|
|
5
|
+
ALTER TABLE "event_trigger_entity"
|
|
6
|
+
ALTER COLUMN "boxSerialized" TYPE character varying
|
|
7
|
+
`);
|
|
8
|
+
await queryRunner.query(`
|
|
9
|
+
ALTER TABLE "event_trigger_entity"
|
|
10
|
+
ALTER COLUMN "spendBlock" TYPE character varying
|
|
11
|
+
`);
|
|
12
|
+
await queryRunner.query(`
|
|
13
|
+
ALTER TABLE "event_trigger_entity"
|
|
14
|
+
RENAME COLUMN "boxSerialized" TO "serialized"
|
|
15
|
+
`);
|
|
16
|
+
}
|
|
17
|
+
async down(queryRunner) {
|
|
18
|
+
await queryRunner.query(`
|
|
19
|
+
ALTER TABLE "event_trigger_entity"
|
|
20
|
+
RENAME COLUMN "serialized" TO "boxSerialized"
|
|
21
|
+
`);
|
|
22
|
+
await queryRunner.query(`
|
|
23
|
+
ALTER TABLE "event_trigger_entity"
|
|
24
|
+
ALTER COLUMN "spendBlock" TYPE text
|
|
25
|
+
`);
|
|
26
|
+
await queryRunner.query(`
|
|
27
|
+
ALTER TABLE "event_trigger_entity"
|
|
28
|
+
ALTER COLUMN "boxSerialized" TYPE text
|
|
29
|
+
`);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTczNzc4NTAzNjI5OS1taWdyYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9saWIvbWlncmF0aW9ucy9wb3N0Z3Jlcy8xNzM3Nzg1MDM2Mjk5LW1pZ3JhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLE9BQU8sc0JBQXNCO0lBQ2pDLElBQUksR0FBRyx3QkFBd0IsQ0FBQztJQUV6QixLQUFLLENBQUMsRUFBRSxDQUFDLFdBQXdCO1FBQ3RDLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7O1NBR25CLENBQUMsQ0FBQztRQUNQLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7O1NBR25CLENBQUMsQ0FBQztRQUNQLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7O1NBR25CLENBQUMsQ0FBQztJQUNULENBQUM7SUFFTSxLQUFLLENBQUMsSUFBSSxDQUFDLFdBQXdCO1FBQ3hDLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7O1NBR25CLENBQUMsQ0FBQztRQUNQLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7O1NBR25CLENBQUMsQ0FBQztRQUNQLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7O1NBR25CLENBQUMsQ0FBQztJQUNULENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1pZ3JhdGlvbkludGVyZmFjZSwgUXVlcnlSdW5uZXIgfSBmcm9tICd0eXBlb3JtJztcblxuZXhwb3J0IGNsYXNzIE1pZ3JhdGlvbjE3Mzc3ODUwMzYyOTkgaW1wbGVtZW50cyBNaWdyYXRpb25JbnRlcmZhY2Uge1xuICBuYW1lID0gJ01pZ3JhdGlvbjE3Mzc3ODUwMzYyOTknO1xuXG4gIHB1YmxpYyBhc3luYyB1cChxdWVyeVJ1bm5lcjogUXVlcnlSdW5uZXIpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBhd2FpdCBxdWVyeVJ1bm5lci5xdWVyeShgXG4gICAgICAgICAgICBBTFRFUiBUQUJMRSBcImV2ZW50X3RyaWdnZXJfZW50aXR5XCIgXG4gICAgICAgICAgICAgICAgQUxURVIgQ09MVU1OIFwiYm94U2VyaWFsaXplZFwiIFRZUEUgY2hhcmFjdGVyIHZhcnlpbmdcbiAgICAgICAgYCk7XG4gICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgQUxURVIgVEFCTEUgXCJldmVudF90cmlnZ2VyX2VudGl0eVwiIFxuICAgICAgICAgICAgICAgIEFMVEVSIENPTFVNTiBcInNwZW5kQmxvY2tcIiBUWVBFIGNoYXJhY3RlciB2YXJ5aW5nXG4gICAgICAgIGApO1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIEFMVEVSIFRBQkxFIFwiZXZlbnRfdHJpZ2dlcl9lbnRpdHlcIlxuICAgICAgICAgICAgICAgIFJFTkFNRSBDT0xVTU4gXCJib3hTZXJpYWxpemVkXCIgVE8gXCJzZXJpYWxpemVkXCJcbiAgICAgICAgYCk7XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgZG93bihxdWVyeVJ1bm5lcjogUXVlcnlSdW5uZXIpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBhd2FpdCBxdWVyeVJ1bm5lci5xdWVyeShgXG4gICAgICAgICAgICBBTFRFUiBUQUJMRSBcImV2ZW50X3RyaWdnZXJfZW50aXR5XCJcbiAgICAgICAgICAgICAgICBSRU5BTUUgQ09MVU1OIFwic2VyaWFsaXplZFwiIFRPIFwiYm94U2VyaWFsaXplZFwiXG4gICAgICAgIGApO1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIEFMVEVSIFRBQkxFIFwiZXZlbnRfdHJpZ2dlcl9lbnRpdHlcIiBcbiAgICAgICAgICAgICAgICBBTFRFUiBDT0xVTU4gXCJzcGVuZEJsb2NrXCIgVFlQRSB0ZXh0XG4gICAgICAgIGApO1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIEFMVEVSIFRBQkxFIFwiZXZlbnRfdHJpZ2dlcl9lbnRpdHlcIiBcbiAgICAgICAgICAgICAgICBBTFRFUiBDT0xVTU4gXCJib3hTZXJpYWxpemVkXCIgVFlQRSB0ZXh0XG4gICAgICAgIGApO1xuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { MigrationInterface, QueryRunner } from 'typeorm';
|
|
2
|
+
export declare class Migration1737547743177 implements MigrationInterface {
|
|
3
|
+
name: string;
|
|
4
|
+
up(queryRunner: QueryRunner): Promise<void>;
|
|
5
|
+
down(queryRunner: QueryRunner): Promise<void>;
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=1737547743177-migration.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"1737547743177-migration.d.ts","sourceRoot":"","sources":["../../../lib/migrations/sqlite/1737547743177-migration.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAE1D,qBAAa,sBAAuB,YAAW,kBAAkB;IAC/D,IAAI,SAA4B;IAEnB,EAAE,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAqG3C,IAAI,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;CAoG3D"}
|
|
@@ -0,0 +1,204 @@
|
|
|
1
|
+
export class Migration1737547743177 {
|
|
2
|
+
name = 'Migration1737547743177';
|
|
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
|
+
"boxId" varchar NOT NULL,
|
|
9
|
+
"block" varchar NOT NULL,
|
|
10
|
+
"height" integer NOT NULL,
|
|
11
|
+
"extractor" varchar NOT NULL,
|
|
12
|
+
"fromChain" varchar NOT NULL,
|
|
13
|
+
"toChain" varchar NOT NULL,
|
|
14
|
+
"txId" varchar NOT NULL,
|
|
15
|
+
"fromAddress" varchar NOT NULL,
|
|
16
|
+
"toAddress" varchar NOT NULL,
|
|
17
|
+
"amount" varchar NOT NULL,
|
|
18
|
+
"bridgeFee" varchar NOT NULL,
|
|
19
|
+
"networkFee" varchar NOT NULL,
|
|
20
|
+
"sourceChainTokenId" varchar NOT NULL,
|
|
21
|
+
"sourceChainHeight" integer NOT NULL,
|
|
22
|
+
"targetChainTokenId" varchar NOT NULL,
|
|
23
|
+
"sourceTxId" varchar NOT NULL,
|
|
24
|
+
"sourceBlockId" varchar NOT NULL,
|
|
25
|
+
"spendBlock" varchar,
|
|
26
|
+
"spendHeight" integer,
|
|
27
|
+
"spendTxId" varchar,
|
|
28
|
+
"result" varchar,
|
|
29
|
+
"paymentTxId" varchar,
|
|
30
|
+
"WIDsCount" integer NOT NULL,
|
|
31
|
+
"WIDsHash" varchar NOT NULL,
|
|
32
|
+
"serialized" varchar NOT NULL,
|
|
33
|
+
CONSTRAINT "UQ_c905f221a1b6271ca4405dbbe5f" UNIQUE ("boxId", "extractor")
|
|
34
|
+
)
|
|
35
|
+
`);
|
|
36
|
+
await queryRunner.query(`
|
|
37
|
+
INSERT INTO "temporary_event_trigger_entity"(
|
|
38
|
+
"id",
|
|
39
|
+
"eventId",
|
|
40
|
+
"txId",
|
|
41
|
+
"extractor",
|
|
42
|
+
"boxId",
|
|
43
|
+
"block",
|
|
44
|
+
"height",
|
|
45
|
+
"fromChain",
|
|
46
|
+
"toChain",
|
|
47
|
+
"fromAddress",
|
|
48
|
+
"toAddress",
|
|
49
|
+
"amount",
|
|
50
|
+
"bridgeFee",
|
|
51
|
+
"networkFee",
|
|
52
|
+
"sourceChainTokenId",
|
|
53
|
+
"sourceChainHeight",
|
|
54
|
+
"targetChainTokenId",
|
|
55
|
+
"sourceTxId",
|
|
56
|
+
"sourceBlockId",
|
|
57
|
+
"spendBlock",
|
|
58
|
+
"spendHeight",
|
|
59
|
+
"spendTxId",
|
|
60
|
+
"result",
|
|
61
|
+
"paymentTxId",
|
|
62
|
+
"WIDsCount",
|
|
63
|
+
"WIDsHash",
|
|
64
|
+
"serialized"
|
|
65
|
+
)
|
|
66
|
+
SELECT "id",
|
|
67
|
+
"eventId",
|
|
68
|
+
"txId",
|
|
69
|
+
"extractor",
|
|
70
|
+
"boxId",
|
|
71
|
+
"block",
|
|
72
|
+
"height",
|
|
73
|
+
"fromChain",
|
|
74
|
+
"toChain",
|
|
75
|
+
"fromAddress",
|
|
76
|
+
"toAddress",
|
|
77
|
+
"amount",
|
|
78
|
+
"bridgeFee",
|
|
79
|
+
"networkFee",
|
|
80
|
+
"sourceChainTokenId",
|
|
81
|
+
"sourceChainHeight",
|
|
82
|
+
"targetChainTokenId",
|
|
83
|
+
"sourceTxId",
|
|
84
|
+
"sourceBlockId",
|
|
85
|
+
"spendBlock",
|
|
86
|
+
"spendHeight",
|
|
87
|
+
"spendTxId",
|
|
88
|
+
"result",
|
|
89
|
+
"paymentTxId",
|
|
90
|
+
"WIDsCount",
|
|
91
|
+
"WIDsHash",
|
|
92
|
+
"boxSerialized"
|
|
93
|
+
FROM "event_trigger_entity"
|
|
94
|
+
`);
|
|
95
|
+
await queryRunner.query(`
|
|
96
|
+
DROP TABLE "event_trigger_entity"
|
|
97
|
+
`);
|
|
98
|
+
await queryRunner.query(`
|
|
99
|
+
ALTER TABLE "temporary_event_trigger_entity"
|
|
100
|
+
RENAME TO "event_trigger_entity"
|
|
101
|
+
`);
|
|
102
|
+
}
|
|
103
|
+
async down(queryRunner) {
|
|
104
|
+
await queryRunner.query(`
|
|
105
|
+
ALTER TABLE "event_trigger_entity"
|
|
106
|
+
RENAME TO "temporary_event_trigger_entity"
|
|
107
|
+
`);
|
|
108
|
+
await queryRunner.query(`
|
|
109
|
+
CREATE TABLE "event_trigger_entity" (
|
|
110
|
+
"id" integer PRIMARY KEY AUTOINCREMENT NOT NULL,
|
|
111
|
+
"eventId" varchar NOT NULL DEFAULT ('Not-set'),
|
|
112
|
+
"txId" varchar NOT NULL,
|
|
113
|
+
"extractor" varchar NOT NULL,
|
|
114
|
+
"boxId" varchar NOT NULL,
|
|
115
|
+
"boxSerialized" varchar NOT NULL,
|
|
116
|
+
"block" varchar NOT NULL,
|
|
117
|
+
"height" integer NOT NULL,
|
|
118
|
+
"fromChain" varchar NOT NULL,
|
|
119
|
+
"toChain" varchar NOT NULL,
|
|
120
|
+
"fromAddress" varchar NOT NULL,
|
|
121
|
+
"toAddress" varchar NOT NULL,
|
|
122
|
+
"amount" varchar NOT NULL,
|
|
123
|
+
"bridgeFee" varchar NOT NULL,
|
|
124
|
+
"networkFee" varchar NOT NULL,
|
|
125
|
+
"sourceChainTokenId" varchar NOT NULL,
|
|
126
|
+
"sourceChainHeight" integer NOT NULL,
|
|
127
|
+
"targetChainTokenId" varchar NOT NULL,
|
|
128
|
+
"sourceTxId" varchar NOT NULL,
|
|
129
|
+
"sourceBlockId" varchar NOT NULL,
|
|
130
|
+
"spendBlock" text,
|
|
131
|
+
"spendHeight" integer,
|
|
132
|
+
"spendTxId" text,
|
|
133
|
+
"result" text,
|
|
134
|
+
"paymentTxId" text,
|
|
135
|
+
"WIDsCount" integer NOT NULL,
|
|
136
|
+
"WIDsHash" varchar NOT NULL,
|
|
137
|
+
CONSTRAINT "UQ_c905f221a1b6271ca4405dbbe5f" UNIQUE ("boxId", "extractor")
|
|
138
|
+
)
|
|
139
|
+
`);
|
|
140
|
+
await queryRunner.query(`
|
|
141
|
+
INSERT INTO "event_trigger_entity"(
|
|
142
|
+
"id",
|
|
143
|
+
"eventId",
|
|
144
|
+
"txId",
|
|
145
|
+
"extractor",
|
|
146
|
+
"boxId",
|
|
147
|
+
"block",
|
|
148
|
+
"height",
|
|
149
|
+
"fromChain",
|
|
150
|
+
"toChain",
|
|
151
|
+
"fromAddress",
|
|
152
|
+
"toAddress",
|
|
153
|
+
"amount",
|
|
154
|
+
"bridgeFee",
|
|
155
|
+
"networkFee",
|
|
156
|
+
"sourceChainTokenId",
|
|
157
|
+
"sourceChainHeight",
|
|
158
|
+
"targetChainTokenId",
|
|
159
|
+
"sourceTxId",
|
|
160
|
+
"sourceBlockId",
|
|
161
|
+
"spendBlock",
|
|
162
|
+
"spendHeight",
|
|
163
|
+
"spendTxId",
|
|
164
|
+
"result",
|
|
165
|
+
"paymentTxId",
|
|
166
|
+
"WIDsCount",
|
|
167
|
+
"WIDsHash",
|
|
168
|
+
"boxSerialized"
|
|
169
|
+
)
|
|
170
|
+
SELECT "id",
|
|
171
|
+
"eventId",
|
|
172
|
+
"txId",
|
|
173
|
+
"extractor",
|
|
174
|
+
"boxId",
|
|
175
|
+
"block",
|
|
176
|
+
"height",
|
|
177
|
+
"fromChain",
|
|
178
|
+
"toChain",
|
|
179
|
+
"fromAddress",
|
|
180
|
+
"toAddress",
|
|
181
|
+
"amount",
|
|
182
|
+
"bridgeFee",
|
|
183
|
+
"networkFee",
|
|
184
|
+
"sourceChainTokenId",
|
|
185
|
+
"sourceChainHeight",
|
|
186
|
+
"targetChainTokenId",
|
|
187
|
+
"sourceTxId",
|
|
188
|
+
"sourceBlockId",
|
|
189
|
+
"spendBlock",
|
|
190
|
+
"spendHeight",
|
|
191
|
+
"spendTxId",
|
|
192
|
+
"result",
|
|
193
|
+
"paymentTxId",
|
|
194
|
+
"WIDsCount",
|
|
195
|
+
"WIDsHash",
|
|
196
|
+
"serialized"
|
|
197
|
+
FROM "temporary_event_trigger_entity"
|
|
198
|
+
`);
|
|
199
|
+
await queryRunner.query(`
|
|
200
|
+
DROP TABLE "temporary_event_trigger_entity"
|
|
201
|
+
`);
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"1737547743177-migration.js","sourceRoot":"","sources":["../../../lib/migrations/sqlite/1737547743177-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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA+BnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA0DnB,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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA+BnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA0DnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;SAEnB,CAAC,CAAC;IACT,CAAC;CACF","sourcesContent":["import { MigrationInterface, QueryRunner } from 'typeorm';\n\nexport class Migration1737547743177 implements MigrationInterface {\n  name = 'Migration1737547743177';\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                \"boxId\" varchar NOT NULL,\n                \"block\" varchar NOT NULL,\n                \"height\" integer NOT NULL,\n                \"extractor\" varchar NOT NULL,\n                \"fromChain\" varchar NOT NULL,\n                \"toChain\" varchar NOT NULL,\n                \"txId\" 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                \"spendBlock\" varchar,\n                \"spendHeight\" integer,\n                \"spendTxId\" varchar,\n                \"result\" varchar,\n                \"paymentTxId\" varchar,\n                \"WIDsCount\" integer NOT NULL,\n                \"WIDsHash\" varchar NOT NULL,\n                \"serialized\" varchar NOT NULL,\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                    \"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                    \"spendBlock\",\n                    \"spendHeight\",\n                    \"spendTxId\",\n                    \"result\",\n                    \"paymentTxId\",\n                    \"WIDsCount\",\n                    \"WIDsHash\",\n                    \"serialized\"\n                )\n            SELECT \"id\",\n                \"eventId\",\n                \"txId\",\n                \"extractor\",\n                \"boxId\",\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                \"spendBlock\",\n                \"spendHeight\",\n                \"spendTxId\",\n                \"result\",\n                \"paymentTxId\",\n                \"WIDsCount\",\n                \"WIDsHash\",\n                \"boxSerialized\"\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  }\n\n  public async down(queryRunner: QueryRunner): Promise<void> {\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                \"spendBlock\" text,\n                \"spendHeight\" integer,\n                \"spendTxId\" text,\n                \"result\" text,\n                \"paymentTxId\" text,\n                \"WIDsCount\" integer NOT NULL,\n                \"WIDsHash\" varchar NOT NULL,\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                    \"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                    \"spendBlock\",\n                    \"spendHeight\",\n                    \"spendTxId\",\n                    \"result\",\n                    \"paymentTxId\",\n                    \"WIDsCount\",\n                    \"WIDsHash\",\n                    \"boxSerialized\"\n                )\n            SELECT \"id\",\n                \"eventId\",\n                \"txId\",\n                \"extractor\",\n                \"boxId\",\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                \"spendBlock\",\n                \"spendHeight\",\n                \"spendTxId\",\n                \"result\",\n                \"paymentTxId\",\n                \"WIDsCount\",\n                \"WIDsHash\",\n                \"serialized\"\n            FROM \"temporary_event_trigger_entity\"\n        `);\n    await queryRunner.query(`\n            DROP TABLE \"temporary_event_trigger_entity\"\n        `);\n  }\n}\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@rosen-bridge/watcher-data-extractor",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "10.0.0",
|
|
4
4
|
"description": "Extractor for rosen specific boxes on ergo blockchain",
|
|
5
5
|
"author": "Rosen Team",
|
|
6
6
|
"license": "GPL-3.0",
|
|
@@ -19,11 +19,11 @@
|
|
|
19
19
|
"dist"
|
|
20
20
|
],
|
|
21
21
|
"dependencies": {
|
|
22
|
-
"@rosen-bridge/abstract-extractor": "^0.
|
|
23
|
-
"@rosen-bridge/abstract-logger": "^
|
|
22
|
+
"@rosen-bridge/abstract-extractor": "^1.0.0",
|
|
23
|
+
"@rosen-bridge/abstract-logger": "^2.0.1",
|
|
24
24
|
"@rosen-bridge/extended-typeorm": "^0.0.3",
|
|
25
25
|
"@rosen-bridge/json-bigint": "^0.1.0",
|
|
26
|
-
"@rosen-bridge/scanner": "^5.0.
|
|
26
|
+
"@rosen-bridge/scanner": "^5.0.1",
|
|
27
27
|
"@rosen-bridge/tokens": "^1.2.1",
|
|
28
28
|
"@rosen-clients/ergo-explorer": "^1.1.1",
|
|
29
29
|
"@types/lodash-es": "^4.17.6",
|