@rosen-bridge/watcher-data-extractor 10.0.0 → 12.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -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: 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 { 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"]}
@@ -2,7 +2,7 @@ import { DataSource } from 'typeorm';
2
2
  import { Transaction } from '@rosen-bridge/scanner';
3
3
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
4
4
  import { AbstractExtractor, Block } from '@rosen-bridge/abstract-extractor';
5
- import { RosenTokens } from '@rosen-bridge/tokens';
5
+ import { TokenMap } from '@rosen-bridge/tokens';
6
6
  declare class CommitmentExtractor extends AbstractExtractor<Transaction> {
7
7
  readonly logger: AbstractLogger;
8
8
  id: string;
@@ -11,7 +11,7 @@ declare class CommitmentExtractor extends AbstractExtractor<Transaction> {
11
11
  private readonly RWTId;
12
12
  private readonly actions;
13
13
  private readonly tokenMap;
14
- constructor(id: string, addresses: Array<string>, RWTId: string, dataSource: DataSource, tokens: RosenTokens, logger?: AbstractLogger);
14
+ constructor(id: string, addresses: Array<string>, RWTId: string, dataSource: DataSource, tokens: TokenMap, logger?: AbstractLogger);
15
15
  /**
16
16
  * get Id for current extractor
17
17
  */
@@ -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,WAAW,EAAY,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,WAAW,EACnB,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,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"}
@@ -3,7 +3,6 @@ import { DummyLogger } from '@rosen-bridge/abstract-logger';
3
3
  import { AbstractExtractor } from '@rosen-bridge/abstract-extractor';
4
4
  import CommitmentAction from '../actions/commitmentAction';
5
5
  import { JsonBI } from '../utils';
6
- import { TokenMap } from '@rosen-bridge/tokens';
7
6
  class CommitmentExtractor extends AbstractExtractor {
8
7
  logger;
9
8
  id;
@@ -20,7 +19,7 @@ class CommitmentExtractor extends AbstractExtractor {
20
19
  this.RWTId = RWTId;
21
20
  this.logger = logger ? logger : new DummyLogger();
22
21
  this.actions = new CommitmentAction(dataSource, this.logger);
23
- this.tokenMap = new TokenMap(tokens);
22
+ this.tokenMap = tokens;
24
23
  }
25
24
  /**
26
25
  * get Id for current extractor
@@ -116,4 +115,4 @@ class CommitmentExtractor extends AbstractExtractor {
116
115
  };
117
116
  }
118
117
  export default CommitmentExtractor;
119
- //# 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: RosenTokens,\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 = new 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 { 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"]}
@@ -1,7 +1,7 @@
1
- import { Migration1737785036299 } from './postgres/1737785036299-migration';
1
+ import { migration1688554842087 } from './postgres/1688554842087-migration';
2
2
  import { migration1688555766601 } from './sqlite/1688555766601-migration';
3
3
  export declare const migrations: {
4
4
  sqlite: (typeof migration1688555766601)[];
5
- postgres: (typeof Migration1737785036299)[];
5
+ postgres: (typeof migration1688554842087)[];
6
6
  };
7
7
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../lib/migrations/index.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,sBAAsB,EAAE,MAAM,oCAAoC,CAAC;AAC5E,OAAO,EAAE,sBAAsB,EAAE,MAAM,kCAAkC,CAAC;AAO1E,eAAO,MAAM,UAAU;;;CAiBtB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../lib/migrations/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,oCAAoC,CAAC;AAM5E,OAAO,EAAE,sBAAsB,EAAE,MAAM,kCAAkC,CAAC;AAO1E,eAAO,MAAM,UAAU;;;CAiBtB,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@rosen-bridge/watcher-data-extractor",
3
- "version": "10.0.0",
3
+ "version": "12.0.0",
4
4
  "description": "Extractor for rosen specific boxes on ergo blockchain",
5
5
  "author": "Rosen Team",
6
6
  "license": "GPL-3.0",
@@ -19,12 +19,12 @@
19
19
  "dist"
20
20
  ],
21
21
  "dependencies": {
22
- "@rosen-bridge/abstract-extractor": "^1.0.0",
22
+ "@rosen-bridge/abstract-extractor": "^1.0.2",
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.0.1",
27
- "@rosen-bridge/tokens": "^1.2.1",
26
+ "@rosen-bridge/scanner": "^5.1.0",
27
+ "@rosen-bridge/tokens": "^3.0.0",
28
28
  "@rosen-clients/ergo-explorer": "^1.1.1",
29
29
  "@types/lodash-es": "^4.17.6",
30
30
  "blakejs": "^1.2.1",
@@ -41,7 +41,7 @@
41
41
  "@babel/preset-env": "^7.19.0",
42
42
  "@types/jest": "^28.1.6",
43
43
  "@types/json-bigint": "^1.0.1",
44
- "@types/node": "^18.0.6",
44
+ "@types/node": "^20.11.9",
45
45
  "@typescript-eslint/eslint-plugin": "^5.30.7",
46
46
  "@typescript-eslint/parser": "^5.26.0",
47
47
  "eslint": "^8.16.0",
@@ -51,5 +51,8 @@
51
51
  "ts-jest": "^28.0.7",
52
52
  "ts-node": "^10.9.1",
53
53
  "typescript": "^4.7.4"
54
+ },
55
+ "engines": {
56
+ "node": ">=20.11.0"
54
57
  }
55
58
  }