@rosen-bridge/abstract-scanner 1.0.3 → 1.1.0-db631ff1
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 +14 -0
- package/dist/constants.d.ts +3 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/constants.js +3 -0
- package/dist/scanner/abstract/generalScanner.d.ts +2 -1
- package/dist/scanner/abstract/generalScanner.d.ts.map +1 -1
- package/dist/scanner/abstract/generalScanner.js +5 -4
- package/dist/scanner/abstract/scanner.d.ts +10 -2
- package/dist/scanner/abstract/scanner.d.ts.map +1 -1
- package/dist/scanner/abstract/scanner.js +34 -2
- package/dist/scanner/abstract/webSocketScanner.d.ts +2 -1
- package/dist/scanner/abstract/webSocketScanner.d.ts.map +1 -1
- package/dist/scanner/abstract/webSocketScanner.js +5 -4
- package/dist/scanner/action.d.ts +22 -1
- package/dist/scanner/action.d.ts.map +1 -1
- package/dist/scanner/action.js +60 -1
- package/dist/scanner/interfaces.d.ts +6 -0
- package/dist/scanner/interfaces.d.ts.map +1 -1
- package/dist/scanner/interfaces.js +1 -1
- package/package.json +3 -3
- package/dist/tsconfig.tsbuildinfo +0 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,19 @@
|
|
|
1
1
|
# @rosen-bridge/abstract-scanner
|
|
2
2
|
|
|
3
|
+
## 1.1.0-db631ff1
|
|
4
|
+
|
|
5
|
+
### Minor Changes
|
|
6
|
+
|
|
7
|
+
- Add removeOldUnusedBlocks method to AbstractScanner for cleaning up old unused blocks
|
|
8
|
+
|
|
9
|
+
## 1.0.4
|
|
10
|
+
|
|
11
|
+
### Patch Changes
|
|
12
|
+
|
|
13
|
+
- Update dependencies
|
|
14
|
+
- @rosen-bridge/abstract-extractor@3.1.2
|
|
15
|
+
- @rosen-bridge/extended-typeorm@1.1.0
|
|
16
|
+
|
|
3
17
|
## 1.0.3
|
|
4
18
|
|
|
5
19
|
### Patch Changes
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../lib/constants.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,oBAAoB,QAAmB,CAAC;AACrD,eAAO,MAAM,kBAAkB,QAAU,CAAC"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export const Seven_Days_InSeconds = 7 * 24 * 60 * 60;
|
|
2
|
+
export const One_Hour_InSeconds = 60 * 60;
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vbGliL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxDQUFDLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLENBQUM7QUFDckQsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQUcsRUFBRSxHQUFHLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBTZXZlbl9EYXlzX0luU2Vjb25kcyA9IDcgKiAyNCAqIDYwICogNjA7XG5leHBvcnQgY29uc3QgT25lX0hvdXJfSW5TZWNvbmRzID0gNjAgKiA2MDtcbiJdfQ==
|
|
@@ -2,6 +2,7 @@ import { AbstractLogger } from '@rosen-bridge/abstract-logger';
|
|
|
2
2
|
import { DataSource } from '@rosen-bridge/extended-typeorm';
|
|
3
3
|
import { AbstractNetworkConnector, Block } from '@rosen-bridge/scanner-interfaces';
|
|
4
4
|
import { BlockEntity } from '../../entities/blockEntity';
|
|
5
|
+
import { BlockTimeConfig } from '../interfaces';
|
|
5
6
|
import { AbstractScanner } from './scanner';
|
|
6
7
|
declare abstract class GeneralScanner<TransactionType> extends AbstractScanner<TransactionType> {
|
|
7
8
|
private scannerName;
|
|
@@ -12,7 +13,7 @@ declare abstract class GeneralScanner<TransactionType> extends AbstractScanner<T
|
|
|
12
13
|
private readonly initialHeight;
|
|
13
14
|
protected blockChainLastHeight: number | undefined;
|
|
14
15
|
name: () => string;
|
|
15
|
-
constructor(scannerName: string, dataSource: DataSource, initialHeight: number, network: AbstractNetworkConnector<TransactionType>, blockRetrieveGap
|
|
16
|
+
constructor(scannerName: string, dataSource: DataSource, initialHeight: number, network: AbstractNetworkConnector<TransactionType>, blockRetrieveGap: number | undefined, blockTimeConfig: BlockTimeConfig, logger?: AbstractLogger, suffix?: string | undefined);
|
|
16
17
|
/**
|
|
17
18
|
* Get the first block to process
|
|
18
19
|
* @returns The first block at the configured initial height
|
|
@@ -1 +1 @@
|
|
|
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;
|
|
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,eAAe,CAAC;AAChD,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;IAGxB,OAAO,CAAC,MAAM,CAAC;IAbjB,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,oBAAI,EAC5B,eAAe,EAAE,eAAe,EAChC,MAAM,CAAC,EAAE,cAAc,EACf,MAAM,CAAC,EAAE,MAAM,YAAA;IAgBzB;;;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,sBAyBJ;CACH;AAED,OAAO,EAAE,cAAc,EAAE,CAAC"}
|
|
@@ -10,8 +10,8 @@ class GeneralScanner extends AbstractScanner {
|
|
|
10
10
|
initialHeight;
|
|
11
11
|
blockChainLastHeight = undefined;
|
|
12
12
|
name = () => this.scannerName + (this.suffix ? `-${this.suffix}` : '');
|
|
13
|
-
constructor(scannerName, dataSource, initialHeight, network, blockRetrieveGap = 0, logger, suffix) {
|
|
14
|
-
super(logger);
|
|
13
|
+
constructor(scannerName, dataSource, initialHeight, network, blockRetrieveGap = 0, blockTimeConfig, logger, suffix) {
|
|
14
|
+
super(blockTimeConfig, logger);
|
|
15
15
|
this.scannerName = scannerName;
|
|
16
16
|
this.dataSource = dataSource;
|
|
17
17
|
this.network = network;
|
|
@@ -148,16 +148,17 @@ class GeneralScanner extends AbstractScanner {
|
|
|
148
148
|
*/
|
|
149
149
|
update = async () => {
|
|
150
150
|
try {
|
|
151
|
+
let lastSavedBlock = await this.action.getLastSavedBlock();
|
|
151
152
|
const latestHeight = await this.network.getCurrentHeight();
|
|
152
153
|
if (!this.blockChainLastHeight ||
|
|
153
154
|
this.blockChainLastHeight < latestHeight)
|
|
154
155
|
this.blockChainLastHeight = latestHeight;
|
|
155
|
-
let lastSavedBlock = await this.action.getLastSavedBlock();
|
|
156
156
|
if (!lastSavedBlock) {
|
|
157
157
|
lastSavedBlock = await this.initialize();
|
|
158
158
|
}
|
|
159
159
|
else
|
|
160
160
|
await this.verifyExtractorsInitialization(lastSavedBlock);
|
|
161
|
+
await this.removeOldUnusedBlocks(lastSavedBlock);
|
|
161
162
|
if (!(await this.isForkHappen())) {
|
|
162
163
|
await this.stepForward(lastSavedBlock);
|
|
163
164
|
}
|
|
@@ -174,4 +175,4 @@ class GeneralScanner extends AbstractScanner {
|
|
|
174
175
|
};
|
|
175
176
|
}
|
|
176
177
|
export { GeneralScanner };
|
|
177
|
-
//# 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(\n      this.dataSource,\n      this.name(),\n      this.logger.child('BlockDbAction'),\n    );\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      if (e instanceof Error && e.stack) {\n        this.logger.error(`error stack: ${e.stack}`);\n      }\n    }\n  };\n}\n\nexport { GeneralScanner };\n"]}
|
|
178
|
+
//# 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 { BlockTimeConfig } from '../interfaces';\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    blockTimeConfig: BlockTimeConfig,\n    logger?: AbstractLogger,\n    private suffix?: string,\n  ) {\n    super(blockTimeConfig, 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(\n      this.dataSource,\n      this.name(),\n      this.logger.child('BlockDbAction'),\n    );\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      let lastSavedBlock = await this.action.getLastSavedBlock();\n      const latestHeight = await this.network.getCurrentHeight();\n      if (\n        !this.blockChainLastHeight ||\n        this.blockChainLastHeight < latestHeight\n      )\n        this.blockChainLastHeight = latestHeight;\n\n      if (!lastSavedBlock) {\n        lastSavedBlock = await this.initialize();\n      } else await this.verifyExtractorsInitialization(lastSavedBlock);\n      await this.removeOldUnusedBlocks(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      if (e instanceof Error && e.stack) {\n        this.logger.error(`error stack: ${e.stack}`);\n      }\n    }\n  };\n}\n\nexport { GeneralScanner };\n"]}
|
|
@@ -3,14 +3,17 @@ import { AbstractExtractor } from '@rosen-bridge/abstract-extractor';
|
|
|
3
3
|
import { AbstractLogger } from '@rosen-bridge/abstract-logger';
|
|
4
4
|
import { ObjectLiteral } from '@rosen-bridge/extended-typeorm';
|
|
5
5
|
import { Block, BlockInfo } from '@rosen-bridge/scanner-interfaces';
|
|
6
|
+
import { BlockEntity } from '../../entities/blockEntity';
|
|
6
7
|
import { BlockDbAction } from '../action';
|
|
8
|
+
import { BlockTimeConfig } from '../interfaces';
|
|
7
9
|
export declare abstract class AbstractScanner<TransactionType> {
|
|
8
10
|
action: BlockDbAction;
|
|
9
11
|
extractors: Array<AbstractExtractor<TransactionType, ObjectLiteral>>;
|
|
10
12
|
newExtractors: Array<AbstractExtractor<TransactionType, ObjectLiteral>>;
|
|
11
13
|
logger: AbstractLogger;
|
|
12
14
|
initializeMutex: Mutex;
|
|
13
|
-
|
|
15
|
+
blockTimeConfig: BlockTimeConfig;
|
|
16
|
+
constructor(blockTimeConfig: BlockTimeConfig, logger?: AbstractLogger);
|
|
14
17
|
abstract name: () => string;
|
|
15
18
|
/**
|
|
16
19
|
* fork blocks from specific height from scanner.
|
|
@@ -22,7 +25,7 @@ export declare abstract class AbstractScanner<TransactionType> {
|
|
|
22
25
|
* @param block: selected block
|
|
23
26
|
* @param transactions: list of transaction for selected block
|
|
24
27
|
*/
|
|
25
|
-
protected processBlockTransactions: (block: Block, transactions: Array<TransactionType>) => Promise<false |
|
|
28
|
+
protected processBlockTransactions: (block: Block, transactions: Array<TransactionType>) => Promise<false | BlockEntity>;
|
|
26
29
|
/**
|
|
27
30
|
* register a nre extractor to scanner.
|
|
28
31
|
* @param extractor
|
|
@@ -45,5 +48,10 @@ export declare abstract class AbstractScanner<TransactionType> {
|
|
|
45
48
|
* @param block
|
|
46
49
|
*/
|
|
47
50
|
protected verifyExtractorsInitialization: (block: BlockInfo) => Promise<void>;
|
|
51
|
+
/**
|
|
52
|
+
* Removes unused blocks from the database
|
|
53
|
+
* @param lastSavedBlock
|
|
54
|
+
*/
|
|
55
|
+
removeOldUnusedBlocks: (lastSavedBlock: BlockEntity | undefined) => Promise<void>;
|
|
48
56
|
}
|
|
49
57
|
//# sourceMappingURL=scanner.d.ts.map
|
|
@@ -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;AAGxC,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,kCAAkC,CAAC;
|
|
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,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,kCAAkC,CAAC;AAGpE,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AACzD,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAC1C,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAEhD,8BAAsB,eAAe,CAAC,eAAe;IACnD,MAAM,EAAE,aAAa,CAAC;IACtB,UAAU,EAAE,KAAK,CAAC,iBAAiB,CAAC,eAAe,EAAE,aAAa,CAAC,CAAC,CAAC;IACrE,aAAa,EAAE,KAAK,CAAC,iBAAiB,CAAC,eAAe,EAAE,aAAa,CAAC,CAAC,CAAC;IACxE,MAAM,EAAE,cAAc,CAAC;IACvB,eAAe,EAAE,KAAK,CAAC;IACvB,eAAe,EAAE,eAAe,CAAC;gBAErB,eAAe,EAAE,eAAe,EAAE,MAAM,CAAC,EAAE,cAAc;IAerE,QAAQ,CAAC,IAAI,EAAE,MAAM,MAAM,CAAC;IAE5B;;;OAGG;IACH,SAAS,CAAC,SAAS,GAAU,QAAQ,MAAM,mBAiBzC;IAEF;;;;OAIG;IACH,SAAS,CAAC,wBAAwB,GAChC,OAAO,KAAK,EACZ,cAAc,KAAK,CAAC,eAAe,CAAC,kCAyBpC;IAEF;;;OAGG;IACH,iBAAiB,GACf,WAAW,iBAAiB,CAAC,eAAe,EAAE,aAAa,CAAC,KAC3D,OAAO,CAAC,IAAI,CAAC,CAmBd;IAEF;;;OAGG;IACH,eAAe,GACb,WAAW,iBAAiB,CAAC,eAAe,EAAE,aAAa,CAAC,KAC3D,OAAO,CAAC,IAAI,CAAC,CAQd;IAEF;;;;OAIG;IACH,OAAO,CAAC,oBAAoB,CAkB1B;IAEF;;;;OAIG;IACH,SAAS,CAAC,8BAA8B,GAAU,OAAO,SAAS,mBAqDhE;IAEF;;;OAGG;IACH,qBAAqB,GACnB,gBAAgB,WAAW,GAAG,SAAS,KACtC,OAAO,CAAC,IAAI,CAAC,CAiCd;CACH"}
|
|
@@ -1,17 +1,24 @@
|
|
|
1
1
|
import { Mutex } from 'await-semaphore';
|
|
2
2
|
import { difference, remove } from 'lodash-es';
|
|
3
3
|
import { DummyLogger } from '@rosen-bridge/abstract-logger';
|
|
4
|
+
import { One_Hour_InSeconds, Seven_Days_InSeconds } from '../../constants';
|
|
4
5
|
export class AbstractScanner {
|
|
5
6
|
action;
|
|
6
7
|
extractors;
|
|
7
8
|
newExtractors;
|
|
8
9
|
logger;
|
|
9
10
|
initializeMutex;
|
|
10
|
-
|
|
11
|
+
blockTimeConfig;
|
|
12
|
+
constructor(blockTimeConfig, logger) {
|
|
11
13
|
this.extractors = [];
|
|
12
14
|
this.newExtractors = [];
|
|
13
15
|
this.logger = logger ? logger : new DummyLogger();
|
|
14
16
|
this.initializeMutex = new Mutex();
|
|
17
|
+
this.blockTimeConfig = {
|
|
18
|
+
blockTime: blockTimeConfig?.blockTime,
|
|
19
|
+
blockAgeThreshold: blockTimeConfig?.blockAgeThreshold ?? Seven_Days_InSeconds,
|
|
20
|
+
blockTrimCountInRound: blockTimeConfig?.blockTrimCountInRound ?? One_Hour_InSeconds,
|
|
21
|
+
};
|
|
15
22
|
}
|
|
16
23
|
/**
|
|
17
24
|
* fork blocks from specific height from scanner.
|
|
@@ -138,5 +145,30 @@ export class AbstractScanner {
|
|
|
138
145
|
release();
|
|
139
146
|
}
|
|
140
147
|
};
|
|
148
|
+
/**
|
|
149
|
+
* Removes unused blocks from the database
|
|
150
|
+
* @param lastSavedBlock
|
|
151
|
+
*/
|
|
152
|
+
removeOldUnusedBlocks = async (lastSavedBlock) => {
|
|
153
|
+
try {
|
|
154
|
+
this.logger.debug('Starting the process to remove old unused blocks');
|
|
155
|
+
const extractorUsedBlocksQueries = this.extractors
|
|
156
|
+
.map((extracor) => extracor.createUsedBlocksQuery())
|
|
157
|
+
.filter((value) => value != undefined);
|
|
158
|
+
const deletedBlockCount = Math.floor(this.blockTimeConfig.blockTrimCountInRound /
|
|
159
|
+
this.blockTimeConfig.blockTime);
|
|
160
|
+
const unusedBlockHashes = await this.action.removeUnusedBlocksInBatches(extractorUsedBlocksQueries, deletedBlockCount, this.name(), this.blockTimeConfig.blockAgeThreshold, lastSavedBlock);
|
|
161
|
+
if (unusedBlockHashes.length)
|
|
162
|
+
this.logger.debug(`Successfully removed old unused block hashes: ${unusedBlockHashes.join(', ')}`);
|
|
163
|
+
else
|
|
164
|
+
this.logger.debug('No unused block hashes found to remove.');
|
|
165
|
+
}
|
|
166
|
+
catch (error) {
|
|
167
|
+
this.logger.error(`An error occurred while removing old unused blocks: ${error}`);
|
|
168
|
+
if (error instanceof Error && error.stack) {
|
|
169
|
+
this.logger.error(`error stack: ${error.stack}`);
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
};
|
|
141
173
|
}
|
|
142
|
-
//# 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 { ObjectLiteral } from '@rosen-bridge/extended-typeorm';\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, ObjectLiteral>>;\n  newExtractors: Array<AbstractExtractor<TransactionType, ObjectLiteral>>;\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        await extractor.forkBlock(lastBlock.hash);\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, ObjectLiteral>,\n  ): Promise<void> => {\n    const notRegisteredIn = (\n      extractors: Array<AbstractExtractor<TransactionType, ObjectLiteral>>,\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, ObjectLiteral>,\n  ): Promise<void> => {\n    const removeFn = (ex: AbstractExtractor<TransactionType, ObjectLiteral>) =>\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.initializeData(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 = (\n      extractors: Array<AbstractExtractor<TransactionType, ObjectLiteral>>,\n    ) => {\n      return extractors.map((extractor) => extractor.getId());\n    };\n    this.logger.debug(`Initializing extractors for block [${block.height}]`);\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    } finally {\n      release();\n    }\n  };\n}\n"]}
|
|
174
|
+
//# 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 { ObjectLiteral } from '@rosen-bridge/extended-typeorm';\nimport { Block, BlockInfo } from '@rosen-bridge/scanner-interfaces';\n\nimport { One_Hour_InSeconds, Seven_Days_InSeconds } from '../../constants';\nimport { BlockEntity } from '../../entities/blockEntity';\nimport { BlockDbAction } from '../action';\nimport { BlockTimeConfig } from '../interfaces';\n\nexport abstract class AbstractScanner<TransactionType> {\n  action: BlockDbAction;\n  extractors: Array<AbstractExtractor<TransactionType, ObjectLiteral>>;\n  newExtractors: Array<AbstractExtractor<TransactionType, ObjectLiteral>>;\n  logger: AbstractLogger;\n  initializeMutex: Mutex;\n  blockTimeConfig: BlockTimeConfig;\n\n  constructor(blockTimeConfig: BlockTimeConfig, logger?: AbstractLogger) {\n    this.extractors = [];\n    this.newExtractors = [];\n    this.logger = logger ? logger : new DummyLogger();\n    this.initializeMutex = new Mutex();\n\n    this.blockTimeConfig = {\n      blockTime: blockTimeConfig?.blockTime,\n      blockAgeThreshold:\n        blockTimeConfig?.blockAgeThreshold ?? Seven_Days_InSeconds,\n      blockTrimCountInRound:\n        blockTimeConfig?.blockTrimCountInRound ?? One_Hour_InSeconds,\n    };\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        await extractor.forkBlock(lastBlock.hash);\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, ObjectLiteral>,\n  ): Promise<void> => {\n    const notRegisteredIn = (\n      extractors: Array<AbstractExtractor<TransactionType, ObjectLiteral>>,\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, ObjectLiteral>,\n  ): Promise<void> => {\n    const removeFn = (ex: AbstractExtractor<TransactionType, ObjectLiteral>) =>\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.initializeData(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 = (\n      extractors: Array<AbstractExtractor<TransactionType, ObjectLiteral>>,\n    ) => {\n      return extractors.map((extractor) => extractor.getId());\n    };\n    this.logger.debug(`Initializing extractors for block [${block.height}]`);\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    } finally {\n      release();\n    }\n  };\n\n  /**\n   * Removes unused blocks from the database\n   * @param lastSavedBlock\n   */\n  removeOldUnusedBlocks = async (\n    lastSavedBlock: BlockEntity | undefined,\n  ): Promise<void> => {\n    try {\n      this.logger.debug('Starting the process to remove old unused blocks');\n\n      const extractorUsedBlocksQueries = this.extractors\n        .map((extracor) => extracor.createUsedBlocksQuery())\n        .filter((value) => value != undefined);\n\n      const deletedBlockCount = Math.floor(\n        this.blockTimeConfig.blockTrimCountInRound! /\n          this.blockTimeConfig.blockTime,\n      );\n\n      const unusedBlockHashes = await this.action.removeUnusedBlocksInBatches(\n        extractorUsedBlocksQueries,\n        deletedBlockCount,\n        this.name(),\n        this.blockTimeConfig.blockAgeThreshold!,\n        lastSavedBlock,\n      );\n      if (unusedBlockHashes.length)\n        this.logger.debug(\n          `Successfully removed old unused block hashes: ${unusedBlockHashes.join(', ')}`,\n        );\n      else this.logger.debug('No unused block hashes found to remove.');\n    } catch (error) {\n      this.logger.error(\n        `An error occurred while removing old unused blocks: ${error}`,\n      );\n      if (error instanceof Error && error.stack) {\n        this.logger.error(`error stack: ${error.stack}`);\n      }\n    }\n  };\n}\n"]}
|
|
@@ -1,13 +1,14 @@
|
|
|
1
1
|
import { Mutex } from 'await-semaphore';
|
|
2
2
|
import { AbstractLogger } from '@rosen-bridge/abstract-logger';
|
|
3
3
|
import { Block } from '@rosen-bridge/scanner-interfaces';
|
|
4
|
+
import { BlockTimeConfig } from '../interfaces';
|
|
4
5
|
import { AbstractScanner } from './scanner';
|
|
5
6
|
declare abstract class WebSocketScanner<TransactionType> extends AbstractScanner<TransactionType> {
|
|
6
7
|
protected scannerName: string;
|
|
7
8
|
protected suffix?: string | undefined;
|
|
8
9
|
readonly maxTryBlock: number;
|
|
9
10
|
protected mutex: Mutex;
|
|
10
|
-
protected constructor(scannerName: string, logger?: AbstractLogger, maxTryBlock?: number, suffix?: string | undefined);
|
|
11
|
+
protected constructor(scannerName: string, blockTimeConfig: BlockTimeConfig, logger?: AbstractLogger, maxTryBlock?: number, suffix?: string | undefined);
|
|
11
12
|
name: () => string;
|
|
12
13
|
abstract start: () => Promise<void>;
|
|
13
14
|
abstract stop: () => Promise<void>;
|
|
@@ -1 +1 @@
|
|
|
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;
|
|
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,eAAe,CAAC;AAChD,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAI5C,uBAAe,gBAAgB,CAC7B,eAAe,CACf,SAAQ,eAAe,CAAC,eAAe,CAAC;IAMtC,SAAS,CAAC,WAAW,EAAE,MAAM;IAI7B,SAAS,CAAC,MAAM,CAAC,EAAE,MAAM;IAT3B,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC;IAE7B,SAAS,CAAC,KAAK,QAAe;IAE9B,SAAS,aACG,WAAW,EAAE,MAAM,EAC7B,eAAe,EAAE,eAAe,EAChC,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,EACX,cAAc,MAAM,IAAI,KACvB,OAAO,CAAC,OAAO,CAAC,CAWjB;IAEF;;;;;OAKG;IACH,SAAS,CAAC,WAAW,GACnB,OAAO,KAAK,EACZ,cAAc,KAAK,CAAC,eAAe,CAAC,mBA0CpC;IAEF;;;OAGG;IACH,SAAS,CAAC,YAAY,GAAU,OAAO,KAAK,mBAmB1C;CACH;AAED,OAAO,EAAE,gBAAgB,EAAE,CAAC"}
|
|
@@ -6,8 +6,8 @@ class WebSocketScanner extends AbstractScanner {
|
|
|
6
6
|
suffix;
|
|
7
7
|
maxTryBlock;
|
|
8
8
|
mutex = new Mutex();
|
|
9
|
-
constructor(scannerName, logger, maxTryBlock = DEFAULT_MAX_TRY_BLOCK, suffix) {
|
|
10
|
-
super(logger);
|
|
9
|
+
constructor(scannerName, blockTimeConfig, logger, maxTryBlock = DEFAULT_MAX_TRY_BLOCK, suffix) {
|
|
10
|
+
super(blockTimeConfig, logger);
|
|
11
11
|
this.scannerName = scannerName;
|
|
12
12
|
this.suffix = suffix;
|
|
13
13
|
this.maxTryBlock = maxTryBlock;
|
|
@@ -32,10 +32,11 @@ class WebSocketScanner extends AbstractScanner {
|
|
|
32
32
|
*/
|
|
33
33
|
stepForward = async (block, transactions) => {
|
|
34
34
|
const release = await this.mutex.acquire();
|
|
35
|
+
const lastSavedBlock = await this.action.getLastSavedBlock();
|
|
36
|
+
await this.removeOldUnusedBlocks(lastSavedBlock);
|
|
35
37
|
await this.tryRunningFunction(async () => {
|
|
36
38
|
try {
|
|
37
39
|
await this.forkBlock(block.height);
|
|
38
|
-
const lastSavedBlock = await this.action.getLastSavedBlock();
|
|
39
40
|
if (lastSavedBlock && block.parentHash !== lastSavedBlock.hash) {
|
|
40
41
|
this.logger.error('It seems saved block is not valid in scanner.');
|
|
41
42
|
return false;
|
|
@@ -87,4 +88,4 @@ class WebSocketScanner extends AbstractScanner {
|
|
|
87
88
|
};
|
|
88
89
|
}
|
|
89
90
|
export { WebSocketScanner };
|
|
90
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
91
|
+
//# 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 { BlockTimeConfig } from '../interfaces';\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    blockTimeConfig: BlockTimeConfig,\n    logger?: AbstractLogger,\n    maxTryBlock: number = DEFAULT_MAX_TRY_BLOCK,\n    protected suffix?: string,\n  ) {\n    super(blockTimeConfig, 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    releaseMutex: () => void,\n  ): Promise<boolean> => {\n    for (let tryRound = 1; tryRound <= this.maxTryBlock; tryRound++) {\n      if (await fn()) return true;\n    }\n    releaseMutex();\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    const lastSavedBlock = await this.action.getLastSavedBlock();\n    await this.removeOldUnusedBlocks(lastSavedBlock);\n    await this.tryRunningFunction(\n      async () => {\n        try {\n          await this.forkBlock(block.height);\n\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(\n              block,\n              transactions,\n            );\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      },\n      `Block at height ${block.height}`,\n      release,\n    );\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(\n      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      },\n      `Forking block at height ${block.height}`,\n      release,\n    );\n    release();\n  };\n}\n\nexport { WebSocketScanner };\n"]}
|
package/dist/scanner/action.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { AbstractLogger } from '@rosen-bridge/abstract-logger';
|
|
2
|
-
import { DataSource, DeleteResult, Repository } from '@rosen-bridge/extended-typeorm';
|
|
2
|
+
import { DataSource, DeleteResult, Repository, ObjectLiteral, SelectQueryBuilder } from '@rosen-bridge/extended-typeorm';
|
|
3
3
|
import { Block } from '@rosen-bridge/scanner-interfaces';
|
|
4
4
|
import { BlockEntity } from '../entities/blockEntity';
|
|
5
5
|
import { ExtractorStatusEntity } from '../entities/extractorStatusEntity';
|
|
@@ -79,5 +79,26 @@ export declare class BlockDbAction {
|
|
|
79
79
|
* @returns extractors` status
|
|
80
80
|
*/
|
|
81
81
|
getExtractorsStatus: (extractorIds: string[]) => Promise<ExtractorStatusEntity[]>;
|
|
82
|
+
/**
|
|
83
|
+
* Generates queries with unique parameters
|
|
84
|
+
*
|
|
85
|
+
* @param queryBuilders
|
|
86
|
+
* @returns queries and their unique parameters
|
|
87
|
+
*/
|
|
88
|
+
generateQueriesWithUniqueParams: (queryBuilders: SelectQueryBuilder<ObjectLiteral>[]) => {
|
|
89
|
+
queryParts: string[];
|
|
90
|
+
parameters: Record<string, unknown>;
|
|
91
|
+
};
|
|
92
|
+
/**
|
|
93
|
+
* Removes unused blocks based on the queries retrieving used blocks
|
|
94
|
+
*
|
|
95
|
+
* @param extractorUsedBlocksQueries
|
|
96
|
+
* @param deletedBlockCount
|
|
97
|
+
* @param scannerName
|
|
98
|
+
* @param blockAgeThreshold
|
|
99
|
+
* @param lastSavedBlock
|
|
100
|
+
* @returns The hashes of the removed unused blocks
|
|
101
|
+
*/
|
|
102
|
+
removeUnusedBlocksInBatches: (extractorUsedBlocksQueries: SelectQueryBuilder<ObjectLiteral>[], deletedBlockCount: number, scannerName: string, blockAgeThreshold: number, lastSavedBlock: BlockEntity | undefined) => Promise<string[]>;
|
|
82
103
|
}
|
|
83
104
|
//# sourceMappingURL=action.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"action.d.ts","sourceRoot":"","sources":["../../lib/scanner/action.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"action.d.ts","sourceRoot":"","sources":["../../lib/scanner/action.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EACL,UAAU,EACV,YAAY,EAEZ,UAAU,EAEV,aAAa,EACb,kBAAkB,EACnB,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;IAEF;;;;;OAKG;IACH,+BAA+B,GAC7B,eAAe,kBAAkB,CAAC,aAAa,CAAC,EAAE,KACjD;QAAE,UAAU,EAAE,MAAM,EAAE,CAAC;QAAC,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;KAAE,CAwB9D;IAEF;;;;;;;;;OASG;IACH,2BAA2B,GACzB,4BAA4B,kBAAkB,CAAC,aAAa,CAAC,EAAE,EAC/D,mBAAmB,MAAM,EACzB,aAAa,MAAM,EACnB,mBAAmB,MAAM,EACzB,gBAAgB,WAAW,GAAG,SAAS,KACtC,OAAO,CAAC,MAAM,EAAE,CAAC,CA+BlB;CACH"}
|