Research
Security News
Malicious npm Packages Inject SSH Backdoors via Typosquatted Libraries
Socket’s threat research team has detected six malicious npm packages typosquatting popular libraries to insert SSH backdoors.
@duell10111/react-native-cache
Advanced tools
LRU cache built on top of the React Native communities' AsyncStorage v2 (or included MemoryStore) and automatic pruning of least recently used items.
Based on timfpark's version.
Additionally a sync version is included to use it on top of the React Native MMKV package.
npm install --save @duell10111/react-native-cache
or
yarn add @duell10111/react-native-cache
import { Cache } from "@duell10111/react-native-cache"; //Async version
import { SyncCache } from "@duell10111/react-native-cache"; //Sync version
You initialize a cache using the following.
const cache = new Cache({
namespace: "myapp",
policy: {
maxEntries: 50000, // if unspecified, it can have unlimited entries
stdTTL: 0 // the standard ttl as number in seconds, default: 0 (unlimited)
},
backend: AsyncStorage,
prunecallback: (keys) => {console.log(keys)} //prunecallback called if a key gets removed
});
Multiple caches can be mantained in an application by instantiating caches with different namespaces.
await cache.set("hello", "world");
// key 'hello' is now set to 'world' in namespace 'myapp'
const value = await cache.get("key1");
console.log(value);
// 'hello'
});
Getting an item from the cache also moves it to the end of the LRU list: it will be evicted from the cache last.
await cache.remove("key1");
// 'key1' is no more.
You can also peek at an item in the cache without updating its position in the LRU list:
const value = await cache.peek("key1");
// value is retrieved but LRU value is unchanged.
You can look at all of the elements in the cache without updating its position in the LRU list:
const entries = await cache.getAll();
console.dir(entries);
// {
// "key1": { "value": 42 }
// "key2": { "value": 2 }
// ...
// }
You can also clear all of the items in the cache with:
await cache.clearAll();
For more usage examples, see the tests.
FAQs
LRU cache built on AsyncStorage for react-native
The npm package @duell10111/react-native-cache receives a total of 1 weekly downloads. As such, @duell10111/react-native-cache popularity was classified as not popular.
We found that @duell10111/react-native-cache 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.
Research
Security News
Socket’s threat research team has detected six malicious npm packages typosquatting popular libraries to insert SSH backdoors.
Security News
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
Security News
In this segment of the Risky Business podcast, Feross Aboukhadijeh and Patrick Gray discuss the challenges of tracking malware discovered in open source softare.