budibase/packages/client/src/api/index.js

60 lines
1.3 KiB
JavaScript
Raw Normal View History

import { authenticate } from "./authenticate"
import { triggerWorkflow } from "./workflow"
2020-08-06 22:12:35 +02:00
import appStore from "../state/store"
const apiCall = method => async ({ url, body }) => {
const response = await fetch(url, {
method: method,
headers: {
"Content-Type": "application/json",
},
body: body && JSON.stringify(body),
credentials: "same-origin",
})
switch (response.status) {
case 200:
return response.json()
case 404:
return error(`${url} Not found`)
case 400:
return error(`${url} Bad Request`)
case 403:
return error(`${url} Forbidden`)
default:
if (response.status >= 200 && response.status < 400) {
2020-05-26 22:34:01 +02:00
return response.json()
2020-08-06 22:12:35 +02:00
}
return error(`${url} - ${response.statusText}`)
}
2020-08-06 22:12:35 +02:00
}
2019-09-23 07:08:06 +02:00
2020-08-06 22:12:35 +02:00
const post = apiCall("POST")
const get = apiCall("GET")
const patch = apiCall("PATCH")
const del = apiCall("DELETE")
2019-09-23 07:08:06 +02:00
2020-08-06 22:12:35 +02:00
const ERROR_MEMBER = "##error"
const error = message => {
const err = { [ERROR_MEMBER]: message }
appStore.update(s => s["##error_message"], message)
return err
}
2019-09-23 07:08:06 +02:00
2020-08-06 22:12:35 +02:00
const isSuccess = obj => !obj || !obj[ERROR_MEMBER]
2019-09-23 07:08:06 +02:00
2020-08-06 22:12:35 +02:00
const apiOpts = {
isSuccess,
error,
post,
get,
patch,
delete: del,
}
export default {
authenticate: authenticate(apiOpts),
triggerWorkflow: triggerWorkflow(apiOpts),
2019-09-23 07:08:06 +02:00
}