debian-mirror-gitlab/app/controllers/concerns/send_file_upload.rb

53 lines
2.2 KiB
Ruby
Raw Normal View History

2018-12-05 23:21:45 +05:30
# frozen_string_literal: true
2018-05-09 12:01:36 +05:30
module SendFileUpload
2018-12-13 13:39:08 +05:30
def send_upload(file_upload, send_params: {}, redirect_params: {}, attachment: nil, proxy: false, disposition: 'attachment')
2018-05-09 12:01:36 +05:30
if attachment
2019-03-02 22:35:43 +05:30
response_disposition = ::Gitlab::ContentDisposition.format(disposition: disposition, filename: attachment)
2018-11-20 20:47:30 +05:30
# Response-Content-Type will not override an existing Content-Type in
# Google Cloud Storage, so the metadata needs to be cleared on GCS for
# this to work. However, this override works with AWS.
2019-03-02 22:35:43 +05:30
redirect_params[:query] = { "response-content-disposition" => response_disposition,
2018-11-20 20:47:30 +05:30
"response-content-type" => guess_content_type(attachment) }
2018-11-08 19:23:39 +05:30
# By default, Rails will send uploads with an extension of .js with a
# content-type of text/javascript, which will trigger Rails'
# cross-origin JavaScript protection.
send_params[:content_type] = 'text/plain' if File.extname(attachment) == '.js'
2019-03-02 22:35:43 +05:30
send_params.merge!(filename: attachment, disposition: utf8_encoded_disposition(disposition, attachment))
2018-05-09 12:01:36 +05:30
end
if file_upload.file_storage?
send_file file_upload.path, send_params
2018-12-13 13:39:08 +05:30
elsif file_upload.class.proxy_download_enabled? || proxy
2018-05-09 12:01:36 +05:30
headers.store(*Gitlab::Workhorse.send_url(file_upload.url(**redirect_params)))
head :ok
else
redirect_to file_upload.url(**redirect_params)
end
end
2018-11-20 20:47:30 +05:30
2019-03-02 22:35:43 +05:30
# Since Rails 5 doesn't properly support support non-ASCII filenames,
# we have to add our own to ensure RFC 5987 compliance. However, Rails
# 5 automatically appends `filename#{filename}` here:
# https://github.com/rails/rails/blob/v5.0.7/actionpack/lib/action_controller/metal/data_streaming.rb#L137
# Rails 6 will have https://github.com/rails/rails/pull/33829, so we
# can get rid of this special case handling when we upgrade.
def utf8_encoded_disposition(disposition, filename)
content = ::Gitlab::ContentDisposition.new(disposition: disposition, filename: filename)
"#{disposition}; #{content.utf8_filename}"
end
2018-11-20 20:47:30 +05:30
def guess_content_type(filename)
types = MIME::Types.type_for(filename)
if types.present?
types.first.content_type
else
"application/octet-stream"
end
end
2018-05-09 12:01:36 +05:30
end