CachifyJS is a lightweight framework-agnostic npm package that helps you cache API responses data in the browser's local storage. By caching API responses, you can reduce the number of network requests and improve the performance of your frontend application built on any technology like: react, vue, angular, you name it.
npm install cachifyjs
-
key
encryptionKeys of the encrypted data will also be encrypted to ensure data security.
-
Wrapper around cached data
The return from
cachify
orgetCache
functions or the received parameter ofcallback
function of either thepostSync
or theafter
property is the cached data with a wrapper around it. Thus, it's structure is similar to the axios api response.If your cached data is like,
const chachedData = {name: 'Ice cream', description: 'Cold'}
Then the wrapper is like,
const response = {data: chachedData}
If no cached data there,
const response = {message: "Data not found",nodata:true}
To use CachifyJS, import the cachify
function into your JavaScript file and pass your API call to it. The cachify
function
will first check if the API response is already cached in local storage. If it is, it will return the cached data inside a
wrapper (ex: {data: cachedData}), make the api call, cache the response data and run the callback. If not, it will make
the API call, cache the response data in local storage and return the data.
Here's an example:
import {cachify} from "cachifyjs";
async function getProductList () {
// configuration for api call
const axiosConfig = {
method: "GET",
headers: { Authorization: `Bearer ${token}` },
url: `https://www.yoursite.com/api/product/list?status=active`
}
// configuration for caching
const cacheConfig = {
key: `product/list?status=active`,//your own choice, recommended to keep it similar to your api uri
errorCallback: handleError,
lifetime: '1h',
encryption: {
secretKey: 'my-secret-key'
},
postSync: {
callback: handleResponse,
skipApiCallFor: '10s',
syncTimeout: 1, //default (ms)
syncInterval: '3h', //with time specifier
},
}
try {
//GET request only
let response = await cachify(axiosConfig, cacheConfig)
//let response = await axios(axiosConfig)
//just replaced the axios() function with cachify()
handleResponse (response)
} catch (error) {
handleError (error)
}
}
//handle api or cache response here
function handleResponse (response) {
if (response.data) {
//handle the response data
}
else {
console.log(response)
}
}
function handleError (error) {
//handle if any error occurs during data refreshing on api call (ex: authentication error)
}
handleResponse
: The function has been used ascallback
inpostSync
property and also been used to handle theresponse
of api call.handleError
: The function has been used aserrorCallback
incacheConfig
and also been used to handle theerror
on api call.- Time specifier: CahcifyJS has 5 time specifiers
s
,m
,h
,d
andw
for seconds, minutes, hours, days and weeks respectively. If no specifier is provided, the value will be considered as milliseconds.
When using CachifyJS, you can configure various options to customize the caching behavior. The cacheConfig
object passed to the cachify
function accepts the following properties:
-
key
: (required) A string that uniquely identifies the API endpoint being called. This key is used as the key for caching the response in local storage. It's recommended to keep it similar to your api uri. -
errorCallback
: (required) A callback function that will be called if an error occurs during the API call. This can be used to handle errors such as authentication failures. -
lifetime
(optional): The amount of time in milliseconds that the cached response should be considered valid. After this time has elapsed, the cache will be invalidated. The default value is7d
or 1 week. -
encryption
(optional): For sensitive data, encryption can be enabled.secretKey
(required): To use encryption, you'll need to provide a secret key to the encryption configuration. This secret key will be used to encrypt and decrypt your data.
-
preSync
: (optional) A boolean that simply enables caching after getting api response and then sending data to frontend. -
postSync
: (recommended) An object that defines how the cache should be updated after the API response is returned. This is useful when you want to keep the cache up to date with new data periodically.-
callback
: (required) A callback function that will be called with the cached data with a wrapper (ex:{data: cachedData}
) after it has been cached. -
skipApiCallFor
: (optional) The amount of time to skip api call. If any api call is made too frequently and we want to reduce the call, we may use this configuration. Then any call tocachify()
function with give data from cache without api call withing this time period. -
syncTimeout
: (optional) The amount of time to wait before syncing the cache with new data. This is useful if you want to avoid syncing the cache too frequently. It's a one time call. -
syncInterval
: (optional) The amount of time to wait before syncing the cache again. This is useful if you want to periodically update the cache with new data.
-
-
Plain
:CachifyJS
will try to get data from cache. If data found, no api call will be made. Otherwise, it will make the api call, cache the data and return the cached data inside a wrapper. It's recommended to uselifetime
for this case. After the cache being expired, new api call will be made to get fresh data. ThecacheConfig
should look like,const cacheConfig = { key: `product/list?status=active`, errorCallback: handleError, lifetime: '30m', encryption: { secretKey: 'my-secret-key' } }
-
preSync
:CachifyJS
will make the api call, cache the response and return the response. ThecacheConfig
should look like,const cacheConfig = { key: `product/list?status=active`, errorCallback: handleError, preSync: true, }
-
postSync
:CachifyJS
will try to get data from cache. If data not found, an immediate api call will be made. Otherwise, ifsyncTimeout
is present in the config a single api call will be made according to the value.If
syncInterval
is present in the config,cachifyjs
will make api call according to thesyncInterval
value and return the response.Data will be cached in both scenarios.
If the api call is requested according to
syncTimeout
orsyncInterval
during skip timezone and cache data is present them the api call will simply be ignored and the cache data will be returned.const cacheConfig = { key: `product/list?status=active`, errorCallback: handleError, lifetime: '1h', postSync: { callback: handleResponse, skipApiCallFor: '10s', syncTimeout: 1,//default (ms) syncInterval: '3h', }, }
Notes:
skipApiCallFor
: The amount of time to skip api call.syncTimeout
: The time delay after that api call will be made. It's a one time call.syncInterval
: The time interval for the api call. It's a repetitive process. It works in background.
The setCache
function allows you to set new cached data in your frontend application. The data could be api response, any app state, you name it.
With this new feature, you can easily set any data in the cache without depending on any type of network request or API call.
To set cached data, import the setCache
function into your JavaScript file and pass a config
and data
to the function.
The function will set new data in cache.
Here's an example:
import {setCache} from "cachifyjs";
async function setWishListCache (data) {
// configuration for updating
const config = {
key: `wishlist`,//Be sure to use unique key
lifetime: '1h',
encryption: {
secretKey: 'my-secret-key'
},
after: {
callback: handleResponse,
}
}
try {
await setCache(config, data);
} catch (error) {
console.log ("Set Cache Error:", error)
}
}
function handleResponse (response) {
//handle response after setting cached data
}
When setting new data, the config
object passed to the setCache
function accepts the following properties:
-
key
: (required) A string that uniquely identifies the cached data. This key is used as the key for caching the response in local storage. -
lifetime
(optional): The amount of time in milliseconds that the cached response should be considered valid. After this time has elapsed, the cache will be invalidated. The default value is7d
or 1 week. -
encryption
(optional): For sensitive data, encryption can be enabled.secretKey
(required): To use encryption, you'll need to provide a secret key to the encryption configuration. This secret key will be used to encrypt and decrypt your data.
-
after
: (recommended) An object that defines the events after the data has been set. This is useful when you want create an effect after the setting up cached data.callback
: (required) A callback function that will be called with the cached data with a wrapper (ex:{data: cachedData}
) after it has been cached.
The getCache
function allows you to get the cached data from your frontend application without complex configuration or subsequent api call.
Here's an example:
import {getCache} from "cachifyjs";
async function getWishListCache () {
const config = {
key: `wishlist`, //it must be the same as the cached key
encryption: {, // if the cached data is ecrypted, the same encryption key is required.
secretKey: 'my-secret-key'
},
}
try {
const response = await getCache(config);
handleResponse(response)
} catch (error) {
console.log ("Get Cache Error:", error)
}
}
//handle cache response here
function handleResponse (response) {
if (response.data) {
//handle the response data
}
else {
console.log(response)
}
}
response
:response
is a wrapper around the cached data. Ex:{data: cachedData}
or{message: "Data not found",nodata:true}
.handleResponse
: The function has been used ascallback
inafter
property.
When getting data, the config
object passed to the getCache
function accepts the following properties:
-
key
: (required) Thiskey
identifies the cached data. It's mandatory to keep it same to the key of the cached data. -
encryption
(optional): If the cached data is encrypted then it's mandatory.secretKey
(required): To use encryption, you'll need to provide a secret key to the encryption configuration. This secret key will be used to decrypt your data.
To update cached data, import the updateCache
function into your JavaScript file and pass a config
and data
to the
function. The function will update the cached data in frontend without making api call.
Here's an example:
import {updateCache} from "cachifyjs";
async function updateProductListCache (updatedData) {
// configuration for updating
const config = {
key: `product/list?status=active`,//it must be the same as the cached key
lifetime: '1h',
encryption: {
secretKey: 'my-secret-key'//it must be the same as the key used to cache the data
},
after: {
callback: handleResponse, //the same callback previously use in cacheConfig
}
}
try {
await updateCache(config, updatedData);
} catch (error) {
console.log ("Cache Update Error:", error)
}
}
//the same function previously used to handle the api response
function handleResponse (response) {
//handle api response here
}
handleResponse
: The function has been used to handle the api response previously. This callback will be called after the data has been updated.
When updating data, the config
object passed to the updateCache
function accepts the following properties:
-
key
: (required) Thiskey
identifies the cached data and update it. It's mandatory to keep it similar to the key of the data needs to be updated. -
lifetime
(optional): The amount of time in milliseconds that the cached response should be considered valid. After this time has elapsed, the cache will be invalidated. -
encryption
(optional): For sensitive data, encryption can be enabled. If the cached data is encrypted then it's mandatory.secretKey
(required): To use encryption, you'll need to provide a secret key to the encryption configuration. This secret key will be used to encrypt and decrypt your data.
-
after
: (recommended) An object that defines the events after the data has been updated. This is useful when you want create an effect after the update.callback
: (required) A callback function that will be called after the data has been updated. It should be the same method that was previously passed in cacheConfig during initial caching.
To remove cached data, import the removeCache
function into your JavaScript file and pass a config
with the key
property to the function.
The function will remove the cached data.
Here's an example:
import {removeCache} from "cachifyjs";
async function removeProductListCache () {
const config = {
key: `product/list?status=active`,//it must be the same as the cached key
}
try {
await removeCache(config);
} catch (error) {
console.log ("Cache Removal Error:", error)
}
}
-
Version
2.3.10
(2023-07-15)- Dependency version update: [email protected] requires [email protected].
-
Version
2.3.9
(2023-06-30)- Skip Api Call: The skip api call feature has been updated to check previous api call timestamp and determine the skip functionality.
-
Version
2.3.8
(2023-06-28)- Skip Api Call: The
skipApiCallFor
property insidepostSync
property ofcacheConfig
for functioncachify()
allows us to skip api calls. If any api call is made too frequently and we want to reduce the call, we may use this configuration.
- Skip Api Call: The
-
Version
2.3.7
(2023-06-19)- Fixed the issue: Not calling api if data is cached even if
postsync
is enabled.
- Fixed the issue: Not calling api if data is cached even if
CachifyJS is a simple yet powerful tool that can help you optimize your frontend application's performance by reducing the number of API requests. By caching API responses in the browser's local storage, you can improve your application's response time and make it more responsive to user interactions. Give it a try in your next project!