UNPKG

@metamask/eth-trezor-keyring

Version:

A MetaMask compatible keyring, for trezor hardware wallets

58 lines 2.58 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.getTrezorErrorMapping = exports.isKnownTrezorError = exports.createTrezorError = void 0; const hw_wallet_sdk_1 = require("@metamask/hw-wallet-sdk"); /** * Factory function to create a HardwareWalletError from a Trezor error identifier. * * @param trezorErrorIdentifier - The Trezor error identifier (e.g., 'Device_Disconnected', 'Method_Cancel') * @param context - Optional additional context to append to the error message * @returns A HardwareWalletError instance with mapped error details */ function createTrezorError(trezorErrorIdentifier, context) { var _a; const errorMapping = getTrezorErrorMapping(trezorErrorIdentifier); if (errorMapping) { const message = context ? `${errorMapping.message} (${context})` : errorMapping.message; return new hw_wallet_sdk_1.HardwareWalletError(message, { code: errorMapping.code, severity: errorMapping.severity, category: errorMapping.category, userMessage: (_a = errorMapping.userMessage) !== null && _a !== void 0 ? _a : message, }); } // Fallback for unknown error codes const fallbackMessage = context ? `Unknown Trezor error: ${trezorErrorIdentifier} (${context})` : `Unknown Trezor error: ${trezorErrorIdentifier}`; return new hw_wallet_sdk_1.HardwareWalletError(fallbackMessage, { code: hw_wallet_sdk_1.ErrorCode.Unknown, severity: hw_wallet_sdk_1.Severity.Err, category: hw_wallet_sdk_1.Category.Unknown, userMessage: fallbackMessage, }); } exports.createTrezorError = createTrezorError; /** * Checks if a Trezor error identifier exists in the error mappings. * * @param trezorErrorIdentifier - The Trezor error identifier to check * @returns True if the error identifier is mapped, false otherwise */ function isKnownTrezorError(trezorErrorIdentifier) { return trezorErrorIdentifier in hw_wallet_sdk_1.TREZOR_ERROR_MAPPINGS; } exports.isKnownTrezorError = isKnownTrezorError; /** * Gets the error mapping details for a Trezor error identifier without creating an error instance. * * @param trezorErrorIdentifier - The Trezor error identifier to look up * @returns The error mapping details or undefined if not found */ function getTrezorErrorMapping(trezorErrorIdentifier) { return hw_wallet_sdk_1.TREZOR_ERROR_MAPPINGS[trezorErrorIdentifier]; } exports.getTrezorErrorMapping = getTrezorErrorMapping; //# sourceMappingURL=trezor-errors.cjs.map