diff --git a/backend/exceptions/exceptionHandler.py b/backend/exceptions/exceptionHandler.py index 658ca1d5..ab4b4c8c 100644 --- a/backend/exceptions/exceptionHandler.py +++ b/backend/exceptions/exceptionHandler.py @@ -23,7 +23,7 @@ class ExceptionHandler: boolean_error = "Veld moet een Boolse waarde zijn." wrong_email_error = "Verkeerd email adres." not_equal_error = "Waarde komt niet overeen." - inactive_error = "Object is verwijderd." + inactive_error = "Dit is een inactieve versie." vervangen_error = "Kan geen aanpassingen doen aan vervangen template" def __init__(self): diff --git a/backend/planning/views.py b/backend/planning/views.py index 1da17ef1..3f2cdee7 100644 --- a/backend/planning/views.py +++ b/backend/planning/views.py @@ -13,6 +13,7 @@ SuperstudentPermission, StudentPermission, SyndicusPermission, \ BewonerPermission from .util import * +from exceptions.exceptionHandler import ExceptionHandler class StudentDayPlan(generics.RetrieveAPIView): @@ -531,6 +532,11 @@ def delete(self, request, *args, **kwargs): template = StudentTemplate.objects.get(id=kwargs["template_id"]) planning = get_current_week_planning() + handler = ExceptionHandler() + handler.check_vervangen(template) + handler.check_not_inactive(template, "template") + handler.check() + if template.status == Status.EENMALIG: # template was eenmalig dus de originele template moet terug actief gemaakt worden original = StudentTemplate.objects.get( @@ -559,6 +565,9 @@ def patch(self, request, *args, **kwargs): Neemt een copy van de template om de geschiedenis te behouden als dit nodig is. """ template = StudentTemplate.objects.get(id=kwargs["template_id"]) + handler = ExceptionHandler() + handler.check_not_inactive(template, "template") + handler.check() current_year, current_week = get_current_time() data = request.data @@ -620,6 +629,9 @@ def post(self, request, *args, **kwargs): Voegt een nieuwe Ronde toe aan de template. """ template = StudentTemplate.objects.get(id=kwargs["template_id"]) + handler = ExceptionHandler() + handler.check_not_inactive(template, "template") + handler.check() data = request.data current_year, current_week = get_current_time() handler = ExceptionHandler() @@ -666,6 +678,9 @@ def delete(self, request, *args, **kwargs): Verwijderd een ronde en al zijn dagplanningen uit de template. """ template = StudentTemplate.objects.get(id=kwargs["template_id"]) + handler = ExceptionHandler() + handler.check_not_inactive(template, "template") + handler.check() ronde = Ronde.objects.get(id=kwargs["ronde_id"]) current_year, current_week = get_current_time() to_remove = template.dag_planningen.filter(ronde=ronde) @@ -704,6 +719,9 @@ def post(self, request, *args, **kwargs): """ data = request.data template = StudentTemplate.objects.get(id=kwargs["template_id"]) + handler = ExceptionHandler() + handler.check_not_inactive(template, "template") + handler.check() ronde_id = kwargs["ronde_id"] data["ronde"] = ronde_id @@ -738,6 +756,9 @@ def delete(self, request, *args, **kwargs): """ template = StudentTemplate.objects.get(id=kwargs["template_id"]) + handler = ExceptionHandler() + handler.check_not_inactive(template, "template") + handler.check() dag_planning = DagPlanning.objects.get(id=kwargs["dag_id"]) permanent = kwargs["permanent"] response = update( @@ -758,6 +779,10 @@ def put(self, request, *args, **kwargs): def patch(self, request, *args, **kwargs): data = request.data template = StudentTemplate.objects.get(id=kwargs["template_id"]) + handler = ExceptionHandler() + handler.check_not_inactive(template, "template") + handler.check() + dag_planning = DagPlanning.objects.get(id=kwargs["dag_id"]) permanent = kwargs["permanent"] data_copy = dict(data) diff --git a/backend/ronde/views.py b/backend/ronde/views.py index d6a35145..304e06fd 100644 --- a/backend/ronde/views.py +++ b/backend/ronde/views.py @@ -8,7 +8,8 @@ from users.permissions import StudentReadOnly, AdminPermission, \ SuperstudentPermission, SyndicusPermission, AllowAnyReadOnly from trashtemplates.util import update -from planning.util import get_current_week_planning, make_copy +from planning.util import get_current_week_planning, make_copy, get_current_time +from planning.views import get_student_templates from .models import * from .serializers import * @@ -265,22 +266,46 @@ def patch(self, request, *args, **kwargs): old.is_active = False old.save() - student_templates = get_current_week_planning().student_templates + current_year, current_week = get_current_time() + student_templates = get_current_week_planning().student_templates.all() | get_student_templates(current_year, current_week + 1) - template = None - for student_template in student_templates.all(): + for student_template in student_templates: for ronde in student_template.rondes.all(): if ronde.id == id: - template = student_template - - if template is not None: - update( - template, - "rondes", - old, - new_ronde, - True, - student_templates, - copy_template=make_copy - ) + update( + student_template, + "rondes", + old, + new_ronde, + True, + student_templates, + copy_template=make_copy + ) + + return Response({"message": "success"}) + + def delete(self, request, *args, **kwargs): + + id = kwargs["pk"] + old = Ronde.objects.get(id=id) + + old.is_active = False + old.save() + current_year, current_week = get_current_time() + + student_templates = get_current_week_planning().student_templates.all() | get_student_templates(current_year, current_week + 1) + + for student_template in student_templates: + for ronde in student_template.rondes.all(): + if ronde.id == id: + update( + student_template, + "rondes", + old, + None, + True, + get_current_week_planning().student_templates, + copy_template=make_copy + ) + return Response({"message": "success"}) diff --git a/backend/trashtemplates/views.py b/backend/trashtemplates/views.py index 8e66b112..a453f4c7 100644 --- a/backend/trashtemplates/views.py +++ b/backend/trashtemplates/views.py @@ -118,6 +118,12 @@ def delete(self, request, *args, **kwargs): was terug actief gezet worden. """ template = TrashContainerTemplate.objects.get(id=kwargs["template_id"]) + + handler = ExceptionHandler() + handler.check_vervangen(template) + handler.check_not_inactive(template, "template") + handler.check() + current_year, current_week = get_current_time() planning = get_current_week_planning() if template.status == Status.EENMALIG: @@ -161,6 +167,9 @@ def post(self, request, *args, **kwargs): Voegt de nieuwe TrashContainer toe aan de template adhv een TrashContainerIdWrapper. """ template = TrashContainerTemplate.objects.get(id=kwargs["template_id"]) + handler = ExceptionHandler() + handler.check_not_inactive(template, "template") + handler.check() permanent = kwargs["permanent"] data = request.data @@ -201,6 +210,9 @@ def patch(self, request, *args, **kwargs): Neemt een copy van de template om de geschiedenis te behouden als dit nodig is. """ template = TrashContainerTemplate.objects.get(id=kwargs["template_id"]) + handler = ExceptionHandler() + handler.check_not_inactive(template, "template") + handler.check() tc_id_wrapper = template.trash_containers.get(extra_id=kwargs[ "extra_id"]) permanent = kwargs["permanent"] @@ -240,6 +252,9 @@ def delete(self, request, *args, **kwargs): Neemt een copy van de template om de geschiedenis te behouden als dit nodig is. """ template = TrashContainerTemplate.objects.get(id=kwargs["template_id"]) + handler = ExceptionHandler() + handler.check_not_inactive(template, "template") + handler.check() tc_id_wrapper = template.trash_containers.get(extra_id=kwargs[ "extra_id"]) permanent = kwargs["permanent"] @@ -274,8 +289,11 @@ def post(self, request, *args, **kwargs): data = request.data template = TrashContainerTemplate.objects.get(id=kwargs[ "template_id"]) + handler = ExceptionHandler() + handler.check_not_inactive(template, "template") + handler.check() + permanent = kwargs["permanent"] - # checks building = Building.objects.get(id=data["building"]) new_building_list = BuildingTrashContainerList.objects.create( building=building @@ -317,6 +335,9 @@ def delete(self, request, *args, **kwargs): Neemt een copy van de template om de geschiedenis te behouden als dit nodig is. """ template = TrashContainerTemplate.objects.get(id=kwargs["template_id"]) + handler = ExceptionHandler() + handler.check_not_inactive(template, "template") + handler.check() building_list = template.buildings.get(building=kwargs["building_id"]) permanent = kwargs["permanent"] update( @@ -338,6 +359,10 @@ def patch(self, request, *args, **kwargs): """ data = request.data template = TrashContainerTemplate.objects.get(id=kwargs["template_id"]) + handler = ExceptionHandler() + handler.check_not_inactive(template, "template") + handler.check() + building_list = template.buildings.get(building=kwargs["building_id"]) permanent = kwargs["permanent"] new_building_list = make_new_building_list(kwargs["building_id"],