@rosen-bridge/abstract-scanner 0.1.0-52fc0239
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/README.md +49 -0
- package/dist/entities/blockEntity.d.ts +17 -0
- package/dist/entities/blockEntity.d.ts.map +1 -0
- package/dist/entities/blockEntity.js +78 -0
- package/dist/entities/extractorStatusEntity.d.ts +7 -0
- package/dist/entities/extractorStatusEntity.d.ts.map +1 -0
- package/dist/entities/extractorStatusEntity.js +37 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +10 -0
- package/dist/migrations/index.d.ts +7 -0
- package/dist/migrations/index.d.ts.map +1 -0
- package/dist/migrations/index.js +31 -0
- package/dist/migrations/postgres/1688545690867-migration.d.ts +7 -0
- package/dist/migrations/postgres/1688545690867-migration.d.ts.map +1 -0
- package/dist/migrations/postgres/1688545690867-migration.js +30 -0
- package/dist/migrations/postgres/1713803486477-migration.d.ts +7 -0
- package/dist/migrations/postgres/1713803486477-migration.d.ts.map +1 -0
- package/dist/migrations/postgres/1713803486477-migration.js +20 -0
- package/dist/migrations/postgres/1718789786123-migration.d.ts +7 -0
- package/dist/migrations/postgres/1718789786123-migration.d.ts.map +1 -0
- package/dist/migrations/postgres/1718789786123-migration.js +12 -0
- package/dist/migrations/postgres/1722697954558-migration.d.ts +7 -0
- package/dist/migrations/postgres/1722697954558-migration.d.ts.map +1 -0
- package/dist/migrations/postgres/1722697954558-migration.js +52 -0
- package/dist/migrations/postgres/1746701087567-migration.d.ts +7 -0
- package/dist/migrations/postgres/1746701087567-migration.d.ts.map +1 -0
- package/dist/migrations/postgres/1746701087567-migration.js +32 -0
- package/dist/migrations/postgres/1747657653564-migration.d.ts +7 -0
- package/dist/migrations/postgres/1747657653564-migration.d.ts.map +1 -0
- package/dist/migrations/postgres/1747657653564-migration.js +134 -0
- package/dist/migrations/sqlite/1688555497475-migration.d.ts +7 -0
- package/dist/migrations/sqlite/1688555497475-migration.d.ts.map +1 -0
- package/dist/migrations/sqlite/1688555497475-migration.js +29 -0
- package/dist/migrations/sqlite/1713786682123-migration.d.ts +7 -0
- package/dist/migrations/sqlite/1713786682123-migration.d.ts.map +1 -0
- package/dist/migrations/sqlite/1713786682123-migration.js +20 -0
- package/dist/migrations/sqlite/1718789744123-migration.d.ts +7 -0
- package/dist/migrations/sqlite/1718789744123-migration.d.ts.map +1 -0
- package/dist/migrations/sqlite/1718789744123-migration.js +12 -0
- package/dist/migrations/sqlite/1722697111974-migration.d.ts +7 -0
- package/dist/migrations/sqlite/1722697111974-migration.d.ts.map +1 -0
- package/dist/migrations/sqlite/1722697111974-migration.js +112 -0
- package/dist/migrations/sqlite/1746701087234-migration.d.ts +7 -0
- package/dist/migrations/sqlite/1746701087234-migration.d.ts.map +1 -0
- package/dist/migrations/sqlite/1746701087234-migration.js +32 -0
- package/dist/migrations/sqlite/1747655941239-migration.d.ts +7 -0
- package/dist/migrations/sqlite/1747655941239-migration.d.ts.map +1 -0
- package/dist/migrations/sqlite/1747655941239-migration.js +134 -0
- package/dist/scanner/abstract/generalScanner.d.ts +63 -0
- package/dist/scanner/abstract/generalScanner.d.ts.map +1 -0
- package/dist/scanner/abstract/generalScanner.js +173 -0
- package/dist/scanner/abstract/scanner.d.ts +48 -0
- package/dist/scanner/abstract/scanner.d.ts.map +1 -0
- package/dist/scanner/abstract/scanner.js +154 -0
- package/dist/scanner/abstract/webSocketScanner.d.ts +29 -0
- package/dist/scanner/abstract/webSocketScanner.d.ts.map +1 -0
- package/dist/scanner/abstract/webSocketScanner.js +89 -0
- package/dist/scanner/action.d.ts +83 -0
- package/dist/scanner/action.d.ts.map +1 -0
- package/dist/scanner/action.js +251 -0
- package/dist/scanner/interfaces.d.ts +12 -0
- package/dist/scanner/interfaces.d.ts.map +1 -0
- package/dist/scanner/interfaces.js +2 -0
- package/dist/scanner/network/ConnectorSelectionStrategies.d.ts +27 -0
- package/dist/scanner/network/ConnectorSelectionStrategies.d.ts.map +1 -0
- package/dist/scanner/network/ConnectorSelectionStrategies.js +22 -0
- package/dist/scanner/network/NetworkConnectorManager.d.ts +64 -0
- package/dist/scanner/network/NetworkConnectorManager.d.ts.map +1 -0
- package/dist/scanner/network/NetworkConnectorManager.js +125 -0
- package/package.json +54 -0
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
import { FailoverStrategy, } from './ConnectorSelectionStrategies';
|
|
2
|
+
import { DummyLogger } from '@rosen-bridge/abstract-logger';
|
|
3
|
+
/**
|
|
4
|
+
* Network connector manager that can handle multiple connectors
|
|
5
|
+
* for a single network with pluggable selection strategy
|
|
6
|
+
*/
|
|
7
|
+
export class NetworkConnectorManager {
|
|
8
|
+
strategy;
|
|
9
|
+
logger;
|
|
10
|
+
connectors;
|
|
11
|
+
currentConnectorIndex;
|
|
12
|
+
constructor(strategy = new FailoverStrategy(), logger = new DummyLogger()) {
|
|
13
|
+
this.strategy = strategy;
|
|
14
|
+
this.logger = logger;
|
|
15
|
+
this.connectors = [];
|
|
16
|
+
this.currentConnectorIndex = 0;
|
|
17
|
+
this.strategy = strategy;
|
|
18
|
+
this.logger.debug('NetworkConnectorManager initialized');
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Add a new connector to the manager
|
|
22
|
+
* @param connector The network connector instance
|
|
23
|
+
*/
|
|
24
|
+
addConnector(connector) {
|
|
25
|
+
this.connectors.push(connector);
|
|
26
|
+
this.logger.info(`Added new connector. Total connectors: ${this.connectors.length}`);
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Get the current active connector
|
|
30
|
+
* @returns The current network connector instance
|
|
31
|
+
* @throws Error if no connectors are available
|
|
32
|
+
*/
|
|
33
|
+
getCurrentConnector() {
|
|
34
|
+
if (this.connectors.length === 0) {
|
|
35
|
+
throw new Error('No connectors available');
|
|
36
|
+
}
|
|
37
|
+
this.logger.debug(`Using connector at index ${this.currentConnectorIndex}`);
|
|
38
|
+
return this.connectors[this.currentConnectorIndex];
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Execute an operation using the configured strategy
|
|
42
|
+
* @param operation The operation to execute
|
|
43
|
+
* @returns The result of the operation
|
|
44
|
+
*/
|
|
45
|
+
async executeWithStrategy(operation) {
|
|
46
|
+
if (this.connectors.length === 0) {
|
|
47
|
+
throw new Error('No connectors available for operation');
|
|
48
|
+
}
|
|
49
|
+
let lastError;
|
|
50
|
+
let attempts = 0;
|
|
51
|
+
const maxAttempts = this.connectors.length;
|
|
52
|
+
while (attempts < maxAttempts) {
|
|
53
|
+
try {
|
|
54
|
+
const connector = this.connectors[this.currentConnectorIndex];
|
|
55
|
+
this.logger.debug(`Attempt ${attempts + 1}/${maxAttempts} with connector at index ${this.currentConnectorIndex}`);
|
|
56
|
+
const result = await operation(connector);
|
|
57
|
+
this.currentConnectorIndex = this.strategy.selectNextConnector(this.connectors, this.currentConnectorIndex);
|
|
58
|
+
this.logger.debug(`Operation successful, next connector index: ${this.currentConnectorIndex}`);
|
|
59
|
+
return result;
|
|
60
|
+
}
|
|
61
|
+
catch (error) {
|
|
62
|
+
lastError = error;
|
|
63
|
+
this.logger.warn(`Operation failed with connector at index ${this.currentConnectorIndex}: ${lastError.message}`);
|
|
64
|
+
this.currentConnectorIndex = this.strategy.selectNextConnector(this.connectors, this.currentConnectorIndex, lastError);
|
|
65
|
+
attempts++;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
throw lastError || new Error('All connectors failed');
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Set the strategy to use for connector selection
|
|
72
|
+
* @param strategy The strategy to use
|
|
73
|
+
*/
|
|
74
|
+
setStrategy(strategy) {
|
|
75
|
+
this.logger.info('Setting new connector selection strategy');
|
|
76
|
+
this.strategy = strategy;
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Get a block at a specific height
|
|
80
|
+
* @param height The height of the block to get
|
|
81
|
+
* @returns The block at the specified height
|
|
82
|
+
*/
|
|
83
|
+
getBlockAtHeight = async (height) => {
|
|
84
|
+
return this.executeWithStrategy((connector) => connector.getBlockAtHeight(height));
|
|
85
|
+
};
|
|
86
|
+
/**
|
|
87
|
+
* Get the current height of the blockchain
|
|
88
|
+
* @returns The current height
|
|
89
|
+
*/
|
|
90
|
+
getCurrentHeight = async () => {
|
|
91
|
+
return this.executeWithStrategy((connector) => connector.getCurrentHeight());
|
|
92
|
+
};
|
|
93
|
+
/**
|
|
94
|
+
* Get all transactions in a block
|
|
95
|
+
* @param blockHash The hash of the block to get transactions from
|
|
96
|
+
* @returns Array of transactions in the block
|
|
97
|
+
*/
|
|
98
|
+
getBlockTxs = async (blockHash) => {
|
|
99
|
+
return this.executeWithStrategy((connector) => connector.getBlockTxs(blockHash));
|
|
100
|
+
};
|
|
101
|
+
/**
|
|
102
|
+
* Get the number of available connectors
|
|
103
|
+
* @returns The number of connectors
|
|
104
|
+
*/
|
|
105
|
+
getConnectorCount() {
|
|
106
|
+
const count = this.connectors.length;
|
|
107
|
+
this.logger.debug(`Current connector count: ${count}`);
|
|
108
|
+
return count;
|
|
109
|
+
}
|
|
110
|
+
/**
|
|
111
|
+
* Remove a connector at the specified index
|
|
112
|
+
* @param index The index of the connector to remove
|
|
113
|
+
*/
|
|
114
|
+
removeConnector(index) {
|
|
115
|
+
if (index < 0 || index >= this.connectors.length) {
|
|
116
|
+
throw new Error('Invalid connector index');
|
|
117
|
+
}
|
|
118
|
+
this.logger.info(`Removing connector at index ${index}`);
|
|
119
|
+
this.connectors.splice(index, 1);
|
|
120
|
+
if (this.currentConnectorIndex >= this.connectors.length) {
|
|
121
|
+
this.currentConnectorIndex = 0;
|
|
122
|
+
}
|
|
123
|
+
}
|
|
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"]}
|
package/package.json
ADDED
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@rosen-bridge/abstract-scanner",
|
|
3
|
+
"version": "0.1.0-52fc0239",
|
|
4
|
+
"description": "Abstract scanner toolkit for blockchain scanning with logging.",
|
|
5
|
+
"author": "Rosen Team",
|
|
6
|
+
"license": "MIT",
|
|
7
|
+
"main": "dist/index.js",
|
|
8
|
+
"types": "dist/index.d.ts",
|
|
9
|
+
"scripts": {
|
|
10
|
+
"prettify": "prettier --write . --ignore-path ../../.gitignore",
|
|
11
|
+
"lint": "eslint --fix . && npm run prettify",
|
|
12
|
+
"test": "jest",
|
|
13
|
+
"coverage": "jest --detectOpenHandles --coverage",
|
|
14
|
+
"build": "tsc --build",
|
|
15
|
+
"type-check": "tsc --noEmit",
|
|
16
|
+
"release": "npm run test && npm run build && npm publish --access public"
|
|
17
|
+
},
|
|
18
|
+
"repository": {
|
|
19
|
+
"type": "git",
|
|
20
|
+
"url": "git+https://github.com/rosen-bridge/scanner"
|
|
21
|
+
},
|
|
22
|
+
"files": [
|
|
23
|
+
"dist"
|
|
24
|
+
],
|
|
25
|
+
"dependencies": {
|
|
26
|
+
"@rosen-bridge/abstract-extractor": "^2.0.3-52fc0239",
|
|
27
|
+
"@rosen-bridge/abstract-logger": "^2.0.1",
|
|
28
|
+
"@rosen-bridge/json-bigint": "^0.1.0",
|
|
29
|
+
"@rosen-bridge/scanner-interfaces": "^0.1.1-52fc0239",
|
|
30
|
+
"await-semaphore": "^0.1.3",
|
|
31
|
+
"lodash-es": "^4.17.21",
|
|
32
|
+
"reflect-metadata": "^0.1.13",
|
|
33
|
+
"sqlite3": "^5.1.7",
|
|
34
|
+
"@rosen-bridge/extended-typeorm": "^0.2.1"
|
|
35
|
+
},
|
|
36
|
+
"type": "module",
|
|
37
|
+
"devDependencies": {
|
|
38
|
+
"@babel/preset-env": "^7.19.0",
|
|
39
|
+
"@types/jest": "^28.1.6",
|
|
40
|
+
"@types/lodash-es": "^4.17.12",
|
|
41
|
+
"@types/node": "^22.18.0",
|
|
42
|
+
"@typescript-eslint/eslint-plugin": "^5.30.7",
|
|
43
|
+
"@typescript-eslint/parser": "^5.26.0",
|
|
44
|
+
"eslint": "^8.16.0",
|
|
45
|
+
"eslint-config-prettier": "^8.5.0",
|
|
46
|
+
"jest": "^28.1.3",
|
|
47
|
+
"prettier": "2.7.1",
|
|
48
|
+
"ts-jest": "^28.0.7",
|
|
49
|
+
"typescript": "^4.7.4"
|
|
50
|
+
},
|
|
51
|
+
"engines": {
|
|
52
|
+
"node": ">=22.18.0"
|
|
53
|
+
}
|
|
54
|
+
}
|