Commit f056c62d authored by Alex Pooley's avatar Alex Pooley Committed by Stan Hu

Leave upload Content-Type unchaged

There are two important changes in this commit.

1. We only run the content type check when the content_type_whitelist
method returns truthy.
2. We don't alter the uploaded file content type as this causes problems
on Google Cloud Storage.
parent d3711900
...@@ -26,14 +26,14 @@ module ContentTypeWhitelist ...@@ -26,14 +26,14 @@ module ContentTypeWhitelist
# Here we override and extend CarrierWave's method that does not parse the # Here we override and extend CarrierWave's method that does not parse the
# magic headers. # magic headers.
def check_content_type_whitelist!(new_file) def check_content_type_whitelist!(new_file)
new_file.content_type = mime_magic_content_type(new_file.path) if content_type_whitelist
content_type = mime_magic_content_type(new_file.path)
if content_type_whitelist && !whitelisted_content_type?(new_file.content_type) unless whitelisted_content_type?(content_type)
message = I18n.translate(:"errors.messages.content_type_whitelist_error", allowed_types: Array(content_type_whitelist).join(", ")) message = I18n.translate(:"errors.messages.content_type_whitelist_error", allowed_types: Array(content_type_whitelist).join(", "))
raise CarrierWave::IntegrityError, message raise CarrierWave::IntegrityError, message
end
end end
super(new_file)
end end
def whitelisted_content_type?(content_type) def whitelisted_content_type?(content_type)
......
---
title: Leave upload Content-Type unchaged
merge_request: 27864
author:
type: fixed
...@@ -26,3 +26,15 @@ shared_examples 'accepted carrierwave upload' do ...@@ -26,3 +26,15 @@ shared_examples 'accepted carrierwave upload' do
expect { uploader.cache!(fixture_file) }.to change { uploader.file }.from(nil).to(kind_of(CarrierWave::SanitizedFile)) expect { uploader.cache!(fixture_file) }.to change { uploader.file }.from(nil).to(kind_of(CarrierWave::SanitizedFile))
end end
end end
# @param path [String] the path to file to upload. E.g. File.join('spec', 'fixtures', 'sanitized.svg')
# @param uploader [CarrierWave::Uploader::Base] uploader to handle the upload.
# @param content_type [String] the upload file content type after cache
shared_examples 'upload with content type' do |content_type|
let(:fixture_file) { fixture_file_upload(path, content_type) }
it 'will not change upload file content type' do
uploader.cache!(fixture_file)
expect(uploader.file.content_type).to eq(content_type)
end
end
...@@ -18,6 +18,7 @@ describe ContentTypeWhitelist do ...@@ -18,6 +18,7 @@ describe ContentTypeWhitelist do
let(:path) { File.join('spec', 'fixtures', 'rails_sample.jpg') } let(:path) { File.join('spec', 'fixtures', 'rails_sample.jpg') }
it_behaves_like 'accepted carrierwave upload' it_behaves_like 'accepted carrierwave upload'
it_behaves_like 'upload with content type', 'image/jpeg'
end end
context 'upload non-whitelisted file content type' do context 'upload non-whitelisted file content type' do
......
...@@ -97,5 +97,12 @@ describe JobArtifactUploader do ...@@ -97,5 +97,12 @@ describe JobArtifactUploader do
it_behaves_like "migrates", to_store: described_class::Store::REMOTE it_behaves_like "migrates", to_store: described_class::Store::REMOTE
it_behaves_like "migrates", from_store: described_class::Store::REMOTE, to_store: described_class::Store::LOCAL it_behaves_like "migrates", from_store: described_class::Store::REMOTE, to_store: described_class::Store::LOCAL
# CI job artifacts usually are shown as text/plain, but they contain
# escape characters so MIME detectors usually fail to determine what
# the Content-Type is.
it 'does not set Content-Type' do
expect(uploader.file.content_type).to be_blank
end
end end
end end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment