1
0
Fork 0
freesewing/sites/shared/hooks/use-backend.mjs
2023-05-26 17:24:25 +02:00

253 lines
6.4 KiB
JavaScript

import axios from 'axios'
import { freeSewingConfig } from 'shared/config/freesewing.config.mjs'
/*
* Helper methods to interact with the FreeSewing backend
*/
const apiHandler = axios.create({
baseURL: freeSewingConfig.backend,
timeout: 3000,
})
/*
* This api object handles async code for different HTTP methods
*/
const api = {
get: async (uri, config = {}) => {
let result
try {
result = await apiHandler.get(uri, config)
return result
} catch (err) {
return err
}
},
post: async (uri, data = null, config = {}) => {
let result
try {
result = await apiHandler.post(uri, data, config)
return result
} catch (err) {
return err
}
},
patch: async (uri, data = null, config = {}) => {
let result
try {
result = await apiHandler.patch(uri, data, config)
return result
} catch (err) {
return err
}
},
delete: async (uri, config = {}) => {
let result
try {
result = await apiHandler.delete(uri, config)
return result
} catch (err) {
return err
}
},
}
/*
* Helper method to handle the response and verify that it was successful
*/
const responseHandler = (response, expectedStatus = 200, expectData = true) => {
if (response && response.status === expectedStatus) {
if (!expectData || response.data) {
return { success: true, data: response.data, response }
}
return { success: true, response }
}
return { success: false, response }
}
export function useBackend(token = false) {
/*
* Set up authentication headers
*/
const auth = token ? { headers: { Authorization: 'Bearer ' + token } } : {}
/*
* This backend object is what we'll end up returning
*/
const backend = {}
/*
* backend.signUp: User signup
*/
backend.signUp = async ({ email, language }) =>
responseHandler(await api.post('/signup', { email, language }), 201)
/*
* backend.loadConfirmation: Load a confirmation
*/
backend.loadConfirmation = async ({ id, check }) =>
responseHandler(await api.get(`/confirmations/${id}/${check}`))
/*
* backend.confirmSignup: Confirm a signup
*/
backend.confirmSignup = async ({ id, consent }) =>
responseHandler(await api.post(`/confirm/signup/${id}`, { consent }))
/*
* backend.signIn: User signin/login
*/
backend.signIn = async ({ username, password = false, token = false }) =>
password === false
? responseHandler(await api.post('/signinlink', { username }))
: responseHandler(await api.post('/signin', { username, password, token }))
/*
* backend.signInFromLink: Trade in sign-in link id & check for JWT token
*/
backend.signInFromLink = async ({ id, check }) =>
responseHandler(await api.post(`/signinlink/${id}/${check}`))
/*
* Generic update account method
*/
backend.updateAccount = async (data) =>
responseHandler(await api.patch(`/account/jwt`, data, auth))
/*
* Checks whether a username is available
*/
backend.isUsernameAvailable = async (username) => {
const response = await api.post(`/available/username/jwt`, { username }, auth)
// 404 means username is available, which is success in this case
return response.status === 404
? { success: true, data: false, available: true, response }
: { success: false, available: false, response }
}
/*
* Remove account method
*/
backend.removeAccount = async () => responseHandler(await api.delete(`/account/jwt`, auth))
/*
* Enable MFA
*/
backend.enableMfa = async () =>
responseHandler(await api.post(`/account/mfa/jwt`, { mfa: true }, auth))
/*
* Confirm MFA
*/
backend.confirmMfa = async (data) =>
responseHandler(await api.post(`/account/mfa/jwt`, { ...data, mfa: true }, auth))
/*
* Disable MFA
*/
backend.disableMfa = async (data) =>
responseHandler(await await api.post(`/account/mfa/jwt`, { ...data, mfa: false }, auth))
/*
* Reload account
*/
backend.reloadAccount = async () => responseHandler(await await api.get(`/whoami/jwt`, auth))
/*
* Create API key
*/
backend.createApikey = async (data) =>
responseHandler(await api.post(`/apikeys/jwt`, data, auth), 201)
/*
* Get API keys
*/
backend.getApikeys = async () => responseHandler(await api.get(`/apikeys/jwt`, auth))
/*
* Remove API key
*/
backend.removeApikey = async (id) => {
const response = await api.delete(`/apikeys/${id}/jwt`, auth)
return response && response.status === 204 ? true : false
}
/*
* Get measurements sets
*/
backend.getSets = async () => responseHandler(await api.get(`/sets/jwt`, auth))
/*
* Get measurements set
*/
backend.getSet = async (id) => responseHandler(await api.get(`/sets/${id}/jwt`, auth))
/*
* Create measurements set
*/
backend.createSet = async (data) => responseHandler(await api.post(`/sets/jwt`, data, auth), 201)
/*
* Remove measurements set
*/
backend.removeSet = async (id) => {
const response = await api.delete(`/sets/${id}/jwt`, auth)
return response && response.status === 204 ? true : false
}
/*
* Generic update measurements set method
*/
backend.updateSet = async (id, data) =>
responseHandler(await api.patch(`/sets/${id}/jwt`, data, auth))
/*
* Get curated measurements sets
*/
backend.getCuratedSets = async () => responseHandler(await api.get(`/curated-sets`))
/*
* Get curated measurements set
*/
backend.getCuratedSet = async (id) => responseHandler(await api.get(`/curated-sets/${id}`))
/*
* Remove curated measurements set
*/
backend.removeCuratedMeasurementsSet = async (id) => {
const response = await api.delete(`/curated-sets/${id}/jwt`, auth)
return response && response.status === 204 ? true : false
}
/*
* Get patterns
*/
backend.getPatterns = async () => responseHandler(await api.get(`/patterns/jwt`, auth))
/*
* Create pattern
*/
backend.createPattern = async (data) =>
responseHandler(await api.post(`/patterns/jwt`, data, auth), 201)
/*
* Remove pattern
*/
backend.removePattern = async (id) => {
const response = await api.delete(`/patterns/${id}/jwt`, auth)
return response && response.status === 204 ? true : false
}
/*
* Generic update pattern set method
*/
backend.updatePattern = async (id, data) =>
responseHandler(await api.patch(`/patterns/${id}/jwt`, data, auth))
return backend
}