Security News
38% of CISOs Fear They’re Not Moving Fast Enough on AI
CISOs are racing to adopt AI for cybersecurity, but hurdles in budgets and governance may leave some falling behind in the fight against cyber threats.
apollo-cache-instorage
Advanced tools
Apollo Cache implementation that facilitates locally storing resources
apollo-cache-instorage
is an extension to apollo-cache-inmemory
that allows
for granular cacheability of resources, in a storage of choice.
The most famous implementation of a persistence layer for Apollo Client is
apollo-cache-persist
. The main caveats with that project is the fastly
growing size of the cache, and the incapability of chosing what needs and
needs not to be cached. apollo-cache-instorage
solves that, while reducing
the complexity on the setup and limiting interaction points between the
caching solution and the Apollo Client multiple services.
yarn add apollo-cache-instorage
InStorageCache
is an extension of InMemoryCache
, so initialization is not so
different than the other:
import { InStorageCache } from 'apollo-cache-instorage'
import { HttpLink } from 'apollo-link-http'
import ApolloClient from 'apollo-client'
const cache = new InStorageCache({
storage: window.localStorage,
})
const client = new ApolloClient({
link: new HttpLink(),
cache,
})
The InStorageCache
constructor takes a config object with all the options available for InMemoryCache
plus the following customization properties:
name | type | default | required |
---|---|---|---|
storage | Object | true | |
shouldPersist | Function | () => true | false |
normalize | Function | JSON.stringify | false |
denormalize | Function | JSON.parse | false |
storage
A Web Storage complient storage implementation.
shouldPersist
shouldPersist(
operation: String,
dataId: String,
value: ?Object
)
Callback to determine if a given data object should be cached. Takes three arguments:
operation
: the ongoing storage operation. Will either be get
, set
, or delete
;dataId
: a data object ID as resolved by dataIdFromObject
;value
: the persisting data object, in case the operation is set
.normalize
normalize(
value: Object
)
Normalization executed against a data object before attaching to the storage for persistence. Defaults to JSON.stringify
.
denormalize
Denormalization executed against a persisted data after retrieving from the storage. Defaults to JSON.parse
.
ROOT_QUERY
Most of the cache consumption in Apollo starts off on the ROOT_QUERY
special key. Make sure that if you implement shouldPersist
you always allow the storage to persist the data related to this key, such as follows:
const shouldPersist = (operation, dataId, value) => {
if (dataId === 'ROOT_QUERY') return true
// ... other logic here.
}
cache.restore()
When restoring the cache (SSR hydration, for instance), keep in mind that any value inserted via hydrating will have precedence over the persisted data.
FAQs
Apollo Cache implementation that facilitates locally storing resources
We found that apollo-cache-instorage demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
CISOs are racing to adopt AI for cybersecurity, but hurdles in budgets and governance may leave some falling behind in the fight against cyber threats.
Research
Security News
Socket researchers uncovered a backdoored typosquat of BoltDB in the Go ecosystem, exploiting Go Module Proxy caching to persist undetected for years.
Security News
Company News
Socket is joining TC54 to help develop standards for software supply chain security, contributing to the evolution of SBOMs, CycloneDX, and Package URL specifications.