|
12345678910111213141516171819202122232425 |
- "use strict"
- Object.defineProperty(exports, "__esModule", { value: true })
- function getHeaderValueFromOptions({ action = "SAMEORIGIN" }) {
- const normalizedAction = typeof action === "string" ? action.toUpperCase() : action
- switch (normalizedAction) {
- case "SAME-ORIGIN":
- return "SAMEORIGIN"
- case "DENY":
- case "SAMEORIGIN":
- return normalizedAction
- case "ALLOW-FROM":
- throw new Error("X-Frame-Options no longer supports `ALLOW-FROM` due to poor browser support. See <https://github.com/helmetjs/helmet/wiki/How-to-use-X%E2%80%93Frame%E2%80%93Options's-%60ALLOW%E2%80%93FROM%60-directive> for more info.")
- default:
- throw new Error(`X-Frame-Options received an invalid action ${JSON.stringify(action)}`)
- }
- }
- function xFrameOptions(options = {}) {
- const headerValue = getHeaderValueFromOptions(options)
- return function xFrameOptionsMiddleware(_req, res, next) {
- res.setHeader("X-Frame-Options", headerValue)
- next()
- }
- }
- module.exports = xFrameOptions
- exports.default = xFrameOptions
|