2023-06-23 09:14:13 +00:00
|
|
|
import { atom, computed } from 'nanostores';
|
|
|
|
import createClient from 'openapi-fetch';
|
|
|
|
import { paths } from 'services/api/schema';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* We use nanostores to store the token and base url for very simple reactivity
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The user's auth token.
|
|
|
|
*/
|
|
|
|
export const $authToken = atom<string | undefined>();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The OpenAPI base url.
|
|
|
|
*/
|
|
|
|
export const $baseUrl = atom<string | undefined>();
|
|
|
|
|
2023-08-02 13:46:29 +00:00
|
|
|
/**
|
|
|
|
* The optional project-id header.
|
|
|
|
*/
|
|
|
|
export const $projectId = atom<string | undefined>();
|
|
|
|
|
2023-06-23 09:14:13 +00:00
|
|
|
/**
|
|
|
|
* Autogenerated, type-safe fetch client for the API. Used when RTK Query is not an option.
|
|
|
|
* Dynamically updates when the token or base url changes.
|
|
|
|
* Use `$client.get()` to get the client.
|
|
|
|
*
|
|
|
|
* @example
|
|
|
|
* const { get, post, del } = $client.get();
|
|
|
|
*/
|
2023-08-02 13:46:29 +00:00
|
|
|
export const $client = computed([$authToken, $baseUrl, $projectId], (authToken, baseUrl, projectId) =>
|
2023-06-23 09:14:13 +00:00
|
|
|
createClient<paths>({
|
2023-08-02 13:46:29 +00:00
|
|
|
headers: {
|
|
|
|
...(authToken ? { Authorization: `Bearer ${authToken}` } : {}),
|
|
|
|
...(projectId ? { "project-id": projectId } : {})
|
|
|
|
},
|
2023-06-23 09:14:13 +00:00
|
|
|
// do not include `api/v1` in the base url for this client
|
|
|
|
baseUrl: `${baseUrl ?? ''}`,
|
|
|
|
})
|
|
|
|
);
|