From 95e89d56d14ad5d82734ca138c016c8c70a50c13 Mon Sep 17 00:00:00 2001 From: Paul <108695806+pxrl@users.noreply.github.com> Date: Fri, 27 Oct 2023 00:47:01 +0200 Subject: [PATCH] improve(suggested-fees): Filter underlying simulation reasons (#885) --- api/_utils.ts | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/api/_utils.ts b/api/_utils.ts index 2d0d6948b..08d46c223 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(`Relayer fill simulation failed - ${reason}`); } }; @@ -729,6 +727,15 @@ export function applyMapFilter( }, []); } +export function resolveEthersError(err: unknown): string { + // prettier-ignore + 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