Prevent accessing another exercise during a programming group session
This commit is contained in:

committed by
Sebastian Serth

parent
01accdae58
commit
3f674d3687
@ -298,6 +298,23 @@ class ExercisesController < ApplicationController
|
||||
private :update_exercise_tips
|
||||
|
||||
def implement
|
||||
if session[:pg_id] && current_contributor.exercise != @exercise
|
||||
# we are acting on behalf of a programming group
|
||||
if current_user.admin?
|
||||
session.delete(:pg_id)
|
||||
@current_contributor = current_user
|
||||
else
|
||||
return redirect_back(
|
||||
fallback_location: implement_exercise_path(current_contributor.exercise),
|
||||
alert: t('exercises.implement.existing_programming_group', exercise: current_contributor.exercise.title)
|
||||
)
|
||||
end
|
||||
elsif session[:pg_id].blank? && (pg = current_user.programming_groups.find_by(exercise: @exercise)) && pg.submissions.where(study_group_id: current_user.current_study_group_id).any?
|
||||
# we are just acting on behalf of a single user who has already worked on this exercise as part of a programming group **in the context of the current study group**
|
||||
session[:pg_id] = pg.id
|
||||
@current_contributor = pg
|
||||
end
|
||||
|
||||
user_solved_exercise = @exercise.solved_by?(current_contributor)
|
||||
count_interventions_today = UserExerciseIntervention.where(user: current_user).where('created_at >= ?',
|
||||
Time.zone.now.beginning_of_day).count
|
||||
|
@ -17,6 +17,7 @@ class SessionsController < ApplicationController
|
||||
end
|
||||
|
||||
def create_through_lti
|
||||
session.delete(:pg_id) # Remove any previous pg_id from the session
|
||||
store_lti_session_data(params)
|
||||
store_nonce(params[:oauth_nonce])
|
||||
if params[:custom_redirect_target]
|
||||
|
@ -465,6 +465,7 @@ de:
|
||||
default_test_feedback: Sehr gut. Alle Tests waren erfolgreich.
|
||||
default_linter_feedback: Sehr gut. Der Linter hat nichts mehr zu beanstanden.
|
||||
error_messages: Fehlermeldungen
|
||||
existing_programming_group: Sie arbeiten gerade an der Übung mit dem Titel '%{exercise}' als Teil einer Programmiergruppe. Bitte schließen Sie Ihre Arbeit dort ab, indem Sie Ihren Code bewerten und abgeben, bevor Sie mit der Bearbeitung dieser Übung beginnen.
|
||||
messages: Meldungen
|
||||
feedback: Feedback
|
||||
test_file: 'Test-Datei <span class="number">%{number}</span> (<span class="filename">%{filename}</span>)'
|
||||
|
@ -465,6 +465,7 @@ en:
|
||||
default_test_feedback: Well done. All tests have been passed.
|
||||
default_linter_feedback: Well done. The linter is completly satisfied.
|
||||
error_messages: Error Messages
|
||||
existing_programming_group: You are currently working on the exercise entitled '%{exercise}' as part of a programming group. Please finish your work there by scoring and submitting your code before you start implementing this exercise.
|
||||
messages: Messages
|
||||
feedback: Feedback
|
||||
test_file: 'Test File <span class="number">%{number}</span> (<span class="filename">%{filename}</span>)'
|
||||
|
Reference in New Issue
Block a user