Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
redis-json
Advanced tools
A wrapper library to store JSON Objects in redis-hashsets and retrieve it back as JSON objects
Nodejs library to store/retreive JSON Objects in RedisDB
Every time set
is called JSON object is flattened(embeded objects are converted to path keys) and then stored in Redis(just like a normal hashset), on get
the hashset is unflattened and converted back to the original JSON object(with the same types as the original object).
setT()
, rewriteT()
& delT()
methods.rewrite
method also supports expiry
options(same as ISetOptions)npm install redis-json --save
Please visit this page for detailed API documentation.
Simple
import Redis from 'ioredis';
import JSONCache from 'redis-json';
const redis = new Redis() as any;
const jsonCache = new JSONCache<{
name: string;
age: 25;
address: {
doorNo: string;
locality: string;
pincode: number;
}
}>(redis, {prefix: 'cache:'});
const user = {
name: 'redis-json',
age: 25,
address: {
doorNo: '12B',
locality: 'pentagon',
pincode: 123456
},
cars: ['BMW 520i', 'Audo A8']
}
await jsonCache.set('123', user)
await jsonCache.get('123')
// output
// {
// name: 'redis-json',
// age: 25,
// address: {
// doorNo: '12B',
// locality: 'pentagon',
// pincode: 123456
// },
// cars: ['BMW 520i', 'Audo A8']
// }
await jsonCache.set('123', {gender: 'male'})
await jsonCache.get('123')
// output
// {
// name: 'redis-json',
// age: 25,
// address: {
// doorNo: '12B',
// locality: 'pentagon',
// pincode: 123456
// },
// cars: ['BMW 520i', 'Audo A8']
// gender: 'male'
// }
await jsonCache.get('123', 'name', 'age');
// output
// {
// name: 'redis-json',
// age: 25,
// }
await jsonCache.get('123', 'name', 'address.doorNo');
// {
// name: 'redis-json',
// address: {
// doorNo: '12B'
// }
// }
await jsonCache.clearAll();
await jsonCache.get('123');
// undefined
With custom stringifier and parser:
const jsonCache = new JSONCache(redis, {
stringifier: {
Date: (val: Date) => val.toISOString()
},
parser: {
Date: (str: string) => new Date(str)
}
})
const date = new Date()
await jsonCache.set('test', {
date: date
})
// Redis hashset
> hgetall jc:test /// data
1) "date"
2) "2020-05-17T14:41:45.861Z"
> hgetall jc:test_t /// type info
1) "date"
2) "Date"
const result = await jsonCache.get('test')
result.date == date /// true
With transactions:
const transaction = redisClient.multi();
transaction
.set('name', 'foo')
.set('bar', 'baz')
jsonCache.setT(transaction, 'test', {name: 'testing'})
jsonCache.delT(transaction, 'test1')
jsonCache.rewriteT(transaction, 'test2', {name: 'testing', age: 25})
transaction
.exec(function(err, replies) => {
/// your logic here after
})
Please note that only setT()
, rewriteT()
& delT()
supports transaction, where as get()
& clearAll()
do NOT support transaction because we process those results before returning it to the calling function. Moreover there is no real usecase in adding get
methods to a transaction!
Types of the data are retained when retrieved from Redis.
Please refer to this page
npm run coverage
This is open-source, which makes it obvious for any PRs, but I would request you to add necessary test-cases for the same.
Run your redis-server and then point the same client to the same.
An easier way to start redis-server, provided you've already installed docker
(else visit this page) is by running this command:
docker run --rm -it --name redis -p 6379:6379 redis
We follow TDD approach, so write your test cases first and then run the same paralelly during development by running the following command:
npm run test:dev
MIT License
v4.3.0
.incr()
& .incrT()
methods to allow incrementing of values using hincrbyfloat
.FAQs
A wrapper library to store JSON Objects in redis-hashsets and retrieve it back as JSON objects
The npm package redis-json receives a total of 6,543 weekly downloads. As such, redis-json popularity was classified as popular.
We found that redis-json 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
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.