From 42b76b2dff2c33ca79aa16d9e498880e7cc8a0db Mon Sep 17 00:00:00 2001 From: DrMint <29893320+DrMint@users.noreply.github.com> Date: Sat, 15 Jun 2024 09:53:34 +0200 Subject: [PATCH] Added option for response caching in SDK --- src/sdk.ts | 77 +++++++++++++++++++++++++++++++----------------------- 1 file changed, 44 insertions(+), 33 deletions(-) diff --git a/src/sdk.ts b/src/sdk.ts index fd21f32..0dcb04c 100644 --- a/src/sdk.ts +++ b/src/sdk.ts @@ -467,17 +467,25 @@ type GetPayloadSDKParams = { apiURL: string; email: string; password: string; - cache: Cache; -}; - -type Cache = { - set: (token: string, expirationTimestamp: number) => void; - get: () => string | undefined; + tokenCache?: { + set: (token: string, expirationTimestamp: number) => void; + get: () => string | undefined; + }; + responseCache?: { + set: (url: string, response: any) => void; + get: (url: string) => any | undefined; + }; }; const logResponse = (res: Response) => console.log(res.status, res.statusText, res.url); -export const getPayloadSDK = ({ apiURL, email, password, cache }: GetPayloadSDKParams) => { +export const getPayloadSDK = ({ + apiURL, + email, + password, + tokenCache, + responseCache, +}: GetPayloadSDKParams) => { const refreshToken = async () => { const loginUrl = payloadApiUrl(Collections.Recorders, "login"); const loginResult = await fetch(loginUrl, { @@ -495,72 +503,75 @@ export const getPayloadSDK = ({ apiURL, email, password, cache }: GetPayloadSDKP token: string; exp: number; }; - cache.set(token, exp); + tokenCache?.set(token, exp); return token; }; const payloadApiUrl = (collection: Collections, endpoint?: string, isGlobal?: boolean): string => `${apiURL}/${isGlobal === undefined ? "" : "globals/"}${collection}${endpoint === undefined ? "" : `/${endpoint}`}`; - const request = async (url: string): Promise => { + const request = async (url: string): Promise => { + const cachedResponse = responseCache?.get(url); + if (cachedResponse) { + return cachedResponse; + } + const result = await fetch(url, { headers: { - Authorization: `JWT ${cache.get() ?? (await refreshToken())}`, + Authorization: `JWT ${tokenCache?.get() ?? (await refreshToken())}`, }, }); logResponse(result); - if (result.status !== 200) { + if (!result.ok) { throw new Error("Unhandled fetch error"); } - return result; + const data = await result.json(); + responseCache?.set(url, data); + return data; }; return { getConfig: async (): Promise => - await (await request(payloadApiUrl(Collections.WebsiteConfig, `config`, true))).json(), + await request(payloadApiUrl(Collections.WebsiteConfig, `config`, true)), getFolder: async (slug: string): Promise => - await (await request(payloadApiUrl(Collections.Folders, `slug/${slug}`))).json(), + await request(payloadApiUrl(Collections.Folders, `slug/${slug}`)), getLanguages: async (): Promise => - await (await request(payloadApiUrl(Collections.Languages, `all`))).json(), + await request(payloadApiUrl(Collections.Languages, `all`)), getCurrencies: async (): Promise => - await (await request(payloadApiUrl(Collections.Currencies, `all`))).json(), + await request(payloadApiUrl(Collections.Currencies, `all`)), getWordings: async (): Promise => - await (await request(payloadApiUrl(Collections.Wordings, `all`))).json(), + await request(payloadApiUrl(Collections.Wordings, `all`)), getPage: async (slug: string): Promise => - await (await request(payloadApiUrl(Collections.Pages, `slug/${slug}`))).json(), + await request(payloadApiUrl(Collections.Pages, `slug/${slug}`)), getCollectible: async (slug: string): Promise => - await (await request(payloadApiUrl(Collections.Collectibles, `slug/${slug}`))).json(), + await request(payloadApiUrl(Collections.Collectibles, `slug/${slug}`)), getCollectibleScans: async (slug: string): Promise => - await (await request(payloadApiUrl(Collections.Collectibles, `slug/${slug}/scans`))).json(), + await request(payloadApiUrl(Collections.Collectibles, `slug/${slug}/scans`)), getCollectibleScanPage: async ( slug: string, index: string ): Promise => - await ( - await request(payloadApiUrl(Collections.Collectibles, `slug/${slug}/scans/${index}`)) - ).json(), + await request(payloadApiUrl(Collections.Collectibles, `slug/${slug}/scans/${index}`)), getCollectibleGallery: async (slug: string): Promise => - await (await request(payloadApiUrl(Collections.Collectibles, `slug/${slug}/gallery`))).json(), + await request(payloadApiUrl(Collections.Collectibles, `slug/${slug}/gallery`)), getCollectibleGalleryImage: async ( slug: string, index: string ): Promise => - await ( - await request(payloadApiUrl(Collections.Collectibles, `slug/${slug}/gallery/${index}`)) - ).json(), + await request(payloadApiUrl(Collections.Collectibles, `slug/${slug}/gallery/${index}`)), getChronologyEvents: async (): Promise => - await (await request(payloadApiUrl(Collections.ChronologyEvents, `all`))).json(), + await request(payloadApiUrl(Collections.ChronologyEvents, `all`)), getChronologyEventByID: async (id: string): Promise => - await (await request(payloadApiUrl(Collections.ChronologyEvents, `id/${id}`))).json(), + await request(payloadApiUrl(Collections.ChronologyEvents, `id/${id}`)), getImageByID: async (id: string): Promise => - await (await request(payloadApiUrl(Collections.Images, `id/${id}`))).json(), + await request(payloadApiUrl(Collections.Images, `id/${id}`)), getAudioByID: async (id: string): Promise => - await (await request(payloadApiUrl(Collections.Audios, `id/${id}`))).json(), + await request(payloadApiUrl(Collections.Audios, `id/${id}`)), getVideoByID: async (id: string): Promise => - await (await request(payloadApiUrl(Collections.Videos, `id/${id}`))).json(), + await request(payloadApiUrl(Collections.Videos, `id/${id}`)), getRecorderByID: async (id: string): Promise => - await (await request(payloadApiUrl(Collections.Recorders, `id/${id}`))).json(), + await request(payloadApiUrl(Collections.Recorders, `id/${id}`)), }; };