From 9468e0c0f2ebfb0111fd3d3fe2af58d8d0fee08f Mon Sep 17 00:00:00 2001 From: Ted Johansson Date: Wed, 19 Jun 2024 16:30:40 +0800 Subject: [PATCH] DEV: More robust referrer host parsing (#27534) --- app/controllers/application_controller.rb | 11 +++++++---- spec/requests/application_controller_spec.rb | 9 +++++++-- 2 files changed, 14 insertions(+), 6 deletions(-) diff --git a/app/controllers/application_controller.rb b/app/controllers/application_controller.rb index c5f613d9aa7..26b9ebfaba4 100644 --- a/app/controllers/application_controller.rb +++ b/app/controllers/application_controller.rb @@ -1008,10 +1008,13 @@ class ApplicationController < ActionController::Base end def set_cross_origin_opener_policy_header - response.headers["Cross-Origin-Opener-Policy"] = if SiteSetting - .cross_origin_opener_unsafe_none_referrers - .split("|") - .include?(request.referrer&.split("://")&.last) + response.headers[ + "Cross-Origin-Opener-Policy" + ] = if SiteSetting.cross_origin_opener_unsafe_none_referrers.present? && + SiteSetting + .cross_origin_opener_unsafe_none_referrers + .split("|") + .include?(UrlHelper.relaxed_parse(request.referrer.to_s)&.host) "unsafe-none" else SiteSetting.cross_origin_opener_policy_header diff --git a/spec/requests/application_controller_spec.rb b/spec/requests/application_controller_spec.rb index a1167032c11..399848494eb 100644 --- a/spec/requests/application_controller_spec.rb +++ b/spec/requests/application_controller_spec.rb @@ -556,14 +556,19 @@ RSpec.describe ApplicationController do end it "sets `Cross-Origin-Opener-Policy` to `unsafe-none` for a listed referrer" do - get "/latest", headers: { "HTTP_REFERER" => "meta.discourse.org" } + get "/latest", headers: { "HTTP_REFERER" => "https://meta.discourse.org/" } + + expect(response.status).to eq(200) + expect(response.headers["Cross-Origin-Opener-Policy"]).to eq("unsafe-none") + + get "/latest", headers: { "HTTP_REFERER" => "https://meta.discourse.org/hot" } expect(response.status).to eq(200) expect(response.headers["Cross-Origin-Opener-Policy"]).to eq("unsafe-none") end it "sets `Cross-Origin-Opener-Policy` to configured value for a non-listed referrer" do - get "/latest", headers: { "HTTP_REFERER" => "www.discourse.org" } + get "/latest", headers: { "HTTP_REFERER" => "https://www.discourse.org/" } expect(response.status).to eq(200) expect(response.headers["Cross-Origin-Opener-Policy"]).to eq("same-origin")