FIX: Never mark uploads based on regular emoji secure (#8973)
Sometimes PullHotlinkedImages pulls down a site emoji and creates a new upload record for it. In the cases where these happen the upload is not created via the normal path that custom emoji follows, so we need to check in UploadSecurity whether the origin of the upload is based on a regular site emoji. If it is we never want to mark it as secure (we don't want emoji not accessible from other posts because of secure media). This only became apparent because the uploads:ensure_correct_acl rake task uses UploadSecurity to check whether an upload should be secure, which would have marked a whole bunch of regular-old-emojis as secure.
This commit is contained in:
parent
3b062f79fc
commit
dac923379a
|
@ -28,7 +28,7 @@ class UploadSecurity
|
||||||
private
|
private
|
||||||
|
|
||||||
def uploading_in_public_context?
|
def uploading_in_public_context?
|
||||||
@upload.for_theme || @upload.for_site_setting || @upload.for_gravatar || public_type? || used_for_custom_emoji?
|
@upload.for_theme || @upload.for_site_setting || @upload.for_gravatar || public_type? || used_for_custom_emoji? || based_on_regular_emoji?
|
||||||
end
|
end
|
||||||
|
|
||||||
def supported_media?
|
def supported_media?
|
||||||
|
@ -72,7 +72,12 @@ class UploadSecurity
|
||||||
end
|
end
|
||||||
|
|
||||||
def used_for_custom_emoji?
|
def used_for_custom_emoji?
|
||||||
return false if @upload.id.blank?
|
@upload.id.present? && CustomEmoji.exists?(upload_id: @upload.id)
|
||||||
CustomEmoji.exists?(upload_id: @upload.id)
|
end
|
||||||
|
|
||||||
|
def based_on_regular_emoji?
|
||||||
|
return false if @upload.origin.blank?
|
||||||
|
uri = URI.parse(@upload.origin)
|
||||||
|
Emoji.all.map(&:url).include?("#{uri.path}?#{uri.query}")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -431,6 +431,14 @@ describe Upload do
|
||||||
|
|
||||||
expect(upload.reload.secure).to eq(false)
|
expect(upload.reload.secure).to eq(false)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it 'does not mark an upload whose origin matches a regular emoji as secure (sometimes emojis are downloaded in pull_hotlinked_images)' do
|
||||||
|
SiteSetting.login_required = true
|
||||||
|
grinning = Emoji.all.last
|
||||||
|
upload.update!(secure: false, origin: "http://localhost:3000#{grinning.url}")
|
||||||
|
expect { upload.update_secure_status }
|
||||||
|
.not_to change { upload.secure }
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue