@rosen-bridge/rosen-extractor 5.0.0 → 5.0.1

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.
@@ -2,17 +2,13 @@ import { RosenTokens, TokenMap } from '@rosen-bridge/tokens';
2
2
  import { RosenData } from './types';
3
3
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
4
4
  export default abstract class AbstractRosenDataExtractor<TransactionType> {
5
- protected readonly logger: AbstractLogger;
6
- protected readonly tokens: TokenMap;
7
- protected readonly lockAddress: string;
8
- constructor(
9
- lockAddress: string,
10
- tokens: RosenTokens,
11
- logger?: AbstractLogger
12
- );
13
- /**
14
- * extracts RosenData from given lock transaction
15
- */
16
- abstract get: (transaction: TransactionType) => RosenData | undefined;
5
+ protected readonly logger: AbstractLogger;
6
+ protected readonly tokens: TokenMap;
7
+ protected readonly lockAddress: string;
8
+ constructor(lockAddress: string, tokens: RosenTokens, logger?: AbstractLogger);
9
+ /**
10
+ * extracts RosenData from given lock transaction
11
+ */
12
+ abstract get: (transaction: TransactionType) => RosenData | undefined;
17
13
  }
18
- //# sourceMappingURL=AbstractRosenDataExtractor.d.ts.map
14
+ //# sourceMappingURL=AbstractRosenDataExtractor.d.ts.map
@@ -1,18 +1,18 @@
1
1
  interface RosenData {
2
- toChain: string;
3
- toAddress: string;
4
- bridgeFee: string;
5
- networkFee: string;
6
- fromAddress: string;
7
- sourceChainTokenId: string;
8
- amount: string;
9
- targetChainTokenId: string;
10
- sourceTxId: string;
2
+ toChain: string;
3
+ toAddress: string;
4
+ bridgeFee: string;
5
+ networkFee: string;
6
+ fromAddress: string;
7
+ sourceChainTokenId: string;
8
+ amount: string;
9
+ targetChainTokenId: string;
10
+ sourceTxId: string;
11
11
  }
12
12
  interface TokenTransformation {
13
- from: string;
14
- to: string;
15
- amount: string;
13
+ from: string;
14
+ to: string;
15
+ amount: string;
16
16
  }
17
17
  export { RosenData, TokenTransformation };
18
- //# sourceMappingURL=types.d.ts.map
18
+ //# sourceMappingURL=types.d.ts.map
@@ -4,25 +4,18 @@ import { BitcoinEsploraTransaction, EsploraTxOutput } from './types';
4
4
  import { RosenTokens } from '@rosen-bridge/tokens';
5
5
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
6
6
  export declare class BitcoinEsploraRosenExtractor extends AbstractRosenDataExtractor<BitcoinEsploraTransaction> {
7
- protected lockScriptPubKey: string;
8
- constructor(
9
- lockAddress: string,
10
- tokens: RosenTokens,
11
- logger?: AbstractLogger
12
- );
13
- /**
14
- * extracts RosenData from given lock transaction in Esplora format
15
- * @param transaction the lock transaction in Esplora format
16
- */
17
- get: (transaction: BitcoinEsploraTransaction) => RosenData | undefined;
18
- /**
19
- * extracts and builds token transformation from UTXO and tokenMap
20
- * @param box transaction output
21
- * @param toChain event target chain
22
- */
23
- getAssetTransformation: (
24
- box: EsploraTxOutput,
25
- toChain: string
26
- ) => TokenTransformation | undefined;
7
+ protected lockScriptPubKey: string;
8
+ constructor(lockAddress: string, tokens: RosenTokens, logger?: AbstractLogger);
9
+ /**
10
+ * extracts RosenData from given lock transaction in Esplora format
11
+ * @param transaction the lock transaction in Esplora format
12
+ */
13
+ get: (transaction: BitcoinEsploraTransaction) => RosenData | undefined;
14
+ /**
15
+ * extracts and builds token transformation from UTXO and tokenMap
16
+ * @param box transaction output
17
+ * @param toChain event target chain
18
+ */
19
+ getAssetTransformation: (box: EsploraTxOutput, toChain: string) => TokenTransformation | undefined;
27
20
  }
28
- //# sourceMappingURL=BitcoinEsploraRosenExtractor.d.ts.map
21
+ //# sourceMappingURL=BitcoinEsploraRosenExtractor.d.ts.map
@@ -4,25 +4,18 @@ import { BitcoinTxOutput } from './types';
4
4
  import { RosenTokens } from '@rosen-bridge/tokens';
5
5
  import { AbstractLogger } from '@rosen-bridge/abstract-logger';
6
6
  export declare class BitcoinRosenExtractor extends AbstractRosenDataExtractor<string> {
7
- protected lockScriptPubKey: string;
8
- constructor(
9
- lockAddress: string,
10
- tokens: RosenTokens,
11
- logger?: AbstractLogger
12
- );
13
- /**
14
- * extracts RosenData from given lock transaction in BitcoinTx format
15
- * @param serializedTransaction stringified transaction in BitcoinTx format
16
- */
17
- get: (serializedTransaction: string) => RosenData | undefined;
18
- /**
19
- * extracts and builds token transformation from UTXO and tokenMap
20
- * @param box transaction output
21
- * @param toChain event target chain
22
- */
23
- getAssetTransformation: (
24
- box: BitcoinTxOutput,
25
- toChain: string
26
- ) => TokenTransformation | undefined;
7
+ protected lockScriptPubKey: string;
8
+ constructor(lockAddress: string, tokens: RosenTokens, logger?: AbstractLogger);
9
+ /**
10
+ * extracts RosenData from given lock transaction in BitcoinTx format
11
+ * @param serializedTransaction stringified transaction in BitcoinTx format
12
+ */
13
+ get: (serializedTransaction: string) => RosenData | undefined;
14
+ /**
15
+ * extracts and builds token transformation from UTXO and tokenMap
16
+ * @param box transaction output
17
+ * @param toChain event target chain
18
+ */
19
+ getAssetTransformation: (box: BitcoinTxOutput, toChain: string) => TokenTransformation | undefined;
27
20
  }
28
- //# sourceMappingURL=BitcoinRosenExtractor.d.ts.map
21
+ //# sourceMappingURL=BitcoinRosenExtractor.d.ts.map
@@ -89,7 +89,7 @@ export class BitcoinRpcRosenExtractor extends AbstractRosenDataExtractor {
89
89
  [this.tokens.getIdKey(BITCOIN_CHAIN)]: BITCOIN_NATIVE_TOKEN,
90
90
  });
91
91
  if (wrappedBtc.length > 0 && Object.hasOwn(wrappedBtc[0], toChain)) {
92
- const satoshiAmount = box.value;
92
+ const satoshiAmount = Math.floor(box.value * 100_000_000);
93
93
  return {
94
94
  from: BITCOIN_NATIVE_TOKEN,
95
95
  to: this.tokens.getID(wrappedBtc[0], toChain),
@@ -101,4 +101,4 @@ export class BitcoinRpcRosenExtractor extends AbstractRosenDataExtractor {
101
101
  }
102
102
  };
103
103
  }
104
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"BitcoinRpcRosenExtractor.js","sourceRoot":"","sources":["../../../../lib/getRosenData/bitcoin/BitcoinRpcRosenExtractor.ts"],"names":[],"mappings":"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","sourcesContent":["import { RosenData, TokenTransformation } from '../abstract/types';\nimport AbstractRosenDataExtractor from '../abstract/AbstractRosenDataExtractor';\nimport { BITCOIN_CHAIN, BITCOIN_NATIVE_TOKEN } from '../const';\nimport {\n  BitcoinRpcTransaction,\n  BitcoinRpcTxOutput,\n  OpReturnData,\n} from './types';\nimport { RosenTokens } from '@rosen-bridge/tokens';\nimport { AbstractLogger } from '@rosen-bridge/abstract-logger';\nimport { address } from 'bitcoinjs-lib';\nimport { parseRosenData } from './utils';\n\nexport class BitcoinRpcRosenExtractor extends AbstractRosenDataExtractor<BitcoinRpcTransaction> {\n  protected lockScriptPubKey: string;\n\n  constructor(\n    lockAddress: string,\n    tokens: RosenTokens,\n    logger?: AbstractLogger\n  ) {\n    super(lockAddress, tokens, logger);\n    this.lockScriptPubKey = address.toOutputScript(lockAddress).toString('hex');\n  }\n\n  /**\n   * extracts RosenData from given lock transaction in Rpc format\n   * @param transaction the lock transaction in Rpc format\n   */\n  get = (transaction: BitcoinRpcTransaction): RosenData | undefined => {\n    const baseError = `No rosen data found for tx [${transaction.txid}]`;\n    try {\n      const outputs = transaction.vout;\n      if (outputs.length < 2) {\n        this.logger.debug(baseError + `: Insufficient number of boxes`);\n        return undefined;\n      }\n\n      let validData = false; // an OP_RETURN box with valid data is found\n      let validLock = false; // a lock box is found with available asset transformation\n\n      // parse rosen data from OP_RETURN box\n      let opReturnData: OpReturnData | undefined;\n      for (let i = 0; i < outputs.length; i++) {\n        const output = outputs[i];\n        if (output.scriptPubKey.hex.slice(0, 2) !== '6a') continue; // not an OP_RETURN utxo\n\n        try {\n          opReturnData = parseRosenData(output.scriptPubKey.hex);\n          validData = true;\n          break;\n        } catch (e) {\n          this.logger.debug(\n            `Failed to extract data from OP_RETURN box [${transaction.txid}.${i}]: ${e}`\n          );\n        }\n      }\n      if (!validData || !opReturnData) {\n        this.logger.debug(\n          baseError + `: No OP_RETURN box with valid data is found`\n        );\n        return undefined;\n      }\n\n      // find target chain token id\n      let assetTransformation: TokenTransformation | undefined;\n      for (let i = 0; i < outputs.length; i++) {\n        const output = outputs[i];\n        if (output.scriptPubKey.hex !== this.lockScriptPubKey) continue; // utxo address is not lock address\n        assetTransformation = this.getAssetTransformation(\n          output,\n          opReturnData.toChain\n        );\n        if (assetTransformation) {\n          validLock = true;\n          break;\n        }\n      }\n      if (!validLock || !assetTransformation) {\n        this.logger.debug(\n          baseError + `: Failed to find rosen asset transformation`\n        );\n        return undefined;\n      }\n\n      const fromAddress = `box:${transaction.vin[0].txid}.${transaction.vin[0].vout}`;\n      return {\n        toChain: opReturnData.toChain,\n        toAddress: opReturnData.toAddress,\n        bridgeFee: opReturnData.bridgeFee,\n        networkFee: opReturnData.networkFee,\n        fromAddress: fromAddress,\n        sourceChainTokenId: assetTransformation.from,\n        amount: assetTransformation.amount,\n        targetChainTokenId: assetTransformation.to,\n        sourceTxId: transaction.txid,\n      };\n    } catch (e) {\n      this.logger.debug(\n        `An error occurred while getting Bitcoin rosen data from Rpc: ${e}`\n      );\n      if (e instanceof Error && e.stack) {\n        this.logger.debug(e.stack);\n      }\n    }\n    return undefined;\n  };\n\n  /**\n   * extracts and builds token transformation from UTXO and tokenMap\n   * @param box transaction output\n   * @param toChain event target chain\n   */\n  getAssetTransformation = (\n    box: BitcoinRpcTxOutput,\n    toChain: string\n  ): TokenTransformation | undefined => {\n    // try to build transformation using locked BTC\n    const wrappedBtc = this.tokens.search(BITCOIN_CHAIN, {\n      [this.tokens.getIdKey(BITCOIN_CHAIN)]: BITCOIN_NATIVE_TOKEN,\n    });\n    if (wrappedBtc.length > 0 && Object.hasOwn(wrappedBtc[0], toChain)) {\n      const satoshiAmount = box.value;\n      return {\n        from: BITCOIN_NATIVE_TOKEN,\n        to: this.tokens.getID(wrappedBtc[0], toChain),\n        amount: satoshiAmount.toString(),\n      };\n    } else {\n      return undefined;\n    }\n  };\n}\n"]}
104
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"BitcoinRpcRosenExtractor.js","sourceRoot":"","sources":["../../../../lib/getRosenData/bitcoin/BitcoinRpcRosenExtractor.ts"],"names":[],"mappings":"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","sourcesContent":["import { RosenData, TokenTransformation } from '../abstract/types';\nimport AbstractRosenDataExtractor from '../abstract/AbstractRosenDataExtractor';\nimport { BITCOIN_CHAIN, BITCOIN_NATIVE_TOKEN } from '../const';\nimport {\n  BitcoinRpcTransaction,\n  BitcoinRpcTxOutput,\n  OpReturnData,\n} from './types';\nimport { RosenTokens } from '@rosen-bridge/tokens';\nimport { AbstractLogger } from '@rosen-bridge/abstract-logger';\nimport { address } from 'bitcoinjs-lib';\nimport { parseRosenData } from './utils';\n\nexport class BitcoinRpcRosenExtractor extends AbstractRosenDataExtractor<BitcoinRpcTransaction> {\n  protected lockScriptPubKey: string;\n\n  constructor(\n    lockAddress: string,\n    tokens: RosenTokens,\n    logger?: AbstractLogger\n  ) {\n    super(lockAddress, tokens, logger);\n    this.lockScriptPubKey = address.toOutputScript(lockAddress).toString('hex');\n  }\n\n  /**\n   * extracts RosenData from given lock transaction in Rpc format\n   * @param transaction the lock transaction in Rpc format\n   */\n  get = (transaction: BitcoinRpcTransaction): RosenData | undefined => {\n    const baseError = `No rosen data found for tx [${transaction.txid}]`;\n    try {\n      const outputs = transaction.vout;\n      if (outputs.length < 2) {\n        this.logger.debug(baseError + `: Insufficient number of boxes`);\n        return undefined;\n      }\n\n      let validData = false; // an OP_RETURN box with valid data is found\n      let validLock = false; // a lock box is found with available asset transformation\n\n      // parse rosen data from OP_RETURN box\n      let opReturnData: OpReturnData | undefined;\n      for (let i = 0; i < outputs.length; i++) {\n        const output = outputs[i];\n        if (output.scriptPubKey.hex.slice(0, 2) !== '6a') continue; // not an OP_RETURN utxo\n\n        try {\n          opReturnData = parseRosenData(output.scriptPubKey.hex);\n          validData = true;\n          break;\n        } catch (e) {\n          this.logger.debug(\n            `Failed to extract data from OP_RETURN box [${transaction.txid}.${i}]: ${e}`\n          );\n        }\n      }\n      if (!validData || !opReturnData) {\n        this.logger.debug(\n          baseError + `: No OP_RETURN box with valid data is found`\n        );\n        return undefined;\n      }\n\n      // find target chain token id\n      let assetTransformation: TokenTransformation | undefined;\n      for (let i = 0; i < outputs.length; i++) {\n        const output = outputs[i];\n        if (output.scriptPubKey.hex !== this.lockScriptPubKey) continue; // utxo address is not lock address\n        assetTransformation = this.getAssetTransformation(\n          output,\n          opReturnData.toChain\n        );\n        if (assetTransformation) {\n          validLock = true;\n          break;\n        }\n      }\n      if (!validLock || !assetTransformation) {\n        this.logger.debug(\n          baseError + `: Failed to find rosen asset transformation`\n        );\n        return undefined;\n      }\n\n      const fromAddress = `box:${transaction.vin[0].txid}.${transaction.vin[0].vout}`;\n      return {\n        toChain: opReturnData.toChain,\n        toAddress: opReturnData.toAddress,\n        bridgeFee: opReturnData.bridgeFee,\n        networkFee: opReturnData.networkFee,\n        fromAddress: fromAddress,\n        sourceChainTokenId: assetTransformation.from,\n        amount: assetTransformation.amount,\n        targetChainTokenId: assetTransformation.to,\n        sourceTxId: transaction.txid,\n      };\n    } catch (e) {\n      this.logger.debug(\n        `An error occurred while getting Bitcoin rosen data from Rpc: ${e}`\n      );\n      if (e instanceof Error && e.stack) {\n        this.logger.debug(e.stack);\n      }\n    }\n    return undefined;\n  };\n\n  /**\n   * extracts and builds token transformation from UTXO and tokenMap\n   * @param box transaction output\n   * @param toChain event target chain\n   */\n  getAssetTransformation = (\n    box: BitcoinRpcTxOutput,\n    toChain: string\n  ): TokenTransformation | undefined => {\n    // try to build transformation using locked BTC\n    const wrappedBtc = this.tokens.search(BITCOIN_CHAIN, {\n      [this.tokens.getIdKey(BITCOIN_CHAIN)]: BITCOIN_NATIVE_TOKEN,\n    });\n    if (wrappedBtc.length > 0 && Object.hasOwn(wrappedBtc[0], toChain)) {\n      const satoshiAmount = Math.floor(box.value * 100_000_000);\n      return {\n        from: BITCOIN_NATIVE_TOKEN,\n        to: this.tokens.getID(wrappedBtc[0], toChain),\n        amount: satoshiAmount.toString(),\n      };\n    } else {\n      return undefined;\n    }\n  };\n}\n"]}
@@ -4,4 +4,4 @@ import { OpReturnData } from './types';
4
4
  * @param scriptPubKeyHex
5
5
  */
6
6
  export declare const parseRosenData: (scriptPubKeyHex: string) => OpReturnData;
7
- //# sourceMappingURL=utils.d.ts.map
7
+ //# sourceMappingURL=utils.d.ts.map
@@ -2,19 +2,16 @@ import { RosenData, TokenTransformation } from '../abstract/types';
2
2
  import AbstractRosenDataExtractor from '../abstract/AbstractRosenDataExtractor';
3
3
  import { BlockFrostOutputBox, BlockFrostTransaction } from './types';
4
4
  export declare class CardanoBlockFrostRosenExtractor extends AbstractRosenDataExtractor<BlockFrostTransaction> {
5
- /**
6
- * extracts RosenData from given lock transaction in blockfrost format
7
- * @param transaction the lock transaction in blockfrost format
8
- */
9
- get: (transaction: BlockFrostTransaction) => RosenData | undefined;
10
- /**
11
- * extracts and builds token transformation from UTXO and tokenMap
12
- * @param box transaction output
13
- * @param toChain event target chain
14
- */
15
- getAssetTransformation: (
16
- box: BlockFrostOutputBox,
17
- toChain: string
18
- ) => TokenTransformation | undefined;
5
+ /**
6
+ * extracts RosenData from given lock transaction in blockfrost format
7
+ * @param transaction the lock transaction in blockfrost format
8
+ */
9
+ get: (transaction: BlockFrostTransaction) => RosenData | undefined;
10
+ /**
11
+ * extracts and builds token transformation from UTXO and tokenMap
12
+ * @param box transaction output
13
+ * @param toChain event target chain
14
+ */
15
+ getAssetTransformation: (box: BlockFrostOutputBox, toChain: string) => TokenTransformation | undefined;
19
16
  }
20
- //# sourceMappingURL=CardanoBlockFrostRosenExtractor.d.ts.map
17
+ //# sourceMappingURL=CardanoBlockFrostRosenExtractor.d.ts.map
@@ -2,19 +2,16 @@ import { RosenData, TokenTransformation } from '../abstract/types';
2
2
  import AbstractRosenDataExtractor from '../abstract/AbstractRosenDataExtractor';
3
3
  import { GraphQLTransaction, GraphQLTxOutput } from './types';
4
4
  export declare class CardanoGraphQLRosenExtractor extends AbstractRosenDataExtractor<GraphQLTransaction> {
5
- /**
6
- * extracts RosenData from given lock transaction in graphql format
7
- * @param transaction the lock transaction in graphql format
8
- */
9
- get: (transaction: GraphQLTransaction) => RosenData | undefined;
10
- /**
11
- * extracts and builds token transformation from UTXO and tokenMap
12
- * @param box transaction output
13
- * @param toChain event target chain
14
- */
15
- getAssetTransformation: (
16
- box: GraphQLTxOutput,
17
- toChain: string
18
- ) => TokenTransformation | undefined;
5
+ /**
6
+ * extracts RosenData from given lock transaction in graphql format
7
+ * @param transaction the lock transaction in graphql format
8
+ */
9
+ get: (transaction: GraphQLTransaction) => RosenData | undefined;
10
+ /**
11
+ * extracts and builds token transformation from UTXO and tokenMap
12
+ * @param box transaction output
13
+ * @param toChain event target chain
14
+ */
15
+ getAssetTransformation: (box: GraphQLTxOutput, toChain: string) => TokenTransformation | undefined;
19
16
  }
20
- //# sourceMappingURL=CardanoGraphQLRosenExtractor.d.ts.map
17
+ //# sourceMappingURL=CardanoGraphQLRosenExtractor.d.ts.map
@@ -2,19 +2,16 @@ import { RosenData, TokenTransformation } from '../abstract/types';
2
2
  import AbstractRosenDataExtractor from '../abstract/AbstractRosenDataExtractor';
3
3
  import { KoiosTransaction, Utxo } from './types';
4
4
  export declare class CardanoKoiosRosenExtractor extends AbstractRosenDataExtractor<KoiosTransaction> {
5
- /**
6
- * extracts RosenData from given lock transaction in Koios format
7
- * @param transaction the lock transaction in Koios format
8
- */
9
- get: (transaction: KoiosTransaction) => RosenData | undefined;
10
- /**
11
- * extracts and builds token transformation from UTXO and tokenMap
12
- * @param box transaction output
13
- * @param toChain event target chain
14
- */
15
- getAssetTransformation: (
16
- box: Utxo,
17
- toChain: string
18
- ) => TokenTransformation | undefined;
5
+ /**
6
+ * extracts RosenData from given lock transaction in Koios format
7
+ * @param transaction the lock transaction in Koios format
8
+ */
9
+ get: (transaction: KoiosTransaction) => RosenData | undefined;
10
+ /**
11
+ * extracts and builds token transformation from UTXO and tokenMap
12
+ * @param box transaction output
13
+ * @param toChain event target chain
14
+ */
15
+ getAssetTransformation: (box: Utxo, toChain: string) => TokenTransformation | undefined;
19
16
  }
20
- //# sourceMappingURL=CardanoKoiosRosenExtractor.d.ts.map
17
+ //# sourceMappingURL=CardanoKoiosRosenExtractor.d.ts.map
@@ -2,19 +2,16 @@ import { RosenData, TokenTransformation } from '../abstract/types';
2
2
  import AbstractRosenDataExtractor from '../abstract/AbstractRosenDataExtractor';
3
3
  import { Transaction, TransactionOutput } from '@cardano-ogmios/schema';
4
4
  export declare class CardanoOgmiosRosenExtractor extends AbstractRosenDataExtractor<Transaction> {
5
- /**
6
- * extracts RosenData from given lock transaction in Ogmios format
7
- * @param transaction the lock transaction in Koios format
8
- */
9
- get: (transaction: Transaction) => RosenData | undefined;
10
- /**
11
- * extracts and builds token transformation from TxOut and tokenMap
12
- * @param box transaction output
13
- * @param toChain event target chain
14
- */
15
- getAssetTransformation: (
16
- box: TransactionOutput,
17
- toChain: string
18
- ) => TokenTransformation | undefined;
5
+ /**
6
+ * extracts RosenData from given lock transaction in Ogmios format
7
+ * @param transaction the lock transaction in Koios format
8
+ */
9
+ get: (transaction: Transaction) => RosenData | undefined;
10
+ /**
11
+ * extracts and builds token transformation from TxOut and tokenMap
12
+ * @param box transaction output
13
+ * @param toChain event target chain
14
+ */
15
+ getAssetTransformation: (box: TransactionOutput, toChain: string) => TokenTransformation | undefined;
19
16
  }
20
- //# sourceMappingURL=CardanoOgmiosRosenExtractor.d.ts.map
17
+ //# sourceMappingURL=CardanoOgmiosRosenExtractor.d.ts.map
@@ -2,19 +2,16 @@ import AbstractRosenDataExtractor from '../abstract/AbstractRosenDataExtractor';
2
2
  import { RosenData, TokenTransformation } from '../abstract/types';
3
3
  import { CardanoBoxCandidate } from './types';
4
4
  export declare class CardanoRosenExtractor extends AbstractRosenDataExtractor<string> {
5
- /**
6
- * extracts RosenData from given lock transaction in CardanoTx format
7
- * @param serializedTransaction stringified transaction in CardanoTx format
8
- */
9
- get: (serializedTransaction: string) => RosenData | undefined;
10
- /**
11
- * extracts and builds token transformation from CardanoBoxCandidate and tokenMap
12
- * @param box transaction output in CardanoBoxCandidate format
13
- * @param toChain event target chain
14
- */
15
- getAssetTransformation: (
16
- box: CardanoBoxCandidate,
17
- toChain: string
18
- ) => TokenTransformation | undefined;
5
+ /**
6
+ * extracts RosenData from given lock transaction in CardanoTx format
7
+ * @param serializedTransaction stringified transaction in CardanoTx format
8
+ */
9
+ get: (serializedTransaction: string) => RosenData | undefined;
10
+ /**
11
+ * extracts and builds token transformation from CardanoBoxCandidate and tokenMap
12
+ * @param box transaction output in CardanoBoxCandidate format
13
+ * @param toChain event target chain
14
+ */
15
+ getAssetTransformation: (box: CardanoBoxCandidate, toChain: string) => TokenTransformation | undefined;
19
16
  }
20
- //# sourceMappingURL=CardanoRosenExtractor.d.ts.map
17
+ //# sourceMappingURL=CardanoRosenExtractor.d.ts.map
@@ -1,146 +1,126 @@
1
1
  import { components } from '@blockfrost/openapi';
2
2
  interface PaymentAddr {
3
- bech32: string;
4
- cred: string;
3
+ bech32: string;
4
+ cred: string;
5
5
  }
6
6
  interface Asset {
7
- policy_id: string;
8
- asset_name: string;
9
- quantity: string;
7
+ policy_id: string;
8
+ asset_name: string;
9
+ quantity: string;
10
10
  }
11
11
  interface Utxo {
12
- payment_addr: PaymentAddr;
13
- stake_addr?: string | null;
14
- tx_hash: string;
15
- tx_index: number;
16
- value: string;
17
- asset_list: Array<Asset>;
12
+ payment_addr: PaymentAddr;
13
+ stake_addr?: string | null;
14
+ tx_hash: string;
15
+ tx_index: number;
16
+ value: string;
17
+ asset_list: Array<Asset>;
18
18
  }
19
19
  interface Metadata {
20
- [key: string]: Record<string, unknown>;
20
+ [key: string]: Record<string, unknown>;
21
21
  }
22
22
  interface KoiosTransaction {
23
- tx_hash: string;
24
- block_hash: string;
25
- inputs: Array<Utxo>;
26
- outputs: Array<Utxo>;
27
- metadata?: Metadata;
23
+ tx_hash: string;
24
+ block_hash: string;
25
+ inputs: Array<Utxo>;
26
+ outputs: Array<Utxo>;
27
+ metadata?: Metadata;
28
28
  }
29
29
  interface CardanoRosenData {
30
- toChain: string;
31
- toAddress: string;
32
- bridgeFee: string;
33
- networkFee: string;
34
- fromAddress: string;
30
+ toChain: string;
31
+ toAddress: string;
32
+ bridgeFee: string;
33
+ networkFee: string;
34
+ fromAddress: string;
35
35
  }
36
36
  interface CardanoMetadataRosenData {
37
- to: string;
38
- networkFee: string;
39
- bridgeFee: string;
40
- toAddress: string;
41
- fromAddress: string[];
37
+ to: string;
38
+ networkFee: string;
39
+ bridgeFee: string;
40
+ toAddress: string;
41
+ fromAddress: string[];
42
42
  }
43
43
  type ListObject = Array<MetadataObject>;
44
44
  type NativeValue = string | undefined;
45
45
  interface JsonObject {
46
- [key: string]: MetadataObject;
46
+ [key: string]: MetadataObject;
47
47
  }
48
48
  type MetadataObject = JsonObject | ListObject | NativeValue;
49
49
  interface CardanoAsset {
50
- policy_id: string;
51
- asset_name: string;
52
- quantity: string;
50
+ policy_id: string;
51
+ asset_name: string;
52
+ quantity: string;
53
53
  }
54
54
  interface CardanoUtxo {
55
- txId: string;
56
- index: number;
57
- value: bigint;
58
- assets: Array<CardanoAsset>;
55
+ txId: string;
56
+ index: number;
57
+ value: bigint;
58
+ assets: Array<CardanoAsset>;
59
59
  }
60
60
  interface CardanoBoxCandidate {
61
- address: string;
62
- value: bigint;
63
- assets: Array<CardanoAsset>;
61
+ address: string;
62
+ value: bigint;
63
+ assets: Array<CardanoAsset>;
64
64
  }
65
65
  type CardanoMetadata = Record<string, string | Record<string, any>>;
66
66
  interface CardanoTx {
67
- id: string;
68
- inputs: CardanoUtxo[];
69
- outputs: CardanoBoxCandidate[];
70
- fee: bigint;
71
- metadata?: CardanoMetadata;
67
+ id: string;
68
+ inputs: CardanoUtxo[];
69
+ outputs: CardanoBoxCandidate[];
70
+ fee: bigint;
71
+ metadata?: CardanoMetadata;
72
72
  }
73
73
  interface BlockFrostTransaction {
74
- utxos: components['schemas']['tx_content_utxo'];
75
- metadata: components['schemas']['tx_content_metadata'];
74
+ utxos: components['schemas']['tx_content_utxo'];
75
+ metadata: components['schemas']['tx_content_metadata'];
76
76
  }
77
- type BlockFrostOutputBox =
78
- components['schemas']['tx_content_utxo']['outputs'][0];
77
+ type BlockFrostOutputBox = components['schemas']['tx_content_utxo']['outputs'][0];
79
78
  type GraphQLBlockTxsQuery = {
80
- __typename?: 'Query';
81
- blocks: Array<{
82
- __typename?: 'Block';
83
- transactions: Array<{
84
- __typename?: 'Transaction';
85
- hash: any;
86
- fee: any;
87
- inputs: Array<{
88
- __typename?: 'TransactionInput';
89
- sourceTxIndex: number;
90
- sourceTxHash: any;
91
- value: any;
92
- tokens: Array<{
93
- __typename?: 'Token';
94
- quantity: string;
95
- asset: {
96
- __typename?: 'Asset';
97
- assetName?: any | null;
98
- policyId: any;
99
- };
79
+ __typename?: 'Query';
80
+ blocks: Array<{
81
+ __typename?: 'Block';
82
+ transactions: Array<{
83
+ __typename?: 'Transaction';
84
+ hash: any;
85
+ fee: any;
86
+ inputs: Array<{
87
+ __typename?: 'TransactionInput';
88
+ sourceTxIndex: number;
89
+ sourceTxHash: any;
90
+ value: any;
91
+ tokens: Array<{
92
+ __typename?: 'Token';
93
+ quantity: string;
94
+ asset: {
95
+ __typename?: 'Asset';
96
+ assetName?: any | null;
97
+ policyId: any;
98
+ };
99
+ } | null>;
100
+ }>;
101
+ outputs: Array<{
102
+ __typename?: 'TransactionOutput';
103
+ address: string;
104
+ value: any;
105
+ tokens: Array<{
106
+ __typename?: 'Token';
107
+ quantity: string;
108
+ asset: {
109
+ __typename?: 'Asset';
110
+ assetName?: any | null;
111
+ policyId: any;
112
+ };
113
+ }>;
114
+ } | null>;
115
+ metadata?: Array<{
116
+ __typename?: 'TransactionMetadata';
117
+ key: string;
118
+ value: any;
119
+ } | null> | null;
100
120
  } | null>;
101
- }>;
102
- outputs: Array<{
103
- __typename?: 'TransactionOutput';
104
- address: string;
105
- value: any;
106
- tokens: Array<{
107
- __typename?: 'Token';
108
- quantity: string;
109
- asset: {
110
- __typename?: 'Asset';
111
- assetName?: any | null;
112
- policyId: any;
113
- };
114
- }>;
115
- } | null>;
116
- metadata?: Array<{
117
- __typename?: 'TransactionMetadata';
118
- key: string;
119
- value: any;
120
- } | null> | null;
121
121
  } | null>;
122
- } | null>;
123
122
  };
124
- type GraphQLTransaction = NonNullable<
125
- NonNullable<GraphQLBlockTxsQuery['blocks'][0]>['transactions'][0]
126
- >;
123
+ type GraphQLTransaction = NonNullable<NonNullable<GraphQLBlockTxsQuery['blocks'][0]>['transactions'][0]>;
127
124
  type GraphQLTxOutput = NonNullable<GraphQLTransaction['outputs'][0]>;
128
- export {
129
- Utxo,
130
- KoiosTransaction,
131
- CardanoRosenData,
132
- CardanoMetadataRosenData,
133
- Metadata,
134
- MetadataObject,
135
- JsonObject,
136
- ListObject,
137
- NativeValue,
138
- CardanoMetadata,
139
- CardanoTx,
140
- CardanoBoxCandidate,
141
- BlockFrostTransaction,
142
- BlockFrostOutputBox,
143
- GraphQLTransaction,
144
- GraphQLTxOutput,
145
- };
146
- //# sourceMappingURL=types.d.ts.map
125
+ export { Utxo, KoiosTransaction, CardanoRosenData, CardanoMetadataRosenData, Metadata, MetadataObject, JsonObject, ListObject, NativeValue, CardanoMetadata, CardanoTx, CardanoBoxCandidate, BlockFrostTransaction, BlockFrostOutputBox, GraphQLTransaction, GraphQLTxOutput, };
126
+ //# sourceMappingURL=types.d.ts.map