Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@rosen-bridge/rosen-extractor

Package Overview
Dependencies
Maintainers
3
Versions
39
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@rosen-bridge/rosen-extractor - npm Package Compare versions

Comparing version 0.1.10 to 0.1.11

14

dist/lib/getRosenData/cardano/CardanoKoiosRosenExtractor.js
import { isPlainObject } from 'lodash-es';
import AbstractRosenDataExtractor from '../abstract/AbstractRosenDataExtractor';
import { CARDANO_CHAIN, CARDANO_NATIVE_TOKEN } from '../const';
import Utils from '../Utils';
export class CardanoKoiosRosenExtractor extends AbstractRosenDataExtractor {

@@ -10,2 +11,3 @@ /**

get = (transaction) => {
const baseError = `No rosen data found for tx [${transaction.tx_hash}]`;
const metadata = transaction.metadata;

@@ -39,4 +41,10 @@ try {

}
this.logger.debug(baseError + `: No valid transformation found in any output boxes`);
}
else
this.logger.debug(baseError +
`: Incomplete metadata. isPlain: ${isPlainObject(data)}, data: ${Utils.JsonBI.stringify(data)}`);
}
else
this.logger.debug(baseError + `: Invalid metadata: ${Utils.JsonBI.stringify(metadata)}`);
}

@@ -83,6 +91,8 @@ catch (e) {

}
else
else {
this.logger.debug(`No rosen asset transformation found for box [${box.tx_hash}.${box.tx_index}]: box assets: ${Utils.JsonBI.stringify(box.asset_list)}`);
return undefined;
}
};
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CardanoKoiosRosenExtractor.js","sourceRoot":"","sources":["../../../../lib/getRosenData/cardano/CardanoKoiosRosenExtractor.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlainObject } from 'lodash-es';\nimport { RosenData } from '../abstract/types';\nimport AbstractRosenDataExtractor from '../abstract/AbstractRosenDataExtractor';\nimport { CARDANO_CHAIN, CARDANO_NATIVE_TOKEN } from '../const';\nimport {\n  CardanoMetadataRosenData,\n  KoiosTransaction,\n  TokenTransformation,\n  Utxo,\n} from './types';\n\nexport class CardanoKoiosRosenExtractor extends AbstractRosenDataExtractor<KoiosTransaction> {\n  /**\n   * extracts RosenData from given lock transaction in Koios format\n   * @param transaction the lock transaction in Koios format\n   */\n  get = (transaction: KoiosTransaction): RosenData | undefined => {\n    const metadata = transaction.metadata;\n    try {\n      if (metadata && Object.prototype.hasOwnProperty.call(metadata, '0')) {\n        const data = metadata['0'];\n        if (\n          isPlainObject(data) &&\n          'to' in data &&\n          'bridgeFee' in data &&\n          'networkFee' in data &&\n          'toAddress' in data &&\n          'fromAddress' in data\n        ) {\n          const rosenData = data as unknown as CardanoMetadataRosenData;\n\n          const lockOutputs = transaction.outputs.filter(\n            (output) => output.payment_addr.bech32 === this.lockAddress\n          );\n          for (const output of lockOutputs) {\n            const assetTransformation = this.getAssetTransformation(\n              output,\n              rosenData.to\n            );\n            if (assetTransformation) {\n              return {\n                toChain: rosenData.to,\n                toAddress: rosenData.toAddress,\n                bridgeFee: rosenData.bridgeFee,\n                networkFee: rosenData.networkFee,\n                fromAddress: rosenData.fromAddress.join(''),\n                sourceChainTokenId: assetTransformation.from,\n                amount: assetTransformation.amount,\n                targetChainTokenId: assetTransformation.to,\n                sourceTxId: transaction.tx_hash,\n              };\n            }\n          }\n        }\n      }\n    } catch (e) {\n      this.logger.debug(\n        `An error occurred while getting Cardano rosen data from Koios: ${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: Utxo,\n    toChain: string\n  ): TokenTransformation | undefined => {\n    // try to build transformation using locked assets\n    if (box.asset_list.length > 0) {\n      for (const asset of box.asset_list) {\n        const token = this.tokens.search(CARDANO_CHAIN, {\n          assetName: asset.asset_name,\n          policyId: asset.policy_id,\n        });\n        if (token.length > 0)\n          return {\n            from: this.tokens.getID(token[0], CARDANO_CHAIN),\n            to: this.tokens.getID(token[0], toChain),\n            amount: asset.quantity,\n          };\n      }\n    }\n\n    // try to build transformation using locked ADA\n    const lovelace = this.tokens.search(CARDANO_CHAIN, {\n      [this.tokens.getIdKey(CARDANO_CHAIN)]: CARDANO_NATIVE_TOKEN,\n    });\n    if (lovelace.length > 0) {\n      return {\n        from: CARDANO_NATIVE_TOKEN,\n        to: this.tokens.getID(lovelace[0], toChain),\n        amount: box.value,\n      };\n    } else return undefined;\n  };\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CardanoKoiosRosenExtractor.js","sourceRoot":"","sources":["../../../../lib/getRosenData/cardano/CardanoKoiosRosenExtractor.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlainObject } from 'lodash-es';\nimport { RosenData } from '../abstract/types';\nimport AbstractRosenDataExtractor from '../abstract/AbstractRosenDataExtractor';\nimport { CARDANO_CHAIN, CARDANO_NATIVE_TOKEN } from '../const';\nimport {\n  CardanoMetadataRosenData,\n  KoiosTransaction,\n  TokenTransformation,\n  Utxo,\n} from './types';\nimport Utils from '../Utils';\n\nexport class CardanoKoiosRosenExtractor extends AbstractRosenDataExtractor<KoiosTransaction> {\n  /**\n   * extracts RosenData from given lock transaction in Koios format\n   * @param transaction the lock transaction in Koios format\n   */\n  get = (transaction: KoiosTransaction): RosenData | undefined => {\n    const baseError = `No rosen data found for tx [${transaction.tx_hash}]`;\n    const metadata = transaction.metadata;\n    try {\n      if (metadata && Object.prototype.hasOwnProperty.call(metadata, '0')) {\n        const data = metadata['0'];\n        if (\n          isPlainObject(data) &&\n          'to' in data &&\n          'bridgeFee' in data &&\n          'networkFee' in data &&\n          'toAddress' in data &&\n          'fromAddress' in data\n        ) {\n          const rosenData = data as unknown as CardanoMetadataRosenData;\n\n          const lockOutputs = transaction.outputs.filter(\n            (output) => output.payment_addr.bech32 === this.lockAddress\n          );\n          for (const output of lockOutputs) {\n            const assetTransformation = this.getAssetTransformation(\n              output,\n              rosenData.to\n            );\n            if (assetTransformation) {\n              return {\n                toChain: rosenData.to,\n                toAddress: rosenData.toAddress,\n                bridgeFee: rosenData.bridgeFee,\n                networkFee: rosenData.networkFee,\n                fromAddress: rosenData.fromAddress.join(''),\n                sourceChainTokenId: assetTransformation.from,\n                amount: assetTransformation.amount,\n                targetChainTokenId: assetTransformation.to,\n                sourceTxId: transaction.tx_hash,\n              };\n            }\n          }\n          this.logger.debug(\n            baseError + `: No valid transformation found in any output boxes`\n          );\n        } else\n          this.logger.debug(\n            baseError +\n              `: Incomplete metadata. isPlain: ${isPlainObject(\n                data\n              )}, data: ${Utils.JsonBI.stringify(data)}`\n          );\n      } else\n        this.logger.debug(\n          baseError + `: Invalid metadata: ${Utils.JsonBI.stringify(metadata)}`\n        );\n    } catch (e) {\n      this.logger.debug(\n        `An error occurred while getting Cardano rosen data from Koios: ${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: Utxo,\n    toChain: string\n  ): TokenTransformation | undefined => {\n    // try to build transformation using locked assets\n    if (box.asset_list.length > 0) {\n      for (const asset of box.asset_list) {\n        const token = this.tokens.search(CARDANO_CHAIN, {\n          assetName: asset.asset_name,\n          policyId: asset.policy_id,\n        });\n        if (token.length > 0)\n          return {\n            from: this.tokens.getID(token[0], CARDANO_CHAIN),\n            to: this.tokens.getID(token[0], toChain),\n            amount: asset.quantity,\n          };\n      }\n    }\n\n    // try to build transformation using locked ADA\n    const lovelace = this.tokens.search(CARDANO_CHAIN, {\n      [this.tokens.getIdKey(CARDANO_CHAIN)]: CARDANO_NATIVE_TOKEN,\n    });\n    if (lovelace.length > 0) {\n      return {\n        from: CARDANO_NATIVE_TOKEN,\n        to: this.tokens.getID(lovelace[0], toChain),\n        amount: box.value,\n      };\n    } else {\n      this.logger.debug(\n        `No rosen asset transformation found for box [${box.tx_hash}.${\n          box.tx_index\n        }]: box assets: ${Utils.JsonBI.stringify(box.asset_list)}`\n      );\n      return undefined;\n    }\n  };\n}\n"]}

@@ -11,2 +11,3 @@ import AbstractRosenDataExtractor from '../abstract/AbstractRosenDataExtractor';

get = (transaction) => {
const baseError = `No rosen data found for tx [${transaction.id}]`;
const metadata = transaction.metadata;

@@ -42,5 +43,13 @@ try {

}
this.logger.debug(baseError + `: No valid transformation found in any output boxes`);
}
else
this.logger.debug(baseError +
`: Incomplete metadata: ${Utils.JsonBI.stringify(metadata)}`);
}
else
this.logger.debug(baseError + `: Invalid blob: ${Utils.JsonBI.stringify(metadata)}`);
}
else
this.logger.debug(baseError + `: Invalid metadata: ${Utils.JsonBI.stringify(metadata)}`);
}

@@ -96,6 +105,8 @@ catch (e) {

}
else
else {
this.logger.debug(`No rosen asset transformation found for Ogmios box with assets: ${Utils.JsonBI.stringify(box.value.assets)}`);
return undefined;
}
};
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CardanoOgmiosRosenExtractor.js","sourceRoot":"","sources":["../../../../lib/getRosenData/cardano/CardanoOgmiosRosenExtractor.ts"],"names":[],"mappings":"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","sourcesContent":["import { RosenData } from '../abstract/types';\nimport AbstractRosenDataExtractor from '../abstract/AbstractRosenDataExtractor';\nimport { CARDANO_CHAIN, CARDANO_NATIVE_TOKEN } from '../const';\nimport Utils from '../Utils';\nimport { TxBabbage, TxOut } from '@cardano-ogmios/schema';\nimport { CardanoMetadataRosenData, TokenTransformation } from './types';\nimport { isArray, isString } from 'lodash-es';\n\nexport class CardanoOgmiosRosenExtractor extends AbstractRosenDataExtractor<TxBabbage> {\n  /**\n   * extracts RosenData from given lock transaction in Ogmios format\n   * @param transaction the lock transaction in Koios format\n   */\n  get = (transaction: TxBabbage): RosenData | undefined => {\n    const metadata = transaction.metadata;\n    try {\n      if (metadata !== null) {\n        const blob = metadata.body.blob;\n        if (blob && blob['0']) {\n          const data = Utils.getDictValue(\n            blob['0']\n          ) as Partial<CardanoMetadataRosenData>;\n          if (\n            isString(data.to) &&\n            isString(data.networkFee) &&\n            isString(data.bridgeFee) &&\n            isString(data.toAddress) &&\n            isArray(data.fromAddress) &&\n            data.fromAddress.every(isString)\n          ) {\n            const rosenData = data as unknown as CardanoMetadataRosenData;\n\n            const lockOutputs = transaction.body.outputs.filter(\n              (output) => output.address === this.lockAddress\n            );\n            for (const output of lockOutputs) {\n              const assetTransformation = this.getAssetTransformation(\n                output,\n                rosenData.to\n              );\n              if (assetTransformation) {\n                return {\n                  toChain: rosenData.to,\n                  toAddress: rosenData.toAddress,\n                  bridgeFee: rosenData.bridgeFee,\n                  networkFee: rosenData.networkFee,\n                  fromAddress: rosenData.fromAddress.join(''),\n                  sourceChainTokenId: assetTransformation.from,\n                  amount: assetTransformation.amount,\n                  targetChainTokenId: assetTransformation.to,\n                  sourceTxId: transaction.id,\n                };\n              }\n            }\n          }\n        }\n      }\n    } catch (e) {\n      this.logger.debug(\n        `An error occurred while getting Cardano rosen data from Ogmios: ${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 TxOut and tokenMap\n   * @param box transaction output\n   * @param toChain event target chain\n   */\n  getAssetTransformation = (\n    box: TxOut,\n    toChain: string\n  ): TokenTransformation | undefined => {\n    // try to build transformation using locked assets\n    if (box.value.assets) {\n      const assets = Object.keys(box.value.assets);\n      if (assets.length > 0) {\n        for (const tokenKey of assets) {\n          // according to ogmios docs assets are stores as\n          //      [policyId.assetName]: amount\n          //      [policyId]: amount        if assetName not exists.\n          const parts = tokenKey.split('.');\n          // if assetName exists, search token with policyId and asset name\n          // if not, search token with policyId\n          const token = this.tokens.search(\n            CARDANO_CHAIN,\n            tokenKey.indexOf('.') != -1\n              ? { policyId: parts[0].trim(), assetName: parts[1].trim() }\n              : { policyId: tokenKey }\n          );\n          if (token.length > 0) {\n            return {\n              from: this.tokens.getID(token[0], CARDANO_CHAIN),\n              to: this.tokens.getID(token[0], toChain),\n              amount: box.value.assets[tokenKey].toString(),\n            };\n          }\n        }\n      }\n    }\n\n    // try to build transformation using locked ADA\n    const lovelace = this.tokens.search(CARDANO_CHAIN, {\n      [this.tokens.getIdKey(CARDANO_CHAIN)]: CARDANO_NATIVE_TOKEN,\n    });\n    if (lovelace.length > 0) {\n      return {\n        from: CARDANO_NATIVE_TOKEN,\n        to: this.tokens.getID(lovelace[0], toChain),\n        amount: box.value.coins.toString(),\n      };\n    } else return undefined;\n  };\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CardanoOgmiosRosenExtractor.js","sourceRoot":"","sources":["../../../../lib/getRosenData/cardano/CardanoOgmiosRosenExtractor.ts"],"names":[],"mappings":"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","sourcesContent":["import { RosenData } from '../abstract/types';\nimport AbstractRosenDataExtractor from '../abstract/AbstractRosenDataExtractor';\nimport { CARDANO_CHAIN, CARDANO_NATIVE_TOKEN } from '../const';\nimport Utils from '../Utils';\nimport { TxBabbage, TxOut } from '@cardano-ogmios/schema';\nimport { CardanoMetadataRosenData, TokenTransformation } from './types';\nimport { isArray, isString } from 'lodash-es';\n\nexport class CardanoOgmiosRosenExtractor extends AbstractRosenDataExtractor<TxBabbage> {\n  /**\n   * extracts RosenData from given lock transaction in Ogmios format\n   * @param transaction the lock transaction in Koios format\n   */\n  get = (transaction: TxBabbage): RosenData | undefined => {\n    const baseError = `No rosen data found for tx [${transaction.id}]`;\n    const metadata = transaction.metadata;\n    try {\n      if (metadata !== null) {\n        const blob = metadata.body.blob;\n        if (blob && blob['0']) {\n          const data = Utils.getDictValue(\n            blob['0']\n          ) as Partial<CardanoMetadataRosenData>;\n          if (\n            isString(data.to) &&\n            isString(data.networkFee) &&\n            isString(data.bridgeFee) &&\n            isString(data.toAddress) &&\n            isArray(data.fromAddress) &&\n            data.fromAddress.every(isString)\n          ) {\n            const rosenData = data as unknown as CardanoMetadataRosenData;\n\n            const lockOutputs = transaction.body.outputs.filter(\n              (output) => output.address === this.lockAddress\n            );\n            for (const output of lockOutputs) {\n              const assetTransformation = this.getAssetTransformation(\n                output,\n                rosenData.to\n              );\n              if (assetTransformation) {\n                return {\n                  toChain: rosenData.to,\n                  toAddress: rosenData.toAddress,\n                  bridgeFee: rosenData.bridgeFee,\n                  networkFee: rosenData.networkFee,\n                  fromAddress: rosenData.fromAddress.join(''),\n                  sourceChainTokenId: assetTransformation.from,\n                  amount: assetTransformation.amount,\n                  targetChainTokenId: assetTransformation.to,\n                  sourceTxId: transaction.id,\n                };\n              }\n            }\n            this.logger.debug(\n              baseError + `: No valid transformation found in any output boxes`\n            );\n          } else\n            this.logger.debug(\n              baseError +\n                `: Incomplete metadata: ${Utils.JsonBI.stringify(metadata)}`\n            );\n        } else\n          this.logger.debug(\n            baseError + `: Invalid blob: ${Utils.JsonBI.stringify(metadata)}`\n          );\n      } else\n        this.logger.debug(\n          baseError + `: Invalid metadata: ${Utils.JsonBI.stringify(metadata)}`\n        );\n    } catch (e) {\n      this.logger.debug(\n        `An error occurred while getting Cardano rosen data from Ogmios: ${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 TxOut and tokenMap\n   * @param box transaction output\n   * @param toChain event target chain\n   */\n  getAssetTransformation = (\n    box: TxOut,\n    toChain: string\n  ): TokenTransformation | undefined => {\n    // try to build transformation using locked assets\n    if (box.value.assets) {\n      const assets = Object.keys(box.value.assets);\n      if (assets.length > 0) {\n        for (const tokenKey of assets) {\n          // according to ogmios docs assets are stores as\n          //      [policyId.assetName]: amount\n          //      [policyId]: amount        if assetName not exists.\n          const parts = tokenKey.split('.');\n          // if assetName exists, search token with policyId and asset name\n          // if not, search token with policyId\n          const token = this.tokens.search(\n            CARDANO_CHAIN,\n            tokenKey.indexOf('.') != -1\n              ? { policyId: parts[0].trim(), assetName: parts[1].trim() }\n              : { policyId: tokenKey }\n          );\n          if (token.length > 0) {\n            return {\n              from: this.tokens.getID(token[0], CARDANO_CHAIN),\n              to: this.tokens.getID(token[0], toChain),\n              amount: box.value.assets[tokenKey].toString(),\n            };\n          }\n        }\n      }\n    }\n\n    // try to build transformation using locked ADA\n    const lovelace = this.tokens.search(CARDANO_CHAIN, {\n      [this.tokens.getIdKey(CARDANO_CHAIN)]: CARDANO_NATIVE_TOKEN,\n    });\n    if (lovelace.length > 0) {\n      return {\n        from: CARDANO_NATIVE_TOKEN,\n        to: this.tokens.getID(lovelace[0], toChain),\n        amount: box.value.coins.toString(),\n      };\n    } else {\n      this.logger.debug(\n        `No rosen asset transformation found for Ogmios box with assets: ${Utils.JsonBI.stringify(\n          box.value.assets\n        )}`\n      );\n      return undefined;\n    }\n  };\n}\n"]}
import AbstractRosenDataExtractor from '../abstract/AbstractRosenDataExtractor';
import { CARDANO_CHAIN, CARDANO_NATIVE_TOKEN } from '../const';
import * as JSONBigInt from 'json-bigint';
import Utils from '../Utils';
export class CardanoRosenExtractor extends AbstractRosenDataExtractor {

@@ -17,2 +18,3 @@ /**

}
const baseError = `No rosen data found for tx [${transaction.id}]`;
const rosenMetadata = transaction.metadata?.['0'];

@@ -43,3 +45,7 @@ if (rosenMetadata &&

}
this.logger.debug(baseError + `: No valid transformation found in any output boxes`);
}
else
this.logger.debug(baseError +
`: Incomplete metadata: ${Utils.JsonBI.stringify(transaction.metadata)}`);
return undefined;

@@ -79,6 +85,8 @@ };

}
else
else {
this.logger.debug(`No rosen asset transformation found for CardanoBoxCandidate with assets: ${Utils.JsonBI.stringify(box.assets)}`);
return undefined;
}
};
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2FyZGFub1Jvc2VuRXh0cmFjdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbGliL2dldFJvc2VuRGF0YS9jYXJkYW5vL0NhcmRhbm9Sb3NlbkV4dHJhY3Rvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLDBCQUEwQixNQUFNLHdDQUF3QyxDQUFDO0FBUWhGLE9BQU8sRUFBRSxhQUFhLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDL0QsT0FBTyxLQUFLLFVBQVUsTUFBTSxhQUFhLENBQUM7QUFFMUMsTUFBTSxPQUFPLHFCQUFzQixTQUFRLDBCQUFrQztJQUMzRTs7O09BR0c7SUFDSCxHQUFHLEdBQUcsQ0FBQyxxQkFBNkIsRUFBeUIsRUFBRTtRQUM3RCxJQUFJLFdBQXNCLENBQUM7UUFDM0IsSUFBSTtZQUNGLFdBQVcsR0FBRyxVQUFVLENBQUMsS0FBSyxDQUFDLHFCQUFxQixDQUFDLENBQUM7U0FDdkQ7UUFBQyxPQUFPLENBQUMsRUFBRTtZQUNWLE1BQU0sSUFBSSxLQUFLLENBQ2IscUZBQXFGLENBQUMsRUFBRSxDQUN6RixDQUFDO1NBQ0g7UUFDRCxNQUFNLGFBQWEsR0FBRyxXQUFXLENBQUMsUUFBUSxFQUFFLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDbEQsSUFDRSxhQUFhO1lBQ2IsSUFBSSxJQUFJLGFBQWE7WUFDckIsV0FBVyxJQUFJLGFBQWE7WUFDNUIsWUFBWSxJQUFJLGFBQWE7WUFDN0IsV0FBVyxJQUFJLGFBQWE7WUFDNUIsYUFBYSxJQUFJLGFBQWEsRUFDOUI7WUFDQSxNQUFNLElBQUksR0FBRyxhQUFvRCxDQUFDO1lBQ2xFLE1BQU0sV0FBVyxHQUFHLFdBQVcsQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUM1QyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsTUFBTSxDQUFDLE9BQU8sS0FBSyxJQUFJLENBQUMsV0FBVyxDQUNoRCxDQUFDO1lBQ0YsS0FBSyxNQUFNLE1BQU0sSUFBSSxXQUFXLEVBQUU7Z0JBQ2hDLE1BQU0sbUJBQW1CLEdBQUcsSUFBSSxDQUFDLHNCQUFzQixDQUNyRCxNQUFNLEVBQ04sSUFBSSxDQUFDLEVBQUUsQ0FDUixDQUFDO2dCQUNGLElBQUksbUJBQW1CLEVBQUU7b0JBQ3ZCLE9BQU87d0JBQ0wsT0FBTyxFQUFFLElBQUksQ0FBQyxFQUFFO3dCQUNoQixTQUFTLEVBQUUsSUFBSSxDQUFDLFNBQVM7d0JBQ3pCLFNBQVMsRUFBRSxJQUFJLENBQUMsU0FBUzt3QkFDekIsVUFBVSxFQUFFLElBQUksQ0FBQyxVQUFVO3dCQUMzQixXQUFXLEVBQUUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDO3dCQUN0QyxrQkFBa0IsRUFBRSxtQkFBbUIsQ0FBQyxJQUFJO3dCQUM1QyxNQUFNLEVBQUUsbUJBQW1CLENBQUMsTUFBTTt3QkFDbEMsa0JBQWtCLEVBQUUsbUJBQW1CLENBQUMsRUFBRTt3QkFDMUMsVUFBVSxFQUFFLFdBQVcsQ0FBQyxFQUFFO3FCQUMzQixDQUFDO2lCQUNIO2FBQ0Y7U0FDRjtRQUNELE9BQU8sU0FBUyxDQUFDO0lBQ25CLENBQUMsQ0FBQztJQUVGOzs7O09BSUc7SUFDSCxzQkFBc0IsR0FBRyxDQUN2QixHQUF3QixFQUN4QixPQUFlLEVBQ2tCLEVBQUU7UUFDbkMsa0RBQWtEO1FBQ2xELElBQUksR0FBRyxDQUFDLE1BQU0sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFO1lBQ3pCLEtBQUssTUFBTSxLQUFLLElBQUksR0FBRyxDQUFDLE1BQU0sRUFBRTtnQkFDOUIsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsYUFBYSxFQUFFO29CQUM5QyxTQUFTLEVBQUUsS0FBSyxDQUFDLFVBQVU7b0JBQzNCLFFBQVEsRUFBRSxLQUFLLENBQUMsU0FBUztpQkFDMUIsQ0FBQyxDQUFDO2dCQUNILElBQUksS0FBSyxDQUFDLE1BQU0sR0FBRyxDQUFDO29CQUNsQixPQUFPO3dCQUNMLElBQUksRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUUsYUFBYSxDQUFDO3dCQUNoRCxFQUFFLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFLE9BQU8sQ0FBQzt3QkFDeEMsTUFBTSxFQUFFLEtBQUssQ0FBQyxRQUFRO3FCQUN2QixDQUFDO2FBQ0w7U0FDRjtRQUVELCtDQUErQztRQUMvQyxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxhQUFhLEVBQUU7WUFDakQsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsQ0FBQyxFQUFFLG9CQUFvQjtTQUM1RCxDQUFDLENBQUM7UUFDSCxJQUFJLFFBQVEsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFO1lBQ3ZCLE9BQU87Z0JBQ0wsSUFBSSxFQUFFLG9CQUFvQjtnQkFDMUIsRUFBRSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsRUFBRSxPQUFPLENBQUM7Z0JBQzNDLE1BQU0sRUFBRSxHQUFHLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFBRTthQUM3QixDQUFDO1NBQ0g7O1lBQU0sT0FBTyxTQUFTLENBQUM7SUFDMUIsQ0FBQyxDQUFDO0NBQ0giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQWJzdHJhY3RSb3NlbkRhdGFFeHRyYWN0b3IgZnJvbSAnLi4vYWJzdHJhY3QvQWJzdHJhY3RSb3NlbkRhdGFFeHRyYWN0b3InO1xuaW1wb3J0IHsgUm9zZW5EYXRhIH0gZnJvbSAnLi4vYWJzdHJhY3QvdHlwZXMnO1xuaW1wb3J0IHtcbiAgQ2FyZGFub0JveENhbmRpZGF0ZSxcbiAgQ2FyZGFub01ldGFkYXRhUm9zZW5EYXRhLFxuICBDYXJkYW5vVHgsXG4gIFRva2VuVHJhbnNmb3JtYXRpb24sXG59IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IHsgQ0FSREFOT19DSEFJTiwgQ0FSREFOT19OQVRJVkVfVE9LRU4gfSBmcm9tICcuLi9jb25zdCc7XG5pbXBvcnQgKiBhcyBKU09OQmlnSW50IGZyb20gJ2pzb24tYmlnaW50JztcblxuZXhwb3J0IGNsYXNzIENhcmRhbm9Sb3NlbkV4dHJhY3RvciBleHRlbmRzIEFic3RyYWN0Um9zZW5EYXRhRXh0cmFjdG9yPHN0cmluZz4ge1xuICAvKipcbiAgICogZXh0cmFjdHMgUm9zZW5EYXRhIGZyb20gZ2l2ZW4gbG9jayB0cmFuc2FjdGlvbiBpbiBDYXJkYW5vVHggZm9ybWF0XG4gICAqIEBwYXJhbSBzZXJpYWxpemVkVHJhbnNhY3Rpb24gc3RyaW5naWZpZWQgdHJhbnNhY3Rpb24gaW4gQ2FyZGFub1R4IGZvcm1hdFxuICAgKi9cbiAgZ2V0ID0gKHNlcmlhbGl6ZWRUcmFuc2FjdGlvbjogc3RyaW5nKTogUm9zZW5EYXRhIHwgdW5kZWZpbmVkID0+IHtcbiAgICBsZXQgdHJhbnNhY3Rpb246IENhcmRhbm9UeDtcbiAgICB0cnkge1xuICAgICAgdHJhbnNhY3Rpb24gPSBKU09OQmlnSW50LnBhcnNlKHNlcmlhbGl6ZWRUcmFuc2FjdGlvbik7XG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgICBgRmFpbGVkIHRvIHBhcnNlIHRyYW5zYWN0aW9uIGpzb24gdG8gQ2FyZGFub1R4IGZvcm1hdCB3aGlsZSBleHRyYWN0aW5nIHJvc2VuIGRhdGE6ICR7ZX1gXG4gICAgICApO1xuICAgIH1cbiAgICBjb25zdCByb3Nlbk1ldGFkYXRhID0gdHJhbnNhY3Rpb24ubWV0YWRhdGE/LlsnMCddO1xuICAgIGlmIChcbiAgICAgIHJvc2VuTWV0YWRhdGEgJiZcbiAgICAgICd0bycgaW4gcm9zZW5NZXRhZGF0YSAmJlxuICAgICAgJ2JyaWRnZUZlZScgaW4gcm9zZW5NZXRhZGF0YSAmJlxuICAgICAgJ25ldHdvcmtGZWUnIGluIHJvc2VuTWV0YWRhdGEgJiZcbiAgICAgICd0b0FkZHJlc3MnIGluIHJvc2VuTWV0YWRhdGEgJiZcbiAgICAgICdmcm9tQWRkcmVzcycgaW4gcm9zZW5NZXRhZGF0YVxuICAgICkge1xuICAgICAgY29uc3QgZGF0YSA9IHJvc2VuTWV0YWRhdGEgYXMgdW5rbm93biBhcyBDYXJkYW5vTWV0YWRhdGFSb3NlbkRhdGE7XG4gICAgICBjb25zdCBsb2NrT3V0cHV0cyA9IHRyYW5zYWN0aW9uLm91dHB1dHMuZmlsdGVyKFxuICAgICAgICAob3V0cHV0KSA9PiBvdXRwdXQuYWRkcmVzcyA9PT0gdGhpcy5sb2NrQWRkcmVzc1xuICAgICAgKTtcbiAgICAgIGZvciAoY29uc3Qgb3V0cHV0IG9mIGxvY2tPdXRwdXRzKSB7XG4gICAgICAgIGNvbnN0IGFzc2V0VHJhbnNmb3JtYXRpb24gPSB0aGlzLmdldEFzc2V0VHJhbnNmb3JtYXRpb24oXG4gICAgICAgICAgb3V0cHV0LFxuICAgICAgICAgIGRhdGEudG9cbiAgICAgICAgKTtcbiAgICAgICAgaWYgKGFzc2V0VHJhbnNmb3JtYXRpb24pIHtcbiAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgdG9DaGFpbjogZGF0YS50byxcbiAgICAgICAgICAgIHRvQWRkcmVzczogZGF0YS50b0FkZHJlc3MsXG4gICAgICAgICAgICBicmlkZ2VGZWU6IGRhdGEuYnJpZGdlRmVlLFxuICAgICAgICAgICAgbmV0d29ya0ZlZTogZGF0YS5uZXR3b3JrRmVlLFxuICAgICAgICAgICAgZnJvbUFkZHJlc3M6IGRhdGEuZnJvbUFkZHJlc3Muam9pbignJyksXG4gICAgICAgICAgICBzb3VyY2VDaGFpblRva2VuSWQ6IGFzc2V0VHJhbnNmb3JtYXRpb24uZnJvbSxcbiAgICAgICAgICAgIGFtb3VudDogYXNzZXRUcmFuc2Zvcm1hdGlvbi5hbW91bnQsXG4gICAgICAgICAgICB0YXJnZXRDaGFpblRva2VuSWQ6IGFzc2V0VHJhbnNmb3JtYXRpb24udG8sXG4gICAgICAgICAgICBzb3VyY2VUeElkOiB0cmFuc2FjdGlvbi5pZCxcbiAgICAgICAgICB9O1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH07XG5cbiAgLyoqXG4gICAqIGV4dHJhY3RzIGFuZCBidWlsZHMgdG9rZW4gdHJhbnNmb3JtYXRpb24gZnJvbSBDYXJkYW5vQm94Q2FuZGlkYXRlIGFuZCB0b2tlbk1hcFxuICAgKiBAcGFyYW0gYm94IHRyYW5zYWN0aW9uIG91dHB1dCBpbiBDYXJkYW5vQm94Q2FuZGlkYXRlIGZvcm1hdFxuICAgKiBAcGFyYW0gdG9DaGFpbiBldmVudCB0YXJnZXQgY2hhaW5cbiAgICovXG4gIGdldEFzc2V0VHJhbnNmb3JtYXRpb24gPSAoXG4gICAgYm94OiBDYXJkYW5vQm94Q2FuZGlkYXRlLFxuICAgIHRvQ2hhaW46IHN0cmluZ1xuICApOiBUb2tlblRyYW5zZm9ybWF0aW9uIHwgdW5kZWZpbmVkID0+IHtcbiAgICAvLyB0cnkgdG8gYnVpbGQgdHJhbnNmb3JtYXRpb24gdXNpbmcgbG9ja2VkIGFzc2V0c1xuICAgIGlmIChib3guYXNzZXRzLmxlbmd0aCA+IDApIHtcbiAgICAgIGZvciAoY29uc3QgYXNzZXQgb2YgYm94LmFzc2V0cykge1xuICAgICAgICBjb25zdCB0b2tlbiA9IHRoaXMudG9rZW5zLnNlYXJjaChDQVJEQU5PX0NIQUlOLCB7XG4gICAgICAgICAgYXNzZXROYW1lOiBhc3NldC5hc3NldF9uYW1lLFxuICAgICAgICAgIHBvbGljeUlkOiBhc3NldC5wb2xpY3lfaWQsXG4gICAgICAgIH0pO1xuICAgICAgICBpZiAodG9rZW4ubGVuZ3RoID4gMClcbiAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgZnJvbTogdGhpcy50b2tlbnMuZ2V0SUQodG9rZW5bMF0sIENBUkRBTk9fQ0hBSU4pLFxuICAgICAgICAgICAgdG86IHRoaXMudG9rZW5zLmdldElEKHRva2VuWzBdLCB0b0NoYWluKSxcbiAgICAgICAgICAgIGFtb3VudDogYXNzZXQucXVhbnRpdHksXG4gICAgICAgICAgfTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICAvLyB0cnkgdG8gYnVpbGQgdHJhbnNmb3JtYXRpb24gdXNpbmcgbG9ja2VkIEFEQVxuICAgIGNvbnN0IGxvdmVsYWNlID0gdGhpcy50b2tlbnMuc2VhcmNoKENBUkRBTk9fQ0hBSU4sIHtcbiAgICAgIFt0aGlzLnRva2Vucy5nZXRJZEtleShDQVJEQU5PX0NIQUlOKV06IENBUkRBTk9fTkFUSVZFX1RPS0VOLFxuICAgIH0pO1xuICAgIGlmIChsb3ZlbGFjZS5sZW5ndGggPiAwKSB7XG4gICAgICByZXR1cm4ge1xuICAgICAgICBmcm9tOiBDQVJEQU5PX05BVElWRV9UT0tFTixcbiAgICAgICAgdG86IHRoaXMudG9rZW5zLmdldElEKGxvdmVsYWNlWzBdLCB0b0NoYWluKSxcbiAgICAgICAgYW1vdW50OiBib3gudmFsdWUudG9TdHJpbmcoKSxcbiAgICAgIH07XG4gICAgfSBlbHNlIHJldHVybiB1bmRlZmluZWQ7XG4gIH07XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CardanoRosenExtractor.js","sourceRoot":"","sources":["../../../../lib/getRosenData/cardano/CardanoRosenExtractor.ts"],"names":[],"mappings":"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","sourcesContent":["import AbstractRosenDataExtractor from '../abstract/AbstractRosenDataExtractor';\nimport { RosenData } from '../abstract/types';\nimport {\n  CardanoBoxCandidate,\n  CardanoMetadataRosenData,\n  CardanoTx,\n  TokenTransformation,\n} from './types';\nimport { CARDANO_CHAIN, CARDANO_NATIVE_TOKEN } from '../const';\nimport * as JSONBigInt from 'json-bigint';\nimport Utils from '../Utils';\n\nexport class CardanoRosenExtractor extends AbstractRosenDataExtractor<string> {\n  /**\n   * extracts RosenData from given lock transaction in CardanoTx format\n   * @param serializedTransaction stringified transaction in CardanoTx format\n   */\n  get = (serializedTransaction: string): RosenData | undefined => {\n    let transaction: CardanoTx;\n    try {\n      transaction = JSONBigInt.parse(serializedTransaction);\n    } catch (e) {\n      throw new Error(\n        `Failed to parse transaction json to CardanoTx format while extracting rosen data: ${e}`\n      );\n    }\n    const baseError = `No rosen data found for tx [${transaction.id}]`;\n    const rosenMetadata = transaction.metadata?.['0'];\n    if (\n      rosenMetadata &&\n      'to' in rosenMetadata &&\n      'bridgeFee' in rosenMetadata &&\n      'networkFee' in rosenMetadata &&\n      'toAddress' in rosenMetadata &&\n      'fromAddress' in rosenMetadata\n    ) {\n      const data = rosenMetadata as unknown as CardanoMetadataRosenData;\n      const lockOutputs = transaction.outputs.filter(\n        (output) => output.address === this.lockAddress\n      );\n      for (const output of lockOutputs) {\n        const assetTransformation = this.getAssetTransformation(\n          output,\n          data.to\n        );\n        if (assetTransformation) {\n          return {\n            toChain: data.to,\n            toAddress: data.toAddress,\n            bridgeFee: data.bridgeFee,\n            networkFee: data.networkFee,\n            fromAddress: data.fromAddress.join(''),\n            sourceChainTokenId: assetTransformation.from,\n            amount: assetTransformation.amount,\n            targetChainTokenId: assetTransformation.to,\n            sourceTxId: transaction.id,\n          };\n        }\n      }\n      this.logger.debug(\n        baseError + `: No valid transformation found in any output boxes`\n      );\n    } else\n      this.logger.debug(\n        baseError +\n          `: Incomplete metadata: ${Utils.JsonBI.stringify(\n            transaction.metadata\n          )}`\n      );\n    return undefined;\n  };\n\n  /**\n   * extracts and builds token transformation from CardanoBoxCandidate and tokenMap\n   * @param box transaction output in CardanoBoxCandidate format\n   * @param toChain event target chain\n   */\n  getAssetTransformation = (\n    box: CardanoBoxCandidate,\n    toChain: string\n  ): TokenTransformation | undefined => {\n    // try to build transformation using locked assets\n    if (box.assets.length > 0) {\n      for (const asset of box.assets) {\n        const token = this.tokens.search(CARDANO_CHAIN, {\n          assetName: asset.asset_name,\n          policyId: asset.policy_id,\n        });\n        if (token.length > 0)\n          return {\n            from: this.tokens.getID(token[0], CARDANO_CHAIN),\n            to: this.tokens.getID(token[0], toChain),\n            amount: asset.quantity,\n          };\n      }\n    }\n\n    // try to build transformation using locked ADA\n    const lovelace = this.tokens.search(CARDANO_CHAIN, {\n      [this.tokens.getIdKey(CARDANO_CHAIN)]: CARDANO_NATIVE_TOKEN,\n    });\n    if (lovelace.length > 0) {\n      return {\n        from: CARDANO_NATIVE_TOKEN,\n        to: this.tokens.getID(lovelace[0], toChain),\n        amount: box.value.toString(),\n      };\n    } else {\n      this.logger.debug(\n        `No rosen asset transformation found for CardanoBoxCandidate with assets: ${Utils.JsonBI.stringify(\n          box.assets\n        )}`\n      );\n      return undefined;\n    }\n  };\n}\n"]}
import AbstractRosenDataExtractor from '../abstract/AbstractRosenDataExtractor';
import { ERGO_CHAIN, ERGO_NATIVE_TOKEN } from '../const';
import { Address, Constant } from 'ergo-lib-wasm-nodejs';
import Utils from '../Utils';
export class ErgoNodeRosenExtractor extends AbstractRosenDataExtractor {

@@ -17,4 +18,6 @@ lockErgoTree;

get = (transaction) => {
const baseError = `No rosen data found for tx [${transaction.id}]`;
try {
for (const box of transaction.outputs) {
const boxBaseError = `No rosen data found in box [${box.boxId}]`;
if (box.ergoTree === this.lockErgoTree && box.additionalRegisters?.R4) {

@@ -41,5 +44,16 @@ const R4 = Constant.decode_from_base16(box.additionalRegisters.R4);

}
else
this.logger.debug(boxBaseError +
`: length of data in R4 is less than expected [${R4Serialized.length} < 5]`);
}
}
else {
if (box.ergoTree !== this.lockErgoTree)
this.logger.debug(boxBaseError +
`: invalid ergo tree [${box.ergoTree} !== ${this.lockErgoTree}]`);
else
this.logger.debug(boxBaseError + `: no R4`);
}
}
this.logger.debug(baseError + `: No valid rosen data found in any output box registers`);
}

@@ -85,6 +99,8 @@ catch (e) {

}
else
else {
this.logger.debug(`No rosen asset transformation found for box [${box.boxId}]: box assets: ${Utils.JsonBI.stringify(box.assets)}`);
return undefined;
}
};
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ErgoNodeRosenExtractor.js","sourceRoot":"","sources":["../../../../lib/getRosenData/ergo/ErgoNodeRosenExtractor.ts"],"names":[],"mappings":"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","sourcesContent":["import { RosenData } from '../abstract/types';\nimport AbstractRosenDataExtractor from '../abstract/AbstractRosenDataExtractor';\nimport { ERGO_CHAIN, ERGO_NATIVE_TOKEN } from '../const';\nimport { NodeOutputBox, NodeTransaction, TokenTransformation } from './types';\nimport { RosenTokens } from '@rosen-bridge/tokens';\nimport { Address, Constant } from 'ergo-lib-wasm-nodejs';\nimport { AbstractLogger } from '@rosen-bridge/logger-interface';\n\nexport class ErgoNodeRosenExtractor extends AbstractRosenDataExtractor<NodeTransaction> {\n  lockErgoTree: string;\n\n  constructor(\n    lockAddress: string,\n    tokens: RosenTokens,\n    logger?: AbstractLogger\n  ) {\n    super(lockAddress, tokens, logger);\n    this.lockErgoTree = Address.from_base58(lockAddress)\n      .to_ergo_tree()\n      .to_base16_bytes();\n  }\n\n  /**\n   * extracts RosenData from given lock transaction in Node format\n   * @param transaction the lock transaction in Node format\n   */\n  get = (transaction: NodeTransaction): RosenData | undefined => {\n    try {\n      for (const box of transaction.outputs) {\n        if (box.ergoTree === this.lockErgoTree && box.additionalRegisters?.R4) {\n          const R4 = Constant.decode_from_base16(box.additionalRegisters.R4);\n          if (R4) {\n            const R4Serialized = R4.to_coll_coll_byte();\n            if (R4Serialized.length >= 5) {\n              const toChain = Buffer.from(R4Serialized[0]).toString();\n\n              const assetTransformation = this.getAssetTransformation(\n                box,\n                toChain\n              );\n              if (assetTransformation) {\n                return {\n                  toChain: toChain,\n                  toAddress: Buffer.from(R4Serialized[1]).toString(),\n                  bridgeFee: Buffer.from(R4Serialized[3]).toString(),\n                  networkFee: Buffer.from(R4Serialized[2]).toString(),\n                  fromAddress: Buffer.from(R4Serialized[4]).toString(),\n                  sourceChainTokenId: assetTransformation.from,\n                  amount: assetTransformation.amount.toString(),\n                  targetChainTokenId: assetTransformation.to,\n                  sourceTxId: transaction.id,\n                };\n              }\n            }\n          }\n        }\n      }\n    } catch (e) {\n      this.logger.debug(\n        `An error occurred while getting Ergo rosen data: ${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 NodeOutputBox and tokenMap\n   * @param box transaction output\n   * @param toChain event target chain\n   */\n  getAssetTransformation = (\n    box: NodeOutputBox,\n    toChain: string\n  ): TokenTransformation | undefined => {\n    // try to build transformation using locked tokens\n    if (box.assets && box.assets.length > 0) {\n      for (const lockedToken of box.assets) {\n        const token = this.tokens.search(ERGO_CHAIN, {\n          [this.tokens.getIdKey(ERGO_CHAIN)]: lockedToken.tokenId,\n        });\n        if (token.length > 0)\n          return {\n            from: this.tokens.getID(token[0], ERGO_CHAIN),\n            to: this.tokens.getID(token[0], toChain),\n            amount: lockedToken.amount,\n          };\n      }\n    }\n\n    // try to build transformation using locked Erg\n    const erg = this.tokens.search(ERGO_CHAIN, {\n      [this.tokens.getIdKey(ERGO_CHAIN)]: ERGO_NATIVE_TOKEN,\n    });\n    if (erg.length > 0) {\n      return {\n        from: ERGO_NATIVE_TOKEN,\n        to: this.tokens.getID(erg[0], toChain),\n        amount: box.value,\n      };\n    } else return undefined;\n  };\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ErgoNodeRosenExtractor.js","sourceRoot":"","sources":["../../../../lib/getRosenData/ergo/ErgoNodeRosenExtractor.ts"],"names":[],"mappings":"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","sourcesContent":["import { RosenData } from '../abstract/types';\nimport AbstractRosenDataExtractor from '../abstract/AbstractRosenDataExtractor';\nimport { ERGO_CHAIN, ERGO_NATIVE_TOKEN } from '../const';\nimport { NodeOutputBox, NodeTransaction, TokenTransformation } from './types';\nimport { RosenTokens } from '@rosen-bridge/tokens';\nimport { Address, Constant } from 'ergo-lib-wasm-nodejs';\nimport { AbstractLogger } from '@rosen-bridge/logger-interface';\nimport Utils from '../Utils';\n\nexport class ErgoNodeRosenExtractor extends AbstractRosenDataExtractor<NodeTransaction> {\n  lockErgoTree: string;\n\n  constructor(\n    lockAddress: string,\n    tokens: RosenTokens,\n    logger?: AbstractLogger\n  ) {\n    super(lockAddress, tokens, logger);\n    this.lockErgoTree = Address.from_base58(lockAddress)\n      .to_ergo_tree()\n      .to_base16_bytes();\n  }\n\n  /**\n   * extracts RosenData from given lock transaction in Node format\n   * @param transaction the lock transaction in Node format\n   */\n  get = (transaction: NodeTransaction): RosenData | undefined => {\n    const baseError = `No rosen data found for tx [${transaction.id}]`;\n    try {\n      for (const box of transaction.outputs) {\n        const boxBaseError = `No rosen data found in box [${box.boxId}]`;\n        if (box.ergoTree === this.lockErgoTree && box.additionalRegisters?.R4) {\n          const R4 = Constant.decode_from_base16(box.additionalRegisters.R4);\n          if (R4) {\n            const R4Serialized = R4.to_coll_coll_byte();\n            if (R4Serialized.length >= 5) {\n              const toChain = Buffer.from(R4Serialized[0]).toString();\n\n              const assetTransformation = this.getAssetTransformation(\n                box,\n                toChain\n              );\n              if (assetTransformation) {\n                return {\n                  toChain: toChain,\n                  toAddress: Buffer.from(R4Serialized[1]).toString(),\n                  bridgeFee: Buffer.from(R4Serialized[3]).toString(),\n                  networkFee: Buffer.from(R4Serialized[2]).toString(),\n                  fromAddress: Buffer.from(R4Serialized[4]).toString(),\n                  sourceChainTokenId: assetTransformation.from,\n                  amount: assetTransformation.amount.toString(),\n                  targetChainTokenId: assetTransformation.to,\n                  sourceTxId: transaction.id,\n                };\n              }\n            } else\n              this.logger.debug(\n                boxBaseError +\n                  `: length of data in R4 is less than expected [${R4Serialized.length} < 5]`\n              );\n          }\n        } else {\n          if (box.ergoTree !== this.lockErgoTree)\n            this.logger.debug(\n              boxBaseError +\n                `: invalid ergo tree [${box.ergoTree} !== ${this.lockErgoTree}]`\n            );\n          else this.logger.debug(boxBaseError + `: no R4`);\n        }\n      }\n      this.logger.debug(\n        baseError + `: No valid rosen data found in any output box registers`\n      );\n    } catch (e) {\n      this.logger.debug(\n        `An error occurred while getting Ergo rosen data: ${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 NodeOutputBox and tokenMap\n   * @param box transaction output\n   * @param toChain event target chain\n   */\n  getAssetTransformation = (\n    box: NodeOutputBox,\n    toChain: string\n  ): TokenTransformation | undefined => {\n    // try to build transformation using locked tokens\n    if (box.assets && box.assets.length > 0) {\n      for (const lockedToken of box.assets) {\n        const token = this.tokens.search(ERGO_CHAIN, {\n          [this.tokens.getIdKey(ERGO_CHAIN)]: lockedToken.tokenId,\n        });\n        if (token.length > 0)\n          return {\n            from: this.tokens.getID(token[0], ERGO_CHAIN),\n            to: this.tokens.getID(token[0], toChain),\n            amount: lockedToken.amount,\n          };\n      }\n    }\n\n    // try to build transformation using locked Erg\n    const erg = this.tokens.search(ERGO_CHAIN, {\n      [this.tokens.getIdKey(ERGO_CHAIN)]: ERGO_NATIVE_TOKEN,\n    });\n    if (erg.length > 0) {\n      return {\n        from: ERGO_NATIVE_TOKEN,\n        to: this.tokens.getID(erg[0], toChain),\n        amount: box.value,\n      };\n    } else {\n      this.logger.debug(\n        `No rosen asset transformation found for box [${\n          box.boxId\n        }]: box assets: ${Utils.JsonBI.stringify(box.assets)}`\n      );\n      return undefined;\n    }\n  };\n}\n"]}

2

package.json
{
"name": "@rosen-bridge/rosen-extractor",
"version": "0.1.10",
"version": "0.1.11",
"description": "this project contains methods to get rosen data from blockchain",

@@ -5,0 +5,0 @@ "main": "dist/lib/index.js",

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc