mirror of
https://github.com/discourse/discourse.git
synced 2025-01-18 21:02:48 +08:00
SECURITY: SSRF vulnerability in TopicEmbed
Block redirects when making the final request in TopicEmbed to prevent Server Side Request Forgery (SSRF)
This commit is contained in:
parent
7d484864fe
commit
5f20748e40
|
@ -126,8 +126,8 @@ class TopicEmbed < ActiveRecord::Base
|
||||||
return if uri.blank?
|
return if uri.blank?
|
||||||
|
|
||||||
begin
|
begin
|
||||||
html = uri.read
|
html = FinalDestination::HTTP.get(uri)
|
||||||
rescue OpenURI::HTTPError, Net::OpenTimeout
|
rescue OpenURI::HTTPError, Net::OpenTimeout, FinalDestination::SSRFDetector::DisallowedIpError
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -299,6 +299,19 @@ RSpec.describe TopicEmbed do
|
||||||
response = TopicEmbed.find_remote(url)
|
response = TopicEmbed.find_remote(url)
|
||||||
expect(response.title).to eq("Through the Looking Glass")
|
expect(response.title).to eq("Through the Looking Glass")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it "doesn't follow redirect when making request" do
|
||||||
|
FinalDestination.any_instance.stubs(:resolve).returns(URI("https://redirect.com"))
|
||||||
|
stub_request(:get, "https://redirect.com/").to_return(
|
||||||
|
status: 301,
|
||||||
|
body: "<title>Moved permanently</title>",
|
||||||
|
headers: {
|
||||||
|
"Location" => "https://www.example.org/",
|
||||||
|
},
|
||||||
|
)
|
||||||
|
response = TopicEmbed.find_remote(url)
|
||||||
|
expect(response.title).to eq("Moved permanently")
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'with post with allowed classes "foo" and "emoji"' do
|
context 'with post with allowed classes "foo" and "emoji"' do
|
||||||
|
|
Loading…
Reference in New Issue
Block a user