]> git.localhorst.tv Git - alttp.git/blobdiff - app/Http/Controllers/ResultController.php
lock rounds
[alttp.git] / app / Http / Controllers / ResultController.php
index 37ebf3b4acc51b995bf47b1f0f4d3686814f29da..d72a10020dbe4b3e4f29cb8a488b808e5b583125 100644 (file)
@@ -14,13 +14,18 @@ class ResultController extends Controller
 
        public function create(Request $request) {
                $validatedData = $request->validate([
+                       'forfeit' => 'boolean',
                        'participant_id' => 'required|exists:App\\Models\\Participant,id',
                        'round_id' => 'required|exists:App\\Models\\Round,id',
-                       'time' => 'required|numeric',
+                       'time' => 'required_if:forfeit,false|numeric',
                ]);
+               error_log(var_export($validatedData, true));
 
                $participant = Participant::findOrFail($validatedData['participant_id']);
                $round = Round::findOrFail($validatedData['round_id']);
+               if (!$round || $round->locked) {
+                       abort(403);
+               }
 
                $user = $request->user();
                if ($user->id != $participant->user->id) {
@@ -31,7 +36,8 @@ class ResultController extends Controller
                        'round_id' => $validatedData['round_id'],
                        'user_id' => $participant->user_id,
                ], [
-                       'time' => $validatedData['time'],
+                       'forfeit' => $validatedData['forfeit'],
+                       'time' => isset($validatedData['time']) ? $validatedData['time'] : 0,
                ]);
 
                Protocol::resultReported(