Skip to content

Commit

Permalink
refactor: fetch api functionality
Browse files Browse the repository at this point in the history
  • Loading branch information
PritishBudhiraja committed Oct 30, 2024
1 parent 4fd172d commit 635cec3
Showing 1 changed file with 45 additions and 24 deletions.
69 changes: 45 additions & 24 deletions src/Utilities/Utils.res
Original file line number Diff line number Diff line change
Expand Up @@ -826,6 +826,7 @@ let delay = timeOut => {
}, timeOut)->ignore
})
}

let getHeaders = (~uri=?, ~token=?, ~headers=Dict.make()) => {
let headerObj =
[
Expand All @@ -848,30 +849,6 @@ let getHeaders = (~uri=?, ~token=?, ~headers=Dict.make()) => {
})
Fetch.Headers.fromObject(headerObj->dictToObj)
}
let fetchApi = (uri, ~bodyStr: string="", ~headers=Dict.make(), ~method: Fetch.method) => {
open Promise
let body = switch method {
| #GET => resolve(None)
| _ => resolve(Some(Fetch.Body.string(bodyStr)))
}
body->then(body => {
Fetch.fetch(
uri,
{
method,
?body,
headers: getHeaders(~headers, ~uri),
},
)
->catch(err => {
reject(err)
})
->then(resp => {
resolve(resp)
})
})
}

let arrayJsonToCamelCase = arr => {
arr->Array.map(item => {
item->transformKeys(CamelCase)
Expand Down Expand Up @@ -901,6 +878,50 @@ let formatException = exc =>
]
}->getJsonFromArrayOfJson

let fetchApi = async (uri, ~bodyStr: string="", ~headers=Dict.make(), ~method: Fetch.method) => {
try {
let body = switch method {
| #GET => None
| _ => Some(Fetch.Body.string(bodyStr))
}

let response = await Fetch.fetch(
uri,
{
method,
?body,
headers: getHeaders(~headers, ~uri),
},
)

if !(response->Fetch.Response.ok) {
let errorText = await response->Fetch.Response.text
let status = response->Fetch.Response.status
let errorMessage = `FetchError: Failed to fetch (${status->Int.toString}): ${errorText}`
Error.raise(Error.make(errorMessage))
}

response
} catch {
| Exn.Error(error) => {
let errorMessage = switch Exn.message(error) {
| Some(msg) => msg
| None => "Unknown error occurred"
}

let enhancedError = Error.make(`APIError: ${errorMessage} (URL: ${uri})`)
Error.raise(enhancedError)
}
| err => {
let exceptionVal = err->formatException->getDictFromJson
let errorMessage = exceptionVal->getString("message", "Unknown error")
let errorType = exceptionVal->getString("type", "Unknown")
let networkError = Error.make(`${errorType}: ${errorMessage} (URL: ${uri})`)
Error.raise(networkError)
}
}
}

let getArrayValFromJsonDict = (dict, key, arrayKey) => {
dict
->Dict.get(key)
Expand Down

0 comments on commit 635cec3

Please sign in to comment.