下载添加权限判断
This commit is contained in:
parent
9b3ffc90ba
commit
6d698cb5d8
|
@ -50,19 +50,39 @@ class AttachmentsController < ApplicationController
|
||||||
end
|
end
|
||||||
|
|
||||||
def download
|
def download
|
||||||
if true || @attachment.container.is_a?(Version) || @attachment.container.is_a?(Project)
|
# modify by nwb
|
||||||
@attachment.increment_download
|
# 下载添加权限设置
|
||||||
|
candown = false
|
||||||
|
if @attachment.container.has_attribute?(:project) && @attachment.container.project
|
||||||
|
project = @attachment.container.project
|
||||||
|
candown= User.current.member_of?(project)
|
||||||
|
elsif @attachment.container.is_a?(Project)
|
||||||
|
project = @attachment.container
|
||||||
|
candown= User.current.member_of?(project)
|
||||||
|
elsif @attachment.container.has_attribute?(:course) && @attachment.container.course
|
||||||
|
course = @attachment.container.course
|
||||||
|
candown= User.current.member_of_course?(course)
|
||||||
|
elsif @attachment.container.is_a?(Course)
|
||||||
|
course = @attachment.container
|
||||||
|
candown= User.current.member_of_course?(course)
|
||||||
|
elsif @attachment.container.class.to_s=="HomeworkAttach" && @attachment.container.bid.reward_type == 3
|
||||||
|
candown = true
|
||||||
end
|
end
|
||||||
|
if candown || User.current.admin?
|
||||||
|
@attachment.increment_download
|
||||||
|
else
|
||||||
|
render_403 :message => :notice_not_authorized
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
if stale?(:etag => @attachment.digest)
|
if stale?(:etag => @attachment.digest)
|
||||||
# images are sent inline
|
# images are sent inline
|
||||||
send_file @attachment.diskfile, :filename => filename_for_content_disposition(@attachment.filename),
|
send_file @attachment.diskfile, :filename => filename_for_content_disposition(@attachment.filename),
|
||||||
:type => detect_content_type(@attachment),
|
:type => detect_content_type(@attachment),
|
||||||
:disposition => (@attachment.image? ? 'inline' : 'attachment')
|
:disposition => (@attachment.image? ? 'inline' : 'attachment')
|
||||||
end
|
end
|
||||||
rescue => e
|
rescue => e
|
||||||
redirect_to "http://" + (Setting.host_name.to_s) +"/file_not_found.html"
|
redirect_to "http://" + (Setting.host_name.to_s) +"/file_not_found.html"
|
||||||
return
|
|
||||||
end
|
end
|
||||||
|
|
||||||
#更新资源文件类型
|
#更新资源文件类型
|
||||||
|
|
Loading…
Reference in New Issue