X-Git-Url: https://git.localhorst.tv/?a=blobdiff_plain;f=app%2FHttp%2FControllers%2FResultController.php;h=d72a10020dbe4b3e4f29cb8a488b808e5b583125;hb=920f11ddfeb2175e4e1556886773dcd044c6085b;hp=37ebf3b4acc51b995bf47b1f0f4d3686814f29da;hpb=d748feb96453d74aeffec648d6f5f68d9ef3b520;p=alttp.git diff --git a/app/Http/Controllers/ResultController.php b/app/Http/Controllers/ResultController.php index 37ebf3b..d72a100 100644 --- a/app/Http/Controllers/ResultController.php +++ b/app/Http/Controllers/ResultController.php @@ -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(