bugfixes, policies, errors now have a link to the submissions
This commit is contained in:
@@ -1,28 +1,60 @@
|
||||
class CommentsController < ApplicationController
|
||||
before_action :set_comment, only: [:show, :edit, :update, :destroy_by_id]
|
||||
|
||||
# disable authorization check. TODO: turn this on later.
|
||||
skip_after_action :verify_authorized
|
||||
# to disable authorization check: comment the line below back in
|
||||
# skip_after_action :verify_authorized
|
||||
|
||||
def authorize!
|
||||
authorize(@comment || @comments)
|
||||
end
|
||||
private :authorize!
|
||||
|
||||
# GET /comments
|
||||
# GET /comments.json
|
||||
def index
|
||||
#@comments = Comment.all
|
||||
@comments = Comment.where(file_id: params[:file_id])
|
||||
#if admin, show all comments.
|
||||
#check whether user is the author of the passed file_id, if so, show all comments. otherwise, only show comments of auther and own comments
|
||||
file = CodeOcean::File.find(params[:file_id])
|
||||
submission = Submission.find(file.context_id)
|
||||
|
||||
is_admin = false
|
||||
if current_user.respond_to? :external_id
|
||||
user_id = current_user.external_id
|
||||
else
|
||||
user_id = current_user.id
|
||||
is_admin = current_user.role == 'admin'
|
||||
end
|
||||
|
||||
if(is_admin || user_id == submission.user_id)
|
||||
# fetch all comments for this file
|
||||
@comments = Comment.where(file_id: params[:file_id])
|
||||
else
|
||||
@comments = Comment.where(file_id: params[:file_id], user_id: user_id)
|
||||
end
|
||||
|
||||
#@comments = Comment.where(file_id: params[:file_id])
|
||||
|
||||
#add names to comments
|
||||
@comments.map{|comment| comment.username = Xikolo::UserClient.get(comment.user_id.to_s)[:display_name]}
|
||||
authorize!
|
||||
end
|
||||
|
||||
# GET /comments/1
|
||||
# GET /comments/1.json
|
||||
def show
|
||||
authorize!
|
||||
end
|
||||
|
||||
# GET /comments/new
|
||||
def new
|
||||
@comment = Comment.new
|
||||
authorize!
|
||||
end
|
||||
|
||||
# GET /comments/1/edit
|
||||
def edit
|
||||
authorize!
|
||||
end
|
||||
|
||||
# POST /comments
|
||||
@@ -39,6 +71,7 @@ class CommentsController < ApplicationController
|
||||
format.json { render json: @comment.errors, status: :unprocessable_entity }
|
||||
end
|
||||
end
|
||||
authorize!
|
||||
end
|
||||
|
||||
# PATCH/PUT /comments/1
|
||||
@@ -53,6 +86,7 @@ class CommentsController < ApplicationController
|
||||
format.json { render json: @comment.errors, status: :unprocessable_entity }
|
||||
end
|
||||
end
|
||||
authorize!
|
||||
end
|
||||
|
||||
# DELETE /comments/1
|
||||
@@ -73,6 +107,7 @@ class CommentsController < ApplicationController
|
||||
format.html { head :no_content, notice: 'Comments were successfully destroyed.' }
|
||||
format.json { head :no_content }
|
||||
end
|
||||
authorize!
|
||||
end
|
||||
|
||||
private
|
||||
|
@@ -22,7 +22,7 @@ class ErrorsController < ApplicationController
|
||||
end
|
||||
|
||||
def error_params
|
||||
params[:error].permit(:message).merge(execution_environment_id: @execution_environment.id)
|
||||
params[:error].permit(:message, :submission_id).merge(execution_environment_id: @execution_environment.id)
|
||||
end
|
||||
private :error_params
|
||||
|
||||
|
@@ -3,21 +3,29 @@ class RequestForCommentsController < ApplicationController
|
||||
|
||||
skip_after_action :verify_authorized
|
||||
|
||||
def authorize!
|
||||
authorize(@request_for_comments || @request_for_comment)
|
||||
end
|
||||
private :authorize!
|
||||
|
||||
# GET /request_for_comments
|
||||
# GET /request_for_comments.json
|
||||
def index
|
||||
@request_for_comments = RequestForComment.all
|
||||
# @request_for_comments = RequestForComment.all
|
||||
@request_for_comments = RequestForComment.all.order('created_at DESC').limit(50)
|
||||
authorize!
|
||||
end
|
||||
|
||||
# GET /request_for_comments/1
|
||||
# GET /request_for_comments/1.json
|
||||
def show
|
||||
authorize!
|
||||
end
|
||||
|
||||
# GET /request_for_comments/new
|
||||
def new
|
||||
@request_for_comment = RequestForComment.new
|
||||
authorize!
|
||||
end
|
||||
|
||||
# GET /request_for_comments/1/edit
|
||||
@@ -27,8 +35,30 @@ class RequestForCommentsController < ApplicationController
|
||||
# POST /request_for_comments
|
||||
# POST /request_for_comments.json
|
||||
def create
|
||||
|
||||
file = CodeOcean::File.find(request_for_comment_params[:fileid])
|
||||
|
||||
# get newest version of the file. this method is only called if there is at least one submission (prevented in frontend otherwise)
|
||||
# find newest submission for that exercise and user, use the file with the same filename for that.
|
||||
# this is necessary because the passed params are not up to date since the data attributes are not updated upon submission creation.
|
||||
|
||||
# if we stat from the template, the context type is exercise. we find the newest submission based on the context_id and the current_user.id
|
||||
if(file.context_type =='Exercise')
|
||||
newest_submission = Submission.where(exercise_id: file.context_id, user_id: current_user.id).order('created_at DESC').first
|
||||
else
|
||||
# else we start from a submission. we find it it by the given context_id and retrieve the newest submission with the info of the known submission.
|
||||
submission = Submission.find(file.context_id)
|
||||
newest_submission = Submission.where(exercise_id: submission.exercise_id, user_id: submission.user_id).order('created_at DESC').first
|
||||
end
|
||||
newest_file = CodeOcean::File.where(context_id: newest_submission.id, name: file.name).first
|
||||
|
||||
#finally, correct the fileid and create the request for comment
|
||||
request_for_comment_params[:fileid]=newest_file.id
|
||||
|
||||
@request_for_comment = RequestForComment.new(request_for_comment_params)
|
||||
|
||||
|
||||
|
||||
respond_to do |format|
|
||||
if @request_for_comment.save
|
||||
format.json { render :show, status: :created, location: @request_for_comment }
|
||||
@@ -37,6 +67,7 @@ class RequestForCommentsController < ApplicationController
|
||||
format.json { render json: @request_for_comment.errors, status: :unprocessable_entity }
|
||||
end
|
||||
end
|
||||
authorize!
|
||||
end
|
||||
|
||||
# DELETE /request_for_comments/1
|
||||
@@ -47,6 +78,7 @@ class RequestForCommentsController < ApplicationController
|
||||
format.html { redirect_to request_for_comments_url, notice: 'Request for comment was successfully destroyed.' }
|
||||
format.json { head :no_content }
|
||||
end
|
||||
authorize!
|
||||
end
|
||||
|
||||
private
|
||||
|
Reference in New Issue
Block a user