From 458baf71a4aca9efb1f12888645c738be61bae12 Mon Sep 17 00:00:00 2001 From: Rodrigo <95635797+poly-rodr@users.noreply.github.com> Date: Fri, 17 May 2024 12:40:34 -0300 Subject: [PATCH] Handling API and network errors --- package.json | 2 +- src/http-helpers/index.ts | 101 ++++++++++++++++++++++++++++---------- 2 files changed, 76 insertions(+), 27 deletions(-) diff --git a/package.json b/package.json index 3f030ca..2d131c6 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "name": "@polymarket/clob-client", "description": "Typescript client for Polymarket's CLOB", - "version": "4.5.3", + "version": "4.5.4", "contributors": [ { "name": "Jonathan Amenechi", diff --git a/src/http-helpers/index.ts b/src/http-helpers/index.ts index 48f4f4c..42103e5 100644 --- a/src/http-helpers/index.ts +++ b/src/http-helpers/index.ts @@ -1,3 +1,4 @@ +/* eslint-disable max-depth */ import axios, { AxiosRequestHeaders, Method } from "axios"; import { DropNotificationParams, OrdersScoringParams } from "src/types"; import { isBrowser } from "browser-or-node"; @@ -35,26 +36,8 @@ export const request = async ( data?: any, params?: any, ): Promise => { - try { - overloadHeaders(method, headers); - const response = await axios({ method, url: endpoint, headers, data, params }); - return response; - } catch (err) { - if (axios.isAxiosError(err)) { - if (err.response) { - console.error("request error", { - status: err.response?.status, - statusText: err.response?.statusText, - data: err.response?.data, - }); - return err.response?.data; - } else { - return { error: "connection error" }; - } - } - - return { error: err }; - } + overloadHeaders(method, headers); + return await axios({ method, url: endpoint, headers, data, params }); }; export type QueryParams = Record; @@ -66,18 +49,84 @@ export interface RequestOptions { } export const post = async (endpoint: string, options?: RequestOptions): Promise => { - const resp = await request(endpoint, POST, options?.headers, options?.data, options?.params); - return "error" in resp ? resp : resp.data; + try { + const resp = await request( + endpoint, + POST, + options?.headers, + options?.data, + options?.params, + ); + return resp.data; + } catch (err: unknown) { + return errorHandling(err); + } }; export const get = async (endpoint: string, options?: RequestOptions): Promise => { - const resp = await request(endpoint, GET, options?.headers, options?.data, options?.params); - return "error" in resp ? resp : resp.data; + try { + const resp = await request(endpoint, GET, options?.headers, options?.data, options?.params); + return resp.data; + } catch (err: unknown) { + return errorHandling(err); + } }; export const del = async (endpoint: string, options?: RequestOptions): Promise => { - const resp = await request(endpoint, DELETE, options?.headers, options?.data, options?.params); - return "error" in resp ? resp : resp.data; + try { + const resp = await request( + endpoint, + DELETE, + options?.headers, + options?.data, + options?.params, + ); + return resp.data; + } catch (err: unknown) { + return errorHandling(err); + } +}; + +const errorHandling = (err: unknown) => { + if (axios.isAxiosError(err)) { + if (err.response) { + console.error( + "[CLOB Client] request error", + JSON.stringify({ + status: err.response?.status, + statusText: err.response?.statusText, + data: err.response?.data, + config: err.response?.config, + }), + ); + if (err.response?.data) { + if ( + typeof err.response?.data === "string" || + err.response?.data instanceof String + ) { + return { error: err.response?.data }; + } + if (!Object.prototype.hasOwnProperty.call(err.response?.data, "error")) { + return { error: err.response?.data }; + } + // in this case the field 'error' is included + return err.response?.data; + } + } + + if (err.message) { + console.error( + "[CLOB Client] request error", + JSON.stringify({ + error: err.message, + }), + ); + return { error: err.message }; + } + } + + console.error("[CLOB Client] request error", err); + return { error: err }; }; export const parseOrdersScoringParams = (orderScoringParams?: OrdersScoringParams): QueryParams => {