@rosen-bridge/watcher-data-extractor 2.2.2 → 3.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/actions/EventTriggerAction.d.ts +4 -1
- package/dist/actions/EventTriggerAction.d.ts.map +1 -1
- package/dist/actions/EventTriggerAction.js +19 -4
- package/dist/entities/EventTriggerEntity.d.ts +3 -1
- package/dist/entities/EventTriggerEntity.d.ts.map +1 -1
- package/dist/entities/EventTriggerEntity.js +13 -3
- package/dist/extractor/EventTriggerExtractor.d.ts +14 -1
- package/dist/extractor/EventTriggerExtractor.d.ts.map +1 -1
- package/dist/extractor/EventTriggerExtractor.js +67 -8
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -1
- package/dist/migrations/index.d.ts +2 -2
- package/dist/migrations/index.d.ts.map +1 -1
- package/dist/migrations/index.js +13 -3
- package/dist/migrations/postgres/1699874447928-migration.d.ts +7 -0
- package/dist/migrations/postgres/1699874447928-migration.d.ts.map +1 -0
- package/dist/migrations/postgres/1699874447928-migration.js +36 -0
- package/dist/migrations/sqlite/1699872205117-migration.d.ts +7 -0
- package/dist/migrations/sqlite/1699872205117-migration.d.ts.map +1 -0
- package/dist/migrations/sqlite/1699872205117-migration.js +192 -0
- package/dist/types.d.ts +6 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +7 -0
- package/package.json +1 -1
|
@@ -17,12 +17,15 @@ declare class EventTriggerAction {
|
|
|
17
17
|
/**
|
|
18
18
|
* Update spendBlock and spendHeight of eventTriggers spent on the block
|
|
19
19
|
* also update the spendTxId with the specified txId
|
|
20
|
+
* and set result and paymentTxId of the event
|
|
20
21
|
* @param spendId
|
|
21
22
|
* @param block
|
|
22
23
|
* @param extractor
|
|
23
24
|
* @param txId
|
|
25
|
+
* @param result
|
|
26
|
+
* @param paymentTxId
|
|
24
27
|
*/
|
|
25
|
-
spendEventTriggers: (spendId: Array<string>, block: BlockEntity, extractor: string, txId: string) => Promise<void>;
|
|
28
|
+
spendEventTriggers: (spendId: Array<string>, block: BlockEntity, extractor: string, txId: string, result: string, paymentTxId: string) => Promise<void>;
|
|
26
29
|
/**
|
|
27
30
|
* Delete all eventTriggers corresponding to the block(id) and extractor(id)
|
|
28
31
|
* and update all eventTriggers spent on the specified block
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EventTriggerAction.d.ts","sourceRoot":"","sources":["../../lib/actions/EventTriggerAction.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;AAGhE,OAAO,EAAE,qBAAqB,EAAE,MAAM,qCAAqC,CAAC;AAG5E,cAAM,kBAAkB;IACtB,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,sBAkEjB;IAEF
|
|
1
|
+
{"version":3,"file":"EventTriggerAction.d.ts","sourceRoot":"","sources":["../../lib/actions/EventTriggerAction.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;AAGhE,OAAO,EAAE,qBAAqB,EAAE,MAAM,qCAAqC,CAAC;AAG5E,cAAM,kBAAkB;IACtB,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,sBAkEjB;IAEF;;;;;;;;;;OAUG;IACH,kBAAkB,YACP,MAAM,MAAM,CAAC,SACf,WAAW,aACP,MAAM,QACX,MAAM,UACJ,MAAM,eACD,MAAM,KAClB,QAAQ,IAAI,CAAC,CA2Bd;IAEF;;;;;OAKG;IACH,WAAW,UAAiB,MAAM,aAAa,MAAM,mBAkBnD;CACH;AAED,eAAe,kBAAkB,CAAC"}
|
|
@@ -82,15 +82,24 @@ class EventTriggerAction {
|
|
|
82
82
|
/**
|
|
83
83
|
* Update spendBlock and spendHeight of eventTriggers spent on the block
|
|
84
84
|
* also update the spendTxId with the specified txId
|
|
85
|
+
* and set result and paymentTxId of the event
|
|
85
86
|
* @param spendId
|
|
86
87
|
* @param block
|
|
87
88
|
* @param extractor
|
|
88
89
|
* @param txId
|
|
90
|
+
* @param result
|
|
91
|
+
* @param paymentTxId
|
|
89
92
|
*/
|
|
90
|
-
spendEventTriggers = async (spendId, block, extractor, txId) => {
|
|
93
|
+
spendEventTriggers = async (spendId, block, extractor, txId, result, paymentTxId) => {
|
|
91
94
|
const spendIdChunks = chunk(spendId, dbIdChunkSize);
|
|
92
95
|
for (const spendIdChunk of spendIdChunks) {
|
|
93
|
-
const updateResult = await this.triggerEventRepository.update({ boxId: In(spendIdChunk), extractor: extractor }, {
|
|
96
|
+
const updateResult = await this.triggerEventRepository.update({ boxId: In(spendIdChunk), extractor: extractor }, {
|
|
97
|
+
spendBlock: block.hash,
|
|
98
|
+
spendHeight: block.height,
|
|
99
|
+
spendTxId: txId,
|
|
100
|
+
result: result,
|
|
101
|
+
paymentTxId: paymentTxId,
|
|
102
|
+
});
|
|
94
103
|
if (updateResult.affected && updateResult.affected > 0) {
|
|
95
104
|
const spentRows = await this.triggerEventRepository.findBy({
|
|
96
105
|
boxId: In(spendIdChunk),
|
|
@@ -115,8 +124,14 @@ class EventTriggerAction {
|
|
|
115
124
|
block: block,
|
|
116
125
|
extractor: extractor,
|
|
117
126
|
});
|
|
118
|
-
await this.triggerEventRepository.update({ spendBlock: block, extractor: extractor }, {
|
|
127
|
+
await this.triggerEventRepository.update({ spendBlock: block, extractor: extractor }, {
|
|
128
|
+
spendBlock: null,
|
|
129
|
+
spendTxId: null,
|
|
130
|
+
spendHeight: 0,
|
|
131
|
+
result: null,
|
|
132
|
+
paymentTxId: null,
|
|
133
|
+
});
|
|
119
134
|
};
|
|
120
135
|
}
|
|
121
136
|
export default EventTriggerAction;
|
|
122
|
-
//# 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 { chunk } from 'lodash-es';\nimport { BlockEntity } from '@rosen-bridge/scanner';\nimport { AbstractLogger } from '@rosen-bridge/logger-interface';\n\nimport EventTriggerEntity from '../entities/EventTriggerEntity';\nimport { ExtractedEventTrigger } from '../interfaces/extractedEventTrigger';\nimport { dbIdChunkSize } from '../constants';\n\nclass EventTriggerAction {\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    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: 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 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 ${extractor}`\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 spendBlock and spendHeight of eventTriggers spent on the block\n   * also update the spendTxId with the specified txId\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.triggerEventRepository.update(\n        { boxId: In(spendIdChunk), extractor: extractor },\n        { spendBlock: block.hash, spendHeight: block.height, spendTxId: txId }\n      );\n\n      if (updateResult.affected && updateResult.affected > 0) {\n        const spentRows = await this.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   * Delete all eventTriggers corresponding to the block(id) and extractor(id)\n   * and update all eventTriggers spent on the specified block\n   * @param block\n   * @param extractor\n   */\n  deleteBlock = async (block: string, extractor: string) => {\n    this.logger.info(\n      `Deleting event triggers at block ${block} and extractor ${extractor}`\n    );\n    await this.triggerEventRepository.delete({\n      block: block,\n      extractor: extractor,\n    });\n    await this.triggerEventRepository.update(\n      { spendBlock: block, extractor: extractor },\n      { spendBlock: null, spendHeight: 0 }\n    );\n  };\n}\n\nexport default EventTriggerAction;\n"]}
|
|
137
|
+
//# 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 { chunk } from 'lodash-es';\nimport { BlockEntity } from '@rosen-bridge/scanner';\nimport { AbstractLogger } from '@rosen-bridge/logger-interface';\n\nimport EventTriggerEntity from '../entities/EventTriggerEntity';\nimport { ExtractedEventTrigger } from '../interfaces/extractedEventTrigger';\nimport { dbIdChunkSize } from '../constants';\n\nclass EventTriggerAction {\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    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: 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 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 ${extractor}`\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 spendBlock and spendHeight of eventTriggers spent on the block\n   * also update the spendTxId with the specified txId\n   * and set result and paymentTxId of the event\n   * @param spendId\n   * @param block\n   * @param extractor\n   * @param txId\n   * @param result\n   * @param paymentTxId\n   */\n  spendEventTriggers = async (\n    spendId: Array<string>,\n    block: BlockEntity,\n    extractor: string,\n    txId: string,\n    result: string,\n    paymentTxId: string\n  ): Promise<void> => {\n    const spendIdChunks = chunk(spendId, dbIdChunkSize);\n    for (const spendIdChunk of spendIdChunks) {\n      const updateResult = await this.triggerEventRepository.update(\n        { boxId: In(spendIdChunk), extractor: extractor },\n        {\n          spendBlock: block.hash,\n          spendHeight: block.height,\n          spendTxId: txId,\n          result: result,\n          paymentTxId: paymentTxId,\n        }\n      );\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   * Delete all eventTriggers corresponding to the block(id) and extractor(id)\n   * and update all eventTriggers spent on the specified block\n   * @param block\n   * @param extractor\n   */\n  deleteBlock = async (block: string, extractor: string) => {\n    this.logger.info(\n      `Deleting event triggers at block ${block} and extractor ${extractor}`\n    );\n    await this.triggerEventRepository.delete({\n      block: block,\n      extractor: extractor,\n    });\n    await this.triggerEventRepository.update(\n      { spendBlock: block, extractor: extractor },\n      {\n        spendBlock: null,\n        spendTxId: null,\n        spendHeight: 0,\n        result: null,\n        paymentTxId: null,\n      }\n    );\n  };\n}\n\nexport default EventTriggerAction;\n"]}
|
|
@@ -22,7 +22,9 @@ declare class EventTriggerEntity {
|
|
|
22
22
|
WIDs: string;
|
|
23
23
|
spendBlock?: string | null;
|
|
24
24
|
spendHeight?: number;
|
|
25
|
-
spendTxId?: string;
|
|
25
|
+
spendTxId?: string | null;
|
|
26
|
+
result?: string | null;
|
|
27
|
+
paymentTxId?: string | null;
|
|
26
28
|
}
|
|
27
29
|
export default EventTriggerEntity;
|
|
28
30
|
//# sourceMappingURL=EventTriggerEntity.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EventTriggerEntity.d.ts","sourceRoot":"","sources":["../../lib/entities/EventTriggerEntity.ts"],"names":[],"mappings":"AAEA,cAEM,kBAAkB;IAEtB,EAAE,EAAE,MAAM,CAAC;IAGX,OAAO,EAAE,MAAM,CAAC;IAGhB,IAAI,EAAE,MAAM,CAAC;IAGb,SAAS,EAAE,MAAM,CAAC;IAGlB,KAAK,EAAE,MAAM,CAAC;IAGd,aAAa,EAAE,MAAM,CAAC;IAGtB,KAAK,EAAE,MAAM,CAAC;IAGd,MAAM,EAAE,MAAM,CAAC;IAGf,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,IAAI,EAAE,MAAM,CAAC;IAGb,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAG3B,WAAW,CAAC,EAAE,MAAM,CAAC;IAGrB,SAAS,CAAC,EAAE,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"EventTriggerEntity.d.ts","sourceRoot":"","sources":["../../lib/entities/EventTriggerEntity.ts"],"names":[],"mappings":"AAEA,cAEM,kBAAkB;IAEtB,EAAE,EAAE,MAAM,CAAC;IAGX,OAAO,EAAE,MAAM,CAAC;IAGhB,IAAI,EAAE,MAAM,CAAC;IAGb,SAAS,EAAE,MAAM,CAAC;IAGlB,KAAK,EAAE,MAAM,CAAC;IAGd,aAAa,EAAE,MAAM,CAAC;IAGtB,KAAK,EAAE,MAAM,CAAC;IAGd,MAAM,EAAE,MAAM,CAAC;IAGf,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,IAAI,EAAE,MAAM,CAAC;IAGb,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAG3B,WAAW,CAAC,EAAE,MAAM,CAAC;IAGrB,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"}
|
|
@@ -33,6 +33,8 @@ let EventTriggerEntity = class EventTriggerEntity {
|
|
|
33
33
|
spendBlock;
|
|
34
34
|
spendHeight;
|
|
35
35
|
spendTxId;
|
|
36
|
+
result;
|
|
37
|
+
paymentTxId;
|
|
36
38
|
};
|
|
37
39
|
__decorate([
|
|
38
40
|
PrimaryGeneratedColumn(),
|
|
@@ -127,12 +129,20 @@ __decorate([
|
|
|
127
129
|
__metadata("design:type", Number)
|
|
128
130
|
], EventTriggerEntity.prototype, "spendHeight", void 0);
|
|
129
131
|
__decorate([
|
|
130
|
-
Column({ nullable: true }),
|
|
131
|
-
__metadata("design:type",
|
|
132
|
+
Column({ nullable: true, type: 'text' }),
|
|
133
|
+
__metadata("design:type", Object)
|
|
132
134
|
], EventTriggerEntity.prototype, "spendTxId", void 0);
|
|
135
|
+
__decorate([
|
|
136
|
+
Column({ nullable: true, type: 'text' }),
|
|
137
|
+
__metadata("design:type", Object)
|
|
138
|
+
], EventTriggerEntity.prototype, "result", void 0);
|
|
139
|
+
__decorate([
|
|
140
|
+
Column({ nullable: true, type: 'text' }),
|
|
141
|
+
__metadata("design:type", Object)
|
|
142
|
+
], EventTriggerEntity.prototype, "paymentTxId", void 0);
|
|
133
143
|
EventTriggerEntity = __decorate([
|
|
134
144
|
Entity(),
|
|
135
145
|
Unique(['boxId', 'extractor'])
|
|
136
146
|
], EventTriggerEntity);
|
|
137
147
|
export default EventTriggerEntity;
|
|
138
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
148
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRXZlbnRUcmlnZ2VyRW50aXR5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vbGliL2VudGl0aWVzL0V2ZW50VHJpZ2dlckVudGl0eS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFJekUsSUFBTSxrQkFBa0IsR0FBeEIsTUFBTSxrQkFBa0I7SUFFdEIsRUFBRSxDQUFTO0lBR1gsT0FBTyxDQUFTO0lBR2hCLElBQUksQ0FBUztJQUdiLFNBQVMsQ0FBUztJQUdsQixLQUFLLENBQVM7SUFHZCxhQUFhLENBQVM7SUFHdEIsS0FBSyxDQUFTO0lBR2QsTUFBTSxDQUFTO0lBR2YsU0FBUyxDQUFTO0lBR2xCLE9BQU8sQ0FBUztJQUdoQixXQUFXLENBQVM7SUFHcEIsU0FBUyxDQUFTO0lBR2xCLE1BQU0sQ0FBUztJQUdmLFNBQVMsQ0FBUztJQUdsQixVQUFVLENBQVM7SUFHbkIsa0JBQWtCLENBQVM7SUFHM0IsaUJBQWlCLENBQVM7SUFHMUIsa0JBQWtCLENBQVM7SUFHM0IsVUFBVSxDQUFTO0lBR25CLGFBQWEsQ0FBUztJQUd0QixJQUFJLENBQVM7SUFHYixVQUFVLENBQWlCO0lBRzNCLFdBQVcsQ0FBVTtJQUdyQixTQUFTLENBQWlCO0lBRzFCLE1BQU0sQ0FBaUI7SUFHdkIsV0FBVyxDQUFpQjtDQUM3QixDQUFBO0FBN0VDO0lBQUMsc0JBQXNCLEVBQUU7OzhDQUNkO0FBRVg7SUFBQyxNQUFNLENBQUMsRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFLENBQUM7O21EQUNmO0FBRWhCO0lBQUMsTUFBTSxFQUFFOztnREFDSTtBQUViO0lBQUMsTUFBTSxFQUFFOztxREFDUztBQUVsQjtJQUFDLE1BQU0sRUFBRTs7aURBQ0s7QUFFZDtJQUFDLE1BQU0sRUFBRTs7eURBQ2E7QUFFdEI7SUFBQyxNQUFNLEVBQUU7O2lEQUNLO0FBRWQ7SUFBQyxNQUFNLEVBQUU7O2tEQUNNO0FBRWY7SUFBQyxNQUFNLEVBQUU7O3FEQUNTO0FBRWxCO0lBQUMsTUFBTSxFQUFFOzttREFDTztBQUVoQjtJQUFDLE1BQU0sRUFBRTs7dURBQ1c7QUFFcEI7SUFBQyxNQUFNLEVBQUU7O3FEQUNTO0FBRWxCO0lBQUMsTUFBTSxFQUFFOztrREFDTTtBQUVmO0lBQUMsTUFBTSxFQUFFOztxREFDUztBQUVsQjtJQUFDLE1BQU0sRUFBRTs7c0RBQ1U7QUFFbkI7SUFBQyxNQUFNLEVBQUU7OzhEQUNrQjtBQUUzQjtJQUFDLE1BQU0sRUFBRTs7NkRBQ2lCO0FBRTFCO0lBQUMsTUFBTSxFQUFFOzs4REFDa0I7QUFFM0I7SUFBQyxNQUFNLEVBQUU7O3NEQUNVO0FBRW5CO0lBQUMsTUFBTSxFQUFFOzt5REFDYTtBQUV0QjtJQUFDLE1BQU0sRUFBRTs7Z0RBQ0k7QUFFYjtJQUFDLE1BQU0sQ0FBQyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxDQUFDOztzREFDZDtBQUUzQjtJQUFDLE1BQU0sQ0FBQyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsQ0FBQzs7dURBQ047QUFFckI7SUFBQyxNQUFNLENBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsQ0FBQzs7cURBQ2Y7QUFFMUI7SUFBQyxNQUFNLENBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsQ0FBQzs7a0RBQ2xCO0FBRXZCO0lBQUMsTUFBTSxDQUFDLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLENBQUM7O3VEQUNiO0FBN0V4QixrQkFBa0I7SUFGdkIsTUFBTSxFQUFFO0lBQ1IsTUFBTSxDQUFDLENBQUMsT0FBTyxFQUFFLFdBQVcsQ0FBQyxDQUFDO0dBQ3pCLGtCQUFrQixDQThFdkI7QUFFRCxlQUFlLGtCQUFrQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29sdW1uLCBFbnRpdHksIFByaW1hcnlHZW5lcmF0ZWRDb2x1bW4sIFVuaXF1ZSB9IGZyb20gJ3R5cGVvcm0nO1xuXG5ARW50aXR5KClcbkBVbmlxdWUoWydib3hJZCcsICdleHRyYWN0b3InXSlcbmNsYXNzIEV2ZW50VHJpZ2dlckVudGl0eSB7XG4gIEBQcmltYXJ5R2VuZXJhdGVkQ29sdW1uKClcbiAgaWQ6IG51bWJlcjtcblxuICBAQ29sdW1uKHsgZGVmYXVsdDogJ05vdC1zZXQnIH0pXG4gIGV2ZW50SWQ6IHN0cmluZztcblxuICBAQ29sdW1uKClcbiAgdHhJZDogc3RyaW5nO1xuXG4gIEBDb2x1bW4oKVxuICBleHRyYWN0b3I6IHN0cmluZztcblxuICBAQ29sdW1uKClcbiAgYm94SWQ6IHN0cmluZztcblxuICBAQ29sdW1uKClcbiAgYm94U2VyaWFsaXplZDogc3RyaW5nO1xuXG4gIEBDb2x1bW4oKVxuICBibG9jazogc3RyaW5nO1xuXG4gIEBDb2x1bW4oKVxuICBoZWlnaHQ6IG51bWJlcjtcblxuICBAQ29sdW1uKClcbiAgZnJvbUNoYWluOiBzdHJpbmc7XG5cbiAgQENvbHVtbigpXG4gIHRvQ2hhaW46IHN0cmluZztcblxuICBAQ29sdW1uKClcbiAgZnJvbUFkZHJlc3M6IHN0cmluZztcblxuICBAQ29sdW1uKClcbiAgdG9BZGRyZXNzOiBzdHJpbmc7XG5cbiAgQENvbHVtbigpXG4gIGFtb3VudDogc3RyaW5nO1xuXG4gIEBDb2x1bW4oKVxuICBicmlkZ2VGZWU6IHN0cmluZztcblxuICBAQ29sdW1uKClcbiAgbmV0d29ya0ZlZTogc3RyaW5nO1xuXG4gIEBDb2x1bW4oKVxuICBzb3VyY2VDaGFpblRva2VuSWQ6IHN0cmluZztcblxuICBAQ29sdW1uKClcbiAgc291cmNlQ2hhaW5IZWlnaHQ6IG51bWJlcjtcblxuICBAQ29sdW1uKClcbiAgdGFyZ2V0Q2hhaW5Ub2tlbklkOiBzdHJpbmc7XG5cbiAgQENvbHVtbigpXG4gIHNvdXJjZVR4SWQ6IHN0cmluZztcblxuICBAQ29sdW1uKClcbiAgc291cmNlQmxvY2tJZDogc3RyaW5nO1xuXG4gIEBDb2x1bW4oKVxuICBXSURzOiBzdHJpbmc7XG5cbiAgQENvbHVtbih7IG51bGxhYmxlOiB0cnVlLCB0eXBlOiAndGV4dCcgfSlcbiAgc3BlbmRCbG9jaz86IHN0cmluZyB8IG51bGw7XG5cbiAgQENvbHVtbih7IG51bGxhYmxlOiB0cnVlIH0pXG4gIHNwZW5kSGVpZ2h0PzogbnVtYmVyO1xuXG4gIEBDb2x1bW4oeyBudWxsYWJsZTogdHJ1ZSwgdHlwZTogJ3RleHQnIH0pXG4gIHNwZW5kVHhJZD86IHN0cmluZyB8IG51bGw7XG5cbiAgQENvbHVtbih7IG51bGxhYmxlOiB0cnVlLCB0eXBlOiAndGV4dCcgfSlcbiAgcmVzdWx0Pzogc3RyaW5nIHwgbnVsbDtcblxuICBAQ29sdW1uKHsgbnVsbGFibGU6IHRydWUsIHR5cGU6ICd0ZXh0JyB9KVxuICBwYXltZW50VHhJZD86IHN0cmluZyB8IG51bGw7XG59XG5cbmV4cG9ydCBkZWZhdWx0IEV2ZW50VHJpZ2dlckVudGl0eTtcbiJdfQ==
|
|
@@ -1,14 +1,17 @@
|
|
|
1
1
|
import { DataSource } from 'typeorm';
|
|
2
2
|
import { AbstractExtractor, BlockEntity, Transaction } from '@rosen-bridge/scanner';
|
|
3
3
|
import { AbstractLogger } from '@rosen-bridge/logger-interface';
|
|
4
|
+
import { EventResult } from '../types';
|
|
4
5
|
declare class EventTriggerExtractor extends AbstractExtractor<Transaction> {
|
|
5
6
|
readonly logger: AbstractLogger;
|
|
6
7
|
id: string;
|
|
7
8
|
private readonly dataSource;
|
|
8
9
|
private readonly actions;
|
|
9
10
|
private readonly eventTriggerErgoTree;
|
|
11
|
+
private readonly permitErgoTree;
|
|
12
|
+
private readonly fraudErgoTree;
|
|
10
13
|
private readonly RWT;
|
|
11
|
-
constructor(id: string, dataSource: DataSource, address: string, RWT: string, logger?: AbstractLogger);
|
|
14
|
+
constructor(id: string, dataSource: DataSource, address: string, RWT: string, permitAddress: string, fraudAddress: string, logger?: AbstractLogger);
|
|
12
15
|
getId: () => string;
|
|
13
16
|
/**
|
|
14
17
|
* gets block id and transactions corresponding to the block and saves if they are valid rosen
|
|
@@ -23,6 +26,16 @@ declare class EventTriggerExtractor extends AbstractExtractor<Transaction> {
|
|
|
23
26
|
* No action needed in event trigger extractors
|
|
24
27
|
*/
|
|
25
28
|
initializeBoxes: () => Promise<void>;
|
|
29
|
+
/**
|
|
30
|
+
* extracts result and paymentTxId from a transaction
|
|
31
|
+
* returns 'unknown' as result when tx is neither fraud or successful
|
|
32
|
+
* @param transaction
|
|
33
|
+
* @returns
|
|
34
|
+
*/
|
|
35
|
+
protected extractEventResult: (transaction: Transaction) => {
|
|
36
|
+
result: EventResult;
|
|
37
|
+
paymentTxId: string;
|
|
38
|
+
};
|
|
26
39
|
}
|
|
27
40
|
export default EventTriggerExtractor;
|
|
28
41
|
//# sourceMappingURL=EventTriggerExtractor.d.ts.map
|
|
@@ -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,EACL,iBAAiB,EACjB,WAAW,EACX,WAAW,EACZ,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EAAE,cAAc,EAAe,MAAM,gCAAgC,CAAC;
|
|
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,EACL,iBAAiB,EACjB,WAAW,EACX,WAAW,EACZ,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EAAE,cAAc,EAAe,MAAM,gCAAgC,CAAC;AAK7E,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAEvC,cAAM,qBAAsB,SAAQ,iBAAiB,CAAC,WAAW,CAAC;IAChE,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC;IAChC,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;IACxC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAqB;IAC7C,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,OAAO,EAAE,MAAM,EACf,GAAG,EAAE,MAAM,EACX,aAAa,EAAE,MAAM,EACrB,YAAY,EAAE,MAAM,EACpB,MAAM,CAAC,EAAE,cAAc;IAmBzB,KAAK,eAAiB;IAEtB;;;;;OAKG;IACH,mBAAmB,QACZ,MAAM,WAAW,CAAC,SAChB,WAAW,KACjB,QAAQ,OAAO,CAAC,CAiIjB;IAEF,SAAS,SAAgB,MAAM,mBAE7B;IAEF;;;OAGG;IACH,eAAe,sBAEb;IAEF;;;;;OAKG;IACH,SAAS,CAAC,kBAAkB,gBAAiB,WAAW;;;MAsCtD;CACH;AAED,eAAe,qBAAqB,CAAC"}
|
|
@@ -4,20 +4,29 @@ import { AbstractExtractor, } from '@rosen-bridge/scanner';
|
|
|
4
4
|
import { DummyLogger } from '@rosen-bridge/logger-interface';
|
|
5
5
|
import EventTriggerAction from '../actions/EventTriggerAction';
|
|
6
6
|
import { JsonBI } from '../utils';
|
|
7
|
+
import { EventResult } from '../types';
|
|
7
8
|
class EventTriggerExtractor extends AbstractExtractor {
|
|
8
9
|
logger;
|
|
9
10
|
id;
|
|
10
11
|
dataSource;
|
|
11
12
|
actions;
|
|
12
13
|
eventTriggerErgoTree;
|
|
14
|
+
permitErgoTree;
|
|
15
|
+
fraudErgoTree;
|
|
13
16
|
RWT;
|
|
14
|
-
constructor(id, dataSource, address, RWT, logger) {
|
|
17
|
+
constructor(id, dataSource, address, RWT, permitAddress, fraudAddress, logger) {
|
|
15
18
|
super();
|
|
16
19
|
this.id = id;
|
|
17
20
|
this.dataSource = dataSource;
|
|
18
21
|
this.eventTriggerErgoTree = wasm.Address.from_base58(address)
|
|
19
22
|
.to_ergo_tree()
|
|
20
23
|
.to_base16_bytes();
|
|
24
|
+
this.permitErgoTree = wasm.Address.from_base58(permitAddress)
|
|
25
|
+
.to_ergo_tree()
|
|
26
|
+
.to_base16_bytes();
|
|
27
|
+
this.fraudErgoTree = wasm.Address.from_base58(fraudAddress)
|
|
28
|
+
.to_ergo_tree()
|
|
29
|
+
.to_base16_bytes();
|
|
21
30
|
this.RWT = RWT;
|
|
22
31
|
this.logger = logger ? logger : new DummyLogger();
|
|
23
32
|
this.actions = new EventTriggerAction(dataSource, this.logger);
|
|
@@ -35,6 +44,8 @@ class EventTriggerExtractor extends AbstractExtractor {
|
|
|
35
44
|
const boxes = [];
|
|
36
45
|
const txSpendIds = [];
|
|
37
46
|
txs.forEach((transaction) => {
|
|
47
|
+
// extract event result
|
|
48
|
+
const { result, paymentTxId } = this.extractEventResult(transaction);
|
|
38
49
|
for (const output of transaction.outputs) {
|
|
39
50
|
try {
|
|
40
51
|
if (output.additionalRegisters &&
|
|
@@ -82,19 +93,21 @@ class EventTriggerExtractor extends AbstractExtractor {
|
|
|
82
93
|
catch {
|
|
83
94
|
continue;
|
|
84
95
|
}
|
|
85
|
-
// process inputs
|
|
86
|
-
txSpendIds.push({
|
|
87
|
-
txId: transaction.id,
|
|
88
|
-
spendBoxes: transaction.inputs.map((box) => box.boxId),
|
|
89
|
-
});
|
|
90
96
|
}
|
|
97
|
+
// process inputs
|
|
98
|
+
txSpendIds.push({
|
|
99
|
+
txId: transaction.id,
|
|
100
|
+
spendBoxes: transaction.inputs.map((box) => box.boxId),
|
|
101
|
+
result: result,
|
|
102
|
+
paymentTxId: paymentTxId,
|
|
103
|
+
});
|
|
91
104
|
});
|
|
92
105
|
this.actions
|
|
93
106
|
.storeEventTriggers(boxes, block, this.getId())
|
|
94
107
|
.then(() => {
|
|
95
108
|
txSpendIds.forEach((txSpends) => {
|
|
96
109
|
this.actions
|
|
97
|
-
.spendEventTriggers(txSpends.spendBoxes, block, this.id, txSpends.txId)
|
|
110
|
+
.spendEventTriggers(txSpends.spendBoxes, block, this.id, txSpends.txId, txSpends.result, txSpends.paymentTxId)
|
|
98
111
|
.then(() => {
|
|
99
112
|
resolve(true);
|
|
100
113
|
});
|
|
@@ -121,6 +134,52 @@ class EventTriggerExtractor extends AbstractExtractor {
|
|
|
121
134
|
initializeBoxes = async () => {
|
|
122
135
|
return;
|
|
123
136
|
};
|
|
137
|
+
/**
|
|
138
|
+
* extracts result and paymentTxId from a transaction
|
|
139
|
+
* returns 'unknown' as result when tx is neither fraud or successful
|
|
140
|
+
* @param transaction
|
|
141
|
+
* @returns
|
|
142
|
+
*/
|
|
143
|
+
extractEventResult = (transaction) => {
|
|
144
|
+
let result = EventResult.unknown;
|
|
145
|
+
let paymentTxId = '';
|
|
146
|
+
if (transaction.outputs[0].ergoTree === this.fraudErgoTree)
|
|
147
|
+
result = EventResult.fraud;
|
|
148
|
+
else if (transaction.outputs[0].ergoTree === this.permitErgoTree) {
|
|
149
|
+
result = EventResult.successful;
|
|
150
|
+
// find first non-watcher box with R4 value
|
|
151
|
+
for (const box of transaction.outputs) {
|
|
152
|
+
// if it's watcher box, skip it
|
|
153
|
+
if (box.ergoTree === this.permitErgoTree)
|
|
154
|
+
continue;
|
|
155
|
+
const outputParsed = wasm.ErgoBox.from_json(JsonBI.stringify(box));
|
|
156
|
+
try {
|
|
157
|
+
const R4Serialized = outputParsed
|
|
158
|
+
.register_value(wasm.NonMandatoryRegisterId.R4)
|
|
159
|
+
?.to_coll_coll_byte();
|
|
160
|
+
if (R4Serialized !== undefined && R4Serialized.length > 0) {
|
|
161
|
+
const txId = Buffer.from(R4Serialized[0]).toString('hex');
|
|
162
|
+
paymentTxId = txId;
|
|
163
|
+
if (txId !== '')
|
|
164
|
+
paymentTxId = txId;
|
|
165
|
+
else {
|
|
166
|
+
paymentTxId = transaction.id;
|
|
167
|
+
this.logger.debug(`successful event is spent. tx [${transaction.id}] is both payment and reward distribution tx`);
|
|
168
|
+
}
|
|
169
|
+
// paymentTxId is extracted. no need to process next boxes
|
|
170
|
+
break;
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
catch (e) {
|
|
174
|
+
continue;
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
return {
|
|
179
|
+
result,
|
|
180
|
+
paymentTxId,
|
|
181
|
+
};
|
|
182
|
+
};
|
|
124
183
|
}
|
|
125
184
|
export default EventTriggerExtractor;
|
|
126
|
-
//# 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 {\n  AbstractExtractor,\n  BlockEntity,\n  Transaction,\n} from '@rosen-bridge/scanner';\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/logger-interface';\n\nimport EventTriggerAction from '../actions/EventTriggerAction';\nimport { ExtractedEventTrigger } from '../interfaces/extractedEventTrigger';\nimport { JsonBI } from '../utils';\n\nclass EventTriggerExtractor extends AbstractExtractor<Transaction> {\n  readonly logger: AbstractLogger;\n  id: string;\n  private readonly dataSource: DataSource;\n  private readonly actions: EventTriggerAction;\n  private readonly eventTriggerErgoTree: string;\n  private readonly RWT: string;\n\n  constructor(\n    id: string,\n    dataSource: DataSource,\n    address: string,\n    RWT: string,\n    logger?: AbstractLogger\n  ) {\n    super();\n    this.id = id;\n    this.dataSource = dataSource;\n    this.eventTriggerErgoTree = wasm.Address.from_base58(address)\n      .to_ergo_tree()\n      .to_base16_bytes();\n    this.RWT = RWT;\n    this.logger = logger ? logger : new DummyLogger();\n    this.actions = new EventTriggerAction(dataSource, this.logger);\n  }\n\n  getId = () => this.id;\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 = (\n    txs: Array<Transaction>,\n    block: BlockEntity\n  ): Promise<boolean> => {\n    return new Promise((resolve, reject) => {\n      try {\n        const boxes: Array<ExtractedEventTrigger> = [];\n        const txSpendIds: Array<{ txId: string; spendBoxes: Array<string> }> =\n          [];\n        txs.forEach((transaction) => {\n          for (const output of transaction.outputs) {\n            try {\n              if (\n                output.additionalRegisters &&\n                output.assets &&\n                output.assets.length > 0 &&\n                output.assets[0].tokenId === this.RWT &&\n                output.ergoTree === this.eventTriggerErgoTree\n              ) {\n                const R4 = output.additionalRegisters.R4;\n                const R5 = output.additionalRegisters.R5;\n                if (R4 && R5) {\n                  const outputParsed = wasm.ErgoBox.from_json(\n                    JsonBI.stringify(output)\n                  );\n                  const R4Const = outputParsed.register_value(\n                    wasm.NonMandatoryRegisterId.R4\n                  );\n                  const R5Const = outputParsed.register_value(\n                    wasm.NonMandatoryRegisterId.R5\n                  );\n                  if (R4Const && R5Const) {\n                    const R4Serialized = R4Const.to_coll_coll_byte();\n                    const R5Serialized = R5Const.to_coll_coll_byte();\n                    if (R4Serialized.length >= 1 && R5Serialized.length >= 12) {\n                      const WIDs = R4Serialized.map((byteArray) =>\n                        Buffer.from(byteArray).toString('hex')\n                      ).join(',');\n                      const sourceTxId = Buffer.from(\n                        R5Serialized[0]\n                      ).toString();\n                      const eventId = Buffer.from(\n                        blake2b(sourceTxId, undefined, 32)\n                      ).toString('hex');\n                      boxes.push({\n                        eventId: eventId,\n                        txId: transaction.id,\n                        boxId: output.boxId,\n                        boxSerialized: Buffer.from(\n                          outputParsed.sigma_serialize_bytes()\n                        ).toString('base64'),\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(\n                          R5Serialized[8]\n                        ).toString(),\n                        targetChainTokenId: Buffer.from(\n                          R5Serialized[9]\n                        ).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                        WIDs: WIDs,\n                        sourceChainHeight: Number(\n                          BigInt(\n                            '0x' + Buffer.from(R5Serialized[11]).toString('hex')\n                          ).toString(10)\n                        ),\n                      });\n                    }\n                  }\n                }\n              }\n            } catch {\n              continue;\n            }\n            // process inputs\n            txSpendIds.push({\n              txId: transaction.id,\n              spendBoxes: transaction.inputs.map((box) => box.boxId),\n            });\n          }\n        });\n        this.actions\n          .storeEventTriggers(boxes, block, this.getId())\n          .then(() => {\n            txSpendIds.forEach((txSpends) => {\n              this.actions\n                .spendEventTriggers(\n                  txSpends.spendBoxes,\n                  block,\n                  this.id,\n                  txSpends.txId\n                )\n                .then(() => {\n                  resolve(true);\n                });\n            });\n          })\n          .catch((e) => {\n            this.logger.error(\n              `Error in storing permits of the block ${block}: ${e}`\n            );\n            reject(e);\n          });\n      } catch (e) {\n        this.logger.error(\n          `block ${block} doesn't save in the database with error: ${e}`\n        );\n        reject(e);\n      }\n    });\n  };\n\n  forkBlock = async (hash: string) => {\n    await this.actions.deleteBlock(hash, this.getId());\n  };\n\n  /**\n   * Extractor box initialization\n   * No action needed in event trigger extractors\n   */\n  initializeBoxes = async () => {\n    return;\n  };\n}\n\nexport default EventTriggerExtractor;\n"]}
|
|
185
|
+
//# 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 {\n  AbstractExtractor,\n  BlockEntity,\n  Transaction,\n} from '@rosen-bridge/scanner';\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/logger-interface';\n\nimport EventTriggerAction from '../actions/EventTriggerAction';\nimport { ExtractedEventTrigger } from '../interfaces/extractedEventTrigger';\nimport { JsonBI } from '../utils';\nimport { EventResult } from '../types';\n\nclass EventTriggerExtractor extends AbstractExtractor<Transaction> {\n  readonly logger: AbstractLogger;\n  id: string;\n  private readonly dataSource: DataSource;\n  private 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    address: string,\n    RWT: string,\n    permitAddress: string,\n    fraudAddress: string,\n    logger?: AbstractLogger\n  ) {\n    super();\n    this.id = id;\n    this.dataSource = dataSource;\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.logger = logger ? logger : new DummyLogger();\n    this.actions = new EventTriggerAction(dataSource, this.logger);\n  }\n\n  getId = () => this.id;\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 = (\n    txs: Array<Transaction>,\n    block: BlockEntity\n  ): Promise<boolean> => {\n    return new Promise((resolve, reject) => {\n      try {\n        const boxes: Array<ExtractedEventTrigger> = [];\n        const txSpendIds: Array<{\n          txId: string;\n          spendBoxes: Array<string>;\n          result: string;\n          paymentTxId: string;\n        }> = [];\n        txs.forEach((transaction) => {\n          // extract event result\n          const { result, paymentTxId } = this.extractEventResult(transaction);\n          for (const output of transaction.outputs) {\n            try {\n              if (\n                output.additionalRegisters &&\n                output.assets &&\n                output.assets.length > 0 &&\n                output.assets[0].tokenId === this.RWT &&\n                output.ergoTree === this.eventTriggerErgoTree\n              ) {\n                const R4 = output.additionalRegisters.R4;\n                const R5 = output.additionalRegisters.R5;\n                if (R4 && R5) {\n                  const outputParsed = wasm.ErgoBox.from_json(\n                    JsonBI.stringify(output)\n                  );\n                  const R4Const = outputParsed.register_value(\n                    wasm.NonMandatoryRegisterId.R4\n                  );\n                  const R5Const = outputParsed.register_value(\n                    wasm.NonMandatoryRegisterId.R5\n                  );\n                  if (R4Const && R5Const) {\n                    const R4Serialized = R4Const.to_coll_coll_byte();\n                    const R5Serialized = R5Const.to_coll_coll_byte();\n                    if (R4Serialized.length >= 1 && R5Serialized.length >= 12) {\n                      const WIDs = R4Serialized.map((byteArray) =>\n                        Buffer.from(byteArray).toString('hex')\n                      ).join(',');\n                      const sourceTxId = Buffer.from(\n                        R5Serialized[0]\n                      ).toString();\n                      const eventId = Buffer.from(\n                        blake2b(sourceTxId, undefined, 32)\n                      ).toString('hex');\n                      boxes.push({\n                        eventId: eventId,\n                        txId: transaction.id,\n                        boxId: output.boxId,\n                        boxSerialized: Buffer.from(\n                          outputParsed.sigma_serialize_bytes()\n                        ).toString('base64'),\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(\n                          R5Serialized[8]\n                        ).toString(),\n                        targetChainTokenId: Buffer.from(\n                          R5Serialized[9]\n                        ).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                        WIDs: WIDs,\n                        sourceChainHeight: Number(\n                          BigInt(\n                            '0x' + Buffer.from(R5Serialized[11]).toString('hex')\n                          ).toString(10)\n                        ),\n                      });\n                    }\n                  }\n                }\n              }\n            } catch {\n              continue;\n            }\n          }\n          // process inputs\n          txSpendIds.push({\n            txId: transaction.id,\n            spendBoxes: transaction.inputs.map((box) => box.boxId),\n            result: result,\n            paymentTxId: paymentTxId,\n          });\n        });\n        this.actions\n          .storeEventTriggers(boxes, block, this.getId())\n          .then(() => {\n            txSpendIds.forEach((txSpends) => {\n              this.actions\n                .spendEventTriggers(\n                  txSpends.spendBoxes,\n                  block,\n                  this.id,\n                  txSpends.txId,\n                  txSpends.result,\n                  txSpends.paymentTxId\n                )\n                .then(() => {\n                  resolve(true);\n                });\n            });\n          })\n          .catch((e) => {\n            this.logger.error(\n              `Error in storing permits of the block ${block}: ${e}`\n            );\n            reject(e);\n          });\n      } catch (e) {\n        this.logger.error(\n          `block ${block} doesn't save in the database with error: ${e}`\n        );\n        reject(e);\n      }\n    });\n  };\n\n  forkBlock = async (hash: string) => {\n    await this.actions.deleteBlock(hash, this.getId());\n  };\n\n  /**\n   * Extractor box initialization\n   * No action needed in event trigger extractors\n   */\n  initializeBoxes = async () => {\n    return;\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_coll_coll_byte();\n          if (R4Serialized !== undefined && R4Serialized.length > 0) {\n            const txId = Buffer.from(R4Serialized[0]).toString('hex');\n            paymentTxId = txId;\n            if (txId !== '') paymentTxId = txId;\n            else {\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"]}
|
package/dist/index.d.ts
CHANGED
|
@@ -7,4 +7,5 @@ import PermitExtractor from './extractor/permitExtractor';
|
|
|
7
7
|
import EventTriggerExtractor from './extractor/EventTriggerExtractor';
|
|
8
8
|
export { migrations } from './migrations/index';
|
|
9
9
|
export { PermitExtractor, EventTriggerExtractor, CommitmentExtractor, CommitmentEntity, EventTriggerEntity, PermitEntity, };
|
|
10
|
+
export * from './types';
|
|
10
11
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../lib/index.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,CAAC;AAC1B,OAAO,kBAAkB,MAAM,+BAA+B,CAAC;AAC/D,OAAO,gBAAgB,MAAM,6BAA6B,CAAC;AAC3D,OAAO,mBAAmB,MAAM,iCAAiC,CAAC;AAClE,OAAO,YAAY,MAAM,yBAAyB,CAAC;AACnD,OAAO,eAAe,MAAM,6BAA6B,CAAC;AAC1D,OAAO,qBAAqB,MAAM,mCAAmC,CAAC;AAEtE,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EACL,eAAe,EACf,qBAAqB,EACrB,mBAAmB,EACnB,gBAAgB,EAChB,kBAAkB,EAClB,YAAY,GACb,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../lib/index.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,CAAC;AAC1B,OAAO,kBAAkB,MAAM,+BAA+B,CAAC;AAC/D,OAAO,gBAAgB,MAAM,6BAA6B,CAAC;AAC3D,OAAO,mBAAmB,MAAM,iCAAiC,CAAC;AAClE,OAAO,YAAY,MAAM,yBAAyB,CAAC;AACnD,OAAO,eAAe,MAAM,6BAA6B,CAAC;AAC1D,OAAO,qBAAqB,MAAM,mCAAmC,CAAC;AAEtE,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EACL,eAAe,EACf,qBAAqB,EACrB,mBAAmB,EACnB,gBAAgB,EAChB,kBAAkB,EAClB,YAAY,GACb,CAAC;AACF,cAAc,SAAS,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -7,4 +7,5 @@ import PermitExtractor from './extractor/permitExtractor';
|
|
|
7
7
|
import EventTriggerExtractor from './extractor/EventTriggerExtractor';
|
|
8
8
|
export { migrations } from './migrations/index';
|
|
9
9
|
export { PermitExtractor, EventTriggerExtractor, CommitmentExtractor, CommitmentEntity, EventTriggerEntity, PermitEntity, };
|
|
10
|
-
|
|
10
|
+
export * from './types';
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9saWIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxrQkFBa0IsQ0FBQztBQUMxQixPQUFPLGtCQUFrQixNQUFNLCtCQUErQixDQUFDO0FBQy9ELE9BQU8sZ0JBQWdCLE1BQU0sNkJBQTZCLENBQUM7QUFDM0QsT0FBTyxtQkFBbUIsTUFBTSxpQ0FBaUMsQ0FBQztBQUNsRSxPQUFPLFlBQVksTUFBTSx5QkFBeUIsQ0FBQztBQUNuRCxPQUFPLGVBQWUsTUFBTSw2QkFBNkIsQ0FBQztBQUMxRCxPQUFPLHFCQUFxQixNQUFNLG1DQUFtQyxDQUFDO0FBRXRFLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUNoRCxPQUFPLEVBQ0wsZUFBZSxFQUNmLHFCQUFxQixFQUNyQixtQkFBbUIsRUFDbkIsZ0JBQWdCLEVBQ2hCLGtCQUFrQixFQUNsQixZQUFZLEdBQ2IsQ0FBQztBQUNGLGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICdyZWZsZWN0LW1ldGFkYXRhJztcbmltcG9ydCBFdmVudFRyaWdnZXJFbnRpdHkgZnJvbSAnLi9lbnRpdGllcy9FdmVudFRyaWdnZXJFbnRpdHknO1xuaW1wb3J0IENvbW1pdG1lbnRFbnRpdHkgZnJvbSAnLi9lbnRpdGllcy9Db21taXRtZW50RW50aXR5JztcbmltcG9ydCBDb21taXRtZW50RXh0cmFjdG9yIGZyb20gJy4vZXh0cmFjdG9yL2NvbW1pdG1lbnRFeHRyYWN0b3InO1xuaW1wb3J0IFBlcm1pdEVudGl0eSBmcm9tICcuL2VudGl0aWVzL1Blcm1pdEVudGl0eSc7XG5pbXBvcnQgUGVybWl0RXh0cmFjdG9yIGZyb20gJy4vZXh0cmFjdG9yL3Blcm1pdEV4dHJhY3Rvcic7XG5pbXBvcnQgRXZlbnRUcmlnZ2VyRXh0cmFjdG9yIGZyb20gJy4vZXh0cmFjdG9yL0V2ZW50VHJpZ2dlckV4dHJhY3Rvcic7XG5cbmV4cG9ydCB7IG1pZ3JhdGlvbnMgfSBmcm9tICcuL21pZ3JhdGlvbnMvaW5kZXgnO1xuZXhwb3J0IHtcbiAgUGVybWl0RXh0cmFjdG9yLFxuICBFdmVudFRyaWdnZXJFeHRyYWN0b3IsXG4gIENvbW1pdG1lbnRFeHRyYWN0b3IsXG4gIENvbW1pdG1lbnRFbnRpdHksXG4gIEV2ZW50VHJpZ2dlckVudGl0eSxcbiAgUGVybWl0RW50aXR5LFxufTtcbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMnO1xuIl19
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { migration1699874447928 } from './postgres/1699874447928-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 migration1699874447928)[];
|
|
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":"AAEA,OAAO,EAAE,sBAAsB,EAAE,MAAM,oCAAoC,CAAC;AAC5E,OAAO,EAAE,sBAAsB,EAAE,MAAM,kCAAkC,CAAC;AAI1E,eAAO,MAAM,UAAU;;;CAWtB,CAAC"}
|
package/dist/migrations/index.js
CHANGED
|
@@ -1,9 +1,19 @@
|
|
|
1
1
|
import { migration1688554842087 } from './postgres/1688554842087-migration';
|
|
2
2
|
import { migration1689175974257 } from './postgres/1689175974257-migration';
|
|
3
|
+
import { migration1699874447928 } from './postgres/1699874447928-migration';
|
|
3
4
|
import { migration1688555766601 } from './sqlite/1688555766601-migration';
|
|
4
5
|
import { migration1689175103163 } from './sqlite/1689175103163-migration';
|
|
6
|
+
import { migration1699872205117 } from './sqlite/1699872205117-migration';
|
|
5
7
|
export const migrations = {
|
|
6
|
-
sqlite: [
|
|
7
|
-
|
|
8
|
+
sqlite: [
|
|
9
|
+
migration1688555766601,
|
|
10
|
+
migration1689175103163,
|
|
11
|
+
migration1699872205117,
|
|
12
|
+
],
|
|
13
|
+
postgres: [
|
|
14
|
+
migration1688554842087,
|
|
15
|
+
migration1689175974257,
|
|
16
|
+
migration1699874447928,
|
|
17
|
+
],
|
|
8
18
|
};
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9saWIvbWlncmF0aW9ucy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUMxRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUMxRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUUxRSxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUc7SUFDeEIsTUFBTSxFQUFFO1FBQ04sc0JBQXNCO1FBQ3RCLHNCQUFzQjtRQUN0QixzQkFBc0I7S0FDdkI7SUFDRCxRQUFRLEVBQUU7UUFDUixzQkFBc0I7UUFDdEIsc0JBQXNCO1FBQ3RCLHNCQUFzQjtLQUN2QjtDQUNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBtaWdyYXRpb24xNjg4NTU0ODQyMDg3IH0gZnJvbSAnLi9wb3N0Z3Jlcy8xNjg4NTU0ODQyMDg3LW1pZ3JhdGlvbic7XG5pbXBvcnQgeyBtaWdyYXRpb24xNjg5MTc1OTc0MjU3IH0gZnJvbSAnLi9wb3N0Z3Jlcy8xNjg5MTc1OTc0MjU3LW1pZ3JhdGlvbic7XG5pbXBvcnQgeyBtaWdyYXRpb24xNjk5ODc0NDQ3OTI4IH0gZnJvbSAnLi9wb3N0Z3Jlcy8xNjk5ODc0NDQ3OTI4LW1pZ3JhdGlvbic7XG5pbXBvcnQgeyBtaWdyYXRpb24xNjg4NTU1NzY2NjAxIH0gZnJvbSAnLi9zcWxpdGUvMTY4ODU1NTc2NjYwMS1taWdyYXRpb24nO1xuaW1wb3J0IHsgbWlncmF0aW9uMTY4OTE3NTEwMzE2MyB9IGZyb20gJy4vc3FsaXRlLzE2ODkxNzUxMDMxNjMtbWlncmF0aW9uJztcbmltcG9ydCB7IG1pZ3JhdGlvbjE2OTk4NzIyMDUxMTcgfSBmcm9tICcuL3NxbGl0ZS8xNjk5ODcyMjA1MTE3LW1pZ3JhdGlvbic7XG5cbmV4cG9ydCBjb25zdCBtaWdyYXRpb25zID0ge1xuICBzcWxpdGU6IFtcbiAgICBtaWdyYXRpb24xNjg4NTU1NzY2NjAxLFxuICAgIG1pZ3JhdGlvbjE2ODkxNzUxMDMxNjMsXG4gICAgbWlncmF0aW9uMTY5OTg3MjIwNTExNyxcbiAgXSxcbiAgcG9zdGdyZXM6IFtcbiAgICBtaWdyYXRpb24xNjg4NTU0ODQyMDg3LFxuICAgIG1pZ3JhdGlvbjE2ODkxNzU5NzQyNTcsXG4gICAgbWlncmF0aW9uMTY5OTg3NDQ0NzkyOCxcbiAgXSxcbn07XG4iXX0=
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { MigrationInterface, QueryRunner } from 'typeorm';
|
|
2
|
+
export declare class migration1699874447928 implements MigrationInterface {
|
|
3
|
+
name: string;
|
|
4
|
+
up(queryRunner: QueryRunner): Promise<void>;
|
|
5
|
+
down(queryRunner: QueryRunner): Promise<void>;
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=1699874447928-migration.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"1699874447928-migration.d.ts","sourceRoot":"","sources":["../../../lib/migrations/postgres/1699874447928-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;IAkB3C,IAAI,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;CAe3D"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
export class migration1699874447928 {
|
|
2
|
+
name = 'migration1699874447928';
|
|
3
|
+
async up(queryRunner) {
|
|
4
|
+
await queryRunner.query(`
|
|
5
|
+
ALTER TABLE "event_trigger_entity"
|
|
6
|
+
ADD "result" text
|
|
7
|
+
`);
|
|
8
|
+
await queryRunner.query(`
|
|
9
|
+
ALTER TABLE "event_trigger_entity"
|
|
10
|
+
ADD "paymentTxId" text
|
|
11
|
+
`);
|
|
12
|
+
await queryRunner.query(`
|
|
13
|
+
ALTER TABLE "event_trigger_entity" DROP COLUMN "spendTxId"
|
|
14
|
+
`);
|
|
15
|
+
await queryRunner.query(`
|
|
16
|
+
ALTER TABLE "event_trigger_entity"
|
|
17
|
+
ADD "spendTxId" text
|
|
18
|
+
`);
|
|
19
|
+
}
|
|
20
|
+
async down(queryRunner) {
|
|
21
|
+
await queryRunner.query(`
|
|
22
|
+
ALTER TABLE "event_trigger_entity" DROP COLUMN "spendTxId"
|
|
23
|
+
`);
|
|
24
|
+
await queryRunner.query(`
|
|
25
|
+
ALTER TABLE "event_trigger_entity"
|
|
26
|
+
ADD "spendTxId" character varying
|
|
27
|
+
`);
|
|
28
|
+
await queryRunner.query(`
|
|
29
|
+
ALTER TABLE "event_trigger_entity" DROP COLUMN "paymentTxId"
|
|
30
|
+
`);
|
|
31
|
+
await queryRunner.query(`
|
|
32
|
+
ALTER TABLE "event_trigger_entity" DROP COLUMN "result"
|
|
33
|
+
`);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTY5OTg3NDQ0NzkyOC1taWdyYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9saWIvbWlncmF0aW9ucy9wb3N0Z3Jlcy8xNjk5ODc0NDQ3OTI4LW1pZ3JhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLE9BQU8sc0JBQXNCO0lBQ2pDLElBQUksR0FBRyx3QkFBd0IsQ0FBQztJQUV6QixLQUFLLENBQUMsRUFBRSxDQUFDLFdBQXdCO1FBQ3RDLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7O1NBR25CLENBQUMsQ0FBQztRQUNQLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7O1NBR25CLENBQUMsQ0FBQztRQUNQLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7U0FFbkIsQ0FBQyxDQUFDO1FBQ1AsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOzs7U0FHbkIsQ0FBQyxDQUFDO0lBQ1QsQ0FBQztJQUVNLEtBQUssQ0FBQyxJQUFJLENBQUMsV0FBd0I7UUFDeEMsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOztTQUVuQixDQUFDLENBQUM7UUFDUCxNQUFNLFdBQVcsQ0FBQyxLQUFLLENBQUM7OztTQUduQixDQUFDLENBQUM7UUFDUCxNQUFNLFdBQVcsQ0FBQyxLQUFLLENBQUM7O1NBRW5CLENBQUMsQ0FBQztRQUNQLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7U0FFbkIsQ0FBQyxDQUFDO0lBQ1QsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWlncmF0aW9uSW50ZXJmYWNlLCBRdWVyeVJ1bm5lciB9IGZyb20gJ3R5cGVvcm0nO1xuXG5leHBvcnQgY2xhc3MgbWlncmF0aW9uMTY5OTg3NDQ0NzkyOCBpbXBsZW1lbnRzIE1pZ3JhdGlvbkludGVyZmFjZSB7XG4gIG5hbWUgPSAnbWlncmF0aW9uMTY5OTg3NDQ0NzkyOCc7XG5cbiAgcHVibGljIGFzeW5jIHVwKHF1ZXJ5UnVubmVyOiBRdWVyeVJ1bm5lcik6IFByb21pc2U8dm9pZD4ge1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIEFMVEVSIFRBQkxFIFwiZXZlbnRfdHJpZ2dlcl9lbnRpdHlcIlxuICAgICAgICAgICAgQUREIFwicmVzdWx0XCIgdGV4dFxuICAgICAgICBgKTtcbiAgICBhd2FpdCBxdWVyeVJ1bm5lci5xdWVyeShgXG4gICAgICAgICAgICBBTFRFUiBUQUJMRSBcImV2ZW50X3RyaWdnZXJfZW50aXR5XCJcbiAgICAgICAgICAgIEFERCBcInBheW1lbnRUeElkXCIgdGV4dFxuICAgICAgICBgKTtcbiAgICBhd2FpdCBxdWVyeVJ1bm5lci5xdWVyeShgXG4gICAgICAgICAgICBBTFRFUiBUQUJMRSBcImV2ZW50X3RyaWdnZXJfZW50aXR5XCIgRFJPUCBDT0xVTU4gXCJzcGVuZFR4SWRcIlxuICAgICAgICBgKTtcbiAgICBhd2FpdCBxdWVyeVJ1bm5lci5xdWVyeShgXG4gICAgICAgICAgICBBTFRFUiBUQUJMRSBcImV2ZW50X3RyaWdnZXJfZW50aXR5XCJcbiAgICAgICAgICAgIEFERCBcInNwZW5kVHhJZFwiIHRleHRcbiAgICAgICAgYCk7XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgZG93bihxdWVyeVJ1bm5lcjogUXVlcnlSdW5uZXIpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBhd2FpdCBxdWVyeVJ1bm5lci5xdWVyeShgXG4gICAgICAgICAgICBBTFRFUiBUQUJMRSBcImV2ZW50X3RyaWdnZXJfZW50aXR5XCIgRFJPUCBDT0xVTU4gXCJzcGVuZFR4SWRcIlxuICAgICAgICBgKTtcbiAgICBhd2FpdCBxdWVyeVJ1bm5lci5xdWVyeShgXG4gICAgICAgICAgICBBTFRFUiBUQUJMRSBcImV2ZW50X3RyaWdnZXJfZW50aXR5XCJcbiAgICAgICAgICAgIEFERCBcInNwZW5kVHhJZFwiIGNoYXJhY3RlciB2YXJ5aW5nXG4gICAgICAgIGApO1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIEFMVEVSIFRBQkxFIFwiZXZlbnRfdHJpZ2dlcl9lbnRpdHlcIiBEUk9QIENPTFVNTiBcInBheW1lbnRUeElkXCJcbiAgICAgICAgYCk7XG4gICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgQUxURVIgVEFCTEUgXCJldmVudF90cmlnZ2VyX2VudGl0eVwiIERST1AgQ09MVU1OIFwicmVzdWx0XCJcbiAgICAgICAgYCk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { MigrationInterface, QueryRunner } from 'typeorm';
|
|
2
|
+
export declare class migration1699872205117 implements MigrationInterface {
|
|
3
|
+
name: string;
|
|
4
|
+
up(queryRunner: QueryRunner): Promise<void>;
|
|
5
|
+
down(queryRunner: QueryRunner): Promise<void>;
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=1699872205117-migration.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"1699872205117-migration.d.ts","sourceRoot":"","sources":["../../../lib/migrations/sqlite/1699872205117-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;IAkG3C,IAAI,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;CA2F3D"}
|
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
export class migration1699872205117 {
|
|
2
|
+
name = 'migration1699872205117';
|
|
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" text,
|
|
30
|
+
"result" text,
|
|
31
|
+
"paymentTxId" text,
|
|
32
|
+
CONSTRAINT "UQ_c905f221a1b6271ca4405dbbe5f" UNIQUE ("boxId", "extractor")
|
|
33
|
+
)
|
|
34
|
+
`);
|
|
35
|
+
await queryRunner.query(`
|
|
36
|
+
INSERT INTO "temporary_event_trigger_entity"(
|
|
37
|
+
"id",
|
|
38
|
+
"eventId",
|
|
39
|
+
"txId",
|
|
40
|
+
"extractor",
|
|
41
|
+
"boxId",
|
|
42
|
+
"boxSerialized",
|
|
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
|
+
"WIDs",
|
|
58
|
+
"spendBlock",
|
|
59
|
+
"spendHeight",
|
|
60
|
+
"spendTxId",
|
|
61
|
+
"result",
|
|
62
|
+
"paymentTxId"
|
|
63
|
+
)
|
|
64
|
+
SELECT "id",
|
|
65
|
+
"eventId",
|
|
66
|
+
"txId",
|
|
67
|
+
"extractor",
|
|
68
|
+
"boxId",
|
|
69
|
+
"boxSerialized",
|
|
70
|
+
"block",
|
|
71
|
+
"height",
|
|
72
|
+
"fromChain",
|
|
73
|
+
"toChain",
|
|
74
|
+
"fromAddress",
|
|
75
|
+
"toAddress",
|
|
76
|
+
"amount",
|
|
77
|
+
"bridgeFee",
|
|
78
|
+
"networkFee",
|
|
79
|
+
"sourceChainTokenId",
|
|
80
|
+
"sourceChainHeight",
|
|
81
|
+
"targetChainTokenId",
|
|
82
|
+
"sourceTxId",
|
|
83
|
+
"sourceBlockId",
|
|
84
|
+
"WIDs",
|
|
85
|
+
"spendBlock",
|
|
86
|
+
"spendHeight",
|
|
87
|
+
"spendTxId",
|
|
88
|
+
"result",
|
|
89
|
+
"paymentTxId"
|
|
90
|
+
FROM "event_trigger_entity"
|
|
91
|
+
`);
|
|
92
|
+
await queryRunner.query(`
|
|
93
|
+
DROP TABLE "event_trigger_entity"
|
|
94
|
+
`);
|
|
95
|
+
await queryRunner.query(`
|
|
96
|
+
ALTER TABLE "temporary_event_trigger_entity"
|
|
97
|
+
RENAME TO "event_trigger_entity"
|
|
98
|
+
`);
|
|
99
|
+
}
|
|
100
|
+
async down(queryRunner) {
|
|
101
|
+
await queryRunner.query(`
|
|
102
|
+
ALTER TABLE "event_trigger_entity"
|
|
103
|
+
RENAME TO "temporary_event_trigger_entity"
|
|
104
|
+
`);
|
|
105
|
+
await queryRunner.query(`
|
|
106
|
+
CREATE TABLE "event_trigger_entity" (
|
|
107
|
+
"id" integer PRIMARY KEY AUTOINCREMENT NOT NULL,
|
|
108
|
+
"eventId" varchar NOT NULL DEFAULT ('Not-set'),
|
|
109
|
+
"txId" varchar NOT NULL,
|
|
110
|
+
"extractor" varchar NOT NULL,
|
|
111
|
+
"boxId" varchar NOT NULL,
|
|
112
|
+
"boxSerialized" varchar NOT NULL,
|
|
113
|
+
"block" varchar NOT NULL,
|
|
114
|
+
"height" integer NOT NULL,
|
|
115
|
+
"fromChain" varchar NOT NULL,
|
|
116
|
+
"toChain" varchar NOT NULL,
|
|
117
|
+
"fromAddress" varchar NOT NULL,
|
|
118
|
+
"toAddress" varchar NOT NULL,
|
|
119
|
+
"amount" varchar NOT NULL,
|
|
120
|
+
"bridgeFee" varchar NOT NULL,
|
|
121
|
+
"networkFee" varchar NOT NULL,
|
|
122
|
+
"sourceChainTokenId" varchar NOT NULL,
|
|
123
|
+
"sourceChainHeight" integer NOT NULL,
|
|
124
|
+
"targetChainTokenId" varchar NOT NULL,
|
|
125
|
+
"sourceTxId" varchar NOT NULL,
|
|
126
|
+
"sourceBlockId" varchar NOT NULL,
|
|
127
|
+
"WIDs" varchar NOT NULL,
|
|
128
|
+
"spendBlock" text,
|
|
129
|
+
"spendHeight" integer,
|
|
130
|
+
"spendTxId" varchar,
|
|
131
|
+
CONSTRAINT "UQ_c905f221a1b6271ca4405dbbe5f" UNIQUE ("boxId", "extractor")
|
|
132
|
+
)
|
|
133
|
+
`);
|
|
134
|
+
await queryRunner.query(`
|
|
135
|
+
INSERT INTO "event_trigger_entity"(
|
|
136
|
+
"id",
|
|
137
|
+
"eventId",
|
|
138
|
+
"txId",
|
|
139
|
+
"extractor",
|
|
140
|
+
"boxId",
|
|
141
|
+
"boxSerialized",
|
|
142
|
+
"block",
|
|
143
|
+
"height",
|
|
144
|
+
"fromChain",
|
|
145
|
+
"toChain",
|
|
146
|
+
"fromAddress",
|
|
147
|
+
"toAddress",
|
|
148
|
+
"amount",
|
|
149
|
+
"bridgeFee",
|
|
150
|
+
"networkFee",
|
|
151
|
+
"sourceChainTokenId",
|
|
152
|
+
"sourceChainHeight",
|
|
153
|
+
"targetChainTokenId",
|
|
154
|
+
"sourceTxId",
|
|
155
|
+
"sourceBlockId",
|
|
156
|
+
"WIDs",
|
|
157
|
+
"spendBlock",
|
|
158
|
+
"spendHeight",
|
|
159
|
+
"spendTxId"
|
|
160
|
+
)
|
|
161
|
+
SELECT "id",
|
|
162
|
+
"eventId",
|
|
163
|
+
"txId",
|
|
164
|
+
"extractor",
|
|
165
|
+
"boxId",
|
|
166
|
+
"boxSerialized",
|
|
167
|
+
"block",
|
|
168
|
+
"height",
|
|
169
|
+
"fromChain",
|
|
170
|
+
"toChain",
|
|
171
|
+
"fromAddress",
|
|
172
|
+
"toAddress",
|
|
173
|
+
"amount",
|
|
174
|
+
"bridgeFee",
|
|
175
|
+
"networkFee",
|
|
176
|
+
"sourceChainTokenId",
|
|
177
|
+
"sourceChainHeight",
|
|
178
|
+
"targetChainTokenId",
|
|
179
|
+
"sourceTxId",
|
|
180
|
+
"sourceBlockId",
|
|
181
|
+
"WIDs",
|
|
182
|
+
"spendBlock",
|
|
183
|
+
"spendHeight",
|
|
184
|
+
"spendTxId"
|
|
185
|
+
FROM "temporary_event_trigger_entity"
|
|
186
|
+
`);
|
|
187
|
+
await queryRunner.query(`
|
|
188
|
+
DROP TABLE "temporary_event_trigger_entity"
|
|
189
|
+
`);
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"1699872205117-migration.js","sourceRoot":"","sources":["../../../lib/migrations/sqlite/1699872205117-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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA8BnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SAwDnB,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;;;;;;;;;;;;;;;;;;;;;;;;;;;;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 migration1699872205117 implements MigrationInterface {\n  name = 'migration1699872205117';\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\" text,\n                \"result\" text,\n                \"paymentTxId\" text,\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                    \"result\",\n                    \"paymentTxId\"\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                \"result\",\n                \"paymentTxId\"\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                \"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 \"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"]}
|
package/dist/types.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../lib/types.ts"],"names":[],"mappings":"AAAA,oBAAY,WAAW;IACrB,OAAO,YAAY;IACnB,KAAK,UAAU;IACf,UAAU,eAAe;CAC1B"}
|
package/dist/types.js
ADDED
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export var EventResult;
|
|
2
|
+
(function (EventResult) {
|
|
3
|
+
EventResult["unknown"] = "unknown";
|
|
4
|
+
EventResult["fraud"] = "fraud";
|
|
5
|
+
EventResult["successful"] = "successful";
|
|
6
|
+
})(EventResult || (EventResult = {}));
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9saWIvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksV0FJWDtBQUpELFdBQVksV0FBVztJQUNyQixrQ0FBbUIsQ0FBQTtJQUNuQiw4QkFBZSxDQUFBO0lBQ2Ysd0NBQXlCLENBQUE7QUFDM0IsQ0FBQyxFQUpXLFdBQVcsS0FBWCxXQUFXLFFBSXRCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gRXZlbnRSZXN1bHQge1xuICB1bmtub3duID0gJ3Vua25vd24nLFxuICBmcmF1ZCA9ICdmcmF1ZCcsXG4gIHN1Y2Nlc3NmdWwgPSAnc3VjY2Vzc2Z1bCcsXG59XG4iXX0=
|