From 500ac715239c27dfaa62e5f969ca08a5d8b04371 Mon Sep 17 00:00:00 2001 From: arthurfiorette Date: Mon, 3 Jan 2022 09:13:02 -0300 Subject: [PATCH] refactor: added data property in memory storages --- src/storage/memory.ts | 34 +++++++++++++++++++++++++++++----- 1 file changed, 29 insertions(+), 5 deletions(-) diff --git a/src/storage/memory.ts b/src/storage/memory.ts index bd4e4370..6df45ceb 100644 --- a/src/storage/memory.ts +++ b/src/storage/memory.ts @@ -1,10 +1,34 @@ import { buildStorage } from './build'; import type { StorageValue } from './types'; -export function buildMemoryStorage(obj: Record = {}) { - return buildStorage({ - find: (key) => Promise.resolve(obj[key]), - set: (key, value) => Promise.resolve(void (obj[key] = value)), - remove: (key) => Promise.resolve(void delete obj[key]) +/** + * Creates a simple in-memory storage. This means that if you need to persist data between + * page or server reloads, this will not help. + * + * This is the storage used by default. + * + * If you need to modify it's data, you can do by the `data` property. + * + * @example + * + * ```js + * const memoryStorage = buildMemoryStorage(); + * + * setupCache(axios, { storage: memoryStorage }); + * + * // Simple example to force delete the request cache + * + * const { id } = axios.get('url'); + * + * delete memoryStorage.data[id]; + * ``` + */ +export function buildMemoryStorage() { + const data: Record = {}; + const storage = buildStorage({ + find: (key) => Promise.resolve(data[key]), + set: (key, value) => Promise.resolve(void (data[key] = value)), + remove: (key) => Promise.resolve(void delete data[key]) }); + return { ...storage, data }; }