mirror of
https://github.com/discourse/discourse.git
synced 2025-01-18 17:52:45 +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?
|
||||
|
||||
begin
|
||||
html = uri.read
|
||||
rescue OpenURI::HTTPError, Net::OpenTimeout
|
||||
html = FinalDestination::HTTP.get(uri)
|
||||
rescue OpenURI::HTTPError, Net::OpenTimeout, FinalDestination::SSRFDetector::DisallowedIpError
|
||||
return
|
||||
end
|
||||
|
||||
|
|
|
@ -299,6 +299,19 @@ RSpec.describe TopicEmbed do
|
|||
response = TopicEmbed.find_remote(url)
|
||||
expect(response.title).to eq("Through the Looking Glass")
|
||||
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
|
||||
|
||||
context 'with post with allowed classes "foo" and "emoji"' do
|
||||
|
|
Loading…
Reference in New Issue
Block a user