From 48695dadf56f1d5456ba4a893afc685bc3e0ae8c Mon Sep 17 00:00:00 2001 From: Henrik Nygren Date: Fri, 2 Feb 2024 16:00:18 +0200 Subject: [PATCH] Optimize api v8 exercises_controller.rb --- .../api/v8/courses/exercises_controller.rb | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/app/controllers/api/v8/courses/exercises_controller.rb b/app/controllers/api/v8/courses/exercises_controller.rb index 3768f5f77..f4a796055 100644 --- a/app/controllers/api/v8/courses/exercises_controller.rb +++ b/app/controllers/api/v8/courses/exercises_controller.rb @@ -37,7 +37,7 @@ def index can_see_everything = current_user.administrator? || current_user.teacher?(course.organization) || current_user.assistant?(course) authorize! :read, course - exercises = Exercise.includes(:available_points).where(course_id: course.id) + exercises = course.exercises unlocked_exercises = course.unlocks .where(user_id: current_user.id) .where(['valid_after IS NULL OR valid_after < ?', Time.now]) @@ -54,19 +54,25 @@ def index exercises = exercises.pluck(:id) - all_exercises = course.exercises.where(disabled_status: 0) + all_exercises = course.exercises.includes(:available_points).where(disabled_status: 0) unless can_see_everything all_exercises = course.exercises + .includes(:available_points) .where(hidden: false) .select(&:_fast_visible?) end + all_awarded_points = AwardedPoints.course_user_points(course, current_user).includes(:submissions) + presentable = all_exercises.map do |ex| points_visible = ex.points_visible_to?(current_user) + available_points = ex.available_points + available_points_names = available_points.map(&:name) + awarded_points = all_awarded_points.select { |awp| available_points_names.include?(awp.name) }.map(&:name) { id: ex.id, - available_points: points_visible ? ex.available_points : [], - awarded_points: points_visible ? ex.points_for(current_user) : [], + available_points: points_visible ? available_points : [], + awarded_points: points_visible ? awarded_points : [], name: ex.name, publish_time: ex.publish_time, solution_visible_after: ex.solution_visible_after,