1
0
mirror of synced 2025-12-30 03:01:36 -05:00
Files
docs/middleware/cache-control.js
Kevin Heis 688a274f1f Remove CSRF check (#29910)
* Use color_mode for gating "sign up" button

* Remove csrf check

* Add `res.removeHeader('set-cookie')` to cache-control

* Update static-assets.js

* Remove package

* Remove tough-cookie

* Update cache-control.js

* Update cache-control.js

* Update cache-control.js
2022-08-15 19:28:42 +00:00

41 lines
1.1 KiB
JavaScript

// Return a function you can pass a Response object to and it will
// set the `Cache-Control` header.
//
// For example:
//
// const cacheControlYear = getCacheControl(60 * 60 * 24 * 365)
// ...
// cacheControlYear(res)
// res.send(body)
//
// Or, if you want to make it definitely not cache:
//
// const noCacheControl = getCacheControl(0) // you can use `false` too
// ...
// noControlYear(res)
// res.send(body)
//
// Max age is in seconds
export function cacheControlFactory(
maxAge = 60 * 60,
{ key = 'cache-control', public_ = true, immutable = false } = {}
) {
const directives = [
maxAge && public_ && 'public',
maxAge && `max-age=${maxAge}`,
maxAge && immutable && 'immutable',
!maxAge && 'private',
!maxAge && 'no-store',
]
.filter(Boolean)
.join(', ')
return (res) => {
if (process.env.NODE_ENV !== 'production' && res.hasHeader('set-cookie')) {
console.warn(
"You can't set a >0 cache-control header AND set-cookie or else the CDN will never respect the cache-control."
)
}
res.set(key, directives)
}
}