@rosen-bridge/watcher-data-extractor 12.0.0 → 12.1.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.
@@ -1,6 +1,7 @@
1
1
  import { DataSource } from 'typeorm';
2
2
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
3
- import { AbstractInitializableErgoExtractorAction, BlockInfo, BoxInfo, SpendInfo } from '@rosen-bridge/abstract-extractor';
3
+ import { AbstractInitializableErgoExtractorAction, BoxInfo, SpendInfo } from '@rosen-bridge/abstract-extractor';
4
+ import { BlockInfo } from '@rosen-bridge/scanner-interfaces';
4
5
  import EventTriggerEntity from '../entities/EventTriggerEntity';
5
6
  import { ExtractedEventTrigger } from '../interfaces/extractedEventTrigger';
6
7
  declare class EventTriggerAction extends AbstractInitializableErgoExtractorAction<ExtractedEventTrigger, EventTriggerEntity> {
@@ -1 +1 @@
1
- {"version":3,"file":"EventTriggerAction.d.ts","sourceRoot":"","sources":["../../lib/actions/EventTriggerAction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAM,MAAM,SAAS,CAAC;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EACL,wCAAwC,EACxC,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
+ {"version":3,"file":"EventTriggerAction.d.ts","sourceRoot":"","sources":["../../lib/actions/EventTriggerAction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAM,MAAM,SAAS,CAAC;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EACL,wCAAwC,EACxC,OAAO,EAEP,SAAS,EACV,MAAM,kCAAkC,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,kCAAkC,CAAC;AAE7D,OAAO,kBAAkB,MAAM,gCAAgC,CAAC;AAChE,OAAO,EAAE,qBAAqB,EAAE,MAAM,qCAAqC,CAAC;AAI5E,cAAM,kBAAmB,SAAQ,wCAAwC,CACvE,qBAAqB,EACrB,kBAAkB,CACnB;IACC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;gBAE5B,UAAU,EAAE,UAAU,EAAE,MAAM,CAAC,EAAE,cAAc;IAK3D;;OAEG;IACH,YAAY,iBACI,qBAAqB,EAAE,SAC9B,SAAS,aACL,MAAM,KAChB,KAAK,kBAAkB,EAAE,IAAI,CAAC,EAAE,CAwBjC;IAEF;;OAEG;IACH,mBAAmB,aACP,kBAAkB,EAAE,KAC7B,qBAAqB,EAAE,CAuBxB;IAEF;;;;;;;;OAQG;IACH,UAAU,mBACQ,MAAM,SAAS,CAAC,SACzB,SAAS,eACH,MAAM,KAClB,QAAQ,OAAO,EAAE,CAAC,CA4CnB;CACH;AAED,eAAe,kBAAkB,CAAC"}
@@ -81,15 +81,18 @@ class EventTriggerAction extends AbstractInitializableErgoExtractorAction {
81
81
  });
82
82
  for (const spentTrigger of spentTriggers) {
83
83
  const spendInfo = spendInfoChunk.find((info) => info.boxId === spentTrigger.boxId);
84
- if (!spendInfo || !spendInfo.extras || spendInfo.extras.length < 2) {
84
+ if (!spendInfo ||
85
+ !spendInfo.extras ||
86
+ !spendInfo.extras.result ||
87
+ !spendInfo.extras.paymentTxId) {
85
88
  throw Error(`Impossible case: spending information extras does not contain result or paymentTxId, ${spendInfo}`);
86
89
  }
87
90
  await this.repository.update({ boxId: spendInfo.boxId, extractor: extractorId }, {
88
91
  spendBlock: block.hash,
89
92
  spendHeight: block.height,
90
93
  spendTxId: spendInfo.txId,
91
- result: spendInfo.extras[0],
92
- paymentTxId: spendInfo.extras[1],
94
+ result: spendInfo.extras.result,
95
+ paymentTxId: spendInfo.extras.paymentTxId,
93
96
  });
94
97
  spentData.push(pick(spendInfo, ['boxId']));
95
98
  this.logger.info(`Spent trigger [${spentTrigger.boxId}] of event [${spentTrigger.eventId}] at height ${block.height}`);
@@ -100,4 +103,4 @@ class EventTriggerAction extends AbstractInitializableErgoExtractorAction {
100
103
  };
101
104
  }
102
105
  export default EventTriggerAction;
103
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"EventTriggerAction.js","sourceRoot":"","sources":["../../lib/actions/EventTriggerAction.ts"],"names":[],"mappings":"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","sourcesContent":["import { DataSource, In } from 'typeorm';\nimport { AbstractLogger } from '@rosen-bridge/abstract-logger';\nimport {\n  AbstractInitializableErgoExtractorAction,\n  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"]}
106
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"EventTriggerAction.js","sourceRoot":"","sources":["../../lib/actions/EventTriggerAction.ts"],"names":[],"mappings":"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","sourcesContent":["import { DataSource, In } from 'typeorm';\nimport { AbstractLogger } from '@rosen-bridge/abstract-logger';\nimport {\n  AbstractInitializableErgoExtractorAction,\n  BoxInfo,\n  DB_CHUNK_SIZE,\n  SpendInfo,\n} from '@rosen-bridge/abstract-extractor';\nimport { BlockInfo } from '@rosen-bridge/scanner-interfaces';\n\nimport EventTriggerEntity from '../entities/EventTriggerEntity';\nimport { ExtractedEventTrigger } from '../interfaces/extractedEventTrigger';\nimport { JsonBI } from '../utils';\nimport { chunk, pick } from 'lodash-es';\n\nclass EventTriggerAction extends AbstractInitializableErgoExtractorAction<\n  ExtractedEventTrigger,\n  EventTriggerEntity\n> {\n  private readonly dataSource: DataSource;\n\n  constructor(dataSource: DataSource, logger?: AbstractLogger) {\n    super(dataSource, EventTriggerEntity, logger);\n    this.dataSource = dataSource;\n  }\n\n  /**\n   * create the box entity from extracted data and block information\n   */\n  createEntity = (\n    triggerBoxes: ExtractedEventTrigger[],\n    block: BlockInfo,\n    extractor: string\n  ): Omit<EventTriggerEntity, 'id'>[] => {\n    return triggerBoxes.map((trigger) => ({\n      txId: trigger.txId,\n      eventId: trigger.eventId,\n      boxId: trigger.boxId,\n      serialized: trigger.serialized,\n      block: block.hash,\n      height: block.height,\n      extractor: extractor,\n      WIDsCount: trigger.WIDsCount,\n      WIDsHash: trigger.WIDsHash,\n      amount: trigger.amount,\n      bridgeFee: trigger.bridgeFee,\n      fromAddress: trigger.fromAddress,\n      toAddress: trigger.toAddress,\n      fromChain: trigger.fromChain,\n      networkFee: trigger.networkFee,\n      sourceChainTokenId: trigger.sourceChainTokenId,\n      targetChainTokenId: trigger.targetChainTokenId,\n      sourceBlockId: trigger.sourceBlockId,\n      toChain: trigger.toChain,\n      sourceTxId: trigger.sourceTxId,\n      sourceChainHeight: trigger.sourceChainHeight,\n    }));\n  };\n\n  /**\n   * convert the database entity back to raw data\n   */\n  convertEntityToData = (\n    entities: EventTriggerEntity[]\n  ): ExtractedEventTrigger[] => {\n    return entities.map((data) =>\n      pick(data, [\n        'eventId',\n        'txId',\n        'boxId',\n        'serialized',\n        'fromChain',\n        'toChain',\n        'fromAddress',\n        'toAddress',\n        'amount',\n        'bridgeFee',\n        'networkFee',\n        'sourceChainTokenId',\n        'targetChainTokenId',\n        'sourceBlockId',\n        'sourceTxId',\n        'WIDsCount',\n        'WIDsHash',\n        'sourceChainHeight',\n      ])\n    );\n  };\n\n  /**\n   * update spending information of stored event triggers\n   * and set result and paymentTxId of the event\n   * chunk spendInfos to prevent large database queries\n   * @param spendInfArray\n   * @param block\n   * @param extractorId\n   * @returns spent box ids\n   */\n  spendBoxes = async (\n    spendInfoArray: Array<SpendInfo>,\n    block: BlockInfo,\n    extractorId: string\n  ): Promise<BoxInfo[]> => {\n    const spentData = [];\n    const spendInfoChunks = chunk(spendInfoArray, DB_CHUNK_SIZE);\n    for (const spendInfoChunk of spendInfoChunks) {\n      const spentTriggers = await this.repository.findBy({\n        boxId: In(spendInfoChunk.map((spendInfo) => spendInfo.boxId)),\n        extractor: extractorId,\n      });\n      for (const spentTrigger of spentTriggers) {\n        const spendInfo = spendInfoChunk.find(\n          (info) => info.boxId === spentTrigger.boxId\n        );\n        if (\n          !spendInfo ||\n          !spendInfo.extras ||\n          !spendInfo.extras.result ||\n          !spendInfo.extras.paymentTxId\n        ) {\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.result,\n            paymentTxId: spendInfo.extras.paymentTxId,\n          }\n        );\n        spentData.push(pick(spendInfo, ['boxId']));\n        this.logger.info(\n          `Spent trigger [${spentTrigger.boxId}] of event [${spentTrigger.eventId}] at height ${block.height}`\n        );\n        this.logger.debug(\n          `Spent trigger: [${JSON.stringify(\n            spentTrigger\n          )}] with spending information [${JsonBI.stringify(spendInfo)}]`\n        );\n      }\n    }\n    return spentData;\n  };\n}\n\nexport default EventTriggerAction;\n"]}
@@ -1,6 +1,6 @@
1
1
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
2
2
  import { DataSource, DeleteResult } from 'typeorm';
3
- import { Block } from '@rosen-bridge/abstract-extractor';
3
+ import { Block } from '@rosen-bridge/scanner-interfaces';
4
4
  import { ExtractedCollateral } from '../interfaces/extractedCollateral';
5
5
  import { SpendInfo } from '../interfaces/types';
6
6
  declare class CollateralAction {
@@ -191,4 +191,4 @@ class CollateralAction {
191
191
  };
192
192
  }
193
193
  export default CollateralAction;
194
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collateralAction.js","sourceRoot":"","sources":["../../lib/actions/collateralAction.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport JsonBigInt from '@rosen-bridge/json-bigint';\nimport { difference } from 'lodash-es';\nimport { DataSource, DeleteResult, In, IsNull, Repository } from 'typeorm';\nimport { Block } from '@rosen-bridge/abstract-extractor';\n\nimport CollateralEntity from '../entities/CollateralEntity';\nimport { ExtractedCollateral } from '../interfaces/extractedCollateral';\nimport { SpendInfo } from '../interfaces/types';\n\nclass CollateralAction {\n  private readonly collateralRepository: Repository<CollateralEntity>;\n\n  constructor(\n    private readonly dataSource: DataSource,\n    readonly logger: AbstractLogger = new DummyLogger()\n  ) {\n    this.collateralRepository = this.dataSource.getRepository(CollateralEntity);\n  }\n\n  /**\n   * inserts a collateral into the database\n   *\n   * @param {ExtractedCollateral} collateral\n   * @param {string} extractor\n   * @memberof CollateralAction\n   */\n  insertCollateral = async (\n    collateral: ExtractedCollateral,\n    extractor: string\n  ) => {\n    return await this.collateralRepository.insert({\n      ...collateral,\n      extractor,\n    });\n  };\n\n  /**\n   * updates a collateral into the database\n   *\n   * @param {ExtractedCollateral} collateral\n   * @param {string} extractor\n   * @memberof CollateralAction\n   */\n  updateCollateral = async (\n    collateral: Partial<ExtractedCollateral> &\n      Pick<ExtractedCollateral, 'boxId'>,\n    extractor: string\n  ) => {\n    return await this.collateralRepository.update(\n      {\n        extractor,\n        boxId: collateral.boxId,\n      },\n      collateral\n    );\n  };\n\n  /**\n   * stores list of collaterals\n   *\n   * @param {Array<ExtractedCollateral>} collaterals\n   * @param {Block} block\n   * @param {string} extractor\n   * @return {Promise<boolean>}\n   * @memberof CollateralAction\n   */\n  storeCollaterals = async (\n    collaterals: Array<ExtractedCollateral>,\n    block: Block,\n    extractor: string\n  ): Promise<boolean> => {\n    if (collaterals.length == 0) {\n      return true;\n    }\n\n    const collateralEntities = collaterals.map((col) => ({\n      extractor: extractor,\n      boxId: col.boxId,\n      boxSerialized: col.boxSerialized,\n      wid: col.wid,\n      rwtCount: col.rwtCount,\n      txId: col.txId,\n      block: block.hash,\n      height: col.height != undefined ? col.height : block.height,\n    }));\n\n    const queryRunner = this.dataSource.createQueryRunner();\n    await queryRunner.connect();\n    await queryRunner.startTransaction();\n    try {\n      const repository = await queryRunner.manager.getRepository(\n        CollateralEntity\n      );\n      const existingBoxIds = (\n        await repository.find({\n          where: {\n            boxId: In(collateralEntities.map((box) => box.boxId)),\n            extractor: extractor,\n          },\n          select: {\n            boxId: true,\n          },\n        })\n      ).map((col) => col.boxId);\n\n      const collateralsToUpdate = collateralEntities.filter((col) =>\n        existingBoxIds.includes(col.boxId)\n      );\n\n      const collateralsToInsert = difference(\n        collateralEntities,\n        collateralsToUpdate\n      );\n\n      if (collateralsToUpdate.length > 0) {\n        this.logger.info(\n          `Inserting boxes with following IDs into the database: [${collateralsToInsert\n            .map((col) => col.boxId)\n            .join(', ')}]`\n        );\n        this.logger.debug(\n          `Inserting collateral boxes [${JsonBigInt.stringify(\n            collateralsToInsert\n          )}]`\n        );\n      }\n      await repository.insert(collateralsToInsert);\n\n      if (collateralsToUpdate.length > 0)\n        this.logger.info(\n          `Updating boxes with following IDs in the database: [${collateralsToUpdate\n            .map((col) => col.boxId)\n            .join(', ')}]`\n        );\n      collateralsToUpdate.forEach(async (collateral) => {\n        this.logger.debug(\n          `Updating collateral box in database [${JsonBigInt.stringify(\n            collateral\n          )}]`\n        );\n        await repository.update(\n          { boxId: collateral.boxId, extractor: extractor },\n          collateral\n        );\n      });\n\n      await queryRunner.commitTransaction();\n    } catch (e) {\n      await queryRunner.rollbackTransaction();\n      this.logger.error(\n        `An error occurred during storeCollaterals action: ${e}`\n      );\n      return false;\n    } finally {\n      await queryRunner.release();\n    }\n\n    return true;\n  };\n\n  /**\n   * Update spendBlock and spendHeight of collaterals spent in the block\n   *\n   * @param {Array<SpendInfo>} spendInfos\n   * @param {Block} block\n   * @param {string} extractor\n   * @return {Promise<void>}\n   * @memberof CollateralAction\n   */\n  spendCollaterals = async (\n    spendInfos: Array<SpendInfo>,\n    block: Block,\n    extractor: string\n  ): Promise<void> => {\n    for (const spendInfo of spendInfos) {\n      const updateResult = await this.collateralRepository.update(\n        {\n          boxId: spendInfo.boxId,\n          extractor: extractor,\n        },\n        {\n          spendBlock: block.hash,\n          spendHeight: block.height,\n          spendTxId: spendInfo.txId,\n        }\n      );\n\n      if (updateResult.affected && updateResult.affected > 0) {\n        const updatedRows = await this.collateralRepository.findBy({\n          boxId: spendInfo.boxId,\n          spendBlock: block.hash,\n        });\n        for (const row of updatedRows) {\n          this.logger.debug(\n            `Spent collateral with boxId [${row.boxId}] belonging to watcher with WID [${row.wid}] at height ${block.height}`\n          );\n        }\n      }\n    }\n  };\n\n  /**\n   * Returns all stored unspent collateral box IDs\n   *\n   * @param {string} extractor\n   * @return {Promise<Array<string>>}\n   * @memberof CollateralAction\n   */\n  getUnspentCollateralBoxIds = async (\n    extractor: string\n  ): Promise<Array<string>> => {\n    const boxIds = await this.collateralRepository.find({\n      where: {\n        extractor: extractor,\n        spendBlock: IsNull(),\n      },\n      select: {\n        boxId: true,\n      },\n    });\n    return boxIds.map((box) => box.boxId);\n  };\n\n  /**\n   * Delete all collaterals corresponding to the passed block and extractor and\n   * update all collaterals spent in the specified block\n   *\n   * @param {string} block\n   * @param {string} extractor\n   * @return {Promise<void>}\n   * @memberof CollateralAction\n   */\n  async deleteBlock(block: string, extractor: string): Promise<void> {\n    this.logger.info(\n      `Deleting collaterals in block=[${block}] and extractor=[${extractor}]`\n    );\n\n    await this.collateralRepository.delete({\n      block: block,\n      extractor: extractor,\n    });\n\n    this.logger.info(\n      `changing spent collaterals in block=[${block}] and extractor=[${extractor}] to unspent status`\n    );\n\n    await this.collateralRepository.update(\n      { spendBlock: block, extractor: extractor },\n      {\n        spendBlock: null,\n        spendHeight: null,\n        spendTxId: null,\n      }\n    );\n  }\n\n  /**\n   * deletes the specified collateral box from database\n   *\n   * @param {string} boxId\n   * @param {string} extractor\n   * @return {Promise<DeleteResult>}\n   * @memberof CollateralAction\n   */\n  deleteCollateral = async (\n    boxId: string,\n    extractor: string\n  ): Promise<DeleteResult> => {\n    return await this.collateralRepository.delete({\n      boxId: boxId,\n      extractor: extractor,\n    });\n  };\n}\n\nexport default CollateralAction;\n"]}
194
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collateralAction.js","sourceRoot":"","sources":["../../lib/actions/collateralAction.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport JsonBigInt from '@rosen-bridge/json-bigint';\nimport { difference } from 'lodash-es';\nimport { DataSource, DeleteResult, In, IsNull, Repository } from 'typeorm';\nimport { Block } from '@rosen-bridge/scanner-interfaces';\n\nimport CollateralEntity from '../entities/CollateralEntity';\nimport { ExtractedCollateral } from '../interfaces/extractedCollateral';\nimport { SpendInfo } from '../interfaces/types';\n\nclass CollateralAction {\n  private readonly collateralRepository: Repository<CollateralEntity>;\n\n  constructor(\n    private readonly dataSource: DataSource,\n    readonly logger: AbstractLogger = new DummyLogger()\n  ) {\n    this.collateralRepository = this.dataSource.getRepository(CollateralEntity);\n  }\n\n  /**\n   * inserts a collateral into the database\n   *\n   * @param {ExtractedCollateral} collateral\n   * @param {string} extractor\n   * @memberof CollateralAction\n   */\n  insertCollateral = async (\n    collateral: ExtractedCollateral,\n    extractor: string\n  ) => {\n    return await this.collateralRepository.insert({\n      ...collateral,\n      extractor,\n    });\n  };\n\n  /**\n   * updates a collateral into the database\n   *\n   * @param {ExtractedCollateral} collateral\n   * @param {string} extractor\n   * @memberof CollateralAction\n   */\n  updateCollateral = async (\n    collateral: Partial<ExtractedCollateral> &\n      Pick<ExtractedCollateral, 'boxId'>,\n    extractor: string\n  ) => {\n    return await this.collateralRepository.update(\n      {\n        extractor,\n        boxId: collateral.boxId,\n      },\n      collateral\n    );\n  };\n\n  /**\n   * stores list of collaterals\n   *\n   * @param {Array<ExtractedCollateral>} collaterals\n   * @param {Block} block\n   * @param {string} extractor\n   * @return {Promise<boolean>}\n   * @memberof CollateralAction\n   */\n  storeCollaterals = async (\n    collaterals: Array<ExtractedCollateral>,\n    block: Block,\n    extractor: string\n  ): Promise<boolean> => {\n    if (collaterals.length == 0) {\n      return true;\n    }\n\n    const collateralEntities = collaterals.map((col) => ({\n      extractor: extractor,\n      boxId: col.boxId,\n      boxSerialized: col.boxSerialized,\n      wid: col.wid,\n      rwtCount: col.rwtCount,\n      txId: col.txId,\n      block: block.hash,\n      height: col.height != undefined ? col.height : block.height,\n    }));\n\n    const queryRunner = this.dataSource.createQueryRunner();\n    await queryRunner.connect();\n    await queryRunner.startTransaction();\n    try {\n      const repository = await queryRunner.manager.getRepository(\n        CollateralEntity\n      );\n      const existingBoxIds = (\n        await repository.find({\n          where: {\n            boxId: In(collateralEntities.map((box) => box.boxId)),\n            extractor: extractor,\n          },\n          select: {\n            boxId: true,\n          },\n        })\n      ).map((col) => col.boxId);\n\n      const collateralsToUpdate = collateralEntities.filter((col) =>\n        existingBoxIds.includes(col.boxId)\n      );\n\n      const collateralsToInsert = difference(\n        collateralEntities,\n        collateralsToUpdate\n      );\n\n      if (collateralsToUpdate.length > 0) {\n        this.logger.info(\n          `Inserting boxes with following IDs into the database: [${collateralsToInsert\n            .map((col) => col.boxId)\n            .join(', ')}]`\n        );\n        this.logger.debug(\n          `Inserting collateral boxes [${JsonBigInt.stringify(\n            collateralsToInsert\n          )}]`\n        );\n      }\n      await repository.insert(collateralsToInsert);\n\n      if (collateralsToUpdate.length > 0)\n        this.logger.info(\n          `Updating boxes with following IDs in the database: [${collateralsToUpdate\n            .map((col) => col.boxId)\n            .join(', ')}]`\n        );\n      collateralsToUpdate.forEach(async (collateral) => {\n        this.logger.debug(\n          `Updating collateral box in database [${JsonBigInt.stringify(\n            collateral\n          )}]`\n        );\n        await repository.update(\n          { boxId: collateral.boxId, extractor: extractor },\n          collateral\n        );\n      });\n\n      await queryRunner.commitTransaction();\n    } catch (e) {\n      await queryRunner.rollbackTransaction();\n      this.logger.error(\n        `An error occurred during storeCollaterals action: ${e}`\n      );\n      return false;\n    } finally {\n      await queryRunner.release();\n    }\n\n    return true;\n  };\n\n  /**\n   * Update spendBlock and spendHeight of collaterals spent in the block\n   *\n   * @param {Array<SpendInfo>} spendInfos\n   * @param {Block} block\n   * @param {string} extractor\n   * @return {Promise<void>}\n   * @memberof CollateralAction\n   */\n  spendCollaterals = async (\n    spendInfos: Array<SpendInfo>,\n    block: Block,\n    extractor: string\n  ): Promise<void> => {\n    for (const spendInfo of spendInfos) {\n      const updateResult = await this.collateralRepository.update(\n        {\n          boxId: spendInfo.boxId,\n          extractor: extractor,\n        },\n        {\n          spendBlock: block.hash,\n          spendHeight: block.height,\n          spendTxId: spendInfo.txId,\n        }\n      );\n\n      if (updateResult.affected && updateResult.affected > 0) {\n        const updatedRows = await this.collateralRepository.findBy({\n          boxId: spendInfo.boxId,\n          spendBlock: block.hash,\n        });\n        for (const row of updatedRows) {\n          this.logger.debug(\n            `Spent collateral with boxId [${row.boxId}] belonging to watcher with WID [${row.wid}] at height ${block.height}`\n          );\n        }\n      }\n    }\n  };\n\n  /**\n   * Returns all stored unspent collateral box IDs\n   *\n   * @param {string} extractor\n   * @return {Promise<Array<string>>}\n   * @memberof CollateralAction\n   */\n  getUnspentCollateralBoxIds = async (\n    extractor: string\n  ): Promise<Array<string>> => {\n    const boxIds = await this.collateralRepository.find({\n      where: {\n        extractor: extractor,\n        spendBlock: IsNull(),\n      },\n      select: {\n        boxId: true,\n      },\n    });\n    return boxIds.map((box) => box.boxId);\n  };\n\n  /**\n   * Delete all collaterals corresponding to the passed block and extractor and\n   * update all collaterals spent in the specified block\n   *\n   * @param {string} block\n   * @param {string} extractor\n   * @return {Promise<void>}\n   * @memberof CollateralAction\n   */\n  async deleteBlock(block: string, extractor: string): Promise<void> {\n    this.logger.info(\n      `Deleting collaterals in block=[${block}] and extractor=[${extractor}]`\n    );\n\n    await this.collateralRepository.delete({\n      block: block,\n      extractor: extractor,\n    });\n\n    this.logger.info(\n      `changing spent collaterals in block=[${block}] and extractor=[${extractor}] to unspent status`\n    );\n\n    await this.collateralRepository.update(\n      { spendBlock: block, extractor: extractor },\n      {\n        spendBlock: null,\n        spendHeight: null,\n        spendTxId: null,\n      }\n    );\n  }\n\n  /**\n   * deletes the specified collateral box from database\n   *\n   * @param {string} boxId\n   * @param {string} extractor\n   * @return {Promise<DeleteResult>}\n   * @memberof CollateralAction\n   */\n  deleteCollateral = async (\n    boxId: string,\n    extractor: string\n  ): Promise<DeleteResult> => {\n    return await this.collateralRepository.delete({\n      boxId: boxId,\n      extractor: extractor,\n    });\n  };\n}\n\nexport default CollateralAction;\n"]}
@@ -1,6 +1,6 @@
1
1
  import { DataSource } from 'typeorm';
2
2
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
3
- import { Block } from '@rosen-bridge/abstract-extractor';
3
+ import { Block } from '@rosen-bridge/scanner-interfaces';
4
4
  import { extractedCommitment } from '../interfaces/extractedCommitment';
5
5
  import { SpendInfo } from '../interfaces/types';
6
6
  declare class CommitmentAction {
@@ -117,4 +117,4 @@ class CommitmentAction {
117
117
  };
118
118
  }
119
119
  export default CommitmentAction;
120
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"commitmentAction.js","sourceRoot":"","sources":["../../lib/actions/commitmentAction.ts"],"names":[],"mappings":"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","sourcesContent":["import { DataSource, In, Repository } from 'typeorm';\nimport { chunk } from 'lodash-es';\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport { Block } from '@rosen-bridge/abstract-extractor';\n\nimport { extractedCommitment } from '../interfaces/extractedCommitment';\nimport CommitmentEntity from '../entities/CommitmentEntity';\nimport { dbIdChunkSize } from '../constants';\nimport { SpendInfo } from '../interfaces/types';\n\nclass CommitmentAction {\n  readonly logger: AbstractLogger;\n  private readonly datasource: DataSource;\n  private readonly commitmentRepository: Repository<CommitmentEntity>;\n\n  constructor(dataSource: DataSource, logger?: AbstractLogger) {\n    this.datasource = dataSource;\n    this.logger = logger ? logger : new DummyLogger();\n    this.commitmentRepository = dataSource.getRepository(CommitmentEntity);\n  }\n\n  /**\n   * It stores list of observations in the dataSource with block id\n   * @param commitments\n   * @param block\n   * @param extractor\n   */\n  storeCommitments = async (\n    commitments: Array<extractedCommitment>,\n    block: Block,\n    extractor: string\n  ): Promise<boolean> => {\n    if (commitments.length === 0) return true;\n    const boxIds = commitments.map((commitment) => commitment.boxId);\n    const savedCommitments = await this.commitmentRepository.findBy({\n      boxId: In(boxIds),\n      extractor: extractor,\n    });\n    let success = true;\n    const queryRunner = this.datasource.createQueryRunner();\n    await queryRunner.connect();\n    await queryRunner.startTransaction();\n    const repository = await queryRunner.manager.getRepository(\n      CommitmentEntity\n    );\n    try {\n      for (const commitment of commitments) {\n        const saved = savedCommitments.some((entity) => {\n          return entity.boxId === commitment.boxId;\n        });\n        const entity = {\n          txId: commitment.txId,\n          commitment: commitment.commitment,\n          eventId: commitment.eventId,\n          boxId: commitment.boxId,\n          WID: commitment.WID,\n          extractor: extractor,\n          block: block.hash,\n          height: block.height,\n          boxSerialized: commitment.boxSerialized,\n          rwtCount: commitment.rwtCount,\n        };\n        if (!saved) {\n          this.logger.info(\n            `Saving commitment [${commitment.boxId}] for event [${commitment.eventId}] from watcher [${commitment.WID}] at height ${block.height} and extractor ${extractor}`\n          );\n          await repository.insert(entity);\n        } else {\n          this.logger.info(\n            `Updating commitment [${commitment.boxId}] for event [${commitment.eventId}] from watcher [${commitment.WID}] at height ${block.height} and extractor ${extractor}`\n          );\n          await repository.update({ boxId: commitment.boxId }, entity);\n        }\n        this.logger.debug(`Entity: ${JSON.stringify(entity)}`);\n      }\n      await queryRunner.commitTransaction();\n    } catch (e) {\n      this.logger.error(\n        `An error occurred during store commitments action: ${e}`\n      );\n      await queryRunner.rollbackTransaction();\n      success = false;\n    } finally {\n      await queryRunner.release();\n    }\n    return success;\n  };\n\n  /**\n   * Update spendBlock and spendHeight of commitments spent on the block\n   * @param spendId\n   * @param block\n   * @param extractor\n   */\n  spendCommitments = async (\n    spendId: Array<SpendInfo>,\n    block: Block,\n    extractor: string\n  ): Promise<void> => {\n    // TODO: improve updating (local:ergo/rosen-bridge/scanner#85)\n    const spendIdChunks = chunk(spendId, dbIdChunkSize);\n    for (const spendIdChunk of spendIdChunks) {\n      const commitments = await this.commitmentRepository.findBy({\n        boxId: In(spendIdChunk.map((info) => info.boxId)),\n        extractor: extractor,\n      });\n\n      for (const commitment of commitments) {\n        const spendInfo = spendIdChunk.find(\n          (info) => info.boxId === commitment.boxId\n        );\n        if (!spendInfo)\n          throw new Error(\n            `Impossible behavior: box [${commitment.boxId}] is not found in spending info list`\n          );\n\n        await this.commitmentRepository.update(\n          {\n            id: commitment.id,\n          },\n          {\n            spendBlock: block.hash,\n            spendHeight: block.height,\n            spendTxId: spendInfo.txId,\n            spendIndex: spendInfo.index,\n          }\n        );\n        this.logger.info(\n          `Spent commitment [${commitment.boxId}] for event [${commitment.eventId}] at height ${block.height}`\n        );\n        this.logger.debug(`Spent commitment [${JSON.stringify(commitment)}]`);\n      }\n    }\n  };\n\n  /**\n   * Delete all commitments corresponding to the block(id) and extractor(id)\n   * and update all commitments spent on the specified block\n   * @param block\n   * @param extractor\n   */\n  deleteBlock = async (block: string, extractor: string) => {\n    this.logger.info(\n      `Deleting commitments of block [${block}] and extractor ${extractor}`\n    );\n    await this.commitmentRepository.delete({\n      block: block,\n      extractor: extractor,\n    });\n    await this.commitmentRepository.update(\n      { spendBlock: block, extractor: extractor },\n      { spendBlock: null, spendHeight: null, spendTxId: null, spendIndex: null }\n    );\n  };\n}\n\nexport default CommitmentAction;\n"]}
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"commitmentAction.js","sourceRoot":"","sources":["../../lib/actions/commitmentAction.ts"],"names":[],"mappings":"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","sourcesContent":["import { DataSource, In, Repository } from 'typeorm';\nimport { chunk } from 'lodash-es';\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport { Block } from '@rosen-bridge/scanner-interfaces';\n\nimport { extractedCommitment } from '../interfaces/extractedCommitment';\nimport CommitmentEntity from '../entities/CommitmentEntity';\nimport { dbIdChunkSize } from '../constants';\nimport { SpendInfo } from '../interfaces/types';\n\nclass CommitmentAction {\n  readonly logger: AbstractLogger;\n  private readonly datasource: DataSource;\n  private readonly commitmentRepository: Repository<CommitmentEntity>;\n\n  constructor(dataSource: DataSource, logger?: AbstractLogger) {\n    this.datasource = dataSource;\n    this.logger = logger ? logger : new DummyLogger();\n    this.commitmentRepository = dataSource.getRepository(CommitmentEntity);\n  }\n\n  /**\n   * It stores list of observations in the dataSource with block id\n   * @param commitments\n   * @param block\n   * @param extractor\n   */\n  storeCommitments = async (\n    commitments: Array<extractedCommitment>,\n    block: Block,\n    extractor: string\n  ): Promise<boolean> => {\n    if (commitments.length === 0) return true;\n    const boxIds = commitments.map((commitment) => commitment.boxId);\n    const savedCommitments = await this.commitmentRepository.findBy({\n      boxId: In(boxIds),\n      extractor: extractor,\n    });\n    let success = true;\n    const queryRunner = this.datasource.createQueryRunner();\n    await queryRunner.connect();\n    await queryRunner.startTransaction();\n    const repository = await queryRunner.manager.getRepository(\n      CommitmentEntity\n    );\n    try {\n      for (const commitment of commitments) {\n        const saved = savedCommitments.some((entity) => {\n          return entity.boxId === commitment.boxId;\n        });\n        const entity = {\n          txId: commitment.txId,\n          commitment: commitment.commitment,\n          eventId: commitment.eventId,\n          boxId: commitment.boxId,\n          WID: commitment.WID,\n          extractor: extractor,\n          block: block.hash,\n          height: block.height,\n          boxSerialized: commitment.boxSerialized,\n          rwtCount: commitment.rwtCount,\n        };\n        if (!saved) {\n          this.logger.info(\n            `Saving commitment [${commitment.boxId}] for event [${commitment.eventId}] from watcher [${commitment.WID}] at height ${block.height} and extractor ${extractor}`\n          );\n          await repository.insert(entity);\n        } else {\n          this.logger.info(\n            `Updating commitment [${commitment.boxId}] for event [${commitment.eventId}] from watcher [${commitment.WID}] at height ${block.height} and extractor ${extractor}`\n          );\n          await repository.update({ boxId: commitment.boxId }, entity);\n        }\n        this.logger.debug(`Entity: ${JSON.stringify(entity)}`);\n      }\n      await queryRunner.commitTransaction();\n    } catch (e) {\n      this.logger.error(\n        `An error occurred during store commitments action: ${e}`\n      );\n      await queryRunner.rollbackTransaction();\n      success = false;\n    } finally {\n      await queryRunner.release();\n    }\n    return success;\n  };\n\n  /**\n   * Update spendBlock and spendHeight of commitments spent on the block\n   * @param spendId\n   * @param block\n   * @param extractor\n   */\n  spendCommitments = async (\n    spendId: Array<SpendInfo>,\n    block: Block,\n    extractor: string\n  ): Promise<void> => {\n    // TODO: improve updating (local:ergo/rosen-bridge/scanner#85)\n    const spendIdChunks = chunk(spendId, dbIdChunkSize);\n    for (const spendIdChunk of spendIdChunks) {\n      const commitments = await this.commitmentRepository.findBy({\n        boxId: In(spendIdChunk.map((info) => info.boxId)),\n        extractor: extractor,\n      });\n\n      for (const commitment of commitments) {\n        const spendInfo = spendIdChunk.find(\n          (info) => info.boxId === commitment.boxId\n        );\n        if (!spendInfo)\n          throw new Error(\n            `Impossible behavior: box [${commitment.boxId}] is not found in spending info list`\n          );\n\n        await this.commitmentRepository.update(\n          {\n            id: commitment.id,\n          },\n          {\n            spendBlock: block.hash,\n            spendHeight: block.height,\n            spendTxId: spendInfo.txId,\n            spendIndex: spendInfo.index,\n          }\n        );\n        this.logger.info(\n          `Spent commitment [${commitment.boxId}] for event [${commitment.eventId}] at height ${block.height}`\n        );\n        this.logger.debug(`Spent commitment [${JSON.stringify(commitment)}]`);\n      }\n    }\n  };\n\n  /**\n   * Delete all commitments corresponding to the block(id) and extractor(id)\n   * and update all commitments spent on the specified block\n   * @param block\n   * @param extractor\n   */\n  deleteBlock = async (block: string, extractor: string) => {\n    this.logger.info(\n      `Deleting commitments of block [${block}] and extractor ${extractor}`\n    );\n    await this.commitmentRepository.delete({\n      block: block,\n      extractor: extractor,\n    });\n    await this.commitmentRepository.update(\n      { spendBlock: block, extractor: extractor },\n      { spendBlock: null, spendHeight: null, spendTxId: null, spendIndex: null }\n    );\n  };\n}\n\nexport default CommitmentAction;\n"]}
@@ -1,6 +1,6 @@
1
1
  import { DataSource } from 'typeorm';
2
2
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
3
- import { Block } from '@rosen-bridge/abstract-extractor';
3
+ import { Block } from '@rosen-bridge/scanner-interfaces';
4
4
  import { ExtractedPermit } from '../interfaces/extractedPermit';
5
5
  declare class PermitAction {
6
6
  readonly logger: AbstractLogger;
@@ -171,4 +171,4 @@ class PermitAction {
171
171
  };
172
172
  }
173
173
  export default PermitAction;
174
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"permitAction.js","sourceRoot":"","sources":["../../lib/actions/permitAction.ts"],"names":[],"mappings":"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","sourcesContent":["import { DataSource, In, Repository } from 'typeorm';\nimport { chunk } from 'lodash-es';\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport { Block } from '@rosen-bridge/abstract-extractor';\n\nimport { ExtractedPermit } from '../interfaces/extractedPermit';\nimport PermitEntity from '../entities/PermitEntity';\nimport { dbIdChunkSize } from '../constants';\n\nclass PermitAction {\n  readonly logger: AbstractLogger;\n  private readonly datasource: DataSource;\n  private readonly permitRepository: Repository<PermitEntity>;\n\n  constructor(dataSource: DataSource, logger?: AbstractLogger) {\n    this.datasource = dataSource;\n    this.logger = logger ? logger : new DummyLogger();\n    this.permitRepository = dataSource.getRepository(PermitEntity);\n  }\n\n  /**\n   * insert a new permit boxes in the database\n   * @param permits\n   * @param initialHeight\n   * @param extractor\n   */\n  insertPermit = async (permit: ExtractedPermit, extractor: string) => {\n    return this.permitRepository.insert({\n      boxId: permit.boxId,\n      boxSerialized: permit.boxSerialized,\n      block: permit.block,\n      height: permit.height,\n      extractor: extractor,\n      WID: permit.WID,\n      txId: permit.txId,\n      spendBlock: permit.spendBlock,\n      spendHeight: permit.spendHeight,\n    });\n  };\n\n  /**\n   * update an unspent permit in the database\n   * @param permit\n   * @param extractor\n   */\n  updatePermit = async (permit: ExtractedPermit, extractor: string) => {\n    await this.permitRepository.update(\n      { boxId: permit.boxId, extractor: extractor },\n      {\n        boxSerialized: permit.boxSerialized,\n        block: permit.block,\n        height: permit.height,\n        WID: permit.WID,\n        txId: permit.txId,\n        spendBlock: null,\n        spendHeight: null,\n      }\n    );\n  };\n\n  /**\n   * It stores list of permits in the dataSource with block id\n   * @param permits\n   * @param block\n   * @param extractor\n   */\n  storePermits = async (\n    permits: Array<ExtractedPermit>,\n    block: Block,\n    extractor: string\n  ) => {\n    if (permits.length === 0) return true;\n    const boxIds = permits.map((permit) => permit.boxId);\n    const savedPermits = await this.permitRepository.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(PermitEntity);\n    try {\n      for (const permit of permits) {\n        const saved = savedPermits.some((entity) => {\n          return entity.boxId === permit.boxId;\n        });\n        const entity = {\n          boxId: permit.boxId,\n          boxSerialized: permit.boxSerialized,\n          block: block.hash,\n          height: block.height,\n          extractor: extractor,\n          WID: permit.WID,\n          txId: permit.txId,\n        };\n        if (!saved) {\n          this.logger.debug(\n            `Saving permit [${permit.boxId}] belonging to watcher [${permit.WID}] at height ${block.height} and extractor ${extractor}`\n          );\n          await repository.insert(entity);\n        } else {\n          this.logger.debug(\n            `Updating permit [${permit.boxId}] belonging to watcher [${permit.WID}] at height ${block.height} and extractor ${extractor}`\n          );\n          await repository.update({ boxId: permit.boxId }, entity);\n        }\n        this.logger.debug(`Entity: ${JSON.stringify(entity)}`);\n      }\n      await queryRunner.commitTransaction();\n    } catch (e) {\n      this.logger.error(`An error occurred during store permit action: ${e}`);\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 permits spent on the block\n   * @param spendId\n   * @param block\n   * @param extractor\n   */\n  spendPermits = async (\n    spendId: Array<string>,\n    block: Block,\n    extractor: string\n  ): Promise<void> => {\n    const spendIdChunks = chunk(spendId, dbIdChunkSize);\n    for (const spendIdChunk of spendIdChunks) {\n      const updateResult = await this.permitRepository.update(\n        { boxId: In(spendIdChunk), extractor: extractor },\n        { spendBlock: block.hash, spendHeight: block.height }\n      );\n\n      if (updateResult.affected && updateResult.affected > 0) {\n        const spentRows = await this.permitRepository.findBy({\n          boxId: In(spendIdChunk),\n          spendBlock: block.hash,\n        });\n        for (const row of spentRows) {\n          this.logger.debug(\n            `Spent permit with boxId [${row.boxId}] belonging to watcher with WID [${row.WID}] at height ${block.height}`\n          );\n        }\n      }\n    }\n  };\n\n  /**\n   * Delete all permits corresponding to the block(id) and extractor(id)\n   * and update all permits spent on the specified block\n   * @param block\n   * @param extractor\n   */\n  deleteBlock = async (block: string, extractor: string): Promise<void> => {\n    this.logger.info(\n      `Deleting permits at block ${block} and extractor ${extractor}`\n    );\n    await this.permitRepository.delete({ block: block, extractor: extractor });\n    await this.permitRepository.update(\n      { spendBlock: block, extractor: extractor },\n      { spendBlock: null, spendHeight: null }\n    );\n  };\n\n  /**\n   *  Returns all stored permit box ids\n   */\n  getAllPermitBoxIds = async (extractor: string): Promise<Array<string>> => {\n    const boxIds = await this.permitRepository.find({\n      where: {\n        extractor: extractor,\n      },\n      select: {\n        boxId: true,\n      },\n    });\n    return boxIds.map((item: { boxId: string }) => item.boxId);\n  };\n\n  /**\n   * Removes specified permit\n   * @param boxId\n   * @param extractor\n   */\n  removePermit = async (boxId: string, extractor: string) => {\n    return await this.permitRepository.delete({\n      boxId: boxId,\n      extractor: extractor,\n    });\n  };\n\n  /**\n   * Update the permit spending information\n   * @param boxId\n   * @param extractor\n   * @param blockId\n   * @param blockHeight\n   */\n  updateSpendBlock = async (\n    boxId: string,\n    extractor: string,\n    blockId: string,\n    blockHeight: number\n  ) => {\n    return await this.permitRepository.update(\n      { boxId: boxId, extractor: extractor },\n      { spendBlock: blockId, spendHeight: blockHeight }\n    );\n  };\n}\n\nexport default PermitAction;\n"]}
174
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"permitAction.js","sourceRoot":"","sources":["../../lib/actions/permitAction.ts"],"names":[],"mappings":"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","sourcesContent":["import { DataSource, In, Repository } from 'typeorm';\nimport { chunk } from 'lodash-es';\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport { Block } from '@rosen-bridge/scanner-interfaces';\n\nimport { ExtractedPermit } from '../interfaces/extractedPermit';\nimport PermitEntity from '../entities/PermitEntity';\nimport { dbIdChunkSize } from '../constants';\n\nclass PermitAction {\n  readonly logger: AbstractLogger;\n  private readonly datasource: DataSource;\n  private readonly permitRepository: Repository<PermitEntity>;\n\n  constructor(dataSource: DataSource, logger?: AbstractLogger) {\n    this.datasource = dataSource;\n    this.logger = logger ? logger : new DummyLogger();\n    this.permitRepository = dataSource.getRepository(PermitEntity);\n  }\n\n  /**\n   * insert a new permit boxes in the database\n   * @param permits\n   * @param initialHeight\n   * @param extractor\n   */\n  insertPermit = async (permit: ExtractedPermit, extractor: string) => {\n    return this.permitRepository.insert({\n      boxId: permit.boxId,\n      boxSerialized: permit.boxSerialized,\n      block: permit.block,\n      height: permit.height,\n      extractor: extractor,\n      WID: permit.WID,\n      txId: permit.txId,\n      spendBlock: permit.spendBlock,\n      spendHeight: permit.spendHeight,\n    });\n  };\n\n  /**\n   * update an unspent permit in the database\n   * @param permit\n   * @param extractor\n   */\n  updatePermit = async (permit: ExtractedPermit, extractor: string) => {\n    await this.permitRepository.update(\n      { boxId: permit.boxId, extractor: extractor },\n      {\n        boxSerialized: permit.boxSerialized,\n        block: permit.block,\n        height: permit.height,\n        WID: permit.WID,\n        txId: permit.txId,\n        spendBlock: null,\n        spendHeight: null,\n      }\n    );\n  };\n\n  /**\n   * It stores list of permits in the dataSource with block id\n   * @param permits\n   * @param block\n   * @param extractor\n   */\n  storePermits = async (\n    permits: Array<ExtractedPermit>,\n    block: Block,\n    extractor: string\n  ) => {\n    if (permits.length === 0) return true;\n    const boxIds = permits.map((permit) => permit.boxId);\n    const savedPermits = await this.permitRepository.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(PermitEntity);\n    try {\n      for (const permit of permits) {\n        const saved = savedPermits.some((entity) => {\n          return entity.boxId === permit.boxId;\n        });\n        const entity = {\n          boxId: permit.boxId,\n          boxSerialized: permit.boxSerialized,\n          block: block.hash,\n          height: block.height,\n          extractor: extractor,\n          WID: permit.WID,\n          txId: permit.txId,\n        };\n        if (!saved) {\n          this.logger.debug(\n            `Saving permit [${permit.boxId}] belonging to watcher [${permit.WID}] at height ${block.height} and extractor ${extractor}`\n          );\n          await repository.insert(entity);\n        } else {\n          this.logger.debug(\n            `Updating permit [${permit.boxId}] belonging to watcher [${permit.WID}] at height ${block.height} and extractor ${extractor}`\n          );\n          await repository.update({ boxId: permit.boxId }, entity);\n        }\n        this.logger.debug(`Entity: ${JSON.stringify(entity)}`);\n      }\n      await queryRunner.commitTransaction();\n    } catch (e) {\n      this.logger.error(`An error occurred during store permit action: ${e}`);\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 permits spent on the block\n   * @param spendId\n   * @param block\n   * @param extractor\n   */\n  spendPermits = async (\n    spendId: Array<string>,\n    block: Block,\n    extractor: string\n  ): Promise<void> => {\n    const spendIdChunks = chunk(spendId, dbIdChunkSize);\n    for (const spendIdChunk of spendIdChunks) {\n      const updateResult = await this.permitRepository.update(\n        { boxId: In(spendIdChunk), extractor: extractor },\n        { spendBlock: block.hash, spendHeight: block.height }\n      );\n\n      if (updateResult.affected && updateResult.affected > 0) {\n        const spentRows = await this.permitRepository.findBy({\n          boxId: In(spendIdChunk),\n          spendBlock: block.hash,\n        });\n        for (const row of spentRows) {\n          this.logger.debug(\n            `Spent permit with boxId [${row.boxId}] belonging to watcher with WID [${row.WID}] at height ${block.height}`\n          );\n        }\n      }\n    }\n  };\n\n  /**\n   * Delete all permits corresponding to the block(id) and extractor(id)\n   * and update all permits spent on the specified block\n   * @param block\n   * @param extractor\n   */\n  deleteBlock = async (block: string, extractor: string): Promise<void> => {\n    this.logger.info(\n      `Deleting permits at block ${block} and extractor ${extractor}`\n    );\n    await this.permitRepository.delete({ block: block, extractor: extractor });\n    await this.permitRepository.update(\n      { spendBlock: block, extractor: extractor },\n      { spendBlock: null, spendHeight: null }\n    );\n  };\n\n  /**\n   *  Returns all stored permit box ids\n   */\n  getAllPermitBoxIds = async (extractor: string): Promise<Array<string>> => {\n    const boxIds = await this.permitRepository.find({\n      where: {\n        extractor: extractor,\n      },\n      select: {\n        boxId: true,\n      },\n    });\n    return boxIds.map((item: { boxId: string }) => item.boxId);\n  };\n\n  /**\n   * Removes specified permit\n   * @param boxId\n   * @param extractor\n   */\n  removePermit = async (boxId: string, extractor: string) => {\n    return await this.permitRepository.delete({\n      boxId: boxId,\n      extractor: extractor,\n    });\n  };\n\n  /**\n   * Update the permit spending information\n   * @param boxId\n   * @param extractor\n   * @param blockId\n   * @param blockHeight\n   */\n  updateSpendBlock = async (\n    boxId: string,\n    extractor: string,\n    blockId: string,\n    blockHeight: number\n  ) => {\n    return await this.permitRepository.update(\n      { boxId: boxId, extractor: extractor },\n      { spendBlock: blockId, spendHeight: blockHeight }\n    );\n  };\n}\n\nexport default PermitAction;\n"]}
@@ -1,7 +1,7 @@
1
1
  import { DataSource } from 'typeorm';
2
- import { Transaction } from '@rosen-bridge/scanner';
3
2
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
4
- import { AbstractInitializableErgoExtractor, BlockInfo, ErgoNetworkType, OutputBox } from '@rosen-bridge/abstract-extractor';
3
+ import { AbstractInitializableErgoExtractor } from '@rosen-bridge/abstract-extractor';
4
+ import { BlockInfo, ErgoNetworkType, OutputBox, Transaction } from '@rosen-bridge/scanner-interfaces';
5
5
  import EventTriggerAction from '../actions/EventTriggerAction';
6
6
  import { ExtractedEventTrigger } from '../interfaces/extractedEventTrigger';
7
7
  import { EventResult } from '../types';
@@ -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,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
+ {"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,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EACL,kCAAkC,EAGnC,MAAM,kCAAkC,CAAC;AAC1C,OAAO,EACL,SAAS,EACT,eAAe,EACf,SAAS,EACT,WAAW,EACZ,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"}
@@ -142,7 +142,7 @@ class EventTriggerExtractor extends AbstractInitializableErgoExtractor {
142
142
  txId: transaction.id,
143
143
  boxId: transaction.inputs[index].boxId,
144
144
  index: index,
145
- extras: [result, paymentTxId],
145
+ extras: { result, paymentTxId },
146
146
  });
147
147
  });
148
148
  if (boxes.length > 0) {
@@ -212,4 +212,4 @@ class EventTriggerExtractor extends AbstractInitializableErgoExtractor {
212
212
  };
213
213
  }
214
214
  export default EventTriggerExtractor;
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"]}
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 { AbstractLogger } from '@rosen-bridge/abstract-logger';\nimport {\n  AbstractInitializableErgoExtractor,\n  CallbackType,\n  SpendInfo,\n} from '@rosen-bridge/abstract-extractor';\nimport {\n  BlockInfo,\n  ErgoNetworkType,\n  OutputBox,\n  Transaction,\n} from '@rosen-bridge/scanner-interfaces';\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,7 +1,7 @@
1
1
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
2
- import { InitialInfo, Transaction } from '@rosen-bridge/scanner';
3
2
  import { DataSource } from 'typeorm';
4
- import { AbstractExtractor, Block } from '@rosen-bridge/abstract-extractor';
3
+ import { Block, BlockInfo, Transaction } from '@rosen-bridge/scanner-interfaces';
4
+ import { AbstractExtractor } from '@rosen-bridge/abstract-extractor';
5
5
  import CollateralAction from '../actions/collateralAction';
6
6
  export declare class CollateralExtractor extends AbstractExtractor<Transaction> {
7
7
  private readonly id;
@@ -53,7 +53,7 @@ export declare class CollateralExtractor extends AbstractExtractor<Transaction>
53
53
  * @return {Promise<void>}
54
54
  * @memberof CollateralExtractor
55
55
  */
56
- initializeBoxes: (initialBlock: InitialInfo) => Promise<void>;
56
+ initializeBoxes: (initialBlock: BlockInfo) => Promise<void>;
57
57
  /**
58
58
  * removes or updates stored collateral boxes before initializing boxes
59
59
  *
@@ -1 +1 @@
1
- {"version":3,"file":"collateralExtractor.d.ts","sourceRoot":"","sources":["../../lib/extractor/collateralExtractor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,WAAW,EAAa,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAG5E,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,EAAE,iBAAiB,EAAE,KAAK,EAAE,MAAM,kCAAkC,CAAC;AAE5E,OAAO,gBAAgB,MAAM,6BAA6B,CAAC;AAM3D,qBAAa,mBAAoB,SAAQ,iBAAiB,CAAC,WAAW,CAAC;IAMnE,OAAO,CAAC,QAAQ,CAAC,EAAE;IACnB,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,OAAO;IACxB,OAAO,CAAC,QAAQ,CAAC,UAAU;IAE3B,OAAO,CAAC,QAAQ,CAAC,MAAM;IAVzB,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAS;IAClC,QAAQ,CAAC,MAAM,EAAE,gBAAgB,CAAC;IAClC,OAAO,CAAC,WAAW,CAAC;gBAGD,EAAE,EAAE,MAAM,EACV,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,MAAM,EACf,UAAU,EAAE,UAAU,EACvC,WAAW,EAAE,MAAM,EACF,MAAM,GAAE,cAAkC;IAU7D;;;;OAIG;IACH,KAAK,QAAO,MAAM,CAAY;IAE9B;;;;;;;OAOG;IACH,mBAAmB,QACZ,WAAW,EAAE,SACX,KAAK,KACX,QAAQ,OAAO,CAAC,CAoCjB;IAEF;;;;;;;OAOG;IACH,OAAO,CAAC,eAAe,CAOrB;IAEF;;;;;;;OAOG;IACH,SAAS,SAAgB,MAAM,KAAG,QAAQ,IAAI,CAAC,CAE7C;IAEF;;;;;;OAMG;IACH,eAAe,iBAAwB,WAAW,KAAG,QAAQ,IAAI,CAAC,CAmChE;IAEF;;;;;;;;OAQG;YACW,uBAAuB;IAkDrC;;;;;;;OAOG;IACH,OAAO,CAAC,wBAAwB,CAiC9B;IAEF;;;;;;;OAOG;IACH,OAAO,CAAC,qBAAqB,CAgD3B;CACH"}
1
+ {"version":3,"file":"collateralExtractor.d.ts","sourceRoot":"","sources":["../../lib/extractor/collateralExtractor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAG5E,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,EACL,KAAK,EACL,SAAS,EAET,WAAW,EACZ,MAAM,kCAAkC,CAAC;AAC1C,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AAErE,OAAO,gBAAgB,MAAM,6BAA6B,CAAC;AAM3D,qBAAa,mBAAoB,SAAQ,iBAAiB,CAAC,WAAW,CAAC;IAMnE,OAAO,CAAC,QAAQ,CAAC,EAAE;IACnB,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,OAAO;IACxB,OAAO,CAAC,QAAQ,CAAC,UAAU;IAE3B,OAAO,CAAC,QAAQ,CAAC,MAAM;IAVzB,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAS;IAClC,QAAQ,CAAC,MAAM,EAAE,gBAAgB,CAAC;IAClC,OAAO,CAAC,WAAW,CAAC;gBAGD,EAAE,EAAE,MAAM,EACV,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,MAAM,EACf,UAAU,EAAE,UAAU,EACvC,WAAW,EAAE,MAAM,EACF,MAAM,GAAE,cAAkC;IAU7D;;;;OAIG;IACH,KAAK,QAAO,MAAM,CAAY;IAE9B;;;;;;;OAOG;IACH,mBAAmB,QACZ,WAAW,EAAE,SACX,KAAK,KACX,QAAQ,OAAO,CAAC,CAoCjB;IAEF;;;;;;;OAOG;IACH,OAAO,CAAC,eAAe,CAOrB;IAEF;;;;;;;OAOG;IACH,SAAS,SAAgB,MAAM,KAAG,QAAQ,IAAI,CAAC,CAE7C;IAEF;;;;;;OAMG;IACH,eAAe,iBAAwB,SAAS,KAAG,QAAQ,IAAI,CAAC,CAmC9D;IAEF;;;;;;;;OAQG;YACW,uBAAuB;IAkDrC;;;;;;;OAOG;IACH,OAAO,CAAC,wBAAwB,CAiC9B;IAEF;;;;;;;OAOG;IACH,OAAO,CAAC,qBAAqB,CAgD3B;CACH"}
@@ -233,4 +233,4 @@ export class CollateralExtractor extends AbstractExtractor {
233
233
  };
234
234
  };
235
235
  }
236
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collateralExtractor.js","sourceRoot":"","sources":["../../lib/extractor/collateralExtractor.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport { InitialInfo, OutputBox, Transaction } from '@rosen-bridge/scanner';\nimport ergoExplorerClientFactory, { V1 } from '@rosen-clients/ergo-explorer';\nimport * as ergoLib from 'ergo-lib-wasm-nodejs';\nimport { DataSource } from 'typeorm';\nimport { AbstractExtractor, Block } from '@rosen-bridge/abstract-extractor';\n\nimport CollateralAction from '../actions/collateralAction';\nimport { DefaultApiLimit } from '../constants';\nimport { ExtractedCollateral } from '../interfaces/extractedCollateral';\nimport { JsonBI, uint8ArrayToHex } from '../utils';\nimport { SpendInfo } from '../interfaces/types';\n\nexport class CollateralExtractor extends AbstractExtractor<Transaction> {\n  private readonly ergoTree: string;\n  readonly action: CollateralAction;\n  private explorerApi;\n\n  constructor(\n    private readonly id: string,\n    private readonly awcNft: string,\n    private readonly address: string,\n    private readonly dataSource: DataSource,\n    explorerUrl: string,\n    private readonly logger: AbstractLogger = new DummyLogger()\n  ) {\n    super();\n    this.ergoTree = ergoLib.Address.from_base58(this.address)\n      .to_ergo_tree()\n      .to_base16_bytes();\n    this.action = new CollateralAction(this.dataSource, this.logger);\n    this.explorerApi = ergoExplorerClientFactory(explorerUrl);\n  }\n\n  /**\n   * get id for extractor. This id must be unique over all extractors.\n   *\n   * @return {string}\n   */\n  getId = (): string => this.id;\n\n  /**\n   * process a list of transactions and store collateral box details\n   *\n   * @param {Transaction[]} txs list of transaction for block\n   * @param {Block} block block id for transactions as hex encoded\n   * @return {Promise<boolean>} Promise<boolean> if no error occurred return\n   * true. otherwise, return false\n   */\n  processTransactions = async (\n    txs: Transaction[],\n    block: Block\n  ): Promise<boolean> => {\n    try {\n      const boxes: Array<ExtractedCollateral> = [];\n      const spentInfos: Array<SpendInfo> = [];\n      for (const tx of txs) {\n        const outputBox = tx.outputs.at(1);\n        if (outputBox == undefined) {\n          continue;\n        }\n\n        if (!this.isCollateralBox(outputBox)) {\n          continue;\n        }\n        const extractedCollateral = this.toExtractedCollateral(\n          outputBox,\n          block.hash,\n          block.height\n        );\n        if (extractedCollateral) boxes.push(extractedCollateral);\n\n        const inputCollateral = tx.inputs.at(1);\n        if (inputCollateral != undefined) {\n          spentInfos.push({ txId: tx.id, boxId: inputCollateral.boxId });\n        }\n      }\n      if (boxes.length > 0)\n        await this.action.storeCollaterals(boxes, block, this.getId());\n      await this.action.spendCollaterals(spentInfos, block, this.getId());\n    } catch (e) {\n      this.logger.error(\n        `Error in storing collaterals of the block ${block}: ${e}`\n      );\n      return false;\n    }\n\n    return true;\n  };\n\n  /**\n   * checks if the passed box is a collateral box\n   *\n   * @private\n   * @param {OutputBox} outputBox\n   * @return {boolean}\n   * @memberof CollateralExtractor\n   */\n  private isCollateralBox = (outputBox: V1.OutputInfo | OutputBox): boolean => {\n    const awcNft = outputBox.assets?.at(0)?.tokenId;\n    return (\n      awcNft != undefined &&\n      awcNft === this.awcNft &&\n      outputBox.ergoTree === this.ergoTree\n    );\n  };\n\n  /**\n   * Delete all collaterals corresponding to the passed block and extractor and\n   * update all collaterals spent in the specified block\n   *\n   * @param {string} hash\n   * @return {Promise<void>}\n   * @memberof CollateralExtractor\n   */\n  forkBlock = async (hash: string): Promise<void> => {\n    await this.action.deleteBlock(hash, this.getId());\n  };\n\n  /**\n   * Initializes the database with older collaterals\n   *\n   * @param {number} initialHeight\n   * @return {Promise<void>}\n   * @memberof CollateralExtractor\n   */\n  initializeBoxes = async (initialBlock: InitialInfo): Promise<void> => {\n    const unspentCollaterals = await this.getAllUnspentCollaterals(\n      initialBlock.height\n    );\n    this.logger.debug(\n      `unspent collateral box info with following IDs gotten form Ergo network: [${unspentCollaterals\n        .map((box) => box.boxId)\n        .join(', ')}]`\n    );\n\n    const storedUnspentCollateralBoxIds =\n      await this.action.getUnspentCollateralBoxIds(this.getId());\n    const unspentCollateralBoxIds = new Set(\n      unspentCollaterals.map((box) => box.boxId)\n    );\n    await this.tidyUpStoredCollaterals(\n      initialBlock.height,\n      storedUnspentCollateralBoxIds.filter(\n        (boxId) => !unspentCollateralBoxIds.has(boxId)\n      )\n    );\n\n    for (const collateral of unspentCollaterals) {\n      if (storedUnspentCollateralBoxIds.includes(collateral.boxId)) {\n        this.logger.debug(\n          `updating unspent collateral with boxId=[${collateral.boxId}] at initialization phase`\n        );\n        await this.action.updateCollateral(collateral, this.getId());\n      } else {\n        this.logger.debug(\n          `inserting unspent collateral with boxId=[${collateral.boxId}] to database at initialization phase`\n        );\n        await this.action.insertCollateral(collateral, this.getId());\n      }\n    }\n  };\n\n  /**\n   * removes or updates stored collateral boxes before initializing boxes\n   *\n   * @private\n   * @param {number} initialHeight\n   * @param {string[]} collateralBoxIds\n   * @return {Promise<void>}\n   * @memberof CollateralExtractor\n   */\n  private async tidyUpStoredCollaterals(\n    initialHeight: number,\n    collateralBoxIds: string[]\n  ) {\n    for (const boxId of collateralBoxIds) {\n      let boxInfo: V1.OutputInfo;\n      try {\n        boxInfo = await this.explorerApi.v1.getApiV1BoxesP1(boxId);\n      } catch (e: any) {\n        if (e?.response?.status === 404) {\n          await this.action.deleteCollateral(boxId, this.getId());\n          continue;\n        } else {\n          throw new Error(\n            `something went wrong when trying to get box=[${boxId}] from Ergo network: ${e?.message}`\n          );\n        }\n      }\n\n      if (boxInfo?.spentTransactionId != null) {\n        try {\n          const transactionInfo: V1.TransactionInfo =\n            await this.explorerApi.v1.getApiV1TransactionsP1(\n              boxInfo.spentTransactionId\n            );\n\n          if (transactionInfo.inclusionHeight < initialHeight) {\n            this.logger.debug(\n              `collateral with boxId=[${boxId}] is spent and is being updated with spendHeight=[${transactionInfo.inclusionHeight}] and spendBlock=[${transactionInfo.blockId}]`\n            );\n\n            await this.action.updateCollateral(\n              {\n                boxId: boxId,\n                spendHeight: transactionInfo.inclusionHeight,\n                spendBlock: transactionInfo.blockId,\n                spendTxId: transactionInfo.id,\n              },\n              this.getId()\n            );\n          }\n        } catch (e: any) {\n          throw new Error(\n            `something went wrong when trying to get transaction=[${boxInfo.spentTransactionId}] from Ergo network: ${e?.message}`\n          );\n        }\n      }\n    }\n  }\n\n  /**\n   * gets all unspent collaterals from Ergo explorer api\n   *\n   * @private\n   * @param {number} initialHeight\n   * @return {Promise<Array<ExtractedCollateral>>}\n   * @memberof CollateralExtractor\n   */\n  private getAllUnspentCollaterals = async (\n    initialHeight: number\n  ): Promise<Array<ExtractedCollateral>> => {\n    const extractedBoxes: Array<ExtractedCollateral> = [];\n    let offset = 0;\n    let total = 1;\n    while (offset < total) {\n      const boxes = await this.explorerApi.v1.getApiV1BoxesUnspentByergotreeP1(\n        this.ergoTree,\n        { offset: offset, limit: DefaultApiLimit }\n      );\n\n      if (!boxes.items) {\n        throw new Error('Explorer api output items should not be undefined.');\n      }\n\n      extractedBoxes.push(\n        ...boxes.items\n          .filter(\n            (box) =>\n              box.creationHeight &&\n              box.creationHeight < initialHeight &&\n              this.isCollateralBox(box)\n          )\n          .map((box) =>\n            this.toExtractedCollateral(box, box.blockId, box.settlementHeight)\n          )\n          .filter((data): data is ExtractedCollateral => data != undefined)\n      );\n      total = boxes.total;\n      offset += DefaultApiLimit;\n    }\n    return extractedBoxes;\n  };\n\n  /**\n   * converts output box information to an ExtractedCollateral object\n   *\n   * @private\n   * @param {(OutputInfo | OutputBox)} box\n   * @return {ExtractedCollateral}\n   * @memberof CollateralExtractor\n   */\n  private toExtractedCollateral = (\n    box: V1.OutputInfo | OutputBox,\n    blockId: string,\n    blockHeight: number\n  ): ExtractedCollateral | undefined => {\n    const ergoOutputBox = ergoLib.ErgoBox.from_json(JsonBI.stringify(box));\n\n    const r4 = ergoOutputBox\n      .register_value(ergoLib.NonMandatoryRegisterId.R4)\n      ?.to_byte_array();\n    if (r4 == undefined) {\n      this.logger.warn(\n        `collateral box with boxId=[${box.boxId}] has an invalid R4 register`\n      );\n      return undefined;\n    }\n    const wid = uint8ArrayToHex(r4);\n    this.logger.debug(\n      `Extracted WID=[${wid}] from R4 register of box=[${box.boxId}]`\n    );\n\n    const r5 = ergoOutputBox\n      .register_value(ergoLib.NonMandatoryRegisterId.R5)\n      ?.to_i64()\n      .to_str();\n\n    if (r5 == undefined) {\n      this.logger.warn(\n        `collateral box with boxId=[${box.boxId}] has an invalid R5 register`\n      );\n      return undefined;\n    }\n    const rwtCount = BigInt(r5);\n    this.logger.debug(\n      `Extracted rwtCount=[${rwtCount}] from R5 register of box=[${box.boxId}]`\n    );\n\n    return {\n      boxId: box.boxId,\n      boxSerialized: Buffer.from(\n        ergoOutputBox.sigma_serialize_bytes()\n      ).toString('base64'),\n      wid: wid,\n      rwtCount: rwtCount,\n      txId: box.transactionId,\n      block: blockId,\n      height: blockHeight,\n    };\n  };\n}\n"]}
236
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collateralExtractor.js","sourceRoot":"","sources":["../../lib/extractor/collateralExtractor.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport ergoExplorerClientFactory, { V1 } from '@rosen-clients/ergo-explorer';\nimport * as ergoLib from 'ergo-lib-wasm-nodejs';\nimport { DataSource } from 'typeorm';\nimport {\n  Block,\n  BlockInfo,\n  OutputBox,\n  Transaction,\n} from '@rosen-bridge/scanner-interfaces';\nimport { AbstractExtractor } from '@rosen-bridge/abstract-extractor';\n\nimport CollateralAction from '../actions/collateralAction';\nimport { DefaultApiLimit } from '../constants';\nimport { ExtractedCollateral } from '../interfaces/extractedCollateral';\nimport { JsonBI, uint8ArrayToHex } from '../utils';\nimport { SpendInfo } from '../interfaces/types';\n\nexport class CollateralExtractor extends AbstractExtractor<Transaction> {\n  private readonly ergoTree: string;\n  readonly action: CollateralAction;\n  private explorerApi;\n\n  constructor(\n    private readonly id: string,\n    private readonly awcNft: string,\n    private readonly address: string,\n    private readonly dataSource: DataSource,\n    explorerUrl: string,\n    private readonly logger: AbstractLogger = new DummyLogger()\n  ) {\n    super();\n    this.ergoTree = ergoLib.Address.from_base58(this.address)\n      .to_ergo_tree()\n      .to_base16_bytes();\n    this.action = new CollateralAction(this.dataSource, this.logger);\n    this.explorerApi = ergoExplorerClientFactory(explorerUrl);\n  }\n\n  /**\n   * get id for extractor. This id must be unique over all extractors.\n   *\n   * @return {string}\n   */\n  getId = (): string => this.id;\n\n  /**\n   * process a list of transactions and store collateral box details\n   *\n   * @param {Transaction[]} txs list of transaction for block\n   * @param {Block} block block id for transactions as hex encoded\n   * @return {Promise<boolean>} Promise<boolean> if no error occurred return\n   * true. otherwise, return false\n   */\n  processTransactions = async (\n    txs: Transaction[],\n    block: Block\n  ): Promise<boolean> => {\n    try {\n      const boxes: Array<ExtractedCollateral> = [];\n      const spentInfos: Array<SpendInfo> = [];\n      for (const tx of txs) {\n        const outputBox = tx.outputs.at(1);\n        if (outputBox == undefined) {\n          continue;\n        }\n\n        if (!this.isCollateralBox(outputBox)) {\n          continue;\n        }\n        const extractedCollateral = this.toExtractedCollateral(\n          outputBox,\n          block.hash,\n          block.height\n        );\n        if (extractedCollateral) boxes.push(extractedCollateral);\n\n        const inputCollateral = tx.inputs.at(1);\n        if (inputCollateral != undefined) {\n          spentInfos.push({ txId: tx.id, boxId: inputCollateral.boxId });\n        }\n      }\n      if (boxes.length > 0)\n        await this.action.storeCollaterals(boxes, block, this.getId());\n      await this.action.spendCollaterals(spentInfos, block, this.getId());\n    } catch (e) {\n      this.logger.error(\n        `Error in storing collaterals of the block ${block}: ${e}`\n      );\n      return false;\n    }\n\n    return true;\n  };\n\n  /**\n   * checks if the passed box is a collateral box\n   *\n   * @private\n   * @param {OutputBox} outputBox\n   * @return {boolean}\n   * @memberof CollateralExtractor\n   */\n  private isCollateralBox = (outputBox: V1.OutputInfo | OutputBox): boolean => {\n    const awcNft = outputBox.assets?.at(0)?.tokenId;\n    return (\n      awcNft != undefined &&\n      awcNft === this.awcNft &&\n      outputBox.ergoTree === this.ergoTree\n    );\n  };\n\n  /**\n   * Delete all collaterals corresponding to the passed block and extractor and\n   * update all collaterals spent in the specified block\n   *\n   * @param {string} hash\n   * @return {Promise<void>}\n   * @memberof CollateralExtractor\n   */\n  forkBlock = async (hash: string): Promise<void> => {\n    await this.action.deleteBlock(hash, this.getId());\n  };\n\n  /**\n   * Initializes the database with older collaterals\n   *\n   * @param {number} initialHeight\n   * @return {Promise<void>}\n   * @memberof CollateralExtractor\n   */\n  initializeBoxes = async (initialBlock: BlockInfo): Promise<void> => {\n    const unspentCollaterals = await this.getAllUnspentCollaterals(\n      initialBlock.height\n    );\n    this.logger.debug(\n      `unspent collateral box info with following IDs gotten form Ergo network: [${unspentCollaterals\n        .map((box) => box.boxId)\n        .join(', ')}]`\n    );\n\n    const storedUnspentCollateralBoxIds =\n      await this.action.getUnspentCollateralBoxIds(this.getId());\n    const unspentCollateralBoxIds = new Set(\n      unspentCollaterals.map((box) => box.boxId)\n    );\n    await this.tidyUpStoredCollaterals(\n      initialBlock.height,\n      storedUnspentCollateralBoxIds.filter(\n        (boxId) => !unspentCollateralBoxIds.has(boxId)\n      )\n    );\n\n    for (const collateral of unspentCollaterals) {\n      if (storedUnspentCollateralBoxIds.includes(collateral.boxId)) {\n        this.logger.debug(\n          `updating unspent collateral with boxId=[${collateral.boxId}] at initialization phase`\n        );\n        await this.action.updateCollateral(collateral, this.getId());\n      } else {\n        this.logger.debug(\n          `inserting unspent collateral with boxId=[${collateral.boxId}] to database at initialization phase`\n        );\n        await this.action.insertCollateral(collateral, this.getId());\n      }\n    }\n  };\n\n  /**\n   * removes or updates stored collateral boxes before initializing boxes\n   *\n   * @private\n   * @param {number} initialHeight\n   * @param {string[]} collateralBoxIds\n   * @return {Promise<void>}\n   * @memberof CollateralExtractor\n   */\n  private async tidyUpStoredCollaterals(\n    initialHeight: number,\n    collateralBoxIds: string[]\n  ) {\n    for (const boxId of collateralBoxIds) {\n      let boxInfo: V1.OutputInfo;\n      try {\n        boxInfo = await this.explorerApi.v1.getApiV1BoxesP1(boxId);\n      } catch (e: any) {\n        if (e?.response?.status === 404) {\n          await this.action.deleteCollateral(boxId, this.getId());\n          continue;\n        } else {\n          throw new Error(\n            `something went wrong when trying to get box=[${boxId}] from Ergo network: ${e?.message}`\n          );\n        }\n      }\n\n      if (boxInfo?.spentTransactionId != null) {\n        try {\n          const transactionInfo: V1.TransactionInfo =\n            await this.explorerApi.v1.getApiV1TransactionsP1(\n              boxInfo.spentTransactionId\n            );\n\n          if (transactionInfo.inclusionHeight < initialHeight) {\n            this.logger.debug(\n              `collateral with boxId=[${boxId}] is spent and is being updated with spendHeight=[${transactionInfo.inclusionHeight}] and spendBlock=[${transactionInfo.blockId}]`\n            );\n\n            await this.action.updateCollateral(\n              {\n                boxId: boxId,\n                spendHeight: transactionInfo.inclusionHeight,\n                spendBlock: transactionInfo.blockId,\n                spendTxId: transactionInfo.id,\n              },\n              this.getId()\n            );\n          }\n        } catch (e: any) {\n          throw new Error(\n            `something went wrong when trying to get transaction=[${boxInfo.spentTransactionId}] from Ergo network: ${e?.message}`\n          );\n        }\n      }\n    }\n  }\n\n  /**\n   * gets all unspent collaterals from Ergo explorer api\n   *\n   * @private\n   * @param {number} initialHeight\n   * @return {Promise<Array<ExtractedCollateral>>}\n   * @memberof CollateralExtractor\n   */\n  private getAllUnspentCollaterals = async (\n    initialHeight: number\n  ): Promise<Array<ExtractedCollateral>> => {\n    const extractedBoxes: Array<ExtractedCollateral> = [];\n    let offset = 0;\n    let total = 1;\n    while (offset < total) {\n      const boxes = await this.explorerApi.v1.getApiV1BoxesUnspentByergotreeP1(\n        this.ergoTree,\n        { offset: offset, limit: DefaultApiLimit }\n      );\n\n      if (!boxes.items) {\n        throw new Error('Explorer api output items should not be undefined.');\n      }\n\n      extractedBoxes.push(\n        ...boxes.items\n          .filter(\n            (box) =>\n              box.creationHeight &&\n              box.creationHeight < initialHeight &&\n              this.isCollateralBox(box)\n          )\n          .map((box) =>\n            this.toExtractedCollateral(box, box.blockId, box.settlementHeight)\n          )\n          .filter((data): data is ExtractedCollateral => data != undefined)\n      );\n      total = boxes.total;\n      offset += DefaultApiLimit;\n    }\n    return extractedBoxes;\n  };\n\n  /**\n   * converts output box information to an ExtractedCollateral object\n   *\n   * @private\n   * @param {(OutputInfo | OutputBox)} box\n   * @return {ExtractedCollateral}\n   * @memberof CollateralExtractor\n   */\n  private toExtractedCollateral = (\n    box: V1.OutputInfo | OutputBox,\n    blockId: string,\n    blockHeight: number\n  ): ExtractedCollateral | undefined => {\n    const ergoOutputBox = ergoLib.ErgoBox.from_json(JsonBI.stringify(box));\n\n    const r4 = ergoOutputBox\n      .register_value(ergoLib.NonMandatoryRegisterId.R4)\n      ?.to_byte_array();\n    if (r4 == undefined) {\n      this.logger.warn(\n        `collateral box with boxId=[${box.boxId}] has an invalid R4 register`\n      );\n      return undefined;\n    }\n    const wid = uint8ArrayToHex(r4);\n    this.logger.debug(\n      `Extracted WID=[${wid}] from R4 register of box=[${box.boxId}]`\n    );\n\n    const r5 = ergoOutputBox\n      .register_value(ergoLib.NonMandatoryRegisterId.R5)\n      ?.to_i64()\n      .to_str();\n\n    if (r5 == undefined) {\n      this.logger.warn(\n        `collateral box with boxId=[${box.boxId}] has an invalid R5 register`\n      );\n      return undefined;\n    }\n    const rwtCount = BigInt(r5);\n    this.logger.debug(\n      `Extracted rwtCount=[${rwtCount}] from R5 register of box=[${box.boxId}]`\n    );\n\n    return {\n      boxId: box.boxId,\n      boxSerialized: Buffer.from(\n        ergoOutputBox.sigma_serialize_bytes()\n      ).toString('base64'),\n      wid: wid,\n      rwtCount: rwtCount,\n      txId: box.transactionId,\n      block: blockId,\n      height: blockHeight,\n    };\n  };\n}\n"]}
@@ -1,7 +1,7 @@
1
1
  import { DataSource } from 'typeorm';
2
- import { Transaction } from '@rosen-bridge/scanner';
3
2
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
4
- import { AbstractExtractor, Block } from '@rosen-bridge/abstract-extractor';
3
+ import { Block, Transaction } from '@rosen-bridge/scanner-interfaces';
4
+ import { AbstractExtractor } from '@rosen-bridge/abstract-extractor';
5
5
  import { TokenMap } from '@rosen-bridge/tokens';
6
6
  declare class CommitmentExtractor extends AbstractExtractor<Transaction> {
7
7
  readonly logger: AbstractLogger;
@@ -1 +1 @@
1
- {"version":3,"file":"commitmentExtractor.d.ts","sourceRoot":"","sources":["../../lib/extractor/commitmentExtractor.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,iBAAiB,EAAE,KAAK,EAAE,MAAM,kCAAkC,CAAC;AAM5E,OAAO,EAAe,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAE7D,cAAM,mBAAoB,SAAQ,iBAAiB,CAAC,WAAW,CAAC;IAC9D,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC;IAChC,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;IACxC,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAgB;IACrD,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAS;IAC/B,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAmB;IAC3C,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAW;gBAGlC,EAAE,EAAE,MAAM,EACV,SAAS,EAAE,KAAK,CAAC,MAAM,CAAC,EACxB,KAAK,EAAE,MAAM,EACb,UAAU,EAAE,UAAU,EACtB,MAAM,EAAE,QAAQ,EAChB,MAAM,CAAC,EAAE,cAAc;IAczB;;OAEG;IACH,KAAK,eAAiB;IAEtB;;;;;OAKG;IACH,mBAAmB,QACZ,MAAM,WAAW,CAAC,SAChB,KAAK,KACX,QAAQ,OAAO,CAAC,CAmFjB;IAEF;;;OAGG;IACH,SAAS,SAAgB,MAAM,KAAG,QAAQ,IAAI,CAAC,CAE7C;IAEF;;;OAGG;IACH,eAAe,sBAEb;CACH;AAED,eAAe,mBAAmB,CAAC"}
1
+ {"version":3,"file":"commitmentExtractor.d.ts","sourceRoot":"","sources":["../../lib/extractor/commitmentExtractor.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,kCAAkC,CAAC;AACtE,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AAMrE,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAEhD,cAAM,mBAAoB,SAAQ,iBAAiB,CAAC,WAAW,CAAC;IAC9D,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC;IAChC,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;IACxC,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAgB;IACrD,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAS;IAC/B,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAmB;IAC3C,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAW;gBAGlC,EAAE,EAAE,MAAM,EACV,SAAS,EAAE,KAAK,CAAC,MAAM,CAAC,EACxB,KAAK,EAAE,MAAM,EACb,UAAU,EAAE,UAAU,EACtB,MAAM,EAAE,QAAQ,EAChB,MAAM,CAAC,EAAE,cAAc;IAczB;;OAEG;IACH,KAAK,eAAiB;IAEtB;;;;;OAKG;IACH,mBAAmB,QACZ,MAAM,WAAW,CAAC,SAChB,KAAK,KACX,QAAQ,OAAO,CAAC,CAmFjB;IAEF;;;OAGG;IACH,SAAS,SAAgB,MAAM,KAAG,QAAQ,IAAI,CAAC,CAE7C;IAEF;;;OAGG;IACH,eAAe,sBAEb;CACH;AAED,eAAe,mBAAmB,CAAC"}
@@ -115,4 +115,4 @@ class CommitmentExtractor extends AbstractExtractor {
115
115
  };
116
116
  }
117
117
  export default CommitmentExtractor;
118
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"commitmentExtractor.js","sourceRoot":"","sources":["../../lib/extractor/commitmentExtractor.ts"],"names":[],"mappings":"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","sourcesContent":["import * as wasm from 'ergo-lib-wasm-nodejs';\nimport { DataSource } from 'typeorm';\nimport { Transaction } from '@rosen-bridge/scanner';\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport { AbstractExtractor, Block } from '@rosen-bridge/abstract-extractor';\n\nimport CommitmentAction from '../actions/commitmentAction';\nimport { extractedCommitment } from '../interfaces/extractedCommitment';\nimport { JsonBI } from '../utils';\nimport { SpendInfo } from '../interfaces/types';\nimport { RosenTokens, TokenMap } from '@rosen-bridge/tokens';\n\nclass CommitmentExtractor extends AbstractExtractor<Transaction> {\n  readonly logger: AbstractLogger;\n  id: string;\n  private readonly dataSource: DataSource;\n  private readonly commitmentsErgoTrees: Array<string>;\n  private readonly RWTId: string;\n  private readonly actions: CommitmentAction;\n  private readonly tokenMap: TokenMap;\n\n  constructor(\n    id: string,\n    addresses: Array<string>,\n    RWTId: string,\n    dataSource: DataSource,\n    tokens: TokenMap,\n    logger?: AbstractLogger\n  ) {\n    super();\n    this.id = id;\n    this.dataSource = dataSource;\n    this.commitmentsErgoTrees = addresses.map((address) =>\n      wasm.Address.from_base58(address).to_ergo_tree().to_base16_bytes()\n    );\n    this.RWTId = RWTId;\n    this.logger = logger ? logger : new DummyLogger();\n    this.actions = new CommitmentAction(dataSource, this.logger);\n    this.tokenMap = tokens;\n  }\n\n  /**\n   * get Id for current extractor\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 txs\n   * @param block\n   */\n  processTransactions = (\n    txs: Array<Transaction>,\n    block: Block\n  ): Promise<boolean> => {\n    return new Promise((resolve, reject) => {\n      try {\n        const commitments: Array<extractedCommitment> = [];\n        const spendIds: Array<SpendInfo> = [];\n        txs.forEach((transaction) => {\n          // process outputs\n          for (const output of transaction.outputs) {\n            if (\n              output.assets &&\n              output.additionalRegisters &&\n              output.assets.length > 0 &&\n              output.assets[0].tokenId === this.RWTId &&\n              this.commitmentsErgoTrees.indexOf(output.ergoTree) !== -1\n            ) {\n              try {\n                const decodedBox = wasm.ErgoBox.from_json(\n                  JsonBI.stringify(output)\n                );\n                const R4 = decodedBox.register_value(\n                  wasm.NonMandatoryRegisterId.R4\n                );\n                const R5 = decodedBox.register_value(\n                  wasm.NonMandatoryRegisterId.R5\n                );\n                const R6 = decodedBox.register_value(\n                  wasm.NonMandatoryRegisterId.R6\n                );\n                if (R4 && R5 && R6) {\n                  const R4Value = R4.to_byte_array();\n                  const R5Value = R5.to_byte_array();\n                  const R6Value = R6.to_byte_array();\n                  const WID = Buffer.from(R4Value).toString('hex');\n                  const requestId = Buffer.from(R5Value).toString('hex');\n                  const eventDigest = Buffer.from(R6Value).toString('hex');\n                  commitments.push({\n                    txId: transaction.id,\n                    WID: WID,\n                    commitment: eventDigest,\n                    eventId: requestId,\n                    boxId: output.boxId,\n                    boxSerialized: Buffer.from(\n                      decodedBox.sigma_serialize_bytes()\n                    ).toString('base64'),\n                    rwtCount: this.tokenMap\n                      .wrapAmount(\n                        this.RWTId,\n                        BigInt(output.assets[0].amount),\n                        'ergo'\n                      )\n                      .amount.toString(),\n                  });\n                }\n              } catch {\n                // empty\n              }\n            }\n          }\n          // process inputs\n          for (let i = 0; i < transaction.inputs.length; i++) {\n            spendIds.push({\n              boxId: transaction.inputs[i].boxId,\n              txId: transaction.id,\n              index: i,\n            });\n          }\n        });\n        // process save commitments\n        this.actions\n          .storeCommitments(commitments, block, this.id)\n          .then(() => {\n            this.actions.spendCommitments(spendIds, block, this.id).then(() => {\n              resolve(true);\n            });\n          })\n          .catch((e) => reject(e));\n      } catch (e) {\n        this.logger.error(\n          `Error in soring permits of the block ${block}: ${e}`\n        );\n        reject(e);\n      }\n    });\n  };\n\n  /**\n   * fork one block and remove all stored information for this block\n   * @param hash: block hash\n   */\n  forkBlock = async (hash: string): Promise<void> => {\n    await this.actions.deleteBlock(hash, this.getId());\n  };\n\n  /**\n   * Extractor box initialization\n   * No action needed for commitment extractor\n   */\n  initializeBoxes = async () => {\n    return;\n  };\n}\n\nexport default CommitmentExtractor;\n"]}
118
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"commitmentExtractor.js","sourceRoot":"","sources":["../../lib/extractor/commitmentExtractor.ts"],"names":[],"mappings":"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","sourcesContent":["import * as wasm from 'ergo-lib-wasm-nodejs';\nimport { DataSource } from 'typeorm';\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport { Block, Transaction } from '@rosen-bridge/scanner-interfaces';\nimport { AbstractExtractor } from '@rosen-bridge/abstract-extractor';\n\nimport CommitmentAction from '../actions/commitmentAction';\nimport { extractedCommitment } from '../interfaces/extractedCommitment';\nimport { JsonBI } from '../utils';\nimport { SpendInfo } from '../interfaces/types';\nimport { TokenMap } from '@rosen-bridge/tokens';\n\nclass CommitmentExtractor extends AbstractExtractor<Transaction> {\n  readonly logger: AbstractLogger;\n  id: string;\n  private readonly dataSource: DataSource;\n  private readonly commitmentsErgoTrees: Array<string>;\n  private readonly RWTId: string;\n  private readonly actions: CommitmentAction;\n  private readonly tokenMap: TokenMap;\n\n  constructor(\n    id: string,\n    addresses: Array<string>,\n    RWTId: string,\n    dataSource: DataSource,\n    tokens: TokenMap,\n    logger?: AbstractLogger\n  ) {\n    super();\n    this.id = id;\n    this.dataSource = dataSource;\n    this.commitmentsErgoTrees = addresses.map((address) =>\n      wasm.Address.from_base58(address).to_ergo_tree().to_base16_bytes()\n    );\n    this.RWTId = RWTId;\n    this.logger = logger ? logger : new DummyLogger();\n    this.actions = new CommitmentAction(dataSource, this.logger);\n    this.tokenMap = tokens;\n  }\n\n  /**\n   * get Id for current extractor\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 txs\n   * @param block\n   */\n  processTransactions = (\n    txs: Array<Transaction>,\n    block: Block\n  ): Promise<boolean> => {\n    return new Promise((resolve, reject) => {\n      try {\n        const commitments: Array<extractedCommitment> = [];\n        const spendIds: Array<SpendInfo> = [];\n        txs.forEach((transaction) => {\n          // process outputs\n          for (const output of transaction.outputs) {\n            if (\n              output.assets &&\n              output.additionalRegisters &&\n              output.assets.length > 0 &&\n              output.assets[0].tokenId === this.RWTId &&\n              this.commitmentsErgoTrees.indexOf(output.ergoTree) !== -1\n            ) {\n              try {\n                const decodedBox = wasm.ErgoBox.from_json(\n                  JsonBI.stringify(output)\n                );\n                const R4 = decodedBox.register_value(\n                  wasm.NonMandatoryRegisterId.R4\n                );\n                const R5 = decodedBox.register_value(\n                  wasm.NonMandatoryRegisterId.R5\n                );\n                const R6 = decodedBox.register_value(\n                  wasm.NonMandatoryRegisterId.R6\n                );\n                if (R4 && R5 && R6) {\n                  const R4Value = R4.to_byte_array();\n                  const R5Value = R5.to_byte_array();\n                  const R6Value = R6.to_byte_array();\n                  const WID = Buffer.from(R4Value).toString('hex');\n                  const requestId = Buffer.from(R5Value).toString('hex');\n                  const eventDigest = Buffer.from(R6Value).toString('hex');\n                  commitments.push({\n                    txId: transaction.id,\n                    WID: WID,\n                    commitment: eventDigest,\n                    eventId: requestId,\n                    boxId: output.boxId,\n                    boxSerialized: Buffer.from(\n                      decodedBox.sigma_serialize_bytes()\n                    ).toString('base64'),\n                    rwtCount: this.tokenMap\n                      .wrapAmount(\n                        this.RWTId,\n                        BigInt(output.assets[0].amount),\n                        'ergo'\n                      )\n                      .amount.toString(),\n                  });\n                }\n              } catch {\n                // empty\n              }\n            }\n          }\n          // process inputs\n          for (let i = 0; i < transaction.inputs.length; i++) {\n            spendIds.push({\n              boxId: transaction.inputs[i].boxId,\n              txId: transaction.id,\n              index: i,\n            });\n          }\n        });\n        // process save commitments\n        this.actions\n          .storeCommitments(commitments, block, this.id)\n          .then(() => {\n            this.actions.spendCommitments(spendIds, block, this.id).then(() => {\n              resolve(true);\n            });\n          })\n          .catch((e) => reject(e));\n      } catch (e) {\n        this.logger.error(\n          `Error in soring permits of the block ${block}: ${e}`\n        );\n        reject(e);\n      }\n    });\n  };\n\n  /**\n   * fork one block and remove all stored information for this block\n   * @param hash: block hash\n   */\n  forkBlock = async (hash: string): Promise<void> => {\n    await this.actions.deleteBlock(hash, this.getId());\n  };\n\n  /**\n   * Extractor box initialization\n   * No action needed for commitment extractor\n   */\n  initializeBoxes = async () => {\n    return;\n  };\n}\n\nexport default CommitmentExtractor;\n"]}
@@ -1,8 +1,8 @@
1
1
  import { DataSource } from 'typeorm';
2
- import { InitialInfo, Transaction } from '@rosen-bridge/scanner';
3
2
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
4
3
  import { OutputInfo } from '@rosen-clients/ergo-explorer/dist/src/v1/types/outputInfo';
5
- import { AbstractExtractor, Block } from '@rosen-bridge/abstract-extractor';
4
+ import { Block, BlockInfo, Transaction } from '@rosen-bridge/scanner-interfaces';
5
+ import { AbstractExtractor } from '@rosen-bridge/abstract-extractor';
6
6
  import PermitAction from '../actions/permitAction';
7
7
  import { ExtractedPermit } from '../interfaces/extractedPermit';
8
8
  declare class PermitExtractor extends AbstractExtractor<Transaction> {
@@ -101,7 +101,7 @@ declare class PermitExtractor extends AbstractExtractor<Transaction> {
101
101
  /**
102
102
  * Initializes the database with older permits related to the address
103
103
  */
104
- initializeBoxes: (initialBlock: InitialInfo) => Promise<void>;
104
+ initializeBoxes: (initialBlock: BlockInfo) => Promise<void>;
105
105
  /**
106
106
  * Validate all remaining permits in the database
107
107
  * update the correct ones and remove the invalid ones
@@ -1 +1 @@
1
- {"version":3,"file":"permitExtractor.d.ts","sourceRoot":"","sources":["../../lib/extractor/permitExtractor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAKrC,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACjE,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,UAAU,EAAE,MAAM,2DAA2D,CAAC;AAEvF,OAAO,EAAE,iBAAiB,EAAE,KAAK,EAAE,MAAM,kCAAkC,CAAC;AAI5E,OAAO,YAAY,MAAM,yBAAyB,CAAC;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAEhE,cAAM,eAAgB,SAAQ,iBAAiB,CAAC,WAAW,CAAC;IAC1D,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC;IAChC,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;IACxC,QAAQ,CAAC,OAAO,EAAE,YAAY,CAAC;IAC/B,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAS;IACxC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAS;IAC7B,QAAQ,CAAC,WAAW;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;MAAC;gBAGnB,EAAE,EAAE,MAAM,EACV,UAAU,EAAE,UAAU,EACtB,OAAO,EAAE,MAAM,EACf,GAAG,EAAE,MAAM,EACX,WAAW,EAAE,MAAM,EACnB,MAAM,CAAC,EAAE,cAAc;IAczB,KAAK,eAAiB;IAEtB;;;;;OAKG;IACH,mBAAmB,QACZ,MAAM,WAAW,CAAC,SAChB,KAAK,KACX,QAAQ,OAAO,CAAC,CAoEjB;IAEF,SAAS,SAAgB,MAAM,mBAE7B;IAEF;;OAEG;IACH,eAAe,iBAAwB,WAAW,mBA0BhD;IAEF;;;;;OAKG;IACH,wBAAwB,0BACC,MAAM,MAAM,CAAC,iBACrB,MAAM,mBAmBrB;IAEF;;;OAGG;IACH,kBAAkB,UACT,MAAM,KACZ,QAAQ,eAAe,GAAG,SAAS,CAAC,CAQrC;IAEF;;;;OAIG;IACH,oBAAoB,kBACH,MAAM,KACpB,QAAQ,MAAM,eAAe,CAAC,CAAC,CAuBhC;IAEF;;;OAGG;IACH,UAAU,SAAgB,MAAM;;;OAM9B;IAEF;;;;;;;OAOG;IACH,iBAAiB,UAAiB,MAAM,UAAU,CAAC,gCA4BjD;CACH;AAED,eAAe,eAAe,CAAC"}
1
+ {"version":3,"file":"permitExtractor.d.ts","sourceRoot":"","sources":["../../lib/extractor/permitExtractor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAKrC,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,UAAU,EAAE,MAAM,2DAA2D,CAAC;AAEvF,OAAO,EACL,KAAK,EACL,SAAS,EACT,WAAW,EACZ,MAAM,kCAAkC,CAAC;AAC1C,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AAIrE,OAAO,YAAY,MAAM,yBAAyB,CAAC;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAEhE,cAAM,eAAgB,SAAQ,iBAAiB,CAAC,WAAW,CAAC;IAC1D,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC;IAChC,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;IACxC,QAAQ,CAAC,OAAO,EAAE,YAAY,CAAC;IAC/B,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAS;IACxC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAS;IAC7B,QAAQ,CAAC,WAAW;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;MAAC;gBAGnB,EAAE,EAAE,MAAM,EACV,UAAU,EAAE,UAAU,EACtB,OAAO,EAAE,MAAM,EACf,GAAG,EAAE,MAAM,EACX,WAAW,EAAE,MAAM,EACnB,MAAM,CAAC,EAAE,cAAc;IAczB,KAAK,eAAiB;IAEtB;;;;;OAKG;IACH,mBAAmB,QACZ,MAAM,WAAW,CAAC,SAChB,KAAK,KACX,QAAQ,OAAO,CAAC,CAoEjB;IAEF,SAAS,SAAgB,MAAM,mBAE7B;IAEF;;OAEG;IACH,eAAe,iBAAwB,SAAS,mBA0B9C;IAEF;;;;;OAKG;IACH,wBAAwB,0BACC,MAAM,MAAM,CAAC,iBACrB,MAAM,mBAmBrB;IAEF;;;OAGG;IACH,kBAAkB,UACT,MAAM,KACZ,QAAQ,eAAe,GAAG,SAAS,CAAC,CAQrC;IAEF;;;;OAIG;IACH,oBAAoB,kBACH,MAAM,KACpB,QAAQ,MAAM,eAAe,CAAC,CAAC,CAuBhC;IAEF;;;OAGG;IACH,UAAU,SAAgB,MAAM;;;OAM9B;IAEF;;;;;;;OAOG;IACH,iBAAiB,UAAiB,MAAM,UAAU,CAAC,gCA4BjD;CACH;AAED,eAAe,eAAe,CAAC"}
@@ -225,4 +225,4 @@ class PermitExtractor extends AbstractExtractor {
225
225
  };
226
226
  }
227
227
  export default PermitExtractor;
228
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"permitExtractor.js","sourceRoot":"","sources":["../../lib/extractor/permitExtractor.ts"],"names":[],"mappings":"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","sourcesContent":["import { DataSource } from 'typeorm';\nimport * as wasm from 'ergo-lib-wasm-nodejs';\nimport { Buffer } from 'buffer';\nimport { difference } from 'lodash-es';\nimport * as ergoLib from 'ergo-lib-wasm-nodejs';\nimport { InitialInfo, Transaction } from '@rosen-bridge/scanner';\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport { OutputInfo } from '@rosen-clients/ergo-explorer/dist/src/v1/types/outputInfo';\nimport ergoExplorerClientFactory from '@rosen-clients/ergo-explorer';\nimport { AbstractExtractor, Block } from '@rosen-bridge/abstract-extractor';\n\nimport { DefaultApiLimit } from '../constants';\nimport { JsonBI } from '../utils';\nimport PermitAction from '../actions/permitAction';\nimport { ExtractedPermit } from '../interfaces/extractedPermit';\n\nclass PermitExtractor extends AbstractExtractor<Transaction> {\n  readonly logger: AbstractLogger;\n  id: string;\n  private readonly dataSource: DataSource;\n  readonly actions: PermitAction;\n  private readonly permitErgoTree: string;\n  private readonly RWT: string;\n  readonly explorerApi;\n\n  constructor(\n    id: string,\n    dataSource: DataSource,\n    address: string,\n    RWT: string,\n    explorerUrl: string,\n    logger?: AbstractLogger\n  ) {\n    super();\n    this.id = id;\n    this.dataSource = dataSource;\n    this.permitErgoTree = 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 PermitAction(dataSource, this.logger);\n    this.explorerApi = ergoExplorerClientFactory(explorerUrl);\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: Block\n  ): Promise<boolean> => {\n    return new Promise((resolve, reject) => {\n      try {\n        const boxes: Array<ExtractedPermit> = [];\n        const spendIds: Array<string> = [];\n        txs.forEach((transaction) => {\n          for (const output of transaction.outputs) {\n            try {\n              if (\n                output.additionalRegisters &&\n                output.additionalRegisters.R4 &&\n                output.assets &&\n                output.assets.length > 0 &&\n                output.assets[0].tokenId === this.RWT &&\n                output.ergoTree === this.permitErgoTree\n              ) {\n                const boxOutput = wasm.ErgoBox.from_json(\n                  JsonBI.stringify(output)\n                );\n                const r4 = boxOutput.register_value(\n                  wasm.NonMandatoryRegisterId.R4\n                );\n                if (r4) {\n                  const R4Serialized = r4.to_byte_array();\n                  if (R4Serialized.length >= 1) {\n                    boxes.push({\n                      boxId: output.boxId,\n                      boxSerialized: Buffer.from(\n                        boxOutput.sigma_serialize_bytes()\n                      ).toString('base64'),\n                      WID: Buffer.from(R4Serialized).toString('hex'),\n                      txId: output.transactionId,\n                    });\n                  }\n                }\n              }\n            } catch {\n              // empty\n            }\n          }\n          // process inputs\n          for (const input of transaction.inputs) {\n            spendIds.push(input.boxId);\n          }\n        });\n\n        this.actions\n          .storePermits(boxes, block, this.getId())\n          .then(() => {\n            this.actions\n              .spendPermits(spendIds, block, this.getId())\n              .then(() => {\n                resolve(true);\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   * Initializes the database with older permits related to the address\n   */\n  initializeBoxes = async (initialBlock: InitialInfo) => {\n    let allStoredBoxIds = await this.actions.getAllPermitBoxIds(this.getId());\n    // Extract unspent permits\n    const unspentPermits = await this.getAllUnspentPermits(initialBlock.height);\n    const unspentBoxIds = unspentPermits.map((box) => box.boxId);\n    // Storing extracted permits\n    for (const permit of unspentPermits) {\n      if (allStoredBoxIds.includes(permit.boxId)) {\n        await this.actions.updatePermit(permit, this.getId());\n        this.logger.info(\n          `Updated the existing unspent permit with boxId, [${permit.boxId}]`\n        );\n        this.logger.debug(`Updated permit [${JSON.stringify(permit)}]`);\n      } else {\n        await this.actions.insertPermit(permit, this.getId());\n        this.logger.info(\n          `Inserted new unspent permit with boxId, [${permit.boxId}]`\n        );\n        this.logger.debug(`Inserted permit [${JSON.stringify(permit)}]`);\n      }\n    }\n    // Remove updated permits from existing permits in database\n    allStoredBoxIds = difference(allStoredBoxIds, unspentBoxIds);\n    // Validating remained permits\n    // TODO: Fix validation process\n    // await this.validateOldStoredPermits(allStoredBoxIds, initialHeight);\n  };\n\n  /**\n   * Validate all remaining permits in the database\n   * update the correct ones and remove the invalid ones\n   * @param unchangedStoredBoxIds\n   * @param initialHeight\n   */\n  validateOldStoredPermits = async (\n    unchangedStoredBoxIds: Array<string>,\n    initialHeight: number\n  ) => {\n    for (const boxId of unchangedStoredBoxIds) {\n      const permit = await this.getPermitWithBoxId(boxId);\n      if (permit && permit.spendBlock && permit.spendHeight) {\n        if (permit.spendHeight < initialHeight)\n          await this.actions.updateSpendBlock(\n            boxId,\n            this.getId(),\n            permit.spendBlock,\n            permit.spendHeight\n          );\n      } else {\n        await this.actions.removePermit(boxId, this.getId());\n        this.logger.info(\n          `Removed invalid box [${boxId}] in initialization validation`\n        );\n      }\n    }\n  };\n\n  /**\n   * Return extracted permit from a box\n   * @param boxId\n   */\n  getPermitWithBoxId = async (\n    boxId: string\n  ): Promise<ExtractedPermit | undefined> => {\n    try {\n      const box = await this.explorerApi.v1.getApiV1BoxesP1(boxId);\n      return (await this.extractPermitData([box]))[0];\n    } catch {\n      this.logger.warn(`Permit with boxId ${boxId} does not exist`);\n      return undefined;\n    }\n  };\n\n  /**\n   * Return all unspent permits\n   * @param initialHeight\n   * @returns\n   */\n  getAllUnspentPermits = async (\n    initialHeight: number\n  ): Promise<Array<ExtractedPermit>> => {\n    let extractedBoxes: Array<ExtractedPermit> = [];\n    let offset = 0,\n      total = DefaultApiLimit;\n    while (offset < total) {\n      const boxes = await this.explorerApi.v1.getApiV1BoxesUnspentByergotreeP1(\n        this.permitErgoTree,\n        { offset: offset, limit: DefaultApiLimit }\n      );\n      if (!boxes.items) {\n        this.logger.warn('Explorer api output items should not be undefined.');\n        throw new Error('Incorrect explorer api output');\n      }\n      const filteredBoxes = await this.extractPermitData(\n        boxes.items.filter(\n          (box) => box.creationHeight && box.creationHeight < initialHeight\n        )\n      );\n      extractedBoxes = [...extractedBoxes, ...filteredBoxes];\n      total = boxes.total;\n      offset += DefaultApiLimit;\n    }\n    return extractedBoxes;\n  };\n\n  /**\n   * Returns block information of tx\n   * @param txId\n   */\n  getTxBlock = async (txId: string) => {\n    const tx = await this.explorerApi.v1.getApiV1TransactionsP1(txId);\n    return {\n      id: tx.blockId,\n      height: tx.inclusionHeight,\n    };\n  };\n\n  /**\n   * Extract permit data from json boxes\n   * and filter to fit in a specified height range\n   * @param boxes\n   * @param toHeight\n   * @param heightDifference\n   * @returns extracted permit\n   */\n  extractPermitData = async (boxes: Array<OutputInfo>) => {\n    const extractedBoxes: Array<ExtractedPermit> = [];\n    for (const boxJson of boxes) {\n      const box = ergoLib.ErgoBox.from_json(JsonBI.stringify(boxJson));\n      const r4 = box.register_value(4);\n      if (r4) {\n        const R4Serialized = r4.to_byte_array();\n        let spendBlock, spendHeight;\n        if (boxJson.spentTransactionId) {\n          const block = await this.getTxBlock(boxJson.spentTransactionId);\n          spendBlock = block.id;\n          spendHeight = block.height;\n        }\n        extractedBoxes.push({\n          boxId: box.box_id().to_str(),\n          boxSerialized: Buffer.from(box.sigma_serialize_bytes()).toString(\n            'base64'\n          ),\n          block: boxJson.blockId,\n          height: boxJson.settlementHeight,\n          WID: Buffer.from(R4Serialized).toString('hex'),\n          txId: box.tx_id().to_str(),\n          spendBlock: spendBlock,\n          spendHeight: spendHeight,\n        });\n      }\n    }\n    return extractedBoxes;\n  };\n}\n\nexport default PermitExtractor;\n"]}
228
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"permitExtractor.js","sourceRoot":"","sources":["../../lib/extractor/permitExtractor.ts"],"names":[],"mappings":"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","sourcesContent":["import { DataSource } from 'typeorm';\nimport * as wasm from 'ergo-lib-wasm-nodejs';\nimport { Buffer } from 'buffer';\nimport { difference } from 'lodash-es';\nimport * as ergoLib from 'ergo-lib-wasm-nodejs';\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport { OutputInfo } from '@rosen-clients/ergo-explorer/dist/src/v1/types/outputInfo';\nimport ergoExplorerClientFactory from '@rosen-clients/ergo-explorer';\nimport {\n  Block,\n  BlockInfo,\n  Transaction,\n} from '@rosen-bridge/scanner-interfaces';\nimport { AbstractExtractor } from '@rosen-bridge/abstract-extractor';\n\nimport { DefaultApiLimit } from '../constants';\nimport { JsonBI } from '../utils';\nimport PermitAction from '../actions/permitAction';\nimport { ExtractedPermit } from '../interfaces/extractedPermit';\n\nclass PermitExtractor extends AbstractExtractor<Transaction> {\n  readonly logger: AbstractLogger;\n  id: string;\n  private readonly dataSource: DataSource;\n  readonly actions: PermitAction;\n  private readonly permitErgoTree: string;\n  private readonly RWT: string;\n  readonly explorerApi;\n\n  constructor(\n    id: string,\n    dataSource: DataSource,\n    address: string,\n    RWT: string,\n    explorerUrl: string,\n    logger?: AbstractLogger\n  ) {\n    super();\n    this.id = id;\n    this.dataSource = dataSource;\n    this.permitErgoTree = 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 PermitAction(dataSource, this.logger);\n    this.explorerApi = ergoExplorerClientFactory(explorerUrl);\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: Block\n  ): Promise<boolean> => {\n    return new Promise((resolve, reject) => {\n      try {\n        const boxes: Array<ExtractedPermit> = [];\n        const spendIds: Array<string> = [];\n        txs.forEach((transaction) => {\n          for (const output of transaction.outputs) {\n            try {\n              if (\n                output.additionalRegisters &&\n                output.additionalRegisters.R4 &&\n                output.assets &&\n                output.assets.length > 0 &&\n                output.assets[0].tokenId === this.RWT &&\n                output.ergoTree === this.permitErgoTree\n              ) {\n                const boxOutput = wasm.ErgoBox.from_json(\n                  JsonBI.stringify(output)\n                );\n                const r4 = boxOutput.register_value(\n                  wasm.NonMandatoryRegisterId.R4\n                );\n                if (r4) {\n                  const R4Serialized = r4.to_byte_array();\n                  if (R4Serialized.length >= 1) {\n                    boxes.push({\n                      boxId: output.boxId,\n                      boxSerialized: Buffer.from(\n                        boxOutput.sigma_serialize_bytes()\n                      ).toString('base64'),\n                      WID: Buffer.from(R4Serialized).toString('hex'),\n                      txId: output.transactionId,\n                    });\n                  }\n                }\n              }\n            } catch {\n              // empty\n            }\n          }\n          // process inputs\n          for (const input of transaction.inputs) {\n            spendIds.push(input.boxId);\n          }\n        });\n\n        this.actions\n          .storePermits(boxes, block, this.getId())\n          .then(() => {\n            this.actions\n              .spendPermits(spendIds, block, this.getId())\n              .then(() => {\n                resolve(true);\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   * Initializes the database with older permits related to the address\n   */\n  initializeBoxes = async (initialBlock: BlockInfo) => {\n    let allStoredBoxIds = await this.actions.getAllPermitBoxIds(this.getId());\n    // Extract unspent permits\n    const unspentPermits = await this.getAllUnspentPermits(initialBlock.height);\n    const unspentBoxIds = unspentPermits.map((box) => box.boxId);\n    // Storing extracted permits\n    for (const permit of unspentPermits) {\n      if (allStoredBoxIds.includes(permit.boxId)) {\n        await this.actions.updatePermit(permit, this.getId());\n        this.logger.info(\n          `Updated the existing unspent permit with boxId, [${permit.boxId}]`\n        );\n        this.logger.debug(`Updated permit [${JSON.stringify(permit)}]`);\n      } else {\n        await this.actions.insertPermit(permit, this.getId());\n        this.logger.info(\n          `Inserted new unspent permit with boxId, [${permit.boxId}]`\n        );\n        this.logger.debug(`Inserted permit [${JSON.stringify(permit)}]`);\n      }\n    }\n    // Remove updated permits from existing permits in database\n    allStoredBoxIds = difference(allStoredBoxIds, unspentBoxIds);\n    // Validating remained permits\n    // TODO: Fix validation process\n    // await this.validateOldStoredPermits(allStoredBoxIds, initialHeight);\n  };\n\n  /**\n   * Validate all remaining permits in the database\n   * update the correct ones and remove the invalid ones\n   * @param unchangedStoredBoxIds\n   * @param initialHeight\n   */\n  validateOldStoredPermits = async (\n    unchangedStoredBoxIds: Array<string>,\n    initialHeight: number\n  ) => {\n    for (const boxId of unchangedStoredBoxIds) {\n      const permit = await this.getPermitWithBoxId(boxId);\n      if (permit && permit.spendBlock && permit.spendHeight) {\n        if (permit.spendHeight < initialHeight)\n          await this.actions.updateSpendBlock(\n            boxId,\n            this.getId(),\n            permit.spendBlock,\n            permit.spendHeight\n          );\n      } else {\n        await this.actions.removePermit(boxId, this.getId());\n        this.logger.info(\n          `Removed invalid box [${boxId}] in initialization validation`\n        );\n      }\n    }\n  };\n\n  /**\n   * Return extracted permit from a box\n   * @param boxId\n   */\n  getPermitWithBoxId = async (\n    boxId: string\n  ): Promise<ExtractedPermit | undefined> => {\n    try {\n      const box = await this.explorerApi.v1.getApiV1BoxesP1(boxId);\n      return (await this.extractPermitData([box]))[0];\n    } catch {\n      this.logger.warn(`Permit with boxId ${boxId} does not exist`);\n      return undefined;\n    }\n  };\n\n  /**\n   * Return all unspent permits\n   * @param initialHeight\n   * @returns\n   */\n  getAllUnspentPermits = async (\n    initialHeight: number\n  ): Promise<Array<ExtractedPermit>> => {\n    let extractedBoxes: Array<ExtractedPermit> = [];\n    let offset = 0,\n      total = DefaultApiLimit;\n    while (offset < total) {\n      const boxes = await this.explorerApi.v1.getApiV1BoxesUnspentByergotreeP1(\n        this.permitErgoTree,\n        { offset: offset, limit: DefaultApiLimit }\n      );\n      if (!boxes.items) {\n        this.logger.warn('Explorer api output items should not be undefined.');\n        throw new Error('Incorrect explorer api output');\n      }\n      const filteredBoxes = await this.extractPermitData(\n        boxes.items.filter(\n          (box) => box.creationHeight && box.creationHeight < initialHeight\n        )\n      );\n      extractedBoxes = [...extractedBoxes, ...filteredBoxes];\n      total = boxes.total;\n      offset += DefaultApiLimit;\n    }\n    return extractedBoxes;\n  };\n\n  /**\n   * Returns block information of tx\n   * @param txId\n   */\n  getTxBlock = async (txId: string) => {\n    const tx = await this.explorerApi.v1.getApiV1TransactionsP1(txId);\n    return {\n      id: tx.blockId,\n      height: tx.inclusionHeight,\n    };\n  };\n\n  /**\n   * Extract permit data from json boxes\n   * and filter to fit in a specified height range\n   * @param boxes\n   * @param toHeight\n   * @param heightDifference\n   * @returns extracted permit\n   */\n  extractPermitData = async (boxes: Array<OutputInfo>) => {\n    const extractedBoxes: Array<ExtractedPermit> = [];\n    for (const boxJson of boxes) {\n      const box = ergoLib.ErgoBox.from_json(JsonBI.stringify(boxJson));\n      const r4 = box.register_value(4);\n      if (r4) {\n        const R4Serialized = r4.to_byte_array();\n        let spendBlock, spendHeight;\n        if (boxJson.spentTransactionId) {\n          const block = await this.getTxBlock(boxJson.spentTransactionId);\n          spendBlock = block.id;\n          spendHeight = block.height;\n        }\n        extractedBoxes.push({\n          boxId: box.box_id().to_str(),\n          boxSerialized: Buffer.from(box.sigma_serialize_bytes()).toString(\n            'base64'\n          ),\n          block: boxJson.blockId,\n          height: boxJson.settlementHeight,\n          WID: Buffer.from(R4Serialized).toString('hex'),\n          txId: box.tx_id().to_str(),\n          spendBlock: spendBlock,\n          spendHeight: spendHeight,\n        });\n      }\n    }\n    return extractedBoxes;\n  };\n}\n\nexport default PermitExtractor;\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@rosen-bridge/watcher-data-extractor",
3
- "version": "12.0.0",
3
+ "version": "12.1.0",
4
4
  "description": "Extractor for rosen specific boxes on ergo blockchain",
5
5
  "author": "Rosen Team",
6
6
  "license": "GPL-3.0",
@@ -19,12 +19,12 @@
19
19
  "dist"
20
20
  ],
21
21
  "dependencies": {
22
- "@rosen-bridge/abstract-extractor": "^1.0.2",
22
+ "@rosen-bridge/abstract-extractor": "^2.0.0",
23
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.1.0",
27
- "@rosen-bridge/tokens": "^3.0.0",
26
+ "@rosen-bridge/scanner-interfaces": "^0.1.0",
27
+ "@rosen-bridge/tokens": "^3.1.0",
28
28
  "@rosen-clients/ergo-explorer": "^1.1.1",
29
29
  "@types/lodash-es": "^4.17.6",
30
30
  "blakejs": "^1.2.1",
@@ -39,6 +39,7 @@
39
39
  "type": "module",
40
40
  "devDependencies": {
41
41
  "@babel/preset-env": "^7.19.0",
42
+ "@rosen-bridge/scanner": "^6.0.0",
42
43
  "@types/jest": "^28.1.6",
43
44
  "@types/json-bigint": "^1.0.1",
44
45
  "@types/node": "^20.11.9",