@rosen-bridge/abstract-scanner 0.2.0 → 0.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,24 @@
1
1
  # @rosen-bridge/abstract-scanner
2
2
 
3
+ ## 0.2.1
4
+
5
+ ### Patch Changes
6
+
7
+ - Fix package-lock and move typescript and types/node into root
8
+ - Update eslint and plugins:
9
+ - Apply new rules such as sort imports and file name
10
+ - Update dependencies
11
+ - @rosen-bridge/extended-typeorm@1.0.1
12
+ - @rosen-clients/rate-limited-axios@1.1.0
13
+ - @rosen-bridge/rosen-extractor@10.1.1
14
+ - @rosen-bridge/tokens@4.0.1
15
+ - @rosen-bridge/abstract-logger@3.0.1
16
+ - @rosen-bridge/json-bigint@1.1.0
17
+ - @rosen-clients/ergo-explorer@2.1.0
18
+ - @rosen-clients/ergo-node@3.1.0
19
+ - @rosen-bridge/abstract-extractor@2.1.2
20
+ - @rosen-bridge/scanner-interfaces@0.2.1
21
+
3
22
  ## 0.2.0
4
23
 
5
24
  ### Minor Changes
package/dist/index.d.ts CHANGED
@@ -5,7 +5,7 @@ export { ExtractorStatusEntity } from './entities/extractorStatusEntity';
5
5
  export { AbstractScanner } from './scanner/abstract/scanner';
6
6
  export { GeneralScanner } from './scanner/abstract/generalScanner';
7
7
  export { WebSocketScanner } from './scanner/abstract/webSocketScanner';
8
- export { ConnectorSelectionStrategy, FailoverStrategy, RoundRobinStrategy, } from './scanner/network/ConnectorSelectionStrategies';
9
- export { NetworkConnectorManager } from './scanner/network/NetworkConnectorManager';
8
+ export { ConnectorSelectionStrategy, FailoverStrategy, RoundRobinStrategy, } from './scanner/network/connectorSelectionStrategies';
9
+ export { NetworkConnectorManager } from './scanner/network/networkConnectorManager';
10
10
  export { ScannerConfig } from './scanner/interfaces';
11
11
  //# sourceMappingURL=index.d.ts.map
package/dist/index.js CHANGED
@@ -5,6 +5,6 @@ export { ExtractorStatusEntity } from './entities/extractorStatusEntity';
5
5
  export { AbstractScanner } from './scanner/abstract/scanner';
6
6
  export { GeneralScanner } from './scanner/abstract/generalScanner';
7
7
  export { WebSocketScanner } from './scanner/abstract/webSocketScanner';
8
- export { FailoverStrategy, RoundRobinStrategy, } from './scanner/network/ConnectorSelectionStrategies';
9
- export { NetworkConnectorManager } from './scanner/network/NetworkConnectorManager';
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9saWIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDMUMsT0FBTyxFQUFFLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUM5RCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUN6RSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDN0QsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ25FLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQ3ZFLE9BQU8sRUFFTCxnQkFBZ0IsRUFDaEIsa0JBQWtCLEdBQ25CLE1BQU0sZ0RBQWdELENBQUM7QUFDeEQsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sMkNBQTJDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBCbG9ja0RiQWN0aW9uIH0gZnJvbSAnLi9zY2FubmVyL2FjdGlvbic7XG5leHBvcnQgeyBtaWdyYXRpb25zIH0gZnJvbSAnLi9taWdyYXRpb25zJztcbmV4cG9ydCB7IFBST0NFRUQsIEJsb2NrRW50aXR5IH0gZnJvbSAnLi9lbnRpdGllcy9ibG9ja0VudGl0eSc7XG5leHBvcnQgeyBFeHRyYWN0b3JTdGF0dXNFbnRpdHkgfSBmcm9tICcuL2VudGl0aWVzL2V4dHJhY3RvclN0YXR1c0VudGl0eSc7XG5leHBvcnQgeyBBYnN0cmFjdFNjYW5uZXIgfSBmcm9tICcuL3NjYW5uZXIvYWJzdHJhY3Qvc2Nhbm5lcic7XG5leHBvcnQgeyBHZW5lcmFsU2Nhbm5lciB9IGZyb20gJy4vc2Nhbm5lci9hYnN0cmFjdC9nZW5lcmFsU2Nhbm5lcic7XG5leHBvcnQgeyBXZWJTb2NrZXRTY2FubmVyIH0gZnJvbSAnLi9zY2FubmVyL2Fic3RyYWN0L3dlYlNvY2tldFNjYW5uZXInO1xuZXhwb3J0IHtcbiAgQ29ubmVjdG9yU2VsZWN0aW9uU3RyYXRlZ3ksXG4gIEZhaWxvdmVyU3RyYXRlZ3ksXG4gIFJvdW5kUm9iaW5TdHJhdGVneSxcbn0gZnJvbSAnLi9zY2FubmVyL25ldHdvcmsvQ29ubmVjdG9yU2VsZWN0aW9uU3RyYXRlZ2llcyc7XG5leHBvcnQgeyBOZXR3b3JrQ29ubmVjdG9yTWFuYWdlciB9IGZyb20gJy4vc2Nhbm5lci9uZXR3b3JrL05ldHdvcmtDb25uZWN0b3JNYW5hZ2VyJztcbmV4cG9ydCB7IFNjYW5uZXJDb25maWcgfSBmcm9tICcuL3NjYW5uZXIvaW50ZXJmYWNlcyc7XG4iXX0=
8
+ export { FailoverStrategy, RoundRobinStrategy, } from './scanner/network/connectorSelectionStrategies';
9
+ export { NetworkConnectorManager } from './scanner/network/networkConnectorManager';
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9saWIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDMUMsT0FBTyxFQUFFLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUM5RCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUN6RSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDN0QsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ25FLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQ3ZFLE9BQU8sRUFFTCxnQkFBZ0IsRUFDaEIsa0JBQWtCLEdBQ25CLE1BQU0sZ0RBQWdELENBQUM7QUFDeEQsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sMkNBQTJDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBCbG9ja0RiQWN0aW9uIH0gZnJvbSAnLi9zY2FubmVyL2FjdGlvbic7XG5leHBvcnQgeyBtaWdyYXRpb25zIH0gZnJvbSAnLi9taWdyYXRpb25zJztcbmV4cG9ydCB7IFBST0NFRUQsIEJsb2NrRW50aXR5IH0gZnJvbSAnLi9lbnRpdGllcy9ibG9ja0VudGl0eSc7XG5leHBvcnQgeyBFeHRyYWN0b3JTdGF0dXNFbnRpdHkgfSBmcm9tICcuL2VudGl0aWVzL2V4dHJhY3RvclN0YXR1c0VudGl0eSc7XG5leHBvcnQgeyBBYnN0cmFjdFNjYW5uZXIgfSBmcm9tICcuL3NjYW5uZXIvYWJzdHJhY3Qvc2Nhbm5lcic7XG5leHBvcnQgeyBHZW5lcmFsU2Nhbm5lciB9IGZyb20gJy4vc2Nhbm5lci9hYnN0cmFjdC9nZW5lcmFsU2Nhbm5lcic7XG5leHBvcnQgeyBXZWJTb2NrZXRTY2FubmVyIH0gZnJvbSAnLi9zY2FubmVyL2Fic3RyYWN0L3dlYlNvY2tldFNjYW5uZXInO1xuZXhwb3J0IHtcbiAgQ29ubmVjdG9yU2VsZWN0aW9uU3RyYXRlZ3ksXG4gIEZhaWxvdmVyU3RyYXRlZ3ksXG4gIFJvdW5kUm9iaW5TdHJhdGVneSxcbn0gZnJvbSAnLi9zY2FubmVyL25ldHdvcmsvY29ubmVjdG9yU2VsZWN0aW9uU3RyYXRlZ2llcyc7XG5leHBvcnQgeyBOZXR3b3JrQ29ubmVjdG9yTWFuYWdlciB9IGZyb20gJy4vc2Nhbm5lci9uZXR3b3JrL25ldHdvcmtDb25uZWN0b3JNYW5hZ2VyJztcbmV4cG9ydCB7IFNjYW5uZXJDb25maWcgfSBmcm9tICcuL3NjYW5uZXIvaW50ZXJmYWNlcyc7XG4iXX0=
@@ -1,8 +1,8 @@
1
- import { AbstractScanner } from './scanner';
2
- import { AbstractNetworkConnector, Block } from '@rosen-bridge/scanner-interfaces';
3
- import { BlockEntity } from '../../entities/blockEntity';
4
1
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
5
2
  import { DataSource } from '@rosen-bridge/extended-typeorm';
3
+ import { AbstractNetworkConnector, Block } from '@rosen-bridge/scanner-interfaces';
4
+ import { BlockEntity } from '../../entities/blockEntity';
5
+ import { AbstractScanner } from './scanner';
6
6
  declare abstract class GeneralScanner<TransactionType> extends AbstractScanner<TransactionType> {
7
7
  private scannerName;
8
8
  private dataSource;
@@ -1 +1 @@
1
- {"version":3,"file":"generalScanner.d.ts","sourceRoot":"","sources":["../../../lib/scanner/abstract/generalScanner.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAC5C,OAAO,EACL,wBAAwB,EACxB,KAAK,EACN,MAAM,kCAAkC,CAAC;AAC1C,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AAEzD,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAE/D,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAE5D,uBAAe,cAAc,CAC3B,eAAe,CACf,SAAQ,eAAe,CAAC,eAAe,CAAC;IAOtC,OAAO,CAAC,WAAW;IACnB,OAAO,CAAC,UAAU;IAElB,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,gBAAgB;IAExB,OAAO,CAAC,MAAM,CAAC;IAZjB,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAS;IACvC,SAAS,CAAC,oBAAoB,EAAE,MAAM,GAAG,SAAS,CAAa;IAE/D,IAAI,eAAmE;gBAG7D,WAAW,EAAE,MAAM,EACnB,UAAU,EAAE,UAAU,EAC9B,aAAa,EAAE,MAAM,EACb,OAAO,EAAE,wBAAwB,CAAC,eAAe,CAAC,EAClD,gBAAgB,SAAI,EAC5B,MAAM,CAAC,EAAE,cAAc,EACf,MAAM,CAAC,oBAAQ;IAYzB;;;OAGG;IACH,SAAS,CAAC,aAAa,QAAO,QAAQ,KAAK,CAAC,CAE1C;IAEF;;;OAGG;IACH,SAAS,CAAC,YAAY,QAAa,QAAQ,OAAO,CAAC,CAUjD;IAEF;;OAEG;IACH,SAAS,CAAC,4BAA4B,cAAqB,MAAM,mBAK/D;IAEF;;;OAGG;IACH,SAAS,CAAC,YAAY,UAAiB,KAAK,kCAyB1C;IAEF;;;OAGG;IACH,SAAS,CAAC,WAAW,mBAA0B,WAAW,mBA8BxD;IAEF;;;OAGG;IACH,SAAS,CAAC,YAAY,sBAepB;IAEF;;;;OAIG;IACH,SAAS,CAAC,UAAU,6BAYlB;IAEF;;;OAGG;IACI,uBAAuB,QAAO,MAAM,GAAG,SAAS,CAC3B;IAE5B;;;OAGG;IACH,MAAM,sBAqBJ;CACH;AAED,OAAO,EAAE,cAAc,EAAE,CAAC"}
1
+ {"version":3,"file":"generalScanner.d.ts","sourceRoot":"","sources":["../../../lib/scanner/abstract/generalScanner.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAE5D,OAAO,EACL,wBAAwB,EACxB,KAAK,EACN,MAAM,kCAAkC,CAAC;AAE1C,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AAEzD,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAE5C,uBAAe,cAAc,CAC3B,eAAe,CACf,SAAQ,eAAe,CAAC,eAAe,CAAC;IAOtC,OAAO,CAAC,WAAW;IACnB,OAAO,CAAC,UAAU;IAElB,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,gBAAgB;IAExB,OAAO,CAAC,MAAM,CAAC;IAZjB,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAS;IACvC,SAAS,CAAC,oBAAoB,EAAE,MAAM,GAAG,SAAS,CAAa;IAE/D,IAAI,eAAmE;gBAG7D,WAAW,EAAE,MAAM,EACnB,UAAU,EAAE,UAAU,EAC9B,aAAa,EAAE,MAAM,EACb,OAAO,EAAE,wBAAwB,CAAC,eAAe,CAAC,EAClD,gBAAgB,SAAI,EAC5B,MAAM,CAAC,EAAE,cAAc,EACf,MAAM,CAAC,EAAE,MAAM,YAAA;IAYzB;;;OAGG;IACH,SAAS,CAAC,aAAa,QAAO,OAAO,CAAC,KAAK,CAAC,CAE1C;IAEF;;;OAGG;IACH,SAAS,CAAC,YAAY,QAAa,OAAO,CAAC,OAAO,CAAC,CAUjD;IAEF;;OAEG;IACH,SAAS,CAAC,4BAA4B,GAAU,WAAW,MAAM,mBAK/D;IAEF;;;OAGG;IACH,SAAS,CAAC,YAAY,GAAU,OAAO,KAAK,kCAyB1C;IAEF;;;OAGG;IACH,SAAS,CAAC,WAAW,GAAU,gBAAgB,WAAW,mBA8BxD;IAEF;;;OAGG;IACH,SAAS,CAAC,YAAY,sBAepB;IAEF;;;;OAIG;IACH,SAAS,CAAC,UAAU,6BAYlB;IAEF;;;OAGG;IACI,uBAAuB,QAAO,MAAM,GAAG,SAAS,CAC3B;IAE5B;;;OAGG;IACH,MAAM,sBAqBJ;CACH;AAED,OAAO,EAAE,cAAc,EAAE,CAAC"}
@@ -1,6 +1,6 @@
1
- import { AbstractScanner } from './scanner';
2
1
  import JsonBI from '@rosen-bridge/json-bigint';
3
2
  import { BlockDbAction } from '../action';
3
+ import { AbstractScanner } from './scanner';
4
4
  class GeneralScanner extends AbstractScanner {
5
5
  scannerName;
6
6
  dataSource;
@@ -171,4 +171,4 @@ class GeneralScanner extends AbstractScanner {
171
171
  };
172
172
  }
173
173
  export { GeneralScanner };
174
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generalScanner.js","sourceRoot":"","sources":["../../../lib/scanner/abstract/generalScanner.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractScanner } from './scanner';\nimport {\n  AbstractNetworkConnector,\n  Block,\n} from '@rosen-bridge/scanner-interfaces';\nimport { BlockEntity } from '../../entities/blockEntity';\nimport JsonBI from '@rosen-bridge/json-bigint';\nimport { AbstractLogger } from '@rosen-bridge/abstract-logger';\nimport { BlockDbAction } from '../action';\nimport { DataSource } from '@rosen-bridge/extended-typeorm';\n\nabstract class GeneralScanner<\n  TransactionType,\n> extends AbstractScanner<TransactionType> {\n  private readonly initialHeight: number;\n  protected blockChainLastHeight: number | undefined = undefined;\n\n  name = () => this.scannerName + (this.suffix ? `-${this.suffix}` : '');\n\n  constructor(\n    private scannerName: string,\n    private dataSource: DataSource,\n    initialHeight: number,\n    private network: AbstractNetworkConnector<TransactionType>,\n    private blockRetrieveGap = 0,\n    logger?: AbstractLogger,\n    private suffix?: string,\n  ) {\n    super(logger);\n    /**\n     * In order to keep the scanners functionalities consistent, we add config\n     * `initialHeight` by one so that it matches how other scanners work.\n     */\n    this.initialHeight = initialHeight + 1;\n    this.suffix = suffix;\n    this.action = new BlockDbAction(this.dataSource, this.name(), this.logger);\n  }\n\n  /**\n   * Get the first block to process\n   * @returns The first block at the configured initial height\n   */\n  protected getFirstBlock = (): Promise<Block> => {\n    return this.network.getBlockAtHeight(this.initialHeight);\n  };\n\n  /**\n   * function that checks if fork is happen in the blockchain or not\n   * @return Promise<Boolean>\n   */\n  protected isForkHappen = async (): Promise<boolean> => {\n    const lastSavedBlock = await this.action.getLastSavedBlock();\n    if (lastSavedBlock !== undefined) {\n      const lastSavedBlockFromNetwork = await this.network.getBlockAtHeight(\n        lastSavedBlock.height,\n      );\n      return lastSavedBlockFromNetwork.hash !== lastSavedBlock.hash;\n    } else {\n      return false;\n    }\n  };\n\n  /**\n   * This method introduces delay between consecutive block processing operations\n   */\n  protected delayBetweenBlocksProcessing = async (startTime: number) => {\n    const spentTime = new Date().getTime() - startTime;\n    await new Promise((resolve) =>\n      setTimeout(() => resolve(null), this.blockRetrieveGap - spentTime),\n    );\n  };\n\n  /**\n   * process a block and execute all extractor on it.\n   * @param block\n   */\n  protected processBlock = async (block: Block) => {\n    const startTime = new Date().getTime();\n    this.logger.debug(\n      `Processing block at height [${block.height}] in scanner ${this.name()}`,\n    );\n    const txs = await this.network.getBlockTxs(block.hash);\n    if (block.txCount) {\n      if (txs.length != block.txCount) {\n        this.logger.debug(\n          `Aborting block process with hash [${block.hash}] expected to have ${block.txCount} transactions but had ${txs.length}`,\n        );\n        return false;\n      }\n      this.logger.debug(\n        `processing ${block.txCount} transactions of block with hash [${block.hash}]`,\n      );\n    }\n\n    const result = await this.processBlockTransactions(block, txs);\n\n    // Spending time between block fetches if the setting is enabled\n    if (this.blockRetrieveGap)\n      await this.delayBetweenBlocksProcessing(startTime);\n\n    return result;\n  };\n\n  /**\n   * process forward in scanner. get blocks and store information from transactions.\n   * @param lastSavedBlock: last saved block entity in database\n   */\n  protected stepForward = async (lastSavedBlock: BlockEntity) => {\n    const currentHeight = await this.network.getCurrentHeight();\n    const firstBlock = await this.action.getFirstSavedBlock();\n    if (!firstBlock || firstBlock.height >= currentHeight) {\n      return;\n    }\n    for (\n      let height = lastSavedBlock.height + 1;\n      height <= currentHeight;\n      height++\n    ) {\n      const block = await this.network.getBlockAtHeight(height);\n      if (lastSavedBlock !== undefined) {\n        if (block.parentHash === lastSavedBlock.hash) {\n          const savedBlock = await this.processBlock(block);\n          if (typeof savedBlock === 'boolean') {\n            break;\n          } else {\n            lastSavedBlock = savedBlock;\n          }\n        } else {\n          this.logger.debug(\n            `Invalid block at height ${height}. Block info is [${JsonBI.stringify(\n              block,\n            )} and the expected parent hash is [${lastSavedBlock.hash}]`,\n          );\n          break;\n        }\n      }\n    }\n  };\n\n  /**\n   * Step backward in blockchain and find fork point.\n   * and remove all forked blocks from database\n   */\n  protected stepBackward = async () => {\n    let block = await this.action.getLastSavedBlock();\n    while (block) {\n      const blockFromNetwork = await this.network.getBlockAtHeight(\n        block.height,\n      );\n      if (\n        blockFromNetwork.hash === block.hash &&\n        block.parentHash === blockFromNetwork.parentHash\n      ) {\n        return;\n      }\n      await this.forkBlock(block.height);\n      block = await this.action.getLastSavedBlock();\n    }\n  };\n\n  /**\n   * Initialize the extractors with the first block\n   * Process and store the first block in database\n   * @returns\n   */\n  protected initialize = async () => {\n    const block = await this.getFirstBlock();\n    await this.verifyExtractorsInitialization({\n      height: block.height - 1,\n      hash: block.parentHash,\n    });\n    await this.processBlock(block);\n    const entity = await this.action.getFirstSavedBlock();\n    if (entity === undefined) {\n      throw new Error('Can not store block in database');\n    }\n    return entity;\n  };\n\n  /**\n   * Return the latest height of the blockchain\n   * @returns { number | undefined }\n   */\n  public getBlockChainLastHeight = (): number | undefined =>\n    this.blockChainLastHeight;\n\n  /**\n   * worker function that runs for syncing the database with the Cardano blockchain and checks if we have any fork\n   * scenario in the blockchain and invalidate the database till the database synced again.\n   */\n  update = async () => {\n    try {\n      const latestHeight = await this.network.getCurrentHeight();\n      if (\n        !this.blockChainLastHeight ||\n        this.blockChainLastHeight < latestHeight\n      )\n        this.blockChainLastHeight = latestHeight;\n\n      let lastSavedBlock = await this.action.getLastSavedBlock();\n      if (!lastSavedBlock) {\n        lastSavedBlock = await this.initialize();\n      } else await this.verifyExtractorsInitialization(lastSavedBlock);\n      if (!(await this.isForkHappen())) {\n        await this.stepForward(lastSavedBlock);\n      } else {\n        await this.stepBackward();\n      }\n    } catch (e) {\n      this.logger.error(`An error occurred during update process. ${e}`);\n    }\n  };\n}\n\nexport { GeneralScanner };\n"]}
174
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generalScanner.js","sourceRoot":"","sources":["../../../lib/scanner/abstract/generalScanner.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractLogger } from '@rosen-bridge/abstract-logger';\nimport { DataSource } from '@rosen-bridge/extended-typeorm';\nimport JsonBI from '@rosen-bridge/json-bigint';\nimport {\n  AbstractNetworkConnector,\n  Block,\n} from '@rosen-bridge/scanner-interfaces';\n\nimport { BlockEntity } from '../../entities/blockEntity';\nimport { BlockDbAction } from '../action';\nimport { AbstractScanner } from './scanner';\n\nabstract class GeneralScanner<\n  TransactionType,\n> extends AbstractScanner<TransactionType> {\n  private readonly initialHeight: number;\n  protected blockChainLastHeight: number | undefined = undefined;\n\n  name = () => this.scannerName + (this.suffix ? `-${this.suffix}` : '');\n\n  constructor(\n    private scannerName: string,\n    private dataSource: DataSource,\n    initialHeight: number,\n    private network: AbstractNetworkConnector<TransactionType>,\n    private blockRetrieveGap = 0,\n    logger?: AbstractLogger,\n    private suffix?: string,\n  ) {\n    super(logger);\n    /**\n     * In order to keep the scanners functionalities consistent, we add config\n     * `initialHeight` by one so that it matches how other scanners work.\n     */\n    this.initialHeight = initialHeight + 1;\n    this.suffix = suffix;\n    this.action = new BlockDbAction(this.dataSource, this.name(), this.logger);\n  }\n\n  /**\n   * Get the first block to process\n   * @returns The first block at the configured initial height\n   */\n  protected getFirstBlock = (): Promise<Block> => {\n    return this.network.getBlockAtHeight(this.initialHeight);\n  };\n\n  /**\n   * function that checks if fork is happen in the blockchain or not\n   * @return Promise<Boolean>\n   */\n  protected isForkHappen = async (): Promise<boolean> => {\n    const lastSavedBlock = await this.action.getLastSavedBlock();\n    if (lastSavedBlock !== undefined) {\n      const lastSavedBlockFromNetwork = await this.network.getBlockAtHeight(\n        lastSavedBlock.height,\n      );\n      return lastSavedBlockFromNetwork.hash !== lastSavedBlock.hash;\n    } else {\n      return false;\n    }\n  };\n\n  /**\n   * This method introduces delay between consecutive block processing operations\n   */\n  protected delayBetweenBlocksProcessing = async (startTime: number) => {\n    const spentTime = new Date().getTime() - startTime;\n    await new Promise((resolve) =>\n      setTimeout(() => resolve(null), this.blockRetrieveGap - spentTime),\n    );\n  };\n\n  /**\n   * process a block and execute all extractor on it.\n   * @param block\n   */\n  protected processBlock = async (block: Block) => {\n    const startTime = new Date().getTime();\n    this.logger.debug(\n      `Processing block at height [${block.height}] in scanner ${this.name()}`,\n    );\n    const txs = await this.network.getBlockTxs(block.hash);\n    if (block.txCount) {\n      if (txs.length != block.txCount) {\n        this.logger.debug(\n          `Aborting block process with hash [${block.hash}] expected to have ${block.txCount} transactions but had ${txs.length}`,\n        );\n        return false;\n      }\n      this.logger.debug(\n        `processing ${block.txCount} transactions of block with hash [${block.hash}]`,\n      );\n    }\n\n    const result = await this.processBlockTransactions(block, txs);\n\n    // Spending time between block fetches if the setting is enabled\n    if (this.blockRetrieveGap)\n      await this.delayBetweenBlocksProcessing(startTime);\n\n    return result;\n  };\n\n  /**\n   * process forward in scanner. get blocks and store information from transactions.\n   * @param lastSavedBlock: last saved block entity in database\n   */\n  protected stepForward = async (lastSavedBlock: BlockEntity) => {\n    const currentHeight = await this.network.getCurrentHeight();\n    const firstBlock = await this.action.getFirstSavedBlock();\n    if (!firstBlock || firstBlock.height >= currentHeight) {\n      return;\n    }\n    for (\n      let height = lastSavedBlock.height + 1;\n      height <= currentHeight;\n      height++\n    ) {\n      const block = await this.network.getBlockAtHeight(height);\n      if (lastSavedBlock !== undefined) {\n        if (block.parentHash === lastSavedBlock.hash) {\n          const savedBlock = await this.processBlock(block);\n          if (typeof savedBlock === 'boolean') {\n            break;\n          } else {\n            lastSavedBlock = savedBlock;\n          }\n        } else {\n          this.logger.debug(\n            `Invalid block at height ${height}. Block info is [${JsonBI.stringify(\n              block,\n            )} and the expected parent hash is [${lastSavedBlock.hash}]`,\n          );\n          break;\n        }\n      }\n    }\n  };\n\n  /**\n   * Step backward in blockchain and find fork point.\n   * and remove all forked blocks from database\n   */\n  protected stepBackward = async () => {\n    let block = await this.action.getLastSavedBlock();\n    while (block) {\n      const blockFromNetwork = await this.network.getBlockAtHeight(\n        block.height,\n      );\n      if (\n        blockFromNetwork.hash === block.hash &&\n        block.parentHash === blockFromNetwork.parentHash\n      ) {\n        return;\n      }\n      await this.forkBlock(block.height);\n      block = await this.action.getLastSavedBlock();\n    }\n  };\n\n  /**\n   * Initialize the extractors with the first block\n   * Process and store the first block in database\n   * @returns\n   */\n  protected initialize = async () => {\n    const block = await this.getFirstBlock();\n    await this.verifyExtractorsInitialization({\n      height: block.height - 1,\n      hash: block.parentHash,\n    });\n    await this.processBlock(block);\n    const entity = await this.action.getFirstSavedBlock();\n    if (entity === undefined) {\n      throw new Error('Can not store block in database');\n    }\n    return entity;\n  };\n\n  /**\n   * Return the latest height of the blockchain\n   * @returns { number | undefined }\n   */\n  public getBlockChainLastHeight = (): number | undefined =>\n    this.blockChainLastHeight;\n\n  /**\n   * worker function that runs for syncing the database with the Cardano blockchain and checks if we have any fork\n   * scenario in the blockchain and invalidate the database till the database synced again.\n   */\n  update = async () => {\n    try {\n      const latestHeight = await this.network.getCurrentHeight();\n      if (\n        !this.blockChainLastHeight ||\n        this.blockChainLastHeight < latestHeight\n      )\n        this.blockChainLastHeight = latestHeight;\n\n      let lastSavedBlock = await this.action.getLastSavedBlock();\n      if (!lastSavedBlock) {\n        lastSavedBlock = await this.initialize();\n      } else await this.verifyExtractorsInitialization(lastSavedBlock);\n      if (!(await this.isForkHappen())) {\n        await this.stepForward(lastSavedBlock);\n      } else {\n        await this.stepBackward();\n      }\n    } catch (e) {\n      this.logger.error(`An error occurred during update process. ${e}`);\n    }\n  };\n}\n\nexport { GeneralScanner };\n"]}
@@ -1,7 +1,7 @@
1
1
  import { Mutex } from 'await-semaphore';
2
- import { Block, BlockInfo } from '@rosen-bridge/scanner-interfaces';
3
- import { AbstractLogger } from '@rosen-bridge/abstract-logger';
4
2
  import { AbstractExtractor } from '@rosen-bridge/abstract-extractor';
3
+ import { AbstractLogger } from '@rosen-bridge/abstract-logger';
4
+ import { Block, BlockInfo } from '@rosen-bridge/scanner-interfaces';
5
5
  import { BlockDbAction } from '../action';
6
6
  export declare abstract class AbstractScanner<TransactionType> {
7
7
  action: BlockDbAction;
@@ -1 +1 @@
1
- {"version":3,"file":"scanner.d.ts","sourceRoot":"","sources":["../../../lib/scanner/abstract/scanner.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AACxC,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,kCAAkC,CAAC;AACpE,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAE5E,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AAErE,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAE1C,8BAAsB,eAAe,CAAC,eAAe;IACnD,MAAM,EAAE,aAAa,CAAC;IACtB,UAAU,EAAE,KAAK,CAAC,iBAAiB,CAAC,eAAe,CAAC,CAAC,CAAC;IACtD,aAAa,EAAE,KAAK,CAAC,iBAAiB,CAAC,eAAe,CAAC,CAAC,CAAC;IACzD,MAAM,EAAE,cAAc,CAAC;IACvB,eAAe,EAAE,KAAK,CAAC;gBAEX,MAAM,CAAC,EAAE,cAAc;IAOnC,QAAQ,CAAC,IAAI,EAAE,MAAM,MAAM,CAAC;IAE5B;;;OAGG;IACH,SAAS,CAAC,SAAS,WAAkB,MAAM,mBAuBzC;IAEF;;;;OAIG;IACH,SAAS,CAAC,wBAAwB,UACzB,KAAK,gBACE,MAAM,eAAe,CAAC,kDAyBpC;IAEF;;;OAGG;IACH,iBAAiB,cACJ,kBAAkB,eAAe,CAAC,KAC5C,QAAQ,IAAI,CAAC,CAmBd;IAEF;;;OAGG;IACH,eAAe,cACF,kBAAkB,eAAe,CAAC,KAC5C,QAAQ,IAAI,CAAC,CAQd;IAEF;;;;OAIG;IACH,OAAO,CAAC,oBAAoB,CAkB1B;IAEF;;;;OAIG;IACH,SAAS,CAAC,8BAA8B,UAAiB,SAAS,mBA2DhE;CACH"}
1
+ {"version":3,"file":"scanner.d.ts","sourceRoot":"","sources":["../../../lib/scanner/abstract/scanner.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAGxC,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,kCAAkC,CAAC;AAEpE,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAE1C,8BAAsB,eAAe,CAAC,eAAe;IACnD,MAAM,EAAE,aAAa,CAAC;IACtB,UAAU,EAAE,KAAK,CAAC,iBAAiB,CAAC,eAAe,CAAC,CAAC,CAAC;IACtD,aAAa,EAAE,KAAK,CAAC,iBAAiB,CAAC,eAAe,CAAC,CAAC,CAAC;IACzD,MAAM,EAAE,cAAc,CAAC;IACvB,eAAe,EAAE,KAAK,CAAC;gBAEX,MAAM,CAAC,EAAE,cAAc;IAOnC,QAAQ,CAAC,IAAI,EAAE,MAAM,MAAM,CAAC;IAE5B;;;OAGG;IACH,SAAS,CAAC,SAAS,GAAU,QAAQ,MAAM,mBAuBzC;IAEF;;;;OAIG;IACH,SAAS,CAAC,wBAAwB,GAChC,OAAO,KAAK,EACZ,cAAc,KAAK,CAAC,eAAe,CAAC,kDAyBpC;IAEF;;;OAGG;IACH,iBAAiB,GACf,WAAW,iBAAiB,CAAC,eAAe,CAAC,KAC5C,OAAO,CAAC,IAAI,CAAC,CAmBd;IAEF;;;OAGG;IACH,eAAe,GACb,WAAW,iBAAiB,CAAC,eAAe,CAAC,KAC5C,OAAO,CAAC,IAAI,CAAC,CAQd;IAEF;;;;OAIG;IACH,OAAO,CAAC,oBAAoB,CAkB1B;IAEF;;;;OAIG;IACH,SAAS,CAAC,8BAA8B,GAAU,OAAO,SAAS,mBA2DhE;CACH"}
@@ -1,6 +1,6 @@
1
1
  import { Mutex } from 'await-semaphore';
2
- import { DummyLogger } from '@rosen-bridge/abstract-logger';
3
2
  import { difference, remove } from 'lodash-es';
3
+ import { DummyLogger } from '@rosen-bridge/abstract-logger';
4
4
  export class AbstractScanner {
5
5
  action;
6
6
  extractors;
@@ -151,4 +151,4 @@ export class AbstractScanner {
151
151
  throw new Error(`Initialization failed for new extractors ${getIds(this.newExtractors)}`);
152
152
  };
153
153
  }
154
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scanner.js","sourceRoot":"","sources":["../../../lib/scanner/abstract/scanner.ts"],"names":[],"mappings":"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","sourcesContent":["import { Mutex } from 'await-semaphore';\nimport { Block, BlockInfo } from '@rosen-bridge/scanner-interfaces';\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport { difference, remove } from 'lodash-es';\nimport { AbstractExtractor } from '@rosen-bridge/abstract-extractor';\n\nimport { BlockDbAction } from '../action';\n\nexport abstract class AbstractScanner<TransactionType> {\n  action: BlockDbAction;\n  extractors: Array<AbstractExtractor<TransactionType>>;\n  newExtractors: Array<AbstractExtractor<TransactionType>>;\n  logger: AbstractLogger;\n  initializeMutex: Mutex;\n\n  constructor(logger?: AbstractLogger) {\n    this.extractors = [];\n    this.newExtractors = [];\n    this.logger = logger ? logger : new DummyLogger();\n    this.initializeMutex = new Mutex();\n  }\n\n  abstract name: () => string;\n\n  /**\n   * fork blocks from specific height from scanner.\n   * @param height: selected height\n   */\n  protected forkBlock = async (height: number) => {\n    let lastBlock = await this.action.getLastSavedBlock();\n    while (lastBlock && lastBlock.height >= height) {\n      this.logger.debug(\n        `Reverting block ${lastBlock.hash} at height ${lastBlock.height}`,\n      );\n      await this.action.revertBlockStatus(\n        lastBlock.height,\n        lastBlock.parentHash,\n        this.extractors.map((e) => e.getId()),\n      );\n      for (const extractor of this.extractors) {\n        try {\n          await extractor.forkBlock(lastBlock.hash);\n        } catch (e) {\n          this.logger.error(\n            `An error occurred during fork block in extractor ${extractor.getId()}: ${e}`,\n          );\n        }\n      }\n      await this.action.removeBlocksFromHeight(lastBlock.height);\n      lastBlock = await this.action.getBlockAtHeight(lastBlock.height - 1);\n    }\n  };\n\n  /**\n   * process a block and all of its transactions. store any information into database\n   * @param block: selected block\n   * @param transactions: list of transaction for selected block\n   */\n  protected processBlockTransactions = async (\n    block: Block,\n    transactions: Array<TransactionType>,\n  ) => {\n    const savedBlock = await this.action.saveBlock(block);\n    if (typeof savedBlock === 'boolean') {\n      return false;\n    }\n    let success = true;\n    for (const extractor of this.extractors) {\n      if (!(await extractor.processTransactions(transactions, savedBlock))) {\n        success = false;\n        break;\n      }\n    }\n\n    if (\n      success &&\n      (await this.action.updateBlockStatus(\n        block.height,\n        block.hash,\n        this.extractors.map((e) => e.getId()),\n      ))\n    ) {\n      return savedBlock;\n    }\n    return false;\n  };\n\n  /**\n   * register a nre extractor to scanner.\n   * @param extractor\n   */\n  registerExtractor = async (\n    extractor: AbstractExtractor<TransactionType>,\n  ): Promise<void> => {\n    const notRegisteredIn = (\n      extractors: Array<AbstractExtractor<TransactionType>>,\n    ) =>\n      extractors.filter(\n        (extractorItem) => extractorItem.getId() === extractor.getId(),\n      ).length === 0;\n    const release = await this.initializeMutex.acquire();\n    if (\n      notRegisteredIn(this.extractors) &&\n      notRegisteredIn(this.newExtractors)\n    ) {\n      this.newExtractors.push(extractor);\n    } else {\n      this.logger.warn(\n        `Extractor with id ${extractor.getId()} is already registered`,\n      );\n    }\n    release();\n  };\n\n  /**\n   * remove an extractor from scanner\n   * @param extractor\n   */\n  removeExtractor = async (\n    extractor: AbstractExtractor<TransactionType>,\n  ): Promise<void> => {\n    const removeFn = (ex: AbstractExtractor<TransactionType>) =>\n      ex.getId() === extractor.getId();\n\n    const release = await this.initializeMutex.acquire();\n    remove(this.extractors, removeFn);\n    remove(this.newExtractors, removeFn);\n    release();\n  };\n\n  /**\n   * Initialize all specified extractors and store the updated status\n   * @param extractorIds\n   * @param height\n   */\n  private initializeExtractors = async (\n    extractorIds: string[],\n    block: BlockInfo,\n  ) => {\n    const allExtractors = [...this.extractors, ...this.newExtractors];\n    const initRequiredExtractors = allExtractors.filter((extractor) =>\n      extractorIds.includes(extractor.getId()),\n    );\n    for (const extractor of initRequiredExtractors) {\n      this.logger.info(`Initializing [${extractor.getId()}] boxes`);\n      await extractor.initializeBoxes(block);\n      await this.action.updateOrInsertExtractorStatus(\n        extractor.getId(),\n        block.height,\n        block.hash,\n      );\n      this.logger.debug(`Initialization finished for [${extractor.getId()}]`);\n    }\n  };\n\n  /**\n   * Initializes the extractors if they're not synced or not initialized yet,\n   * and update the active extractors list\n   * @param block\n   */\n  protected verifyExtractorsInitialization = async (block: BlockInfo) => {\n    const getIds = (extractors: Array<AbstractExtractor<TransactionType>>) => {\n      return extractors.map((extractor) => extractor.getId());\n    };\n    this.logger.debug(`Initializing extractors for block [${block.height}]`);\n    let success = true;\n    const release = await this.initializeMutex.acquire();\n    try {\n      const extractorsStatus = await this.action.getExtractorsStatus([\n        ...getIds(this.extractors),\n        ...getIds(this.newExtractors),\n      ]);\n      this.logger.debug(\n        `Stored extractors status are [${JSON.stringify(extractorsStatus)}]`,\n      );\n      // Find extractors not synced with the latest height\n      const notSyncedExtractorIds = extractorsStatus\n        .filter((es) => es.updateBlockHash != block.hash)\n        .map((es) => es.extractorId);\n      if (notSyncedExtractorIds.length > 0)\n        this.logger.debug(\n          `Old not synced extractors are ${notSyncedExtractorIds}`,\n        );\n      // Find new extractors not available in database\n      const storedExtractorIds = extractorsStatus.map((es) => es.extractorId);\n      const newRegisteredExtractorIds = difference(\n        getIds(this.newExtractors),\n        storedExtractorIds,\n      );\n      if (newRegisteredExtractorIds.length > 0)\n        this.logger.debug(\n          `New registered extractors are ${newRegisteredExtractorIds}`,\n        );\n      // Initialize required extractors\n      const initRequiredExtractors = [\n        ...newRegisteredExtractorIds,\n        ...notSyncedExtractorIds,\n      ];\n      if (initRequiredExtractors.length > 0) {\n        this.logger.info(\n          `Initializing ${\n            initRequiredExtractors.length\n          } extractor(s) for [${this.name()}]`,\n          { initRequiredExtractors },\n        );\n        await this.initializeExtractors(initRequiredExtractors, block);\n      }\n      this.extractors.push(...this.newExtractors);\n      this.newExtractors = [];\n    } catch (e) {\n      this.logger.warn(`Initialization for extractors failed with error ${e}`);\n      success = false;\n    } finally {\n      release();\n    }\n    if (!success)\n      throw new Error(\n        `Initialization failed for new extractors ${getIds(this.newExtractors)}`,\n      );\n  };\n}\n"]}
154
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scanner.js","sourceRoot":"","sources":["../../../lib/scanner/abstract/scanner.ts"],"names":[],"mappings":"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","sourcesContent":["import { Mutex } from 'await-semaphore';\nimport { difference, remove } from 'lodash-es';\n\nimport { AbstractExtractor } from '@rosen-bridge/abstract-extractor';\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport { Block, BlockInfo } from '@rosen-bridge/scanner-interfaces';\n\nimport { BlockDbAction } from '../action';\n\nexport abstract class AbstractScanner<TransactionType> {\n  action: BlockDbAction;\n  extractors: Array<AbstractExtractor<TransactionType>>;\n  newExtractors: Array<AbstractExtractor<TransactionType>>;\n  logger: AbstractLogger;\n  initializeMutex: Mutex;\n\n  constructor(logger?: AbstractLogger) {\n    this.extractors = [];\n    this.newExtractors = [];\n    this.logger = logger ? logger : new DummyLogger();\n    this.initializeMutex = new Mutex();\n  }\n\n  abstract name: () => string;\n\n  /**\n   * fork blocks from specific height from scanner.\n   * @param height: selected height\n   */\n  protected forkBlock = async (height: number) => {\n    let lastBlock = await this.action.getLastSavedBlock();\n    while (lastBlock && lastBlock.height >= height) {\n      this.logger.debug(\n        `Reverting block ${lastBlock.hash} at height ${lastBlock.height}`,\n      );\n      await this.action.revertBlockStatus(\n        lastBlock.height,\n        lastBlock.parentHash,\n        this.extractors.map((e) => e.getId()),\n      );\n      for (const extractor of this.extractors) {\n        try {\n          await extractor.forkBlock(lastBlock.hash);\n        } catch (e) {\n          this.logger.error(\n            `An error occurred during fork block in extractor ${extractor.getId()}: ${e}`,\n          );\n        }\n      }\n      await this.action.removeBlocksFromHeight(lastBlock.height);\n      lastBlock = await this.action.getBlockAtHeight(lastBlock.height - 1);\n    }\n  };\n\n  /**\n   * process a block and all of its transactions. store any information into database\n   * @param block: selected block\n   * @param transactions: list of transaction for selected block\n   */\n  protected processBlockTransactions = async (\n    block: Block,\n    transactions: Array<TransactionType>,\n  ) => {\n    const savedBlock = await this.action.saveBlock(block);\n    if (typeof savedBlock === 'boolean') {\n      return false;\n    }\n    let success = true;\n    for (const extractor of this.extractors) {\n      if (!(await extractor.processTransactions(transactions, savedBlock))) {\n        success = false;\n        break;\n      }\n    }\n\n    if (\n      success &&\n      (await this.action.updateBlockStatus(\n        block.height,\n        block.hash,\n        this.extractors.map((e) => e.getId()),\n      ))\n    ) {\n      return savedBlock;\n    }\n    return false;\n  };\n\n  /**\n   * register a nre extractor to scanner.\n   * @param extractor\n   */\n  registerExtractor = async (\n    extractor: AbstractExtractor<TransactionType>,\n  ): Promise<void> => {\n    const notRegisteredIn = (\n      extractors: Array<AbstractExtractor<TransactionType>>,\n    ) =>\n      extractors.filter(\n        (extractorItem) => extractorItem.getId() === extractor.getId(),\n      ).length === 0;\n    const release = await this.initializeMutex.acquire();\n    if (\n      notRegisteredIn(this.extractors) &&\n      notRegisteredIn(this.newExtractors)\n    ) {\n      this.newExtractors.push(extractor);\n    } else {\n      this.logger.warn(\n        `Extractor with id ${extractor.getId()} is already registered`,\n      );\n    }\n    release();\n  };\n\n  /**\n   * remove an extractor from scanner\n   * @param extractor\n   */\n  removeExtractor = async (\n    extractor: AbstractExtractor<TransactionType>,\n  ): Promise<void> => {\n    const removeFn = (ex: AbstractExtractor<TransactionType>) =>\n      ex.getId() === extractor.getId();\n\n    const release = await this.initializeMutex.acquire();\n    remove(this.extractors, removeFn);\n    remove(this.newExtractors, removeFn);\n    release();\n  };\n\n  /**\n   * Initialize all specified extractors and store the updated status\n   * @param extractorIds\n   * @param height\n   */\n  private initializeExtractors = async (\n    extractorIds: string[],\n    block: BlockInfo,\n  ) => {\n    const allExtractors = [...this.extractors, ...this.newExtractors];\n    const initRequiredExtractors = allExtractors.filter((extractor) =>\n      extractorIds.includes(extractor.getId()),\n    );\n    for (const extractor of initRequiredExtractors) {\n      this.logger.info(`Initializing [${extractor.getId()}] boxes`);\n      await extractor.initializeBoxes(block);\n      await this.action.updateOrInsertExtractorStatus(\n        extractor.getId(),\n        block.height,\n        block.hash,\n      );\n      this.logger.debug(`Initialization finished for [${extractor.getId()}]`);\n    }\n  };\n\n  /**\n   * Initializes the extractors if they're not synced or not initialized yet,\n   * and update the active extractors list\n   * @param block\n   */\n  protected verifyExtractorsInitialization = async (block: BlockInfo) => {\n    const getIds = (extractors: Array<AbstractExtractor<TransactionType>>) => {\n      return extractors.map((extractor) => extractor.getId());\n    };\n    this.logger.debug(`Initializing extractors for block [${block.height}]`);\n    let success = true;\n    const release = await this.initializeMutex.acquire();\n    try {\n      const extractorsStatus = await this.action.getExtractorsStatus([\n        ...getIds(this.extractors),\n        ...getIds(this.newExtractors),\n      ]);\n      this.logger.debug(\n        `Stored extractors status are [${JSON.stringify(extractorsStatus)}]`,\n      );\n      // Find extractors not synced with the latest height\n      const notSyncedExtractorIds = extractorsStatus\n        .filter((es) => es.updateBlockHash != block.hash)\n        .map((es) => es.extractorId);\n      if (notSyncedExtractorIds.length > 0)\n        this.logger.debug(\n          `Old not synced extractors are ${notSyncedExtractorIds}`,\n        );\n      // Find new extractors not available in database\n      const storedExtractorIds = extractorsStatus.map((es) => es.extractorId);\n      const newRegisteredExtractorIds = difference(\n        getIds(this.newExtractors),\n        storedExtractorIds,\n      );\n      if (newRegisteredExtractorIds.length > 0)\n        this.logger.debug(\n          `New registered extractors are ${newRegisteredExtractorIds}`,\n        );\n      // Initialize required extractors\n      const initRequiredExtractors = [\n        ...newRegisteredExtractorIds,\n        ...notSyncedExtractorIds,\n      ];\n      if (initRequiredExtractors.length > 0) {\n        this.logger.info(\n          `Initializing ${\n            initRequiredExtractors.length\n          } extractor(s) for [${this.name()}]`,\n          { initRequiredExtractors },\n        );\n        await this.initializeExtractors(initRequiredExtractors, block);\n      }\n      this.extractors.push(...this.newExtractors);\n      this.newExtractors = [];\n    } catch (e) {\n      this.logger.warn(`Initialization for extractors failed with error ${e}`);\n      success = false;\n    } finally {\n      release();\n    }\n    if (!success)\n      throw new Error(\n        `Initialization failed for new extractors ${getIds(this.newExtractors)}`,\n      );\n  };\n}\n"]}
@@ -1,7 +1,7 @@
1
- import { AbstractScanner } from './scanner';
2
- import { Block } from '@rosen-bridge/scanner-interfaces';
3
1
  import { Mutex } from 'await-semaphore';
4
2
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
3
+ import { Block } from '@rosen-bridge/scanner-interfaces';
4
+ import { AbstractScanner } from './scanner';
5
5
  declare abstract class WebSocketScanner<TransactionType> extends AbstractScanner<TransactionType> {
6
6
  protected scannerName: string;
7
7
  protected suffix?: string | undefined;
@@ -1 +1 @@
1
- {"version":3,"file":"webSocketScanner.d.ts","sourceRoot":"","sources":["../../../lib/scanner/abstract/webSocketScanner.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAC5C,OAAO,EAAE,KAAK,EAAE,MAAM,kCAAkC,CAAC;AACzD,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AACxC,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAI/D,uBAAe,gBAAgB,CAC7B,eAAe,CACf,SAAQ,eAAe,CAAC,eAAe,CAAC;IAMtC,SAAS,CAAC,WAAW,EAAE,MAAM;IAG7B,SAAS,CAAC,MAAM,CAAC;IARnB,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC;IAE7B,SAAS,CAAC,KAAK,QAAe;IAE9B,SAAS,aACG,WAAW,EAAE,MAAM,EAC7B,MAAM,CAAC,EAAE,cAAc,EACvB,WAAW,GAAE,MAA8B,EACjC,MAAM,CAAC,oBAAQ;IAK3B,IAAI,eAAmE;IAEvE,QAAQ,CAAC,KAAK,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IACpC,QAAQ,CAAC,IAAI,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAEnC,SAAS,CAAC,kBAAkB,OACtB,MAAM,QAAQ,OAAO,CAAC,OACrB,MAAM,KACV,QAAQ,OAAO,CAAC,CAUjB;IAEF;;;;;OAKG;IACH,SAAS,CAAC,WAAW,UACZ,KAAK,gBACE,MAAM,eAAe,CAAC,mBAkCpC;IAEF;;;OAGG;IACH,SAAS,CAAC,YAAY,UAAiB,KAAK,mBAe1C;CACH;AAED,OAAO,EAAE,gBAAgB,EAAE,CAAC"}
1
+ {"version":3,"file":"webSocketScanner.d.ts","sourceRoot":"","sources":["../../../lib/scanner/abstract/webSocketScanner.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAExC,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EAAE,KAAK,EAAE,MAAM,kCAAkC,CAAC;AAEzD,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAI5C,uBAAe,gBAAgB,CAC7B,eAAe,CACf,SAAQ,eAAe,CAAC,eAAe,CAAC;IAMtC,SAAS,CAAC,WAAW,EAAE,MAAM;IAG7B,SAAS,CAAC,MAAM,CAAC,EAAE,MAAM;IAR3B,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC;IAE7B,SAAS,CAAC,KAAK,QAAe;IAE9B,SAAS,aACG,WAAW,EAAE,MAAM,EAC7B,MAAM,CAAC,EAAE,cAAc,EACvB,WAAW,GAAE,MAA8B,EACjC,MAAM,CAAC,EAAE,MAAM,YAAA;IAK3B,IAAI,eAAmE;IAEvE,QAAQ,CAAC,KAAK,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IACpC,QAAQ,CAAC,IAAI,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAEnC,SAAS,CAAC,kBAAkB,GAC1B,IAAI,MAAM,OAAO,CAAC,OAAO,CAAC,EAC1B,KAAK,MAAM,KACV,OAAO,CAAC,OAAO,CAAC,CAUjB;IAEF;;;;;OAKG;IACH,SAAS,CAAC,WAAW,GACnB,OAAO,KAAK,EACZ,cAAc,KAAK,CAAC,eAAe,CAAC,mBAkCpC;IAEF;;;OAGG;IACH,SAAS,CAAC,YAAY,GAAU,OAAO,KAAK,mBAe1C;CACH;AAED,OAAO,EAAE,gBAAgB,EAAE,CAAC"}
@@ -1,5 +1,5 @@
1
- import { AbstractScanner } from './scanner';
2
1
  import { Mutex } from 'await-semaphore';
2
+ import { AbstractScanner } from './scanner';
3
3
  const DEFAULT_MAX_TRY_BLOCK = 10;
4
4
  class WebSocketScanner extends AbstractScanner {
5
5
  scannerName;
@@ -86,4 +86,4 @@ class WebSocketScanner extends AbstractScanner {
86
86
  };
87
87
  }
88
88
  export { WebSocketScanner };
89
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"webSocketScanner.js","sourceRoot":"","sources":["../../../lib/scanner/abstract/webSocketScanner.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractScanner } from './scanner';\nimport { Block } from '@rosen-bridge/scanner-interfaces';\nimport { Mutex } from 'await-semaphore';\nimport { AbstractLogger } from '@rosen-bridge/abstract-logger';\n\nconst DEFAULT_MAX_TRY_BLOCK = 10;\n\nabstract class WebSocketScanner<\n  TransactionType,\n> extends AbstractScanner<TransactionType> {\n  readonly maxTryBlock: number;\n\n  protected mutex = new Mutex();\n\n  protected constructor(\n    protected scannerName: string,\n    logger?: AbstractLogger,\n    maxTryBlock: number = DEFAULT_MAX_TRY_BLOCK,\n    protected suffix?: string,\n  ) {\n    super(logger);\n    this.maxTryBlock = maxTryBlock;\n  }\n  name = () => this.scannerName + (this.suffix ? `-${this.suffix}` : '');\n\n  abstract start: () => Promise<void>;\n  abstract stop: () => Promise<void>;\n\n  protected tryRunningFunction = async (\n    fn: () => Promise<boolean>,\n    msg: string,\n  ): Promise<boolean> => {\n    for (let tryRound = 1; tryRound <= this.maxTryBlock; tryRound++) {\n      if (await fn()) return true;\n    }\n    this.logger.error(\n      `${msg} can not be proceed in ${this.maxTryBlock} try. scanner restarted automatically`,\n    );\n    await this.stop();\n    await this.start();\n    return false;\n  };\n\n  /**\n   * Handle new block arrived.\n   * save block and its transactions.\n   * @param block\n   * @param transactions\n   */\n  protected stepForward = async (\n    block: Block,\n    transactions: Array<TransactionType>,\n  ) => {\n    const release = await this.mutex.acquire();\n    await this.tryRunningFunction(async () => {\n      try {\n        await this.forkBlock(block.height);\n\n        const lastSavedBlock = await this.action.getLastSavedBlock();\n        if (lastSavedBlock && block.parentHash !== lastSavedBlock.hash) {\n          this.logger.error('It seems saved block is not valid in scanner.');\n          return false;\n        } else {\n          await this.verifyExtractorsInitialization({\n            height: block.height - 1,\n            hash: block.parentHash,\n          });\n          const res = await this.processBlockTransactions(block, transactions);\n          if (res === false) {\n            this.logger.error(\n              `Can not process block at height ${block.height}`,\n            );\n          } else {\n            return true;\n          }\n        }\n      } catch (e) {\n        this.logger.warn(`unknown error occurred ${e}`);\n        if (e instanceof Error && e.stack) {\n          this.logger.warn(e.stack);\n        }\n      }\n      return false;\n    }, `Block at height ${block.height}`);\n    release();\n  };\n\n  /**\n   * Handle forking a block\n   * @param block\n   */\n  protected stepBackward = async (block: Block) => {\n    const release = await this.mutex.acquire();\n    await this.tryRunningFunction(async () => {\n      try {\n        await this.forkBlock(block.height + 1);\n        return true;\n      } catch (e) {\n        this.logger.error(`unknown error occurred ${e}`);\n        if (e instanceof Error && e.stack) {\n          this.logger.warn(e.stack);\n        }\n      }\n      return false;\n    }, `Forking block at height ${block.height}`);\n    release();\n  };\n}\n\nexport { WebSocketScanner };\n"]}
89
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"webSocketScanner.js","sourceRoot":"","sources":["../../../lib/scanner/abstract/webSocketScanner.ts"],"names":[],"mappings":"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","sourcesContent":["import { Mutex } from 'await-semaphore';\n\nimport { AbstractLogger } from '@rosen-bridge/abstract-logger';\nimport { Block } from '@rosen-bridge/scanner-interfaces';\n\nimport { AbstractScanner } from './scanner';\n\nconst DEFAULT_MAX_TRY_BLOCK = 10;\n\nabstract class WebSocketScanner<\n  TransactionType,\n> extends AbstractScanner<TransactionType> {\n  readonly maxTryBlock: number;\n\n  protected mutex = new Mutex();\n\n  protected constructor(\n    protected scannerName: string,\n    logger?: AbstractLogger,\n    maxTryBlock: number = DEFAULT_MAX_TRY_BLOCK,\n    protected suffix?: string,\n  ) {\n    super(logger);\n    this.maxTryBlock = maxTryBlock;\n  }\n  name = () => this.scannerName + (this.suffix ? `-${this.suffix}` : '');\n\n  abstract start: () => Promise<void>;\n  abstract stop: () => Promise<void>;\n\n  protected tryRunningFunction = async (\n    fn: () => Promise<boolean>,\n    msg: string,\n  ): Promise<boolean> => {\n    for (let tryRound = 1; tryRound <= this.maxTryBlock; tryRound++) {\n      if (await fn()) return true;\n    }\n    this.logger.error(\n      `${msg} can not be proceed in ${this.maxTryBlock} try. scanner restarted automatically`,\n    );\n    await this.stop();\n    await this.start();\n    return false;\n  };\n\n  /**\n   * Handle new block arrived.\n   * save block and its transactions.\n   * @param block\n   * @param transactions\n   */\n  protected stepForward = async (\n    block: Block,\n    transactions: Array<TransactionType>,\n  ) => {\n    const release = await this.mutex.acquire();\n    await this.tryRunningFunction(async () => {\n      try {\n        await this.forkBlock(block.height);\n\n        const lastSavedBlock = await this.action.getLastSavedBlock();\n        if (lastSavedBlock && block.parentHash !== lastSavedBlock.hash) {\n          this.logger.error('It seems saved block is not valid in scanner.');\n          return false;\n        } else {\n          await this.verifyExtractorsInitialization({\n            height: block.height - 1,\n            hash: block.parentHash,\n          });\n          const res = await this.processBlockTransactions(block, transactions);\n          if (res === false) {\n            this.logger.error(\n              `Can not process block at height ${block.height}`,\n            );\n          } else {\n            return true;\n          }\n        }\n      } catch (e) {\n        this.logger.warn(`unknown error occurred ${e}`);\n        if (e instanceof Error && e.stack) {\n          this.logger.warn(e.stack);\n        }\n      }\n      return false;\n    }, `Block at height ${block.height}`);\n    release();\n  };\n\n  /**\n   * Handle forking a block\n   * @param block\n   */\n  protected stepBackward = async (block: Block) => {\n    const release = await this.mutex.acquire();\n    await this.tryRunningFunction(async () => {\n      try {\n        await this.forkBlock(block.height + 1);\n        return true;\n      } catch (e) {\n        this.logger.error(`unknown error occurred ${e}`);\n        if (e instanceof Error && e.stack) {\n          this.logger.warn(e.stack);\n        }\n      }\n      return false;\n    }, `Forking block at height ${block.height}`);\n    release();\n  };\n}\n\nexport { WebSocketScanner };\n"]}
@@ -1,7 +1,7 @@
1
- import { BlockEntity } from '../entities/blockEntity';
1
+ import { AbstractLogger } from '@rosen-bridge/abstract-logger';
2
2
  import { DataSource, DeleteResult, Repository } from '@rosen-bridge/extended-typeorm';
3
3
  import { Block } from '@rosen-bridge/scanner-interfaces';
4
- import { AbstractLogger } from '@rosen-bridge/abstract-logger';
4
+ import { BlockEntity } from '../entities/blockEntity';
5
5
  import { ExtractorStatusEntity } from '../entities/extractorStatusEntity';
6
6
  export declare class BlockDbAction {
7
7
  readonly blockRepository: Repository<BlockEntity>;
@@ -1 +1 @@
1
- {"version":3,"file":"action.d.ts","sourceRoot":"","sources":["../../lib/scanner/action.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAuB,MAAM,yBAAyB,CAAC;AAC3E,OAAO,EACL,UAAU,EACV,YAAY,EAEZ,UAAU,EAEX,MAAM,gCAAgC,CAAC;AACxC,OAAO,EAAE,KAAK,EAAE,MAAM,kCAAkC,CAAC;AACzD,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAE1E,qBAAa,aAAa;IACxB,QAAQ,CAAC,eAAe,EAAE,UAAU,CAAC,WAAW,CAAC,CAAC;IAClD,QAAQ,CAAC,yBAAyB,EAAE,UAAU,CAAC,qBAAqB,CAAC,CAAC;IACtE,QAAQ,CAAC,UAAU,EAAE,UAAU,CAAC;IAChC,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC;IAC7B,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC;gBAG9B,UAAU,EAAE,UAAU,EACtB,WAAW,EAAE,MAAM,EACnB,MAAM,CAAC,EAAE,cAAc;IAWzB,QAAQ,CAAC,IAAI,eAA0B;IAEvC;;;OAGG;IACH,iBAAiB,QAAa,QAAQ,WAAW,GAAG,SAAS,CAAC,CAW5D;IAEF;;;;OAIG;IACH,kBAAkB,SACV,MAAM,SACL,MAAM,KACZ,QAAQ,MAAM,WAAW,CAAC,CAAC,CAO5B;IAEF;;;OAGG;IACH,kBAAkB,QAAa,QAAQ,WAAW,GAAG,SAAS,CAAC,CAW7D;IAEF;;;;;OAKG;IACH,gBAAgB,WACN,MAAM,WACN,MAAM,KACb,QAAQ,WAAW,GAAG,SAAS,CAAC,CAWjC;IAEF;;;;OAIG;IACH,gBAAgB,SAAgB,MAAM,WAAU,MAAM,iCAMpD;IAEF;;;;OAIG;IACH,sBAAsB,WAAkB,MAAM,KAAG,QAAQ,YAAY,CAAC,CAMpE;IAEF;;;OAGG;IACH,SAAS,UAAiB,KAAK,KAAG,QAAQ,WAAW,GAAG,OAAO,CAAC,CA0C9D;IAEF;;;OAGG;IACH,iBAAiB,WACP,MAAM,aACH,MAAM,gBACH,MAAM,EAAE,KACrB,QAAQ,OAAO,CAAC,CAqCjB;IAEF;;;OAGG;IACH,iBAAiB,WACP,MAAM,cACF,MAAM,gBACJ,MAAM,EAAE,KACrB,QAAQ,OAAO,CAAC,CAsCjB;IAEF;;;;;OAKG;IACH,6BAA6B,gBACd,MAAM,UACX,MAAM,aACH,MAAM;;;;;+BAgBjB;IAEF;;;;OAIG;IACH,mBAAmB,iBACH,MAAM,EAAE,KACrB,QAAQ,qBAAqB,EAAE,CAAC,CAKjC;CACH"}
1
+ {"version":3,"file":"action.d.ts","sourceRoot":"","sources":["../../lib/scanner/action.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EACL,UAAU,EACV,YAAY,EAEZ,UAAU,EAEX,MAAM,gCAAgC,CAAC;AACxC,OAAO,EAAE,KAAK,EAAE,MAAM,kCAAkC,CAAC;AAEzD,OAAO,EAAE,WAAW,EAAuB,MAAM,yBAAyB,CAAC;AAC3E,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAE1E,qBAAa,aAAa;IACxB,QAAQ,CAAC,eAAe,EAAE,UAAU,CAAC,WAAW,CAAC,CAAC;IAClD,QAAQ,CAAC,yBAAyB,EAAE,UAAU,CAAC,qBAAqB,CAAC,CAAC;IACtE,QAAQ,CAAC,UAAU,EAAE,UAAU,CAAC;IAChC,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC;IAC7B,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC;gBAG9B,UAAU,EAAE,UAAU,EACtB,WAAW,EAAE,MAAM,EACnB,MAAM,CAAC,EAAE,cAAc;IAWzB,QAAQ,CAAC,IAAI,eAA0B;IAEvC;;;OAGG;IACH,iBAAiB,QAAa,OAAO,CAAC,WAAW,GAAG,SAAS,CAAC,CAW5D;IAEF;;;;OAIG;IACH,kBAAkB,GAChB,MAAM,MAAM,EACZ,OAAO,MAAM,KACZ,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAO5B;IAEF;;;OAGG;IACH,kBAAkB,QAAa,OAAO,CAAC,WAAW,GAAG,SAAS,CAAC,CAW7D;IAEF;;;;;OAKG;IACH,gBAAgB,GACd,QAAQ,MAAM,EACd,SAAQ,MAAgB,KACvB,OAAO,CAAC,WAAW,GAAG,SAAS,CAAC,CAWjC;IAEF;;;;OAIG;IACH,gBAAgB,GAAU,MAAM,MAAM,EAAE,SAAQ,MAAgB,iCAM9D;IAEF;;;;OAIG;IACH,sBAAsB,GAAU,QAAQ,MAAM,KAAG,OAAO,CAAC,YAAY,CAAC,CAMpE;IAEF;;;OAGG;IACH,SAAS,GAAU,OAAO,KAAK,KAAG,OAAO,CAAC,WAAW,GAAG,OAAO,CAAC,CA0C9D;IAEF;;;OAGG;IACH,iBAAiB,GACf,QAAQ,MAAM,EACd,WAAW,MAAM,EACjB,cAAc,MAAM,EAAE,KACrB,OAAO,CAAC,OAAO,CAAC,CAqCjB;IAEF;;;OAGG;IACH,iBAAiB,GACf,QAAQ,MAAM,EACd,YAAY,MAAM,EAClB,cAAc,MAAM,EAAE,KACrB,OAAO,CAAC,OAAO,CAAC,CAsCjB;IAEF;;;;;OAKG;IACH,6BAA6B,GAC3B,aAAa,MAAM,EACnB,QAAQ,MAAM,EACd,WAAW,MAAM;;;;;+BAgBjB;IAEF;;;;OAIG;IACH,mBAAmB,GACjB,cAAc,MAAM,EAAE,KACrB,OAAO,CAAC,qBAAqB,EAAE,CAAC,CAKjC;CACH"}
@@ -1,6 +1,6 @@
1
- import { BlockEntity, PROCEED, PROCESSING } from '../entities/blockEntity';
2
- import { MoreThanOrEqual, In, } from '@rosen-bridge/extended-typeorm';
3
1
  import { DummyLogger } from '@rosen-bridge/abstract-logger';
2
+ import { MoreThanOrEqual, In, } from '@rosen-bridge/extended-typeorm';
3
+ import { BlockEntity, PROCEED, PROCESSING } from '../entities/blockEntity';
4
4
  import { ExtractorStatusEntity } from '../entities/extractorStatusEntity';
5
5
  export class BlockDbAction {
6
6
  blockRepository;
@@ -174,7 +174,7 @@ export class BlockDbAction {
174
174
  .update({ extractorId: In(extractorIds), scannerId: this.name() }, { updateHeight: height, updateBlockHash: blockHash });
175
175
  await runner.commitTransaction();
176
176
  }
177
- catch (e) {
177
+ catch {
178
178
  await runner.rollbackTransaction();
179
179
  success = false;
180
180
  }
@@ -248,4 +248,4 @@ export class BlockDbAction {
248
248
  });
249
249
  };
250
250
  }
251
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action.js","sourceRoot":"","sources":["../../lib/scanner/action.ts"],"names":[],"mappings":"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","sourcesContent":["import { BlockEntity, PROCEED, PROCESSING } from '../entities/blockEntity';\nimport {\n  DataSource,\n  DeleteResult,\n  MoreThanOrEqual,\n  Repository,\n  In,\n} from '@rosen-bridge/extended-typeorm';\nimport { Block } from '@rosen-bridge/scanner-interfaces';\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport { ExtractorStatusEntity } from '../entities/extractorStatusEntity';\n\nexport class BlockDbAction {\n  readonly blockRepository: Repository<BlockEntity>;\n  readonly extractorStatusRepository: Repository<ExtractorStatusEntity>;\n  readonly dataSource: DataSource;\n  readonly scannerName: string;\n  readonly logger: AbstractLogger;\n\n  constructor(\n    dataSource: DataSource,\n    scannerName: string,\n    logger?: AbstractLogger,\n  ) {\n    this.blockRepository = dataSource.getRepository(BlockEntity);\n    this.extractorStatusRepository = dataSource.getRepository(\n      ExtractorStatusEntity,\n    );\n    this.dataSource = dataSource;\n    this.scannerName = scannerName;\n    this.logger = logger ? logger : new DummyLogger();\n  }\n\n  readonly name = () => this.scannerName;\n\n  /**\n   * get last saved block\n   * @return Promise<BlockEntity or undefined>\n   */\n  getLastSavedBlock = async (): Promise<BlockEntity | undefined> => {\n    const lastBlock = await this.blockRepository.find({\n      where: { status: PROCEED, scanner: this.name() },\n      order: { height: 'DESC' },\n      take: 1,\n    });\n    if (lastBlock.length !== 0) {\n      return lastBlock[0];\n    } else {\n      return undefined;\n    }\n  };\n\n  /**\n   * get last n stored blocks in database\n   * @param skip\n   * @param count\n   */\n  getLastSavedBlocks = async (\n    skip: number,\n    count: number,\n  ): Promise<Array<BlockEntity>> => {\n    return await this.blockRepository.find({\n      where: { status: PROCEED, scanner: this.name() },\n      order: { height: 'DESC' },\n      skip: skip,\n      take: count,\n    });\n  };\n\n  /**\n   * get first saved block\n   * @return Promise<BlockEntity or undefined>\n   */\n  getFirstSavedBlock = async (): Promise<BlockEntity | undefined> => {\n    const lastBlock = await this.blockRepository.find({\n      where: { status: PROCEED, scanner: this.name() },\n      order: { height: 'ASC' },\n      take: 1,\n    });\n    if (lastBlock.length !== 0) {\n      return lastBlock[0];\n    } else {\n      return undefined;\n    }\n  };\n\n  /**\n   * get block hash and height\n   * @param height\n   * @param status\n   * @return Promise<BlockEntity|undefined>\n   */\n  getBlockAtHeight = async (\n    height: number,\n    status: string = PROCEED,\n  ): Promise<BlockEntity | undefined> => {\n    const block = await this.blockRepository.findOneBy({\n      status: status,\n      height: height,\n      scanner: this.name(),\n    });\n    if (block !== null) {\n      return block;\n    } else {\n      return undefined;\n    }\n  };\n\n  /**\n   * get block with entered blockhash\n   * @param hash\n   * @param status\n   */\n  getBlockWithHash = async (hash: string, status: string = PROCEED) => {\n    return this.blockRepository.findOneBy({\n      hash: hash,\n      status: status,\n      scanner: this.name(),\n    });\n  };\n\n  /**\n   * it deletes every block that more than or equal height\n   * @param height\n   * @return Promise<DeleteResult>\n   */\n  removeBlocksFromHeight = async (height: number): Promise<DeleteResult> => {\n    this.logger.debug(`Removing blocks from height ${height}`);\n    return await this.blockRepository.delete({\n      height: MoreThanOrEqual(height),\n      scanner: this.name(),\n    });\n  };\n\n  /**\n   * store a block into database.\n   * @param block\n   */\n  saveBlock = async (block: Block): Promise<BlockEntity | boolean> => {\n    try {\n      const instance = await this.blockRepository.findOneBy({\n        height: block.height,\n        scanner: this.name(),\n      });\n      const date = new Date(block.timestamp * 1000);\n      const blockInfo = {\n        height: block.height,\n        hash: block.hash,\n        parentHash: block.parentHash,\n        status: PROCESSING,\n        scanner: this.name(),\n        extra: block.extra,\n        timestamp: block.timestamp,\n        year: date.getFullYear(),\n        month: date.getMonth() + 1,\n        day: date.getDate(),\n      };\n      if (!instance) {\n        this.logger.debug(\n          `Inserting block with info: ${JSON.stringify(blockInfo)}`,\n        );\n        await this.blockRepository.insert(blockInfo);\n      } else {\n        this.logger.debug(\n          `Updating block with info: ${JSON.stringify(blockInfo)}`,\n        );\n        await this.blockRepository.update(\n          { height: block.height, scanner: this.name() },\n          blockInfo,\n        );\n      }\n      const res = await this.blockRepository.findOneBy({\n        height: block.height,\n        scanner: this.name(),\n      });\n      return res ? res : false;\n    } catch (exp) {\n      this.logger.error(`An error occurred during save new block: ${exp}`);\n      return false;\n    }\n  };\n\n  /**\n   * Update status of a block to proceed\n   * @param height: height of expected block\n   */\n  updateBlockStatus = async (\n    height: number,\n    blockHash: string,\n    extractorIds: string[],\n  ): Promise<boolean> => {\n    let success = true;\n    this.logger.debug(\n      `Block at height ${height} has been proceed in scanner ${this.name()}, updating status`,\n    );\n    const runner = this.dataSource.createQueryRunner();\n    await runner.connect();\n    await runner.startTransaction();\n    try {\n      await runner.manager.getRepository(BlockEntity).update(\n        {\n          height: height,\n          status: PROCESSING,\n          scanner: this.name(),\n        },\n        {\n          status: PROCEED,\n        },\n      );\n\n      this.logger.debug('Updating extractors status', {\n        extractorIds,\n      });\n      await runner.manager\n        .getRepository(ExtractorStatusEntity)\n        .update(\n          { extractorId: In(extractorIds), scannerId: this.name() },\n          { updateHeight: height, updateBlockHash: blockHash },\n        );\n      await runner.commitTransaction();\n    } catch (e) {\n      await runner.rollbackTransaction();\n      success = false;\n    } finally {\n      await runner.release();\n    }\n    return success;\n  };\n\n  /**\n   * Update status of a block to processing in case of fork\n   * @param height: height of expected block\n   */\n  revertBlockStatus = async (\n    height: number,\n    parentHash: string,\n    extractorIds: string[],\n  ): Promise<boolean> => {\n    let success = true;\n    const runner = this.dataSource.createQueryRunner();\n    await runner.connect();\n    await runner.startTransaction();\n    try {\n      this.logger.debug(`Reverting block status at height ${height}`);\n      await runner.manager.getRepository(BlockEntity).update(\n        {\n          height: height,\n          status: PROCEED,\n          scanner: this.name(),\n        },\n        {\n          status: PROCESSING,\n        },\n      );\n\n      this.logger.debug(\n        `Reverting extractors update height to previous block at height ${\n          height - 1\n        }`,\n      );\n      await runner.manager\n        .getRepository(ExtractorStatusEntity)\n        .update(\n          { extractorId: In(extractorIds), scannerId: this.name() },\n          { updateHeight: height - 1, updateBlockHash: parentHash },\n        );\n      await runner.commitTransaction();\n    } catch (e) {\n      this.logger.warn(`An Error occurred while reverting block status: ${e}`);\n      await runner.rollbackTransaction();\n      success = false;\n    } finally {\n      await runner.release();\n    }\n    return success;\n  };\n\n  /**\n   * Insert a newly initialized extractor or update an existing extractor status\n   * @param extractorId\n   * @param height\n   * @returns\n   */\n  updateOrInsertExtractorStatus = async (\n    extractorId: string,\n    height: number,\n    blockHash: string,\n  ) => {\n    this.logger.debug(\n      'Inserting new extractor status or Updating existing resynced extractor status',\n      {\n        extractorId,\n        height,\n        blockHash,\n      },\n    );\n    return await this.extractorStatusRepository.save({\n      scannerId: this.name(),\n      extractorId,\n      updateHeight: height,\n      updateBlockHash: blockHash,\n    });\n  };\n\n  /**\n   * Return extractors` status specified by id\n   * @param extractorIds\n   * @returns extractors` status\n   */\n  getExtractorsStatus = async (\n    extractorIds: string[],\n  ): Promise<ExtractorStatusEntity[]> => {\n    return await this.extractorStatusRepository.findBy({\n      scannerId: this.name(),\n      extractorId: In(extractorIds),\n    });\n  };\n}\n"]}
251
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action.js","sourceRoot":"","sources":["../../lib/scanner/action.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport {\n  DataSource,\n  DeleteResult,\n  MoreThanOrEqual,\n  Repository,\n  In,\n} from '@rosen-bridge/extended-typeorm';\nimport { Block } from '@rosen-bridge/scanner-interfaces';\n\nimport { BlockEntity, PROCEED, PROCESSING } from '../entities/blockEntity';\nimport { ExtractorStatusEntity } from '../entities/extractorStatusEntity';\n\nexport class BlockDbAction {\n  readonly blockRepository: Repository<BlockEntity>;\n  readonly extractorStatusRepository: Repository<ExtractorStatusEntity>;\n  readonly dataSource: DataSource;\n  readonly scannerName: string;\n  readonly logger: AbstractLogger;\n\n  constructor(\n    dataSource: DataSource,\n    scannerName: string,\n    logger?: AbstractLogger,\n  ) {\n    this.blockRepository = dataSource.getRepository(BlockEntity);\n    this.extractorStatusRepository = dataSource.getRepository(\n      ExtractorStatusEntity,\n    );\n    this.dataSource = dataSource;\n    this.scannerName = scannerName;\n    this.logger = logger ? logger : new DummyLogger();\n  }\n\n  readonly name = () => this.scannerName;\n\n  /**\n   * get last saved block\n   * @return Promise<BlockEntity or undefined>\n   */\n  getLastSavedBlock = async (): Promise<BlockEntity | undefined> => {\n    const lastBlock = await this.blockRepository.find({\n      where: { status: PROCEED, scanner: this.name() },\n      order: { height: 'DESC' },\n      take: 1,\n    });\n    if (lastBlock.length !== 0) {\n      return lastBlock[0];\n    } else {\n      return undefined;\n    }\n  };\n\n  /**\n   * get last n stored blocks in database\n   * @param skip\n   * @param count\n   */\n  getLastSavedBlocks = async (\n    skip: number,\n    count: number,\n  ): Promise<Array<BlockEntity>> => {\n    return await this.blockRepository.find({\n      where: { status: PROCEED, scanner: this.name() },\n      order: { height: 'DESC' },\n      skip: skip,\n      take: count,\n    });\n  };\n\n  /**\n   * get first saved block\n   * @return Promise<BlockEntity or undefined>\n   */\n  getFirstSavedBlock = async (): Promise<BlockEntity | undefined> => {\n    const lastBlock = await this.blockRepository.find({\n      where: { status: PROCEED, scanner: this.name() },\n      order: { height: 'ASC' },\n      take: 1,\n    });\n    if (lastBlock.length !== 0) {\n      return lastBlock[0];\n    } else {\n      return undefined;\n    }\n  };\n\n  /**\n   * get block hash and height\n   * @param height\n   * @param status\n   * @return Promise<BlockEntity|undefined>\n   */\n  getBlockAtHeight = async (\n    height: number,\n    status: string = PROCEED,\n  ): Promise<BlockEntity | undefined> => {\n    const block = await this.blockRepository.findOneBy({\n      status: status,\n      height: height,\n      scanner: this.name(),\n    });\n    if (block !== null) {\n      return block;\n    } else {\n      return undefined;\n    }\n  };\n\n  /**\n   * get block with entered blockhash\n   * @param hash\n   * @param status\n   */\n  getBlockWithHash = async (hash: string, status: string = PROCEED) => {\n    return this.blockRepository.findOneBy({\n      hash: hash,\n      status: status,\n      scanner: this.name(),\n    });\n  };\n\n  /**\n   * it deletes every block that more than or equal height\n   * @param height\n   * @return Promise<DeleteResult>\n   */\n  removeBlocksFromHeight = async (height: number): Promise<DeleteResult> => {\n    this.logger.debug(`Removing blocks from height ${height}`);\n    return await this.blockRepository.delete({\n      height: MoreThanOrEqual(height),\n      scanner: this.name(),\n    });\n  };\n\n  /**\n   * store a block into database.\n   * @param block\n   */\n  saveBlock = async (block: Block): Promise<BlockEntity | boolean> => {\n    try {\n      const instance = await this.blockRepository.findOneBy({\n        height: block.height,\n        scanner: this.name(),\n      });\n      const date = new Date(block.timestamp * 1000);\n      const blockInfo = {\n        height: block.height,\n        hash: block.hash,\n        parentHash: block.parentHash,\n        status: PROCESSING,\n        scanner: this.name(),\n        extra: block.extra,\n        timestamp: block.timestamp,\n        year: date.getFullYear(),\n        month: date.getMonth() + 1,\n        day: date.getDate(),\n      };\n      if (!instance) {\n        this.logger.debug(\n          `Inserting block with info: ${JSON.stringify(blockInfo)}`,\n        );\n        await this.blockRepository.insert(blockInfo);\n      } else {\n        this.logger.debug(\n          `Updating block with info: ${JSON.stringify(blockInfo)}`,\n        );\n        await this.blockRepository.update(\n          { height: block.height, scanner: this.name() },\n          blockInfo,\n        );\n      }\n      const res = await this.blockRepository.findOneBy({\n        height: block.height,\n        scanner: this.name(),\n      });\n      return res ? res : false;\n    } catch (exp) {\n      this.logger.error(`An error occurred during save new block: ${exp}`);\n      return false;\n    }\n  };\n\n  /**\n   * Update status of a block to proceed\n   * @param height: height of expected block\n   */\n  updateBlockStatus = async (\n    height: number,\n    blockHash: string,\n    extractorIds: string[],\n  ): Promise<boolean> => {\n    let success = true;\n    this.logger.debug(\n      `Block at height ${height} has been proceed in scanner ${this.name()}, updating status`,\n    );\n    const runner = this.dataSource.createQueryRunner();\n    await runner.connect();\n    await runner.startTransaction();\n    try {\n      await runner.manager.getRepository(BlockEntity).update(\n        {\n          height: height,\n          status: PROCESSING,\n          scanner: this.name(),\n        },\n        {\n          status: PROCEED,\n        },\n      );\n\n      this.logger.debug('Updating extractors status', {\n        extractorIds,\n      });\n      await runner.manager\n        .getRepository(ExtractorStatusEntity)\n        .update(\n          { extractorId: In(extractorIds), scannerId: this.name() },\n          { updateHeight: height, updateBlockHash: blockHash },\n        );\n      await runner.commitTransaction();\n    } catch {\n      await runner.rollbackTransaction();\n      success = false;\n    } finally {\n      await runner.release();\n    }\n    return success;\n  };\n\n  /**\n   * Update status of a block to processing in case of fork\n   * @param height: height of expected block\n   */\n  revertBlockStatus = async (\n    height: number,\n    parentHash: string,\n    extractorIds: string[],\n  ): Promise<boolean> => {\n    let success = true;\n    const runner = this.dataSource.createQueryRunner();\n    await runner.connect();\n    await runner.startTransaction();\n    try {\n      this.logger.debug(`Reverting block status at height ${height}`);\n      await runner.manager.getRepository(BlockEntity).update(\n        {\n          height: height,\n          status: PROCEED,\n          scanner: this.name(),\n        },\n        {\n          status: PROCESSING,\n        },\n      );\n\n      this.logger.debug(\n        `Reverting extractors update height to previous block at height ${\n          height - 1\n        }`,\n      );\n      await runner.manager\n        .getRepository(ExtractorStatusEntity)\n        .update(\n          { extractorId: In(extractorIds), scannerId: this.name() },\n          { updateHeight: height - 1, updateBlockHash: parentHash },\n        );\n      await runner.commitTransaction();\n    } catch (e) {\n      this.logger.warn(`An Error occurred while reverting block status: ${e}`);\n      await runner.rollbackTransaction();\n      success = false;\n    } finally {\n      await runner.release();\n    }\n    return success;\n  };\n\n  /**\n   * Insert a newly initialized extractor or update an existing extractor status\n   * @param extractorId\n   * @param height\n   * @returns\n   */\n  updateOrInsertExtractorStatus = async (\n    extractorId: string,\n    height: number,\n    blockHash: string,\n  ) => {\n    this.logger.debug(\n      'Inserting new extractor status or Updating existing resynced extractor status',\n      {\n        extractorId,\n        height,\n        blockHash,\n      },\n    );\n    return await this.extractorStatusRepository.save({\n      scannerId: this.name(),\n      extractorId,\n      updateHeight: height,\n      updateBlockHash: blockHash,\n    });\n  };\n\n  /**\n   * Return extractors` status specified by id\n   * @param extractorIds\n   * @returns extractors` status\n   */\n  getExtractorsStatus = async (\n    extractorIds: string[],\n  ): Promise<ExtractorStatusEntity[]> => {\n    return await this.extractorStatusRepository.findBy({\n      scannerId: this.name(),\n      extractorId: In(extractorIds),\n    });\n  };\n}\n"]}
@@ -24,4 +24,4 @@ export declare class FailoverStrategy<TransactionType> implements ConnectorSelec
24
24
  export declare class RoundRobinStrategy<TransactionType> implements ConnectorSelectionStrategy<TransactionType> {
25
25
  selectNextConnector(connectors: Array<AbstractNetworkConnector<TransactionType>>, currentIndex: number): number;
26
26
  }
27
- //# sourceMappingURL=ConnectorSelectionStrategies.d.ts.map
27
+ //# sourceMappingURL=connectorSelectionStrategies.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"ConnectorSelectionStrategies.d.ts","sourceRoot":"","sources":["../../../lib/scanner/network/ConnectorSelectionStrategies.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,wBAAwB,EAAE,MAAM,kCAAkC,CAAC;AAE5E;;GAEG;AACH,MAAM,WAAW,0BAA0B,CAAC,eAAe;IACzD;;;;;;OAMG;IACH,mBAAmB,CACjB,UAAU,EAAE,KAAK,CAAC,wBAAwB,CAAC,eAAe,CAAC,CAAC,EAC5D,YAAY,EAAE,MAAM,EACpB,SAAS,CAAC,EAAE,KAAK,GAChB,MAAM,CAAC;CACX;AAED;;GAEG;AACH,qBAAa,gBAAgB,CAAC,eAAe,CAC3C,YAAW,0BAA0B,CAAC,eAAe,CAAC;IAEtD,mBAAmB,CACjB,UAAU,EAAE,KAAK,CAAC,wBAAwB,CAAC,eAAe,CAAC,CAAC,EAC5D,YAAY,EAAE,MAAM,EACpB,SAAS,CAAC,EAAE,KAAK,GAChB,MAAM;CAQV;AAED;;GAEG;AACH,qBAAa,kBAAkB,CAAC,eAAe,CAC7C,YAAW,0BAA0B,CAAC,eAAe,CAAC;IAEtD,mBAAmB,CACjB,UAAU,EAAE,KAAK,CAAC,wBAAwB,CAAC,eAAe,CAAC,CAAC,EAC5D,YAAY,EAAE,MAAM,GACnB,MAAM;CAGV"}
1
+ {"version":3,"file":"connectorSelectionStrategies.d.ts","sourceRoot":"","sources":["../../../lib/scanner/network/connectorSelectionStrategies.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,wBAAwB,EAAE,MAAM,kCAAkC,CAAC;AAE5E;;GAEG;AACH,MAAM,WAAW,0BAA0B,CAAC,eAAe;IACzD;;;;;;OAMG;IACH,mBAAmB,CACjB,UAAU,EAAE,KAAK,CAAC,wBAAwB,CAAC,eAAe,CAAC,CAAC,EAC5D,YAAY,EAAE,MAAM,EACpB,SAAS,CAAC,EAAE,KAAK,GAChB,MAAM,CAAC;CACX;AAED;;GAEG;AACH,qBAAa,gBAAgB,CAAC,eAAe,CAC3C,YAAW,0BAA0B,CAAC,eAAe,CAAC;IAEtD,mBAAmB,CACjB,UAAU,EAAE,KAAK,CAAC,wBAAwB,CAAC,eAAe,CAAC,CAAC,EAC5D,YAAY,EAAE,MAAM,EACpB,SAAS,CAAC,EAAE,KAAK,GAChB,MAAM;CAQV;AAED;;GAEG;AACH,qBAAa,kBAAkB,CAAC,eAAe,CAC7C,YAAW,0BAA0B,CAAC,eAAe,CAAC;IAEtD,mBAAmB,CACjB,UAAU,EAAE,KAAK,CAAC,wBAAwB,CAAC,eAAe,CAAC,CAAC,EAC5D,YAAY,EAAE,MAAM,GACnB,MAAM;CAGV"}
@@ -19,4 +19,4 @@ export class RoundRobinStrategy {
19
19
  return (currentIndex + 1) % connectors.length;
20
20
  }
21
21
  }
22
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ29ubmVjdG9yU2VsZWN0aW9uU3RyYXRlZ2llcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9zY2FubmVyL25ldHdvcmsvQ29ubmVjdG9yU2VsZWN0aW9uU3RyYXRlZ2llcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvQkE7O0dBRUc7QUFDSCxNQUFNLE9BQU8sZ0JBQWdCO0lBRzNCLG1CQUFtQixDQUNqQixVQUE0RCxFQUM1RCxZQUFvQixFQUNwQixTQUFpQjtRQUVqQixnREFBZ0Q7UUFDaEQsSUFBSSxTQUFTLEVBQUUsQ0FBQztZQUNkLE9BQU8sQ0FBQyxZQUFZLEdBQUcsQ0FBQyxDQUFDLEdBQUcsVUFBVSxDQUFDLE1BQU0sQ0FBQztRQUNoRCxDQUFDO1FBQ0Qsd0NBQXdDO1FBQ3hDLE9BQU8sWUFBWSxDQUFDO0lBQ3RCLENBQUM7Q0FDRjtBQUVEOztHQUVHO0FBQ0gsTUFBTSxPQUFPLGtCQUFrQjtJQUc3QixtQkFBbUIsQ0FDakIsVUFBNEQsRUFDNUQsWUFBb0I7UUFFcEIsT0FBTyxDQUFDLFlBQVksR0FBRyxDQUFDLENBQUMsR0FBRyxVQUFVLENBQUMsTUFBTSxDQUFDO0lBQ2hELENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFic3RyYWN0TmV0d29ya0Nvbm5lY3RvciB9IGZyb20gJ0Byb3Nlbi1icmlkZ2Uvc2Nhbm5lci1pbnRlcmZhY2VzJztcblxuLyoqXG4gKiBJbnRlcmZhY2UgZm9yIGNvbm5lY3RvciBzZWxlY3Rpb24gc3RyYXRlZ2llc1xuICovXG5leHBvcnQgaW50ZXJmYWNlIENvbm5lY3RvclNlbGVjdGlvblN0cmF0ZWd5PFRyYW5zYWN0aW9uVHlwZT4ge1xuICAvKipcbiAgICogU2VsZWN0IHRoZSBuZXh0IGNvbm5lY3RvciB0byB1c2VcbiAgICogQHBhcmFtIGNvbm5lY3RvcnMgQXJyYXkgb2YgYXZhaWxhYmxlIGNvbm5lY3RvcnNcbiAgICogQHBhcmFtIGN1cnJlbnRJbmRleCBDdXJyZW50IGNvbm5lY3RvciBpbmRleFxuICAgKiBAcGFyYW0gbGFzdEVycm9yIEVycm9yIGZyb20gdGhlIGxhc3Qgb3BlcmF0aW9uLCBpZiBhbnlcbiAgICogQHJldHVybnMgVGhlIGluZGV4IG9mIHRoZSBuZXh0IGNvbm5lY3RvciB0byB1c2VcbiAgICovXG4gIHNlbGVjdE5leHRDb25uZWN0b3IoXG4gICAgY29ubmVjdG9yczogQXJyYXk8QWJzdHJhY3ROZXR3b3JrQ29ubmVjdG9yPFRyYW5zYWN0aW9uVHlwZT4+LFxuICAgIGN1cnJlbnRJbmRleDogbnVtYmVyLFxuICAgIGxhc3RFcnJvcj86IEVycm9yLFxuICApOiBudW1iZXI7XG59XG5cbi8qKlxuICogRmFpbG92ZXIgc3RyYXRlZ3kgLSBzd2l0Y2hlcyB0byBuZXh0IGNvbm5lY3RvciBvbmx5IG9uIGZhaWx1cmVcbiAqL1xuZXhwb3J0IGNsYXNzIEZhaWxvdmVyU3RyYXRlZ3k8VHJhbnNhY3Rpb25UeXBlPlxuICBpbXBsZW1lbnRzIENvbm5lY3RvclNlbGVjdGlvblN0cmF0ZWd5PFRyYW5zYWN0aW9uVHlwZT5cbntcbiAgc2VsZWN0TmV4dENvbm5lY3RvcihcbiAgICBjb25uZWN0b3JzOiBBcnJheTxBYnN0cmFjdE5ldHdvcmtDb25uZWN0b3I8VHJhbnNhY3Rpb25UeXBlPj4sXG4gICAgY3VycmVudEluZGV4OiBudW1iZXIsXG4gICAgbGFzdEVycm9yPzogRXJyb3IsXG4gICk6IG51bWJlciB7XG4gICAgLy8gSWYgdGhlcmUgd2FzIGFuIGVycm9yLCB0cnkgdGhlIG5leHQgY29ubmVjdG9yXG4gICAgaWYgKGxhc3RFcnJvcikge1xuICAgICAgcmV0dXJuIChjdXJyZW50SW5kZXggKyAxKSAlIGNvbm5lY3RvcnMubGVuZ3RoO1xuICAgIH1cbiAgICAvLyBPdGhlcndpc2Ugc3RheSB3aXRoIGN1cnJlbnQgY29ubmVjdG9yXG4gICAgcmV0dXJuIGN1cnJlbnRJbmRleDtcbiAgfVxufVxuXG4vKipcbiAqIFJvdW5kLXJvYmluIHN0cmF0ZWd5IC0gc3dpdGNoZXMgdG8gbmV4dCBjb25uZWN0b3IgYWZ0ZXIgZWFjaCBvcGVyYXRpb25cbiAqL1xuZXhwb3J0IGNsYXNzIFJvdW5kUm9iaW5TdHJhdGVneTxUcmFuc2FjdGlvblR5cGU+XG4gIGltcGxlbWVudHMgQ29ubmVjdG9yU2VsZWN0aW9uU3RyYXRlZ3k8VHJhbnNhY3Rpb25UeXBlPlxue1xuICBzZWxlY3ROZXh0Q29ubmVjdG9yKFxuICAgIGNvbm5lY3RvcnM6IEFycmF5PEFic3RyYWN0TmV0d29ya0Nvbm5lY3RvcjxUcmFuc2FjdGlvblR5cGU+PixcbiAgICBjdXJyZW50SW5kZXg6IG51bWJlcixcbiAgKTogbnVtYmVyIHtcbiAgICByZXR1cm4gKGN1cnJlbnRJbmRleCArIDEpICUgY29ubmVjdG9ycy5sZW5ndGg7XG4gIH1cbn1cbiJdfQ==
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29ubmVjdG9yU2VsZWN0aW9uU3RyYXRlZ2llcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9zY2FubmVyL25ldHdvcmsvY29ubmVjdG9yU2VsZWN0aW9uU3RyYXRlZ2llcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvQkE7O0dBRUc7QUFDSCxNQUFNLE9BQU8sZ0JBQWdCO0lBRzNCLG1CQUFtQixDQUNqQixVQUE0RCxFQUM1RCxZQUFvQixFQUNwQixTQUFpQjtRQUVqQixnREFBZ0Q7UUFDaEQsSUFBSSxTQUFTLEVBQUUsQ0FBQztZQUNkLE9BQU8sQ0FBQyxZQUFZLEdBQUcsQ0FBQyxDQUFDLEdBQUcsVUFBVSxDQUFDLE1BQU0sQ0FBQztRQUNoRCxDQUFDO1FBQ0Qsd0NBQXdDO1FBQ3hDLE9BQU8sWUFBWSxDQUFDO0lBQ3RCLENBQUM7Q0FDRjtBQUVEOztHQUVHO0FBQ0gsTUFBTSxPQUFPLGtCQUFrQjtJQUc3QixtQkFBbUIsQ0FDakIsVUFBNEQsRUFDNUQsWUFBb0I7UUFFcEIsT0FBTyxDQUFDLFlBQVksR0FBRyxDQUFDLENBQUMsR0FBRyxVQUFVLENBQUMsTUFBTSxDQUFDO0lBQ2hELENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFic3RyYWN0TmV0d29ya0Nvbm5lY3RvciB9IGZyb20gJ0Byb3Nlbi1icmlkZ2Uvc2Nhbm5lci1pbnRlcmZhY2VzJztcblxuLyoqXG4gKiBJbnRlcmZhY2UgZm9yIGNvbm5lY3RvciBzZWxlY3Rpb24gc3RyYXRlZ2llc1xuICovXG5leHBvcnQgaW50ZXJmYWNlIENvbm5lY3RvclNlbGVjdGlvblN0cmF0ZWd5PFRyYW5zYWN0aW9uVHlwZT4ge1xuICAvKipcbiAgICogU2VsZWN0IHRoZSBuZXh0IGNvbm5lY3RvciB0byB1c2VcbiAgICogQHBhcmFtIGNvbm5lY3RvcnMgQXJyYXkgb2YgYXZhaWxhYmxlIGNvbm5lY3RvcnNcbiAgICogQHBhcmFtIGN1cnJlbnRJbmRleCBDdXJyZW50IGNvbm5lY3RvciBpbmRleFxuICAgKiBAcGFyYW0gbGFzdEVycm9yIEVycm9yIGZyb20gdGhlIGxhc3Qgb3BlcmF0aW9uLCBpZiBhbnlcbiAgICogQHJldHVybnMgVGhlIGluZGV4IG9mIHRoZSBuZXh0IGNvbm5lY3RvciB0byB1c2VcbiAgICovXG4gIHNlbGVjdE5leHRDb25uZWN0b3IoXG4gICAgY29ubmVjdG9yczogQXJyYXk8QWJzdHJhY3ROZXR3b3JrQ29ubmVjdG9yPFRyYW5zYWN0aW9uVHlwZT4+LFxuICAgIGN1cnJlbnRJbmRleDogbnVtYmVyLFxuICAgIGxhc3RFcnJvcj86IEVycm9yLFxuICApOiBudW1iZXI7XG59XG5cbi8qKlxuICogRmFpbG92ZXIgc3RyYXRlZ3kgLSBzd2l0Y2hlcyB0byBuZXh0IGNvbm5lY3RvciBvbmx5IG9uIGZhaWx1cmVcbiAqL1xuZXhwb3J0IGNsYXNzIEZhaWxvdmVyU3RyYXRlZ3k8VHJhbnNhY3Rpb25UeXBlPlxuICBpbXBsZW1lbnRzIENvbm5lY3RvclNlbGVjdGlvblN0cmF0ZWd5PFRyYW5zYWN0aW9uVHlwZT5cbntcbiAgc2VsZWN0TmV4dENvbm5lY3RvcihcbiAgICBjb25uZWN0b3JzOiBBcnJheTxBYnN0cmFjdE5ldHdvcmtDb25uZWN0b3I8VHJhbnNhY3Rpb25UeXBlPj4sXG4gICAgY3VycmVudEluZGV4OiBudW1iZXIsXG4gICAgbGFzdEVycm9yPzogRXJyb3IsXG4gICk6IG51bWJlciB7XG4gICAgLy8gSWYgdGhlcmUgd2FzIGFuIGVycm9yLCB0cnkgdGhlIG5leHQgY29ubmVjdG9yXG4gICAgaWYgKGxhc3RFcnJvcikge1xuICAgICAgcmV0dXJuIChjdXJyZW50SW5kZXggKyAxKSAlIGNvbm5lY3RvcnMubGVuZ3RoO1xuICAgIH1cbiAgICAvLyBPdGhlcndpc2Ugc3RheSB3aXRoIGN1cnJlbnQgY29ubmVjdG9yXG4gICAgcmV0dXJuIGN1cnJlbnRJbmRleDtcbiAgfVxufVxuXG4vKipcbiAqIFJvdW5kLXJvYmluIHN0cmF0ZWd5IC0gc3dpdGNoZXMgdG8gbmV4dCBjb25uZWN0b3IgYWZ0ZXIgZWFjaCBvcGVyYXRpb25cbiAqL1xuZXhwb3J0IGNsYXNzIFJvdW5kUm9iaW5TdHJhdGVneTxUcmFuc2FjdGlvblR5cGU+XG4gIGltcGxlbWVudHMgQ29ubmVjdG9yU2VsZWN0aW9uU3RyYXRlZ3k8VHJhbnNhY3Rpb25UeXBlPlxue1xuICBzZWxlY3ROZXh0Q29ubmVjdG9yKFxuICAgIGNvbm5lY3RvcnM6IEFycmF5PEFic3RyYWN0TmV0d29ya0Nvbm5lY3RvcjxUcmFuc2FjdGlvblR5cGU+PixcbiAgICBjdXJyZW50SW5kZXg6IG51bWJlcixcbiAgKTogbnVtYmVyIHtcbiAgICByZXR1cm4gKGN1cnJlbnRJbmRleCArIDEpICUgY29ubmVjdG9ycy5sZW5ndGg7XG4gIH1cbn1cbiJdfQ==
@@ -1,6 +1,6 @@
1
- import { AbstractNetworkConnector, Block } from '@rosen-bridge/scanner-interfaces';
2
- import { ConnectorSelectionStrategy } from './ConnectorSelectionStrategies';
3
1
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
2
+ import { AbstractNetworkConnector, Block } from '@rosen-bridge/scanner-interfaces';
3
+ import { ConnectorSelectionStrategy } from './connectorSelectionStrategies';
4
4
  /**
5
5
  * Network connector manager that can handle multiple connectors
6
6
  * for a single network with pluggable selection strategy
@@ -61,4 +61,4 @@ export declare class NetworkConnectorManager<TransactionType> implements Abstrac
61
61
  */
62
62
  removeConnector(index: number): void;
63
63
  }
64
- //# sourceMappingURL=NetworkConnectorManager.d.ts.map
64
+ //# sourceMappingURL=networkConnectorManager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"networkConnectorManager.d.ts","sourceRoot":"","sources":["../../../lib/scanner/network/networkConnectorManager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EACL,wBAAwB,EACxB,KAAK,EACN,MAAM,kCAAkC,CAAC;AAE1C,OAAO,EACL,0BAA0B,EAE3B,MAAM,gCAAgC,CAAC;AAExC;;;GAGG;AACH,qBAAa,uBAAuB,CAAC,eAAe,CAClD,YAAW,wBAAwB,CAAC,eAAe,CAAC;IAMlD,OAAO,CAAC,QAAQ;IAChB,OAAO,CAAC,MAAM;IALhB,OAAO,CAAC,UAAU,CAAmD;IACrE,OAAO,CAAC,qBAAqB,CAAS;gBAG5B,QAAQ,GAAE,0BAA0B,CAAC,eAAe,CAA2C,EAC/F,MAAM,GAAE,cAAkC;IAQpD;;;OAGG;IACI,YAAY,CACjB,SAAS,EAAE,wBAAwB,CAAC,eAAe,CAAC,GACnD,IAAI;IAOP;;;;OAIG;IACH,mBAAmB,IAAI,wBAAwB,CAAC,eAAe,CAAC;IAQhE;;;;OAIG;YACW,mBAAmB;IA8CjC;;;OAGG;IACI,WAAW,CAChB,QAAQ,EAAE,0BAA0B,CAAC,eAAe,CAAC,GACpD,IAAI;IAKP;;;;OAIG;IACH,gBAAgB,GAAU,QAAQ,MAAM,KAAG,OAAO,CAAC,KAAK,CAAC,CAIvD;IAEF;;;OAGG;IACH,gBAAgB,QAAa,OAAO,CAAC,MAAM,CAAC,CAI1C;IAEF;;;;OAIG;IACH,WAAW,GAAU,WAAW,MAAM,KAAG,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,CAItE;IAEF;;;OAGG;IACI,iBAAiB,IAAI,MAAM;IAMlC;;;OAGG;IACI,eAAe,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;CAU5C"}
@@ -1,5 +1,5 @@
1
- import { FailoverStrategy, } from './ConnectorSelectionStrategies';
2
1
  import { DummyLogger } from '@rosen-bridge/abstract-logger';
2
+ import { FailoverStrategy, } from './connectorSelectionStrategies';
3
3
  /**
4
4
  * Network connector manager that can handle multiple connectors
5
5
  * for a single network with pluggable selection strategy
@@ -122,4 +122,4 @@ export class NetworkConnectorManager {
122
122
  }
123
123
  }
124
124
  }
125
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"NetworkConnectorManager.js","sourceRoot":"","sources":["../../../lib/scanner/network/NetworkConnectorManager.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AbstractNetworkConnector,\n  Block,\n} from '@rosen-bridge/scanner-interfaces';\nimport {\n  ConnectorSelectionStrategy,\n  FailoverStrategy,\n} from './ConnectorSelectionStrategies';\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\n\n/**\n * Network connector manager that can handle multiple connectors\n * for a single network with pluggable selection strategy\n */\nexport class NetworkConnectorManager<TransactionType>\n  implements AbstractNetworkConnector<TransactionType>\n{\n  private connectors: Array<AbstractNetworkConnector<TransactionType>>;\n  private currentConnectorIndex: number;\n\n  constructor(\n    private strategy: ConnectorSelectionStrategy<TransactionType> = new FailoverStrategy<TransactionType>(),\n    private logger: AbstractLogger = new DummyLogger(),\n  ) {\n    this.connectors = [];\n    this.currentConnectorIndex = 0;\n    this.strategy = strategy;\n    this.logger.debug('NetworkConnectorManager initialized');\n  }\n\n  /**\n   * Add a new connector to the manager\n   * @param connector The network connector instance\n   */\n  public addConnector(\n    connector: AbstractNetworkConnector<TransactionType>,\n  ): void {\n    this.connectors.push(connector);\n    this.logger.info(\n      `Added new connector. Total connectors: ${this.connectors.length}`,\n    );\n  }\n\n  /**\n   * Get the current active connector\n   * @returns The current network connector instance\n   * @throws Error if no connectors are available\n   */\n  getCurrentConnector(): AbstractNetworkConnector<TransactionType> {\n    if (this.connectors.length === 0) {\n      throw new Error('No connectors available');\n    }\n    this.logger.debug(`Using connector at index ${this.currentConnectorIndex}`);\n    return this.connectors[this.currentConnectorIndex];\n  }\n\n  /**\n   * Execute an operation using the configured strategy\n   * @param operation The operation to execute\n   * @returns The result of the operation\n   */\n  private async executeWithStrategy<T>(\n    operation: (\n      connector: AbstractNetworkConnector<TransactionType>,\n    ) => Promise<T>,\n  ): Promise<T> {\n    if (this.connectors.length === 0) {\n      throw new Error('No connectors available for operation');\n    }\n\n    let lastError: Error | undefined;\n    let attempts = 0;\n    const maxAttempts = this.connectors.length;\n\n    while (attempts < maxAttempts) {\n      try {\n        const connector = this.connectors[this.currentConnectorIndex];\n        this.logger.debug(\n          `Attempt ${attempts + 1}/${maxAttempts} with connector at index ${\n            this.currentConnectorIndex\n          }`,\n        );\n        const result = await operation(connector);\n        this.currentConnectorIndex = this.strategy.selectNextConnector(\n          this.connectors,\n          this.currentConnectorIndex,\n        );\n        this.logger.debug(\n          `Operation successful, next connector index: ${this.currentConnectorIndex}`,\n        );\n        return result;\n      } catch (error) {\n        lastError = error as Error;\n        this.logger.warn(\n          `Operation failed with connector at index ${this.currentConnectorIndex}: ${lastError.message}`,\n        );\n        this.currentConnectorIndex = this.strategy.selectNextConnector(\n          this.connectors,\n          this.currentConnectorIndex,\n          lastError,\n        );\n        attempts++;\n      }\n    }\n    throw lastError || new Error('All connectors failed');\n  }\n\n  /**\n   * Set the strategy to use for connector selection\n   * @param strategy The strategy to use\n   */\n  public setStrategy(\n    strategy: ConnectorSelectionStrategy<TransactionType>,\n  ): void {\n    this.logger.info('Setting new connector selection strategy');\n    this.strategy = strategy;\n  }\n\n  /**\n   * Get a block at a specific height\n   * @param height The height of the block to get\n   * @returns The block at the specified height\n   */\n  getBlockAtHeight = async (height: number): Promise<Block> => {\n    return this.executeWithStrategy((connector) =>\n      connector.getBlockAtHeight(height),\n    );\n  };\n\n  /**\n   * Get the current height of the blockchain\n   * @returns The current height\n   */\n  getCurrentHeight = async (): Promise<number> => {\n    return this.executeWithStrategy((connector) =>\n      connector.getCurrentHeight(),\n    );\n  };\n\n  /**\n   * Get all transactions in a block\n   * @param blockHash The hash of the block to get transactions from\n   * @returns Array of transactions in the block\n   */\n  getBlockTxs = async (blockHash: string): Promise<Array<TransactionType>> => {\n    return this.executeWithStrategy((connector) =>\n      connector.getBlockTxs(blockHash),\n    );\n  };\n\n  /**\n   * Get the number of available connectors\n   * @returns The number of connectors\n   */\n  public getConnectorCount(): number {\n    const count = this.connectors.length;\n    this.logger.debug(`Current connector count: ${count}`);\n    return count;\n  }\n\n  /**\n   * Remove a connector at the specified index\n   * @param index The index of the connector to remove\n   */\n  public removeConnector(index: number): void {\n    if (index < 0 || index >= this.connectors.length) {\n      throw new Error('Invalid connector index');\n    }\n    this.logger.info(`Removing connector at index ${index}`);\n    this.connectors.splice(index, 1);\n    if (this.currentConnectorIndex >= this.connectors.length) {\n      this.currentConnectorIndex = 0;\n    }\n  }\n}\n"]}
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"networkConnectorManager.js","sourceRoot":"","sources":["../../../lib/scanner/network/networkConnectorManager.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport {\n  AbstractNetworkConnector,\n  Block,\n} from '@rosen-bridge/scanner-interfaces';\n\nimport {\n  ConnectorSelectionStrategy,\n  FailoverStrategy,\n} from './connectorSelectionStrategies';\n\n/**\n * Network connector manager that can handle multiple connectors\n * for a single network with pluggable selection strategy\n */\nexport class NetworkConnectorManager<TransactionType>\n  implements AbstractNetworkConnector<TransactionType>\n{\n  private connectors: Array<AbstractNetworkConnector<TransactionType>>;\n  private currentConnectorIndex: number;\n\n  constructor(\n    private strategy: ConnectorSelectionStrategy<TransactionType> = new FailoverStrategy<TransactionType>(),\n    private logger: AbstractLogger = new DummyLogger(),\n  ) {\n    this.connectors = [];\n    this.currentConnectorIndex = 0;\n    this.strategy = strategy;\n    this.logger.debug('NetworkConnectorManager initialized');\n  }\n\n  /**\n   * Add a new connector to the manager\n   * @param connector The network connector instance\n   */\n  public addConnector(\n    connector: AbstractNetworkConnector<TransactionType>,\n  ): void {\n    this.connectors.push(connector);\n    this.logger.info(\n      `Added new connector. Total connectors: ${this.connectors.length}`,\n    );\n  }\n\n  /**\n   * Get the current active connector\n   * @returns The current network connector instance\n   * @throws Error if no connectors are available\n   */\n  getCurrentConnector(): AbstractNetworkConnector<TransactionType> {\n    if (this.connectors.length === 0) {\n      throw new Error('No connectors available');\n    }\n    this.logger.debug(`Using connector at index ${this.currentConnectorIndex}`);\n    return this.connectors[this.currentConnectorIndex];\n  }\n\n  /**\n   * Execute an operation using the configured strategy\n   * @param operation The operation to execute\n   * @returns The result of the operation\n   */\n  private async executeWithStrategy<T>(\n    operation: (\n      connector: AbstractNetworkConnector<TransactionType>,\n    ) => Promise<T>,\n  ): Promise<T> {\n    if (this.connectors.length === 0) {\n      throw new Error('No connectors available for operation');\n    }\n\n    let lastError: Error | undefined;\n    let attempts = 0;\n    const maxAttempts = this.connectors.length;\n\n    while (attempts < maxAttempts) {\n      try {\n        const connector = this.connectors[this.currentConnectorIndex];\n        this.logger.debug(\n          `Attempt ${attempts + 1}/${maxAttempts} with connector at index ${\n            this.currentConnectorIndex\n          }`,\n        );\n        const result = await operation(connector);\n        this.currentConnectorIndex = this.strategy.selectNextConnector(\n          this.connectors,\n          this.currentConnectorIndex,\n        );\n        this.logger.debug(\n          `Operation successful, next connector index: ${this.currentConnectorIndex}`,\n        );\n        return result;\n      } catch (error) {\n        lastError = error as Error;\n        this.logger.warn(\n          `Operation failed with connector at index ${this.currentConnectorIndex}: ${lastError.message}`,\n        );\n        this.currentConnectorIndex = this.strategy.selectNextConnector(\n          this.connectors,\n          this.currentConnectorIndex,\n          lastError,\n        );\n        attempts++;\n      }\n    }\n    throw lastError || new Error('All connectors failed');\n  }\n\n  /**\n   * Set the strategy to use for connector selection\n   * @param strategy The strategy to use\n   */\n  public setStrategy(\n    strategy: ConnectorSelectionStrategy<TransactionType>,\n  ): void {\n    this.logger.info('Setting new connector selection strategy');\n    this.strategy = strategy;\n  }\n\n  /**\n   * Get a block at a specific height\n   * @param height The height of the block to get\n   * @returns The block at the specified height\n   */\n  getBlockAtHeight = async (height: number): Promise<Block> => {\n    return this.executeWithStrategy((connector) =>\n      connector.getBlockAtHeight(height),\n    );\n  };\n\n  /**\n   * Get the current height of the blockchain\n   * @returns The current height\n   */\n  getCurrentHeight = async (): Promise<number> => {\n    return this.executeWithStrategy((connector) =>\n      connector.getCurrentHeight(),\n    );\n  };\n\n  /**\n   * Get all transactions in a block\n   * @param blockHash The hash of the block to get transactions from\n   * @returns Array of transactions in the block\n   */\n  getBlockTxs = async (blockHash: string): Promise<Array<TransactionType>> => {\n    return this.executeWithStrategy((connector) =>\n      connector.getBlockTxs(blockHash),\n    );\n  };\n\n  /**\n   * Get the number of available connectors\n   * @returns The number of connectors\n   */\n  public getConnectorCount(): number {\n    const count = this.connectors.length;\n    this.logger.debug(`Current connector count: ${count}`);\n    return count;\n  }\n\n  /**\n   * Remove a connector at the specified index\n   * @param index The index of the connector to remove\n   */\n  public removeConnector(index: number): void {\n    if (index < 0 || index >= this.connectors.length) {\n      throw new Error('Invalid connector index');\n    }\n    this.logger.info(`Removing connector at index ${index}`);\n    this.connectors.splice(index, 1);\n    if (this.currentConnectorIndex >= this.connectors.length) {\n      this.currentConnectorIndex = 0;\n    }\n  }\n}\n"]}
package/package.json CHANGED
@@ -1,44 +1,45 @@
1
1
  {
2
2
  "name": "@rosen-bridge/abstract-scanner",
3
- "version": "0.2.0",
3
+ "version": "0.2.1",
4
4
  "description": "Abstract scanner toolkit for blockchain scanning with logging.",
5
- "author": "Rosen Team",
5
+ "repository": {
6
+ "type": "git",
7
+ "url": "git+https://github.com/rosen-bridge/scanner.git"
8
+ },
6
9
  "license": "MIT",
10
+ "author": "Rosen Team",
11
+ "type": "module",
7
12
  "main": "dist/index.js",
8
13
  "types": "dist/index.d.ts",
14
+ "files": [
15
+ "dist",
16
+ "CHANGELOG.md"
17
+ ],
9
18
  "scripts": {
10
19
  "build": "tsc --build tsconfig.build.json",
20
+ "clean": "rimraf dist && rimraf tsconfig.build.tsbuildinfo",
11
21
  "coverage": "npm run test -- --coverage",
12
22
  "lint": "eslint --fix . && npm run prettify",
23
+ "lint:check": "eslint . && npm run prettify:check",
13
24
  "prettify": "prettier --write . --ignore-path ../../.gitignore",
14
- "release": "npm run test -- --run && npm run build && npm publish --access public",
25
+ "prettify:check": "prettier --check . --ignore-path ../../.gitignore",
26
+ "release": "npm run test -- --run && npm run clean && npm run build && npm publish --access public",
15
27
  "test": "NODE_OPTIONS='--import tsx' vitest",
16
28
  "type-check": "tsc --noEmit"
17
29
  },
18
- "repository": {
19
- "type": "git",
20
- "url": "git+https://github.com/rosen-bridge/scanner.git"
21
- },
22
- "files": [
23
- "dist",
24
- "CHANGELOG.md"
25
- ],
26
30
  "dependencies": {
27
- "@rosen-bridge/abstract-extractor": "^2.1.1",
28
- "@rosen-bridge/abstract-logger": "^3.0.0",
29
- "@rosen-bridge/extended-typeorm": "^1.0.0",
30
- "@rosen-bridge/json-bigint": "^1.0.0",
31
- "@rosen-bridge/scanner-interfaces": "^0.2.0",
31
+ "@rosen-bridge/abstract-extractor": "^2.1.2",
32
+ "@rosen-bridge/abstract-logger": "^3.0.1",
33
+ "@rosen-bridge/extended-typeorm": "^1.0.1",
34
+ "@rosen-bridge/json-bigint": "^1.1.0",
35
+ "@rosen-bridge/scanner-interfaces": "^0.2.1",
32
36
  "await-semaphore": "^0.1.3",
33
37
  "lodash-es": "^4.17.21"
34
38
  },
35
- "type": "module",
36
39
  "devDependencies": {
37
40
  "@types/lodash-es": "^4.17.12",
38
- "@types/node": "^22.18.0",
39
41
  "@vitest/coverage-istanbul": "^3.1.4",
40
42
  "tsx": "^4.19.4",
41
- "typescript": "^5.3.3",
42
43
  "vitest": "^3.1.4"
43
44
  },
44
45
  "engines": {
@@ -1 +0,0 @@
1
- {"version":3,"file":"NetworkConnectorManager.d.ts","sourceRoot":"","sources":["../../../lib/scanner/network/NetworkConnectorManager.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,wBAAwB,EACxB,KAAK,EACN,MAAM,kCAAkC,CAAC;AAC1C,OAAO,EACL,0BAA0B,EAE3B,MAAM,gCAAgC,CAAC;AACxC,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAE5E;;;GAGG;AACH,qBAAa,uBAAuB,CAAC,eAAe,CAClD,YAAW,wBAAwB,CAAC,eAAe,CAAC;IAMlD,OAAO,CAAC,QAAQ;IAChB,OAAO,CAAC,MAAM;IALhB,OAAO,CAAC,UAAU,CAAmD;IACrE,OAAO,CAAC,qBAAqB,CAAS;gBAG5B,QAAQ,GAAE,0BAA0B,CAAC,eAAe,CAA2C,EAC/F,MAAM,GAAE,cAAkC;IAQpD;;;OAGG;IACI,YAAY,CACjB,SAAS,EAAE,wBAAwB,CAAC,eAAe,CAAC,GACnD,IAAI;IAOP;;;;OAIG;IACH,mBAAmB,IAAI,wBAAwB,CAAC,eAAe,CAAC;IAQhE;;;;OAIG;YACW,mBAAmB;IA8CjC;;;OAGG;IACI,WAAW,CAChB,QAAQ,EAAE,0BAA0B,CAAC,eAAe,CAAC,GACpD,IAAI;IAKP;;;;OAIG;IACH,gBAAgB,WAAkB,MAAM,KAAG,QAAQ,KAAK,CAAC,CAIvD;IAEF;;;OAGG;IACH,gBAAgB,QAAa,QAAQ,MAAM,CAAC,CAI1C;IAEF;;;;OAIG;IACH,WAAW,cAAqB,MAAM,KAAG,QAAQ,MAAM,eAAe,CAAC,CAAC,CAItE;IAEF;;;OAGG;IACI,iBAAiB,IAAI,MAAM;IAMlC;;;OAGG;IACI,eAAe,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;CAU5C"}