@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.
Files changed (71) hide show
  1. package/README.md +49 -0
  2. package/dist/entities/blockEntity.d.ts +17 -0
  3. package/dist/entities/blockEntity.d.ts.map +1 -0
  4. package/dist/entities/blockEntity.js +78 -0
  5. package/dist/entities/extractorStatusEntity.d.ts +7 -0
  6. package/dist/entities/extractorStatusEntity.d.ts.map +1 -0
  7. package/dist/entities/extractorStatusEntity.js +37 -0
  8. package/dist/index.d.ts +11 -0
  9. package/dist/index.d.ts.map +1 -0
  10. package/dist/index.js +10 -0
  11. package/dist/migrations/index.d.ts +7 -0
  12. package/dist/migrations/index.d.ts.map +1 -0
  13. package/dist/migrations/index.js +31 -0
  14. package/dist/migrations/postgres/1688545690867-migration.d.ts +7 -0
  15. package/dist/migrations/postgres/1688545690867-migration.d.ts.map +1 -0
  16. package/dist/migrations/postgres/1688545690867-migration.js +30 -0
  17. package/dist/migrations/postgres/1713803486477-migration.d.ts +7 -0
  18. package/dist/migrations/postgres/1713803486477-migration.d.ts.map +1 -0
  19. package/dist/migrations/postgres/1713803486477-migration.js +20 -0
  20. package/dist/migrations/postgres/1718789786123-migration.d.ts +7 -0
  21. package/dist/migrations/postgres/1718789786123-migration.d.ts.map +1 -0
  22. package/dist/migrations/postgres/1718789786123-migration.js +12 -0
  23. package/dist/migrations/postgres/1722697954558-migration.d.ts +7 -0
  24. package/dist/migrations/postgres/1722697954558-migration.d.ts.map +1 -0
  25. package/dist/migrations/postgres/1722697954558-migration.js +52 -0
  26. package/dist/migrations/postgres/1746701087567-migration.d.ts +7 -0
  27. package/dist/migrations/postgres/1746701087567-migration.d.ts.map +1 -0
  28. package/dist/migrations/postgres/1746701087567-migration.js +32 -0
  29. package/dist/migrations/postgres/1747657653564-migration.d.ts +7 -0
  30. package/dist/migrations/postgres/1747657653564-migration.d.ts.map +1 -0
  31. package/dist/migrations/postgres/1747657653564-migration.js +134 -0
  32. package/dist/migrations/sqlite/1688555497475-migration.d.ts +7 -0
  33. package/dist/migrations/sqlite/1688555497475-migration.d.ts.map +1 -0
  34. package/dist/migrations/sqlite/1688555497475-migration.js +29 -0
  35. package/dist/migrations/sqlite/1713786682123-migration.d.ts +7 -0
  36. package/dist/migrations/sqlite/1713786682123-migration.d.ts.map +1 -0
  37. package/dist/migrations/sqlite/1713786682123-migration.js +20 -0
  38. package/dist/migrations/sqlite/1718789744123-migration.d.ts +7 -0
  39. package/dist/migrations/sqlite/1718789744123-migration.d.ts.map +1 -0
  40. package/dist/migrations/sqlite/1718789744123-migration.js +12 -0
  41. package/dist/migrations/sqlite/1722697111974-migration.d.ts +7 -0
  42. package/dist/migrations/sqlite/1722697111974-migration.d.ts.map +1 -0
  43. package/dist/migrations/sqlite/1722697111974-migration.js +112 -0
  44. package/dist/migrations/sqlite/1746701087234-migration.d.ts +7 -0
  45. package/dist/migrations/sqlite/1746701087234-migration.d.ts.map +1 -0
  46. package/dist/migrations/sqlite/1746701087234-migration.js +32 -0
  47. package/dist/migrations/sqlite/1747655941239-migration.d.ts +7 -0
  48. package/dist/migrations/sqlite/1747655941239-migration.d.ts.map +1 -0
  49. package/dist/migrations/sqlite/1747655941239-migration.js +134 -0
  50. package/dist/scanner/abstract/generalScanner.d.ts +63 -0
  51. package/dist/scanner/abstract/generalScanner.d.ts.map +1 -0
  52. package/dist/scanner/abstract/generalScanner.js +173 -0
  53. package/dist/scanner/abstract/scanner.d.ts +48 -0
  54. package/dist/scanner/abstract/scanner.d.ts.map +1 -0
  55. package/dist/scanner/abstract/scanner.js +154 -0
  56. package/dist/scanner/abstract/webSocketScanner.d.ts +29 -0
  57. package/dist/scanner/abstract/webSocketScanner.d.ts.map +1 -0
  58. package/dist/scanner/abstract/webSocketScanner.js +89 -0
  59. package/dist/scanner/action.d.ts +83 -0
  60. package/dist/scanner/action.d.ts.map +1 -0
  61. package/dist/scanner/action.js +251 -0
  62. package/dist/scanner/interfaces.d.ts +12 -0
  63. package/dist/scanner/interfaces.d.ts.map +1 -0
  64. package/dist/scanner/interfaces.js +2 -0
  65. package/dist/scanner/network/ConnectorSelectionStrategies.d.ts +27 -0
  66. package/dist/scanner/network/ConnectorSelectionStrategies.d.ts.map +1 -0
  67. package/dist/scanner/network/ConnectorSelectionStrategies.js +22 -0
  68. package/dist/scanner/network/NetworkConnectorManager.d.ts +64 -0
  69. package/dist/scanner/network/NetworkConnectorManager.d.ts.map +1 -0
  70. package/dist/scanner/network/NetworkConnectorManager.js +125 -0
  71. 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
+ }