Description:
fixed submission view bug, reported by chalet git-svn-id: http://theory.cpe.ku.ac.th/grader/web/trunk@292 6386c4cd-e34a-4fa8-8920-d93eb39b512e
Commit status:
[Not Reviewed]
References:
Comments:
0 Commit comments 0 Inline Comments
Unresolved TODOs:
There are no unresolved TODOs
Add another comment

r153:15e1ee6d602b - - 1 file changed: 5 inserted, 0 deleted

@@ -78,96 +78,101
78 78 if @submission.save == false
79 79 flash[:notice] = 'Error saving your submission'
80 80 elsif Task.create(:submission_id => @submission.id,
81 81 :status => Task::STATUS_INQUEUE) == false
82 82 flash[:notice] = 'Error adding your submission to task queue'
83 83 end
84 84 else
85 85 prepare_list_information
86 86 render :action => 'list' and return
87 87 end
88 88 redirect_to :action => 'list'
89 89 end
90 90
91 91 def source
92 92 submission = Submission.find(params[:id])
93 93 if submission.user_id == session[:user_id]
94 94 if submission.problem.output_only
95 95 fname = submission.source_filename
96 96 else
97 97 fname = submission.problem.name + '.' + submission.language.ext
98 98 end
99 99 send_data(submission.source,
100 100 {:filename => fname,
101 101 :type => 'text/plain'})
102 102 else
103 103 flash[:notice] = 'Error viewing source'
104 104 redirect_to :action => 'list'
105 105 end
106 106 end
107 107
108 108 def compiler_msg
109 109 @submission = Submission.find(params[:id])
110 110 if @submission.user_id == session[:user_id]
111 111 render :action => 'compiler_msg', :layout => 'empty'
112 112 else
113 113 flash[:notice] = 'Error viewing source'
114 114 redirect_to :action => 'list'
115 115 end
116 116 end
117 117
118 118 def submission
119 119 @user = User.find(session[:user_id])
120 120 @problems = Problem.find_available_problems
121 121 if params[:id]==nil
122 122 @problem = nil
123 123 @submissions = nil
124 124 else
125 125 @problem = Problem.find_by_name(params[:id])
126 + if not @problem.available
127 + redirect_to :action => 'list'
128 + flash[:notice] = 'Error: submissions for that problem is not available'
129 + return
130 + end
126 131 @submissions = Submission.find_all_by_user_problem(@user.id, @problem.id)
127 132 end
128 133 end
129 134
130 135 def result
131 136 if !Configuration.show_grading_result
132 137 redirect_to :action => 'list' and return
133 138 end
134 139 @user = User.find(session[:user_id])
135 140 @submission = Submission.find(params[:id])
136 141 if @submission.user!=@user
137 142 flash[:notice] = 'You are not allowed to view result of other users.'
138 143 redirect_to :action => 'list' and return
139 144 end
140 145 prepare_grading_result(@submission)
141 146 end
142 147
143 148 def load_output
144 149 if !Configuration.show_grading_result or params[:num]==nil
145 150 redirect_to :action => 'list' and return
146 151 end
147 152 @user = User.find(session[:user_id])
148 153 @submission = Submission.find(params[:id])
149 154 if @submission.user!=@user
150 155 flash[:notice] = 'You are not allowed to view result of other users.'
151 156 redirect_to :action => 'list' and return
152 157 end
153 158 case_num = params[:num].to_i
154 159 out_filename = output_filename(@user.login,
155 160 @submission.problem.name,
156 161 @submission.id,
157 162 case_num)
158 163 if !FileTest.exists?(out_filename)
159 164 flash[:notice] = 'Output not found.'
160 165 redirect_to :action => 'list' and return
161 166 end
162 167
163 168 response.headers['Content-Type'] = "application/force-download"
164 169 response.headers['Content-Disposition'] = "attachment; filename=\"output-#{case_num}.txt\""
165 170 response.headers["X-Sendfile"] = out_filename
166 171 response.headers['Content-length'] = File.size(out_filename)
167 172 render :nothing => true
168 173 end
169 174
170 175 def error
171 176 @user = User.find(session[:user_id])
172 177 end
173 178
You need to be logged in to leave comments. Login now