@rosen-bridge/watcher-data-extractor 12.1.2 → 12.1.4

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 +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;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"}
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;IAsDrC;;;;;;;OAOG;IACH,OAAO,CAAC,wBAAwB,CAiC9B;IAEF;;;;;;;OAOG;IACH,OAAO,CAAC,qBAAqB,CAgD3B;CACH"}
@@ -138,12 +138,12 @@ export class CollateralExtractor extends AbstractExtractor {
138
138
  boxInfo = await this.explorerApi.v1.getApiV1BoxesP1(boxId);
139
139
  }
140
140
  catch (e) {
141
- if (e?.response?.status === 404) {
141
+ if (e.response?.status === 404) {
142
142
  await this.action.deleteCollateral(boxId, this.getId());
143
143
  continue;
144
144
  }
145
145
  else {
146
- throw new Error(`something went wrong when trying to get box=[${boxId}] from Ergo network: ${e?.message}`);
146
+ throw new Error(`something went wrong when trying to get box=[${boxId}] from Ergo network: ${e.message}`);
147
147
  }
148
148
  }
149
149
  if (boxInfo?.spentTransactionId != null) {
@@ -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 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"]}
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) {\n        if ((e as { response: { status: number } }).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: ${\n              (e as Error).message\n            }`\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) {\n          throw new Error(\n            `something went wrong when trying to get transaction=[${\n              boxInfo.spentTransactionId\n            }] from Ergo network: ${(e as Error)?.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
- import { migration1688554842087 } from './postgres/1688554842087-migration';
1
+ import { migration1706610773315 } from './postgres/1706610773315-migration';
2
2
  import { migration1688555766601 } from './sqlite/1688555766601-migration';
3
3
  export declare const migrations: {
4
4
  sqlite: (typeof migration1688555766601)[];
5
- postgres: (typeof migration1688554842087)[];
5
+ postgres: (typeof migration1706610773315)[];
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":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,oCAAoC,CAAC;AAO5E,OAAO,EAAE,sBAAsB,EAAE,MAAM,kCAAkC,CAAC;AAQ1E,eAAO,MAAM,UAAU;;;CAmBtB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../lib/migrations/index.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,sBAAsB,EAAE,MAAM,oCAAoC,CAAC;AAI5E,OAAO,EAAE,sBAAsB,EAAE,MAAM,kCAAkC,CAAC;AAQ1E,eAAO,MAAM,UAAU;;;CAmBtB,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"1706610773315-migration.d.ts","sourceRoot":"","sources":["../../../lib/migrations/postgres/1706610773315-migration.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAG1D,qBAAa,sBAAuB,YAAW,kBAAkB;IAC/D,IAAI,SAA4B;IAEnB,EAAE,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IA6C3C,IAAI,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;CAsB3D"}
1
+ {"version":3,"file":"1706610773315-migration.d.ts","sourceRoot":"","sources":["../../../lib/migrations/postgres/1706610773315-migration.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAG1D,qBAAa,sBAAuB,YAAW,kBAAkB;IAC/D,IAAI,SAA4B;IAEnB,EAAE,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IA+C3C,IAAI,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;CAsB3D"}
@@ -66,4 +66,4 @@ export class migration1706610773315 {
66
66
  `);
67
67
  }
68
68
  }
69
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTcwNjYxMDc3MzMxNS1taWdyYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9saWIvbWlncmF0aW9ucy9wb3N0Z3Jlcy8xNzA2NjEwNzczMzE1LW1pZ3JhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRXpDLE1BQU0sT0FBTyxzQkFBc0I7SUFDakMsSUFBSSxHQUFHLHdCQUF3QixDQUFDO0lBRXpCLEtBQUssQ0FBQyxFQUFFLENBQUMsV0FBd0I7UUFDdEMsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOzs7U0FHbkIsQ0FBQyxDQUFDO1FBQ1AsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOzs7U0FHbkIsQ0FBQyxDQUFDO1FBQ1AsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOzs7U0FHbkIsQ0FBQyxDQUFDO1FBQ1AsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOzs7U0FHbkIsQ0FBQyxDQUFDO1FBQ1AsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOzs7U0FHbkIsQ0FBQyxDQUFDO1FBQ1AsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOzs7U0FHbkIsQ0FBQyxDQUFDO1FBRVAsNkNBQTZDO1FBQzdDLE1BQU0sTUFBTSxHQUFHLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7U0FFbEMsQ0FBQyxDQUFDO1FBQ1AseUVBQXlFO1FBQ3pFLEtBQUssTUFBTSxLQUFLLElBQUksTUFBTSxFQUFFO1lBQzFCLE1BQU0sRUFBRSxRQUFRLEVBQUUsU0FBUyxFQUFFLEdBQUcsVUFBVSxDQUFFLEtBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUNoRSxNQUFNLFdBQVcsQ0FBQyxLQUFLLENBQUM7O2dDQUVFLFFBQVEscUJBQXFCLFNBQVM7MkJBQzNDLEtBQUssQ0FBQyxFQUFFO1NBQzFCLENBQUMsQ0FBQztTQUNOO1FBRUQsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOztTQUVuQixDQUFDLENBQUM7SUFDVCxDQUFDO0lBRU0sS0FBSyxDQUFDLElBQUksQ0FBQyxXQUF3QjtRQUN4QyxNQUFNLFdBQVcsQ0FBQyxLQUFLLENBQUM7O1NBRW5CLENBQUMsQ0FBQztRQUNQLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7U0FFbkIsQ0FBQyxDQUFDO1FBQ1AsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOztTQUVuQixDQUFDLENBQUM7UUFDUCxNQUFNLFdBQVcsQ0FBQyxLQUFLLENBQUM7O1NBRW5CLENBQUMsQ0FBQztRQUNQLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7O1NBR25CLENBQUMsQ0FBQztRQUNQLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7O1NBR25CLENBQUMsQ0FBQztJQUNULENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1pZ3JhdGlvbkludGVyZmFjZSwgUXVlcnlSdW5uZXIgfSBmcm9tICd0eXBlb3JtJztcbmltcG9ydCB7IGdldFdpZEluZm8gfSBmcm9tICcuLi8uLi91dGlscyc7XG5cbmV4cG9ydCBjbGFzcyBtaWdyYXRpb24xNzA2NjEwNzczMzE1IGltcGxlbWVudHMgTWlncmF0aW9uSW50ZXJmYWNlIHtcbiAgbmFtZSA9ICdtaWdyYXRpb24xNzA2NjEwNzczMzE1JztcblxuICBwdWJsaWMgYXN5bmMgdXAocXVlcnlSdW5uZXI6IFF1ZXJ5UnVubmVyKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgQUxURVIgVEFCTEUgXCJldmVudF90cmlnZ2VyX2VudGl0eVwiXG4gICAgICAgICAgICBBREQgXCJXSURzQ291bnRcIiBpbnRlZ2VyIE5PVCBOVUxMIERFRkFVTFQgMFxuICAgICAgICBgKTtcbiAgICBhd2FpdCBxdWVyeVJ1bm5lci5xdWVyeShgXG4gICAgICAgICAgICBBTFRFUiBUQUJMRSBcImV2ZW50X3RyaWdnZXJfZW50aXR5XCJcbiAgICAgICAgICAgIEFERCBcIldJRHNIYXNoXCIgY2hhcmFjdGVyIHZhcnlpbmcgTk9UIE5VTEwgREVGQVVMVCAnJ1xuICAgICAgICBgKTtcbiAgICBhd2FpdCBxdWVyeVJ1bm5lci5xdWVyeShgXG4gICAgICAgICAgICBBTFRFUiBUQUJMRSBcImV2ZW50X3RyaWdnZXJfZW50aXR5XCJcbiAgICAgICAgICAgIEFMVEVSIFwiV0lEc0NvdW50XCIgRFJPUCBERUZBVUxUXG4gICAgICAgIGApO1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIEFMVEVSIFRBQkxFIFwiZXZlbnRfdHJpZ2dlcl9lbnRpdHlcIlxuICAgICAgICAgICAgQUxURVIgXCJXSURzSGFzaFwiIERST1AgREVGQVVMVFxuICAgICAgICBgKTtcbiAgICBhd2FpdCBxdWVyeVJ1bm5lci5xdWVyeShgXG4gICAgICAgICAgICBBTFRFUiBUQUJMRSBcImNvbW1pdG1lbnRfZW50aXR5XCJcbiAgICAgICAgICAgIEFERCBcInNwZW5kVHhJZFwiIHRleHRcbiAgICAgICAgYCk7XG4gICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgQUxURVIgVEFCTEUgXCJjb21taXRtZW50X2VudGl0eVwiXG4gICAgICAgICAgICBBREQgXCJzcGVuZEluZGV4XCIgaW50ZWdlclxuICAgICAgICBgKTtcblxuICAgIC8vIGdldCBhbGwgZXZlbnRzIGJlZm9yZSByZW1vdmluZyBXSURzIGNvbHVtblxuICAgIGNvbnN0IGV2ZW50cyA9IGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIFNFTEVDVCBcImlkXCIsIFwiV0lEc1wiIGZyb20gXCJldmVudF90cmlnZ2VyX2VudGl0eVwiXG4gICAgICAgIGApO1xuICAgIC8vIGNhbGN1bGF0ZSBgV0lEc0NvdW50YCBhbmQgYFdJRHNIYXNoYCBjb2x1bW5zIGluIGBldmVudF90cmlnZ2VyX2VudGl0eWBcbiAgICBmb3IgKGNvbnN0IGV2ZW50IG9mIGV2ZW50cykge1xuICAgICAgY29uc3QgeyBXSURzSGFzaCwgV0lEc0NvdW50IH0gPSBnZXRXaWRJbmZvKChldmVudCBhcyBhbnkpLldJRHMpO1xuICAgICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgVVBEQVRFIFwiZXZlbnRfdHJpZ2dlcl9lbnRpdHlcIlxuICAgICAgICAgICAgU0VUIFwiV0lEc0hhc2hcIiA9ICcke1dJRHNIYXNofScsIFwiV0lEc0NvdW50XCIgPSAnJHtXSURzQ291bnR9J1xuICAgICAgICAgICAgV0hFUkUgXCJpZFwiID0gJHtldmVudC5pZH1cbiAgICAgICAgYCk7XG4gICAgfVxuXG4gICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgQUxURVIgVEFCTEUgXCJldmVudF90cmlnZ2VyX2VudGl0eVwiIERST1AgQ09MVU1OIFwiV0lEc1wiXG4gICAgICAgIGApO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIGRvd24ocXVlcnlSdW5uZXI6IFF1ZXJ5UnVubmVyKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgQUxURVIgVEFCTEUgXCJjb21taXRtZW50X2VudGl0eVwiIERST1AgQ09MVU1OIFwic3BlbmRJbmRleFwiXG4gICAgICAgIGApO1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIEFMVEVSIFRBQkxFIFwiY29tbWl0bWVudF9lbnRpdHlcIiBEUk9QIENPTFVNTiBcInNwZW5kVHhJZFwiXG4gICAgICAgIGApO1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIEFMVEVSIFRBQkxFIFwiZXZlbnRfdHJpZ2dlcl9lbnRpdHlcIiBEUk9QIENPTFVNTiBcIldJRHNIYXNoXCJcbiAgICAgICAgYCk7XG4gICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgQUxURVIgVEFCTEUgXCJldmVudF90cmlnZ2VyX2VudGl0eVwiIERST1AgQ09MVU1OIFwiV0lEc0NvdW50XCJcbiAgICAgICAgYCk7XG4gICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgQUxURVIgVEFCTEUgXCJldmVudF90cmlnZ2VyX2VudGl0eVwiXG4gICAgICAgICAgICBBREQgXCJXSURzXCIgY2hhcmFjdGVyIHZhcnlpbmcgTk9UIE5VTEwgREVGQVVMVCAnJ1xuICAgICAgICBgKTtcbiAgICBhd2FpdCBxdWVyeVJ1bm5lci5xdWVyeShgXG4gICAgICAgICAgICBBTFRFUiBUQUJMRSBcImV2ZW50X3RyaWdnZXJfZW50aXR5XCJcbiAgICAgICAgICAgIEFMVEVSIFwiV0lEc1wiIERST1AgREVGQVVMVFxuICAgICAgICBgKTtcbiAgfVxufVxuIl19
69
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTcwNjYxMDc3MzMxNS1taWdyYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9saWIvbWlncmF0aW9ucy9wb3N0Z3Jlcy8xNzA2NjEwNzczMzE1LW1pZ3JhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRXpDLE1BQU0sT0FBTyxzQkFBc0I7SUFDakMsSUFBSSxHQUFHLHdCQUF3QixDQUFDO0lBRXpCLEtBQUssQ0FBQyxFQUFFLENBQUMsV0FBd0I7UUFDdEMsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOzs7U0FHbkIsQ0FBQyxDQUFDO1FBQ1AsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOzs7U0FHbkIsQ0FBQyxDQUFDO1FBQ1AsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOzs7U0FHbkIsQ0FBQyxDQUFDO1FBQ1AsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOzs7U0FHbkIsQ0FBQyxDQUFDO1FBQ1AsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOzs7U0FHbkIsQ0FBQyxDQUFDO1FBQ1AsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOzs7U0FHbkIsQ0FBQyxDQUFDO1FBRVAsNkNBQTZDO1FBQzdDLE1BQU0sTUFBTSxHQUFHLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7U0FFbEMsQ0FBQyxDQUFDO1FBQ1AseUVBQXlFO1FBQ3pFLEtBQUssTUFBTSxLQUFLLElBQUksTUFBTSxFQUFFO1lBQzFCLE1BQU0sRUFBRSxRQUFRLEVBQUUsU0FBUyxFQUFFLEdBQUcsVUFBVSxDQUN2QyxLQUEwQixDQUFDLElBQUksQ0FDakMsQ0FBQztZQUNGLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7Z0NBRUUsUUFBUSxxQkFBcUIsU0FBUzsyQkFDM0MsS0FBSyxDQUFDLEVBQUU7U0FDMUIsQ0FBQyxDQUFDO1NBQ047UUFFRCxNQUFNLFdBQVcsQ0FBQyxLQUFLLENBQUM7O1NBRW5CLENBQUMsQ0FBQztJQUNULENBQUM7SUFFTSxLQUFLLENBQUMsSUFBSSxDQUFDLFdBQXdCO1FBQ3hDLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7U0FFbkIsQ0FBQyxDQUFDO1FBQ1AsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOztTQUVuQixDQUFDLENBQUM7UUFDUCxNQUFNLFdBQVcsQ0FBQyxLQUFLLENBQUM7O1NBRW5CLENBQUMsQ0FBQztRQUNQLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7U0FFbkIsQ0FBQyxDQUFDO1FBQ1AsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOzs7U0FHbkIsQ0FBQyxDQUFDO1FBQ1AsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOzs7U0FHbkIsQ0FBQyxDQUFDO0lBQ1QsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWlncmF0aW9uSW50ZXJmYWNlLCBRdWVyeVJ1bm5lciB9IGZyb20gJ3R5cGVvcm0nO1xuaW1wb3J0IHsgZ2V0V2lkSW5mbyB9IGZyb20gJy4uLy4uL3V0aWxzJztcblxuZXhwb3J0IGNsYXNzIG1pZ3JhdGlvbjE3MDY2MTA3NzMzMTUgaW1wbGVtZW50cyBNaWdyYXRpb25JbnRlcmZhY2Uge1xuICBuYW1lID0gJ21pZ3JhdGlvbjE3MDY2MTA3NzMzMTUnO1xuXG4gIHB1YmxpYyBhc3luYyB1cChxdWVyeVJ1bm5lcjogUXVlcnlSdW5uZXIpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBhd2FpdCBxdWVyeVJ1bm5lci5xdWVyeShgXG4gICAgICAgICAgICBBTFRFUiBUQUJMRSBcImV2ZW50X3RyaWdnZXJfZW50aXR5XCJcbiAgICAgICAgICAgIEFERCBcIldJRHNDb3VudFwiIGludGVnZXIgTk9UIE5VTEwgREVGQVVMVCAwXG4gICAgICAgIGApO1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIEFMVEVSIFRBQkxFIFwiZXZlbnRfdHJpZ2dlcl9lbnRpdHlcIlxuICAgICAgICAgICAgQUREIFwiV0lEc0hhc2hcIiBjaGFyYWN0ZXIgdmFyeWluZyBOT1QgTlVMTCBERUZBVUxUICcnXG4gICAgICAgIGApO1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIEFMVEVSIFRBQkxFIFwiZXZlbnRfdHJpZ2dlcl9lbnRpdHlcIlxuICAgICAgICAgICAgQUxURVIgXCJXSURzQ291bnRcIiBEUk9QIERFRkFVTFRcbiAgICAgICAgYCk7XG4gICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgQUxURVIgVEFCTEUgXCJldmVudF90cmlnZ2VyX2VudGl0eVwiXG4gICAgICAgICAgICBBTFRFUiBcIldJRHNIYXNoXCIgRFJPUCBERUZBVUxUXG4gICAgICAgIGApO1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIEFMVEVSIFRBQkxFIFwiY29tbWl0bWVudF9lbnRpdHlcIlxuICAgICAgICAgICAgQUREIFwic3BlbmRUeElkXCIgdGV4dFxuICAgICAgICBgKTtcbiAgICBhd2FpdCBxdWVyeVJ1bm5lci5xdWVyeShgXG4gICAgICAgICAgICBBTFRFUiBUQUJMRSBcImNvbW1pdG1lbnRfZW50aXR5XCJcbiAgICAgICAgICAgIEFERCBcInNwZW5kSW5kZXhcIiBpbnRlZ2VyXG4gICAgICAgIGApO1xuXG4gICAgLy8gZ2V0IGFsbCBldmVudHMgYmVmb3JlIHJlbW92aW5nIFdJRHMgY29sdW1uXG4gICAgY29uc3QgZXZlbnRzID0gYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgU0VMRUNUIFwiaWRcIiwgXCJXSURzXCIgZnJvbSBcImV2ZW50X3RyaWdnZXJfZW50aXR5XCJcbiAgICAgICAgYCk7XG4gICAgLy8gY2FsY3VsYXRlIGBXSURzQ291bnRgIGFuZCBgV0lEc0hhc2hgIGNvbHVtbnMgaW4gYGV2ZW50X3RyaWdnZXJfZW50aXR5YFxuICAgIGZvciAoY29uc3QgZXZlbnQgb2YgZXZlbnRzKSB7XG4gICAgICBjb25zdCB7IFdJRHNIYXNoLCBXSURzQ291bnQgfSA9IGdldFdpZEluZm8oXG4gICAgICAgIChldmVudCBhcyB7IFdJRHM6IHN0cmluZyB9KS5XSURzXG4gICAgICApO1xuICAgICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgVVBEQVRFIFwiZXZlbnRfdHJpZ2dlcl9lbnRpdHlcIlxuICAgICAgICAgICAgU0VUIFwiV0lEc0hhc2hcIiA9ICcke1dJRHNIYXNofScsIFwiV0lEc0NvdW50XCIgPSAnJHtXSURzQ291bnR9J1xuICAgICAgICAgICAgV0hFUkUgXCJpZFwiID0gJHtldmVudC5pZH1cbiAgICAgICAgYCk7XG4gICAgfVxuXG4gICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgQUxURVIgVEFCTEUgXCJldmVudF90cmlnZ2VyX2VudGl0eVwiIERST1AgQ09MVU1OIFwiV0lEc1wiXG4gICAgICAgIGApO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIGRvd24ocXVlcnlSdW5uZXI6IFF1ZXJ5UnVubmVyKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgQUxURVIgVEFCTEUgXCJjb21taXRtZW50X2VudGl0eVwiIERST1AgQ09MVU1OIFwic3BlbmRJbmRleFwiXG4gICAgICAgIGApO1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIEFMVEVSIFRBQkxFIFwiY29tbWl0bWVudF9lbnRpdHlcIiBEUk9QIENPTFVNTiBcInNwZW5kVHhJZFwiXG4gICAgICAgIGApO1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIEFMVEVSIFRBQkxFIFwiZXZlbnRfdHJpZ2dlcl9lbnRpdHlcIiBEUk9QIENPTFVNTiBcIldJRHNIYXNoXCJcbiAgICAgICAgYCk7XG4gICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgQUxURVIgVEFCTEUgXCJldmVudF90cmlnZ2VyX2VudGl0eVwiIERST1AgQ09MVU1OIFwiV0lEc0NvdW50XCJcbiAgICAgICAgYCk7XG4gICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgQUxURVIgVEFCTEUgXCJldmVudF90cmlnZ2VyX2VudGl0eVwiXG4gICAgICAgICAgICBBREQgXCJXSURzXCIgY2hhcmFjdGVyIHZhcnlpbmcgTk9UIE5VTEwgREVGQVVMVCAnJ1xuICAgICAgICBgKTtcbiAgICBhd2FpdCBxdWVyeVJ1bm5lci5xdWVyeShgXG4gICAgICAgICAgICBBTFRFUiBUQUJMRSBcImV2ZW50X3RyaWdnZXJfZW50aXR5XCJcbiAgICAgICAgICAgIEFMVEVSIFwiV0lEc1wiIERST1AgREVGQVVMVFxuICAgICAgICBgKTtcbiAgfVxufVxuIl19
@@ -2,6 +2,6 @@ import { MigrationInterface, QueryRunner } from 'typeorm';
2
2
  export declare class migration1746354253000 implements MigrationInterface {
3
3
  name: string;
4
4
  up(queryRunner: QueryRunner): Promise<void>;
5
- down(queryRunner: QueryRunner): Promise<void>;
5
+ down(): Promise<void>;
6
6
  }
7
7
  //# sourceMappingURL=1746354253000-migration.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"1746354253000-migration.d.ts","sourceRoot":"","sources":["../../../lib/migrations/postgres/1746354253000-migration.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAE1D,qBAAa,sBAAuB,YAAW,kBAAkB;IAC/D,IAAI,SAA4B;IAEnB,EAAE,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAS3C,IAAI,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;CAG3D"}
1
+ {"version":3,"file":"1746354253000-migration.d.ts","sourceRoot":"","sources":["../../../lib/migrations/postgres/1746354253000-migration.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAE1D,qBAAa,sBAAuB,YAAW,kBAAkB;IAC/D,IAAI,SAA4B;IAEnB,EAAE,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAS3C,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;CAGnC"}
@@ -8,8 +8,8 @@ export class migration1746354253000 {
8
8
  WHERE "toChain" = 'ergo' AND "spendTxId" IS NOT NULL
9
9
  `);
10
10
  }
11
- async down(queryRunner) {
11
+ async down() {
12
12
  // do nothing
13
13
  }
14
14
  }
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTc0NjM1NDI1MzAwMC1taWdyYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9saWIvbWlncmF0aW9ucy9wb3N0Z3Jlcy8xNzQ2MzU0MjUzMDAwLW1pZ3JhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLE9BQU8sc0JBQXNCO0lBQ2pDLElBQUksR0FBRyx3QkFBd0IsQ0FBQztJQUV6QixLQUFLLENBQUMsRUFBRSxDQUFDLFdBQXdCO1FBQ3RDLHFGQUFxRjtRQUNyRixNQUFNLFdBQVcsQ0FBQyxLQUFLLENBQUM7Ozs7S0FJdkIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVNLEtBQUssQ0FBQyxJQUFJLENBQUMsV0FBd0I7UUFDeEMsYUFBYTtJQUNmLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1pZ3JhdGlvbkludGVyZmFjZSwgUXVlcnlSdW5uZXIgfSBmcm9tICd0eXBlb3JtJztcblxuZXhwb3J0IGNsYXNzIG1pZ3JhdGlvbjE3NDYzNTQyNTMwMDAgaW1wbGVtZW50cyBNaWdyYXRpb25JbnRlcmZhY2Uge1xuICBuYW1lID0gJ21pZ3JhdGlvbjE3NDYzNTQyNTMwMDAnO1xuXG4gIHB1YmxpYyBhc3luYyB1cChxdWVyeVJ1bm5lcjogUXVlcnlSdW5uZXIpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICAvLyBmaXggYHBheW1lbnRUeElkYCBjb2x1bW4gZm9yIGFsbCBldmVudHMgdGFyZ2V0ZWQgdG8gRXJnbyBpbiBgZXZlbnRfdHJpZ2dlcl9lbnRpdHlgXG4gICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICBVUERBVEUgXCJldmVudF90cmlnZ2VyX2VudGl0eVwiXG4gICAgICAgIFNFVCBcInBheW1lbnRUeElkXCIgPSBcInNwZW5kVHhJZFwiXG4gICAgICAgIFdIRVJFIFwidG9DaGFpblwiID0gJ2VyZ28nIEFORCBcInNwZW5kVHhJZFwiIElTIE5PVCBOVUxMXG4gICAgYCk7XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgZG93bihxdWVyeVJ1bm5lcjogUXVlcnlSdW5uZXIpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICAvLyBkbyBub3RoaW5nXG4gIH1cbn1cbiJdfQ==
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTc0NjM1NDI1MzAwMC1taWdyYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9saWIvbWlncmF0aW9ucy9wb3N0Z3Jlcy8xNzQ2MzU0MjUzMDAwLW1pZ3JhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLE9BQU8sc0JBQXNCO0lBQ2pDLElBQUksR0FBRyx3QkFBd0IsQ0FBQztJQUV6QixLQUFLLENBQUMsRUFBRSxDQUFDLFdBQXdCO1FBQ3RDLHFGQUFxRjtRQUNyRixNQUFNLFdBQVcsQ0FBQyxLQUFLLENBQUM7Ozs7S0FJdkIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVNLEtBQUssQ0FBQyxJQUFJO1FBQ2YsYUFBYTtJQUNmLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1pZ3JhdGlvbkludGVyZmFjZSwgUXVlcnlSdW5uZXIgfSBmcm9tICd0eXBlb3JtJztcblxuZXhwb3J0IGNsYXNzIG1pZ3JhdGlvbjE3NDYzNTQyNTMwMDAgaW1wbGVtZW50cyBNaWdyYXRpb25JbnRlcmZhY2Uge1xuICBuYW1lID0gJ21pZ3JhdGlvbjE3NDYzNTQyNTMwMDAnO1xuXG4gIHB1YmxpYyBhc3luYyB1cChxdWVyeVJ1bm5lcjogUXVlcnlSdW5uZXIpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICAvLyBmaXggYHBheW1lbnRUeElkYCBjb2x1bW4gZm9yIGFsbCBldmVudHMgdGFyZ2V0ZWQgdG8gRXJnbyBpbiBgZXZlbnRfdHJpZ2dlcl9lbnRpdHlgXG4gICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICBVUERBVEUgXCJldmVudF90cmlnZ2VyX2VudGl0eVwiXG4gICAgICAgIFNFVCBcInBheW1lbnRUeElkXCIgPSBcInNwZW5kVHhJZFwiXG4gICAgICAgIFdIRVJFIFwidG9DaGFpblwiID0gJ2VyZ28nIEFORCBcInNwZW5kVHhJZFwiIElTIE5PVCBOVUxMXG4gICAgYCk7XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgZG93bigpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICAvLyBkbyBub3RoaW5nXG4gIH1cbn1cbiJdfQ==
@@ -1 +1 @@
1
- {"version":3,"file":"1706610773176-migration.d.ts","sourceRoot":"","sources":["../../../lib/migrations/sqlite/1706610773176-migration.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAG1D,qBAAa,sBAAuB,YAAW,kBAAkB;IAC/D,IAAI,SAA4B;IAEnB,EAAE,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IA+K3C,IAAI,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;CAqP3D"}
1
+ {"version":3,"file":"1706610773176-migration.d.ts","sourceRoot":"","sources":["../../../lib/migrations/sqlite/1706610773176-migration.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAG1D,qBAAa,sBAAuB,YAAW,kBAAkB;IAC/D,IAAI,SAA4B;IAEnB,EAAE,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAiL3C,IAAI,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;CAqP3D"}
@@ -418,4 +418,4 @@ export class migration1706610773176 {
418
418
  `);
419
419
  }
420
420
  }
421
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"1706610773176-migration.js","sourceRoot":"","sources":["../../../lib/migrations/sqlite/1706610773176-migration.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAEzC,MAAM,OAAO,sBAAsB;IACjC,IAAI,GAAG,wBAAwB,CAAC;IAEzB,KAAK,CAAC,EAAE,CAAC,WAAwB;QACtC,6CAA6C;QAC7C,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,KAAK,CAAC;;SAElC,CAAC,CAAC;QAEP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA+BnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA0DnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;SAEnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;SAGnB,CAAC,CAAC;QAEP,yEAAyE;QACzE,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE;YAC1B,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,UAAU,CAAE,KAAa,CAAC,IAAI,CAAC,CAAC;YAChE,MAAM,WAAW,CAAC,KAAK,CAAC;;kCAEI,QAAQ,qBAAqB,SAAS;6BAC3C,KAAK,CAAC,EAAE;WAC1B,CAAC,CAAC;SACR;QAED,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;SAmBnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA8BnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;SAEnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;SAGnB,CAAC,CAAC;IACT,CAAC;IAEM,KAAK,CAAC,IAAI,CAAC,WAAwB;QACxC,MAAM,WAAW,CAAC,KAAK,CAAC;;;SAGnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;SAiBnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA8BnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;SAEnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;SAGnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA6BnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SAsDnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;SAEnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;SAGnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA8BnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SAwDnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;SAEnB,CAAC,CAAC;IACT,CAAC;CACF","sourcesContent":["import { MigrationInterface, QueryRunner } from 'typeorm';\nimport { getWidInfo } from '../../utils';\n\nexport class migration1706610773176 implements MigrationInterface {\n  name = 'migration1706610773176';\n\n  public async up(queryRunner: QueryRunner): Promise<void> {\n    // get all events before removing WIDs column\n    const events = await queryRunner.query(`\n            SELECT \"id\", \"WIDs\" from \"event_trigger_entity\"\n        `);\n\n    await queryRunner.query(`\n            CREATE TABLE \"temporary_event_trigger_entity\" (\n                \"id\" integer PRIMARY KEY AUTOINCREMENT NOT NULL,\n                \"eventId\" varchar NOT NULL DEFAULT ('Not-set'),\n                \"txId\" varchar NOT NULL,\n                \"extractor\" varchar NOT NULL,\n                \"boxId\" varchar NOT NULL,\n                \"boxSerialized\" varchar NOT NULL,\n                \"block\" varchar NOT NULL,\n                \"height\" integer NOT NULL,\n                \"fromChain\" varchar NOT NULL,\n                \"toChain\" varchar NOT NULL,\n                \"fromAddress\" varchar NOT NULL,\n                \"toAddress\" varchar NOT NULL,\n                \"amount\" varchar NOT NULL,\n                \"bridgeFee\" varchar NOT NULL,\n                \"networkFee\" varchar NOT NULL,\n                \"sourceChainTokenId\" varchar NOT NULL,\n                \"sourceChainHeight\" integer NOT NULL,\n                \"targetChainTokenId\" varchar NOT NULL,\n                \"sourceTxId\" varchar NOT NULL,\n                \"sourceBlockId\" varchar NOT NULL,\n                \"spendBlock\" text,\n                \"spendHeight\" integer,\n                \"spendTxId\" text,\n                \"result\" text,\n                \"paymentTxId\" text,\n                \"WIDsCount\" integer NOT NULL,\n                \"WIDsHash\" varchar NOT NULL,\n                CONSTRAINT \"UQ_c905f221a1b6271ca4405dbbe5f\" UNIQUE (\"boxId\", \"extractor\")\n            )\n        `);\n    await queryRunner.query(`\n            INSERT INTO \"temporary_event_trigger_entity\"(\n                    \"id\",\n                    \"eventId\",\n                    \"txId\",\n                    \"extractor\",\n                    \"boxId\",\n                    \"boxSerialized\",\n                    \"block\",\n                    \"height\",\n                    \"fromChain\",\n                    \"toChain\",\n                    \"fromAddress\",\n                    \"toAddress\",\n                    \"amount\",\n                    \"bridgeFee\",\n                    \"networkFee\",\n                    \"sourceChainTokenId\",\n                    \"sourceChainHeight\",\n                    \"targetChainTokenId\",\n                    \"sourceTxId\",\n                    \"sourceBlockId\",\n                    \"spendBlock\",\n                    \"spendHeight\",\n                    \"spendTxId\",\n                    \"result\",\n                    \"paymentTxId\",\n                    \"WIDsCount\",\n                    \"WIDsHash\"\n                )\n            SELECT \"id\",\n                \"eventId\",\n                \"txId\",\n                \"extractor\",\n                \"boxId\",\n                \"boxSerialized\",\n                \"block\",\n                \"height\",\n                \"fromChain\",\n                \"toChain\",\n                \"fromAddress\",\n                \"toAddress\",\n                \"amount\",\n                \"bridgeFee\",\n                \"networkFee\",\n                \"sourceChainTokenId\",\n                \"sourceChainHeight\",\n                \"targetChainTokenId\",\n                \"sourceTxId\",\n                \"sourceBlockId\",\n                \"spendBlock\",\n                \"spendHeight\",\n                \"spendTxId\",\n                \"result\",\n                \"paymentTxId\",\n                0,\n                ''\n            FROM \"event_trigger_entity\"\n        `);\n    await queryRunner.query(`\n            DROP TABLE \"event_trigger_entity\"\n        `);\n    await queryRunner.query(`\n            ALTER TABLE \"temporary_event_trigger_entity\"\n                RENAME TO \"event_trigger_entity\"\n        `);\n\n    // calculate `WIDsCount` and `WIDsHash` columns in `event_trigger_entity`\n    for (const event of events) {\n      const { WIDsHash, WIDsCount } = getWidInfo((event as any).WIDs);\n      await queryRunner.query(`\n              UPDATE \"event_trigger_entity\"\n              SET \"WIDsHash\" = '${WIDsHash}', \"WIDsCount\" = '${WIDsCount}'\n              WHERE \"id\" = ${event.id}\n          `);\n    }\n\n    await queryRunner.query(`\n            CREATE TABLE \"temporary_commitment_entity\" (\n                \"id\" integer PRIMARY KEY AUTOINCREMENT NOT NULL,\n                \"txId\" varchar NOT NULL,\n                \"extractor\" varchar NOT NULL,\n                \"eventId\" varchar NOT NULL,\n                \"commitment\" varchar NOT NULL,\n                \"WID\" varchar NOT NULL,\n                \"boxId\" varchar NOT NULL,\n                \"block\" varchar NOT NULL,\n                \"height\" integer NOT NULL,\n                \"boxSerialized\" varchar NOT NULL,\n                \"spendBlock\" text,\n                \"spendHeight\" integer,\n                \"rwtCount\" varchar,\n                \"spendTxId\" text,\n                \"spendIndex\" integer,\n                CONSTRAINT \"UQ_cc294fc304a66f8f194840f1ece\" UNIQUE (\"boxId\", \"extractor\")\n            )\n        `);\n    await queryRunner.query(`\n            INSERT INTO \"temporary_commitment_entity\"(\n                    \"id\",\n                    \"txId\",\n                    \"extractor\",\n                    \"eventId\",\n                    \"commitment\",\n                    \"WID\",\n                    \"boxId\",\n                    \"block\",\n                    \"height\",\n                    \"boxSerialized\",\n                    \"spendBlock\",\n                    \"spendHeight\",\n                    \"rwtCount\"\n                )\n            SELECT \"id\",\n                \"txId\",\n                \"extractor\",\n                \"eventId\",\n                \"commitment\",\n                \"WID\",\n                \"boxId\",\n                \"block\",\n                \"height\",\n                \"boxSerialized\",\n                \"spendBlock\",\n                \"spendHeight\",\n                \"rwtCount\"\n            FROM \"commitment_entity\"\n        `);\n    await queryRunner.query(`\n            DROP TABLE \"commitment_entity\"\n        `);\n    await queryRunner.query(`\n            ALTER TABLE \"temporary_commitment_entity\"\n                RENAME TO \"commitment_entity\"\n        `);\n  }\n\n  public async down(queryRunner: QueryRunner): Promise<void> {\n    await queryRunner.query(`\n            ALTER TABLE \"commitment_entity\"\n                RENAME TO \"temporary_commitment_entity\"\n        `);\n    await queryRunner.query(`\n            CREATE TABLE \"commitment_entity\" (\n                \"id\" integer PRIMARY KEY AUTOINCREMENT NOT NULL,\n                \"txId\" varchar NOT NULL,\n                \"extractor\" varchar NOT NULL,\n                \"eventId\" varchar NOT NULL,\n                \"commitment\" varchar NOT NULL,\n                \"WID\" varchar NOT NULL,\n                \"boxId\" varchar NOT NULL,\n                \"block\" varchar NOT NULL,\n                \"height\" integer NOT NULL,\n                \"boxSerialized\" varchar NOT NULL,\n                \"spendBlock\" text,\n                \"spendHeight\" integer,\n                \"rwtCount\" varchar,\n                CONSTRAINT \"UQ_cc294fc304a66f8f194840f1ece\" UNIQUE (\"boxId\", \"extractor\")\n            )\n        `);\n    await queryRunner.query(`\n            INSERT INTO \"commitment_entity\"(\n                    \"id\",\n                    \"txId\",\n                    \"extractor\",\n                    \"eventId\",\n                    \"commitment\",\n                    \"WID\",\n                    \"boxId\",\n                    \"block\",\n                    \"height\",\n                    \"boxSerialized\",\n                    \"spendBlock\",\n                    \"spendHeight\",\n                    \"rwtCount\"\n                )\n            SELECT \"id\",\n                \"txId\",\n                \"extractor\",\n                \"eventId\",\n                \"commitment\",\n                \"WID\",\n                \"boxId\",\n                \"block\",\n                \"height\",\n                \"boxSerialized\",\n                \"spendBlock\",\n                \"spendHeight\",\n                \"rwtCount\"\n            FROM \"temporary_commitment_entity\"\n        `);\n    await queryRunner.query(`\n            DROP TABLE \"temporary_commitment_entity\"\n        `);\n    await queryRunner.query(`\n            ALTER TABLE \"event_trigger_entity\"\n                RENAME TO \"temporary_event_trigger_entity\"\n        `);\n    await queryRunner.query(`\n            CREATE TABLE \"event_trigger_entity\" (\n                \"id\" integer PRIMARY KEY AUTOINCREMENT NOT NULL,\n                \"eventId\" varchar NOT NULL DEFAULT ('Not-set'),\n                \"txId\" varchar NOT NULL,\n                \"extractor\" varchar NOT NULL,\n                \"boxId\" varchar NOT NULL,\n                \"boxSerialized\" varchar NOT NULL,\n                \"block\" varchar NOT NULL,\n                \"height\" integer NOT NULL,\n                \"fromChain\" varchar NOT NULL,\n                \"toChain\" varchar NOT NULL,\n                \"fromAddress\" varchar NOT NULL,\n                \"toAddress\" varchar NOT NULL,\n                \"amount\" varchar NOT NULL,\n                \"bridgeFee\" varchar NOT NULL,\n                \"networkFee\" varchar NOT NULL,\n                \"sourceChainTokenId\" varchar NOT NULL,\n                \"sourceChainHeight\" integer NOT NULL,\n                \"targetChainTokenId\" varchar NOT NULL,\n                \"sourceTxId\" varchar NOT NULL,\n                \"sourceBlockId\" varchar NOT NULL,\n                \"spendBlock\" text,\n                \"spendHeight\" integer,\n                \"spendTxId\" text,\n                \"result\" text,\n                \"paymentTxId\" text,\n                CONSTRAINT \"UQ_c905f221a1b6271ca4405dbbe5f\" UNIQUE (\"boxId\", \"extractor\")\n            )\n        `);\n    await queryRunner.query(`\n            INSERT INTO \"event_trigger_entity\"(\n                    \"id\",\n                    \"eventId\",\n                    \"txId\",\n                    \"extractor\",\n                    \"boxId\",\n                    \"boxSerialized\",\n                    \"block\",\n                    \"height\",\n                    \"fromChain\",\n                    \"toChain\",\n                    \"fromAddress\",\n                    \"toAddress\",\n                    \"amount\",\n                    \"bridgeFee\",\n                    \"networkFee\",\n                    \"sourceChainTokenId\",\n                    \"sourceChainHeight\",\n                    \"targetChainTokenId\",\n                    \"sourceTxId\",\n                    \"sourceBlockId\",\n                    \"spendBlock\",\n                    \"spendHeight\",\n                    \"spendTxId\",\n                    \"result\",\n                    \"paymentTxId\"\n                )\n            SELECT \"id\",\n                \"eventId\",\n                \"txId\",\n                \"extractor\",\n                \"boxId\",\n                \"boxSerialized\",\n                \"block\",\n                \"height\",\n                \"fromChain\",\n                \"toChain\",\n                \"fromAddress\",\n                \"toAddress\",\n                \"amount\",\n                \"bridgeFee\",\n                \"networkFee\",\n                \"sourceChainTokenId\",\n                \"sourceChainHeight\",\n                \"targetChainTokenId\",\n                \"sourceTxId\",\n                \"sourceBlockId\",\n                \"spendBlock\",\n                \"spendHeight\",\n                \"spendTxId\",\n                \"result\",\n                \"paymentTxId\"\n            FROM \"temporary_event_trigger_entity\"\n        `);\n    await queryRunner.query(`\n            DROP TABLE \"temporary_event_trigger_entity\"\n        `);\n    await queryRunner.query(`\n            ALTER TABLE \"event_trigger_entity\"\n                RENAME TO \"temporary_event_trigger_entity\"\n        `);\n    await queryRunner.query(`\n            CREATE TABLE \"event_trigger_entity\" (\n                \"id\" integer PRIMARY KEY AUTOINCREMENT NOT NULL,\n                \"eventId\" varchar NOT NULL DEFAULT ('Not-set'),\n                \"txId\" varchar NOT NULL,\n                \"extractor\" varchar NOT NULL,\n                \"boxId\" varchar NOT NULL,\n                \"boxSerialized\" varchar NOT NULL,\n                \"block\" varchar NOT NULL,\n                \"height\" integer NOT NULL,\n                \"fromChain\" varchar NOT NULL,\n                \"toChain\" varchar NOT NULL,\n                \"fromAddress\" varchar NOT NULL,\n                \"toAddress\" varchar NOT NULL,\n                \"amount\" varchar NOT NULL,\n                \"bridgeFee\" varchar NOT NULL,\n                \"networkFee\" varchar NOT NULL,\n                \"sourceChainTokenId\" varchar NOT NULL,\n                \"sourceChainHeight\" integer NOT NULL,\n                \"targetChainTokenId\" varchar NOT NULL,\n                \"sourceTxId\" varchar NOT NULL,\n                \"sourceBlockId\" varchar NOT NULL,\n                \"WIDs\" varchar NOT NULL,\n                \"spendBlock\" text,\n                \"spendHeight\" integer,\n                \"spendTxId\" text,\n                \"result\" text,\n                \"paymentTxId\" text,\n                CONSTRAINT \"UQ_c905f221a1b6271ca4405dbbe5f\" UNIQUE (\"boxId\", \"extractor\")\n            )\n        `);\n    await queryRunner.query(`\n            INSERT INTO \"event_trigger_entity\"(\n                    \"id\",\n                    \"eventId\",\n                    \"txId\",\n                    \"extractor\",\n                    \"boxId\",\n                    \"boxSerialized\",\n                    \"block\",\n                    \"height\",\n                    \"fromChain\",\n                    \"toChain\",\n                    \"fromAddress\",\n                    \"toAddress\",\n                    \"amount\",\n                    \"bridgeFee\",\n                    \"networkFee\",\n                    \"sourceChainTokenId\",\n                    \"sourceChainHeight\",\n                    \"targetChainTokenId\",\n                    \"sourceTxId\",\n                    \"sourceBlockId\",\n                    \"spendBlock\",\n                    \"spendHeight\",\n                    \"spendTxId\",\n                    \"result\",\n                    \"paymentTxId\",\n                    \"WIDs\"\n                )\n            SELECT \"id\",\n                \"eventId\",\n                \"txId\",\n                \"extractor\",\n                \"boxId\",\n                \"boxSerialized\",\n                \"block\",\n                \"height\",\n                \"fromChain\",\n                \"toChain\",\n                \"fromAddress\",\n                \"toAddress\",\n                \"amount\",\n                \"bridgeFee\",\n                \"networkFee\",\n                \"sourceChainTokenId\",\n                \"sourceChainHeight\",\n                \"targetChainTokenId\",\n                \"sourceTxId\",\n                \"sourceBlockId\",\n                \"spendBlock\",\n                \"spendHeight\",\n                \"spendTxId\",\n                \"result\",\n                \"paymentTxId\",\n                ''\n            FROM \"temporary_event_trigger_entity\"\n        `);\n    await queryRunner.query(`\n            DROP TABLE \"temporary_event_trigger_entity\"\n        `);\n  }\n}\n"]}
421
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"1706610773176-migration.js","sourceRoot":"","sources":["../../../lib/migrations/sqlite/1706610773176-migration.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAEzC,MAAM,OAAO,sBAAsB;IACjC,IAAI,GAAG,wBAAwB,CAAC;IAEzB,KAAK,CAAC,EAAE,CAAC,WAAwB;QACtC,6CAA6C;QAC7C,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,KAAK,CAAC;;SAElC,CAAC,CAAC;QAEP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA+BnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA0DnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;SAEnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;SAGnB,CAAC,CAAC;QAEP,yEAAyE;QACzE,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE;YAC1B,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,UAAU,CACvC,KAA0B,CAAC,IAAI,CACjC,CAAC;YACF,MAAM,WAAW,CAAC,KAAK,CAAC;;kCAEI,QAAQ,qBAAqB,SAAS;6BAC3C,KAAK,CAAC,EAAE;WAC1B,CAAC,CAAC;SACR;QAED,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;SAmBnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA8BnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;SAEnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;SAGnB,CAAC,CAAC;IACT,CAAC;IAEM,KAAK,CAAC,IAAI,CAAC,WAAwB;QACxC,MAAM,WAAW,CAAC,KAAK,CAAC;;;SAGnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;SAiBnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA8BnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;SAEnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;SAGnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA6BnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SAsDnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;SAEnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;SAGnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SA8BnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SAwDnB,CAAC,CAAC;QACP,MAAM,WAAW,CAAC,KAAK,CAAC;;SAEnB,CAAC,CAAC;IACT,CAAC;CACF","sourcesContent":["import { MigrationInterface, QueryRunner } from 'typeorm';\nimport { getWidInfo } from '../../utils';\n\nexport class migration1706610773176 implements MigrationInterface {\n  name = 'migration1706610773176';\n\n  public async up(queryRunner: QueryRunner): Promise<void> {\n    // get all events before removing WIDs column\n    const events = await queryRunner.query(`\n            SELECT \"id\", \"WIDs\" from \"event_trigger_entity\"\n        `);\n\n    await queryRunner.query(`\n            CREATE TABLE \"temporary_event_trigger_entity\" (\n                \"id\" integer PRIMARY KEY AUTOINCREMENT NOT NULL,\n                \"eventId\" varchar NOT NULL DEFAULT ('Not-set'),\n                \"txId\" varchar NOT NULL,\n                \"extractor\" varchar NOT NULL,\n                \"boxId\" varchar NOT NULL,\n                \"boxSerialized\" varchar NOT NULL,\n                \"block\" varchar NOT NULL,\n                \"height\" integer NOT NULL,\n                \"fromChain\" varchar NOT NULL,\n                \"toChain\" varchar NOT NULL,\n                \"fromAddress\" varchar NOT NULL,\n                \"toAddress\" varchar NOT NULL,\n                \"amount\" varchar NOT NULL,\n                \"bridgeFee\" varchar NOT NULL,\n                \"networkFee\" varchar NOT NULL,\n                \"sourceChainTokenId\" varchar NOT NULL,\n                \"sourceChainHeight\" integer NOT NULL,\n                \"targetChainTokenId\" varchar NOT NULL,\n                \"sourceTxId\" varchar NOT NULL,\n                \"sourceBlockId\" varchar NOT NULL,\n                \"spendBlock\" text,\n                \"spendHeight\" integer,\n                \"spendTxId\" text,\n                \"result\" text,\n                \"paymentTxId\" text,\n                \"WIDsCount\" integer NOT NULL,\n                \"WIDsHash\" varchar NOT NULL,\n                CONSTRAINT \"UQ_c905f221a1b6271ca4405dbbe5f\" UNIQUE (\"boxId\", \"extractor\")\n            )\n        `);\n    await queryRunner.query(`\n            INSERT INTO \"temporary_event_trigger_entity\"(\n                    \"id\",\n                    \"eventId\",\n                    \"txId\",\n                    \"extractor\",\n                    \"boxId\",\n                    \"boxSerialized\",\n                    \"block\",\n                    \"height\",\n                    \"fromChain\",\n                    \"toChain\",\n                    \"fromAddress\",\n                    \"toAddress\",\n                    \"amount\",\n                    \"bridgeFee\",\n                    \"networkFee\",\n                    \"sourceChainTokenId\",\n                    \"sourceChainHeight\",\n                    \"targetChainTokenId\",\n                    \"sourceTxId\",\n                    \"sourceBlockId\",\n                    \"spendBlock\",\n                    \"spendHeight\",\n                    \"spendTxId\",\n                    \"result\",\n                    \"paymentTxId\",\n                    \"WIDsCount\",\n                    \"WIDsHash\"\n                )\n            SELECT \"id\",\n                \"eventId\",\n                \"txId\",\n                \"extractor\",\n                \"boxId\",\n                \"boxSerialized\",\n                \"block\",\n                \"height\",\n                \"fromChain\",\n                \"toChain\",\n                \"fromAddress\",\n                \"toAddress\",\n                \"amount\",\n                \"bridgeFee\",\n                \"networkFee\",\n                \"sourceChainTokenId\",\n                \"sourceChainHeight\",\n                \"targetChainTokenId\",\n                \"sourceTxId\",\n                \"sourceBlockId\",\n                \"spendBlock\",\n                \"spendHeight\",\n                \"spendTxId\",\n                \"result\",\n                \"paymentTxId\",\n                0,\n                ''\n            FROM \"event_trigger_entity\"\n        `);\n    await queryRunner.query(`\n            DROP TABLE \"event_trigger_entity\"\n        `);\n    await queryRunner.query(`\n            ALTER TABLE \"temporary_event_trigger_entity\"\n                RENAME TO \"event_trigger_entity\"\n        `);\n\n    // calculate `WIDsCount` and `WIDsHash` columns in `event_trigger_entity`\n    for (const event of events) {\n      const { WIDsHash, WIDsCount } = getWidInfo(\n        (event as { WIDs: string }).WIDs\n      );\n      await queryRunner.query(`\n              UPDATE \"event_trigger_entity\"\n              SET \"WIDsHash\" = '${WIDsHash}', \"WIDsCount\" = '${WIDsCount}'\n              WHERE \"id\" = ${event.id}\n          `);\n    }\n\n    await queryRunner.query(`\n            CREATE TABLE \"temporary_commitment_entity\" (\n                \"id\" integer PRIMARY KEY AUTOINCREMENT NOT NULL,\n                \"txId\" varchar NOT NULL,\n                \"extractor\" varchar NOT NULL,\n                \"eventId\" varchar NOT NULL,\n                \"commitment\" varchar NOT NULL,\n                \"WID\" varchar NOT NULL,\n                \"boxId\" varchar NOT NULL,\n                \"block\" varchar NOT NULL,\n                \"height\" integer NOT NULL,\n                \"boxSerialized\" varchar NOT NULL,\n                \"spendBlock\" text,\n                \"spendHeight\" integer,\n                \"rwtCount\" varchar,\n                \"spendTxId\" text,\n                \"spendIndex\" integer,\n                CONSTRAINT \"UQ_cc294fc304a66f8f194840f1ece\" UNIQUE (\"boxId\", \"extractor\")\n            )\n        `);\n    await queryRunner.query(`\n            INSERT INTO \"temporary_commitment_entity\"(\n                    \"id\",\n                    \"txId\",\n                    \"extractor\",\n                    \"eventId\",\n                    \"commitment\",\n                    \"WID\",\n                    \"boxId\",\n                    \"block\",\n                    \"height\",\n                    \"boxSerialized\",\n                    \"spendBlock\",\n                    \"spendHeight\",\n                    \"rwtCount\"\n                )\n            SELECT \"id\",\n                \"txId\",\n                \"extractor\",\n                \"eventId\",\n                \"commitment\",\n                \"WID\",\n                \"boxId\",\n                \"block\",\n                \"height\",\n                \"boxSerialized\",\n                \"spendBlock\",\n                \"spendHeight\",\n                \"rwtCount\"\n            FROM \"commitment_entity\"\n        `);\n    await queryRunner.query(`\n            DROP TABLE \"commitment_entity\"\n        `);\n    await queryRunner.query(`\n            ALTER TABLE \"temporary_commitment_entity\"\n                RENAME TO \"commitment_entity\"\n        `);\n  }\n\n  public async down(queryRunner: QueryRunner): Promise<void> {\n    await queryRunner.query(`\n            ALTER TABLE \"commitment_entity\"\n                RENAME TO \"temporary_commitment_entity\"\n        `);\n    await queryRunner.query(`\n            CREATE TABLE \"commitment_entity\" (\n                \"id\" integer PRIMARY KEY AUTOINCREMENT NOT NULL,\n                \"txId\" varchar NOT NULL,\n                \"extractor\" varchar NOT NULL,\n                \"eventId\" varchar NOT NULL,\n                \"commitment\" varchar NOT NULL,\n                \"WID\" varchar NOT NULL,\n                \"boxId\" varchar NOT NULL,\n                \"block\" varchar NOT NULL,\n                \"height\" integer NOT NULL,\n                \"boxSerialized\" varchar NOT NULL,\n                \"spendBlock\" text,\n                \"spendHeight\" integer,\n                \"rwtCount\" varchar,\n                CONSTRAINT \"UQ_cc294fc304a66f8f194840f1ece\" UNIQUE (\"boxId\", \"extractor\")\n            )\n        `);\n    await queryRunner.query(`\n            INSERT INTO \"commitment_entity\"(\n                    \"id\",\n                    \"txId\",\n                    \"extractor\",\n                    \"eventId\",\n                    \"commitment\",\n                    \"WID\",\n                    \"boxId\",\n                    \"block\",\n                    \"height\",\n                    \"boxSerialized\",\n                    \"spendBlock\",\n                    \"spendHeight\",\n                    \"rwtCount\"\n                )\n            SELECT \"id\",\n                \"txId\",\n                \"extractor\",\n                \"eventId\",\n                \"commitment\",\n                \"WID\",\n                \"boxId\",\n                \"block\",\n                \"height\",\n                \"boxSerialized\",\n                \"spendBlock\",\n                \"spendHeight\",\n                \"rwtCount\"\n            FROM \"temporary_commitment_entity\"\n        `);\n    await queryRunner.query(`\n            DROP TABLE \"temporary_commitment_entity\"\n        `);\n    await queryRunner.query(`\n            ALTER TABLE \"event_trigger_entity\"\n                RENAME TO \"temporary_event_trigger_entity\"\n        `);\n    await queryRunner.query(`\n            CREATE TABLE \"event_trigger_entity\" (\n                \"id\" integer PRIMARY KEY AUTOINCREMENT NOT NULL,\n                \"eventId\" varchar NOT NULL DEFAULT ('Not-set'),\n                \"txId\" varchar NOT NULL,\n                \"extractor\" varchar NOT NULL,\n                \"boxId\" varchar NOT NULL,\n                \"boxSerialized\" varchar NOT NULL,\n                \"block\" varchar NOT NULL,\n                \"height\" integer NOT NULL,\n                \"fromChain\" varchar NOT NULL,\n                \"toChain\" varchar NOT NULL,\n                \"fromAddress\" varchar NOT NULL,\n                \"toAddress\" varchar NOT NULL,\n                \"amount\" varchar NOT NULL,\n                \"bridgeFee\" varchar NOT NULL,\n                \"networkFee\" varchar NOT NULL,\n                \"sourceChainTokenId\" varchar NOT NULL,\n                \"sourceChainHeight\" integer NOT NULL,\n                \"targetChainTokenId\" varchar NOT NULL,\n                \"sourceTxId\" varchar NOT NULL,\n                \"sourceBlockId\" varchar NOT NULL,\n                \"spendBlock\" text,\n                \"spendHeight\" integer,\n                \"spendTxId\" text,\n                \"result\" text,\n                \"paymentTxId\" text,\n                CONSTRAINT \"UQ_c905f221a1b6271ca4405dbbe5f\" UNIQUE (\"boxId\", \"extractor\")\n            )\n        `);\n    await queryRunner.query(`\n            INSERT INTO \"event_trigger_entity\"(\n                    \"id\",\n                    \"eventId\",\n                    \"txId\",\n                    \"extractor\",\n                    \"boxId\",\n                    \"boxSerialized\",\n                    \"block\",\n                    \"height\",\n                    \"fromChain\",\n                    \"toChain\",\n                    \"fromAddress\",\n                    \"toAddress\",\n                    \"amount\",\n                    \"bridgeFee\",\n                    \"networkFee\",\n                    \"sourceChainTokenId\",\n                    \"sourceChainHeight\",\n                    \"targetChainTokenId\",\n                    \"sourceTxId\",\n                    \"sourceBlockId\",\n                    \"spendBlock\",\n                    \"spendHeight\",\n                    \"spendTxId\",\n                    \"result\",\n                    \"paymentTxId\"\n                )\n            SELECT \"id\",\n                \"eventId\",\n                \"txId\",\n                \"extractor\",\n                \"boxId\",\n                \"boxSerialized\",\n                \"block\",\n                \"height\",\n                \"fromChain\",\n                \"toChain\",\n                \"fromAddress\",\n                \"toAddress\",\n                \"amount\",\n                \"bridgeFee\",\n                \"networkFee\",\n                \"sourceChainTokenId\",\n                \"sourceChainHeight\",\n                \"targetChainTokenId\",\n                \"sourceTxId\",\n                \"sourceBlockId\",\n                \"spendBlock\",\n                \"spendHeight\",\n                \"spendTxId\",\n                \"result\",\n                \"paymentTxId\"\n            FROM \"temporary_event_trigger_entity\"\n        `);\n    await queryRunner.query(`\n            DROP TABLE \"temporary_event_trigger_entity\"\n        `);\n    await queryRunner.query(`\n            ALTER TABLE \"event_trigger_entity\"\n                RENAME TO \"temporary_event_trigger_entity\"\n        `);\n    await queryRunner.query(`\n            CREATE TABLE \"event_trigger_entity\" (\n                \"id\" integer PRIMARY KEY AUTOINCREMENT NOT NULL,\n                \"eventId\" varchar NOT NULL DEFAULT ('Not-set'),\n                \"txId\" varchar NOT NULL,\n                \"extractor\" varchar NOT NULL,\n                \"boxId\" varchar NOT NULL,\n                \"boxSerialized\" varchar NOT NULL,\n                \"block\" varchar NOT NULL,\n                \"height\" integer NOT NULL,\n                \"fromChain\" varchar NOT NULL,\n                \"toChain\" varchar NOT NULL,\n                \"fromAddress\" varchar NOT NULL,\n                \"toAddress\" varchar NOT NULL,\n                \"amount\" varchar NOT NULL,\n                \"bridgeFee\" varchar NOT NULL,\n                \"networkFee\" varchar NOT NULL,\n                \"sourceChainTokenId\" varchar NOT NULL,\n                \"sourceChainHeight\" integer NOT NULL,\n                \"targetChainTokenId\" varchar NOT NULL,\n                \"sourceTxId\" varchar NOT NULL,\n                \"sourceBlockId\" varchar NOT NULL,\n                \"WIDs\" varchar NOT NULL,\n                \"spendBlock\" text,\n                \"spendHeight\" integer,\n                \"spendTxId\" text,\n                \"result\" text,\n                \"paymentTxId\" text,\n                CONSTRAINT \"UQ_c905f221a1b6271ca4405dbbe5f\" UNIQUE (\"boxId\", \"extractor\")\n            )\n        `);\n    await queryRunner.query(`\n            INSERT INTO \"event_trigger_entity\"(\n                    \"id\",\n                    \"eventId\",\n                    \"txId\",\n                    \"extractor\",\n                    \"boxId\",\n                    \"boxSerialized\",\n                    \"block\",\n                    \"height\",\n                    \"fromChain\",\n                    \"toChain\",\n                    \"fromAddress\",\n                    \"toAddress\",\n                    \"amount\",\n                    \"bridgeFee\",\n                    \"networkFee\",\n                    \"sourceChainTokenId\",\n                    \"sourceChainHeight\",\n                    \"targetChainTokenId\",\n                    \"sourceTxId\",\n                    \"sourceBlockId\",\n                    \"spendBlock\",\n                    \"spendHeight\",\n                    \"spendTxId\",\n                    \"result\",\n                    \"paymentTxId\",\n                    \"WIDs\"\n                )\n            SELECT \"id\",\n                \"eventId\",\n                \"txId\",\n                \"extractor\",\n                \"boxId\",\n                \"boxSerialized\",\n                \"block\",\n                \"height\",\n                \"fromChain\",\n                \"toChain\",\n                \"fromAddress\",\n                \"toAddress\",\n                \"amount\",\n                \"bridgeFee\",\n                \"networkFee\",\n                \"sourceChainTokenId\",\n                \"sourceChainHeight\",\n                \"targetChainTokenId\",\n                \"sourceTxId\",\n                \"sourceBlockId\",\n                \"spendBlock\",\n                \"spendHeight\",\n                \"spendTxId\",\n                \"result\",\n                \"paymentTxId\",\n                ''\n            FROM \"temporary_event_trigger_entity\"\n        `);\n    await queryRunner.query(`\n            DROP TABLE \"temporary_event_trigger_entity\"\n        `);\n  }\n}\n"]}
@@ -2,6 +2,6 @@ import { MigrationInterface, QueryRunner } from 'typeorm';
2
2
  export declare class migration1746354254000 implements MigrationInterface {
3
3
  name: string;
4
4
  up(queryRunner: QueryRunner): Promise<void>;
5
- down(queryRunner: QueryRunner): Promise<void>;
5
+ down(): Promise<void>;
6
6
  }
7
7
  //# sourceMappingURL=1746354254000-migration.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"1746354254000-migration.d.ts","sourceRoot":"","sources":["../../../lib/migrations/sqlite/1746354254000-migration.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAE1D,qBAAa,sBAAuB,YAAW,kBAAkB;IAC/D,IAAI,SAA4B;IAEnB,EAAE,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAS3C,IAAI,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;CAG3D"}
1
+ {"version":3,"file":"1746354254000-migration.d.ts","sourceRoot":"","sources":["../../../lib/migrations/sqlite/1746354254000-migration.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAE1D,qBAAa,sBAAuB,YAAW,kBAAkB;IAC/D,IAAI,SAA4B;IAEnB,EAAE,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAS3C,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;CAGnC"}
@@ -8,8 +8,8 @@ export class migration1746354254000 {
8
8
  WHERE "toChain" = 'ergo' AND "spendTxId" IS NOT NULL
9
9
  `);
10
10
  }
11
- async down(queryRunner) {
11
+ async down() {
12
12
  // do nothing
13
13
  }
14
14
  }
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTc0NjM1NDI1NDAwMC1taWdyYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9saWIvbWlncmF0aW9ucy9zcWxpdGUvMTc0NjM1NDI1NDAwMC1taWdyYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxPQUFPLHNCQUFzQjtJQUNqQyxJQUFJLEdBQUcsd0JBQXdCLENBQUM7SUFFekIsS0FBSyxDQUFDLEVBQUUsQ0FBQyxXQUF3QjtRQUN0QyxxRkFBcUY7UUFDckYsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOzs7O0tBSXZCLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFTSxLQUFLLENBQUMsSUFBSSxDQUFDLFdBQXdCO1FBQ3hDLGFBQWE7SUFDZixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNaWdyYXRpb25JbnRlcmZhY2UsIFF1ZXJ5UnVubmVyIH0gZnJvbSAndHlwZW9ybSc7XG5cbmV4cG9ydCBjbGFzcyBtaWdyYXRpb24xNzQ2MzU0MjU0MDAwIGltcGxlbWVudHMgTWlncmF0aW9uSW50ZXJmYWNlIHtcbiAgbmFtZSA9ICdtaWdyYXRpb24xNzQ2MzU0MjU0MDAwJztcblxuICBwdWJsaWMgYXN5bmMgdXAocXVlcnlSdW5uZXI6IFF1ZXJ5UnVubmVyKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgLy8gZml4IGBwYXltZW50VHhJZGAgY29sdW1uIGZvciBhbGwgZXZlbnRzIHRhcmdldGVkIHRvIEVyZ28gaW4gYGV2ZW50X3RyaWdnZXJfZW50aXR5YFxuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgVVBEQVRFIFwiZXZlbnRfdHJpZ2dlcl9lbnRpdHlcIlxuICAgICAgICBTRVQgXCJwYXltZW50VHhJZFwiID0gXCJzcGVuZFR4SWRcIlxuICAgICAgICBXSEVSRSBcInRvQ2hhaW5cIiA9ICdlcmdvJyBBTkQgXCJzcGVuZFR4SWRcIiBJUyBOT1QgTlVMTFxuICAgIGApO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIGRvd24ocXVlcnlSdW5uZXI6IFF1ZXJ5UnVubmVyKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgLy8gZG8gbm90aGluZ1xuICB9XG59XG4iXX0=
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTc0NjM1NDI1NDAwMC1taWdyYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9saWIvbWlncmF0aW9ucy9zcWxpdGUvMTc0NjM1NDI1NDAwMC1taWdyYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxPQUFPLHNCQUFzQjtJQUNqQyxJQUFJLEdBQUcsd0JBQXdCLENBQUM7SUFFekIsS0FBSyxDQUFDLEVBQUUsQ0FBQyxXQUF3QjtRQUN0QyxxRkFBcUY7UUFDckYsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOzs7O0tBSXZCLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFTSxLQUFLLENBQUMsSUFBSTtRQUNmLGFBQWE7SUFDZixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNaWdyYXRpb25JbnRlcmZhY2UsIFF1ZXJ5UnVubmVyIH0gZnJvbSAndHlwZW9ybSc7XG5cbmV4cG9ydCBjbGFzcyBtaWdyYXRpb24xNzQ2MzU0MjU0MDAwIGltcGxlbWVudHMgTWlncmF0aW9uSW50ZXJmYWNlIHtcbiAgbmFtZSA9ICdtaWdyYXRpb24xNzQ2MzU0MjU0MDAwJztcblxuICBwdWJsaWMgYXN5bmMgdXAocXVlcnlSdW5uZXI6IFF1ZXJ5UnVubmVyKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgLy8gZml4IGBwYXltZW50VHhJZGAgY29sdW1uIGZvciBhbGwgZXZlbnRzIHRhcmdldGVkIHRvIEVyZ28gaW4gYGV2ZW50X3RyaWdnZXJfZW50aXR5YFxuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgVVBEQVRFIFwiZXZlbnRfdHJpZ2dlcl9lbnRpdHlcIlxuICAgICAgICBTRVQgXCJwYXltZW50VHhJZFwiID0gXCJzcGVuZFR4SWRcIlxuICAgICAgICBXSEVSRSBcInRvQ2hhaW5cIiA9ICdlcmdvJyBBTkQgXCJzcGVuZFR4SWRcIiBJUyBOT1QgTlVMTFxuICAgIGApO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIGRvd24oKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgLy8gZG8gbm90aGluZ1xuICB9XG59XG4iXX0=
package/package.json CHANGED
@@ -1,9 +1,9 @@
1
1
  {
2
2
  "name": "@rosen-bridge/watcher-data-extractor",
3
- "version": "12.1.2",
3
+ "version": "12.1.4",
4
4
  "description": "Extractor for rosen specific boxes on ergo blockchain",
5
5
  "author": "Rosen Team",
6
- "license": "GPL-3.0",
6
+ "license": "MIT",
7
7
  "main": "dist/index.js",
8
8
  "types": "dist/index.d.ts",
9
9
  "scripts": {
@@ -19,13 +19,13 @@
19
19
  "dist"
20
20
  ],
21
21
  "dependencies": {
22
- "@rosen-bridge/abstract-extractor": "^2.0.1",
22
+ "@rosen-bridge/abstract-extractor": "^2.0.3",
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-interfaces": "^0.1.0",
27
- "@rosen-bridge/tokens": "^3.1.0",
28
- "@rosen-clients/ergo-explorer": "^1.1.4",
26
+ "@rosen-bridge/scanner-interfaces": "^0.1.1",
27
+ "@rosen-bridge/tokens": "^3.1.1",
28
+ "@rosen-clients/ergo-explorer": "^1.1.5",
29
29
  "@types/lodash-es": "^4.17.6",
30
30
  "blakejs": "^1.2.1",
31
31
  "ergo-lib-wasm-nodejs": "^0.24.1",
@@ -39,7 +39,7 @@
39
39
  "type": "module",
40
40
  "devDependencies": {
41
41
  "@babel/preset-env": "^7.19.0",
42
- "@rosen-bridge/scanner": "^7.1.0",
42
+ "@rosen-bridge/scanner": "^8.0.1",
43
43
  "@types/jest": "^28.1.6",
44
44
  "@types/json-bigint": "^1.0.1",
45
45
  "@types/node": "^20.11.9",