@metamask/eth-trezor-keyring
Version:
A MetaMask compatible keyring, for trezor hardware wallets
58 lines • 2.58 kB
JavaScript
;
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