From 6152f76bcc24b974fa78bc2d218bf720f39409ef Mon Sep 17 00:00:00 2001 From: bhavanakarwade Date: Wed, 4 Dec 2024 18:45:25 +0530 Subject: [PATCH] refactor: middleware Signed-off-by: bhavanakarwade --- src/middleware.ts | 85 ++++++++++++++++++++++++++++++++++------------- 1 file changed, 62 insertions(+), 23 deletions(-) diff --git a/src/middleware.ts b/src/middleware.ts index c73dc4a46..d52bec13b 100644 --- a/src/middleware.ts +++ b/src/middleware.ts @@ -1,36 +1,75 @@ +// import { envConfig } from "./config/envConfig"; +// import { pathRoutes } from "./config/pathRoutes"; + import { envConfig } from "./config/envConfig"; import { pathRoutes } from "./config/pathRoutes"; +// export const onRequest = async (context: any, next: any) => { +// const response = await next(); +// const html = await response.text(); + +// const domains = envConfig.PUBLIC_ALLOW_DOMAIN; + +// const allowedDomain = `${context.url.origin} ${domains}` + +// const nonce = "dynamicNONCE" + new Date().getTime().toString(); + +// response.headers.set('Content-Security-Policy',`default-src 'self'; script-src 'self' ${allowedDomain} 'nonce-${nonce}_scripts'; style-src 'unsafe-inline' ${allowedDomain}; font-src ${allowedDomain}; img-src 'self' data: ${allowedDomain}; frame-src 'self' ${allowedDomain}; object-src 'none'; media-src 'self'; connect-src 'self' ${allowedDomain}; form-action 'self'; frame-ancestors 'self'; `); +// response.headers.set('X-Frame-Options', "DENY"); +// response.headers.set('X-Content-Type-Options', 'nosniff'); +// response.headers.set('Access-Control-Allow-Origin', allowedDomain) +// response.headers.set('ServerTokens', 'dummy_server_name') +// response.headers.set('server_tokens', 'off') +// response.headers.set('server', 'dummy_server_name') +// response.headers.set('Server', 'dummy_server_name') +// response.headers.set("Strict-Transport-Security", "max-age=31536000; includeSubDomains; preload") +// response.headers.set("X-XSS-Protection", "1; mode=block") + +// let updatedHtml = await html.split(" { const response = await next(); const html = await response.text(); - + const domains = envConfig.PUBLIC_ALLOW_DOMAIN; - - const allowedDomain = `${context.url.origin} ${domains}` - - const nonce = "dynamicNONCE" + new Date().getTime().toString(); + const allowedDomain = `${context.url.origin} ${domains}`; + + // Generate a dynamic nonce + const nonce = `dynamicNONCE-${new Date().getTime()}`; - response.headers.set('Content-Security-Policy',`default-src 'self'; script-src 'self' ${allowedDomain} 'nonce-${nonce}_scripts'; style-src 'unsafe-inline' ${allowedDomain}; font-src ${allowedDomain}; img-src 'self' data: ${allowedDomain}; frame-src 'self' ${allowedDomain}; object-src 'none'; media-src 'self'; connect-src 'self' ${allowedDomain}; form-action 'self'; frame-ancestors 'self'; `); - response.headers.set('X-Frame-Options', "DENY"); + // Update CSP headers + response.headers.set( + 'Content-Security-Policy', + `default-src 'self'; script-src 'self' ${allowedDomain} 'nonce-${nonce}'; style-src 'unsafe-inline' ${allowedDomain}; font-src ${allowedDomain}; img-src 'self' data: ${allowedDomain}; frame-src 'self' ${allowedDomain}; object-src 'none'; media-src 'self'; connect-src 'self' ${allowedDomain}; form-action 'self'; frame-ancestors 'self';` + ); + response.headers.set('X-Frame-Options', 'DENY'); response.headers.set('X-Content-Type-Options', 'nosniff'); - response.headers.set('Access-Control-Allow-Origin', allowedDomain) - response.headers.set('ServerTokens', 'dummy_server_name') - response.headers.set('server_tokens', 'off') - response.headers.set('server', 'dummy_server_name') - response.headers.set('Server', 'dummy_server_name') - response.headers.set("Strict-Transport-Security", "max-age=31536000; includeSubDomains; preload") - response.headers.set("X-XSS-Protection", "1; mode=block") - - let updatedHtml = await html.split("