@rosen-bridge/ergo-observation-extractor 0.1.1 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,41 @@
1
1
  # @rosen-bridge/ergo-observation-extractor
2
2
 
3
+ ## 0.2.0
4
+
5
+ ### Minor Changes
6
+
7
+ - The observation extractor have been updated to follow the format defined in `abstract-observation-extractor`
8
+ - Update rosen-extractor version to the 10.1.0
9
+
10
+ ### Patch Changes
11
+
12
+ - Fix package-lock and move typescript and types/node into root
13
+ - Update eslint and plugins:
14
+ - Apply new rules such as sort imports and file name
15
+ - Update dependencies
16
+ - @rosen-bridge/extended-typeorm@1.0.1
17
+ - @rosen-clients/rate-limited-axios@1.1.0
18
+ - @rosen-bridge/rosen-extractor@10.1.1
19
+ - @rosen-bridge/tokens@4.0.1
20
+ - @rosen-bridge/abstract-logger@3.0.1
21
+ - @rosen-bridge/json-bigint@1.1.0
22
+ - @rosen-clients/ergo-explorer@2.1.0
23
+ - @rosen-clients/ergo-node@3.1.0
24
+ - @rosen-bridge/abstract-observation-extractor@0.2.0
25
+ - @rosen-bridge/scanner-interfaces@0.2.1
26
+
27
+ ## 0.1.2
28
+
29
+ ### Patch Changes
30
+
31
+ - Update dependencies
32
+ - @rosen-bridge/abstract-observation-extractor@0.1.2
33
+ - @rosen-bridge/abstract-extractor@2.1.1
34
+ - @rosen-bridge/extended-typeorm@1.0.0
35
+ - @rosen-bridge/tokens@4.0.0
36
+ - @rosen-bridge/rosen-extractor@10.0.0
37
+ - @rosen-bridge/abstract-logger@3.0.0
38
+
3
39
  ## 0.1.1
4
40
 
5
41
  ### Patch Changes
@@ -1,34 +1,22 @@
1
- import { DataSource } from '@rosen-bridge/extended-typeorm';
2
1
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
3
- import { TokenMap } from '@rosen-bridge/tokens';
2
+ import { AbstractObservationExtractor } from '@rosen-bridge/abstract-observation-extractor';
3
+ import { DataSource } from '@rosen-bridge/extended-typeorm';
4
4
  import { Block, Transaction } from '@rosen-bridge/scanner-interfaces';
5
- import { AbstractExtractor } from '@rosen-bridge/abstract-extractor';
6
- export declare class ErgoObservationExtractor extends AbstractExtractor<Transaction> {
7
- readonly logger: AbstractLogger;
8
- private readonly actions;
9
- private readonly extractor;
10
- static readonly FROM_CHAIN: string;
11
- constructor(dataSource: DataSource, tokens: TokenMap, address: string, logger?: AbstractLogger);
5
+ import { TokenMap } from '@rosen-bridge/tokens';
6
+ export declare class ErgoObservationExtractor extends AbstractObservationExtractor<Transaction> {
7
+ readonly FROM_CHAIN: string;
8
+ constructor(lockAddress: string, dataSource: DataSource, tokens: TokenMap, logger?: AbstractLogger);
12
9
  /**
13
10
  * get Id for current extractor
14
11
  */
15
12
  getId: () => string;
16
13
  /**
17
- * gets block id and transactions corresponding to the block and saves if they are valid rosen
18
- * transactions and in case of success return true and in case of failure returns false
19
- * @param txs
20
- * @param block
21
- */
22
- processTransactions: (txs: Array<Transaction>, block: Block) => Promise<boolean>;
23
- /**
24
- * fork one block and remove all stored information for this block
25
- * @param hash: block hash
14
+ * gets transaction id from TransactionType
26
15
  */
27
- forkBlock: (hash: string) => Promise<void>;
16
+ getTxId: (tx: Transaction) => string;
28
17
  /**
29
- * Extractor box initialization
30
- * No action needed in cardano extractors
18
+ * Filter transactions before processing
31
19
  */
32
- initializeBoxes: () => Promise<void>;
20
+ protected preprocessTransactions: (txs: Array<Transaction>, block: Block) => Transaction[];
33
21
  }
34
22
  //# sourceMappingURL=ergoExtractor.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"ergoExtractor.d.ts","sourceRoot":"","sources":["../../lib/extractor/ergoExtractor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAG5D,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAEhD,OAAO,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,kCAAkC,CAAC;AACtE,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AAKrE,qBAAa,wBAAyB,SAAQ,iBAAiB,CAAC,WAAW,CAAC;IAC1E,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC;IAChC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAA0B;IAClD,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAyB;IACnD,MAAM,CAAC,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAU;gBAG1C,UAAU,EAAE,UAAU,EACtB,MAAM,EAAE,QAAQ,EAChB,OAAO,EAAE,MAAM,EACf,MAAM,CAAC,EAAE,cAAc;IAQzB;;OAEG;IACH,KAAK,eAAsC;IAE3C;;;;;OAKG;IACH,mBAAmB,GACjB,KAAK,KAAK,CAAC,WAAW,CAAC,EACvB,OAAO,KAAK,KACX,OAAO,CAAC,OAAO,CAAC,CAwDjB;IAEF;;;OAGG;IACH,SAAS,GAAU,MAAM,MAAM,KAAG,OAAO,CAAC,IAAI,CAAC,CAE7C;IAEF;;;OAGG;IACH,eAAe,sBAEb;CACH"}
1
+ {"version":3,"file":"ergoExtractor.d.ts","sourceRoot":"","sources":["../../lib/extractor/ergoExtractor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EAAE,4BAA4B,EAAE,MAAM,8CAA8C,CAAC;AAC5F,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAE5D,OAAO,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,kCAAkC,CAAC;AACtE,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAIhD,qBAAa,wBAAyB,SAAQ,4BAA4B,CAAC,WAAW,CAAC;IACrF,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAU;gBAGnC,WAAW,EAAE,MAAM,EACnB,UAAU,EAAE,UAAU,EACtB,MAAM,EAAE,QAAQ,EAChB,MAAM,CAAC,EAAE,cAAc;IAUzB;;OAEG;IACH,KAAK,eAAsC;IAE3C;;OAEG;IACH,OAAO,GAAI,IAAI,WAAW,YAAW;IAErC;;OAEG;IACH,SAAS,CAAC,sBAAsB,GAC9B,KAAK,KAAK,CAAC,WAAW,CAAC,EACvB,OAAO,KAAK,mBAiBZ;CACH"}
@@ -1,92 +1,34 @@
1
- import { Buffer } from 'buffer';
2
- import { blake2b } from 'blakejs';
3
- import { DummyLogger } from '@rosen-bridge/abstract-logger';
1
+ import { AbstractObservationExtractor } from '@rosen-bridge/abstract-observation-extractor';
4
2
  import { ErgoNodeRosenExtractor } from '@rosen-bridge/rosen-extractor';
5
- import { AbstractExtractor } from '@rosen-bridge/abstract-extractor';
6
- import { ObservationEntityAction } from '@rosen-bridge/abstract-observation-extractor';
7
3
  import { NUMBER_OF_BLOCKS_PER_YEAR } from '../const';
8
- export class ErgoObservationExtractor extends AbstractExtractor {
9
- logger;
10
- actions;
11
- extractor;
12
- static FROM_CHAIN = 'ergo';
13
- constructor(dataSource, tokens, address, logger) {
14
- super();
15
- this.logger = logger ? logger : new DummyLogger();
16
- this.actions = new ObservationEntityAction(dataSource, this.logger);
17
- this.extractor = new ErgoNodeRosenExtractor(address, tokens, this.logger);
4
+ export class ErgoObservationExtractor extends AbstractObservationExtractor {
5
+ FROM_CHAIN = 'ergo';
6
+ constructor(lockAddress, dataSource, tokens, logger) {
7
+ super(dataSource, tokens, new ErgoNodeRosenExtractor(lockAddress, tokens, logger), logger);
18
8
  }
19
9
  /**
20
10
  * get Id for current extractor
21
11
  */
22
12
  getId = () => 'ergo-observation-extractor';
23
13
  /**
24
- * gets block id and transactions corresponding to the block and saves if they are valid rosen
25
- * transactions and in case of success return true and in case of failure returns false
26
- * @param txs
27
- * @param block
14
+ * gets transaction id from TransactionType
28
15
  */
29
- processTransactions = (txs, block) => {
30
- return new Promise((resolve, reject) => {
31
- try {
32
- const observations = [];
33
- txs.forEach((transaction) => {
34
- for (let i = 0; i < transaction.outputs.length; i++) {
35
- const box = transaction.outputs[i];
36
- if (block.height - Number(box.creationHeight) >
37
- NUMBER_OF_BLOCKS_PER_YEAR) {
38
- this.logger.debug(`Skipping tx [${transaction.id}], box [${box.boxId}] creation_height [${box.creationHeight}] is more than a year ago [currentHeight: ${block.height}]`);
39
- return;
40
- }
41
- }
42
- const data = this.extractor.get(transaction);
43
- if (data) {
44
- const requestId = Buffer.from(blake2b(transaction.id, undefined, 32)).toString('hex');
45
- observations.push({
46
- fromChain: ErgoObservationExtractor.FROM_CHAIN,
47
- toChain: data.toChain,
48
- networkFee: data.networkFee,
49
- bridgeFee: data.bridgeFee,
50
- amount: data.amount,
51
- sourceChainTokenId: data.sourceChainTokenId,
52
- targetChainTokenId: data.targetChainTokenId,
53
- sourceTxId: data.sourceTxId,
54
- sourceBlockId: block.hash,
55
- requestId: requestId,
56
- toAddress: data.toAddress,
57
- fromAddress: data.fromAddress,
58
- });
59
- }
60
- });
61
- this.actions
62
- .storeObservations(observations, block, this.getId())
63
- .then((status) => {
64
- resolve(status);
65
- })
66
- .catch((e) => {
67
- this.logger.error(`An error uncached exception occurred during store ergo observation: ${e}`);
68
- reject(e);
69
- });
70
- }
71
- catch (e) {
72
- this.logger.error(`An error occurred while saving block ${block}: [${e}]`);
73
- reject(e);
74
- }
75
- });
76
- };
16
+ getTxId = (tx) => tx.id;
77
17
  /**
78
- * fork one block and remove all stored information for this block
79
- * @param hash: block hash
18
+ * Filter transactions before processing
80
19
  */
81
- forkBlock = async (hash) => {
82
- await this.actions.deleteBlockObservation(hash, this.getId());
83
- };
84
- /**
85
- * Extractor box initialization
86
- * No action needed in cardano extractors
87
- */
88
- initializeBoxes = async () => {
89
- return;
20
+ preprocessTransactions = (txs, block) => {
21
+ return txs.filter((transaction) => {
22
+ for (let i = 0; i < transaction.outputs.length; i++) {
23
+ const box = transaction.outputs[i];
24
+ if (block.height - Number(box.creationHeight) >
25
+ NUMBER_OF_BLOCKS_PER_YEAR) {
26
+ this.logger.debug(`Skipping tx [${transaction.id}], box [${box.boxId}] creation_height [${box.creationHeight}] is more than a year ago [currentHeight: ${block.height}]`);
27
+ return false;
28
+ }
29
+ }
30
+ return true;
31
+ });
90
32
  };
91
33
  }
92
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ergoExtractor.js","sourceRoot":"","sources":["../../lib/extractor/ergoExtractor.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAChC,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAkB,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAE5E,OAAO,EAAE,sBAAsB,EAAE,MAAM,+BAA+B,CAAC;AAEvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AAErE,OAAO,EAAE,uBAAuB,EAAE,MAAM,8CAA8C,CAAC;AACvF,OAAO,EAAE,yBAAyB,EAAE,MAAM,UAAU,CAAC;AAErD,MAAM,OAAO,wBAAyB,SAAQ,iBAA8B;IACjE,MAAM,CAAiB;IACf,OAAO,CAA0B;IACjC,SAAS,CAAyB;IACnD,MAAM,CAAU,UAAU,GAAW,MAAM,CAAC;IAE5C,YACE,UAAsB,EACtB,MAAgB,EAChB,OAAe,EACf,MAAuB;QAEvB,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,WAAW,EAAE,CAAC;QAClD,IAAI,CAAC,OAAO,GAAG,IAAI,uBAAuB,CAAC,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QACpE,IAAI,CAAC,SAAS,GAAG,IAAI,sBAAsB,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IAC5E,CAAC;IAED;;OAEG;IACH,KAAK,GAAG,GAAG,EAAE,CAAC,4BAA4B,CAAC;IAE3C;;;;;OAKG;IACH,mBAAmB,GAAG,CACpB,GAAuB,EACvB,KAAY,EACM,EAAE;QACpB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACrC,IAAI,CAAC;gBACH,MAAM,YAAY,GAAgC,EAAE,CAAC;gBACrD,GAAG,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,EAAE;oBAC1B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;wBACpD,MAAM,GAAG,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;wBACnC,IACE,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,cAAc,CAAC;4BACzC,yBAAyB,EACzB,CAAC;4BACD,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,gBAAgB,WAAW,CAAC,EAAE,WAAW,GAAG,CAAC,KAAK,sBAAsB,GAAG,CAAC,cAAc,6CAA6C,KAAK,CAAC,MAAM,GAAG,CACvJ,CAAC;4BACF,OAAO;wBACT,CAAC;oBACH,CAAC;oBACD,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;oBAC7C,IAAI,IAAI,EAAE,CAAC;wBACT,MAAM,SAAS,GAAG,MAAM,CAAC,IAAI,CAC3B,OAAO,CAAC,WAAW,CAAC,EAAE,EAAE,SAAS,EAAE,EAAE,CAAC,CACvC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;wBAClB,YAAY,CAAC,IAAI,CAAC;4BAChB,SAAS,EAAE,wBAAwB,CAAC,UAAU;4BAC9C,OAAO,EAAE,IAAI,CAAC,OAAO;4BACrB,UAAU,EAAE,IAAI,CAAC,UAAU;4BAC3B,SAAS,EAAE,IAAI,CAAC,SAAS;4BACzB,MAAM,EAAE,IAAI,CAAC,MAAM;4BACnB,kBAAkB,EAAE,IAAI,CAAC,kBAAkB;4BAC3C,kBAAkB,EAAE,IAAI,CAAC,kBAAkB;4BAC3C,UAAU,EAAE,IAAI,CAAC,UAAU;4BAC3B,aAAa,EAAE,KAAK,CAAC,IAAI;4BACzB,SAAS,EAAE,SAAS;4BACpB,SAAS,EAAE,IAAI,CAAC,SAAS;4BACzB,WAAW,EAAE,IAAI,CAAC,WAAW;yBAC9B,CAAC,CAAC;oBACL,CAAC;gBACH,CAAC,CAAC,CAAC;gBACH,IAAI,CAAC,OAAO;qBACT,iBAAiB,CAAC,YAAY,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC;qBACpD,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE;oBACf,OAAO,CAAC,MAAM,CAAC,CAAC;gBAClB,CAAC,CAAC;qBACD,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE;oBACX,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,uEAAuE,CAAC,EAAE,CAC3E,CAAC;oBACF,MAAM,CAAC,CAAC,CAAC,CAAC;gBACZ,CAAC,CAAC,CAAC;YACP,CAAC;YAAC,OAAO,CAAC,EAAE,CAAC;gBACX,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,wCAAwC,KAAK,MAAM,CAAC,GAAG,CACxD,CAAC;gBACF,MAAM,CAAC,CAAC,CAAC,CAAC;YACZ,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC;IAEF;;;OAGG;IACH,SAAS,GAAG,KAAK,EAAE,IAAY,EAAiB,EAAE;QAChD,MAAM,IAAI,CAAC,OAAO,CAAC,sBAAsB,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;IAChE,CAAC,CAAC;IAEF;;;OAGG;IACH,eAAe,GAAG,KAAK,IAAI,EAAE;QAC3B,OAAO;IACT,CAAC,CAAC","sourcesContent":["import { DataSource } from '@rosen-bridge/extended-typeorm';\nimport { Buffer } from 'buffer';\nimport { blake2b } from 'blakejs';\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport { TokenMap } from '@rosen-bridge/tokens';\nimport { ErgoNodeRosenExtractor } from '@rosen-bridge/rosen-extractor';\nimport { Block, Transaction } from '@rosen-bridge/scanner-interfaces';\nimport { AbstractExtractor } from '@rosen-bridge/abstract-extractor';\nimport { ExtractedObservation } from '@rosen-bridge/abstract-observation-extractor';\nimport { ObservationEntityAction } from '@rosen-bridge/abstract-observation-extractor';\nimport { NUMBER_OF_BLOCKS_PER_YEAR } from '../const';\n\nexport class ErgoObservationExtractor extends AbstractExtractor<Transaction> {\n  readonly logger: AbstractLogger;\n  private readonly actions: ObservationEntityAction;\n  private readonly extractor: ErgoNodeRosenExtractor;\n  static readonly FROM_CHAIN: string = 'ergo';\n\n  constructor(\n    dataSource: DataSource,\n    tokens: TokenMap,\n    address: string,\n    logger?: AbstractLogger,\n  ) {\n    super();\n    this.logger = logger ? logger : new DummyLogger();\n    this.actions = new ObservationEntityAction(dataSource, this.logger);\n    this.extractor = new ErgoNodeRosenExtractor(address, tokens, this.logger);\n  }\n\n  /**\n   * get Id for current extractor\n   */\n  getId = () => 'ergo-observation-extractor';\n\n  /**\n   * gets block id and transactions corresponding to the block and saves if they are valid rosen\n   *  transactions and in case of success return true and in case of failure returns false\n   * @param txs\n   * @param block\n   */\n  processTransactions = (\n    txs: Array<Transaction>,\n    block: Block,\n  ): Promise<boolean> => {\n    return new Promise((resolve, reject) => {\n      try {\n        const observations: Array<ExtractedObservation> = [];\n        txs.forEach((transaction) => {\n          for (let i = 0; i < transaction.outputs.length; i++) {\n            const box = transaction.outputs[i];\n            if (\n              block.height - Number(box.creationHeight) >\n              NUMBER_OF_BLOCKS_PER_YEAR\n            ) {\n              this.logger.debug(\n                `Skipping tx [${transaction.id}], box [${box.boxId}] creation_height [${box.creationHeight}] is more than a year ago [currentHeight: ${block.height}]`,\n              );\n              return;\n            }\n          }\n          const data = this.extractor.get(transaction);\n          if (data) {\n            const requestId = Buffer.from(\n              blake2b(transaction.id, undefined, 32),\n            ).toString('hex');\n            observations.push({\n              fromChain: ErgoObservationExtractor.FROM_CHAIN,\n              toChain: data.toChain,\n              networkFee: data.networkFee,\n              bridgeFee: data.bridgeFee,\n              amount: data.amount,\n              sourceChainTokenId: data.sourceChainTokenId,\n              targetChainTokenId: data.targetChainTokenId,\n              sourceTxId: data.sourceTxId,\n              sourceBlockId: block.hash,\n              requestId: requestId,\n              toAddress: data.toAddress,\n              fromAddress: data.fromAddress,\n            });\n          }\n        });\n        this.actions\n          .storeObservations(observations, block, this.getId())\n          .then((status) => {\n            resolve(status);\n          })\n          .catch((e) => {\n            this.logger.error(\n              `An error uncached exception occurred during store ergo observation: ${e}`,\n            );\n            reject(e);\n          });\n      } catch (e) {\n        this.logger.error(\n          `An error occurred while saving block ${block}: [${e}]`,\n        );\n        reject(e);\n      }\n    });\n  };\n\n  /**\n   * fork one block and remove all stored information for this block\n   * @param hash: block hash\n   */\n  forkBlock = async (hash: string): Promise<void> => {\n    await this.actions.deleteBlockObservation(hash, this.getId());\n  };\n\n  /**\n   * Extractor box initialization\n   * No action needed in cardano extractors\n   */\n  initializeBoxes = async () => {\n    return;\n  };\n}\n"]}
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJnb0V4dHJhY3Rvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9leHRyYWN0b3IvZXJnb0V4dHJhY3Rvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSw4Q0FBOEMsQ0FBQztBQUU1RixPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUl2RSxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFFckQsTUFBTSxPQUFPLHdCQUF5QixTQUFRLDRCQUF5QztJQUM1RSxVQUFVLEdBQVcsTUFBTSxDQUFDO0lBRXJDLFlBQ0UsV0FBbUIsRUFDbkIsVUFBc0IsRUFDdEIsTUFBZ0IsRUFDaEIsTUFBdUI7UUFFdkIsS0FBSyxDQUNILFVBQVUsRUFDVixNQUFNLEVBQ04sSUFBSSxzQkFBc0IsQ0FBQyxXQUFXLEVBQUUsTUFBTSxFQUFFLE1BQU0sQ0FBQyxFQUN2RCxNQUFNLENBQ1AsQ0FBQztJQUNKLENBQUM7SUFFRDs7T0FFRztJQUNILEtBQUssR0FBRyxHQUFHLEVBQUUsQ0FBQyw0QkFBNEIsQ0FBQztJQUUzQzs7T0FFRztJQUNILE9BQU8sR0FBRyxDQUFDLEVBQWUsRUFBRSxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQztJQUVyQzs7T0FFRztJQUNPLHNCQUFzQixHQUFHLENBQ2pDLEdBQXVCLEVBQ3ZCLEtBQVksRUFDWixFQUFFO1FBQ0YsT0FBTyxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUMsV0FBVyxFQUFFLEVBQUU7WUFDaEMsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLFdBQVcsQ0FBQyxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUM7Z0JBQ3BELE1BQU0sR0FBRyxHQUFHLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQ25DLElBQ0UsS0FBSyxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLGNBQWMsQ0FBQztvQkFDekMseUJBQXlCLEVBQ3pCLENBQUM7b0JBQ0QsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQ2YsZ0JBQWdCLFdBQVcsQ0FBQyxFQUFFLFdBQVcsR0FBRyxDQUFDLEtBQUssc0JBQXNCLEdBQUcsQ0FBQyxjQUFjLDZDQUE2QyxLQUFLLENBQUMsTUFBTSxHQUFHLENBQ3ZKLENBQUM7b0JBQ0YsT0FBTyxLQUFLLENBQUM7Z0JBQ2YsQ0FBQztZQUNILENBQUM7WUFDRCxPQUFPLElBQUksQ0FBQztRQUNkLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyxDQUFDO0NBQ0giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBYnN0cmFjdExvZ2dlciB9IGZyb20gJ0Byb3Nlbi1icmlkZ2UvYWJzdHJhY3QtbG9nZ2VyJztcbmltcG9ydCB7IEFic3RyYWN0T2JzZXJ2YXRpb25FeHRyYWN0b3IgfSBmcm9tICdAcm9zZW4tYnJpZGdlL2Fic3RyYWN0LW9ic2VydmF0aW9uLWV4dHJhY3Rvcic7XG5pbXBvcnQgeyBEYXRhU291cmNlIH0gZnJvbSAnQHJvc2VuLWJyaWRnZS9leHRlbmRlZC10eXBlb3JtJztcbmltcG9ydCB7IEVyZ29Ob2RlUm9zZW5FeHRyYWN0b3IgfSBmcm9tICdAcm9zZW4tYnJpZGdlL3Jvc2VuLWV4dHJhY3Rvcic7XG5pbXBvcnQgeyBCbG9jaywgVHJhbnNhY3Rpb24gfSBmcm9tICdAcm9zZW4tYnJpZGdlL3NjYW5uZXItaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBUb2tlbk1hcCB9IGZyb20gJ0Byb3Nlbi1icmlkZ2UvdG9rZW5zJztcblxuaW1wb3J0IHsgTlVNQkVSX09GX0JMT0NLU19QRVJfWUVBUiB9IGZyb20gJy4uL2NvbnN0JztcblxuZXhwb3J0IGNsYXNzIEVyZ29PYnNlcnZhdGlvbkV4dHJhY3RvciBleHRlbmRzIEFic3RyYWN0T2JzZXJ2YXRpb25FeHRyYWN0b3I8VHJhbnNhY3Rpb24+IHtcbiAgcmVhZG9ubHkgRlJPTV9DSEFJTjogc3RyaW5nID0gJ2VyZ28nO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIGxvY2tBZGRyZXNzOiBzdHJpbmcsXG4gICAgZGF0YVNvdXJjZTogRGF0YVNvdXJjZSxcbiAgICB0b2tlbnM6IFRva2VuTWFwLFxuICAgIGxvZ2dlcj86IEFic3RyYWN0TG9nZ2VyLFxuICApIHtcbiAgICBzdXBlcihcbiAgICAgIGRhdGFTb3VyY2UsXG4gICAgICB0b2tlbnMsXG4gICAgICBuZXcgRXJnb05vZGVSb3NlbkV4dHJhY3Rvcihsb2NrQWRkcmVzcywgdG9rZW5zLCBsb2dnZXIpLFxuICAgICAgbG9nZ2VyLFxuICAgICk7XG4gIH1cblxuICAvKipcbiAgICogZ2V0IElkIGZvciBjdXJyZW50IGV4dHJhY3RvclxuICAgKi9cbiAgZ2V0SWQgPSAoKSA9PiAnZXJnby1vYnNlcnZhdGlvbi1leHRyYWN0b3InO1xuXG4gIC8qKlxuICAgKiBnZXRzIHRyYW5zYWN0aW9uIGlkIGZyb20gVHJhbnNhY3Rpb25UeXBlXG4gICAqL1xuICBnZXRUeElkID0gKHR4OiBUcmFuc2FjdGlvbikgPT4gdHguaWQ7XG5cbiAgLyoqXG4gICAqIEZpbHRlciB0cmFuc2FjdGlvbnMgYmVmb3JlIHByb2Nlc3NpbmdcbiAgICovXG4gIHByb3RlY3RlZCBwcmVwcm9jZXNzVHJhbnNhY3Rpb25zID0gKFxuICAgIHR4czogQXJyYXk8VHJhbnNhY3Rpb24+LFxuICAgIGJsb2NrOiBCbG9jayxcbiAgKSA9PiB7XG4gICAgcmV0dXJuIHR4cy5maWx0ZXIoKHRyYW5zYWN0aW9uKSA9PiB7XG4gICAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRyYW5zYWN0aW9uLm91dHB1dHMubGVuZ3RoOyBpKyspIHtcbiAgICAgICAgY29uc3QgYm94ID0gdHJhbnNhY3Rpb24ub3V0cHV0c1tpXTtcbiAgICAgICAgaWYgKFxuICAgICAgICAgIGJsb2NrLmhlaWdodCAtIE51bWJlcihib3guY3JlYXRpb25IZWlnaHQpID5cbiAgICAgICAgICBOVU1CRVJfT0ZfQkxPQ0tTX1BFUl9ZRUFSXG4gICAgICAgICkge1xuICAgICAgICAgIHRoaXMubG9nZ2VyLmRlYnVnKFxuICAgICAgICAgICAgYFNraXBwaW5nIHR4IFske3RyYW5zYWN0aW9uLmlkfV0sIGJveCBbJHtib3guYm94SWR9XSBjcmVhdGlvbl9oZWlnaHQgWyR7Ym94LmNyZWF0aW9uSGVpZ2h0fV0gaXMgbW9yZSB0aGFuIGEgeWVhciBhZ28gW2N1cnJlbnRIZWlnaHQ6ICR7YmxvY2suaGVpZ2h0fV1gLFxuICAgICAgICAgICk7XG4gICAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9KTtcbiAgfTtcbn1cbiJdfQ==
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@rosen-bridge/ergo-observation-extractor",
3
- "version": "0.1.1",
3
+ "version": "0.2.0",
4
4
  "description": "Event observation data extractor for Ergo chain",
5
5
  "repository": {
6
6
  "type": "git",
@@ -17,33 +17,32 @@
17
17
  ],
18
18
  "scripts": {
19
19
  "build": "tsc --build tsconfig.build.json",
20
+ "clean": "rimraf dist && rimraf tsconfig.build.tsbuildinfo",
20
21
  "coverage": "npm run test -- --coverage",
21
22
  "lint": "eslint --fix . && npm run prettify",
22
- "prettify": "prettier --write . --ignore-path ./.gitignore",
23
- "release": "npm run test -- --run && npm run build && npm publish --access public",
23
+ "lint:check": "eslint . && npm run prettify:check",
24
+ "prettify": "prettier --write . --ignore-path ../../../.gitignore",
25
+ "prettify:check": "prettier --check . --ignore-path ../../../.gitignore",
26
+ "release": "npm run test -- --run && npm run clean && npm run build && npm publish --access public",
24
27
  "test": "NODE_OPTIONS='--import tsx' vitest",
25
28
  "type-check": "tsc --noEmit"
26
29
  },
30
+ "dependencies": {
31
+ "@rosen-bridge/abstract-logger": "^3.0.1",
32
+ "@rosen-bridge/abstract-observation-extractor": "^0.2.0",
33
+ "@rosen-bridge/extended-typeorm": "^1.0.1",
34
+ "@rosen-bridge/rosen-extractor": "^10.1.1",
35
+ "@rosen-bridge/scanner-interfaces": "^0.2.1",
36
+ "@rosen-bridge/tokens": "^4.0.1"
37
+ },
27
38
  "devDependencies": {
28
- "@rosen-bridge/abstract-scanner": "^0.1.0",
29
- "@rosen-bridge/json-bigint": "^0.1.0",
30
- "@types/node": "^22.18.0",
39
+ "@rosen-bridge/abstract-scanner": "^0.2.1",
40
+ "@rosen-bridge/json-bigint": "^1.1.0",
31
41
  "@vitest/coverage-istanbul": "^3.1.4",
32
42
  "ergo-lib-wasm-nodejs": "^0.24.1",
33
43
  "tsx": "^4.19.4",
34
- "typescript": "^5.3.3",
35
44
  "vitest": "^3.1.4"
36
45
  },
37
- "dependencies": {
38
- "@rosen-bridge/abstract-extractor": "^2.1.0",
39
- "@rosen-bridge/abstract-logger": "^2.0.1",
40
- "@rosen-bridge/abstract-observation-extractor": "^0.1.1",
41
- "@rosen-bridge/extended-typeorm": "^0.2.1",
42
- "@rosen-bridge/rosen-extractor": "^9.0.0",
43
- "@rosen-bridge/scanner-interfaces": "^0.2.0",
44
- "@rosen-bridge/tokens": "^3.1.1",
45
- "blakejs": "^1.2.1"
46
- },
47
46
  "engines": {
48
47
  "node": ">=22.18.0"
49
48
  }