diff --git a/api/_utils.ts b/api/_utils.ts index 2d0d6948b..26b6b982f 100644 --- a/api/_utils.ts +++ b/api/_utils.ts @@ -524,11 +524,9 @@ export const getRelayerFeeDetails = async ( relayerAddress, tokenPrice ); - } catch (_e: unknown) { - // Resolve and transform the error - const e = _e as Error; - // We want to mask this error as an Input error. - throw new InputError(e?.message); + } catch (err: unknown) { + const reason = resolveEthersError(err); + throw new InputError(`Failed to estimate relayer fees (${reason})`); } }; @@ -729,6 +727,14 @@ export function applyMapFilter( }, []); } +export function resolveEthersError(err: unknown): string { + return sdk.typeguards.isEthersError(err) + ? `${err.reason}: ${err.code}` + : sdk.typeguards.isError(err) + ? err.message + : "unknown error"; +} + /** * Handles the recurring case of error handling * @param endpoint A string numeric to indicate to the logging utility where this error occurs