FIX: handle URL encoded email addresses

This commit is contained in:
Gerhard Schlager 2017-09-22 14:26:06 +02:00
parent e08b5feb8a
commit 1a435414d5
2 changed files with 18 additions and 1 deletions

View File

@ -125,7 +125,7 @@ class TopicEmbed < ActiveRecord::Base
uri.host = original_uri.host uri.host = original_uri.host
node[url_param] = uri.to_s node[url_param] = uri.to_s
end end
rescue URI::InvalidURIError rescue URI::InvalidURIError, URI::InvalidComponentError
# If there is a mistyped URL, just do nothing # If there is a mistyped URL, just do nothing
end end
end end

View File

@ -195,6 +195,23 @@ describe TopicEmbed do
end end
end end
context "emails" do
let(:url) { 'http://example.com/foo' }
let(:contents) { '<p><a href="mailto:foo%40example.com">URL encoded @ symbol</a></p><p><a href="mailto:bar@example.com">normal mailto link</a></p>' }
let!(:embeddable_host) { Fabricate(:embeddable_host) }
let!(:file) { StringIO.new }
before do
file.stubs(:read).returns contents
TopicEmbed.stubs(:open).returns file
end
it "handles mailto links" do
response = TopicEmbed.find_remote(url)
expect(response.body).to have_tag('a', with: { href: 'mailto:foo%40example.com' })
expect(response.body).to have_tag('a', with: { href: 'mailto:bar@example.com' })
end
end
end end
end end