Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
http-cache-middleware
Advanced tools
High performance connect-like HTTP cache middleware for Node.js. So your latency can decrease to single digit milliseconds 🚀
Uses
cache-manager
as caching layer, so multiple storage engines are supported, i.e: Memory, Redis, ... https://www.npmjs.com/package/cache-manager
npm i http-cache-middleware
const middleware = require('http-cache-middleware')()
const service = require('restana')()
service.use(middleware)
service.get('/cache-on-get', (req, res) => {
setTimeout(() => {
// keep response in cache for 1 minute if not expired before
res.setHeader('x-cache-timeout', '1 minute')
res.send('this supposed to be a cacheable response')
}, 50)
})
service.delete('/cache', (req, res) => {
// ... the logic here changes the cache state
// expire the cache keys using pattern
res.setHeader('x-cache-expire', '*/cache-on-get')
res.end()
})
service.start(3000)
// redis setup
const CacheManager = require('cache-manager')
const redisStore = require('cache-manager-ioredis')
const redisCache = CacheManager.caching({
store: redisStore,
db: 0,
host: 'localhost',
port: 6379,
ttl: 30
})
// middleware instance
const middleware = require('http-cache-middleware')({
stores: [redisCache]
})
Because caching is the last mile for low latency distributed systems!
Enabling proper caching strategies will drastically reduce the latency of your system, as it reduces network round-trips, database calls and CPU processing.
For our services, we are talking here about improvements in response times from X ms
to ~2ms
, as an example.
Enabling a response to be cached just requires the
x-cache-timeout
header to be set:
res.setHeader('x-cache-timeout', '1 hour')
Here we use the
ms
package to convert timeout to seconds. Please note thatmillisecond
unit is not supported!
Example on service using restana
:
service.get('/numbers', (req, res) => {
res.setHeader('x-cache-timeout', '1 hour')
res.send([
1, 2, 3
])
})
From version
1.2.x
you can also use the HTTP compatibleCache-Control
header: https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control When using the Cache-Control header, you can omit the customx-cache-timeout
header as the timeout can be passed using themax-age
directive.
res.setHeader('cache-control', 'private, no-cache, max-age=300')
res.setHeader('etag', 'cvbonrw6g00')
res.end('5 minutes cacheable content here....')
When using:
res.setHeader('x-cache-timeout', '5 minutes')
The middleware will now transparently generate default Cache-Control
and ETag
headers as described below:
res.setHeader('cache-control', 'private, no-cache, max-age=300')
res.setHeader('etag', 'ao8onrw6gbt') // random ETag value
This will enable browser clients to keep a copy of the cache on their side, but still being forced to validate the cache state on the server before using the cached response, therefore supporting gateway based cache invalidation.
NOTE: In order to fetch the generated
Cache-Control
andETag
headers, there have to be at least one cache hit.
Services can easily expire cache entries on demand, i.e: when the data state changes. Here we use the x-cache-expire
header to indicate the cache entries to expire using a matching pattern:
res.setHeader('x-cache-expire', '*/numbers')
Here we use the
matcher
package for matching patterns evaluation.
Example on service using restana
:
service.patch('/numbers', (req, res) => {
// ...
res.setHeader('x-cache-expire', '*/numbers')
res.send(200)
})
Sometimes is required to expire cache entries using multiple patterns, that is also possible using the ,
separator:
res.setHeader('x-cache-expire', '*/pattern1,*/pattern2')
const stores = [redisCache]
const middleware = require('http-cache-middleware')({
stores
})
const { deleteKeys } = require('http-cache-middleware/utils')
deleteKeys(stores, '*/pattern1,*/pattern2')
Cache keys are generated using: req.method + req.url
, however, for indexing/segmenting requirements it makes sense to allow cache keys extensions.
To accomplish this, we simply recommend using middlewares to extend the keys before caching checks happen:
service.use((req, res, next) => {
req.cacheAppendKey = (req) => req.user.id // here cache key will be: req.method + req.url + req.user.id
return next()
})
In this example we also distinguish cache entries by
user.id
, commonly used for authorization reasons.
In case full control of the cache-key
value is preferred, just populate the req.cacheKey
property with a string
value. In this case, the req.method + req.url prefix is discarded:
service.use((req, res, next) => {
req.cacheKey = 'CUSTOM-CACHE-KEY'
return next()
})
You can also disable cache checks for certain requests programmatically:
service.use((req, res, next) => {
req.cacheDisabled = true
return next()
})
This is your repo ;)
Note: We aim to be 100% code coverage, please consider it on your pull requests.
You can support the maintenance of this project:
TJ5Bbf9v4kpptnRsePXYDvnYcYrS5Tyxus
FAQs
HTTP Cache Middleware
The npm package http-cache-middleware receives a total of 2,433 weekly downloads. As such, http-cache-middleware popularity was classified as popular.
We found that http-cache-middleware 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
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.