@rosen-bridge/cardano-observation-extractor 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/CHANGELOG.md +8 -0
- package/README.md +24 -0
- package/dist/const.d.ts +2 -0
- package/dist/const.d.ts.map +1 -0
- package/dist/const.js +2 -0
- package/dist/extractor/blockfrost.d.ts +40 -0
- package/dist/extractor/blockfrost.d.ts.map +1 -0
- package/dist/extractor/blockfrost.js +82 -0
- package/dist/extractor/koios.d.ts +35 -0
- package/dist/extractor/koios.d.ts.map +1 -0
- package/dist/extractor/koios.js +82 -0
- package/dist/extractor/ogmios.d.ts +35 -0
- package/dist/extractor/ogmios.d.ts.map +1 -0
- package/dist/extractor/ogmios.js +82 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +4 -0
- package/dist/interfaces/koiosTransaction.d.ts +13 -0
- package/dist/interfaces/koiosTransaction.d.ts.map +1 -0
- package/dist/interfaces/koiosTransaction.js +2 -0
- package/package.json +51 -0
package/CHANGELOG.md
ADDED
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
# @rosen-bridge/cardano-observation-extractor
|
|
2
|
+
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
## 0.1.0
|
|
6
|
+
|
|
7
|
+
- This package was **extracted** from `@rosen-bridge/observation-extractor`.
|
|
8
|
+
You can follow the previous history in the old package’s changelog. The last changelog update is available [here](https://github.com/rosen-bridge/scanner/blob/d4a5539b01c523b101104470b03ff7023a10b70b/packages/observation-extractor/CHANGELOG.md).
|
package/README.md
ADDED
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
# @rosen-bridge/cardano-observation-extractor
|
|
2
|
+
|
|
3
|
+
## Table of contents
|
|
4
|
+
|
|
5
|
+
- [Introduction](#introduction)
|
|
6
|
+
- [Installation](#installation)
|
|
7
|
+
|
|
8
|
+
## Introduction
|
|
9
|
+
|
|
10
|
+
Event observation data extractor for Cardano chain.
|
|
11
|
+
|
|
12
|
+
## Installation
|
|
13
|
+
|
|
14
|
+
npm:
|
|
15
|
+
|
|
16
|
+
```sh
|
|
17
|
+
npm i @rosen-bridge/cardano-observation-extractor
|
|
18
|
+
```
|
|
19
|
+
|
|
20
|
+
yarn:
|
|
21
|
+
|
|
22
|
+
```sh
|
|
23
|
+
yarn add @rosen-bridge/cardano-observation-extractor
|
|
24
|
+
```
|
package/dist/const.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"const.d.ts","sourceRoot":"","sources":["../lib/const.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,oBAAoB,QAAQ,CAAC"}
|
package/dist/const.js
ADDED
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export const CARDANO_NATIVE_TOKEN = 'ada';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9saWIvY29uc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQUcsS0FBSyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IENBUkRBTk9fTkFUSVZFX1RPS0VOID0gJ2FkYSc7XG4iXX0=
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { DataSource } from '@rosen-bridge/extended-typeorm';
|
|
2
|
+
import { AbstractLogger } from '@rosen-bridge/abstract-logger';
|
|
3
|
+
import { TokenMap } from '@rosen-bridge/tokens';
|
|
4
|
+
import { components } from '@blockfrost/openapi';
|
|
5
|
+
import { Block } from '@rosen-bridge/scanner-interfaces';
|
|
6
|
+
import { AbstractExtractor } from '@rosen-bridge/abstract-extractor';
|
|
7
|
+
interface BlockFrostTransaction {
|
|
8
|
+
utxos: components['schemas']['tx_content_utxo'];
|
|
9
|
+
metadata: components['schemas']['tx_content_metadata'];
|
|
10
|
+
}
|
|
11
|
+
export declare class CardanoBlockFrostObservationExtractor extends AbstractExtractor<BlockFrostTransaction> {
|
|
12
|
+
readonly logger: AbstractLogger;
|
|
13
|
+
private readonly actions;
|
|
14
|
+
private readonly extractor;
|
|
15
|
+
static readonly FROM_CHAIN: string;
|
|
16
|
+
constructor(dataSource: DataSource, tokens: TokenMap, address: string, logger?: AbstractLogger);
|
|
17
|
+
/**
|
|
18
|
+
* get Id for current extractor
|
|
19
|
+
*/
|
|
20
|
+
getId: () => string;
|
|
21
|
+
/**
|
|
22
|
+
* gets block id and transactions corresponding to the block and saves if they are valid rosen
|
|
23
|
+
* transactions and in case of success return true and in case of failure returns false
|
|
24
|
+
* @param block
|
|
25
|
+
* @param txs
|
|
26
|
+
*/
|
|
27
|
+
processTransactions: (txs: Array<BlockFrostTransaction>, block: Block) => Promise<boolean>;
|
|
28
|
+
/**
|
|
29
|
+
* fork one block and remove all stored information for this block
|
|
30
|
+
* @param hash: block hash
|
|
31
|
+
*/
|
|
32
|
+
forkBlock: (hash: string) => Promise<void>;
|
|
33
|
+
/**
|
|
34
|
+
* Extractor box initialization
|
|
35
|
+
* No action needed in cardano extractors
|
|
36
|
+
*/
|
|
37
|
+
initializeBoxes: () => Promise<void>;
|
|
38
|
+
}
|
|
39
|
+
export {};
|
|
40
|
+
//# sourceMappingURL=blockfrost.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"blockfrost.d.ts","sourceRoot":"","sources":["../../lib/extractor/blockfrost.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,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,EAAE,KAAK,EAAE,MAAM,kCAAkC,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AAMrE,UAAU,qBAAqB;IAC7B,KAAK,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC,iBAAiB,CAAC,CAAC;IAChD,QAAQ,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC,qBAAqB,CAAC,CAAC;CACxD;AAED,qBAAa,qCAAsC,SAAQ,iBAAiB,CAAC,qBAAqB,CAAC;IACjG,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC;IAChC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAA0B;IAClD,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAkC;IAC5D,MAAM,CAAC,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAa;gBAG7C,UAAU,EAAE,UAAU,EACtB,MAAM,EAAE,QAAQ,EAChB,OAAO,EAAE,MAAM,EACf,MAAM,CAAC,EAAE,cAAc;IAYzB;;OAEG;IACH,KAAK,eAAwC;IAE7C;;;;;OAKG;IACH,mBAAmB,GACjB,KAAK,KAAK,CAAC,qBAAqB,CAAC,EACjC,OAAO,KAAK,KACX,OAAO,CAAC,OAAO,CAAC,CAyCjB;IAEF;;;OAGG;IACH,SAAS,GAAU,MAAM,MAAM,KAAG,OAAO,CAAC,IAAI,CAAC,CAE7C;IAEF;;;OAGG;IACH,eAAe,sBAEb;CACH"}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { Buffer } from 'buffer';
|
|
2
|
+
import { blake2b } from 'blakejs';
|
|
3
|
+
import { DummyLogger } from '@rosen-bridge/abstract-logger';
|
|
4
|
+
import { CardanoBlockFrostRosenExtractor } from '@rosen-bridge/rosen-extractor';
|
|
5
|
+
import { AbstractExtractor } from '@rosen-bridge/abstract-extractor';
|
|
6
|
+
import { ObservationEntityAction, } from '@rosen-bridge/abstract-observation-extractor';
|
|
7
|
+
export class CardanoBlockFrostObservationExtractor extends AbstractExtractor {
|
|
8
|
+
logger;
|
|
9
|
+
actions;
|
|
10
|
+
extractor;
|
|
11
|
+
static FROM_CHAIN = 'cardano';
|
|
12
|
+
constructor(dataSource, tokens, address, logger) {
|
|
13
|
+
super();
|
|
14
|
+
this.logger = logger ? logger : new DummyLogger();
|
|
15
|
+
this.actions = new ObservationEntityAction(dataSource, this.logger);
|
|
16
|
+
this.extractor = new CardanoBlockFrostRosenExtractor(address, tokens, this.logger);
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* get Id for current extractor
|
|
20
|
+
*/
|
|
21
|
+
getId = () => 'cardano-blockfrost-extractor';
|
|
22
|
+
/**
|
|
23
|
+
* gets block id and transactions corresponding to the block and saves if they are valid rosen
|
|
24
|
+
* transactions and in case of success return true and in case of failure returns false
|
|
25
|
+
* @param block
|
|
26
|
+
* @param txs
|
|
27
|
+
*/
|
|
28
|
+
processTransactions = (txs, block) => {
|
|
29
|
+
return new Promise((resolve, reject) => {
|
|
30
|
+
try {
|
|
31
|
+
const observations = [];
|
|
32
|
+
txs.forEach((transaction) => {
|
|
33
|
+
const data = this.extractor.get(transaction);
|
|
34
|
+
if (data) {
|
|
35
|
+
const requestId = Buffer.from(blake2b(transaction.utxos.hash, undefined, 32)).toString('hex');
|
|
36
|
+
observations.push({
|
|
37
|
+
fromChain: CardanoBlockFrostObservationExtractor.FROM_CHAIN,
|
|
38
|
+
toChain: data.toChain,
|
|
39
|
+
amount: data.amount,
|
|
40
|
+
sourceChainTokenId: data.sourceChainTokenId,
|
|
41
|
+
targetChainTokenId: data.targetChainTokenId,
|
|
42
|
+
sourceTxId: data.sourceTxId,
|
|
43
|
+
bridgeFee: data.bridgeFee,
|
|
44
|
+
networkFee: data.networkFee,
|
|
45
|
+
sourceBlockId: block.hash,
|
|
46
|
+
requestId: requestId,
|
|
47
|
+
toAddress: data.toAddress,
|
|
48
|
+
fromAddress: data.fromAddress,
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
this.actions
|
|
53
|
+
.storeObservations(observations, block, this.getId())
|
|
54
|
+
.then((status) => {
|
|
55
|
+
resolve(status);
|
|
56
|
+
})
|
|
57
|
+
.catch((e) => {
|
|
58
|
+
this.logger.error(`An error occurred during store observations: ${e}`);
|
|
59
|
+
reject(e);
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
catch (e) {
|
|
63
|
+
reject(e);
|
|
64
|
+
}
|
|
65
|
+
});
|
|
66
|
+
};
|
|
67
|
+
/**
|
|
68
|
+
* fork one block and remove all stored information for this block
|
|
69
|
+
* @param hash: block hash
|
|
70
|
+
*/
|
|
71
|
+
forkBlock = async (hash) => {
|
|
72
|
+
await this.actions.deleteBlockObservation(hash, this.getId());
|
|
73
|
+
};
|
|
74
|
+
/**
|
|
75
|
+
* Extractor box initialization
|
|
76
|
+
* No action needed in cardano extractors
|
|
77
|
+
*/
|
|
78
|
+
initializeBoxes = async () => {
|
|
79
|
+
return;
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"blockfrost.js","sourceRoot":"","sources":["../../lib/extractor/blockfrost.ts"],"names":[],"mappings":"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","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 { CardanoBlockFrostRosenExtractor } from '@rosen-bridge/rosen-extractor';\nimport { components } from '@blockfrost/openapi';\nimport { Block } from '@rosen-bridge/scanner-interfaces';\nimport { AbstractExtractor } from '@rosen-bridge/abstract-extractor';\nimport {\n  ObservationEntityAction,\n  ExtractedObservation,\n} from '@rosen-bridge/abstract-observation-extractor';\n\ninterface BlockFrostTransaction {\n  utxos: components['schemas']['tx_content_utxo'];\n  metadata: components['schemas']['tx_content_metadata'];\n}\n\nexport class CardanoBlockFrostObservationExtractor extends AbstractExtractor<BlockFrostTransaction> {\n  readonly logger: AbstractLogger;\n  private readonly actions: ObservationEntityAction;\n  private readonly extractor: CardanoBlockFrostRosenExtractor;\n  static readonly FROM_CHAIN: string = 'cardano';\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 CardanoBlockFrostRosenExtractor(\n      address,\n      tokens,\n      this.logger\n    );\n  }\n\n  /**\n   * get Id for current extractor\n   */\n  getId = () => 'cardano-blockfrost-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 block\n   * @param txs\n   */\n  processTransactions = (\n    txs: Array<BlockFrostTransaction>,\n    block: Block\n  ): Promise<boolean> => {\n    return new Promise((resolve, reject) => {\n      try {\n        const observations: Array<ExtractedObservation> = [];\n        txs.forEach((transaction) => {\n          const data = this.extractor.get(transaction);\n          if (data) {\n            const requestId = Buffer.from(\n              blake2b(transaction.utxos.hash, undefined, 32)\n            ).toString('hex');\n            observations.push({\n              fromChain: CardanoBlockFrostObservationExtractor.FROM_CHAIN,\n              toChain: data.toChain,\n              amount: data.amount,\n              sourceChainTokenId: data.sourceChainTokenId,\n              targetChainTokenId: data.targetChainTokenId,\n              sourceTxId: data.sourceTxId,\n              bridgeFee: data.bridgeFee,\n              networkFee: data.networkFee,\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 occurred during store observations: ${e}`\n            );\n            reject(e);\n          });\n      } catch (e) {\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"]}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { DataSource } from '@rosen-bridge/extended-typeorm';
|
|
2
|
+
import { AbstractLogger } from '@rosen-bridge/abstract-logger';
|
|
3
|
+
import { TokenMap } from '@rosen-bridge/tokens';
|
|
4
|
+
import { Block } from '@rosen-bridge/scanner-interfaces';
|
|
5
|
+
import { AbstractExtractor } from '@rosen-bridge/abstract-extractor';
|
|
6
|
+
import { KoiosTransaction } from '../interfaces/koiosTransaction';
|
|
7
|
+
export declare class CardanoKoiosObservationExtractor extends AbstractExtractor<KoiosTransaction> {
|
|
8
|
+
readonly logger: AbstractLogger;
|
|
9
|
+
private readonly actions;
|
|
10
|
+
private readonly extractor;
|
|
11
|
+
static readonly FROM_CHAIN: string;
|
|
12
|
+
constructor(dataSource: DataSource, tokens: TokenMap, address: string, logger?: AbstractLogger);
|
|
13
|
+
/**
|
|
14
|
+
* get Id for current extractor
|
|
15
|
+
*/
|
|
16
|
+
getId: () => string;
|
|
17
|
+
/**
|
|
18
|
+
* gets block id and transactions corresponding to the block and saves if they are valid rosen
|
|
19
|
+
* transactions and in case of success return true and in case of failure returns false
|
|
20
|
+
* @param block
|
|
21
|
+
* @param txs
|
|
22
|
+
*/
|
|
23
|
+
processTransactions: (txs: Array<KoiosTransaction>, block: Block) => Promise<boolean>;
|
|
24
|
+
/**
|
|
25
|
+
* fork one block and remove all stored information for this block
|
|
26
|
+
* @param hash: block hash
|
|
27
|
+
*/
|
|
28
|
+
forkBlock: (hash: string) => Promise<void>;
|
|
29
|
+
/**
|
|
30
|
+
* Extractor box initialization
|
|
31
|
+
* No action needed in cardano extractors
|
|
32
|
+
*/
|
|
33
|
+
initializeBoxes: () => Promise<void>;
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=koios.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"koios.d.ts","sourceRoot":"","sources":["../../lib/extractor/koios.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,MAAM,kCAAkC,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AAKrE,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AAElE,qBAAa,gCAAiC,SAAQ,iBAAiB,CAAC,gBAAgB,CAAC;IACvF,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC;IAChC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAA0B;IAClD,OAAO,CAAC,QAAQ,CAAC,SAAS,CAA6B;IACvD,MAAM,CAAC,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAa;gBAG7C,UAAU,EAAE,UAAU,EACtB,MAAM,EAAE,QAAQ,EAChB,OAAO,EAAE,MAAM,EACf,MAAM,CAAC,EAAE,cAAc;IAYzB;;OAEG;IACH,KAAK,eAAmC;IAExC;;;;;OAKG;IACH,mBAAmB,GACjB,KAAK,KAAK,CAAC,gBAAgB,CAAC,EAC5B,OAAO,KAAK,KACX,OAAO,CAAC,OAAO,CAAC,CAyCjB;IAEF;;;OAGG;IACH,SAAS,GAAU,MAAM,MAAM,KAAG,OAAO,CAAC,IAAI,CAAC,CAE7C;IAEF;;;OAGG;IACH,eAAe,sBAEb;CACH"}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { Buffer } from 'buffer';
|
|
2
|
+
import { blake2b } from 'blakejs';
|
|
3
|
+
import { DummyLogger } from '@rosen-bridge/abstract-logger';
|
|
4
|
+
import { CardanoKoiosRosenExtractor } from '@rosen-bridge/rosen-extractor';
|
|
5
|
+
import { AbstractExtractor } from '@rosen-bridge/abstract-extractor';
|
|
6
|
+
import { ObservationEntityAction, } from '@rosen-bridge/abstract-observation-extractor';
|
|
7
|
+
export class CardanoKoiosObservationExtractor extends AbstractExtractor {
|
|
8
|
+
logger;
|
|
9
|
+
actions;
|
|
10
|
+
extractor;
|
|
11
|
+
static FROM_CHAIN = 'cardano';
|
|
12
|
+
constructor(dataSource, tokens, address, logger) {
|
|
13
|
+
super();
|
|
14
|
+
this.logger = logger ? logger : new DummyLogger();
|
|
15
|
+
this.actions = new ObservationEntityAction(dataSource, this.logger);
|
|
16
|
+
this.extractor = new CardanoKoiosRosenExtractor(address, tokens, this.logger);
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* get Id for current extractor
|
|
20
|
+
*/
|
|
21
|
+
getId = () => 'cardano-koios-extractor';
|
|
22
|
+
/**
|
|
23
|
+
* gets block id and transactions corresponding to the block and saves if they are valid rosen
|
|
24
|
+
* transactions and in case of success return true and in case of failure returns false
|
|
25
|
+
* @param block
|
|
26
|
+
* @param txs
|
|
27
|
+
*/
|
|
28
|
+
processTransactions = (txs, block) => {
|
|
29
|
+
return new Promise((resolve, reject) => {
|
|
30
|
+
try {
|
|
31
|
+
const observations = [];
|
|
32
|
+
txs.forEach((transaction) => {
|
|
33
|
+
const data = this.extractor.get(transaction);
|
|
34
|
+
if (data) {
|
|
35
|
+
const requestId = Buffer.from(blake2b(transaction.tx_hash, undefined, 32)).toString('hex');
|
|
36
|
+
observations.push({
|
|
37
|
+
fromChain: CardanoKoiosObservationExtractor.FROM_CHAIN,
|
|
38
|
+
toChain: data.toChain,
|
|
39
|
+
amount: data.amount,
|
|
40
|
+
sourceChainTokenId: data.sourceChainTokenId,
|
|
41
|
+
targetChainTokenId: data.targetChainTokenId,
|
|
42
|
+
sourceTxId: data.sourceTxId,
|
|
43
|
+
bridgeFee: data.bridgeFee,
|
|
44
|
+
networkFee: data.networkFee,
|
|
45
|
+
sourceBlockId: block.hash,
|
|
46
|
+
requestId: requestId,
|
|
47
|
+
toAddress: data.toAddress,
|
|
48
|
+
fromAddress: data.fromAddress,
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
this.actions
|
|
53
|
+
.storeObservations(observations, block, this.getId())
|
|
54
|
+
.then((status) => {
|
|
55
|
+
resolve(status);
|
|
56
|
+
})
|
|
57
|
+
.catch((e) => {
|
|
58
|
+
this.logger.error(`An error occurred during store observations: ${e}`);
|
|
59
|
+
reject(e);
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
catch (e) {
|
|
63
|
+
reject(e);
|
|
64
|
+
}
|
|
65
|
+
});
|
|
66
|
+
};
|
|
67
|
+
/**
|
|
68
|
+
* fork one block and remove all stored information for this block
|
|
69
|
+
* @param hash: block hash
|
|
70
|
+
*/
|
|
71
|
+
forkBlock = async (hash) => {
|
|
72
|
+
await this.actions.deleteBlockObservation(hash, this.getId());
|
|
73
|
+
};
|
|
74
|
+
/**
|
|
75
|
+
* Extractor box initialization
|
|
76
|
+
* No action needed in cardano extractors
|
|
77
|
+
*/
|
|
78
|
+
initializeBoxes = async () => {
|
|
79
|
+
return;
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"koios.js","sourceRoot":"","sources":["../../lib/extractor/koios.ts"],"names":[],"mappings":"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","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 { CardanoKoiosRosenExtractor } from '@rosen-bridge/rosen-extractor';\nimport { Block } from '@rosen-bridge/scanner-interfaces';\nimport { AbstractExtractor } from '@rosen-bridge/abstract-extractor';\nimport {\n  ExtractedObservation,\n  ObservationEntityAction,\n} from '@rosen-bridge/abstract-observation-extractor';\nimport { KoiosTransaction } from '../interfaces/koiosTransaction';\n\nexport class CardanoKoiosObservationExtractor extends AbstractExtractor<KoiosTransaction> {\n  readonly logger: AbstractLogger;\n  private readonly actions: ObservationEntityAction;\n  private readonly extractor: CardanoKoiosRosenExtractor;\n  static readonly FROM_CHAIN: string = 'cardano';\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 CardanoKoiosRosenExtractor(\n      address,\n      tokens,\n      this.logger\n    );\n  }\n\n  /**\n   * get Id for current extractor\n   */\n  getId = () => 'cardano-koios-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 block\n   * @param txs\n   */\n  processTransactions = (\n    txs: Array<KoiosTransaction>,\n    block: Block\n  ): Promise<boolean> => {\n    return new Promise((resolve, reject) => {\n      try {\n        const observations: Array<ExtractedObservation> = [];\n        txs.forEach((transaction) => {\n          const data = this.extractor.get(transaction);\n          if (data) {\n            const requestId = Buffer.from(\n              blake2b(transaction.tx_hash, undefined, 32)\n            ).toString('hex');\n            observations.push({\n              fromChain: CardanoKoiosObservationExtractor.FROM_CHAIN,\n              toChain: data.toChain,\n              amount: data.amount,\n              sourceChainTokenId: data.sourceChainTokenId,\n              targetChainTokenId: data.targetChainTokenId,\n              sourceTxId: data.sourceTxId,\n              bridgeFee: data.bridgeFee,\n              networkFee: data.networkFee,\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 occurred during store observations: ${e}`\n            );\n            reject(e);\n          });\n      } catch (e) {\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"]}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { AbstractLogger } from '@rosen-bridge/abstract-logger';
|
|
2
|
+
import { Transaction } from '@cardano-ogmios/schema';
|
|
3
|
+
import { DataSource } from '@rosen-bridge/extended-typeorm';
|
|
4
|
+
import { TokenMap } from '@rosen-bridge/tokens';
|
|
5
|
+
import { Block } from '@rosen-bridge/scanner-interfaces';
|
|
6
|
+
import { AbstractExtractor } from '@rosen-bridge/abstract-extractor';
|
|
7
|
+
export declare class CardanoOgmiosObservationExtractor extends AbstractExtractor<Transaction> {
|
|
8
|
+
readonly logger: AbstractLogger;
|
|
9
|
+
private readonly actions;
|
|
10
|
+
private readonly extractor;
|
|
11
|
+
static readonly FROM_CHAIN: string;
|
|
12
|
+
constructor(dataSource: DataSource, tokens: TokenMap, address: string, logger?: AbstractLogger);
|
|
13
|
+
/**
|
|
14
|
+
* get Id for current extractor
|
|
15
|
+
*/
|
|
16
|
+
getId: () => string;
|
|
17
|
+
/**
|
|
18
|
+
* gets block id and transactions corresponding to the block and saves if they are valid rosen
|
|
19
|
+
* transactions and in case of success return true and in case of failure returns false
|
|
20
|
+
* @param block
|
|
21
|
+
* @param txs
|
|
22
|
+
*/
|
|
23
|
+
processTransactions: (txs: Array<Transaction>, block: Block) => Promise<boolean>;
|
|
24
|
+
/**
|
|
25
|
+
* fork one block and remove all stored information for this block
|
|
26
|
+
* @param hash: block hash
|
|
27
|
+
*/
|
|
28
|
+
forkBlock: (hash: string) => Promise<void>;
|
|
29
|
+
/**
|
|
30
|
+
* Extractor box initialization
|
|
31
|
+
* No action needed in cardano extractors
|
|
32
|
+
*/
|
|
33
|
+
initializeBoxes: () => Promise<void>;
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=ogmios.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ogmios.d.ts","sourceRoot":"","sources":["../../lib/extractor/ogmios.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAe,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AACrD,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAC5D,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAIhD,OAAO,EAAE,KAAK,EAAE,MAAM,kCAAkC,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AAMrE,qBAAa,iCAAkC,SAAQ,iBAAiB,CAAC,WAAW,CAAC;IACnF,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC;IAChC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAA0B;IAClD,OAAO,CAAC,QAAQ,CAAC,SAAS,CAA8B;IACxD,MAAM,CAAC,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAa;gBAG7C,UAAU,EAAE,UAAU,EACtB,MAAM,EAAE,QAAQ,EAChB,OAAO,EAAE,MAAM,EACf,MAAM,CAAC,EAAE,cAAc;IAYzB;;OAEG;IACH,KAAK,eAAoC;IAEzC;;;;;OAKG;IACH,mBAAmB,GACjB,KAAK,KAAK,CAAC,WAAW,CAAC,EACvB,OAAO,KAAK,KACX,OAAO,CAAC,OAAO,CAAC,CAyCjB;IAEF;;;OAGG;IACH,SAAS,GAAU,MAAM,MAAM,KAAG,OAAO,CAAC,IAAI,CAAC,CAE7C;IAEF;;;OAGG;IACH,eAAe,sBAEb;CACH"}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { DummyLogger } from '@rosen-bridge/abstract-logger';
|
|
2
|
+
import { Buffer } from 'buffer';
|
|
3
|
+
import { blake2b } from 'blakejs';
|
|
4
|
+
import { CardanoOgmiosRosenExtractor } from '@rosen-bridge/rosen-extractor';
|
|
5
|
+
import { AbstractExtractor } from '@rosen-bridge/abstract-extractor';
|
|
6
|
+
import { ObservationEntityAction, } from '@rosen-bridge/abstract-observation-extractor';
|
|
7
|
+
export class CardanoOgmiosObservationExtractor extends AbstractExtractor {
|
|
8
|
+
logger;
|
|
9
|
+
actions;
|
|
10
|
+
extractor;
|
|
11
|
+
static FROM_CHAIN = 'cardano';
|
|
12
|
+
constructor(dataSource, tokens, address, logger) {
|
|
13
|
+
super();
|
|
14
|
+
this.logger = logger ? logger : new DummyLogger();
|
|
15
|
+
this.actions = new ObservationEntityAction(dataSource, this.logger);
|
|
16
|
+
this.extractor = new CardanoOgmiosRosenExtractor(address, tokens, this.logger);
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* get Id for current extractor
|
|
20
|
+
*/
|
|
21
|
+
getId = () => 'cardano-ogmios-extractor';
|
|
22
|
+
/**
|
|
23
|
+
* gets block id and transactions corresponding to the block and saves if they are valid rosen
|
|
24
|
+
* transactions and in case of success return true and in case of failure returns false
|
|
25
|
+
* @param block
|
|
26
|
+
* @param txs
|
|
27
|
+
*/
|
|
28
|
+
processTransactions = (txs, block) => {
|
|
29
|
+
return new Promise((resolve, reject) => {
|
|
30
|
+
try {
|
|
31
|
+
const observations = [];
|
|
32
|
+
for (const transaction of txs) {
|
|
33
|
+
const data = this.extractor.get(transaction);
|
|
34
|
+
if (data) {
|
|
35
|
+
const requestId = Buffer.from(blake2b(transaction.id, undefined, 32)).toString('hex');
|
|
36
|
+
observations.push({
|
|
37
|
+
fromChain: CardanoOgmiosObservationExtractor.FROM_CHAIN,
|
|
38
|
+
toChain: data.toChain,
|
|
39
|
+
amount: data.amount,
|
|
40
|
+
sourceChainTokenId: data.sourceChainTokenId,
|
|
41
|
+
targetChainTokenId: data.targetChainTokenId,
|
|
42
|
+
sourceTxId: data.sourceTxId,
|
|
43
|
+
bridgeFee: data.bridgeFee,
|
|
44
|
+
networkFee: data.networkFee,
|
|
45
|
+
sourceBlockId: block.hash,
|
|
46
|
+
requestId: requestId,
|
|
47
|
+
toAddress: data.toAddress,
|
|
48
|
+
fromAddress: data.fromAddress,
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
this.actions
|
|
53
|
+
.storeObservations(observations, block, this.getId())
|
|
54
|
+
.then((status) => {
|
|
55
|
+
resolve(status);
|
|
56
|
+
})
|
|
57
|
+
.catch((e) => {
|
|
58
|
+
this.logger.error(`An error occurred during store observations: ${e}`);
|
|
59
|
+
reject(e);
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
catch (e) {
|
|
63
|
+
reject(e);
|
|
64
|
+
}
|
|
65
|
+
});
|
|
66
|
+
};
|
|
67
|
+
/**
|
|
68
|
+
* fork one block and remove all stored information for this block
|
|
69
|
+
* @param hash: block hash
|
|
70
|
+
*/
|
|
71
|
+
forkBlock = async (hash) => {
|
|
72
|
+
await this.actions.deleteBlockObservation(hash, this.getId());
|
|
73
|
+
};
|
|
74
|
+
/**
|
|
75
|
+
* Extractor box initialization
|
|
76
|
+
* No action needed in cardano extractors
|
|
77
|
+
*/
|
|
78
|
+
initializeBoxes = async () => {
|
|
79
|
+
return;
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ogmios.js","sourceRoot":"","sources":["../../lib/extractor/ogmios.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAI5E,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAChC,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,2BAA2B,EAAE,MAAM,+BAA+B,CAAC;AAE5E,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,OAAO,EAEL,uBAAuB,GACxB,MAAM,8CAA8C,CAAC;AAEtD,MAAM,OAAO,iCAAkC,SAAQ,iBAA8B;IAC1E,MAAM,CAAiB;IACf,OAAO,CAA0B;IACjC,SAAS,CAA8B;IACxD,MAAM,CAAU,UAAU,GAAW,SAAS,CAAC;IAE/C,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,2BAA2B,CAC9C,OAAO,EACP,MAAM,EACN,IAAI,CAAC,MAAM,CACZ,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,KAAK,GAAG,GAAG,EAAE,CAAC,0BAA0B,CAAC;IAEzC;;;;;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,KAAK,MAAM,WAAW,IAAI,GAAG,EAAE,CAAC;oBAC9B,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,iCAAiC,CAAC,UAAU;4BACvD,OAAO,EAAE,IAAI,CAAC,OAAO;4BACrB,MAAM,EAAE,IAAI,CAAC,MAAM;4BACnB,kBAAkB,EAAE,IAAI,CAAC,kBAAkB;4BAC3C,kBAAkB,EAAE,IAAI,CAAC,kBAAkB;4BAC3C,UAAU,EAAE,IAAI,CAAC,UAAU;4BAC3B,SAAS,EAAE,IAAI,CAAC,SAAS;4BACzB,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;gBACD,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,gDAAgD,CAAC,EAAE,CACpD,CAAC;oBACF,MAAM,CAAC,CAAC,CAAC,CAAC;gBACZ,CAAC,CAAC,CAAC;YACP,CAAC;YAAC,OAAO,CAAC,EAAE,CAAC;gBACX,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 { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport { Transaction } from '@cardano-ogmios/schema';\nimport { DataSource } from '@rosen-bridge/extended-typeorm';\nimport { TokenMap } from '@rosen-bridge/tokens';\nimport { Buffer } from 'buffer';\nimport { blake2b } from 'blakejs';\nimport { CardanoOgmiosRosenExtractor } from '@rosen-bridge/rosen-extractor';\nimport { Block } from '@rosen-bridge/scanner-interfaces';\nimport { AbstractExtractor } from '@rosen-bridge/abstract-extractor';\nimport {\n  ExtractedObservation,\n  ObservationEntityAction,\n} from '@rosen-bridge/abstract-observation-extractor';\n\nexport class CardanoOgmiosObservationExtractor extends AbstractExtractor<Transaction> {\n  readonly logger: AbstractLogger;\n  private readonly actions: ObservationEntityAction;\n  private readonly extractor: CardanoOgmiosRosenExtractor;\n  static readonly FROM_CHAIN: string = 'cardano';\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 CardanoOgmiosRosenExtractor(\n      address,\n      tokens,\n      this.logger\n    );\n  }\n\n  /**\n   * get Id for current extractor\n   */\n  getId = () => 'cardano-ogmios-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 block\n   * @param txs\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        for (const transaction of txs) {\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: CardanoOgmiosObservationExtractor.FROM_CHAIN,\n              toChain: data.toChain,\n              amount: data.amount,\n              sourceChainTokenId: data.sourceChainTokenId,\n              targetChainTokenId: data.targetChainTokenId,\n              sourceTxId: data.sourceTxId,\n              bridgeFee: data.bridgeFee,\n              networkFee: data.networkFee,\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 occurred during store observations: ${e}`\n            );\n            reject(e);\n          });\n      } catch (e) {\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"]}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../lib/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAC;AACvC,cAAc,mBAAmB,CAAC;AAClC,cAAc,oBAAoB,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export * from './extractor/blockfrost';
|
|
2
|
+
export * from './extractor/koios';
|
|
3
|
+
export * from './extractor/ogmios';
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9saWIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsb0JBQW9CLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2V4dHJhY3Rvci9ibG9ja2Zyb3N0JztcbmV4cG9ydCAqIGZyb20gJy4vZXh0cmFjdG9yL2tvaW9zJztcbmV4cG9ydCAqIGZyb20gJy4vZXh0cmFjdG9yL29nbWlvcyc7XG4iXX0=
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { TransactionJSON } from '@emurgo/cardano-serialization-lib-nodejs';
|
|
2
|
+
interface KoiosCborTx {
|
|
3
|
+
tx_hash: string;
|
|
4
|
+
block_hash: string;
|
|
5
|
+
block_height: number;
|
|
6
|
+
epoch_no: number;
|
|
7
|
+
absolute_slot: number;
|
|
8
|
+
tx_timestamp: number;
|
|
9
|
+
cbor: string;
|
|
10
|
+
}
|
|
11
|
+
type KoiosTransaction = KoiosCborTx & TransactionJSON;
|
|
12
|
+
export { KoiosTransaction };
|
|
13
|
+
//# sourceMappingURL=koiosTransaction.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"koiosTransaction.d.ts","sourceRoot":"","sources":["../../lib/interfaces/koiosTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,0CAA0C,CAAC;AAE3E,UAAU,WAAW;IACnB,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,QAAQ,EAAE,MAAM,CAAC;IACjB,aAAa,EAAE,MAAM,CAAC;IACtB,YAAY,EAAE,MAAM,CAAC;IACrB,IAAI,EAAE,MAAM,CAAC;CACd;AAED,KAAK,gBAAgB,GAAG,WAAW,GAAG,eAAe,CAAC;AAEtD,OAAO,EAAE,gBAAgB,EAAE,CAAC"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia29pb3NUcmFuc2FjdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9pbnRlcmZhY2VzL2tvaW9zVHJhbnNhY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRyYW5zYWN0aW9uSlNPTiB9IGZyb20gJ0BlbXVyZ28vY2FyZGFuby1zZXJpYWxpemF0aW9uLWxpYi1ub2RlanMnO1xuXG5pbnRlcmZhY2UgS29pb3NDYm9yVHgge1xuICB0eF9oYXNoOiBzdHJpbmc7XG4gIGJsb2NrX2hhc2g6IHN0cmluZztcbiAgYmxvY2tfaGVpZ2h0OiBudW1iZXI7XG4gIGVwb2NoX25vOiBudW1iZXI7XG4gIGFic29sdXRlX3Nsb3Q6IG51bWJlcjtcbiAgdHhfdGltZXN0YW1wOiBudW1iZXI7XG4gIGNib3I6IHN0cmluZztcbn1cblxudHlwZSBLb2lvc1RyYW5zYWN0aW9uID0gS29pb3NDYm9yVHggJiBUcmFuc2FjdGlvbkpTT047XG5cbmV4cG9ydCB7IEtvaW9zVHJhbnNhY3Rpb24gfTtcbiJdfQ==
|
package/package.json
ADDED
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@rosen-bridge/cardano-observation-extractor",
|
|
3
|
+
"version": "0.1.0-52fc0239",
|
|
4
|
+
"description": "Event observation data extractor for Cardano chain",
|
|
5
|
+
"repository": {
|
|
6
|
+
"type": "git",
|
|
7
|
+
"url": "git+https://github.com/rosen-bridge/scanner.git"
|
|
8
|
+
},
|
|
9
|
+
"license": "MIT",
|
|
10
|
+
"author": "Rosen Team",
|
|
11
|
+
"type": "module",
|
|
12
|
+
"main": "dist/index.js",
|
|
13
|
+
"types": "dist/index.d.ts",
|
|
14
|
+
"files": [
|
|
15
|
+
"dist",
|
|
16
|
+
"CHANGELOG.md"
|
|
17
|
+
],
|
|
18
|
+
"scripts": {
|
|
19
|
+
"build": "tsc --build tsconfig.build.json",
|
|
20
|
+
"coverage": "npm run test -- --coverage",
|
|
21
|
+
"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",
|
|
24
|
+
"test": "NODE_OPTIONS='--import tsx' vitest",
|
|
25
|
+
"type-check": "tsc --noEmit"
|
|
26
|
+
},
|
|
27
|
+
"devDependencies": {
|
|
28
|
+
"@types/node": "^22.18.0",
|
|
29
|
+
"@vitest/coverage-istanbul": "^3.1.4",
|
|
30
|
+
"@rosen-bridge/abstract-scanner": "^0.1.0-52fc0239",
|
|
31
|
+
"tsx": "^4.19.4",
|
|
32
|
+
"typescript": "^5.3.3",
|
|
33
|
+
"vitest": "^3.1.4"
|
|
34
|
+
},
|
|
35
|
+
"dependencies": {
|
|
36
|
+
"@blockfrost/openapi": "0.1.78",
|
|
37
|
+
"@cardano-ogmios/schema": "^6.6.1",
|
|
38
|
+
"@emurgo/cardano-serialization-lib-nodejs": "^13.2.1",
|
|
39
|
+
"@rosen-bridge/abstract-observation-extractor": "^0.1.0-52fc0239",
|
|
40
|
+
"@rosen-bridge/abstract-extractor": "^2.0.3-52fc0239",
|
|
41
|
+
"@rosen-bridge/abstract-logger": "^2.0.1",
|
|
42
|
+
"@rosen-bridge/rosen-extractor": "^8.0.1",
|
|
43
|
+
"@rosen-bridge/scanner-interfaces": "^0.1.1-52fc0239",
|
|
44
|
+
"@rosen-bridge/tokens": "^3.1.1",
|
|
45
|
+
"blakejs": "^1.2.1",
|
|
46
|
+
"@rosen-bridge/extended-typeorm": "^0.2.1"
|
|
47
|
+
},
|
|
48
|
+
"engines": {
|
|
49
|
+
"node": ">=22.18.0"
|
|
50
|
+
}
|
|
51
|
+
}
|