FIX: whitelist oneboxed iframes
This commit is contained in:
parent
b74e933cfb
commit
d6b22e6cc1
|
@ -14,6 +14,24 @@ module Onebox
|
|||
Float::INFINITY
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
# overwrite to whitelist iframes
|
||||
def is_embedded?
|
||||
return false unless data[:html] && data[:height]
|
||||
return true if WhitelistedGenericOnebox.html_providers.include?(data[:provider_name])
|
||||
|
||||
if data[:html]["iframe"]
|
||||
fragment = Nokogiri::HTML::fragment(data[:html])
|
||||
if iframe = fragment.at_css("iframe")
|
||||
src = iframe["src"]
|
||||
return src.present? && SiteSetting.allowed_iframes.split("|").any? { |url| src.start_with?(url) }
|
||||
end
|
||||
end
|
||||
|
||||
false
|
||||
end
|
||||
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
@ -15,4 +15,32 @@ describe Onebox::Engine::WhitelistedGenericOnebox do
|
|||
|
||||
end
|
||||
|
||||
it "whitelists iframes" do
|
||||
whitelisted_body = '<html><head><link rel="alternate" type="application/json+oembed" href="https://whitelist.ed/iframes.json" />'
|
||||
blacklisted_body = '<html><head><link rel="alternate" type="application/json+oembed" href="https://blacklist.ed/iframes.json" />'
|
||||
|
||||
whitelisted_oembed = {
|
||||
type: "rich",
|
||||
height: "100",
|
||||
html: "<iframe src='https://ifram.es/foo/bar'></iframe>"
|
||||
}
|
||||
|
||||
blacklisted_oembed = {
|
||||
type: "rich",
|
||||
height: "100",
|
||||
html: "<iframe src='https://malicious/discourse.org/'></iframe>"
|
||||
}
|
||||
|
||||
stub_request(:get, "https://blacklist.ed/iframes").to_return(status: 200, body: blacklisted_body)
|
||||
stub_request(:get, "https://blacklist.ed/iframes.json").to_return(status: 200, body: blacklisted_oembed.to_json)
|
||||
|
||||
stub_request(:get, "https://whitelist.ed/iframes").to_return(status: 200, body: whitelisted_body)
|
||||
stub_request(:get, "https://whitelist.ed/iframes.json").to_return(status: 200, body: whitelisted_oembed.to_json)
|
||||
|
||||
SiteSetting.allowed_iframes = "discourse.org|https://ifram.es"
|
||||
|
||||
expect(Onebox.preview("https://blacklist.ed/iframes").to_s).to be_empty
|
||||
expect(Onebox.preview("https://whitelist.ed/iframes").to_s).to match("iframe src")
|
||||
end
|
||||
|
||||
end
|
||||
|
|
Loading…
Reference in New Issue