class TasksController < ApplicationController before_filter :authenticate, :check_viewability def index redirect_to :action => 'list' end def list @problems = Problem.find_available_problems @user = User.find(session[:user_id]) end def view base_name = params[:file] if !check_user_viewability(base_name) redirect_to :action => 'index' and return end base_filename = File.basename("#{base_name}.#{params[:ext]}") filename = "#{Problem.download_file_basedir}/#{base_filename}" if !check_user_viewability(base_name) or !FileTest.exists?(filename) redirect_to :action => 'index' and return end if defined?(USE_APACHE_XSENDFILE) and USE_APACHE_XSENDFILE response.headers['Content-Type'] = "application/force-download" response.headers['Content-Disposition'] = "attachment; filename=\"#{File.basename(filename)}\"" response.headers["X-Sendfile"] = filename response.headers['Content-length'] = File.size(filename) render :nothing => true else send_file filename, :stream => false, :filename => base_filename end end protected def check_viewability @user = User.find(session[:user_id]) if @user==nil or !Configuration.show_tasks_to?(@user) redirect_to :controller => 'main', :action => 'list' return false end end def check_user_viewability(filename) # individual file access control shall be added here return false if not @user return Configuration.show_tasks_to?(@user) end end