mirror of
https://github.com/discourse/discourse.git
synced 2024-11-25 08:43:25 +08:00
FEATURE: Add hidden site setting to list 'unsafe-none' COOP referrers (#27510)
Some tooling may rely on an unsafe-none cross origin opener policy to work. This change adds a hidden site setting that can be used to list referrers where we add this header instead of the default one configured in cross_origin_opener_policy_header.
This commit is contained in:
parent
489aac3fdd
commit
3ff7ce78e7
|
@ -1008,7 +1008,14 @@ class ApplicationController < ActionController::Base
|
|||
end
|
||||
|
||||
def set_cross_origin_opener_policy_header
|
||||
response.headers["Cross-Origin-Opener-Policy"] = SiteSetting.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)
|
||||
"unsafe-none"
|
||||
else
|
||||
SiteSetting.cross_origin_opener_policy_header
|
||||
end
|
||||
end
|
||||
|
||||
protected
|
||||
|
|
|
@ -2052,6 +2052,10 @@ security:
|
|||
- "same-origin"
|
||||
- "same-origin-allow-popups"
|
||||
hidden: true
|
||||
cross_origin_opener_unsafe_none_referrers:
|
||||
default: ""
|
||||
type: host_list
|
||||
hidden: true
|
||||
|
||||
onebox:
|
||||
post_onebox_maxlength:
|
||||
|
|
|
@ -547,6 +547,35 @@ RSpec.describe ApplicationController do
|
|||
expect(response.headers["Cross-Origin-Opener-Policy"]).to eq("unsafe-none")
|
||||
end
|
||||
end
|
||||
|
||||
describe "when `cross_origin_unsafe_none_referrers` site setting has been set" do
|
||||
before do
|
||||
SiteSetting.cross_origin_opener_policy_header = "same-origin"
|
||||
SiteSetting.cross_origin_opener_unsafe_none_referrers =
|
||||
"meta.discourse.org|try.discourse.org"
|
||||
end
|
||||
|
||||
it "sets `Cross-Origin-Opener-Policy` to `unsafe-none` for a listed referrer" do
|
||||
get "/latest", headers: { "HTTP_REFERER" => "meta.discourse.org" }
|
||||
|
||||
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" }
|
||||
|
||||
expect(response.status).to eq(200)
|
||||
expect(response.headers["Cross-Origin-Opener-Policy"]).to eq("same-origin")
|
||||
end
|
||||
|
||||
it "sets `Cross-Origin-Opener-Policy` to configured value when referrer is missing" do
|
||||
get "/latest"
|
||||
|
||||
expect(response.status).to eq(200)
|
||||
expect(response.headers["Cross-Origin-Opener-Policy"]).to eq("same-origin")
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
describe "splash_screen" do
|
||||
|
|
Loading…
Reference in New Issue
Block a user