42 lines
1.2 KiB
TypeScript
42 lines
1.2 KiB
TypeScript
// Solar Network aka the api client
|
|
import { keysToCamel, keysToSnake } from "~/utils/transformKeys"
|
|
|
|
export const useSolarNetwork = () => {
|
|
const apiBase = useSolarNetworkUrl()
|
|
|
|
// Access SSR request event only on the server
|
|
const event = import.meta.server ? useRequestEvent() : null
|
|
|
|
// Forward cookies from the incoming request
|
|
const headers: HeadersInit = import.meta.server && event
|
|
? { cookie: event.headers.get('cookie') ?? '' }
|
|
: {}
|
|
|
|
return $fetch.create({
|
|
baseURL: apiBase,
|
|
credentials: "include",
|
|
headers,
|
|
// Add Authorization header with Bearer token
|
|
onRequest: ({ request, options }) => {
|
|
const side = import.meta.server ? "SERVER" : "CLIENT"
|
|
console.log(`[useSolarNetwork] onRequest for ${request} on ${side}`)
|
|
|
|
// Transform request data from camelCase to snake_case
|
|
if (options.body && typeof options.body === "object") {
|
|
options.body = keysToSnake(options.body)
|
|
}
|
|
},
|
|
// Transform response keys from snake_case to camelCase
|
|
onResponse: ({ response }) => {
|
|
if (response._data) {
|
|
response._data = keysToCamel(response._data)
|
|
}
|
|
}
|
|
})
|
|
}
|
|
|
|
export const useSolarNetworkUrl = () => {
|
|
const config = useRuntimeConfig()
|
|
return config.public.apiBase
|
|
}
|