Skip to content
/ kesha Public

Caching utils based on ioredis and dataloaders

License

Notifications You must be signed in to change notification settings

AckeeCZ/kesha

Repository files navigation

Kesha

Caching utils based on ioredis and dataloaders

Quick start 🚀

import Redis from 'ioredis';

const redisClient = new Redis({
  // Host, DB,...
})
import { rateLimiter } from 'kesha';

const rateLimitedFn = rateLimiter(redisClient, (number: number) => {
  console.log('Called')
}, '', 1000)
import { createRedisRepository } from 'kesha';

const repo = createRedisRepository(client)

const rateLimitedFn = repo.rateLimiter((number: number) => {
  console.log('Called')
}, '', 1000)
  • Provide typehints for setJSON and getJSON methods
// Per key
const repoPerKey = createRedisRepository<{ 'test:key': string }>(client)

repoPerKey.setJSON('test:key', {}) // TS Error: {} is not assignable to string

// Using template litarals to define key prefixes (From TS 4.4+)
const repo = createRedisRepository<{ [K: `test:key:${number}`]: string }>(client)

repo.setJSON('test:key:1', {}) // TS Error: {} is not assignable to string
repo.getJSON('test:key:1') // TS: Returns string
repo.getJSON('test:key:a') // TS: Returns any

Tests 🧪

  • Prepare docker container with Redis 🐳
sudo docker-compose -f docker-compose/docker-compose.yml up
  • Run the tests
npm run test