diff --git a/CHANGELOG.md b/CHANGELOG.md index 516e499a..1effbc2e 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -19,6 +19,7 @@ Special thanks to: @rejas, @sdetweil, @MagMar94 - Added css class names "today" and "tomorrow" for default calendar - Added Collaboration.md - Added new github action for dependency review (#2862) +- Added config options "ignoreXOriginHeader" and "ignoreContentSecurityPolicy" ### Removed diff --git a/js/electron.js b/js/electron.js index ffa48e6a..ac58657c 100644 --- a/js/electron.js +++ b/js/electron.js @@ -103,6 +103,20 @@ function createWindow() { }, 1000); }); } + + //remove response headers that prevent sites of being embedded into iframes if configured + mainWindow.webContents.session.webRequest.onHeadersReceived((details, callback) => { + let curHeaders = details.responseHeaders; + if (config["ignoreXOriginHeader"] || false) { + curHeaders = Object.fromEntries(Object.entries(curHeaders).filter((header) => !/x-frame-options/i.test(header[0]))); + } + + if (config["ignoreContentSecurityPolicy"] || false) { + curHeaders = Object.fromEntries(Object.entries(curHeaders).filter((header) => !/content-security-policy/i.test(header[0]))); + } + + callback({ responseHeaders: curHeaders }); + }); } // This method will be called when Electron has finished