mirror of
https://github.com/discourse/discourse.git
synced 2025-02-21 11:25:24 +00:00
FIX: Maintain HTML <img
when downloading remote images (#16278)
Under some conditions, replacing an `<img` with `![]()` can break rendering, and make the image disappear. Context at https://meta.discourse.org/t/152801
This commit is contained in:
parent
8e5614b1bf
commit
b2a8dc4c0f
@ -204,16 +204,10 @@ class InlineUploads
|
||||
|
||||
if src && (external_src || matched_uploads(src).present?)
|
||||
upload = uploads&.[](src)
|
||||
|
||||
text = upload&.original_filename || node.attributes["alt"]&.value
|
||||
width = (node.attributes["width"]&.value || upload&.width).to_i
|
||||
height = (node.attributes["height"]&.value || upload&.height).to_i
|
||||
title = node.attributes["title"]&.value
|
||||
text = "#{text}|#{width}x#{height}" if width > 0 && height > 0
|
||||
url = upload&.short_url || PLACEHOLDER
|
||||
node["src"] = upload&.short_url || PLACEHOLDER
|
||||
|
||||
spaces_before = match[1].present? ? match[1][/ +$/].size : 0
|
||||
replacement = +"#{" " * spaces_before}data:image/s3,"s3://crabby-images/97df7/97df7057a47a35c709849bb06d7896d45182a9c9" alt="#{text}""
|
||||
replacement = +"#{" " * spaces_before}#{node.to_s}"
|
||||
|
||||
yield(match[2], src, replacement, $~.offset(0)[0]) if block_given?
|
||||
end
|
||||
|
@ -67,7 +67,7 @@ describe Jobs::PullHotlinkedImages do
|
||||
end.to change { Upload.count }.by(1) &
|
||||
change { UserHistory.count }.by(0) # Should not add to the staff log
|
||||
|
||||
expect(post.reload.raw).to eq("data:image/s3,"s3://crabby-images/b3d92/b3d9278a3a2bb8190f68ca4688ad97379cea0257" alt=""")
|
||||
expect(post.reload.raw).to eq("<img src=\"#{Upload.last.short_url}\">")
|
||||
end
|
||||
|
||||
it 'removes downloaded images when they are no longer needed' do
|
||||
@ -91,7 +91,7 @@ describe Jobs::PullHotlinkedImages do
|
||||
post.rebake!
|
||||
end.to change { Upload.count }.by(1)
|
||||
|
||||
expect(post.reload.raw).to eq("data:image/s3,"s3://crabby-images/b3d92/b3d9278a3a2bb8190f68ca4688ad97379cea0257" alt=""")
|
||||
expect(post.reload.raw).to eq("<img src=\"#{Upload.last.short_url}\">")
|
||||
|
||||
# Post raw is updated back to the old value (e.g. by wordpress integration)
|
||||
post.update(raw: "<img src='#{image_url}'>")
|
||||
@ -100,7 +100,7 @@ describe Jobs::PullHotlinkedImages do
|
||||
post.rebake!
|
||||
end.to change { Upload.count }.by(0) # We alread have the upload
|
||||
|
||||
expect(post.reload.raw).to eq("data:image/s3,"s3://crabby-images/b3d92/b3d9278a3a2bb8190f68ca4688ad97379cea0257" alt=""")
|
||||
expect(post.reload.raw).to eq("<img src=\"#{Upload.last.short_url}\">")
|
||||
end
|
||||
|
||||
it 'replaces encoded image urls' do
|
||||
@ -110,10 +110,10 @@ describe Jobs::PullHotlinkedImages do
|
||||
Jobs::PullHotlinkedImages.new.execute(post_id: post.id)
|
||||
end.to change { Upload.count }.by(1)
|
||||
|
||||
expect(post.reload.raw).to eq("data:image/s3,"s3://crabby-images/b3d92/b3d9278a3a2bb8190f68ca4688ad97379cea0257" alt=""")
|
||||
expect(post.reload.raw).to eq("<img src=\"#{Upload.last.short_url}\">")
|
||||
end
|
||||
|
||||
xit 'replaces images in an anchor tag with weird indentation' do
|
||||
it 'replaces images in an anchor tag with weird indentation' do
|
||||
# Skipped pending https://meta.discourse.org/t/152801
|
||||
# This spec was previously passing, even though the resulting markdown was invalid
|
||||
# Now the spec has been improved, and shows the issue
|
||||
@ -124,7 +124,7 @@ describe Jobs::PullHotlinkedImages do
|
||||
post = Fabricate(:post, raw: <<~MD)
|
||||
<h1></h1>
|
||||
<a href="https://somelink.com">
|
||||
<img alt="somelink" src="#{image_url}" />
|
||||
<img alt="somelink" src="#{image_url}">
|
||||
</a>
|
||||
MD
|
||||
|
||||
@ -137,7 +137,7 @@ describe Jobs::PullHotlinkedImages do
|
||||
expect(post.reload.raw).to eq(<<~MD.chomp)
|
||||
<h1></h1>
|
||||
<a href="https://somelink.com">
|
||||
data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt="somelink"
|
||||
<img alt="somelink" src="#{upload.short_url}">
|
||||
</a>
|
||||
MD
|
||||
end
|
||||
@ -163,7 +163,7 @@ describe Jobs::PullHotlinkedImages do
|
||||
Jobs::PullHotlinkedImages.new.execute(post_id: post.id)
|
||||
end.to change { Upload.count }.by(1)
|
||||
|
||||
expect(post.reload.raw).to eq("data:image/s3,"s3://crabby-images/b3d92/b3d9278a3a2bb8190f68ca4688ad97379cea0257" alt="test"")
|
||||
expect(post.reload.raw).to eq("<img alt=\"test\" src=\"#{Upload.last.short_url}\">")
|
||||
end
|
||||
|
||||
it 'replaces images without extension' do
|
||||
@ -176,7 +176,7 @@ describe Jobs::PullHotlinkedImages do
|
||||
Jobs::PullHotlinkedImages.new.execute(post_id: post.id)
|
||||
end.to change { Upload.count }.by(1)
|
||||
|
||||
expect(post.reload.raw).to eq("data:image/s3,"s3://crabby-images/b3d92/b3d9278a3a2bb8190f68ca4688ad97379cea0257" alt=""")
|
||||
expect(post.reload.raw).to eq("<img src=\"#{Upload.last.short_url}\">")
|
||||
end
|
||||
|
||||
it 'replaces optimized images' do
|
||||
@ -195,7 +195,7 @@ describe Jobs::PullHotlinkedImages do
|
||||
upload = Upload.last
|
||||
post.reload
|
||||
|
||||
expect(post.raw).to eq("data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt=""")
|
||||
expect(post.raw).to eq("<img src=\"#{Upload.last.short_url}\">")
|
||||
expect(post.uploads).to contain_exactly(upload)
|
||||
end
|
||||
|
||||
@ -385,7 +385,7 @@ describe Jobs::PullHotlinkedImages do
|
||||
post.reload
|
||||
|
||||
expect(post.raw).to eq(<<~MD.chomp)
|
||||
data:image/s3,"s3://crabby-images/e111a/e111a30ac41b2de68a7dfc0dfba92c073f0a7ad9" alt=""
|
||||
<img src="upload://z2QSs1KJWoj51uYhDjb6ifCzxH6.gif">
|
||||
https://commons.wikimedia.org/wiki/File:Brisbane_May_2013201.jpg
|
||||
<img src='#{broken_image_url}'>
|
||||
<a href='#{url}'><img src='#{large_image_url}'></a>
|
||||
@ -525,7 +525,7 @@ describe Jobs::PullHotlinkedImages do
|
||||
|
||||
post.reload
|
||||
|
||||
expect(post.raw).to eq("data:image/s3,"s3://crabby-images/b3d92/b3d9278a3a2bb8190f68ca4688ad97379cea0257" alt=""")
|
||||
expect(post.raw).to eq("<img src=\"#{Upload.last.short_url}\">")
|
||||
expect(post.uploads.count).to eq(1)
|
||||
end
|
||||
|
||||
|
@ -614,7 +614,7 @@ describe Email::Receiver do
|
||||
expect(post.raw).to eq(<<~MD.chomp)
|
||||
**Before**
|
||||
|
||||
data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt="#{upload.original_filename}|#{upload.width}x#{upload.height}"
|
||||
<img src="#{upload.short_url}" alt="内嵌图片 1">
|
||||
|
||||
*After*
|
||||
MD
|
||||
@ -648,7 +648,7 @@ describe Email::Receiver do
|
||||
<details class='elided'>
|
||||
<summary title='Show trimmed content'>···</summary>
|
||||
|
||||
data:image/s3,"s3://crabby-images/92f90/92f9001cf844c5650bf546ccf4d098d5a269bbe6" alt="logo.png|300x200"
|
||||
<img src="upload://qUm0DGR49PAZshIi7HxMd3cAlzn.png" width="300" height="200">
|
||||
|
||||
</details>
|
||||
MD
|
||||
@ -673,7 +673,7 @@ describe Email::Receiver do
|
||||
expect(post.raw).to eq(<<~MD.chomp)
|
||||
Picture below.
|
||||
|
||||
data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt="#{upload.original_filename}|#{upload.width}x#{upload.height}"
|
||||
<img apple-inline="yes" id="06C04C58-783E-4753-9B6B-D57403903060" src="#{upload.short_url}" class="">
|
||||
|
||||
Picture above.
|
||||
MD
|
||||
|
@ -31,9 +31,9 @@ RSpec.describe InlineUploads, type: :multisite do
|
||||
#{Discourse.base_url}#{upload2.short_path} #{Discourse.base_url}#{upload2.short_path}
|
||||
#{Discourse.base_url}#{upload2.short_path}
|
||||
|
||||
data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt="some image"
|
||||
data:image/s3,"s3://crabby-images/91a23/91a236f38b244292bd620fb06551475d5b2c5560" alt="some image"
|
||||
data:image/s3,"s3://crabby-images/fb013/fb0137e18134bf946a6ed529712adcb483f42495" alt=""
|
||||
<img src="#{upload.short_url}" alt="some image">
|
||||
<img src="#{upload2.short_url}" alt="some image">
|
||||
<img src="#{upload3.short_url}">
|
||||
MD
|
||||
end
|
||||
end
|
||||
|
@ -46,7 +46,7 @@ RSpec.describe InlineUploads do
|
||||
MD
|
||||
|
||||
expect(InlineUploads.process(md)).to eq(<<~MD)
|
||||
data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt=""
|
||||
<img src="#{upload.short_url}">
|
||||
|
||||
This is an invalid `<img ...>` tag
|
||||
MD
|
||||
@ -102,7 +102,7 @@ RSpec.describe InlineUploads do
|
||||
data:image/s3,"s3://crabby-images/fb013/fb0137e18134bf946a6ed529712adcb483f42495" alt=""
|
||||
[/quote]
|
||||
|
||||
data:image/s3,"s3://crabby-images/91a23/91a236f38b244292bd620fb06551475d5b2c5560" alt=""
|
||||
<img src="#{upload2.short_url}">
|
||||
MD
|
||||
end
|
||||
|
||||
@ -173,7 +173,7 @@ RSpec.describe InlineUploads do
|
||||
expect(InlineUploads.process(md)).to eq(<<~MD)
|
||||
[img]http://some.external.img[/img]
|
||||
data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt=""
|
||||
data:image/s3,"s3://crabby-images/fb013/fb0137e18134bf946a6ed529712adcb483f42495" alt=""
|
||||
<img src="#{upload3.short_url}">
|
||||
|
||||
data:image/s3,"s3://crabby-images/91a23/91a236f38b244292bd620fb06551475d5b2c5560" alt=""
|
||||
|
||||
@ -202,7 +202,7 @@ RSpec.describe InlineUploads do
|
||||
|
||||
This is a [link1][1] test [link2][2] something
|
||||
|
||||
data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt=""
|
||||
<img src="#{upload.short_url}">
|
||||
|
||||
[1]: #{Discourse.base_url}#{upload.short_path}
|
||||
[2]: #{Discourse.base_url}#{upload2.short_path}
|
||||
@ -218,7 +218,7 @@ RSpec.describe InlineUploads do
|
||||
|
||||
expect(InlineUploads.process(md)).to eq(<<~MD)
|
||||
data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt=""
|
||||
data:image/s3,"s3://crabby-images/91a23/91a236f38b244292bd620fb06551475d5b2c5560" alt=""
|
||||
<img src="#{upload2.short_url}">
|
||||
[Text|attachment](#{upload3.short_url})
|
||||
MD
|
||||
end
|
||||
@ -237,11 +237,11 @@ RSpec.describe InlineUploads do
|
||||
MD
|
||||
|
||||
expect(InlineUploads.process(md)).to eq(<<~MD)
|
||||
data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt=""
|
||||
<img src="#{upload.short_url}">
|
||||
|
||||
data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt=""
|
||||
<img src="#{upload.short_url}">
|
||||
|
||||
data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt=""
|
||||
<img src="#{upload.short_url}">
|
||||
|
||||
data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt=""
|
||||
|
||||
@ -262,7 +262,7 @@ RSpec.describe InlineUploads do
|
||||
MD
|
||||
|
||||
expect(InlineUploads.process(md)).to eq(<<~MD)
|
||||
data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt=""
|
||||
<img src="#{upload.short_url}">
|
||||
|
||||
data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt=""
|
||||
MD
|
||||
@ -319,7 +319,7 @@ RSpec.describe InlineUploads do
|
||||
MD
|
||||
|
||||
expect(InlineUploads.process(md)).to eq(<<~MD)
|
||||
testdata:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt=""
|
||||
test<img src="#{upload.short_url}">
|
||||
MD
|
||||
end
|
||||
|
||||
@ -371,13 +371,13 @@ RSpec.describe InlineUploads do
|
||||
data:image/s3,"s3://crabby-images/91a23/91a236f38b244292bd620fb06551475d5b2c5560" alt="image"
|
||||
data:image/s3,"s3://crabby-images/fb013/fb0137e18134bf946a6ed529712adcb483f42495" alt="image|100x100"
|
||||
|
||||
data:image/s3,"s3://crabby-images/27afb/27afbf91e912028fabdb7ee17c3a21424dfec525" alt="some image"
|
||||
data:image/s3,"s3://crabby-images/91a23/91a236f38b244292bd620fb06551475d5b2c5560" alt="some image"data:image/s3,"s3://crabby-images/fb013/fb0137e18134bf946a6ed529712adcb483f42495" alt="some image"
|
||||
<img src="#{upload.short_url}" alt="some image" title="some title">
|
||||
<img src="#{upload2.short_url}" alt="some image"><img src="#{upload3.short_url}" alt="some image">
|
||||
|
||||
#{Discourse.base_url}#{upload3.short_path} #{Discourse.base_url}#{upload3.short_path}
|
||||
|
||||
data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt="|5x4"
|
||||
data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt=""
|
||||
<img src="#{upload.short_url}" width="5" height="4">
|
||||
<img src="#{upload.short_url}" width="5px" height="auto">
|
||||
|
||||
`<img src="#{upload.url}" alt="image inside code quotes">`
|
||||
|
||||
@ -421,7 +421,7 @@ RSpec.describe InlineUploads do
|
||||
expect(InlineUploads.process(md)).to eq(<<~MD)
|
||||
<h1></h1>
|
||||
<a href="http://somelink.com">
|
||||
data:image/s3,"s3://crabby-images/91a23/91a236f38b244292bd620fb06551475d5b2c5560" alt="test|500x500"
|
||||
<img src="#{upload2.short_url}" alt="test" width="500" height="500">
|
||||
</a>
|
||||
|
||||
<a href="http://somelink.com">
|
||||
@ -431,7 +431,7 @@ RSpec.describe InlineUploads do
|
||||
|
||||
md = "<h1></h1>\r\n<a href=\"http://somelink.com\">\r\n <img src=\"#{upload.url}\" alt=\"test\" width=\"500\" height=\"500\">\r\n</a>"
|
||||
|
||||
expect(InlineUploads.process(md)).to eq("<h1></h1>\r\n<a href=\"http://somelink.com\">\r\n data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt="test|500x500"\r\n</a>")
|
||||
expect(InlineUploads.process(md)).to eq("<h1></h1>\r\n<a href=\"http://somelink.com\">\r\n <img src=\"#{upload.short_url}\" alt=\"test\" width=\"500\" height=\"500\">\r\n</a>")
|
||||
end
|
||||
|
||||
it "should correctly update image sources within anchor or paragraph tags" do
|
||||
@ -463,28 +463,28 @@ RSpec.describe InlineUploads do
|
||||
|
||||
expect(InlineUploads.process(md)).to eq(<<~MD)
|
||||
<a href="http://somelink.com">
|
||||
data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt="test|500x500"
|
||||
<img src="#{upload.short_url}" alt="test" width="500" height="500">
|
||||
</a>
|
||||
|
||||
<p>
|
||||
data:image/s3,"s3://crabby-images/91a23/91a236f38b244292bd620fb06551475d5b2c5560" alt="test"
|
||||
<img src="#{upload2.short_url}" alt="test">
|
||||
</p>
|
||||
|
||||
<a href="http://somelink.com">data:image/s3,"s3://crabby-images/fb013/fb0137e18134bf946a6ed529712adcb483f42495" alt="test|500x500"</a>
|
||||
<a href="http://somelink.com"><img src="#{upload3.short_url}" alt="test" width="500" height="500"></a>
|
||||
|
||||
<a href="http://somelink.com"> data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt="test|500x500" </a>
|
||||
<a href="http://somelink.com"> <img src="#{upload.short_url}" alt="test" width="500" height="500"> </a>
|
||||
|
||||
<a href="http://somelink.com">
|
||||
|
||||
|
||||
data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt="test|500x500"
|
||||
<img src="#{upload.short_url}" alt="test" width="500" height="500">
|
||||
|
||||
</a>
|
||||
|
||||
<p>Test data:image/s3,"s3://crabby-images/91a23/91a236f38b244292bd620fb06551475d5b2c5560" alt="test|500x500"</p>
|
||||
<p>Test <img src="#{upload2.short_url}" alt="test" width="500" height="500"></p>
|
||||
|
||||
<hr/>
|
||||
data:image/s3,"s3://crabby-images/91a23/91a236f38b244292bd620fb06551475d5b2c5560" alt="test|500x500"
|
||||
<img src="#{upload2.short_url}" alt="test" width="500" height="500">
|
||||
MD
|
||||
end
|
||||
|
||||
@ -508,9 +508,9 @@ RSpec.describe InlineUploads do
|
||||
This is some <img src=" and <a href="
|
||||
```
|
||||
|
||||
data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt="test"
|
||||
<img src="#{upload.short_url}" alt="test">
|
||||
|
||||
data:image/s3,"s3://crabby-images/91a23/91a236f38b244292bd620fb06551475d5b2c5560" alt="test"
|
||||
<img src="#{upload2.short_url}" alt="test" height="150<img">
|
||||
|
||||
> some quote
|
||||
|
||||
@ -671,9 +671,9 @@ RSpec.describe InlineUploads do
|
||||
|
||||
expect(InlineUploads.process(md)).to eq(<<~MD)
|
||||
data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt=""
|
||||
data:image/s3,"s3://crabby-images/654bd/654bd5584197d7a66c82c71204fe0e64f82502cb" alt="some image"
|
||||
testdata:image/s3,"s3://crabby-images/91a23/91a236f38b244292bd620fb06551475d5b2c5560" alt="some image"test
|
||||
data:image/s3,"s3://crabby-images/91a23/91a236f38b244292bd620fb06551475d5b2c5560" alt="some image"
|
||||
<img src="#{upload.short_url}" alt="some image">
|
||||
test<img src="#{upload2.short_url}" alt="some image">test
|
||||
<img src="#{upload2.short_url}" alt="some image">
|
||||
MD
|
||||
end
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user