gitlab-org--gitlab-foss/app/controllers/projects/uploads_controller.rb

56 lines
1.3 KiB
Ruby
Raw Normal View History

class Projects::UploadsController < Projects::ApplicationController
2016-03-20 20:03:53 +00:00
skip_before_action :reject_blocked!, :project,
:repository, if: -> { action_name == 'show' && image_or_video? }
2016-03-21 23:09:20 +00:00
before_action :authorize_upload_file!, only: [:create]
2016-03-20 20:03:53 +00:00
2015-02-16 18:58:40 +00:00
def create
2015-02-20 14:56:12 +00:00
link_to_file = ::Projects::UploadService.new(project, params[:file]).
2015-02-16 18:58:40 +00:00
execute
respond_to do |format|
if link_to_file
format.json do
render json: { link: link_to_file }
end
else
format.json do
render json: 'Invalid file.', status: :unprocessable_entity
end
end
end
end
def show
2015-10-09 17:07:29 +00:00
return render_404 if uploader.nil? || !uploader.file.exists?
disposition = uploader.image_or_video? ? 'inline' : 'attachment'
send_file uploader.file.path, disposition: disposition
end
2016-03-20 20:03:53 +00:00
private
2015-04-17 09:33:53 +00:00
def uploader
return @uploader if defined?(@uploader)
namespace = params[:namespace_id]
id = params[:project_id]
2015-02-16 18:58:40 +00:00
file_project = Project.find_by_full_path("#{namespace}/#{id}")
2015-04-17 09:33:53 +00:00
if file_project.nil?
@uploader = nil
2015-04-17 09:33:53 +00:00
return
end
2015-04-17 09:33:53 +00:00
@uploader = FileUploader.new(file_project, params[:secret])
@uploader.retrieve_from_store!(params[:filename])
2015-04-17 09:33:53 +00:00
@uploader
end
def image_or_video?
uploader && uploader.file.exists? && uploader.image_or_video?
end
2015-02-20 13:39:35 +00:00
end